public static LinkedListTree parseRegexpLiteral(
     LinkedListToken startMarker, AS3Lexer lexer, CharStream cs, LinkedListTokenStream stream)
     throws RecognitionException {
   String tail = cs.substring(cs.index(), cs.size() - 1);
   int initialTailLength = tail.length();
   RegexSimpleParser parser;
   try {
     parser = regexpParserOn(new StringReader(tail), stream);
   } catch (IOException e) {
     // TODO: better exception type?
     throw new RuntimeException(e);
   }
   LinkedListTree ast = AS3FragmentParser.tree(parser.regexpLiteral());
   tail = parser.getInputTail();
   // skip over the regexp in the original, underlying CharStream
   cs.seek(cs.index() + (initialTailLength - tail.length()));
   LinkedListTokenSource source = (LinkedListTokenSource) stream.getTokenSource();
   stream.setTokenSource(source); // cause any remembered RegexpSimple state to be dropped
   stream.scrub(1); // erase the subsequent token that the RegexpSimple parser got from this stream
   source.setDelegate(lexer);
   return ast;
 }
  private static RegexSimpleParser regexpParserOn(Reader in, LinkedListTokenStream stream)
      throws IOException {
    ANTLRReaderStream cs = new ANTLRReaderStream(in);
    RegexSimpleLexer lexer = new RegexSimpleLexer(cs);
    LinkedListTokenSource source = (LinkedListTokenSource) stream.getTokenSource();
    source.setDelegate(lexer);

    // The AS3 grammar will see the initial '/' as an DIV (divide)
    // token, and lookahead in the AS3Parser will have already
    // grabbed references to that token in order to make it the
    // startToken for various AST subtrees, so we can't just delete
    // it.  We therefore find the DIC token and change its type to
    // match the regexp vocabulary, and then rewind the token stream
    // so that this will be the first token that the
    // SinpleRegexpParser will see.
    LinkedListToken startMarker = (LinkedListToken) stream.LT(-1);
    startMarker.setType(RegexSimpleParser.REGEXP_DELIMITER);
    stream.seek(stream.index() - 1);

    RegexSimpleParser parser = new RegexSimpleParser(stream);
    parser.setTreeAdaptor(new LinkedListTreeAdaptor());
    parser.setInput(lexer, cs);
    return parser;
  }