2018-10-11 00:25:40 +03:00
|
|
|
package geojson
|
|
|
|
|
|
|
|
import (
|
|
|
|
"strings"
|
|
|
|
|
|
|
|
"github.com/tidwall/gjson"
|
|
|
|
)
|
|
|
|
|
|
|
|
// FeatureCollection ...
|
|
|
|
type FeatureCollection struct{ collection }
|
|
|
|
|
|
|
|
// NewFeatureCollection ...
|
|
|
|
func NewFeatureCollection(features []Object) *FeatureCollection {
|
|
|
|
g := new(FeatureCollection)
|
|
|
|
g.children = features
|
|
|
|
g.parseInitRectIndex(DefaultParseOptions)
|
|
|
|
return g
|
|
|
|
}
|
|
|
|
|
|
|
|
// AppendJSON appends the GeoJSON reprensentation to dst
|
|
|
|
func (g *FeatureCollection) AppendJSON(dst []byte) []byte {
|
|
|
|
dst = append(dst, `{"type":"FeatureCollection","features":[`...)
|
|
|
|
for i := 0; i < len(g.children); i++ {
|
|
|
|
if i > 0 {
|
|
|
|
dst = append(dst, ',')
|
|
|
|
}
|
|
|
|
dst = g.children[i].AppendJSON(dst)
|
|
|
|
}
|
|
|
|
dst = append(dst, ']')
|
|
|
|
if g.extra != nil {
|
2019-02-12 16:49:13 +03:00
|
|
|
dst = g.extra.appendJSONExtra(dst, false)
|
2018-10-11 00:25:40 +03:00
|
|
|
}
|
|
|
|
dst = append(dst, '}')
|
|
|
|
strings.Index("", " ")
|
|
|
|
return dst
|
|
|
|
}
|
|
|
|
|
|
|
|
// String ...
|
|
|
|
func (g *FeatureCollection) String() string {
|
|
|
|
return string(g.AppendJSON(nil))
|
|
|
|
}
|
|
|
|
|
|
|
|
// JSON ...
|
|
|
|
func (g *FeatureCollection) JSON() string {
|
|
|
|
return string(g.AppendJSON(nil))
|
|
|
|
}
|
|
|
|
|
2019-02-12 16:49:13 +03:00
|
|
|
// MarshalJSON ...
|
|
|
|
func (g *FeatureCollection) MarshalJSON() ([]byte, error) {
|
|
|
|
return g.AppendJSON(nil), nil
|
|
|
|
}
|
|
|
|
|
2018-10-11 00:25:40 +03:00
|
|
|
func parseJSONFeatureCollection(
|
|
|
|
keys *parseKeys, opts *ParseOptions,
|
|
|
|
) (Object, error) {
|
|
|
|
var g FeatureCollection
|
|
|
|
if !keys.rFeatures.Exists() {
|
|
|
|
return nil, errFeaturesMissing
|
|
|
|
}
|
|
|
|
if !keys.rFeatures.IsArray() {
|
|
|
|
return nil, errFeaturesInvalid
|
|
|
|
}
|
|
|
|
var err error
|
|
|
|
keys.rFeatures.ForEach(func(key, value gjson.Result) bool {
|
|
|
|
var f Object
|
|
|
|
f, err = Parse(value.Raw, opts)
|
|
|
|
if err != nil {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
g.children = append(g.children, f)
|
|
|
|
return true
|
|
|
|
})
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
if err := parseBBoxAndExtras(&g.extra, keys, opts); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
g.parseInitRectIndex(opts)
|
|
|
|
return &g, nil
|
|
|
|
}
|