File: Main.cs

package info (click to toggle)
antlr 2.7.7%2Bdfsg-7
  • links: PTS, VCS
  • area: main
  • in suites: stretch
  • size: 9,888 kB
  • sloc: java: 54,649; cs: 12,537; makefile: 8,945; cpp: 7,359; pascal: 5,273; sh: 4,337; python: 4,301; lisp: 1,969; xml: 220; lex: 192; ansic: 127
file content (46 lines) | stat: -rwxr-xr-x 1,536 bytes parent folder | download | duplicates (11)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
using System;
using antlr.collections;
using antlr.collections.impl;
using antlr;

class MultiLexer {
  // Define a selector that can switch from java to javadoc; make visible to lexers
  public static TokenStreamSelector selector = new TokenStreamSelector();

  public static void Main(String[] args) {
    try {
      // open a simple stream to the input
      ByteBuffer input = new ByteBuffer(Console.OpenStandardInput());

      // attach java lexer to the input stream, which also creates a shared input state object
      DemoJavaLexer main = new DemoJavaLexer(input);

      // create javadoc lexer; attach to same shared input state as java lexer
      DemoJavaDocLexer doclexer = new DemoJavaDocLexer(main.getInputState());

      // notify selector about various lexers; name them for convenient reference later
      selector.addInputStream(main, "main");
      selector.addInputStream(doclexer, "doclexer");
      selector.select("main"); // start with main java lexer

      // Create parser attached to selector
      DemoJavaParser parser = new DemoJavaParser(selector);

      // Pull in one or more int decls with optional javadoc
      parser.input();

      /*
      // spin thru all tokens generated via the SELECTOR.
      Token t;
      while ( (t=selector.nextToken()).Type!=main.EOF ) {
		Console.Out.WriteLine(t.ToString());
      }
      */
    }
    catch(Exception e) {
      Console.Error.WriteLine("exception: "+e);
      Console.Error.WriteLine(e.StackTrace); 		// so we can get stack trace
    }
  }

}