summaryrefslogtreecommitdiff
path: root/misc/openlayers/lib/OpenLayers/Format/GML/Base.js
diff options
context:
space:
mode:
authorChris Schlaeger <chris@linux.com>2015-10-17 21:36:38 +0200
committerChris Schlaeger <chris@linux.com>2015-10-17 21:36:38 +0200
commite30f267181d990947e67909de4809fa941698c85 (patch)
tree46e9f94c2b3699ed378963b420b8a8d361286ea1 /misc/openlayers/lib/OpenLayers/Format/GML/Base.js
parente763ceb183f389fcd314a4a6a712d87c9d4cdb32 (diff)
downloadpostrunner-e30f267181d990947e67909de4809fa941698c85.zip
Upgrading openlayers to 3.x
Diffstat (limited to 'misc/openlayers/lib/OpenLayers/Format/GML/Base.js')
-rw-r--r--misc/openlayers/lib/OpenLayers/Format/GML/Base.js645
1 files changed, 0 insertions, 645 deletions
diff --git a/misc/openlayers/lib/OpenLayers/Format/GML/Base.js b/misc/openlayers/lib/OpenLayers/Format/GML/Base.js
deleted file mode 100644
index 6c49969..0000000
--- a/misc/openlayers/lib/OpenLayers/Format/GML/Base.js
+++ /dev/null
@@ -1,645 +0,0 @@
-/* Copyright (c) 2006-2013 by OpenLayers Contributors (see authors.txt for
- * full list of contributors). Published under the 2-clause BSD license.
- * See license.txt in the OpenLayers distribution or repository for the
- * full text of the license. */
-
-/**
- * @requires OpenLayers/Format/XML.js
- * @requires OpenLayers/Format/GML.js
- */
-
-/**
- * Though required in the full build, if the GML format is excluded, we set
- * the namespace here.
- */
-if(!OpenLayers.Format.GML) {
- OpenLayers.Format.GML = {};
-}
-
-/**
- * Class: OpenLayers.Format.GML.Base
- * Superclass for GML parsers.
- *
- * Inherits from:
- * - <OpenLayers.Format.XML>
- */
-OpenLayers.Format.GML.Base = OpenLayers.Class(OpenLayers.Format.XML, {
-
- /**
- * Property: namespaces
- * {Object} Mapping of namespace aliases to namespace URIs.
- */
- namespaces: {
- gml: "http://www.opengis.net/gml",
- xlink: "http://www.w3.org/1999/xlink",
- xsi: "http://www.w3.org/2001/XMLSchema-instance",
- wfs: "http://www.opengis.net/wfs" // this is a convenience for reading wfs:FeatureCollection
- },
-
- /**
- * Property: defaultPrefix
- */
- defaultPrefix: "gml",
-
- /**
- * Property: schemaLocation
- * {String} Schema location for a particular minor version.
- */
- schemaLocation: null,
-
- /**
- * APIProperty: featureType
- * {Array(String) or String} The local (without prefix) feature typeName(s).
- */
- featureType: null,
-
- /**
- * APIProperty: featureNS
- * {String} The feature namespace. Must be set in the options at
- * construction.
- */
- featureNS: null,
-
- /**
- * APIProperty: geometry
- * {String} Name of geometry element. Defaults to "geometry". If null, it
- * will be set on <read> when the first geometry is parsed.
- */
- geometryName: "geometry",
-
- /**
- * APIProperty: extractAttributes
- * {Boolean} Extract attributes from GML. Default is true.
- */
- extractAttributes: true,
-
- /**
- * APIProperty: srsName
- * {String} URI for spatial reference system. This is optional for
- * single part geometries and mandatory for collections and multis.
- * If set, the srsName attribute will be written for all geometries.
- * Default is null.
- */
- srsName: null,
-
- /**
- * APIProperty: xy
- * {Boolean} Order of the GML coordinate true:(x,y) or false:(y,x)
- * Changing is not recommended, a new Format should be instantiated.
- */
- xy: true,
-
- /**
- * Property: geometryTypes
- * {Object} Maps OpenLayers geometry class names to GML element names.
- * Use <setGeometryTypes> before accessing this property.
- */
- geometryTypes: null,
-
- /**
- * Property: singleFeatureType
- * {Boolean} True if there is only 1 featureType, and not an array
- * of featuretypes.
- */
- singleFeatureType: null,
-
- /**
- * Property: autoConfig
- * {Boolean} Indicates if the format was configured without a <featureNS>,
- * but auto-configured <featureNS> and <featureType> during read.
- * Subclasses making use of <featureType> auto-configuration should make
- * the first call to the <readNode> method (usually in the read method)
- * with true as 3rd argument, so the auto-configured featureType can be
- * reset and the format can be reused for subsequent reads with data from
- * different featureTypes. Set to false after read if you want to keep the
- * auto-configured values.
- */
-
- /**
- * Property: regExes
- * Compiled regular expressions for manipulating strings.
- */
- regExes: {
- trimSpace: (/^\s*|\s*$/g),
- removeSpace: (/\s*/g),
- splitSpace: (/\s+/),
- trimComma: (/\s*,\s*/g),
- featureMember: (/^(.*:)?featureMembers?$/)
- },
-
- /**
- * Constructor: OpenLayers.Format.GML.Base
- * Instances of this class are not created directly. Use the
- * <OpenLayers.Format.GML.v2> or <OpenLayers.Format.GML.v3> constructor
- * instead.
- *
- * Parameters:
- * options - {Object} An optional object whose properties will be set on
- * this instance.
- *
- * Valid options properties:
- * featureType - {Array(String) or String} Local (without prefix) feature
- * typeName(s) (required for write).
- * featureNS - {String} Feature namespace (required for write).
- * geometryName - {String} Geometry element name (required for write).
- */
- initialize: function(options) {
- OpenLayers.Format.XML.prototype.initialize.apply(this, [options]);
- this.setGeometryTypes();
- if(options && options.featureNS) {
- this.setNamespace("feature", options.featureNS);
- }
- this.singleFeatureType = !options || (typeof options.featureType === "string");
- },
-
- /**
- * Method: read
- *
- * Parameters:
- * data - {DOMElement} A gml:featureMember element, a gml:featureMembers
- * element, or an element containing either of the above at any level.
- *
- * Returns:
- * {Array(<OpenLayers.Feature.Vector>)} An array of features.
- */
- read: function(data) {
- if(typeof data == "string") {
- data = OpenLayers.Format.XML.prototype.read.apply(this, [data]);
- }
- if(data && data.nodeType == 9) {
- data = data.documentElement;
- }
- var features = [];
- this.readNode(data, {features: features}, true);
- if(features.length == 0) {
- // look for gml:featureMember elements
- var elements = this.getElementsByTagNameNS(
- data, this.namespaces.gml, "featureMember"
- );
- if(elements.length) {
- for(var i=0, len=elements.length; i<len; ++i) {
- this.readNode(elements[i], {features: features}, true);
- }
- } else {
- // look for gml:featureMembers elements (this is v3, but does no harm here)
- var elements = this.getElementsByTagNameNS(
- data, this.namespaces.gml, "featureMembers"
- );
- if(elements.length) {
- // there can be only one
- this.readNode(elements[0], {features: features}, true);
- }
- }
- }
- return features;
- },
-
- /**
- * Method: readNode
- * Shorthand for applying one of the named readers given the node
- * namespace and local name. Readers take two args (node, obj) and
- * generally extend or modify the second.
- *
- * Parameters:
- * node - {DOMElement} The node to be read (required).
- * obj - {Object} The object to be modified (optional).
- * first - {Boolean} Should be set to true for the first node read. This
- * is usually the readNode call in the read method. Without this being
- * set, auto-configured properties will stick on subsequent reads.
- *
- * Returns:
- * {Object} The input object, modified (or a new one if none was provided).
- */
- readNode: function(node, obj, first) {
- // on subsequent calls of format.read(), we want to reset auto-
- // configured properties and auto-configure again.
- if (first === true && this.autoConfig === true) {
- this.featureType = null;
- delete this.namespaceAlias[this.featureNS];
- delete this.namespaces["feature"];
- this.featureNS = null;
- }
- // featureType auto-configuration
- if (!this.featureNS && (!(node.prefix in this.namespaces) &&
- node.parentNode.namespaceURI == this.namespaces["gml"] &&
- this.regExes.featureMember.test(node.parentNode.nodeName))) {
- this.featureType = node.nodeName.split(":").pop();
- this.setNamespace("feature", node.namespaceURI);
- this.featureNS = node.namespaceURI;
- this.autoConfig = true;
- }
- return OpenLayers.Format.XML.prototype.readNode.apply(this, [node, obj]);
- },
-
- /**
- * Property: readers
- * Contains public functions, grouped by namespace prefix, that will
- * be applied when a namespaced node is found matching the function
- * name. The function will be applied in the scope of this parser
- * with two arguments: the node being read and a context object passed
- * from the parent.
- */
- readers: {
- "gml": {
- "_inherit": function(node, obj, container) {
- // To be implemented by version specific parsers
- },
- "featureMember": function(node, obj) {
- this.readChildNodes(node, obj);
- },
- "featureMembers": function(node, obj) {
- this.readChildNodes(node, obj);
- },
- "name": function(node, obj) {
- obj.name = this.getChildValue(node);
- },
- "boundedBy": function(node, obj) {
- var container = {};
- this.readChildNodes(node, container);
- if(container.components && container.components.length > 0) {
- obj.bounds = container.components[0];
- }
- },
- "Point": function(node, container) {
- var obj = {points: []};
- this.readChildNodes(node, obj);
- if(!container.components) {
- container.components = [];
- }
- container.components.push(obj.points[0]);
- },
- "coordinates": function(node, obj) {
- var str = this.getChildValue(node).replace(
- this.regExes.trimSpace, ""
- );
- str = str.replace(this.regExes.trimComma, ",");
- var pointList = str.split(this.regExes.splitSpace);
- var coords;
- var numPoints = pointList.length;
- var points = new Array(numPoints);
- for(var i=0; i<numPoints; ++i) {
- coords = pointList[i].split(",");
- if (this.xy) {
- points[i] = new OpenLayers.Geometry.Point(
- coords[0], coords[1], coords[2]
- );
- } else {
- points[i] = new OpenLayers.Geometry.Point(
- coords[1], coords[0], coords[2]
- );
- }
- }
- obj.points = points;
- },
- "coord": function(node, obj) {
- var coord = {};
- this.readChildNodes(node, coord);
- if(!obj.points) {
- obj.points = [];
- }
- obj.points.push(new OpenLayers.Geometry.Point(
- coord.x, coord.y, coord.z
- ));
- },
- "X": function(node, coord) {
- coord.x = this.getChildValue(node);
- },
- "Y": function(node, coord) {
- coord.y = this.getChildValue(node);
- },
- "Z": function(node, coord) {
- coord.z = this.getChildValue(node);
- },
- "MultiPoint": function(node, container) {
- var obj = {components: []};
- this.readers.gml._inherit.apply(this, [node, obj, container]);
- this.readChildNodes(node, obj);
- container.components = [
- new OpenLayers.Geometry.MultiPoint(obj.components)
- ];
- },
- "pointMember": function(node, obj) {
- this.readChildNodes(node, obj);
- },
- "LineString": function(node, container) {
- var obj = {};
- this.readers.gml._inherit.apply(this, [node, obj, container]);
- this.readChildNodes(node, obj);
- if(!container.components) {
- container.components = [];
- }
- container.components.push(
- new OpenLayers.Geometry.LineString(obj.points)
- );
- },
- "MultiLineString": function(node, container) {
- var obj = {components: []};
- this.readers.gml._inherit.apply(this, [node, obj, container]);
- this.readChildNodes(node, obj);
- container.components = [
- new OpenLayers.Geometry.MultiLineString(obj.components)
- ];
- },
- "lineStringMember": function(node, obj) {
- this.readChildNodes(node, obj);
- },
- "Polygon": function(node, container) {
- var obj = {outer: null, inner: []};
- this.readers.gml._inherit.apply(this, [node, obj, container]);
- this.readChildNodes(node, obj);
- obj.inner.unshift(obj.outer);
- if(!container.components) {
- container.components = [];
- }
- container.components.push(
- new OpenLayers.Geometry.Polygon(obj.inner)
- );
- },
- "LinearRing": function(node, obj) {
- var container = {};
- this.readers.gml._inherit.apply(this, [node, container]);
- this.readChildNodes(node, container);
- obj.components = [new OpenLayers.Geometry.LinearRing(
- container.points
- )];
- },
- "MultiPolygon": function(node, container) {
- var obj = {components: []};
- this.readers.gml._inherit.apply(this, [node, obj, container]);
- this.readChildNodes(node, obj);
- container.components = [
- new OpenLayers.Geometry.MultiPolygon(obj.components)
- ];
- },
- "polygonMember": function(node, obj) {
- this.readChildNodes(node, obj);
- },
- "GeometryCollection": function(node, container) {
- var obj = {components: []};
- this.readers.gml._inherit.apply(this, [node, obj, container]);
- this.readChildNodes(node, obj);
- container.components = [
- new OpenLayers.Geometry.Collection(obj.components)
- ];
- },
- "geometryMember": function(node, obj) {
- this.readChildNodes(node, obj);
- }
- },
- "feature": {
- "*": function(node, obj) {
- // The node can either be named like the featureType, or it
- // can be a child of the feature:featureType. Children can be
- // geometry or attributes.
- var name;
- var local = node.localName || node.nodeName.split(":").pop();
- // Since an attribute can have the same name as the feature type
- // we only want to read the node as a feature if the parent
- // node can have feature nodes as children. In this case, the
- // obj.features property is set.
- if (obj.features) {
- if (!this.singleFeatureType &&
- (OpenLayers.Util.indexOf(this.featureType, local) !== -1)) {
- name = "_typeName";
- } else if(local === this.featureType) {
- name = "_typeName";
- }
- } else {
- // Assume attribute elements have one child node and that the child
- // is a text node. Otherwise assume it is a geometry node.
- if(node.childNodes.length == 0 ||
- (node.childNodes.length == 1 && node.firstChild.nodeType == 3)) {
- if(this.extractAttributes) {
- name = "_attribute";
- }
- } else {
- name = "_geometry";
- }
- }
- if(name) {
- this.readers.feature[name].apply(this, [node, obj]);
- }
- },
- "_typeName": function(node, obj) {
- var container = {components: [], attributes: {}};
- this.readChildNodes(node, container);
- // look for common gml namespaced elements
- if(container.name) {
- container.attributes.name = container.name;
- }
- var feature = new OpenLayers.Feature.Vector(
- container.components[0], container.attributes
- );
- if (!this.singleFeatureType) {
- feature.type = node.nodeName.split(":").pop();
- feature.namespace = node.namespaceURI;
- }
- var fid = node.getAttribute("fid") ||
- this.getAttributeNS(node, this.namespaces["gml"], "id");
- if(fid) {
- feature.fid = fid;
- }
- if(this.internalProjection && this.externalProjection &&
- feature.geometry) {
- feature.geometry.transform(
- this.externalProjection, this.internalProjection
- );
- }
- if(container.bounds) {
- feature.bounds = container.bounds;
- }
- obj.features.push(feature);
- },
- "_geometry": function(node, obj) {
- if (!this.geometryName) {
- this.geometryName = node.nodeName.split(":").pop();
- }
- this.readChildNodes(node, obj);
- },
- "_attribute": function(node, obj) {
- var local = node.localName || node.nodeName.split(":").pop();
- var value = this.getChildValue(node);
- obj.attributes[local] = value;
- }
- },
- "wfs": {
- "FeatureCollection": function(node, obj) {
- this.readChildNodes(node, obj);
- }
- }
- },
-
- /**
- * Method: write
- *
- * Parameters:
- * features - {Array(<OpenLayers.Feature.Vector>) | OpenLayers.Feature.Vector}
- * An array of features or a single feature.
- *
- * Returns:
- * {String} Given an array of features, a doc with a gml:featureMembers
- * element will be returned. Given a single feature, a doc with a
- * gml:featureMember element will be returned.
- */
- write: function(features) {
- var name;
- if(OpenLayers.Util.isArray(features)) {
- name = "featureMembers";
- } else {
- name = "featureMember";
- }
- var root = this.writeNode("gml:" + name, features);
- this.setAttributeNS(
- root, this.namespaces["xsi"],
- "xsi:schemaLocation", this.schemaLocation
- );
-
- return OpenLayers.Format.XML.prototype.write.apply(this, [root]);
- },
-
- /**
- * Property: writers
- * As a compliment to the readers property, this structure contains public
- * writing functions grouped by namespace alias and named like the
- * node names they produce.
- */
- writers: {
- "gml": {
- "featureMember": function(feature) {
- var node = this.createElementNSPlus("gml:featureMember");
- this.writeNode("feature:_typeName", feature, node);
- return node;
- },
- "MultiPoint": function(geometry) {
- var node = this.createElementNSPlus("gml:MultiPoint");
- var components = geometry.components || [geometry];
- for(var i=0, ii=components.length; i<ii; ++i) {
- this.writeNode("pointMember", components[i], node);
- }
- return node;
- },
- "pointMember": function(geometry) {
- var node = this.createElementNSPlus("gml:pointMember");
- this.writeNode("Point", geometry, node);
- return node;
- },
- "MultiLineString": function(geometry) {
- var node = this.createElementNSPlus("gml:MultiLineString");
- var components = geometry.components || [geometry];
- for(var i=0, ii=components.length; i<ii; ++i) {
- this.writeNode("lineStringMember", components[i], node);
- }
- return node;
- },
- "lineStringMember": function(geometry) {
- var node = this.createElementNSPlus("gml:lineStringMember");
- this.writeNode("LineString", geometry, node);
- return node;
- },
- "MultiPolygon": function(geometry) {
- var node = this.createElementNSPlus("gml:MultiPolygon");
- var components = geometry.components || [geometry];
- for(var i=0, ii=components.length; i<ii; ++i) {
- this.writeNode(
- "polygonMember", components[i], node
- );
- }
- return node;
- },
- "polygonMember": function(geometry) {
- var node = this.createElementNSPlus("gml:polygonMember");
- this.writeNode("Polygon", geometry, node);
- return node;
- },
- "GeometryCollection": function(geometry) {
- var node = this.createElementNSPlus("gml:GeometryCollection");
- for(var i=0, len=geometry.components.length; i<len; ++i) {
- this.writeNode("geometryMember", geometry.components[i], node);
- }
- return node;
- },
- "geometryMember": function(geometry) {
- var node = this.createElementNSPlus("gml:geometryMember");
- var child = this.writeNode("feature:_geometry", geometry);
- node.appendChild(child.firstChild);
- return node;
- }
- },
- "feature": {
- "_typeName": function(feature) {
- var node = this.createElementNSPlus("feature:" + this.featureType, {
- attributes: {fid: feature.fid}
- });
- if(feature.geometry) {
- this.writeNode("feature:_geometry", feature.geometry, node);
- }
- for(var name in feature.attributes) {
- var value = feature.attributes[name];
- if(value != null) {
- this.writeNode(
- "feature:_attribute",
- {name: name, value: value}, node
- );
- }
- }
- return node;
- },
- "_geometry": function(geometry) {
- if(this.externalProjection && this.internalProjection) {
- geometry = geometry.clone().transform(
- this.internalProjection, this.externalProjection
- );
- }
- var node = this.createElementNSPlus(
- "feature:" + this.geometryName
- );
- var type = this.geometryTypes[geometry.CLASS_NAME];
- var child = this.writeNode("gml:" + type, geometry, node);
- if(this.srsName) {
- child.setAttribute("srsName", this.srsName);
- }
- return node;
- },
- "_attribute": function(obj) {
- return this.createElementNSPlus("feature:" + obj.name, {
- value: obj.value
- });
- }
- },
- "wfs": {
- "FeatureCollection": function(features) {
- /**
- * This is only here because GML2 only describes abstract
- * feature collections. Typically, you would not be using
- * the GML format to write wfs elements. This just provides
- * some way to write out lists of features. GML3 defines the
- * featureMembers element, so that is used by default instead.
- */
- var node = this.createElementNSPlus("wfs:FeatureCollection");
- for(var i=0, len=features.length; i<len; ++i) {
- this.writeNode("gml:featureMember", features[i], node);
- }
- return node;
- }
- }
- },
-
- /**
- * Method: setGeometryTypes
- * Sets the <geometryTypes> mapping.
- */
- setGeometryTypes: function() {
- this.geometryTypes = {
- "OpenLayers.Geometry.Point": "Point",
- "OpenLayers.Geometry.MultiPoint": "MultiPoint",
- "OpenLayers.Geometry.LineString": "LineString",
- "OpenLayers.Geometry.MultiLineString": "MultiLineString",
- "OpenLayers.Geometry.Polygon": "Polygon",
- "OpenLayers.Geometry.MultiPolygon": "MultiPolygon",
- "OpenLayers.Geometry.Collection": "GeometryCollection"
- };
- },
-
- CLASS_NAME: "OpenLayers.Format.GML.Base"
-
-});