Improve semantics of the TEXT bytecode instruction

The TEXT instruction now replaces position at the top of the stack with
the input from that position until the current position. This is simpler
and cleaner semantics than the previous one, where TEXT also popped an
additional value from the stack and kept the position there.
This commit is contained in:
David Majda 2014-05-15 19:12:38 +02:00
parent a815a8b902
commit dad1207c46
3 changed files with 12 additions and 11 deletions

View file

@ -68,8 +68,7 @@ var arrays = require("../../utils/arrays"),
* *
* [8] TEXT * [8] TEXT
* *
* stack.pop(); * stack.push(input.substring(stack.pop(), currPos));
* stack.push(input.substring(stack.top(), currPos));
* *
* Conditions and Loops * Conditions and Loops
* -------------------- * --------------------
@ -443,8 +442,11 @@ function generateBytecode(ast) {
env: { }, env: { },
action: null action: null
}), }),
buildCondition([op.IF_NOT_ERROR], [op.TEXT], []), buildCondition(
[op.IF_NOT_ERROR],
buildSequence([op.POP], [op.TEXT]),
[op.NIP] [op.NIP]
)
); );
}, },

View file

@ -219,8 +219,7 @@ function generateJavascript(ast, options) {
' break;', ' break;',
'', '',
' case ' + op.TEXT + ':', // TEXT ' case ' + op.TEXT + ':', // TEXT
' stack.pop();', ' stack.push(input.substring(stack.pop(), peg$currPos));',
' stack.push(input.substring(stack[stack.length - 1], peg$currPos));',
' ip++;', ' ip++;',
' break;', ' break;',
'', '',
@ -522,9 +521,8 @@ function generateJavascript(ast, options) {
break; break;
case op.TEXT: // TEXT case op.TEXT: // TEXT
stack.pop();
parts.push( parts.push(
stack.push('input.substring(' + stack.top() + ', peg$currPos)') stack.push('input.substring(' + stack.pop() + ', peg$currPos)')
); );
ip++; ip++;
break; break;

View file

@ -221,9 +221,10 @@ describe("compiler pass |generateBytecode|", function() {
expect(pass).toChangeAST('start = $"a"', bytecodeDetails([ expect(pass).toChangeAST('start = $"a"', bytecodeDetails([
1, // PUSH_CURR_POS 1, // PUSH_CURR_POS
14, 0, 2, 2, 18, 0, 19, 1, // <expression> 14, 0, 2, 2, 18, 0, 19, 1, // <expression>
11, 1, 0, // IF_NOT_ERROR 11, 2, 1, // IF_NOT_ERROR
8, // * TEXT 2, // * POP
5 // NIP 8, // TEXT
5 // * NIP
])); ]));
}); });
}); });