2011-02-13 12:22:56 +01:00
|
|
|
(function() {
|
2010-08-18 21:15:48 +02:00
|
|
|
|
|
|
|
module("PEG.compiler.checks");
|
|
|
|
|
|
|
|
test("reports missing referenced rules", function() {
|
2011-09-14 12:45:41 +02:00
|
|
|
function testGrammar(grammar) {
|
|
|
|
raises(
|
|
|
|
function() {
|
|
|
|
var ast = PEG.parser.parse(grammar);
|
|
|
|
PEG.compiler.checks.missingReferencedRules(ast);
|
|
|
|
},
|
|
|
|
function(e) {
|
|
|
|
return e instanceof PEG.GrammarError
|
|
|
|
&& e.message === "Referenced rule \"missing\" does not exist.";
|
|
|
|
}
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2010-08-18 21:15:48 +02:00
|
|
|
var grammars = [
|
|
|
|
'start = missing',
|
|
|
|
'start = missing / "a" / "b"',
|
|
|
|
'start = "a" / "b" / missing',
|
|
|
|
'start = missing "a" "b"',
|
|
|
|
'start = "a" "b" missing',
|
|
|
|
'start = label:missing',
|
|
|
|
'start = &missing',
|
|
|
|
'start = !missing',
|
|
|
|
'start = missing?',
|
|
|
|
'start = missing*',
|
|
|
|
'start = missing+',
|
|
|
|
'start = missing { }'
|
|
|
|
];
|
|
|
|
|
2011-09-14 12:45:41 +02:00
|
|
|
for (var i = 0; i < grammars.length; i++) { testGrammar(grammars[i]); }
|
|
|
|
});
|
|
|
|
|
|
|
|
test("reports left recursion", function() {
|
|
|
|
function testGrammar(grammar) {
|
2011-01-25 14:54:38 +01:00
|
|
|
raises(
|
2010-08-21 11:59:42 +02:00
|
|
|
function() {
|
2011-09-14 12:45:41 +02:00
|
|
|
var ast = PEG.parser.parse(grammar);
|
|
|
|
PEG.compiler.checks.leftRecursion(ast);
|
2010-08-21 11:59:42 +02:00
|
|
|
},
|
2011-01-25 14:54:38 +01:00
|
|
|
function(e) {
|
|
|
|
return e instanceof PEG.GrammarError
|
2011-09-14 12:45:41 +02:00
|
|
|
&& e.message === "Left recursion detected for rule \"start\".";
|
2011-01-25 14:54:38 +01:00
|
|
|
}
|
2010-08-18 21:15:48 +02:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
var grammars = [
|
|
|
|
/* Direct */
|
|
|
|
'start = start',
|
|
|
|
'start = start / "a" / "b"',
|
|
|
|
'start = "a" / "b" / start',
|
|
|
|
'start = start "a" "b"',
|
|
|
|
'start = label:start',
|
|
|
|
'start = &start',
|
|
|
|
'start = !start',
|
|
|
|
'start = start?',
|
|
|
|
'start = start*',
|
|
|
|
'start = start+',
|
|
|
|
'start = start { }',
|
|
|
|
|
|
|
|
/* Indirect */
|
|
|
|
'start = stop; stop = start'
|
|
|
|
];
|
|
|
|
|
2011-09-14 12:45:41 +02:00
|
|
|
for (var i = 0; i < grammars.length; i++) { testGrammar(grammars[i]); }
|
2010-08-18 21:15:48 +02:00
|
|
|
});
|
|
|
|
|
2011-02-13 12:22:56 +01:00
|
|
|
})();
|