forked from MTSR/mapserver
mapobjects stub
This commit is contained in:
parent
9f9e50329c
commit
0a702d240c
@ -26,12 +26,11 @@ func Render(tr *tilerenderer.TileRenderer,
|
|||||||
jobs := make(chan coords.TileCoords, 100)
|
jobs := make(chan coords.TileCoords, 100)
|
||||||
|
|
||||||
fields := logrus.Fields{
|
fields := logrus.Fields{
|
||||||
"workers": runtime.NumCPU(),
|
"workers": runtime.NumCPU(),
|
||||||
}
|
}
|
||||||
logrus.WithFields(fields).Info("Starting initial render progress")
|
logrus.WithFields(fields).Info("Starting initial render progress")
|
||||||
|
|
||||||
|
for i := 0; i < runtime.NumCPU(); i++ {
|
||||||
for i := 0; i<runtime.NumCPU(); i++ {
|
|
||||||
go worker(tr, jobs)
|
go worker(tr, jobs)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -10,13 +10,13 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
type MapBlockAccessor struct {
|
type MapBlockAccessor struct {
|
||||||
accessor db.DBAccessor
|
accessor db.DBAccessor
|
||||||
c *cache.Cache
|
c *cache.Cache
|
||||||
listeners []MapBlockListener
|
listeners []MapBlockListener
|
||||||
}
|
}
|
||||||
|
|
||||||
type MapBlockListener interface {
|
type MapBlockListener interface {
|
||||||
OnParsedMapBlock(block *mapblockparser.MapBlock)
|
OnParsedMapBlock(block *mapblockparser.MapBlock, pos coords.MapBlockCoords)
|
||||||
}
|
}
|
||||||
|
|
||||||
func getKey(pos coords.MapBlockCoords) string {
|
func getKey(pos coords.MapBlockCoords) string {
|
||||||
@ -55,8 +55,8 @@ func (a *MapBlockAccessor) FindLatestMapBlocks(mintime int64, limit int) ([]*map
|
|||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
for _, listener := range(a.listeners) {
|
for _, listener := range a.listeners {
|
||||||
listener.OnParsedMapBlock(mapblock)
|
listener.OnParsedMapBlock(mapblock, block.Pos)
|
||||||
}
|
}
|
||||||
|
|
||||||
a.c.Set(key, mapblock, cache.DefaultExpiration)
|
a.c.Set(key, mapblock, cache.DefaultExpiration)
|
||||||
@ -88,8 +88,8 @@ func (a *MapBlockAccessor) GetMapBlock(pos coords.MapBlockCoords) (*mapblockpars
|
|||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
for _, listener := range(a.listeners) {
|
for _, listener := range a.listeners {
|
||||||
listener.OnParsedMapBlock(mapblock)
|
listener.OnParsedMapBlock(mapblock, pos)
|
||||||
}
|
}
|
||||||
|
|
||||||
a.c.Set(key, mapblock, cache.DefaultExpiration)
|
a.c.Set(key, mapblock, cache.DefaultExpiration)
|
||||||
|
@ -6,9 +6,11 @@ import (
|
|||||||
|
|
||||||
type MapData struct {
|
type MapData struct {
|
||||||
//mapblock position
|
//mapblock position
|
||||||
MBPos coords.MapBlockCoords
|
MBPos coords.MapBlockCoords
|
||||||
|
|
||||||
//block position
|
//block position
|
||||||
X, Y, Z int
|
X, Y, Z int
|
||||||
|
|
||||||
Type string
|
Type string
|
||||||
Data string
|
Data string
|
||||||
Mtime int64
|
Mtime int64
|
||||||
@ -17,11 +19,12 @@ type MapData struct {
|
|||||||
type SearchQuery struct {
|
type SearchQuery struct {
|
||||||
//block position (not mapblock)
|
//block position (not mapblock)
|
||||||
Pos1, Pos2 coords.MapBlockCoords
|
Pos1, Pos2 coords.MapBlockCoords
|
||||||
Type string
|
Type string
|
||||||
}
|
}
|
||||||
|
|
||||||
type DBAccessor interface {
|
type DBAccessor interface {
|
||||||
Migrate() error
|
Migrate() error
|
||||||
GetMapData(q SearchQuery) ([]MapData, error)
|
GetMapData(q SearchQuery) ([]MapData, error)
|
||||||
SetMapData(pos coords.MapBlockCoords, data []MapData) error
|
RemoveMapData(pos coords.MapBlockCoords) error
|
||||||
|
AddMapData(data MapData) error
|
||||||
}
|
}
|
||||||
|
18
mapobject/clearmapdata.go
Normal file
18
mapobject/clearmapdata.go
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
package mapobject
|
||||||
|
|
||||||
|
import (
|
||||||
|
"mapserver/coords"
|
||||||
|
"mapserver/mapblockparser"
|
||||||
|
"mapserver/mapdb"
|
||||||
|
)
|
||||||
|
|
||||||
|
type ClearMapData struct {
|
||||||
|
db mapdb.DBAccessor
|
||||||
|
}
|
||||||
|
|
||||||
|
func (this *ClearMapData) OnParsedMapBlock(block *mapblockparser.MapBlock, pos coords.MapBlockCoords) {
|
||||||
|
err := this.db.RemoveMapData(pos)
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
}
|
27
mapobject/poi.go
Normal file
27
mapobject/poi.go
Normal file
@ -0,0 +1,27 @@
|
|||||||
|
package mapobject
|
||||||
|
|
||||||
|
import (
|
||||||
|
"mapserver/coords"
|
||||||
|
"mapserver/mapblockparser"
|
||||||
|
"mapserver/mapdb"
|
||||||
|
)
|
||||||
|
|
||||||
|
type POI struct {
|
||||||
|
db mapdb.DBAccessor
|
||||||
|
}
|
||||||
|
|
||||||
|
func (this *POI) OnParsedMapBlock(block *mapblockparser.MapBlock, pos coords.MapBlockCoords) {
|
||||||
|
var found bool
|
||||||
|
for _, v := range(block.BlockMapping) {
|
||||||
|
if v == "mapserver:poi" {
|
||||||
|
found = true
|
||||||
|
break
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if !found {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
panic("OK") //XXX
|
||||||
|
}
|
@ -7,7 +7,7 @@ import (
|
|||||||
type ParamsType struct {
|
type ParamsType struct {
|
||||||
Help bool
|
Help bool
|
||||||
Version bool
|
Version bool
|
||||||
Debug bool
|
Debug bool
|
||||||
Dumpconfig bool
|
Dumpconfig bool
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user