You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
86 lines
2.6 KiB
86 lines
2.6 KiB
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
|
|
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
|
|
<head>
|
|
<meta http-equiv="content-type" content="text/html;charset=utf-8" />
|
|
<title>t005lexer</title>
|
|
|
|
<!-- ANTLR includes -->
|
|
<script type="text/javascript" src="../../lib/antlr3-all.js"></script>
|
|
<script type="text/javascript" src="t005lexer.js"></script>
|
|
|
|
<!-- JsUnit include -->
|
|
<script type="text/javascript" src="../jsunit/app/jsUnitCore.js"></script>
|
|
|
|
<!-- Test Code -->
|
|
<script type="text/javascript">
|
|
function TLexer() {
|
|
TLexer.superclass.constructor.apply(this, arguments);
|
|
}
|
|
org.antlr.lang.extend(TLexer, t005lexer, {
|
|
reportError: function(re) {
|
|
/* don't recover, just crash */
|
|
throw re;
|
|
}
|
|
});
|
|
|
|
function testValid() {
|
|
var stream = new org.antlr.runtime.ANTLRStringStream("fofoofooo"),
|
|
lexer = new TLexer(stream),
|
|
token;
|
|
|
|
token = lexer.nextToken();
|
|
assertEquals(token.getType(), lexer.FOO);
|
|
assertEquals(token.getStartIndex(), 0);
|
|
assertEquals(token.getStopIndex(), 1);
|
|
assertEquals(token.getText(), "fo");
|
|
|
|
token = lexer.nextToken();
|
|
assertEquals(token.getType(), lexer.FOO);
|
|
assertEquals(token.getStartIndex(), 2);
|
|
assertEquals(token.getStopIndex(), 4);
|
|
assertEquals(token.getText(), 'foo');
|
|
|
|
token = lexer.nextToken();
|
|
assertEquals(token.getType(), lexer.FOO);
|
|
assertEquals(token.getStartIndex(), 5);
|
|
assertEquals(token.getStopIndex(), 8);
|
|
assertEquals(token.getText(), 'fooo');
|
|
|
|
token = lexer.nextToken();
|
|
assertEquals(token.getType(), lexer.EOF);
|
|
}
|
|
|
|
function testMalformedInput1() {
|
|
var stream = new org.antlr.runtime.ANTLRStringStream('2'),
|
|
lexer = new TLexer(stream),
|
|
token;
|
|
|
|
try {
|
|
token = lexer.nextToken();
|
|
fail("nextToken should have thrown error on invalid input");
|
|
} catch (e) {
|
|
assertEquals(e.expecting, 'f');
|
|
assertEquals(e.getUnexpectedType(), '2');
|
|
}
|
|
}
|
|
|
|
function testMalformedInput2() {
|
|
var stream = new org.antlr.runtime.ANTLRStringStream('f'),
|
|
lexer = new TLexer(stream),
|
|
token;
|
|
|
|
try {
|
|
token = lexer.nextToken();
|
|
fail("nextToken should have thrown error on invalid input");
|
|
} catch (e) {
|
|
assertEquals(e.getUnexpectedType(), lexer.EOF);
|
|
}
|
|
}
|
|
</script>
|
|
|
|
</head>
|
|
<body>
|
|
<h1>t005lexer</h1>
|
|
</body>
|
|
</html>
|