Applying VersionedOGC pattern to WMSDescribeLayer format
The WMSDescribeLayer format currently differs from other formats that inhreit from VersionedOGC by having an array instead of an object as return type. This especially bad since the VersionedOGC superclass sets a version property on the array. With this change, the WMSDescribeLayer format will also be compatible with GeoServer's new JSON response type for DescribeLayer - see http://sourceforge.net/mailarchive/message.php?msg_id=29912776. Another change included here is the removal of the WMSDescribeLayer format's getVersion hack, which was replaced by a generic fallback to less generic parsers, e.g. from a v1_1_1 parser to a v1_1 parser if v1_1_1 is not implemented.
This commit is contained in:
@@ -23,28 +23,6 @@ OpenLayers.Format.WMSDescribeLayer = OpenLayers.Class(OpenLayers.Format.XML.Vers
|
||||
*/
|
||||
defaultVersion: "1.1.1",
|
||||
|
||||
/**
|
||||
* Method: getVersion
|
||||
* Returns the version to use. Subclasses can override this function
|
||||
* if a different version detection is needed.
|
||||
*
|
||||
* Parameters:
|
||||
* root - {DOMElement}
|
||||
* options - {Object} Optional configuration object.
|
||||
*
|
||||
* Returns:
|
||||
* {String} The version to use.
|
||||
*/
|
||||
getVersion: function(root, options) {
|
||||
var version = OpenLayers.Format.XML.VersionedOGC.prototype.getVersion.apply(
|
||||
this, arguments);
|
||||
// these are identical to us, but some WMS use 1.1.1 and some use 1.1.0
|
||||
if (version == "1.1.1" || version == "1.1.0") {
|
||||
version = "1.1";
|
||||
}
|
||||
return version;
|
||||
},
|
||||
|
||||
/**
|
||||
* Constructor: OpenLayers.Format.WMSDescribeLayer
|
||||
* Create a new parser for WMS DescribeLayer responses.
|
||||
|
||||
@@ -45,10 +45,12 @@ OpenLayers.Format.WMSDescribeLayer.v1_1 = OpenLayers.Class(
|
||||
* data - {String} or {DOMElement} data to read/parse.
|
||||
*
|
||||
* Returns:
|
||||
* {Array} Array of {<LayerDescription>} objects which have:
|
||||
* {Object} Object with a layerDescriptions property, which holds an Array
|
||||
* of {<LayerDescription>} objects which have:
|
||||
* - {String} owsType: WFS/WCS
|
||||
* - {String} owsURL: the online resource
|
||||
* - {String} typeName: the name of the typename on the service
|
||||
* - {String} typeName: the name of the typename on the owsType service
|
||||
* - {String} layerName: the name of the WMS layer we did a lookup for
|
||||
*/
|
||||
read: function(data) {
|
||||
if(typeof data == "string") {
|
||||
@@ -56,7 +58,7 @@ OpenLayers.Format.WMSDescribeLayer.v1_1 = OpenLayers.Class(
|
||||
}
|
||||
var root = data.documentElement;
|
||||
var children = root.childNodes;
|
||||
var describelayer = [];
|
||||
var describelayer = {layerDescriptions: []};
|
||||
var childNode, nodeName;
|
||||
for(var i=0; i<children.length; ++i) {
|
||||
childNode = children[i];
|
||||
@@ -89,8 +91,16 @@ OpenLayers.Format.WMSDescribeLayer.v1_1 = OpenLayers.Class(
|
||||
typeName = query[0].getAttribute('typename');
|
||||
}
|
||||
}
|
||||
describelayer.push({layerName: layerName, owsType: owsType,
|
||||
owsURL: owsURL, typeName: typeName});
|
||||
var layerDescription = {
|
||||
layerName: layerName, owsType: owsType,
|
||||
owsURL: owsURL, typeName: typeName
|
||||
};
|
||||
describelayer.layerDescriptions.push(layerDescription);
|
||||
|
||||
// deprecated array style index for backwards compatibility
|
||||
describelayer.length = describelayer.layerDescriptions.length;
|
||||
describelayer[describelayer.length - 1] = layerDescription;
|
||||
|
||||
} else if (nodeName == 'ServiceException') {
|
||||
// an exception must have occurred, so parse it
|
||||
var parser = new OpenLayers.Format.OGCExceptionReport();
|
||||
|
||||
@@ -127,6 +127,11 @@ OpenLayers.Format.XML.VersionedOGC = OpenLayers.Class(OpenLayers.Format.XML, {
|
||||
var format = OpenLayers.Format[this.name][
|
||||
"v" + version.replace(/\./g, "_") + profile
|
||||
];
|
||||
if (!format && ~version.indexOf('.')) {
|
||||
// falling back to less specific parser
|
||||
return this.getParser(
|
||||
version.substr(0, version.lastIndexOf('.')));
|
||||
}
|
||||
if(!format) {
|
||||
throw "Can't find a " + this.name + " parser for version " +
|
||||
version + profile;
|
||||
|
||||
Reference in New Issue
Block a user