<!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>t008lexer</title>
<!-- ANTLR includes -->
<script type="text/javascript" src="../../lib/antlr3-all.js"></script>
<script type="text/javascript" src="t008lexer.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, t008lexer, {
reportError: function(re) {
/* don't recover, just crash */
throw re;
}
});
function testValid() {
var stream = new org.antlr.runtime.ANTLRStringStream("ffaf"),
lexer = new TLexer(stream),
token;
token = lexer.nextToken();
assertEquals(token.getType(), lexer.FOO);
assertEquals(token.getStartIndex(), 0);
assertEquals(token.getStopIndex(), 0);
assertEquals(token.getText(), "f");
token = lexer.nextToken();
assertEquals(token.getType(), lexer.FOO);
assertEquals(token.getStartIndex(), 1);
assertEquals(token.getStopIndex(), 2);
assertEquals(token.getText(), 'fa');
token = lexer.nextToken();
assertEquals(token.getType(), lexer.FOO);
assertEquals(token.getStartIndex(), 3);
assertEquals(token.getStopIndex(), 3);
assertEquals(token.getText(), 'f');
token = lexer.nextToken();
assertEquals(token.getType(), lexer.EOF);
}
function testMalformedInput() {
var stream = new org.antlr.runtime.ANTLRStringStream('fafb'),
lexer = new TLexer(stream),
token;
lexer.nextToken();
lexer.nextToken();
try {
token = lexer.nextToken();
fail("nextToken should have thrown error on invalid input");
} catch (e) {
assertEquals(e.getUnexpectedType(), 'b');
assertEquals(e.charPositionInLine, 3);
assertEquals(e.line, 1);
}
}
</script>
</head>
<body>
<h1>t008lexer</h1>
</body>