2023-06-28 22:56:18 +08:00
|
|
|
grammar Nlp;
|
|
|
|
|
2023-06-29 21:46:58 +08:00
|
|
|
document: LANG_HEADER (section)* ;
|
2023-06-28 22:56:18 +08:00
|
|
|
|
2023-06-29 21:46:58 +08:00
|
|
|
section: SECTION_HEAD (subSection | entry)* ;
|
2023-06-28 22:56:18 +08:00
|
|
|
|
2023-06-29 21:46:58 +08:00
|
|
|
subSection: SUB_SECTION_HEAD (entry)* ;
|
2023-06-28 22:56:18 +08:00
|
|
|
|
2023-06-29 21:46:58 +08:00
|
|
|
entry: ENTRY_STRING # entryString
|
|
|
|
| ENTRY_STRING (LINE_CONCAT ENTRY_STRING)+ # entryConcatedString
|
|
|
|
| ENTRY_INTEGER # entryInteger
|
2023-06-28 22:56:18 +08:00
|
|
|
;
|
|
|
|
|
|
|
|
LANG_HEADER: 'Language:' [a-zA-Z]+ ;
|
|
|
|
|
|
|
|
SECTION_HEAD: '[' NAME_SECTION ']' ;
|
|
|
|
SUB_SECTION_HEAD: '<' NAME_SECTION '>' ;
|
|
|
|
fragment NAME_SECTION: [ a-zA-Z0-9]+ ; // section name are consisted of space, char and number
|
|
|
|
|
|
|
|
ENTRY_STRING: '"' (STRING_ESC|.)*? '"' ;
|
|
|
|
fragment STRING_ESC: '\\"' | '\\\\' ;
|
|
|
|
|
|
|
|
ENTRY_INTEGER: [1-9][0-9]+ ;
|
|
|
|
|
|
|
|
SPLITTOR: [ ,;\r\n]+ -> skip; // ignore all splittor and space
|
|
|
|
LINE_CONCAT: '\\' ;
|
|
|
|
LINE_COMMENT: '//' ~[\r\n]* -> skip ; // consume all non-line-breaker. because we need line breaker.
|
|
|
|
BLOCK_COMMENT: '/*' .*? '*/' -> skip ;
|