1 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 2 <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en"> 3 <head> 4 <meta http-equiv="content-type" content="text/html;charset=utf-8" /> 5 <title>t003lexer</title> 6 7 <!-- ANTLR includes --> 8 <script type="text/javascript" src="../../lib/antlr3-all.js"></script> 9 <script type="text/javascript" src="t003lexer.js"></script> 10 11 <!-- JsUnit include --> 12 <script type="text/javascript" src="../jsunit/app/jsUnitCore.js"></script> 13 14 <!-- Test Code --> 15 <script type="text/javascript"> 16 function TLexer() { 17 TLexer.superclass.constructor.apply(this, arguments); 18 } 19 org.antlr.lang.extend(TLexer, t003lexer, { 20 reportError: function(re) { 21 /* don't recover, just crash */ 22 throw re; 23 } 24 }); 25 26 function testValid() { 27 var stream = new org.antlr.runtime.ANTLRStringStream("0fooze1"), 28 lexer = new TLexer(stream), 29 token; 30 31 token = lexer.nextToken(); 32 assertEquals(token.getType(), lexer.ZERO); 33 34 token = lexer.nextToken(); 35 assertEquals(token.getType(), lexer.FOOZE); 36 37 token = lexer.nextToken(); 38 assertEquals(token.getType(), lexer.ONE); 39 40 token = lexer.nextToken(); 41 assertEquals(token.getType(), lexer.EOF); 42 } 43 44 function testMalformedInput() { 45 var stream = new org.antlr.runtime.ANTLRStringStream('2'), 46 lexer = new TLexer(stream), 47 token; 48 49 try { 50 token = lexer.nextToken(); 51 fail("nextToken should have thrown error on invalid input"); 52 } catch (e) { 53 assertEquals(e.getUnexpectedType(), '2'); 54 } 55 } 56 </script> 57 58 </head> 59 <body> 60 <h1>t003lexer</h1> 61 </body> 62 </html> 63