Add scope and type checking to ol.reader.GeoJSON
This commit is contained in:
@@ -54,13 +54,16 @@ ol.reader.GeoJSON.readPolygonGeometry_ = function(geometry) {
|
||||
|
||||
|
||||
/**
|
||||
* @param {GeoJSONFeature} feature Feature.
|
||||
* @param {function(ol.Feature): *} callback Callback.
|
||||
* @param {GeoJSONObject} object Object.
|
||||
* @param {function(this: S, ol.Feature): T} callback Callback.
|
||||
* @param {S=} opt_obj Scope.
|
||||
* @private
|
||||
* @return {*} Callback result.
|
||||
* @return {T} Callback result.
|
||||
* @template S,T
|
||||
*/
|
||||
ol.reader.GeoJSON.readFeature_ = function(feature, callback) {
|
||||
goog.asserts.assert(feature.type == 'Feature');
|
||||
ol.reader.GeoJSON.readFeature_ = function(object, callback, opt_obj) {
|
||||
goog.asserts.assert(object.type == 'Feature');
|
||||
var feature = /** @type {GeoJSONFeature} */ (object);
|
||||
var geometryReader =
|
||||
ol.reader.GeoJSON.GEOMETRY_READERS_[feature.geometry.type];
|
||||
goog.asserts.assert(goog.isDef(geometryReader));
|
||||
@@ -69,23 +72,25 @@ ol.reader.GeoJSON.readFeature_ = function(feature, callback) {
|
||||
if (goog.isDef(feature.properties)) {
|
||||
f.setValues(feature.properties);
|
||||
}
|
||||
return callback(f);
|
||||
return callback.call(opt_obj, f);
|
||||
};
|
||||
|
||||
|
||||
/**
|
||||
* @param {GeoJSONFeatureCollection} featureCollection Feature collection.
|
||||
* @param {function(ol.Feature): *} callback Callback.
|
||||
* @param {GeoJSONObject} object Object.
|
||||
* @param {function(this: S, ol.Feature): T} callback Callback.
|
||||
* @param {S=} opt_obj Scope.
|
||||
* @private
|
||||
* @return {*} Callback result.
|
||||
* @return {T|undefined} Callback result.
|
||||
* @template S,T
|
||||
*/
|
||||
ol.reader.GeoJSON.readFeatureCollection_ =
|
||||
function(featureCollection, callback) {
|
||||
goog.asserts.assert(featureCollection.type == 'FeatureCollection');
|
||||
ol.reader.GeoJSON.readFeatureCollection_ = function(object, callback, opt_obj) {
|
||||
goog.asserts.assert(object.type == 'FeatureCollection');
|
||||
var featureCollection = /** @type {GeoJSONFeatureCollection} */ (object);
|
||||
var features = featureCollection.features;
|
||||
var i, ii;
|
||||
for (i = 0, ii = features.length; i < ii; ++i) {
|
||||
var result = ol.reader.GeoJSON.readFeature_(features[i], callback);
|
||||
var result = ol.reader.GeoJSON.readFeature_(features[i], callback, opt_obj);
|
||||
if (result) {
|
||||
return result;
|
||||
}
|
||||
@@ -96,22 +101,26 @@ ol.reader.GeoJSON.readFeatureCollection_ =
|
||||
|
||||
/**
|
||||
* @param {GeoJSONObject} object Object.
|
||||
* @param {function(ol.Feature): *} callback Callback.
|
||||
* @return {*} Callback result.
|
||||
* @param {function(this: S, ol.Feature): T} callback Callback.
|
||||
* @param {S=} opt_obj Scope.
|
||||
* @return {T} Callback result.
|
||||
* @template S,T
|
||||
*/
|
||||
ol.reader.GeoJSON.readObject = function(object, callback) {
|
||||
ol.reader.GeoJSON.readObject = function(object, callback, opt_obj) {
|
||||
var objectReader = ol.reader.GeoJSON.OBJECT_READERS_[object.type];
|
||||
goog.asserts.assert(goog.isDef(objectReader));
|
||||
return objectReader(object, callback);
|
||||
return objectReader(object, callback, opt_obj);
|
||||
};
|
||||
|
||||
|
||||
/**
|
||||
* @param {string} string String.
|
||||
* @param {function(ol.Feature): *} callback Callback.
|
||||
* @return {*} Callback result.
|
||||
* @param {function(ol.Feature): T} callback Callback.
|
||||
* @param {S=} opt_obj Scope.
|
||||
* @return {T} Callback result.
|
||||
* @template S,T
|
||||
*/
|
||||
ol.reader.GeoJSON.readString = function(string, callback) {
|
||||
ol.reader.GeoJSON.readString = function(string, callback, opt_obj) {
|
||||
var object = goog.json.parse(string);
|
||||
return ol.reader.GeoJSON.readObject(
|
||||
/** @type {GeoJSONObject} */ (object), callback);
|
||||
@@ -133,7 +142,7 @@ ol.reader.GeoJSON.GEOMETRY_READERS_ = {
|
||||
/**
|
||||
* @const
|
||||
* @private
|
||||
* @type {Object.<string, function(*, function(ol.Feature): *): *>}
|
||||
* @type {Object.<string, function(GeoJSONObject, function(ol.Feature): *, *): *>}
|
||||
*/
|
||||
ol.reader.GeoJSON.OBJECT_READERS_ = {
|
||||
'Feature': ol.reader.GeoJSON.readFeature_,
|
||||
|
||||
Reference in New Issue
Block a user