forked from MTSR/mapserver
app bootstrap
This commit is contained in:
parent
7cff189b0b
commit
6943f10f59
29
app/app.go
Normal file
29
app/app.go
Normal file
@ -0,0 +1,29 @@
|
||||
package app
|
||||
|
||||
import (
|
||||
"mapserver/params"
|
||||
"mapserver/worldconfig"
|
||||
"mapserver/db"
|
||||
"mapserver/mapblockaccessor"
|
||||
"mapserver/colormapping"
|
||||
"mapserver/mapblockrenderer"
|
||||
"mapserver/tiledb"
|
||||
"mapserver/tilerenderer"
|
||||
)
|
||||
|
||||
const (
|
||||
Version = "2.0-DEV"
|
||||
)
|
||||
|
||||
type App struct {
|
||||
Params params.ParamsType
|
||||
Worldconfig worldconfig.WorldConfig
|
||||
|
||||
Blockdb db.DBAccessor
|
||||
Tiledb tiledb.DBAccessor
|
||||
|
||||
BlockAccessor *mapblockaccessor.MapBlockAccessor
|
||||
Colormapping *colormapping.ColorMapping
|
||||
Mapblockrenderer *mapblockrenderer.MapBlockRenderer
|
||||
Tilerenderer *tilerenderer.TileRenderer
|
||||
}
|
85
app/setup.go
Normal file
85
app/setup.go
Normal file
@ -0,0 +1,85 @@
|
||||
package app
|
||||
|
||||
import (
|
||||
"mapserver/params"
|
||||
"mapserver/worldconfig"
|
||||
"mapserver/db"
|
||||
"mapserver/mapblockaccessor"
|
||||
"mapserver/colormapping"
|
||||
"mapserver/mapblockrenderer"
|
||||
"mapserver/tiledb"
|
||||
"mapserver/tilerenderer"
|
||||
"mapserver/layerconfig"
|
||||
|
||||
"github.com/sirupsen/logrus"
|
||||
|
||||
"errors"
|
||||
)
|
||||
|
||||
func Setup(p params.ParamsType) (*App, error) {
|
||||
a := App{}
|
||||
a.Params = p
|
||||
|
||||
//Parse world config
|
||||
|
||||
a.Worldconfig = worldconfig.Parse(a.Params.Worlddir + "world.mt")
|
||||
logrus.WithFields(logrus.Fields{"version": Version}).Info("Starting mapserver")
|
||||
|
||||
if a.Worldconfig.Backend != worldconfig.BACKEND_SQLITE3 {
|
||||
return nil, errors.New("no supported backend found!")
|
||||
}
|
||||
|
||||
//create db accessor
|
||||
var err error
|
||||
a.Blockdb, err = db.NewSqliteAccessor("map.sqlite")
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
//migrate block db
|
||||
|
||||
err = a.Blockdb.Migrate()
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
//mapblock accessor
|
||||
a.BlockAccessor = mapblockaccessor.NewMapBlockAccessor(a.Blockdb)
|
||||
|
||||
//color mapping
|
||||
|
||||
a.Colormapping = colormapping.NewColorMapping()
|
||||
err = a.Colormapping.LoadVFSColors(false, "/colors.txt")
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
//mapblock renderer
|
||||
a.Mapblockrenderer = mapblockrenderer.NewMapBlockRenderer(a.BlockAccessor, a.Colormapping)
|
||||
|
||||
//tile database
|
||||
|
||||
a.Tiledb, err = tiledb.NewSqliteAccessor("tiles.sqlite")
|
||||
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
//migrate tile database
|
||||
|
||||
err = a.Tiledb.Migrate()
|
||||
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
//setup tile renderer
|
||||
a.Tilerenderer = tilerenderer.NewTileRenderer(
|
||||
a.Mapblockrenderer,
|
||||
a.Tiledb,
|
||||
a.Blockdb,
|
||||
layerconfig.DefaultLayers,
|
||||
)
|
||||
|
||||
return &a, nil
|
||||
}
|
@ -47,7 +47,7 @@ func Render(tr *tilerenderer.TileRenderer,
|
||||
fields := logrus.Fields{
|
||||
"x": x,
|
||||
"y": y,
|
||||
"progress%": progress,
|
||||
"progress(%)": progress,
|
||||
"layer": layer.Name,
|
||||
"perf": perf_count,
|
||||
}
|
||||
|
63
main.go
63
main.go
@ -1,82 +1,45 @@
|
||||
package main
|
||||
|
||||
import (
|
||||
"flag"
|
||||
"fmt"
|
||||
"mapserver/initialrenderer"
|
||||
"mapserver/colormapping"
|
||||
"mapserver/db"
|
||||
"mapserver/mapblockaccessor"
|
||||
"mapserver/mapblockrenderer"
|
||||
"mapserver/params"
|
||||
"mapserver/worldconfig"
|
||||
"github.com/sirupsen/logrus"
|
||||
"mapserver/tilerenderer"
|
||||
"mapserver/tiledb"
|
||||
"mapserver/layerconfig"
|
||||
|
||||
"mapserver/app"
|
||||
"mapserver/params"
|
||||
"fmt"
|
||||
)
|
||||
|
||||
const (
|
||||
Version = "2.0-DEV"
|
||||
)
|
||||
|
||||
|
||||
func main() {
|
||||
logrus.SetLevel(logrus.InfoLevel)
|
||||
|
||||
//Parse command line
|
||||
|
||||
p := params.Parse()
|
||||
|
||||
if p.Help {
|
||||
flag.PrintDefaults()
|
||||
params.PrintHelp()
|
||||
return
|
||||
}
|
||||
|
||||
if p.Version {
|
||||
fmt.Print("Mapserver version: ")
|
||||
fmt.Println(Version)
|
||||
fmt.Println(app.Version)
|
||||
return
|
||||
}
|
||||
|
||||
worldcfg := worldconfig.Parse(p.Worlddir + "world.mt")
|
||||
logrus.WithFields(logrus.Fields{"version": Version}).Info("Starting mapserver")
|
||||
//setup app context
|
||||
|
||||
if worldcfg.Backend != worldconfig.BACKEND_SQLITE3 {
|
||||
panic("no sqlite3 backend found!")
|
||||
}
|
||||
ctx, err := app.Setup(p)
|
||||
|
||||
a, err := db.NewSqliteAccessor("map.sqlite")
|
||||
if err != nil {
|
||||
//error case
|
||||
panic(err)
|
||||
}
|
||||
|
||||
err = a.Migrate()
|
||||
if err != nil {
|
||||
panic(err)
|
||||
}
|
||||
//run initial rendering
|
||||
|
||||
cache := mapblockaccessor.NewMapBlockAccessor(a)
|
||||
c := colormapping.NewColorMapping()
|
||||
err = c.LoadVFSColors(false, "/colors.txt")
|
||||
if err != nil {
|
||||
panic(err)
|
||||
}
|
||||
|
||||
r := mapblockrenderer.NewMapBlockRenderer(cache, c)
|
||||
|
||||
tdb, err := tiledb.NewSqliteAccessor("tiles.sqlite")
|
||||
|
||||
if err != nil {
|
||||
panic(err)
|
||||
}
|
||||
|
||||
err = tdb.Migrate()
|
||||
|
||||
if err != nil {
|
||||
panic(err)
|
||||
}
|
||||
|
||||
tr := tilerenderer.NewTileRenderer(r, tdb, a, layerconfig.DefaultLayers)
|
||||
|
||||
initialrenderer.Render(tr, layerconfig.DefaultLayers)
|
||||
initialrenderer.Render(ctx.Tilerenderer, layerconfig.DefaultLayers)
|
||||
|
||||
}
|
||||
|
@ -22,3 +22,7 @@ func Parse() ParamsType {
|
||||
|
||||
return params
|
||||
}
|
||||
|
||||
func PrintHelp(){
|
||||
flag.PrintDefaults()
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user