151 lines
		
	
	
		
			5.4 KiB
		
	
	
	
		
			HTML
		
	
	
		
			Executable File
		
	
	
			
		
		
	
	
			151 lines
		
	
	
		
			5.4 KiB
		
	
	
	
		
			HTML
		
	
	
		
			Executable File
		
	
	
| <!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>t056lexer</title>
 | |
| 
 | |
| <!-- ANTLR includes -->
 | |
| <script type="text/javascript" src="../../lib/antlr3-all.js"></script>
 | |
| <script type="text/javascript" src="t056lexer1Lexer.js"></script>
 | |
| <script type="text/javascript" src="t056lexer1Parser.js"></script>
 | |
| <script type="text/javascript" src="t056lexer2Lexer.js"></script>
 | |
| <script type="text/javascript" src="t056lexer2Parser.js"></script>
 | |
| <script type="text/javascript" src="t056lexer3Lexer.js"></script>
 | |
| <script type="text/javascript" src="t056lexer3Parser.js"></script>
 | |
| <script type="text/javascript" src="t056lexer4Lexer.js"></script>
 | |
| <script type="text/javascript" src="t056lexer4Parser.js"></script>
 | |
| <script type="text/javascript" src="t056lexer5Lexer.js"></script>
 | |
| <script type="text/javascript" src="t056lexer5Parser.js"></script>
 | |
| <script type="text/javascript" src="t056lexer6Lexer.js"></script>
 | |
| <script type="text/javascript" src="t056lexer6Parser.js"></script>
 | |
| <script type="text/javascript" src="t056lexer7Lexer.js"></script>
 | |
| <script type="text/javascript" src="t056lexer7Parser.js"></script>
 | |
| <script type="text/javascript" src="t056lexer8Lexer.js"></script>
 | |
| <script type="text/javascript" src="t056lexer8Parser.js"></script>
 | |
| <script type="text/javascript" src="t056lexer9Lexer.js"></script>
 | |
| <script type="text/javascript" src="t056lexer9Parser.js"></script>
 | |
| <script type="text/javascript" src="t056lexer10Lexer.js"></script>
 | |
| <script type="text/javascript" src="t056lexer10Parser.js"></script>
 | |
| <script type="text/javascript" src="t056lexer11Lexer.js"></script>
 | |
| <script type="text/javascript" src="t056lexer11Parser.js"></script>
 | |
| <script type="text/javascript" src="t056lexer12.js"></script>
 | |
| <script type="text/javascript" src="t056lexer13.js"></script>
 | |
| <script type="text/javascript" src="t056lexer14.js"></script>
 | |
| <script type="text/javascript" src="t056lexer15.js"></script>
 | |
| 
 | |
| <!-- JsUnit include -->
 | |
| <script type="text/javascript" src="../jsunit/app/jsUnitCore.js"></script>
 | |
| 
 | |
| <!-- Test Code -->
 | |
| <script type="text/javascript">
 | |
|     function execParser(lexerCls, parserCls, grammarEntry, xinput)
 | |
|     {
 | |
|         var cstream = new org.antlr.runtime.ANTLRStringStream(xinput),
 | |
|             lexer = new lexerCls(cstream),
 | |
|             tstream = new org.antlr.runtime.CommonTokenStream(lexer),
 | |
|             parser = new parserCls(tstream),
 | |
|             output = "";
 | |
|         lexer.xlog = function(msg){output += msg;};
 | |
|         parser.xlog = lexer.xlog;
 | |
|         var r = parser[grammarEntry]();
 | |
| 
 | |
|         return output;
 | |
|     }
 | |
| 
 | |
|     function execLexer(lexerCls, xinput) {
 | |
|         var token,
 | |
|             cstream = new org.antlr.runtime.ANTLRStringStream(xinput),
 | |
|             lexer = new lexerCls(cstream);
 | |
|         do {
 | |
|             token = lexer.nextToken();
 | |
|         } while (token.getType()!==lexer.EOF);
 | |
|     }
 | |
| 
 | |
| function testSetText() {
 | |
|     var found = execParser(t056lexer1Lexer, t056lexer1Parser, "a", "\\t");
 | |
|     assertEquals("  ", found);
 | |
| }
 | |
| 
 | |
| function testRefToRuleDoesNotSetTokenNorEmitAnother() {
 | |
|     // this must return A not I to the parser; calling a nonfragment rule
 | |
|     // from a nonfragment rule does not set the overall token.
 | |
|     var found = execParser(t056lexer2Lexer, t056lexer2Parser, "a", "-34");
 | |
|     assertEquals("-34", found);
 | |
| }
 | |
| 
 | |
| function testRefToRuleDoesNotSetChannel() {
 | |
|     // this must set channel of A to HIDDEN.  $channel is local to rule
 | |
|     // like $type.
 | |
|     var found = execParser(t056lexer3Lexer, t056lexer3Parser, "a", "- 34");
 | |
|     assertEquals("- 34, channel=0", found);
 | |
| }
 | |
| 
 | |
| function testWeCanSetType() {
 | |
|     var found = execParser(t056lexer4Lexer, t056lexer4Parser, "a", "-34");
 | |
|     assertEquals("-34", found);
 | |
| }
 | |
| 
 | |
| function testRefToFragment() {
 | |
|     // this must return A not I to the parser; calling a nonfragment rule
 | |
|     // from a nonfragment rule does not set the overall token.
 | |
|     var found = execParser(t056lexer5Lexer, t056lexer5Parser, "a", "-34");
 | |
|     assertEquals("-34", found);
 | |
| }
 | |
| 
 | |
| function testMultipleRefToFragment() {
 | |
|     // this must return A not I to the parser; calling a nonfragment rule
 | |
|     // from a nonfragment rule does not set the overall token.
 | |
|     var found = execParser(t056lexer6Lexer, t056lexer6Parser, "a", "3.14159");
 | |
|     assertEquals("3.14159", found);
 | |
| }
 | |
| 
 | |
| function testLabelInSubrule() {
 | |
|     // can we see v outside?
 | |
|     var found = execParser(t056lexer7Lexer, t056lexer7Parser, "a", "hi 342");
 | |
|     assertEquals("342", found);
 | |
| }
 | |
| 
 | |
| function testRefToTokenInLexer() {
 | |
|     var found = execParser(t056lexer8Lexer, t056lexer8Parser, "a", "342");
 | |
|     assertEquals("342", found);
 | |
| }
 | |
| 
 | |
| function testListLabelInLexer() {
 | |
|     var found = execParser(t056lexer9Lexer, t056lexer9Parser, "a", "33 297");
 | |
|     assertEquals(" 33 297", found);
 | |
| }
 | |
| 
 | |
| function testDupListRefInLexer() {
 | |
|     var found = execParser(t056lexer10Lexer, t056lexer10Parser, "a", "33 297");
 | |
|     assertEquals(" 33 297", found);
 | |
| }
 | |
| 
 | |
| function testCharLabelInLexer() {
 | |
|     var found = execParser(t056lexer11Lexer, t056lexer11Parser, "a", "a");
 | |
|     assertEquals("a", found);
 | |
| }
 | |
| 
 | |
| function testRepeatedLabelInLexer() {
 | |
|     execLexer(t056lexer12, "ababab");
 | |
| }
 | |
| 
 | |
| function testRepeatedRuleLabelInLexer() {
 | |
|     execLexer(t056lexer13, "aa");
 | |
| }
 | |
| 
 | |
| function testIsolatedEOTEdge() {
 | |
|     execLexer(t056lexer14, "qbalogna!q");
 | |
| }
 | |
| 
 | |
| function testEscapedLiterals() {
 | |
|     execLexer(t056lexer15, "\\\"");
 | |
| }
 | |
| </script>
 | |
| 
 | |
| </head>
 | |
| <body>
 | |
|     <h1>t056lexer</h1>
 | |
| </body>
 | |
| </html>
 | |
| 
 |