Skip to content

Commit

Permalink
Parser base class
Browse files Browse the repository at this point in the history
GeoJSON is now a parser.  The idea is that we'll want to pass parsers to sources or protocols and want a known type.
  • Loading branch information
tschaub committed Mar 3, 2013
1 parent 93ab454 commit 69b6fae
Show file tree
Hide file tree
Showing 4 changed files with 75 additions and 33 deletions.
60 changes: 35 additions & 25 deletions src/ol/parser/geojson.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
goog.provide('ol.parser.geojson');
goog.provide('ol.parser.GeoJSON');

goog.require('ol.Feature');
goog.require('ol.geom.Geometry');
Expand All @@ -8,6 +8,16 @@ goog.require('ol.geom.MultiPoint');
goog.require('ol.geom.MultiPolygon');
goog.require('ol.geom.Point');
goog.require('ol.geom.Polygon');
goog.require('ol.parser.Parser');



/**
* @constructor
* @extends {ol.parser.Parser}
*/
ol.parser.GeoJSON = function() {};
goog.inherits(ol.parser.GeoJSON, ol.parser.Parser);


/**
Expand All @@ -17,10 +27,10 @@ goog.require('ol.geom.Polygon');
* ol.geom.Geometry|Array.<ol.geom.Geometry>} Parsed geometry or array
* of geometries.
*/
ol.parser.geojson.read = function(str) {
ol.parser.GeoJSON.prototype.read = function(str) {
// TODO: add options and accept projection
var json = /** @type {GeoJSONObject} */ (JSON.parse(str));
return ol.parser.geojson.parse_(json);
return ol.parser.GeoJSON.prototype.parse_(json);
};


Expand All @@ -31,43 +41,43 @@ ol.parser.geojson.read = function(str) {
* of geometries.
* @private
*/
ol.parser.geojson.parse_ = function(json) {
ol.parser.GeoJSON.prototype.parse_ = function(json) {
var result;
switch (json.type) {
case 'FeatureCollection':
result = ol.parser.geojson.parseFeatureCollection_(
result = this.parseFeatureCollection_(
/** @type {GeoJSONFeatureCollection} */ (json));
break;
case 'Feature':
result = ol.parser.geojson.parseFeature_(
result = this.parseFeature_(
/** @type {GeoJSONFeature} */ (json));
break;
case 'GeometryCollection':
result = ol.parser.geojson.parseGeometryCollection_(
result = this.parseGeometryCollection_(
/** @type {GeoJSONGeometryCollection} */ (json));
break;
case 'Point':
result = ol.parser.geojson.parsePoint_(
result = this.parsePoint_(
/** @type {GeoJSONGeometry} */ (json));
break;
case 'LineString':
result = ol.parser.geojson.parseLineString_(
result = this.parseLineString_(
/** @type {GeoJSONGeometry} */ (json));
break;
case 'Polygon':
result = ol.parser.geojson.parsePolygon_(
result = this.parsePolygon_(
/** @type {GeoJSONGeometry} */ (json));
break;
case 'MultiPoint':
result = ol.parser.geojson.parseMultiPoint_(
result = this.parseMultiPoint_(
/** @type {GeoJSONGeometry} */ (json));
break;
case 'MultiLineString':
result = ol.parser.geojson.parseMultiLineString_(
result = this.parseMultiLineString_(
/** @type {GeoJSONGeometry} */ (json));
break;
case 'MultiPolygon':
result = ol.parser.geojson.parseMultiPolygon_(
result = this.parseMultiPolygon_(
/** @type {GeoJSONGeometry} */ (json));
break;
default:
Expand All @@ -82,11 +92,11 @@ ol.parser.geojson.parse_ = function(json) {
* @return {ol.Feature} Parsed feature.
* @private
*/
ol.parser.geojson.parseFeature_ = function(json) {
ol.parser.GeoJSON.prototype.parseFeature_ = function(json) {
var geomJson = json.geometry,
geometry = null;
if (geomJson) {
geometry = /** @type {ol.geom.Geometry} */ (ol.parser.geojson.parse_(
geometry = /** @type {ol.geom.Geometry} */ (this.parse_(
/** @type {GeoJSONGeometry} */ (geomJson)));
}
var feature = new ol.Feature();
Expand All @@ -101,14 +111,14 @@ ol.parser.geojson.parseFeature_ = function(json) {
* @return {Array.<ol.Feature>} Parsed array of features.
* @private
*/
ol.parser.geojson.parseFeatureCollection_ = function(json) {
ol.parser.GeoJSON.prototype.parseFeatureCollection_ = function(json) {
var features = json.features,
len = features.length,
result = new Array(len),
i;

for (i = 0; i < len; ++i) {
result[i] = ol.parser.geojson.parse_(
result[i] = this.parse_(
/** @type {GeoJSONFeature} */ (features[i]));
}
return result;
Expand All @@ -120,14 +130,14 @@ ol.parser.geojson.parseFeatureCollection_ = function(json) {
* @return {Array.<ol.geom.Geometry>} Parsed array of geometries.
* @private
*/
ol.parser.geojson.parseGeometryCollection_ = function(json) {
ol.parser.GeoJSON.prototype.parseGeometryCollection_ = function(json) {
var geometries = json.geometries,
len = geometries.length,
result = new Array(len),
i;

for (i = 0; i < len; ++i) {
result[i] = ol.parser.geojson.parse_(
result[i] = this.parse_(
/** @type {GeoJSONGeometry} */ (geometries[i]));
}
return result;
Expand All @@ -139,7 +149,7 @@ ol.parser.geojson.parseGeometryCollection_ = function(json) {
* @return {ol.geom.LineString} Parsed linestring.
* @private
*/
ol.parser.geojson.parseLineString_ = function(json) {
ol.parser.GeoJSON.prototype.parseLineString_ = function(json) {
return new ol.geom.LineString(json.coordinates);
};

Expand All @@ -149,7 +159,7 @@ ol.parser.geojson.parseLineString_ = function(json) {
* @return {ol.geom.MultiLineString} Parsed multi-linestring.
* @private
*/
ol.parser.geojson.parseMultiLineString_ = function(json) {
ol.parser.GeoJSON.prototype.parseMultiLineString_ = function(json) {
return new ol.geom.MultiLineString(json.coordinates);
};

Expand All @@ -159,7 +169,7 @@ ol.parser.geojson.parseMultiLineString_ = function(json) {
* @return {ol.geom.MultiPoint} Parsed multi-point.
* @private
*/
ol.parser.geojson.parseMultiPoint_ = function(json) {
ol.parser.GeoJSON.prototype.parseMultiPoint_ = function(json) {
return new ol.geom.MultiPoint(json.coordinates);
};

Expand All @@ -169,7 +179,7 @@ ol.parser.geojson.parseMultiPoint_ = function(json) {
* @return {ol.geom.MultiPolygon} Parsed multi-polygon.
* @private
*/
ol.parser.geojson.parseMultiPolygon_ = function(json) {
ol.parser.GeoJSON.prototype.parseMultiPolygon_ = function(json) {
return new ol.geom.MultiPolygon(json.coordinates);
};

Expand All @@ -179,7 +189,7 @@ ol.parser.geojson.parseMultiPolygon_ = function(json) {
* @return {ol.geom.Point} Parsed multi-point.
* @private
*/
ol.parser.geojson.parsePoint_ = function(json) {
ol.parser.GeoJSON.prototype.parsePoint_ = function(json) {
return new ol.geom.Point(json.coordinates);
};

Expand All @@ -189,6 +199,6 @@ ol.parser.geojson.parsePoint_ = function(json) {
* @return {ol.geom.Polygon} Parsed polygon.
* @private
*/
ol.parser.geojson.parsePolygon_ = function(json) {
ol.parser.GeoJSON.prototype.parsePolygon_ = function(json) {
return new ol.geom.Polygon(json.coordinates);
};
21 changes: 21 additions & 0 deletions src/ol/parser/parser.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
goog.provide('ol.parser.Parser');



/**
* @constructor
*/
ol.parser.Parser = function() {};

/**
* @param {*} data Data to deserialize.
* @return {*} Parsed data.
*/
ol.parser.Parser.prototype.read = goog.abstractMethod;


/**
* @param {*} obj Object to serialize.
* @return {*} Serialized object.
*/
ol.parser.Parser.prototype.write = goog.abstractMethod;
4 changes: 4 additions & 0 deletions src/ol/parser/xml.js
Original file line number Diff line number Diff line change
@@ -1,9 +1,12 @@
goog.provide('ol.parser.XML');

goog.require('ol.parser.Parser');



/**
* @constructor
* @extends {ol.parser.Parser}
*/
ol.parser.XML = function() {
this.regExes = {
Expand All @@ -13,6 +16,7 @@ ol.parser.XML = function() {
trimComma: (/\s*,\s*/g)
};
};
goog.inherits(ol.parser.XML, ol.parser.Parser);


/**
Expand Down
23 changes: 15 additions & 8 deletions test/spec/ol/parser/geojson.test.js
Original file line number Diff line number Diff line change
@@ -1,6 +1,8 @@
goog.provide('ol.test.parser.geojson');
goog.provide('ol.test.parser.GeoJSON');

describe('ol.parser.geojson', function() {
describe('ol.parser.GeoJSON', function() {

var parser = new ol.parser.GeoJSON();

var data = {
'type': 'FeatureCollection',
Expand Down Expand Up @@ -74,7 +76,7 @@ describe('ol.parser.geojson', function() {
coordinates: [10, 20]
});

var obj = ol.parser.geojson.read(str);
var obj = parser.read(str);
expect(obj).toBeA(ol.geom.Point);
expect(obj.getCoordinates()).toEqual([10, 20]);
});
Expand All @@ -85,7 +87,7 @@ describe('ol.parser.geojson', function() {
coordinates: [[10, 20], [30, 40]]
});

var obj = ol.parser.geojson.read(str);
var obj = parser.read(str);
expect(obj).toBeA(ol.geom.LineString);
expect(obj.getCoordinates()).toEqual([[10, 20], [30, 40]]);
});
Expand All @@ -99,7 +101,7 @@ describe('ol.parser.geojson', function() {
coordinates: [outer, inner1, inner2]
});

var obj = ol.parser.geojson.read(str);
var obj = parser.read(str);
expect(obj).toBeA(ol.geom.Polygon);
expect(obj.rings.length).toBe(3);
expect(obj.rings[0]).toBeA(ol.geom.LinearRing);
Expand All @@ -116,15 +118,15 @@ describe('ol.parser.geojson', function() {
]
});

var array = ol.parser.geojson.read(str);
var array = parser.read(str);
expect(array.length).toBe(2);
expect(array[0]).toBeA(ol.geom.Point);
expect(array[1]).toBeA(ol.geom.LineString);
});

it('parses feature collection', function() {
var str = JSON.stringify(data),
array = ol.parser.geojson.read(str);
array = parser.read(str);

expect(array.length).toBe(2);

Expand All @@ -145,4 +147,9 @@ describe('ol.parser.geojson', function() {

});

goog.require('ol.parser.geojson');
goog.require('ol.Feature');
goog.require('ol.geom.LinearRing');
goog.require('ol.geom.LineString');
goog.require('ol.geom.Point');
goog.require('ol.geom.Polygon');
goog.require('ol.parser.GeoJSON');

0 comments on commit 69b6fae

Please sign in to comment.