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 47 48 49 50 51 52 53 54 55 56 57 58
|
header {
#include "antlr/TokenStreamSelector.hpp"
}
options {
language="Cpp";
}
class DemoJavaDocLexer extends Lexer;
options {
k=2;
importVocab = Common;
exportVocab = JavaDoc;
filter=true;
}
{
private:
ANTLR_USE_NAMESPACE(antlr)TokenStreamSelector* selector;
public:
void setSelector(ANTLR_USE_NAMESPACE(antlr)TokenStreamSelector* selector_) {
selector=selector_;
}
}
PARAM
: "@param" ' ' ID
;
EXCEPTION
: "@exception" ' ' ID
;
protected
ID : ('a'..'z'|'A'..'Z')+
;
/** This rule simply prevents JAVADOC_CLOSE from being
* called for every '*' in a comment. Calling JAVADOC_CLOSE
* will fail for simple '*' and cause an exception, which
* is slow. In other words, the grammar will work without
* this rule, but is slower.
*/
STAR: '*' {$setType(ANTLR_USE_NAMESPACE(antlr)Token::SKIP);}
;
JAVADOC_CLOSE
: "*/" {selector->pop();}
;
/** Ignore whitespace inside JavaDoc comments */
NEWLINE
: ( "\r\n" // Evil DOS
| '\r' // Macintosh
| '\n' // Unix (the right way)
)
{ newline(); $setType(ANTLR_USE_NAMESPACE(antlr)Token::SKIP); }
;
|