Documentation ¶
Index ¶
- Constants
- Variables
- type Action
- type ActionType
- type Actions
- type Bounds
- type Change
- type Changeset
- func (c *Changeset) Bot() bool
- func (c *Changeset) Bounds() *Bounds
- func (c *Changeset) Comment() string
- func (c *Changeset) CreatedBy() string
- func (c *Changeset) Host() string
- func (c *Changeset) ImageryUsed() string
- func (c *Changeset) Locale() string
- func (c *Changeset) ObjectID() ObjectID
- func (c *Changeset) Source() string
- type ChangesetComment
- type ChangesetDiscussion
- type ChangesetID
- type Changesets
- type Date
- type Diff
- type Element
- type ElementID
- func (id ElementID) FeatureID() FeatureID
- func (id ElementID) NodeID() NodeID
- func (id ElementID) ObjectID() ObjectID
- func (id ElementID) Ref() int64
- func (id ElementID) RelationID() RelationID
- func (id ElementID) String() string
- func (id ElementID) Type() Type
- func (id ElementID) Version() int
- func (id ElementID) WayID() WayID
- type ElementIDs
- type Elements
- type FeatureID
- func (id FeatureID) ElementID(v int) ElementID
- func (id FeatureID) NodeID() NodeID
- func (id FeatureID) ObjectID(v int) ObjectID
- func (id FeatureID) Ref() int64
- func (id FeatureID) RelationID() RelationID
- func (id FeatureID) String() string
- func (id FeatureID) Type() Type
- func (id FeatureID) WayID() WayID
- type FeatureIDs
- type HistoryDatasource
- func (ds *HistoryDatasource) NodeHistory(ctx context.Context, id NodeID) (Nodes, error)
- func (ds *HistoryDatasource) NotFound(err error) bool
- func (ds *HistoryDatasource) RelationHistory(ctx context.Context, id RelationID) (Relations, error)
- func (ds *HistoryDatasource) WayHistory(ctx context.Context, id WayID) (Ways, error)
- type HistoryDatasourcer
- type Member
- type Members
- type Node
- type NodeID
- type Nodes
- type Note
- type NoteComment
- type NoteCommentAction
- type NoteID
- type NoteStatus
- type Notes
- type OSM
- func (o *OSM) Append(obj Object)
- func (o *OSM) ElementIDs() ElementIDs
- func (o *OSM) Elements() Elements
- func (o *OSM) FeatureIDs() FeatureIDs
- func (o *OSM) HistoryDatasource() *HistoryDatasource
- func (o OSM) MarshalJSON() ([]byte, error)
- func (o OSM) MarshalXML(e *xml.Encoder, start xml.StartElement) error
- func (o *OSM) Objects() Objects
- func (o *OSM) UnmarshalJSON(data []byte) error
- type Object
- type ObjectID
- type ObjectIDs
- type Objects
- type Relation
- type RelationID
- type Relations
- type Scanner
- type Tag
- type Tags
- func (ts Tags) AnyInteresting() bool
- func (ts Tags) Find(k string) string
- func (ts Tags) FindTag(k string) *Tag
- func (ts Tags) HasTag(k string) bool
- func (ts Tags) Map() map[string]string
- func (ts Tags) MarshalJSON() ([]byte, error)
- func (ts Tags) SortByKeyValue()
- func (ts *Tags) UnmarshalJSON(data []byte) error
- type Type
- type Update
- type UpdateIndexOutOfRangeError
- type Updates
- type User
- type UserID
- type Users
- type Way
- func (w *Way) ApplyUpdatesUpTo(t time.Time) error
- func (w *Way) CommittedAt() time.Time
- func (w *Way) ElementID() ElementID
- func (w *Way) FeatureID() FeatureID
- func (w *Way) LineString() orb.LineString
- func (w *Way) LineStringAt(t time.Time) orb.LineString
- func (w *Way) ObjectID() ObjectID
- func (w *Way) Polygon() bool
- func (w *Way) TagMap() map[string]string
- type WayID
- type WayNode
- type WayNodes
- type Ways
Constants ¶
const ( Copyright = "OpenStreetMap and contributors" Attribution = "http://www.openstreetmap.org/copyright" License = "http://opendatacommons.org/licenses/odbl/1-0/" )
These values should be returned if the osm data is actual osm data to give some information about the source and license.
Variables ¶
var CommitInfoStart = time.Date(2012, 9, 12, 9, 30, 3, 0, time.UTC)
CommitInfoStart is the start time when we know committed at information. Any update.Timestamp >= this date is a committed at time. Anything before this date is the element timestamp.
var CustomJSONMarshaler interface { Marshal(v interface{}) ([]byte, error) }
CustomJSONMarshaler can be set to have the code use a different json marshaler than the default in the standard library. One use case in enabling `github.com/json-iterator/go` with something like this:
import ( jsoniter "github.com/json-iterator/go" "github.com/nextmv-io/osm" ) var c = jsoniter.Config{ EscapeHTML: true, SortMapKeys: false, MarshalFloatWith6Digits: true, }.Froze() osm.CustomJSONMarshaler = c osm.CustomJSONUnmarshaler = c
Note that any errors encountered during marshaling will be different.
var CustomJSONUnmarshaler interface { Unmarshal(data []byte, v interface{}) error }
CustomJSONUnmarshaler can be set to have the code use a different json unmarshaler than the default in the standard library. One use case in enabling `github.com/json-iterator/go` with something like this:
import ( jsoniter "github.com/json-iterator/go" "github.com/nextmv-io/osm" ) var c = jsoniter.Config{ EscapeHTML: true, SortMapKeys: false, MarshalFloatWith6Digits: true, }.Froze() osm.CustomJSONMarshaler = c osm.CustomJSONUnmarshaler = c
Note that any errors encountered during unmarshaling will be different.
var ( // ErrScannerClosed is returned by scanner.Err() if the scanner is closed // and there are no other io or xml errors to report. ErrScannerClosed = errors.New("osm: scanner closed by user") )
var UninterestingTags = map[string]bool{ "source": true, "source_ref": true, "source:ref": true, "history": true, "attribution": true, "created_by": true, "tiger:county": true, "tiger:tlid": true, "tiger:upload_uuid": true, }
UninterestingTags are boring tags. If an element only has these tags it does not usually need to be displayed. For example, if a node with just these tags is part of a way, it probably does not need its own icon along the way.
Functions ¶
This section is empty.
Types ¶
type Action ¶
type Action struct { Type ActionType `xml:"type,attr"` *OSM `xml:",omitempty"` Old *OSM `xml:"old,omitempty"` New *OSM `xml:"new,omitempty"` }
Action is an explicit create, modify or delete action with old and new data if applicable. Different properties of this struct will be populated depending on the action.
Create: da.OSM will contain the new element Modify: da.Old and da.New will contain the old and new elements. Delete: da.Old and da.New will contain the old and new elements.
func (Action) MarshalXML ¶
MarshalXML converts a diff action to xml creating the proper structures.
func (*Action) UnmarshalXML ¶
UnmarshalXML converts xml into a diff action.
type ActionType ¶
type ActionType string
ActionType is a strong type for the different diff actions.
const ( ActionCreate ActionType = "create" ActionModify ActionType = "modify" ActionDelete ActionType = "delete" )
The different types of diff actions.
type Bounds ¶
type Bounds struct { MinLat float64 `xml:"minlat,attr"` MaxLat float64 `xml:"maxlat,attr"` MinLon float64 `xml:"minlon,attr"` MaxLon float64 `xml:"maxlon,attr"` }
Bounds are the bounds of osm data as defined in the xml file.
func NewBoundsFromTile ¶
NewBoundsFromTile creates a bound given an online map tile index.
func (*Bounds) ContainsNode ¶
ContainsNode returns true if the node is within the bound. Uses inclusive intervals, ie. returns true if on the boundary.
type Change ¶
type Change struct { Version string `xml:"version,attr,omitempty" json:"version,omitempty"` Generator string `xml:"generator,attr,omitempty" json:"generator,omitempty"` // to indicate the origin of the data Copyright string `xml:"copyright,attr,omitempty" json:"copyright,omitempty"` Attribution string `xml:"attribution,attr,omitempty" json:"attribution,omitempty"` License string `xml:"license,attr,omitempty" json:"license,omitempty"` Create *OSM `xml:"create" json:"create,omitempty"` Modify *OSM `xml:"modify" json:"modify,omitempty"` Delete *OSM `xml:"delete" json:"delete,omitempty"` }
Change is the structure of a changeset to be uploaded or downloaded from the osm api server. See: http://wiki.openstreetmap.org/wiki/OsmChange
func (*Change) AppendCreate ¶
AppendCreate will append the object to the Create OSM object.
func (*Change) AppendDelete ¶
AppendDelete will append the object to the Delete OSM object.
func (*Change) AppendModify ¶
AppendModify will append the object to the Modify OSM object.
func (*Change) HistoryDatasource ¶
func (c *Change) HistoryDatasource() *HistoryDatasource
HistoryDatasource converts the change object to a datasource accessible by feature id. All the creates, modifies and deletes will be added in that order.
func (Change) MarshalXML ¶
MarshalXML implements the xml.Marshaller method to allow for the correct wrapper/start element case and attr data.
type Changeset ¶
type Changeset struct { XMLName xmlNameJSONTypeCS `xml:"changeset" json:"type"` ID ChangesetID `xml:"id,attr" json:"id"` User string `xml:"user,attr" json:"user,omitempty"` UserID UserID `xml:"uid,attr" json:"uid,omitempty"` CreatedAt time.Time `xml:"created_at,attr" json:"created_at"` ClosedAt time.Time `xml:"closed_at,attr" json:"closed_at"` Open bool `xml:"open,attr" json:"open"` ChangesCount int `xml:"num_changes,attr,omitempty" json:"num_changes,omitempty"` MinLat float64 `xml:"min_lat,attr" json:"min_lat,omitempty"` MaxLat float64 `xml:"max_lat,attr" json:"max_lat,omitempty"` MinLon float64 `xml:"min_lon,attr" json:"min_lon,omitempty"` MaxLon float64 `xml:"max_lon,attr" json:"max_lon,omitempty"` CommentsCount int `xml:"comments_count,attr,omitempty" json:"comments_count,omitempty"` Tags Tags `xml:"tag" json:"tags,omitempty"` Discussion *ChangesetDiscussion `xml:"discussion,omitempty" json:"discussion,omitempty"` Change *Change `xml:"-" json:"change,omitempty"` }
A Changeset is a set of metadata around a set of osm changes.
func (*Changeset) CreatedBy ¶
CreatedBy is a helper and returns the changeset created by from the tag.
func (*Changeset) ImageryUsed ¶
ImageryUsed is a helper and returns imagery used for the changeset from the tag.
type ChangesetComment ¶
type ChangesetComment struct { User string `xml:"user,attr" json:"user"` UserID UserID `xml:"uid,attr" json:"uid"` Timestamp time.Time `xml:"date,attr" json:"date"` Text string `xml:"text" json:"text"` }
ChangesetComment is a specific comment in a changeset discussion.
type ChangesetDiscussion ¶
type ChangesetDiscussion struct {
Comments []*ChangesetComment `xml:"comment" json:"comments"`
}
ChangesetDiscussion is a conversation about a changeset.
func (ChangesetDiscussion) MarshalXML ¶
func (csd ChangesetDiscussion) MarshalXML(e *xml.Encoder, start xml.StartElement) error
MarshalXML implements the xml.Marshaller method to exclude this whole element if the comments are empty.
type ChangesetID ¶
type ChangesetID int64
ChangesetID is the primary key for an osm changeset.
func (ChangesetID) ObjectID ¶
func (id ChangesetID) ObjectID() ObjectID
ObjectID is a helper returning the object id for this changeset id.
type Changesets ¶
type Changesets []*Changeset
Changesets is a collection with some helper functions attached.
func (Changesets) IDs ¶
func (cs Changesets) IDs() []ChangesetID
IDs returns the ids of the changesets in the slice.
type Date ¶
Date is an object to decode the date format used in the osm notes xml api. The format is '2006-01-02 15:04:05 MST'.
func (Date) MarshalJSON ¶
MarshalJSON will return null if the date is empty.
func (Date) MarshalXML ¶
MarshalXML is meant to encode the time.Time into the osm note date formation of '2006-01-02 15:04:05 MST'.
func (*Date) UnmarshalXML ¶
UnmarshalXML is meant to decode the osm note date formation of '2006-01-02 15:04:05 MST' into a time.Time object.
type Diff ¶
type Diff struct { XMLName xml.Name `xml:"osm"` Actions Actions `xml:"action"` Changesets Changesets `xml:"changeset"` }
Diff represents a difference of osm data with old and new data.
type Element ¶
type Element interface { Object ElementID() ElementID FeatureID() FeatureID TagMap() map[string]string }
An Element represents a Node, Way or Relation.
type ElementID ¶
type ElementID int64
ElementID is a unique key for an osm element. It contains the type, id and version information.
func ParseElementID ¶
ParseElementID takes a string and tries to determine the element id from it. The string must be formatted as "type/id:version", the same as the result of the String method.
func (ElementID) FeatureID ¶
FeatureID returns the feature id for the element id. i.e removing the version.
func (ElementID) NodeID ¶
NodeID returns the id of this feature as a node id. The function will panic if this element is not of TypeNode.
func (ElementID) RelationID ¶
func (id ElementID) RelationID() RelationID
RelationID returns the id of this feature as a relation id. The function will panic if this element is not of TypeRelation.
type ElementIDs ¶
type ElementIDs []ElementID
ElementIDs is a list of element ids with helper functions on top.
func (ElementIDs) Counts ¶
func (ids ElementIDs) Counts() (nodes, ways, relations int)
Counts returns the number of each type of element in the set of ids.
func (ElementIDs) Sort ¶
func (ids ElementIDs) Sort()
Sort will order the ids by type, node, way, relation, changeset, and then id.
type Elements ¶
type Elements []Element
Elements is a collection of the Element type.
func (Elements) ElementIDs ¶
func (es Elements) ElementIDs() ElementIDs
ElementIDs returns a slice of the element ids of the elements.
func (Elements) FeatureIDs ¶
func (es Elements) FeatureIDs() FeatureIDs
FeatureIDs returns a slice of the feature ids of the elements.
type FeatureID ¶
type FeatureID int64
A FeatureID is an identifier for a feature in OSM. It is meant to represent all the versions of a given element.
func ParseFeatureID ¶
ParseFeatureID takes a string and tries to determine the feature id from it. The string must be formatted at "type/id", the same as the result of the String method.
func (FeatureID) NodeID ¶
NodeID returns the id of this feature as a node id. The function will panic if this feature is not of TypeNode..
func (FeatureID) RelationID ¶
func (id FeatureID) RelationID() RelationID
RelationID returns the id of this feature as a relation id. The function will panic if this feature is not of TypeRelation.
type FeatureIDs ¶
type FeatureIDs []FeatureID
FeatureIDs is a slice of FeatureIDs with some helpers on top.
func (FeatureIDs) Counts ¶
func (ids FeatureIDs) Counts() (nodes, ways, relations int)
Counts returns the number of each type of feature in the set of ids.
func (FeatureIDs) Sort ¶
func (ids FeatureIDs) Sort()
Sort will order the ids by type, node, way, relation, changeset, and then id.
type HistoryDatasource ¶
type HistoryDatasource struct { Nodes map[NodeID]Nodes Ways map[WayID]Ways Relations map[RelationID]Relations }
A HistoryDatasource wraps maps to implement the HistoryDataSource interface.
func (*HistoryDatasource) NodeHistory ¶
NodeHistory returns the history for the given id from the map.
func (*HistoryDatasource) NotFound ¶
func (ds *HistoryDatasource) NotFound(err error) bool
NotFound returns true if the error returned is a not found error.
func (*HistoryDatasource) RelationHistory ¶
func (ds *HistoryDatasource) RelationHistory(ctx context.Context, id RelationID) (Relations, error)
RelationHistory returns the history for the given id from the map.
func (*HistoryDatasource) WayHistory ¶
WayHistory returns the history for the given id from the map.
type HistoryDatasourcer ¶
type HistoryDatasourcer interface { NodeHistory(context.Context, NodeID) (Nodes, error) WayHistory(context.Context, WayID) (Ways, error) RelationHistory(context.Context, RelationID) (Relations, error) NotFound(error) bool }
A HistoryDatasourcer defines an interface to osm history data.
type Member ¶
type Member struct { Type Type `xml:"type,attr" json:"type"` Ref int64 `xml:"ref,attr" json:"ref"` Role string `xml:"role,attr" json:"role"` Version int `xml:"version,attr,omitempty" json:"version,omitempty"` ChangesetID ChangesetID `xml:"changeset,attr,omitempty" json:"changeset,omitempty"` // Node location if Type == Node // Closest vertex to centroid if Type == Way // Empty/invalid if Type == Relation Lat float64 `xml:"lat,attr,omitempty" json:"lat,omitempty"` Lon float64 `xml:"lon,attr,omitempty" json:"lon,omitempty"` // Orientation is the direction of the way around a ring of a multipolygon. // Only valid for multipolygon or boundary relations. Orientation orb.Orientation `xml:"orientation,attr,omitempty" json:"orientation,omitempty"` // Nodes are sometimes included in members of type way to include the lat/lon // path of the way. Overpass returns xml like this. Nodes WayNodes `xml:"nd" json:"nodes,omitempty"` }
Member is a member of a relation.
type Members ¶
type Members []Member
Members represents an ordered list of relation members.
func (Members) ElementIDs ¶
func (ms Members) ElementIDs() ElementIDs
ElementIDs returns the a list of element ids for the members.
func (Members) FeatureIDs ¶
func (ms Members) FeatureIDs() FeatureIDs
FeatureIDs returns the a list of feature ids for the members.
func (Members) MarshalJSON ¶
MarshalJSON allows the members to be marshalled as defined by the overpass osmjson. This function is a wrapper to marshal null as [].
type Node ¶
type Node struct { XMLName xmlNameJSONTypeNode `xml:"node" json:"type"` ID NodeID `xml:"id,attr" json:"id"` Lat float64 `xml:"lat,attr" json:"lat"` Lon float64 `xml:"lon,attr" json:"lon"` User string `xml:"user,attr" json:"user,omitempty"` UserID UserID `xml:"uid,attr" json:"uid,omitempty"` Visible bool `xml:"visible,attr" json:"visible"` Version int `xml:"version,attr" json:"version,omitempty"` ChangesetID ChangesetID `xml:"changeset,attr" json:"changeset,omitempty"` Timestamp time.Time `xml:"timestamp,attr" json:"timestamp"` Tags Tags `xml:"tag" json:"tags,omitempty"` // Committed, is the estimated time this object was committed // and made visible in the central OSM database. Committed *time.Time `xml:"committed,attr,omitempty" json:"committed,omitempty"` }
Node is an osm point and allows for marshalling to/from osm xml.
func (*Node) CommittedAt ¶
CommittedAt returns the best estimate on when this element became was written/committed into the database.
type NodeID ¶
type NodeID int64
NodeID corresponds the primary key of a node. The node id + version uniquely identify a node.
type Nodes ¶
type Nodes []*Node
Nodes is a list of nodes with helper functions on top.
func (Nodes) ElementIDs ¶
func (ns Nodes) ElementIDs() ElementIDs
ElementIDs returns the element ids for all the nodes.
func (Nodes) FeatureIDs ¶
func (ns Nodes) FeatureIDs() FeatureIDs
FeatureIDs returns the feature ids for all the nodes.
func (Nodes) SortByIDVersion ¶
func (ns Nodes) SortByIDVersion()
SortByIDVersion will sort the set of nodes first by id and then version in ascending order.
type Note ¶
type Note struct { XMLName xmlNameJSONTypeNote `xml:"note" json:"type"` ID NoteID `xml:"id" json:"id"` Lat float64 `xml:"lat,attr" json:"lat"` Lon float64 `xml:"lon,attr" json:"lon"` URL string `xml:"url" json:"url,omitempty"` CommentURL string `xml:"comment_url" json:"comment_url,omitempty"` CloseURL string `xml:"close_url" json:"close_url,omitempty"` ReopenURL string `xml:"reopen_url" json:"reopen_url,omitempty"` DateCreated Date `xml:"date_created" json:"date_created"` DateClosed Date `xml:"date_closed" json:"date_closed,omitempty"` Status NoteStatus `xml:"status" json:"status,omitempty"` Comments []*NoteComment `xml:"comments>comment" json:"comments"` }
Note is information for other mappers dropped at a map location.
type NoteComment ¶
type NoteComment struct { XMLName xml.Name `xml:"comment" json:"-"` Date Date `xml:"date" json:"date"` UserID UserID `xml:"uid" json:"uid,omitempty"` User string `xml:"user" json:"user,omitempty"` UserURL string `xml:"user_url" json:"user_url,omitempty"` Action NoteCommentAction `xml:"action" json:"action"` Text string `xml:"text" json:"text"` HTML string `xml:"html" json:"html"` }
NoteComment is a comment on a note.
type NoteCommentAction ¶
type NoteCommentAction string
NoteCommentAction are actions that a note comment took.
var ( NoteCommentOpened NoteCommentAction = "opened" NoteCommentComment NoteCommentAction = "commented" NoteCommentClosed NoteCommentAction = "closed" )
The set of comment actions.
type NoteStatus ¶
type NoteStatus string
NoteStatus is the status of the note.
var ( NoteOpen NoteStatus = "open" NoteClosed NoteStatus = "closed" )
A note can be open or closed.
type OSM ¶
type OSM struct { // JSON APIs can return version as a string or number, converted to string // for consistency. Version string `xml:"version,attr,omitempty"` Generator string `xml:"generator,attr,omitempty"` // These three attributes are returned by the osm api. // The Copyright, Attribution and License constants contain // suggested values that match those returned by the official api. Copyright string `xml:"copyright,attr,omitempty"` Attribution string `xml:"attribution,attr,omitempty"` License string `xml:"license,attr,omitempty"` Bounds *Bounds `xml:"bounds,omitempty"` Nodes Nodes `xml:"node"` Ways Ways `xml:"way"` Relations Relations `xml:"relation"` // Changesets will typically not be included with actual data, // but all this stuff is technically all under the osm xml Changesets Changesets `xml:"changeset"` Notes Notes `xml:"note"` Users Users `xml:"user"` }
OSM represents the core osm data designed to parse http://wiki.openstreetmap.org/wiki/OSM_XML
func (*OSM) ElementIDs ¶
func (o *OSM) ElementIDs() ElementIDs
ElementIDs returns the slice of element ids for all the nodes, ways and relations.
func (*OSM) Elements ¶
Elements returns all the nodes, ways and relations as a single slice of Elements.
func (*OSM) FeatureIDs ¶
func (o *OSM) FeatureIDs() FeatureIDs
FeatureIDs returns the slice of feature ids for all the nodes, ways and relations.
func (*OSM) HistoryDatasource ¶
func (o *OSM) HistoryDatasource() *HistoryDatasource
HistoryDatasource converts the osm object to a datasource accessible by the feature id.
func (OSM) MarshalJSON ¶
MarshalJSON allows the tags to be marshalled as an object as defined by the overpass osmjson. http://overpass-api.de/output_formats.html#json
func (OSM) MarshalXML ¶
MarshalXML implements the xml.Marshaller method to allow for the correct wrapper/start element case and attr data.
func (*OSM) Objects ¶
Objects returns an array of objects containing any nodes, ways, relations, changesets, notes and users.
func (*OSM) UnmarshalJSON ¶
UnmarshalJSON will decode osm json representation as defined by the overpass osmjson. This format can also by returned by the official OSM API. http://overpass-api.de/output_formats.html#json
type Object ¶
type Object interface { ObjectID() ObjectID // contains filtered or unexported methods }
An Object represents a Node, Way, Relation, Changeset, Note or User only.
type ObjectID ¶
type ObjectID int64
ObjectID encodes the type and ref of an osm object, e.g. nodes, ways, relations, changesets, notes and users.
func ParseObjectID ¶
ParseObjectID takes a string and tries to determine the object id from it. The string must be formatted as "type/id:version", the same as the result of the String method.
type ObjectIDs ¶
type ObjectIDs []ObjectID
ObjectIDs is a slice of ObjectIDs with some helpers on top.
type Relation ¶
type Relation struct { XMLName xmlNameJSONTypeRel `xml:"relation" json:"type"` ID RelationID `xml:"id,attr" json:"id"` User string `xml:"user,attr" json:"user,omitempty"` UserID UserID `xml:"uid,attr" json:"uid,omitempty"` Visible bool `xml:"visible,attr" json:"visible"` Version int `xml:"version,attr" json:"version,omitempty"` ChangesetID ChangesetID `xml:"changeset,attr" json:"changeset,omitempty"` Timestamp time.Time `xml:"timestamp,attr" json:"timestamp,omitempty"` Tags Tags `xml:"tag" json:"tags,omitempty"` Members Members `xml:"member" json:"members"` // Committed, is the estimated time this object was committed // and made visible in the central OSM database. Committed *time.Time `xml:"committed,attr,omitempty" json:"committed,omitempty"` // Updates are changes to the members of this relation independent // of an update to the relation itself. The OSM api allows a child // to be updated without any changes to the parent. Updates Updates `xml:"update,omitempty" json:"updates,omitempty"` // Bounds are included by overpass, and maybe others Bounds *Bounds `xml:"bounds,omitempty" json:"bounds,omitempty"` }
Relation is an collection of nodes, ways and other relations with some defining attributes.
func (*Relation) ApplyUpdatesUpTo ¶
ApplyUpdatesUpTo will apply the updates to this object upto and including the given time.
func (*Relation) CommittedAt ¶
CommittedAt returns the best estimate on when this element became was written/committed into the database.
type RelationID ¶
type RelationID int64
RelationID is the primary key of a relation. A relation is uniquely identifiable by the id + version.
func (RelationID) ElementID ¶
func (id RelationID) ElementID(v int) ElementID
ElementID is a helper to convert the id to an element id.
func (RelationID) FeatureID ¶
func (id RelationID) FeatureID() FeatureID
FeatureID is a helper returning the feature id for this relation id.
func (RelationID) ObjectID ¶
func (id RelationID) ObjectID(v int) ObjectID
ObjectID is a helper returning the object id for this relation id.
type Relations ¶
type Relations []*Relation
Relations is a list of relations with some helper functions attached.
func (Relations) ElementIDs ¶
func (rs Relations) ElementIDs() ElementIDs
ElementIDs returns the element ids for all the relations.
func (Relations) FeatureIDs ¶
func (rs Relations) FeatureIDs() FeatureIDs
FeatureIDs returns the feature ids for all the relations.
func (Relations) IDs ¶
func (rs Relations) IDs() []RelationID
IDs returns the ids for all the relations.
func (Relations) SortByIDVersion ¶
func (rs Relations) SortByIDVersion()
SortByIDVersion will sort the set of relations first by id and then version in ascending order.
type Scanner ¶
A Scanner reads osm data from planet dump files. It is based on the bufio.Scanner, common usage. Scanners are not safe for parallel use. One should feed the objects into their own channel and have workers read from that.
s := scanner.New(r) defer s.Close() for s.Next() { o := s.Object() // do something } if s.Err() != nil { // scanner did not complete fully }
type Tags ¶
type Tags []Tag
Tags is a collection of Tag objects with some helper functions.
func (Tags) AnyInteresting ¶
AnyInteresting will return true if there is at last one interesting tag.
func (Tags) Find ¶
Find will return the value for the key. Will return an empty string if not found.
func (Tags) FindTag ¶
FindTag will return the Tag for the given key. Can be used to determine if a key exists, even with an empty value. Returns nil if not found.
func (Tags) MarshalJSON ¶
MarshalJSON allows the tags to be marshalled as a key/value object, as defined by the overpass osmjson.
func (Tags) SortByKeyValue ¶
func (ts Tags) SortByKeyValue()
SortByKeyValue will do an inplace sort of the tags.
func (*Tags) UnmarshalJSON ¶
UnmarshalJSON allows the tags to be unmarshalled from a key/value object, as defined by the overpass osmjson.
type Type ¶
type Type string
Type is the type of different osm objects. ie. node, way, relation, changeset, note, user.
type Update ¶
type Update struct { Index int `xml:"index,attr" json:"index"` Version int `xml:"version,attr" json:"version"` // Timestamp is the committed at time if time > CommitInfoStart or the // element timestamp if before that date. Timestamp time.Time `xml:"timestamp,attr" json:"timestamp"` ChangesetID ChangesetID `xml:"changeset,attr,omitempty" json:"changeset,omitempty"` Lat float64 `xml:"lat,attr,omitempty" json:"lat,omitempty"` Lon float64 `xml:"lon,attr,omitempty" json:"lon,omitempty"` Reverse bool `xml:"reverse,attr,omitempty" json:"reverse,omitempty"` }
An Update is a change to children of a way or relation. The child type, id, ref and/or role are the same as the child at the given index. Lon/Lat are only updated for nodes.
type UpdateIndexOutOfRangeError ¶
type UpdateIndexOutOfRangeError struct {
Index int
}
UpdateIndexOutOfRangeError is return when applying an update to an object and the update index is out of range.
func (*UpdateIndexOutOfRangeError) Error ¶
func (e *UpdateIndexOutOfRangeError) Error() string
Error returns a string representation of the error.
type Updates ¶
type Updates []Update
Updates are collections of updates.
func (Updates) SortByIndex ¶
func (us Updates) SortByIndex()
SortByIndex will sort the updates by index in ascending order.
func (Updates) SortByTimestamp ¶
func (us Updates) SortByTimestamp()
SortByTimestamp will sort the updates by timestamp in ascending order.
type User ¶
type User struct { XMLName xmlNameJSONTypeUser `xml:"user" json:"type"` ID UserID `xml:"id,attr" json:"id"` Name string `xml:"display_name,attr" json:"name"` Description string `xml:"description" json:"description,omitempty"` Img struct { Href string `xml:"href,attr" json:"href"` } `xml:"img" json:"img"` Changesets struct { Count int `xml:"count,attr" json:"count"` } `xml:"changesets" json:"changesets"` Traces struct { Count int `xml:"count,attr" json:"count"` } `xml:"traces" json:"traces"` Home struct { Lat float64 `xml:"lat,attr" json:"lat"` Lon float64 `xml:"lon,attr" json:"lon"` Zoom int `xml:"zoom,attr" json:"zoom"` } `xml:"home" json:"home"` Languages []string `xml:"languages>lang" json:"languages"` Blocks struct { Received struct { Count int `xml:"count,attr" json:"count"` Active int `xml:"active,attr" json:"active"` } `xml:"received" json:"received"` } `xml:"blocks" json:"blocks"` Messages struct { Received struct { Count int `xml:"count,attr" json:"count"` Unread int `xml:"unread,attr" json:"unread"` } `xml:"received" json:"received"` Sent struct { Count int `xml:"count,attr" json:"count"` } `xml:"sent" json:"sent"` } `xml:"messages" json:"messages"` CreatedAt time.Time `xml:"account_created,attr" json:"created_at"` }
A User is a registered OSM user.
type UserID ¶
type UserID int64
UserID is the primary key for a user. This is unique as the display name may change.
type Way ¶
type Way struct { XMLName xmlNameJSONTypeWay `xml:"way" json:"type"` ID WayID `xml:"id,attr" json:"id"` User string `xml:"user,attr" json:"user,omitempty"` UserID UserID `xml:"uid,attr" json:"uid,omitempty"` Visible bool `xml:"visible,attr" json:"visible"` Version int `xml:"version,attr" json:"version,omitempty"` ChangesetID ChangesetID `xml:"changeset,attr" json:"changeset,omitempty"` Timestamp time.Time `xml:"timestamp,attr" json:"timestamp"` Nodes WayNodes `xml:"nd" json:"nodes"` Tags Tags `xml:"tag" json:"tags,omitempty"` // Committed, is the estimated time this object was committed // and made visible in the central OSM database. Committed *time.Time `xml:"committed,attr,omitempty" json:"committed,omitempty"` // Updates are changes to the nodes of this way independent // of an update to the way itself. The OSM api allows a child // to be updated without any changes to the parent. Updates Updates `xml:"update,omitempty" json:"updates,omitempty"` // Bounds are included by overpass, and maybe others Bounds *Bounds `xml:"bounds,omitempty" json:"bounds,omitempty"` }
Way is an osm way, ie collection of nodes.
func (*Way) ApplyUpdatesUpTo ¶
ApplyUpdatesUpTo will apply the updates to this object upto and including the given time.
func (*Way) CommittedAt ¶
CommittedAt returns the best estimate on when this element became was written/committed into the database.
func (*Way) LineString ¶
func (w *Way) LineString() orb.LineString
LineString will convert the annotated nodes into a LineString datatype.
func (*Way) LineStringAt ¶
func (w *Way) LineStringAt(t time.Time) orb.LineString
LineStringAt will return the LineString from the annotated points at the given time. It will apply to the updates upto and including the give time.
func (*Way) Polygon ¶
Polygon returns true if the way should be considered a closed polygon area. OpenStreetMap doesn't have an intrinsic area data type. The algorithm used here considers a set of heuristics to determine what is most likely an area. The heuristics can be found here, https://wiki.openstreetmap.org/wiki/Overpass_turbo/Polygon_Features and are used by osmtogeojson and overpass turbo.
type WayID ¶
type WayID int64
WayID is the primary key of a way. A way is uniquely identifiable by the id + version.
type WayNode ¶
type WayNode struct { ID NodeID `xml:"ref,attr,omitempty"` // These attributes are populated for concrete versions of ways. Version int `xml:"version,attr,omitempty"` ChangesetID ChangesetID `xml:"changeset,attr,omitempty"` Lat float64 `xml:"lat,attr,omitempty"` Lon float64 `xml:"lon,attr,omitempty"` }
WayNode is a short node used as part of ways and relations in the osm xml.
type WayNodes ¶
type WayNodes []WayNode
WayNodes represents a collection of way nodes.
func (WayNodes) ElementIDs ¶
func (wn WayNodes) ElementIDs() ElementIDs
ElementIDs returns a list of element ids for the way nodes.
func (WayNodes) FeatureIDs ¶
func (wn WayNodes) FeatureIDs() FeatureIDs
FeatureIDs returns a list of feature ids for the way nodes.
func (WayNodes) MarshalJSON ¶
MarshalJSON allows the waynodes to be marshalled as an array of ids, as defined by the overpass osmjson.
func (*WayNodes) UnmarshalJSON ¶
UnmarshalJSON allows the tags to be unmarshalled from an array of ids, as defined by the overpass osmjson.
type Ways ¶
type Ways []*Way
Ways is a list of osm ways with some helper functions attached.
func (Ways) ElementIDs ¶
func (ws Ways) ElementIDs() ElementIDs
ElementIDs returns the element ids for all the ways.
func (Ways) FeatureIDs ¶
func (ws Ways) FeatureIDs() FeatureIDs
FeatureIDs returns the feature ids for all the ways.
func (Ways) SortByIDVersion ¶
func (ws Ways) SortByIDVersion()
SortByIDVersion will sort the set of ways first by id and then version in ascending order.