no way to pass read options from protocol to format, r=ahocevar,elemoine (closes #2656)

git-svn-id: http://svn.openlayers.org/trunk/openlayers@10703 dc9f47b5-9b13-0410-9fdd-eb0c1a62fdaf
This commit is contained in:
bartvde
2010-08-29 08:41:13 +00:00
parent 54fd1f561c
commit fd083d64d2
2 changed files with 54 additions and 9 deletions

View File

@@ -74,6 +74,12 @@ OpenLayers.Protocol.WFS.v1 = OpenLayers.Class(OpenLayers.Protocol, {
*/
readFormat: null,
/**
* Property: readOptions
* {Object} Optional object to pass to format's read.
*/
readOptions: null,
/**
* Constructor: OpenLayers.Protocol.WFS
* A class for giving layers WFS protocol.
@@ -173,7 +179,12 @@ OpenLayers.Protocol.WFS.v1 = OpenLayers.Class(OpenLayers.Protocol, {
var request = response.priv;
if(request.status >= 200 && request.status < 300) {
// success
response.features = this.parseFeatures(request);
if (this.readOptions && this.readOptions.output == "object") {
OpenLayers.Util.extend(response,
this.parseResponse(request, this.readOptions));
} else {
response.features = this.parseResponse(request);
}
response.code = OpenLayers.Protocol.Response.SUCCESS;
} else {
// failure
@@ -184,17 +195,20 @@ OpenLayers.Protocol.WFS.v1 = OpenLayers.Class(OpenLayers.Protocol, {
},
/**
* Method: parseFeatures
* Method: parseResponse
* Read HTTP response body and return features
*
* Parameters:
* request - {XMLHttpRequest} The request object
* options - {Object} Optional object to pass to format's read
*
* Returns:
* {Array({<OpenLayers.Feature.Vector>})} or
* {<OpenLayers.Feature.Vector>} Array of features or a single feature.
* {Object} or {Array({<OpenLayers.Feature.Vector>})} or
* {<OpenLayers.Feature.Vector>}
* An object with a features property, an array of features or a single
* feature.
*/
parseFeatures: function(request) {
parseResponse: function(request, options) {
var doc = request.responseXML;
if(!doc || !doc.documentElement) {
doc = request.responseText;
@@ -203,7 +217,7 @@ OpenLayers.Protocol.WFS.v1 = OpenLayers.Class(OpenLayers.Protocol, {
return null;
}
return (this.readFormat !== null) ? this.readFormat.read(doc) :
this.format.read(doc);
this.format.read(doc, options);
},
/**

View File

@@ -31,8 +31,8 @@
url: "http://some.url.org",
featureNS: "http://namespace.org",
featureType: "type",
parseFeatures: function(request) {
t.eq(request.responseText, "foo", "parseFeatures called properly");
parseResponse: function(request) {
t.eq(request.responseText, "foo", "parseResponse called properly");
return "foo";
}
});
@@ -225,10 +225,41 @@
var request = {};
request.responseText = '{"type":"FeatureCollection","features":[{"type":"Feature","id":"V_HECTOPUNTEN.108411","geometry":{"type":"MultiPoint","coordinates":[[190659.467,349576.19]]},"geometry_name":"ORA_GEOMETRY","properties":{"WEGNUMMER":"002","HECTOMTRNG_ORG":2200,"HECTOMTRNG":"220.00","bbox":[190659.467,349576.19,190659.467,349576.19]}}]}';
var features = protocol.parseFeatures(request);
var features = protocol.parseResponse(request);
t.eq(features.length, 1, "the right format is used to read the request (GeoJSON)");
}
function test_readOptions(t) {
t.plan(1);
var protocol = new OpenLayers.Protocol.WFS({
url: "http://some.url.org",
version: "1.1.0",
featureNS: "http://namespace.org",
featureType: "type",
readOptions: {'output': 'object'},
parseResponse: function(request, options) {
t.eq(options.output, "object", "Options object correctly set to pass on to Format's read");
}
});
var _POST = OpenLayers.Request.POST;
OpenLayers.Request.POST = function(obj) {
obj.status = 200;
obj.responseText = "foo";
obj.options = {};
t.delay_call(0.1, function() {obj.callback.call(this)});
return obj;
};
protocol.read({
callback: function() {}
});
OpenLayers.Request.POST = _POST;
}
function readXML(id) {
var xml = document.getElementById(id).firstChild.nodeValue;
return new OpenLayers.Format.XML().read(xml).documentElement;