<!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>t010lexer</title> <!-- ANTLR includes --> <script type="text/javascript" src="../../lib/antlr3-all.js"></script> <script type="text/javascript" src="t010lexer.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, t010lexer, { reportError: function(re) { /* don't recover, just crash */ throw re; } }); function testValid() { var stream = new org.antlr.runtime.ANTLRStringStream("foobar _Ab98 \n A12sdf"), lexer = new TLexer(stream), token; token = lexer.nextToken(); assertEquals(token.getType(), lexer.IDENTIFIER); assertEquals(token.getStartIndex(), 0); assertEquals(token.getStopIndex(), 5); assertEquals(token.getText(), "foobar"); token = lexer.nextToken(); assertEquals(token.getType(), lexer.WS); assertEquals(token.getStartIndex(), 6); assertEquals(token.getStopIndex(), 6); assertEquals(token.getText(), ' '); token = lexer.nextToken(); assertEquals(token.getType(), lexer.IDENTIFIER); assertEquals(token.getStartIndex(), 7); assertEquals(token.getStopIndex(), 11); assertEquals(token.getText(), '_Ab98'); token = lexer.nextToken(); assertEquals(token.getType(), lexer.WS); assertEquals(token.getStartIndex(), 12); assertEquals(token.getStopIndex(), 14); assertEquals(token.getText(), " \n "); token = lexer.nextToken(); assertEquals(token.getType(), lexer.IDENTIFIER); assertEquals(token.getStartIndex(), 15); assertEquals(token.getStopIndex(), 20); assertEquals(token.getText(), 'A12sdf'); token = lexer.nextToken(); assertEquals(token.getType(), lexer.EOF); } function testMalformedInput() { var stream = new org.antlr.runtime.ANTLRStringStream('a-b'), lexer = new TLexer(stream), token; lexer.nextToken(); try { token = lexer.nextToken(); fail("nextToken should have thrown error on invalid input"); } catch (e) { assert(e instanceof org.antlr.runtime.NoViableAltException); assertEquals(e.getUnexpectedType(), '-'); assertEquals(e.charPositionInLine, 1); assertEquals(e.line, 1); } } </script> </head> <body> <h1>t010lexer</h1> </body>