Merge branch 'master' into threejs-wip
11
.gitignore
vendored
@ -1,2 +1,11 @@
|
||||
output
|
||||
.releasetoken
|
||||
mapserver
|
||||
world.mt
|
||||
output
|
||||
test-output
|
||||
map.sqlite
|
||||
mapserver.tiles
|
||||
mapserver.sqlite
|
||||
mapserver.sqlite-journal
|
||||
mapserver.json
|
||||
debug.txt
|
||||
|
19
.travis.yml
@ -1,11 +1,14 @@
|
||||
sudo: required
|
||||
language: go
|
||||
sudo: false
|
||||
|
||||
services:
|
||||
- docker
|
||||
go:
|
||||
- 1.11.x
|
||||
|
||||
install:
|
||||
- docker build -t thomasrudin-mt/mapserver ./server
|
||||
os:
|
||||
- linux
|
||||
|
||||
deploy:
|
||||
provider: script
|
||||
script: echo
|
||||
script:
|
||||
- go get github.com/mjibson/esc
|
||||
- go generate
|
||||
- go build
|
||||
- go test
|
||||
|
75
Makefile
@ -1,25 +1,78 @@
|
||||
|
||||
STATIC_VFS=vfs/static.go
|
||||
OUT_DIR=output
|
||||
ENV=GO111MODULE=on
|
||||
VERSION=git-$(shell git rev-parse HEAD)
|
||||
|
||||
all: builder_image $(OUT_DIR) $(MOD_ZIP)
|
||||
|
||||
# -ldflags="-X mapserver/app.Version=1.0"
|
||||
GO_LDFLAGS=-ldflags "-linkmode external -extldflags -static -X mapserver/app.Version=$(VERSION)"
|
||||
GO_LDFLAGS_WIN=-ldflags "-X mapserver/app.Version=$(VERSION)"
|
||||
GO_BUILD=CGO_ENABLED=1 go build
|
||||
|
||||
BINARIES = $(OUT_DIR)/mapserver-linux-x86_64
|
||||
BINARIES += $(OUT_DIR)/mapserver-linux-x86
|
||||
BINARIES += $(OUT_DIR)/mapserver-windows-x86.exe
|
||||
BINARIES += $(OUT_DIR)/mapserver-windows-x86-64.exe
|
||||
BINARIES += $(OUT_DIR)/mapserver-linux-arm
|
||||
|
||||
|
||||
all: $(STATIC_VFS)
|
||||
go build
|
||||
|
||||
$(OUT_DIR):
|
||||
mkdir $@
|
||||
|
||||
fmt:
|
||||
go fmt ./...
|
||||
|
||||
test: $(OUT_DIR)
|
||||
go generate
|
||||
go build
|
||||
go vet ./...
|
||||
$(ENV) go test ./...
|
||||
|
||||
clean:
|
||||
rm -rf $(STATIC_VFS) test-output
|
||||
rm -rf $(OUT_DIR)
|
||||
|
||||
jshint:
|
||||
jshint static/js/*.js static/js/util static/js/overlays static/js/search
|
||||
|
||||
$(STATIC_VFS):
|
||||
go generate
|
||||
|
||||
$(OUT_DIR)/mapserver-linux-x86_64: $(OUT_DIR)
|
||||
# native (linux x86_64)
|
||||
GOOS=linux GOARCH=amd64 CC=x86_64-linux-gnu-gcc $(GO_BUILD) $(GO_LDFLAGS) -o $@
|
||||
|
||||
$(OUT_DIR)/mapserver-linux-x86: $(OUT_DIR)
|
||||
# apt install gcc-8-i686-linux-gnu
|
||||
GOOS=linux GOARCH=386 CC=i686-linux-gnu-gcc-7 $(GO_BUILD) $(GO_LDFLAGS) -o $@
|
||||
|
||||
$(OUT_DIR)/mapserver-windows-x86.exe: $(OUT_DIR)
|
||||
# apt install gcc-mingw-w64
|
||||
GOARCH=386 GOOS=windows CC=i686-w64-mingw32-gcc $(GO_BUILD) $(GO_LDFLAGS_WIN) -o $@
|
||||
|
||||
$(OUT_DIR)/mapserver-windows-x86-64.exe: $(OUT_DIR)
|
||||
GOARCH=amd64 GOOS=windows CC=x86_64-w64-mingw32-gcc $(GO_BUILD) $(GO_LDFLAGS_WIN) -o $@
|
||||
|
||||
$(OUT_DIR)/mapserver-linux-arm: $(OUT_DIR)
|
||||
# apt install gcc-5-arm-linux-gnueabihf
|
||||
GOARCH=arm GOARM=7 CC=arm-linux-gnueabihf-gcc-5 $(GO_BUILD) $(GO_LDFLAGS) -o $@
|
||||
|
||||
|
||||
release: builder_image $(OUT_DIR) $(MOD_ZIP)
|
||||
# build all with the docker image
|
||||
sudo docker run --rm -it\
|
||||
-v $(shell pwd)/server/:/app\
|
||||
-v $(shell pwd):/app\
|
||||
-v mapserver-volume:/root/go\
|
||||
-w /app\
|
||||
mapserver-builder\
|
||||
make test jshint all VERSION=$(VERSION)
|
||||
make test jshint release-all VERSION=$(VERSION)
|
||||
# copy generated files to output dir
|
||||
cp server/output/* $(OUT_DIR)/
|
||||
|
||||
builder_image:
|
||||
# build the docker image with all dependencies
|
||||
$(MAKE) -C docker_builder build
|
||||
|
||||
$(OUT_DIR):
|
||||
mkdir $@
|
||||
|
||||
clean:
|
||||
rm -rf $(OUT_DIR)
|
||||
$(MAKE) -C server clean
|
||||
release-all: $(STATIC_VFS) $(BINARIES)
|
||||
|
@ -1,6 +1,7 @@
|
||||
package app
|
||||
|
||||
import (
|
||||
"mapserver/blockaccessor"
|
||||
"mapserver/colormapping"
|
||||
"mapserver/db"
|
||||
"mapserver/eventbus"
|
||||
@ -23,10 +24,13 @@ type App struct {
|
||||
TileDB *tiledb.TileDB
|
||||
Settings settings.Settings
|
||||
|
||||
BlockAccessor *mapblockaccessor.MapBlockAccessor
|
||||
MapBlockAccessor *mapblockaccessor.MapBlockAccessor
|
||||
BlockAccessor *blockaccessor.BlockAccessor
|
||||
Colormapping *colormapping.ColorMapping
|
||||
Mapblockrenderer *mapblockrenderer.MapBlockRenderer
|
||||
Tilerenderer *tilerenderer.TileRenderer
|
||||
|
||||
MediaRepo map[string][]byte
|
||||
|
||||
WebEventbus *eventbus.Eventbus
|
||||
}
|
@ -17,6 +17,7 @@ type Config struct {
|
||||
EnableSearch bool `json:"enablesearch"`
|
||||
EnableInitialRendering bool `json:"enableinitialrendering"`
|
||||
EnableTransparency bool `json:"enabletransparency"`
|
||||
EnableMediaRepository bool `json:"enablemediarepository"`
|
||||
Webdev bool `json:"webdev"`
|
||||
WebApi *WebApiConfig `json:"webapi"`
|
||||
Layers []*layer.Layer `json:"layers"`
|
||||
@ -60,7 +61,9 @@ type MapObjectConfig struct {
|
||||
Fancyvend bool `json:"fancyvend"`
|
||||
ATM bool `json:"atm"`
|
||||
Train bool `json:"train"`
|
||||
TrainSignal bool `json:"trainsignal"`
|
||||
Minecart bool `json:"minecart"`
|
||||
Locator bool `json:"locator"`
|
||||
}
|
||||
|
||||
type WebApiConfig struct {
|
||||
@ -137,9 +140,9 @@ func ParseConfig(filename string) (*Config, error) {
|
||||
Travelnet: true,
|
||||
MapserverPlayer: true,
|
||||
MapserverPOI: true,
|
||||
MapserverLabel: false,
|
||||
MapserverLabel: true,
|
||||
MapserverTrainline: true,
|
||||
MapserverBorder: false,
|
||||
MapserverBorder: true,
|
||||
TileServerLegacy: true,
|
||||
Mission: true,
|
||||
Jumpdrive: true,
|
||||
@ -147,13 +150,15 @@ func ParseConfig(filename string) (*Config, error) {
|
||||
Fancyvend: true,
|
||||
ATM: true,
|
||||
Train: true,
|
||||
TrainSignal: true,
|
||||
Minecart: false,
|
||||
Locator: false,
|
||||
}
|
||||
|
||||
mapblockaccessor := MapBlockAccessorConfig{
|
||||
Expiretime: "15s",
|
||||
Purgetime: "30s",
|
||||
MaxItems: 5000,
|
||||
MaxItems: 500,
|
||||
}
|
||||
|
||||
defaultoverlays := []string{
|
||||
@ -170,6 +175,7 @@ func ParseConfig(filename string) (*Config, error) {
|
||||
EnableSearch: true,
|
||||
EnableInitialRendering: true,
|
||||
EnableTransparency: false,
|
||||
EnableMediaRepository: false,
|
||||
Webdev: false,
|
||||
WebApi: &webapi,
|
||||
Layers: layers,
|
@ -1,6 +1,7 @@
|
||||
package app
|
||||
|
||||
import (
|
||||
"mapserver/blockaccessor"
|
||||
"mapserver/colormapping"
|
||||
"mapserver/db/postgres"
|
||||
"mapserver/db/sqlite"
|
||||
@ -9,6 +10,7 @@ import (
|
||||
"mapserver/mapblockrenderer"
|
||||
postgresobjdb "mapserver/mapobjectdb/postgres"
|
||||
sqliteobjdb "mapserver/mapobjectdb/sqlite"
|
||||
"mapserver/media"
|
||||
"mapserver/params"
|
||||
"mapserver/settings"
|
||||
"mapserver/tiledb"
|
||||
@ -70,20 +72,32 @@ func Setup(p params.ParamsType, cfg *Config) *App {
|
||||
panic(err)
|
||||
}
|
||||
|
||||
a.BlockAccessor = mapblockaccessor.NewMapBlockAccessor(
|
||||
// mapblock accessor
|
||||
a.MapBlockAccessor = mapblockaccessor.NewMapBlockAccessor(
|
||||
a.Blockdb,
|
||||
expireDuration, purgeDuration,
|
||||
cfg.MapBlockAccessorCfg.MaxItems)
|
||||
|
||||
// block accessor
|
||||
a.BlockAccessor = blockaccessor.New(a.MapBlockAccessor)
|
||||
|
||||
//color mapping
|
||||
a.Colormapping = colormapping.NewColorMapping()
|
||||
|
||||
//load default colors
|
||||
count, err := a.Colormapping.LoadVFSColors(false, "/colors.txt")
|
||||
if err != nil {
|
||||
panic(err)
|
||||
colorfiles := []string{
|
||||
//https://daconcepts.com/vanessa/hobbies/minetest/colors.txt
|
||||
"/colors/custom.txt",
|
||||
"/colors/vanessa.txt",
|
||||
"/colors/advtrains.txt",
|
||||
"/colors/scifi_nodes.txt",
|
||||
}
|
||||
|
||||
for _, colorfile := range colorfiles {
|
||||
_, err := a.Colormapping.LoadVFSColors(false, colorfile)
|
||||
if err != nil {
|
||||
panic(err.Error() + " file:" + colorfile)
|
||||
}
|
||||
}
|
||||
logrus.WithFields(logrus.Fields{"count": count}).Info("Loaded default colors")
|
||||
|
||||
//load provided colors, if available
|
||||
info, err := os.Stat("colors.txt")
|
||||
@ -95,7 +109,7 @@ func Setup(p params.ParamsType, cfg *Config) *App {
|
||||
panic(err)
|
||||
}
|
||||
|
||||
count, err = a.Colormapping.LoadBytes(data)
|
||||
count, err := a.Colormapping.LoadBytes(data)
|
||||
if err != nil {
|
||||
panic(err)
|
||||
}
|
||||
@ -105,7 +119,7 @@ func Setup(p params.ParamsType, cfg *Config) *App {
|
||||
}
|
||||
|
||||
//mapblock renderer
|
||||
a.Mapblockrenderer = mapblockrenderer.NewMapBlockRenderer(a.BlockAccessor, a.Colormapping)
|
||||
a.Mapblockrenderer = mapblockrenderer.NewMapBlockRenderer(a.MapBlockAccessor, a.Colormapping)
|
||||
|
||||
//mapserver database
|
||||
if a.Worldconfig[worldconfig.CONFIG_PSQL_MAPSERVER] != "" {
|
||||
@ -143,5 +157,19 @@ func Setup(p params.ParamsType, cfg *Config) *App {
|
||||
a.Config.Layers,
|
||||
)
|
||||
|
||||
//create media repo
|
||||
repo := make(map[string][]byte)
|
||||
|
||||
if a.Config.EnableMediaRepository {
|
||||
mediasize, _ := media.ScanDir(repo, ".", []string{"mapserver.tiles", ".git"})
|
||||
fields := logrus.Fields{
|
||||
"count": len(repo),
|
||||
"bytes": mediasize,
|
||||
}
|
||||
logrus.WithFields(fields).Info("Created media repository")
|
||||
}
|
||||
|
||||
a.MediaRepo = repo
|
||||
|
||||
return &a
|
||||
}
|
43
blockaccessor/blockaccessor.go
Normal file
@ -0,0 +1,43 @@
|
||||
package blockaccessor
|
||||
|
||||
import (
|
||||
"mapserver/coords"
|
||||
"mapserver/mapblockaccessor"
|
||||
)
|
||||
|
||||
func New(mba *mapblockaccessor.MapBlockAccessor) *BlockAccessor {
|
||||
return &BlockAccessor{mba: mba}
|
||||
}
|
||||
|
||||
type BlockAccessor struct {
|
||||
mba *mapblockaccessor.MapBlockAccessor
|
||||
}
|
||||
|
||||
type Block struct {
|
||||
Name string
|
||||
//TODO: param1, param2
|
||||
}
|
||||
|
||||
func (this *BlockAccessor) GetBlock(x, y, z int) (*Block, error) {
|
||||
|
||||
mbc := coords.NewMapBlockCoordsFromBlock(x, y, z)
|
||||
mapblock, err := this.mba.GetMapBlock(mbc)
|
||||
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
if mapblock == nil {
|
||||
return nil, nil
|
||||
}
|
||||
|
||||
relx := x % 16
|
||||
rely := y % 16
|
||||
relz := z % 16
|
||||
|
||||
block := Block{
|
||||
Name: mapblock.GetNodeName(relx, rely, relz),
|
||||
}
|
||||
|
||||
return &block, nil
|
||||
}
|
59
blockaccessor/blockaccessor_test.go
Normal file
@ -0,0 +1,59 @@
|
||||
package blockaccessor
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
"io/ioutil"
|
||||
"mapserver/db/sqlite"
|
||||
"mapserver/mapblockaccessor"
|
||||
"mapserver/testutils"
|
||||
"os"
|
||||
"testing"
|
||||
"time"
|
||||
|
||||
"github.com/sirupsen/logrus"
|
||||
)
|
||||
|
||||
func TestSimpleAccess(t *testing.T) {
|
||||
logrus.SetLevel(logrus.DebugLevel)
|
||||
|
||||
tmpfile, err := ioutil.TempFile("", "TestMigrate.*.sqlite")
|
||||
if err != nil {
|
||||
panic(err)
|
||||
}
|
||||
defer os.Remove(tmpfile.Name())
|
||||
testutils.CreateTestDatabase(tmpfile.Name())
|
||||
|
||||
a, err := sqlite.New(tmpfile.Name())
|
||||
if err != nil {
|
||||
panic(err)
|
||||
}
|
||||
|
||||
err = a.Migrate()
|
||||
if err != nil {
|
||||
panic(err)
|
||||
}
|
||||
|
||||
mba := mapblockaccessor.NewMapBlockAccessor(a, 500*time.Millisecond, 1000*time.Millisecond, 1000)
|
||||
|
||||
if mba == nil {
|
||||
t.Fatal("Mapblockaccessor is nil")
|
||||
}
|
||||
|
||||
ba := New(mba)
|
||||
|
||||
if ba == nil {
|
||||
t.Fatal("blockaccessor is nil")
|
||||
}
|
||||
|
||||
block, err := ba.GetBlock(0, 2, 0)
|
||||
|
||||
if err != nil {
|
||||
panic(err)
|
||||
}
|
||||
|
||||
if block == nil {
|
||||
t.Fatal("block is nil")
|
||||
}
|
||||
|
||||
fmt.Println(block.Name)
|
||||
}
|
@ -14,9 +14,17 @@ import (
|
||||
|
||||
type ColorMapping struct {
|
||||
colors map[string]*color.RGBA
|
||||
extendedpaletteblock map[string]bool
|
||||
extendedpalette *Palette
|
||||
}
|
||||
|
||||
func (m *ColorMapping) GetColor(name string) *color.RGBA {
|
||||
func (m *ColorMapping) GetColor(name string, param2 int) *color.RGBA {
|
||||
//TODO: list of node->palette
|
||||
if m.extendedpaletteblock[name] {
|
||||
// param2 coloring
|
||||
return m.extendedpalette.GetColor(param2)
|
||||
}
|
||||
|
||||
return m.colors[name]
|
||||
}
|
||||
|
||||
@ -86,18 +94,46 @@ func (m *ColorMapping) LoadBytes(buffer []byte) (int, error) {
|
||||
}
|
||||
|
||||
func (m *ColorMapping) LoadVFSColors(useLocal bool, filename string) (int, error) {
|
||||
buffer, err := vfs.FSByte(useLocal, "/colors.txt")
|
||||
buffer, err := vfs.FSByte(useLocal, filename)
|
||||
if err != nil {
|
||||
return 0, err
|
||||
}
|
||||
|
||||
log.WithFields(logrus.Fields{"size": len(buffer),
|
||||
"filename": filename,
|
||||
"useLocal": useLocal}).Info("Loading default colors")
|
||||
"useLocal": useLocal}).Info("Loading colors")
|
||||
|
||||
return m.LoadBytes(buffer)
|
||||
}
|
||||
|
||||
func NewColorMapping() *ColorMapping {
|
||||
return &ColorMapping{colors: make(map[string]*color.RGBA)}
|
||||
extendedpalette, err := NewPalette(vfs.FSMustByte(false, "/pics/unifieddyes_palette_extended.png"))
|
||||
|
||||
if err != nil {
|
||||
panic(err)
|
||||
}
|
||||
|
||||
scanner := bufio.NewScanner(bytes.NewReader(vfs.FSMustByte(false, "/extended_palette.txt")))
|
||||
extendedpaletteblock := make(map[string]bool)
|
||||
|
||||
if err != nil {
|
||||
panic(err)
|
||||
}
|
||||
|
||||
for scanner.Scan() {
|
||||
txt := strings.Trim(scanner.Text(), " ")
|
||||
|
||||
if len(txt) == 0 {
|
||||
//empty
|
||||
continue
|
||||
}
|
||||
|
||||
extendedpaletteblock[txt] = true
|
||||
}
|
||||
|
||||
return &ColorMapping{
|
||||
colors: make(map[string]*color.RGBA),
|
||||
extendedpaletteblock: extendedpaletteblock,
|
||||
extendedpalette: extendedpalette,
|
||||
}
|
||||
}
|
38
colormapping/colormapping_test.go
Normal file
@ -0,0 +1,38 @@
|
||||
package colormapping
|
||||
|
||||
import (
|
||||
"testing"
|
||||
)
|
||||
|
||||
func TestNewMapping(t *testing.T) {
|
||||
m := NewColorMapping()
|
||||
_, err := m.LoadVFSColors(false, "/colors/vanessa.txt")
|
||||
if err != nil {
|
||||
t.Fatal(err)
|
||||
}
|
||||
|
||||
_, err = m.LoadVFSColors(false, "/colors/scifi_nodes.txt")
|
||||
if err != nil {
|
||||
t.Fatal(err)
|
||||
}
|
||||
|
||||
c := m.GetColor("scifi_nodes:blacktile2", 0)
|
||||
if c == nil {
|
||||
panic("no color")
|
||||
}
|
||||
|
||||
c = m.GetColor("default:river_water_flowing", 0)
|
||||
if c == nil {
|
||||
panic("no color")
|
||||
}
|
||||
|
||||
c = m.GetColor("unifiedbricks:brickblock_multicolor_dark", 100)
|
||||
if c == nil {
|
||||
panic("no color")
|
||||
}
|
||||
|
||||
//if c.A != 128 {
|
||||
// panic("wrong alpha")
|
||||
//}
|
||||
|
||||
}
|
45
colormapping/palette.go
Normal file
@ -0,0 +1,45 @@
|
||||
package colormapping
|
||||
|
||||
import (
|
||||
"bytes"
|
||||
"image/color"
|
||||
"image/png"
|
||||
)
|
||||
|
||||
type Palette struct {
|
||||
colors map[int]*color.RGBA
|
||||
}
|
||||
|
||||
func NewPalette(imagefile []byte) (*Palette, error) {
|
||||
palette := &Palette{
|
||||
colors: make(map[int]*color.RGBA),
|
||||
}
|
||||
|
||||
reader := bytes.NewReader(imagefile)
|
||||
img, err := png.Decode(reader)
|
||||
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
bounds := img.Bounds()
|
||||
|
||||
index := 0
|
||||
for y := bounds.Min.Y; y < bounds.Max.Y; y++ {
|
||||
for x := bounds.Min.X; x < bounds.Max.X; x++ {
|
||||
c := img.At(x, y)
|
||||
r, g, b, a := c.RGBA()
|
||||
|
||||
//fmt.Println("x ", x, " y ", y, " Index: ", index, " Color ", c)
|
||||
palette.colors[index] = &color.RGBA{uint8(r), uint8(g), uint8(b), uint8(a)}
|
||||
|
||||
index++
|
||||
}
|
||||
}
|
||||
|
||||
return palette, nil
|
||||
}
|
||||
|
||||
func (m *Palette) GetColor(param2 int) *color.RGBA {
|
||||
return m.colors[param2]
|
||||
}
|
30
colormapping/palette_test.go
Normal file
@ -0,0 +1,30 @@
|
||||
package colormapping
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
"io/ioutil"
|
||||
"testing"
|
||||
)
|
||||
|
||||
func TestNewPalette(t *testing.T) {
|
||||
data, err := ioutil.ReadFile("./testdata/unifieddyes_palette_extended.png")
|
||||
|
||||
if err != nil {
|
||||
t.Fatal(err)
|
||||
}
|
||||
|
||||
palette, err := NewPalette(data)
|
||||
|
||||
if err != nil {
|
||||
t.Fatal(err)
|
||||
}
|
||||
|
||||
color := palette.GetColor(0)
|
||||
|
||||
if color == nil {
|
||||
t.Fatal("color not found!")
|
||||
}
|
||||
|
||||
fmt.Println(color)
|
||||
|
||||
}
|
BIN
colormapping/testdata/unifieddyes_palette_extended.png
vendored
Normal file
After Width: | Height: | Size: 290 B |
@ -1,5 +1,9 @@
|
||||
package coords
|
||||
|
||||
import (
|
||||
"math"
|
||||
)
|
||||
|
||||
type MapBlockCoords struct {
|
||||
X int `json:"x"`
|
||||
Y int `json:"y"`
|
||||
@ -10,6 +14,14 @@ func NewMapBlockCoords(x, y, z int) *MapBlockCoords {
|
||||
return &MapBlockCoords{X: x, Y: y, Z: z}
|
||||
}
|
||||
|
||||
func NewMapBlockCoordsFromBlock(x, y, z int) *MapBlockCoords {
|
||||
return &MapBlockCoords{
|
||||
X: int(math.Floor(float64(x) / 16)),
|
||||
Y: int(math.Floor(float64(y) / 16)),
|
||||
Z: int(math.Floor(float64(z) / 16)),
|
||||
}
|
||||
}
|
||||
|
||||
type MapBlockRange struct {
|
||||
Pos1, Pos2 *MapBlockCoords
|
||||
}
|
26
coords/mapblockcoords_test.go
Normal file
@ -0,0 +1,26 @@
|
||||
package coords
|
||||
|
||||
import (
|
||||
"testing"
|
||||
)
|
||||
|
||||
func TestNewMapBlockCoordsFromBlock(t *testing.T) {
|
||||
c := NewMapBlockCoordsFromBlock(1, 1, 1)
|
||||
|
||||
if c.X != 0 || c.Y != 0 || c.Z != 0 {
|
||||
t.Fatal("mismatch", c)
|
||||
}
|
||||
|
||||
c = NewMapBlockCoordsFromBlock(16, 1, 1)
|
||||
|
||||
if c.X != 1 || c.Y != 0 || c.Z != 0 {
|
||||
t.Fatal("mismatch", c)
|
||||
}
|
||||
|
||||
c = NewMapBlockCoordsFromBlock(16, 1, -1)
|
||||
|
||||
if c.X != 1 || c.Y != 0 || c.Z != -1 {
|
||||
t.Fatal("mismatch", c)
|
||||
}
|
||||
|
||||
}
|
24
doc/building.md
Normal file
@ -0,0 +1,24 @@
|
||||
|
||||
# Building the mapserver
|
||||
|
||||
Instructions to build the mapserver from source
|
||||
|
||||
## Build dependencies
|
||||
|
||||
* go >= 1.11
|
||||
|
||||
Ubuntu install: https://github.com/golang/go/wiki/Ubuntu
|
||||
|
||||
## Compile
|
||||
|
||||
```bash
|
||||
# generate the static web files
|
||||
go generate
|
||||
|
||||
# build the binary for the current playtform
|
||||
go build
|
||||
|
||||
# (optionally) run the unit-tests
|
||||
go test ./...
|
||||
|
||||
```
|
@ -1,6 +1,31 @@
|
||||
|
||||
# Changelog
|
||||
|
||||
## Next
|
||||
|
||||
* Train overlay decluttering
|
||||
|
||||
## 3.0.0
|
||||
|
||||
* Javascript ES6 frontend
|
||||
* Param2 coloring
|
||||
* More player infos (RTT)
|
||||
* Search ability for LCD displays
|
||||
* City border support
|
||||
* Label support (street, city names, regions)
|
||||
* Various bugfixes
|
||||
|
||||
## 2.2.0
|
||||
|
||||
* Added ATM overlay
|
||||
* Added locator overlay
|
||||
* Add ability for bone-owner search
|
||||
* Separate mapserver_mod into own repository
|
||||
|
||||
## 2.1.1
|
||||
|
||||
* force tcp v4 for listener
|
||||
|
||||
## 2.1.0
|
||||
|
||||
* Added search bar
|
||||
|
@ -3,7 +3,7 @@
|
||||
|
||||
**Please make a backup of your world in case something goes wrong**
|
||||
|
||||
* Download the binary from the [releases](https://github.com/thomasrudin-mt/mapserver/releases) for your architecture and platform
|
||||
* Download the binary from the [releases](https://github.com/minetest-tools/mapserver/releases) for your architecture and platform
|
||||
* Drop the binary into your world folder (the one with the `world.mt` and `map.sqlite` files)
|
||||
* Start the mapserver via command-line: `./mapserver` or `./mapserver.exe`
|
||||
* Point your browser to `http://127.0.0.1:8080`
|
||||
|
@ -11,31 +11,31 @@
|
||||
* sam.png
|
||||
* heart.png
|
||||
* default_tool_mesepick.png
|
||||
** License: CC BY-SA 3.0
|
||||
** Source: [minetest_game](https://github.com/minetest/minetest_game)
|
||||
* License: CC BY-SA 3.0
|
||||
* Source: [minetest_game](https://github.com/minetest/minetest_game)
|
||||
|
||||
* travelnet_inv.png
|
||||
** License: CC BY-SA 3.0
|
||||
** Source: [travelnet](https://github.com/Sokomine/travelnet)
|
||||
* License: CC BY-SA 3.0
|
||||
* Source: [travelnet](https://github.com/Sokomine/travelnet)
|
||||
|
||||
* technic_admin_anchor.png
|
||||
* technic_hv_nuclear_reactor_core.png
|
||||
* technic_water_mill_top_active.png
|
||||
** LGPL, V2
|
||||
** Source: [technic](https://github.com/minetest-mods/technic)
|
||||
* LGPL, V2
|
||||
* Source: [technic](https://github.com/minetest-mods/technic)
|
||||
|
||||
* lcd_lcd.png
|
||||
** WTFPL
|
||||
** Source: [digilines](https://github.com/minetest-mods/digilines)
|
||||
* WTFPL
|
||||
* Source: [digilines](https://github.com/minetest-mods/digilines)
|
||||
|
||||
* jeija_luacontroller_top.png
|
||||
* jeija_luacontroller_burnt_top.png
|
||||
** CC-BY-SA-3.0
|
||||
** Source [mesecons](https://github.com/minetest-mods/mesecons)
|
||||
* CC-BY-SA-3.0
|
||||
* Source [mesecons](https://github.com/minetest-mods/mesecons)
|
||||
|
||||
* digiterms_beige_front.png
|
||||
** License: CC BY-SA 3.0
|
||||
** Source [digiterms](https://github.com/Pyrollo/digiterms)
|
||||
* License: CC BY-SA 3.0
|
||||
* Source [digiterms](https://github.com/Pyrollo/digiterms)
|
||||
|
||||
|
||||
* advtrains_detailed_engine_steam_inv.png
|
||||
@ -48,13 +48,27 @@
|
||||
* advtrains_wagon_japan_inv.png
|
||||
* advtrains_wagon_tank_inv.png
|
||||
* advtrains_wagon_wood_inv.png
|
||||
** License: CC BY-SA 3.0
|
||||
** Source [advtrains](http://advtrains.bleipb.de/)
|
||||
* advtrains_signal_on.png
|
||||
* advtrains_signal_off.png
|
||||
* License: CC BY-SA 3.0
|
||||
* Source [advtrains](http://advtrains.bleipb.de/)
|
||||
|
||||
* minecart_logo.png
|
||||
** License: CC0
|
||||
** Source [minecart](https://github.com/joe7575/minecart)
|
||||
* License: CC0
|
||||
* Source [minecart](https://github.com/joe7575/minecart)
|
||||
|
||||
* mapserver_gold_block.png
|
||||
** License: CC BY-SA 3.0
|
||||
** Source [minetest_game](https://github.com/minetest/minetest_game)
|
||||
* License: CC BY-SA 3.0
|
||||
* Source [minetest_game](https://github.com/minetest/minetest_game)
|
||||
|
||||
* atm_front_wt.png
|
||||
* atm_front.png
|
||||
* atm2_front.png
|
||||
* atm3_front.png
|
||||
* WTFPL
|
||||
* Source: http://git.gpcf.eu/?p=atm.git;a=summary
|
||||
|
||||
|
||||
* unifieddyes_palette_extended.png
|
||||
* GPL 2.0
|
||||
* Source: https://gitlab.com/VanessaE/unifieddyes
|
||||
|
12
doc/mod.md
@ -1,7 +1,7 @@
|
||||
|
||||
# Mapserver mod
|
||||
|
||||
* Repository: https://github.com/thomasrudin/mapserver_mod
|
||||
* Repository: https://github.com/minetest-tools/mapserver_mod
|
||||
|
||||
If the `mapserver-mod` is installed and configured
|
||||
you get more realtime-data from within your minetest-world:
|
||||
@ -15,8 +15,7 @@ You can use the `mapserver-mod` either passive or active:
|
||||
|
||||
## Installing and configuring the bridge-mod
|
||||
|
||||
The mod itself is available in the git [repo](../mapserver_mod)
|
||||
or as a zip package in the [releases](../../../releases)
|
||||
Download or clone from https://github.com/minetest-tools/mapserver_mod
|
||||
|
||||
If you want to enable craftable mapobjects (poi, labels, trainblocks, etc) you
|
||||
can enable the setting in your `minetest.conf` (defaults to false)
|
||||
@ -25,6 +24,13 @@ can enable the setting in your `minetest.conf` (defaults to false)
|
||||
mapserver.enable_crafting = true
|
||||
```
|
||||
|
||||
The update interval of the players on the map can be changed with:
|
||||
```
|
||||
mapserver.send_interval = 1
|
||||
```
|
||||
|
||||
Default is `2`, means that the player, time and lag info get sent every 2 seconds.
|
||||
|
||||
## Passive mode
|
||||
|
||||
You don't have to set up anything, passive mode is the default.
|
||||
|
BIN
doc/pics/General_map_preview.png
Normal file
After Width: | Height: | Size: 299 KiB |
BIN
doc/pics/advtrains_signals.png
Normal file
After Width: | Height: | Size: 39 KiB |
BIN
doc/pics/border.png
Normal file
After Width: | Height: | Size: 243 KiB |
BIN
doc/pics/labels.png
Normal file
After Width: | Height: | Size: 87 KiB |
BIN
doc/pics/labels2.png
Normal file
After Width: | Height: | Size: 70 KiB |
BIN
doc/pics/labels3.png
Normal file
After Width: | Height: | Size: 375 KiB |
BIN
doc/pics/layers.png
Normal file
After Width: | Height: | Size: 44 KiB |
BIN
doc/pics/lcd_display.png
Normal file
After Width: | Height: | Size: 89 KiB |
BIN
doc/pics/markers.png
Normal file
After Width: | Height: | Size: 143 KiB |
BIN
doc/pics/protector.png
Normal file
After Width: | Height: | Size: 236 KiB |
BIN
doc/pics/shops.png
Normal file
After Width: | Height: | Size: 135 KiB |
BIN
doc/pics/shopsearch.png
Normal file
After Width: | Height: | Size: 102 KiB |
BIN
doc/pics/trainline_search.png
Normal file
After Width: | Height: | Size: 27 KiB |
BIN
doc/pics/trainlines.png
Normal file
After Width: | Height: | Size: 164 KiB |
BIN
doc/pics/travelnet.png
Normal file
After Width: | Height: | Size: 258 KiB |
820
doc/wip/advtrains.json
Normal file
@ -0,0 +1,820 @@
|
||||
{
|
||||
"147592" : {
|
||||
"name" : "Section 147592",
|
||||
"route" : {
|
||||
"entry" : {
|
||||
"p" : {
|
||||
"x" : -1346,
|
||||
"y" : 6501,
|
||||
"z" : -902
|
||||
},
|
||||
"s" : 2
|
||||
},
|
||||
"first" : true,
|
||||
"origin" : {
|
||||
"p" : {
|
||||
"x" : -1346,
|
||||
"y" : 6501,
|
||||
"z" : -902
|
||||
},
|
||||
"s" : 2
|
||||
},
|
||||
"rsn" : "Route 'x4' from signal 'Signal at (-1346,6501,-902)', segment #1"
|
||||
},
|
||||
"route_post" : {
|
||||
"locks" : null
|
||||
},
|
||||
"tc_breaks" : [
|
||||
{
|
||||
"p" : {
|
||||
"x" : -1431,
|
||||
"y" : 6501,
|
||||
"z" : -902
|
||||
},
|
||||
"s" : 1
|
||||
},
|
||||
{
|
||||
"p" : {
|
||||
"x" : -1346,
|
||||
"y" : 6501,
|
||||
"z" : -902
|
||||
},
|
||||
"s" : 2
|
||||
}
|
||||
],
|
||||
"trains" : null
|
||||
},
|
||||
"202775" : {
|
||||
"name" : "Section 202775",
|
||||
"route_post" : {
|
||||
"locks" : null
|
||||
},
|
||||
"tc_breaks" : [
|
||||
{
|
||||
"p" : {
|
||||
"x" : -1346,
|
||||
"y" : 6501,
|
||||
"z" : -905
|
||||
},
|
||||
"s" : 2
|
||||
},
|
||||
{
|
||||
"p" : {
|
||||
"x" : -1346,
|
||||
"y" : 6501,
|
||||
"z" : -902
|
||||
},
|
||||
"s" : 1
|
||||
}
|
||||
],
|
||||
"trains" : [ "347062" ]
|
||||
},
|
||||
"245036" : {
|
||||
"name" : "Section 245036",
|
||||
"route" : {
|
||||
"entry" : {
|
||||
"p" : {
|
||||
"x" : -907,
|
||||
"y" : 2,
|
||||
"z" : 310
|
||||
},
|
||||
"s" : 1
|
||||
},
|
||||
"first" : true,
|
||||
"origin" : {
|
||||
"p" : {
|
||||
"x" : -907,
|
||||
"y" : 2,
|
||||
"z" : 310
|
||||
},
|
||||
"s" : 1
|
||||
},
|
||||
"rsn" : "Route 'x' from signal 'Signal at (-907,2,310)', segment #1"
|
||||
},
|
||||
"route_post" : {
|
||||
"locks" : null
|
||||
},
|
||||
"tc_breaks" : [
|
||||
{
|
||||
"p" : {
|
||||
"x" : -907,
|
||||
"y" : 2,
|
||||
"z" : 320
|
||||
},
|
||||
"s" : 2
|
||||
},
|
||||
{
|
||||
"p" : {
|
||||
"x" : -907,
|
||||
"y" : 2,
|
||||
"z" : 310
|
||||
},
|
||||
"s" : 1
|
||||
}
|
||||
]
|
||||
},
|
||||
"287775" : {
|
||||
"name" : "Section 287775",
|
||||
"route_post" : {
|
||||
"locks" : null
|
||||
},
|
||||
"tc_breaks" : [
|
||||
{
|
||||
"p" : {
|
||||
"x" : -1877,
|
||||
"y" : 42,
|
||||
"z" : 395
|
||||
},
|
||||
"s" : 1
|
||||
},
|
||||
{
|
||||
"p" : {
|
||||
"x" : -1066,
|
||||
"y" : 42,
|
||||
"z" : 395
|
||||
},
|
||||
"s" : 2
|
||||
}
|
||||
],
|
||||
"trains" : [ "506728" ]
|
||||
},
|
||||
"308300" : {
|
||||
"name" : "Section 308300",
|
||||
"route" : {
|
||||
"entry" : {
|
||||
"p" : {
|
||||
"x" : -2124,
|
||||
"y" : 28,
|
||||
"z" : 562
|
||||
},
|
||||
"s" : 1
|
||||
},
|
||||
"first" : true,
|
||||
"origin" : {
|
||||
"p" : {
|
||||
"x" : -2124,
|
||||
"y" : 28,
|
||||
"z" : 562
|
||||
},
|
||||
"s" : 1
|
||||
},
|
||||
"rsn" : "Route 'x' from signal 'Signal at (-2124,28,562)', segment #1"
|
||||
},
|
||||
"route_post" : {
|
||||
"locks" : null
|
||||
},
|
||||
"tc_breaks" : [
|
||||
{
|
||||
"p" : {
|
||||
"x" : -2124,
|
||||
"y" : 28,
|
||||
"z" : 593
|
||||
},
|
||||
"s" : 2
|
||||
},
|
||||
{
|
||||
"p" : {
|
||||
"x" : -2124,
|
||||
"y" : 28,
|
||||
"z" : 562
|
||||
},
|
||||
"s" : 1
|
||||
}
|
||||
],
|
||||
"trains" : null
|
||||
},
|
||||
"332248" : {
|
||||
"name" : "Section 332248",
|
||||
"route_post" : {
|
||||
"locks" : null
|
||||
},
|
||||
"tc_breaks" : [
|
||||
{
|
||||
"p" : {
|
||||
"x" : -911,
|
||||
"y" : 2,
|
||||
"z" : 321
|
||||
},
|
||||
"s" : 2
|
||||
},
|
||||
{
|
||||
"p" : {
|
||||
"x" : -911,
|
||||
"y" : 2,
|
||||
"z" : 312
|
||||
},
|
||||
"s" : 2
|
||||
}
|
||||
],
|
||||
"trains" : [ "525416" ]
|
||||
},
|
||||
"380370" : {
|
||||
"name" : "Section 380370",
|
||||
"tc_breaks" : [
|
||||
{
|
||||
"p" : {
|
||||
"x" : -1879,
|
||||
"y" : 42,
|
||||
"z" : 392
|
||||
},
|
||||
"s" : 1
|
||||
},
|
||||
{
|
||||
"p" : {
|
||||
"x" : -1080,
|
||||
"y" : 42,
|
||||
"z" : 392
|
||||
},
|
||||
"s" : 2
|
||||
}
|
||||
],
|
||||
"trains" : null
|
||||
},
|
||||
"396699" : {
|
||||
"name" : "Section 396699",
|
||||
"tc_breaks" : [
|
||||
{
|
||||
"p" : {
|
||||
"x" : -2127,
|
||||
"y" : 28,
|
||||
"z" : 595
|
||||
},
|
||||
"s" : 2
|
||||
},
|
||||
{
|
||||
"p" : {
|
||||
"x" : -2127,
|
||||
"y" : 28,
|
||||
"z" : 562
|
||||
},
|
||||
"s" : 1
|
||||
}
|
||||
],
|
||||
"trains" : null
|
||||
},
|
||||
"424731" : {
|
||||
"name" : "Section 424731",
|
||||
"route" : {
|
||||
"entry" : {
|
||||
"p" : {
|
||||
"x" : -2088,
|
||||
"y" : 21,
|
||||
"z" : 774
|
||||
},
|
||||
"s" : 1
|
||||
},
|
||||
"first" : true,
|
||||
"origin" : {
|
||||
"p" : {
|
||||
"x" : -2088,
|
||||
"y" : 21,
|
||||
"z" : 774
|
||||
},
|
||||
"s" : 1
|
||||
},
|
||||
"rsn" : "Route 'TR-JOIN' from signal 'Signal at (-2088,21,774)', segment #1"
|
||||
},
|
||||
"route_post" : {
|
||||
"locks" : null
|
||||
},
|
||||
"tc_breaks" : [
|
||||
{
|
||||
"p" : {
|
||||
"x" : -2103,
|
||||
"y" : 21,
|
||||
"z" : 772
|
||||
},
|
||||
"s" : 2
|
||||
},
|
||||
{
|
||||
"p" : {
|
||||
"x" : -2088,
|
||||
"y" : 21,
|
||||
"z" : 774
|
||||
},
|
||||
"s" : 1
|
||||
}
|
||||
],
|
||||
"trains" : null
|
||||
},
|
||||
"448317" : {
|
||||
"name" : "Section 448317",
|
||||
"tc_breaks" : [
|
||||
{
|
||||
"p" : {
|
||||
"x" : -907,
|
||||
"y" : 2,
|
||||
"z" : 320
|
||||
},
|
||||
"s" : 1
|
||||
},
|
||||
{
|
||||
"p" : {
|
||||
"x" : -925,
|
||||
"y" : 2,
|
||||
"z" : 339
|
||||
},
|
||||
"s" : 2
|
||||
},
|
||||
{
|
||||
"p" : {
|
||||
"x" : -927,
|
||||
"y" : 2,
|
||||
"z" : 335
|
||||
},
|
||||
"s" : 2
|
||||
},
|
||||
{
|
||||
"p" : {
|
||||
"x" : -911,
|
||||
"y" : 2,
|
||||
"z" : 321
|
||||
},
|
||||
"s" : 1
|
||||
}
|
||||
],
|
||||
"trains" : [ "525416" ]
|
||||
},
|
||||
"495941" : {
|
||||
"name" : "Section 495941",
|
||||
"route_post" : {
|
||||
"locks" : null
|
||||
},
|
||||
"tc_breaks" : [
|
||||
{
|
||||
"p" : {
|
||||
"x" : -1927,
|
||||
"y" : 42,
|
||||
"z" : 392
|
||||
},
|
||||
"s" : 1
|
||||
},
|
||||
{
|
||||
"p" : {
|
||||
"x" : -1877,
|
||||
"y" : 42,
|
||||
"z" : 395
|
||||
},
|
||||
"s" : 2
|
||||
}
|
||||
],
|
||||
"trains" : [ "238799" ]
|
||||
},
|
||||
"509928" : {
|
||||
"name" : "Section 509928",
|
||||
"route" : {
|
||||
"entry" : {
|
||||
"p" : {
|
||||
"x" : -1045,
|
||||
"y" : 42,
|
||||
"z" : 392
|
||||
},
|
||||
"s" : 1
|
||||
},
|
||||
"first" : true,
|
||||
"origin" : {
|
||||
"p" : {
|
||||
"x" : -1045,
|
||||
"y" : 42,
|
||||
"z" : 392
|
||||
},
|
||||
"s" : 1
|
||||
},
|
||||
"rsn" : "Route 'x' from signal 'Signal at (-1045,42,392)', segment #1"
|
||||
},
|
||||
"route_post" : {
|
||||
"locks" : null
|
||||
},
|
||||
"tc_breaks" : [
|
||||
{
|
||||
"p" : {
|
||||
"x" : -1066,
|
||||
"y" : 42,
|
||||
"z" : 395
|
||||
},
|
||||
"s" : 1
|
||||
},
|
||||
{
|
||||
"p" : {
|
||||
"x" : -1021,
|
||||
"y" : 42,
|
||||
"z" : 395
|
||||
},
|
||||
"s" : 1
|
||||
},
|
||||
{
|
||||
"p" : {
|
||||
"x" : -1045,
|
||||
"y" : 42,
|
||||
"z" : 392
|
||||
},
|
||||
"s" : 1
|
||||
}
|
||||
],
|
||||
"trains" : null
|
||||
},
|
||||
"594356" : {
|
||||
"name" : "Section 594356",
|
||||
"tc_breaks" : [
|
||||
{
|
||||
"p" : {
|
||||
"x" : -2124,
|
||||
"y" : 28,
|
||||
"z" : 593
|
||||
},
|
||||
"s" : 1
|
||||
},
|
||||
{
|
||||
"p" : {
|
||||
"x" : -2127,
|
||||
"y" : 28,
|
||||
"z" : 595
|
||||
},
|
||||
"s" : 1
|
||||
}
|
||||
],
|
||||
"trains" : [ "830099" ]
|
||||
},
|
||||
"614720" : {
|
||||
"name" : "Section 614720",
|
||||
"route" : {
|
||||
"entry" : {
|
||||
"p" : {
|
||||
"x" : -1927,
|
||||
"y" : 42,
|
||||
"z" : 392
|
||||
},
|
||||
"s" : 2
|
||||
},
|
||||
"first" : true,
|
||||
"origin" : {
|
||||
"p" : {
|
||||
"x" : -1927,
|
||||
"y" : 42,
|
||||
"z" : 392
|
||||
},
|
||||
"s" : 2
|
||||
},
|
||||
"rsn" : "Route 'x' from signal 'Signal at (-1927,42,392)', segment #1"
|
||||
},
|
||||
"route_post" : {
|
||||
"locks" : null
|
||||
},
|
||||
"tc_breaks" : [
|
||||
{
|
||||
"p" : {
|
||||
"x" : -2124,
|
||||
"y" : 28,
|
||||
"z" : 562
|
||||
},
|
||||
"s" : 2
|
||||
},
|
||||
{
|
||||
"p" : {
|
||||
"x" : -1927,
|
||||
"y" : 42,
|
||||
"z" : 392
|
||||
},
|
||||
"s" : 2
|
||||
}
|
||||
],
|
||||
"trains" : null
|
||||
},
|
||||
"623523" : {
|
||||
"name" : "Section 623523",
|
||||
"tc_breaks" : [
|
||||
{
|
||||
"p" : {
|
||||
"x" : -2127,
|
||||
"y" : 28,
|
||||
"z" : 562
|
||||
},
|
||||
"s" : 2
|
||||
},
|
||||
{
|
||||
"p" : {
|
||||
"x" : -1924,
|
||||
"y" : 42,
|
||||
"z" : 390
|
||||
},
|
||||
"s" : 2
|
||||
}
|
||||
],
|
||||
"trains" : null
|
||||
},
|
||||
"651629" : {
|
||||
"name" : "Section 651629",
|
||||
"tc_breaks" : [
|
||||
{
|
||||
"p" : {
|
||||
"x" : -1924,
|
||||
"y" : 42,
|
||||
"z" : 390
|
||||
},
|
||||
"s" : 1
|
||||
},
|
||||
{
|
||||
"p" : {
|
||||
"x" : -1879,
|
||||
"y" : 42,
|
||||
"z" : 392
|
||||
},
|
||||
"s" : 2
|
||||
}
|
||||
],
|
||||
"trains" : null
|
||||
},
|
||||
"676937" : {
|
||||
"name" : "Section 676937",
|
||||
"tc_breaks" : [
|
||||
{
|
||||
"p" : {
|
||||
"x" : -2088,
|
||||
"y" : 21,
|
||||
"z" : 774
|
||||
},
|
||||
"s" : 2
|
||||
},
|
||||
{
|
||||
"p" : {
|
||||
"x" : -2101,
|
||||
"y" : 22,
|
||||
"z" : 787
|
||||
},
|
||||
"s" : 2
|
||||
}
|
||||
],
|
||||
"trains" : [ "747089", "358528" ]
|
||||
},
|
||||
"778640" : {
|
||||
"name" : "Section 778640",
|
||||
"route" : {
|
||||
"entry" : {
|
||||
"p" : {
|
||||
"x" : -1432,
|
||||
"y" : 6501,
|
||||
"z" : -905
|
||||
},
|
||||
"s" : 2
|
||||
},
|
||||
"first" : true,
|
||||
"origin" : {
|
||||
"p" : {
|
||||
"x" : -1432,
|
||||
"y" : 6501,
|
||||
"z" : -905
|
||||
},
|
||||
"s" : 2
|
||||
},
|
||||
"rsn" : "Route 'x5' from signal 'Signal at (-1432,6501,-905)', segment #1"
|
||||
},
|
||||
"route_post" : {
|
||||
"locks" : null
|
||||
},
|
||||
"tc_breaks" : [
|
||||
{
|
||||
"p" : {
|
||||
"x" : -1432,
|
||||
"y" : 6501,
|
||||
"z" : -905
|
||||
},
|
||||
"s" : 2
|
||||
},
|
||||
{
|
||||
"p" : {
|
||||
"x" : -1346,
|
||||
"y" : 6501,
|
||||
"z" : -905
|
||||
},
|
||||
"s" : 1
|
||||
}
|
||||
],
|
||||
"trains" : null
|
||||
},
|
||||
"819070" : {
|
||||
"name" : "Section 819070",
|
||||
"route" : {
|
||||
"entry" : {
|
||||
"p" : {
|
||||
"x" : -1080,
|
||||
"y" : 42,
|
||||
"z" : 392
|
||||
},
|
||||
"s" : 1
|
||||
},
|
||||
"first" : true,
|
||||
"origin" : {
|
||||
"p" : {
|
||||
"x" : -1080,
|
||||
"y" : 42,
|
||||
"z" : 392
|
||||
},
|
||||
"s" : 1
|
||||
},
|
||||
"rsn" : "Route 'x' from signal 'Signal at (-1080,42,392)', segment #1"
|
||||
},
|
||||
"route_post" : {
|
||||
"locks" : null
|
||||
},
|
||||
"tc_breaks" : [
|
||||
{
|
||||
"p" : {
|
||||
"x" : -1045,
|
||||
"y" : 42,
|
||||
"z" : 392
|
||||
},
|
||||
"s" : 2
|
||||
},
|
||||
{
|
||||
"p" : {
|
||||
"x" : -1080,
|
||||
"y" : 42,
|
||||
"z" : 392
|
||||
},
|
||||
"s" : 1
|
||||
}
|
||||
],
|
||||
"trains" : null
|
||||
},
|
||||
"819379" : {
|
||||
"name" : "Section 819379",
|
||||
"route_post" : {
|
||||
"locks" : null
|
||||
},
|
||||
"tc_breaks" : [
|
||||
{
|
||||
"p" : {
|
||||
"x" : -1431,
|
||||
"y" : 6501,
|
||||
"z" : -902
|
||||
},
|
||||
"s" : 2
|
||||
},
|
||||
{
|
||||
"p" : {
|
||||
"x" : -1432,
|
||||
"y" : 6501,
|
||||
"z" : -905
|
||||
},
|
||||
"s" : 1
|
||||
}
|
||||
],
|
||||
"trains" : [ "279633" ]
|
||||
},
|
||||
"853427" : {
|
||||
"name" : "Section 853427",
|
||||
"route" : {
|
||||
"entry" : {
|
||||
"p" : {
|
||||
"x" : -2109,
|
||||
"y" : 22,
|
||||
"z" : 787
|
||||
},
|
||||
"s" : 1
|
||||
},
|
||||
"first" : true,
|
||||
"origin" : {
|
||||
"p" : {
|
||||
"x" : -2109,
|
||||
"y" : 22,
|
||||
"z" : 787
|
||||
},
|
||||
"s" : 1
|
||||
},
|
||||
"rsn" : "Route 'TR01' from signal 'Signal at (-2109,22,787)', segment #1"
|
||||
},
|
||||
"route_post" : {
|
||||
"locks" : null
|
||||
},
|
||||
"tc_breaks" : [
|
||||
{
|
||||
"p" : {
|
||||
"x" : -2109,
|
||||
"y" : 22,
|
||||
"z" : 787
|
||||
},
|
||||
"s" : 1
|
||||
},
|
||||
{
|
||||
"p" : {
|
||||
"x" : -2101,
|
||||
"y" : 22,
|
||||
"z" : 787
|
||||
},
|
||||
"s" : 1
|
||||
}
|
||||
],
|
||||
"trains" : null
|
||||
},
|
||||
"908240" : {
|
||||
"name" : "Section 908240",
|
||||
"route" : {
|
||||
"entry" : {
|
||||
"p" : {
|
||||
"x" : -1027,
|
||||
"y" : 2,
|
||||
"z" : 335
|
||||
},
|
||||
"s" : 1
|
||||
},
|
||||
"first" : true,
|
||||
"origin" : {
|
||||
"p" : {
|
||||
"x" : -1027,
|
||||
"y" : 2,
|
||||
"z" : 335
|
||||
},
|
||||
"s" : 1
|
||||
},
|
||||
"rsn" : "Route 'x' from signal 'Signal at (-1027,2,335)', segment #1"
|
||||
},
|
||||
"route_post" : {
|
||||
"locks" : null
|
||||
},
|
||||
"tc_breaks" : [
|
||||
{
|
||||
"p" : {
|
||||
"x" : -1027,
|
||||
"y" : 2,
|
||||
"z" : 335
|
||||
},
|
||||
"s" : 1
|
||||
},
|
||||
{
|
||||
"p" : {
|
||||
"x" : -927,
|
||||
"y" : 2,
|
||||
"z" : 335
|
||||
},
|
||||
"s" : 1
|
||||
}
|
||||
]
|
||||
},
|
||||
"937130" : {
|
||||
"name" : "Section 937130",
|
||||
"tc_breaks" : [
|
||||
{
|
||||
"p" : {
|
||||
"x" : -2063,
|
||||
"y" : 19,
|
||||
"z" : 806
|
||||
},
|
||||
"s" : 2
|
||||
},
|
||||
{
|
||||
"p" : {
|
||||
"x" : -2085,
|
||||
"y" : 22,
|
||||
"z" : 798
|
||||
},
|
||||
"s" : 1
|
||||
}
|
||||
],
|
||||
"trains" : null
|
||||
},
|
||||
"963095" : {
|
||||
"name" : "Section 963095",
|
||||
"route" : {
|
||||
"entry" : {
|
||||
"p" : {
|
||||
"x" : -925,
|
||||
"y" : 2,
|
||||
"z" : 339
|
||||
},
|
||||
"s" : 1
|
||||
},
|
||||
"first" : true,
|
||||
"origin" : {
|
||||
"p" : {
|
||||
"x" : -925,
|
||||
"y" : 2,
|
||||
"z" : 339
|
||||
},
|
||||
"s" : 1
|
||||
},
|
||||
"rsn" : "Route 'y' from signal 'Signal at (-925,2,339)', segment #1"
|
||||
},
|
||||
"route_post" : {
|
||||
"locks" : null
|
||||
},
|
||||
"tc_breaks" : [
|
||||
{
|
||||
"p" : {
|
||||
"x" : -1026,
|
||||
"y" : 2,
|
||||
"z" : 339
|
||||
},
|
||||
"s" : 1
|
||||
},
|
||||
{
|
||||
"p" : {
|
||||
"x" : -925,
|
||||
"y" : 2,
|
||||
"z" : 339
|
||||
},
|
||||
"s" : 1
|
||||
}
|
||||
],
|
||||
"trains" : null
|
||||
}
|
||||
}
|
10
doc/wip/advtrains_interlock_dump.lua
Normal file
@ -0,0 +1,10 @@
|
||||
minetest.after(2, function()
|
||||
local world_path = minetest.get_worldpath()
|
||||
local file, err = io.open(world_path .. "advtrains.json", "w")
|
||||
|
||||
local data = advtrains.interlocking.db.save()
|
||||
local json = minetest.write_json(data.ts, true)
|
||||
|
||||
file:write(json)
|
||||
file:close()
|
||||
end)
|
28
doc/wip/advtrains_tcb_dump.lua
Normal file
@ -0,0 +1,28 @@
|
||||
minetest.after(2, function()
|
||||
local world_path = minetest.get_worldpath()
|
||||
local file, err = io.open(world_path .. "advtrains_tcbs.json", "w")
|
||||
|
||||
local data = advtrains.interlocking.db.save()
|
||||
local tmp = {}
|
||||
|
||||
for _, entry in pairs(data.tcbs) do
|
||||
local tcb = entry[1]
|
||||
-- print(dump(tcb))
|
||||
if tcb.signal then
|
||||
table.insert(tmp, {
|
||||
signal = tcb.signal,
|
||||
aspect = tcb.aspect,
|
||||
signal_name = tcb.signal_name
|
||||
})
|
||||
end
|
||||
end
|
||||
|
||||
local json, err = minetest.write_json(tmp, true)
|
||||
|
||||
if err then
|
||||
error(err)
|
||||
end
|
||||
|
||||
file:write(json)
|
||||
file:close()
|
||||
end)
|
222
doc/wip/advtrains_tcbs.json
Normal file
@ -0,0 +1,222 @@
|
||||
[
|
||||
{
|
||||
"signal" : {
|
||||
"x" : -2103,
|
||||
"y" : 22,
|
||||
"z" : 790
|
||||
},
|
||||
"signal_name" : "Signal at (-2109,22,787)"
|
||||
},
|
||||
{
|
||||
"aspect" : {
|
||||
"dst" : {
|
||||
"free" : true,
|
||||
"speed" : -1
|
||||
},
|
||||
"info" : null,
|
||||
"main" : {
|
||||
"free" : true,
|
||||
"speed" : -1
|
||||
},
|
||||
"shunt" : {
|
||||
"free" : false
|
||||
}
|
||||
},
|
||||
"signal" : {
|
||||
"x" : -2125,
|
||||
"y" : 28,
|
||||
"z" : 562
|
||||
},
|
||||
"signal_name" : "Signal at (-2124,28,562)"
|
||||
},
|
||||
{
|
||||
"signal" : {
|
||||
"x" : 10003,
|
||||
"y" : 9699,
|
||||
"z" : 15558
|
||||
},
|
||||
"signal_name" : "Signal at (10003,9696,15559)"
|
||||
},
|
||||
{
|
||||
"aspect" : {
|
||||
"dst" : {
|
||||
"free" : true,
|
||||
"speed" : -1
|
||||
},
|
||||
"info" : null,
|
||||
"main" : {
|
||||
"free" : true,
|
||||
"speed" : -1
|
||||
},
|
||||
"shunt" : {
|
||||
"free" : false
|
||||
}
|
||||
},
|
||||
"signal" : {
|
||||
"x" : 10000,
|
||||
"y" : 9699,
|
||||
"z" : 15391
|
||||
},
|
||||
"signal_name" : "Signal at (10000,9696,15391)"
|
||||
},
|
||||
{
|
||||
"signal" : {
|
||||
"x" : -2087,
|
||||
"y" : 21,
|
||||
"z" : 775
|
||||
},
|
||||
"signal_name" : "Signal at (-2088,21,774)"
|
||||
},
|
||||
{
|
||||
"signal" : {
|
||||
"x" : -1323,
|
||||
"y" : 42,
|
||||
"z" : 393
|
||||
},
|
||||
"signal_name" : "Signal at (-1323,42,392)"
|
||||
},
|
||||
{
|
||||
"aspect" : {
|
||||
"dst" : {
|
||||
"free" : true,
|
||||
"speed" : -1
|
||||
},
|
||||
"info" : null,
|
||||
"main" : {
|
||||
"free" : true,
|
||||
"speed" : -1
|
||||
},
|
||||
"shunt" : {
|
||||
"free" : false
|
||||
}
|
||||
},
|
||||
"signal" : {
|
||||
"x" : 10003,
|
||||
"y" : 9699,
|
||||
"z" : 15027
|
||||
},
|
||||
"signal_name" : "Signal at (10003,9696,15027)"
|
||||
},
|
||||
{
|
||||
"aspect" : {
|
||||
"dst" : {
|
||||
"free" : true,
|
||||
"speed" : -1
|
||||
},
|
||||
"info" : null,
|
||||
"main" : {
|
||||
"free" : true,
|
||||
"speed" : -1
|
||||
},
|
||||
"shunt" : {
|
||||
"free" : false
|
||||
}
|
||||
},
|
||||
"signal" : {
|
||||
"x" : -1044,
|
||||
"y" : 42,
|
||||
"z" : 393
|
||||
},
|
||||
"signal_name" : "Signal at (-1045,42,392)"
|
||||
},
|
||||
{
|
||||
"signal" : {
|
||||
"x" : -1019,
|
||||
"y" : 42,
|
||||
"z" : 396
|
||||
},
|
||||
"signal_name" : "Signal at (-1021,42,395)"
|
||||
},
|
||||
{
|
||||
"signal" : {
|
||||
"x" : -2428,
|
||||
"y" : 18,
|
||||
"z" : 3954
|
||||
},
|
||||
"signal_name" : "Signal at (-2426,18,3953)"
|
||||
},
|
||||
{
|
||||
"signal" : {
|
||||
"x" : -1875,
|
||||
"y" : 42,
|
||||
"z" : 393
|
||||
},
|
||||
"signal_name" : "Signal at (-1875,42,392)"
|
||||
},
|
||||
{
|
||||
"signal" : {
|
||||
"x" : -1925,
|
||||
"y" : 42,
|
||||
"z" : 388
|
||||
},
|
||||
"signal_name" : "Signal at (-1924,42,390)"
|
||||
},
|
||||
{
|
||||
"aspect" : {
|
||||
"dst" : {
|
||||
"free" : true,
|
||||
"speed" : -1
|
||||
},
|
||||
"info" : null,
|
||||
"main" : {
|
||||
"free" : true,
|
||||
"speed" : -1
|
||||
},
|
||||
"shunt" : {
|
||||
"free" : false
|
||||
}
|
||||
},
|
||||
"signal" : {
|
||||
"x" : -1079,
|
||||
"y" : 42,
|
||||
"z" : 393
|
||||
},
|
||||
"signal_name" : "Signal at (-1080,42,392)"
|
||||
},
|
||||
{
|
||||
"signal" : {
|
||||
"x" : 10003,
|
||||
"y" : 9699,
|
||||
"z" : 15160
|
||||
},
|
||||
"signal_name" : "Signal at (10003,9696,15160)"
|
||||
},
|
||||
{
|
||||
"signal" : {
|
||||
"x" : -1292,
|
||||
"y" : 42,
|
||||
"z" : 393
|
||||
},
|
||||
"signal_name" : "Signal at (-1292,42,392)"
|
||||
},
|
||||
{
|
||||
"aspect" : {
|
||||
"dst" : {
|
||||
"free" : true,
|
||||
"speed" : -1
|
||||
},
|
||||
"info" : null,
|
||||
"main" : {
|
||||
"free" : true,
|
||||
"speed" : -1
|
||||
},
|
||||
"shunt" : {
|
||||
"free" : false
|
||||
}
|
||||
},
|
||||
"signal" : {
|
||||
"x" : -2125,
|
||||
"y" : 28,
|
||||
"z" : 595
|
||||
},
|
||||
"signal_name" : "Signal at (-2124,28,593)"
|
||||
},
|
||||
{
|
||||
"signal" : {
|
||||
"x" : 10003,
|
||||
"y" : 9699,
|
||||
"z" : 15249
|
||||
},
|
||||
"signal_name" : "Signal at (10003,9696,15249)"
|
||||
}
|
||||
]
|
@ -84,6 +84,11 @@ func (mb *MapBlock) GetNodeId(x, y, z int) int {
|
||||
return mb.Mapdata.ContentId[pos]
|
||||
}
|
||||
|
||||
func (mb *MapBlock) GetParam2(x, y, z int) int {
|
||||
pos := getNodePos(x, y, z)
|
||||
return mb.Mapdata.Param2[pos]
|
||||
}
|
||||
|
||||
func (mb *MapBlock) GetNodeName(x, y, z int) string {
|
||||
id := mb.GetNodeId(x, y, z)
|
||||
return mb.BlockMapping[id]
|
@ -39,8 +39,8 @@ func parseMapdata(mapblock *MapBlock, data []byte) (int, error) {
|
||||
|
||||
for i := 0; i < 4096; i++ {
|
||||
mapd.ContentId[i] = readU16(rawdata, i*2)
|
||||
mapd.Param1[i] = readU8(rawdata, (i*2)+2)
|
||||
mapd.Param2[i] = readU8(rawdata, (i*2)+3) //TODO: last item has wrong value
|
||||
mapd.Param1[i] = readU8(rawdata, (4096*2)+i)
|
||||
mapd.Param2[i] = readU8(rawdata, (4096*3)+i)
|
||||
}
|
||||
|
||||
return cr.Count, nil
|