aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorbooo <borgers@mi.fu-berlin.de>2011-01-30 01:35:57 +0100
committerbooo <borgers@mi.fu-berlin.de>2011-01-30 01:35:57 +0100
commit46956a6a4079917bca0d5a22497116caa82386db (patch)
treee3d6aae326d1831e34f26960927dca779c4027a3
parentfb8641c55e99b6a207dcd7507310d9c4b3bbc376 (diff)
downloadosm-xapi-46956a6a4079917bca0d5a22497116caa82386db.tar.gz
osm-xapi-46956a6a4079917bca0d5a22497116caa82386db.tar.xz
osm-xapi-46956a6a4079917bca0d5a22497116caa82386db.zip
almost working; do some testing...
Diffstat (limited to '')
-rw-r--r--src/nodejs/alternative/parser.js54
-rw-r--r--src/nodejs/alternative/testgrammar2
2 files changed, 31 insertions, 25 deletions
diff --git a/src/nodejs/alternative/parser.js b/src/nodejs/alternative/parser.js
index ac10479..d388471 100644
--- a/src/nodejs/alternative/parser.js
+++ b/src/nodejs/alternative/parser.js
@@ -96,49 +96,55 @@ exports.parser = parser = (function(){
var savedPos1 = pos;
- var result7 = parse_object(context);
- if (result7 !== null) {
- var result8 = parse_predicate(context);
- if (result8 !== null) {
- var result9 = parse_predicate(context);
- if (result9 !== null) {
- var result6 = [result7, result8, result9];
+ var result9 = parse_object(context);
+ if (result9 !== null) {
+ var result10 = parse_predicate(context);
+ if (result10 !== null) {
+ var result11 = parse_predicate(context);
+ if (result11 !== null) {
+ var result8 = [result9, result10, result11];
} else {
- var result6 = null;
+ var result8 = null;
pos = savedPos1;
}
} else {
- var result6 = null;
+ var result8 = null;
pos = savedPos1;
}
} else {
- var result6 = null;
+ var result8 = null;
pos = savedPos1;
}
- var result5 = result6 !== null
- ? (function(object, p1, p2) { var result = {object:object}; if(p1.tags != undefined) {result.tags= p1.tags} else if(p1.bbox != undefined) {result.bbox=p1.bbox;} if(p2.tags != undefined) {result.tags= p2.tags} else if(p2.bbox != undefined) {result.bbox=p2.bbox;} return result;})(result6[0], result6[1], result6[2])
+ var result7 = result8 !== null
+ ? (function(object, p1, p2) { var result = {object:object}; if(p1.tags != undefined) {result.tags= p1.tags} else if(p1.bbox != undefined) {result.bbox=p1.bbox;} if(p2.tags != undefined) {result.tags= p2.tags} else if(p2.bbox != undefined) {result.bbox=p2.bbox;} return result;})(result8[0], result8[1], result8[2])
: null;
- if (result5 !== null) {
- var result0 = result5;
+ if (result7 !== null) {
+ var result0 = result7;
} else {
var savedPos0 = pos;
- var result3 = parse_object(context);
- if (result3 !== null) {
- var result4 = parse_predicate(context);
- if (result4 !== null) {
- var result2 = [result3, result4];
+ var result5 = parse_object(context);
+ if (result5 !== null) {
+ var result6 = parse_predicate(context);
+ if (result6 !== null) {
+ var result4 = [result5, result6];
} else {
- var result2 = null;
+ var result4 = null;
pos = savedPos0;
}
} else {
- var result2 = null;
+ var result4 = null;
pos = savedPos0;
}
- if (result2 !== null) {
- var result0 = result2;
+ var result3 = result4 !== null
+ ? (function(object, p) {var result={}; result.object=object; if(p.tags != undefined) {result.tags=p.tags} else {result.bbox=p.bbox} return result})(result4[0], result4[1])
+ : null;
+ if (result3 !== null) {
+ var result0 = result3;
} else {
- var result1 = parse_object(context);
+ var result2 = parse_object(context);
+ var result1 = result2 !== null
+ ? (function(object) { return {object:object}})(result2)
+ : null;
if (result1 !== null) {
var result0 = result1;
} else {
diff --git a/src/nodejs/alternative/testgrammar b/src/nodejs/alternative/testgrammar
index e212493..0e43013 100644
--- a/src/nodejs/alternative/testgrammar
+++ b/src/nodejs/alternative/testgrammar
@@ -3,7 +3,7 @@
* "2*(3+4)". The parser generated from this grammar then computes their value.
*/
-url = object:object p1:predicate p2:predicate { var result = {object:object}; if(p1.tags != undefined) {result.tags= p1.tags} else if(p1.bbox != undefined) {result.bbox=p1.bbox;} if(p2.tags != undefined) {result.tags= p2.tags} else if(p2.bbox != undefined) {result.bbox=p2.bbox;} return result;}/ object predicate / object
+url = object:object p1:predicate p2:predicate { var result = {object:object}; if(p1.tags != undefined) {result.tags= p1.tags} else if(p1.bbox != undefined) {result.bbox=p1.bbox;} if(p2.tags != undefined) {result.tags= p2.tags} else if(p2.bbox != undefined) {result.bbox=p2.bbox;} return result;}/ object:object p:predicate {var result={}; result.object=object; if(p.tags != undefined) {result.tags=p.tags} else {result.bbox=p.bbox} return result} / object:object { return {object:object}}
object = v:"node" {return v} / v:"way" {return v} / v:"relation" {return v} / v:"*" {return v}