trcombine 0.16.4
See the version list below for details.
dotnet tool install --global trcombine --version 0.16.4
dotnet new tool-manifest # if you are setting up this repo dotnet tool install --local trcombine --version 0.16.4
#tool dotnet:?package=trcombine&version=0.16.4
nuke :add-package trcombine --version 0.16.4
Reads an Antlr4 grammar from stdin and identifies problems in the grammar.
This program is part of the Trash toolkit.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net6.0 is compatible. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. |
This package has no dependencies.
Version | Downloads | Last updated |
---|---|---|
0.23.9 | 35 | 11/29/2024 |
0.23.8 | 122 | 11/1/2024 |
0.23.7 | 2,699 | 10/9/2024 |
0.23.6 | 730 | 9/21/2024 |
0.23.5 | 106 | 9/15/2024 |
0.23.4 | 105 | 9/7/2024 |
0.23.3 | 119 | 8/15/2024 |
0.23.2 | 125 | 6/28/2024 |
0.23.1 | 112 | 6/22/2024 |
0.23.0 | 188 | 4/25/2024 |
0.22.0 | 181 | 2/26/2024 |
0.21.16 | 274 | 11/16/2023 |
0.21.15 | 177 | 11/16/2023 |
0.21.14 | 184 | 11/15/2023 |
0.21.13 | 190 | 11/14/2023 |
0.21.12 | 281 | 10/27/2023 |
0.21.11 | 278 | 10/24/2023 |
0.21.9 | 288 | 9/27/2023 |
0.21.8 | 303 | 9/26/2023 |
0.21.7 | 234 | 9/26/2023 |
0.21.6 | 223 | 9/20/2023 |
0.21.5 | 206 | 9/18/2023 |
0.21.4 | 169 | 9/17/2023 |
0.21.3 | 203 | 9/14/2023 |
0.21.2 | 241 | 9/4/2023 |
0.21.1 | 318 | 8/15/2023 |
0.21.0 | 251 | 6/25/2023 |
0.20.27 | 226 | 6/15/2023 |
0.20.26 | 229 | 6/5/2023 |
0.20.25 | 215 | 6/3/2023 |
0.20.24 | 220 | 6/1/2023 |
0.20.23 | 174 | 5/31/2023 |
0.20.22 | 220 | 5/21/2023 |
0.20.21 | 230 | 5/15/2023 |
0.20.20 | 195 | 5/11/2023 |
0.20.19 | 197 | 5/8/2023 |
0.20.18 | 177 | 5/8/2023 |
0.20.17 | 214 | 5/4/2023 |
0.20.16 | 226 | 5/1/2023 |
0.20.15 | 211 | 4/27/2023 |
0.20.14 | 250 | 4/21/2023 |
0.20.13 | 273 | 4/13/2023 |
0.20.12 | 332 | 3/17/2023 |
0.20.11 | 296 | 3/15/2023 |
0.20.10 | 301 | 3/15/2023 |
0.20.9 | 301 | 3/14/2023 |
0.20.8 | 282 | 3/14/2023 |
0.20.7 | 275 | 3/13/2023 |
0.20.6 | 304 | 3/11/2023 |
0.20.5 | 329 | 3/11/2023 |
0.20.4 | 276 | 3/9/2023 |
0.20.3 | 283 | 3/8/2023 |
0.20.2 | 319 | 3/7/2023 |
0.20.1 | 293 | 3/7/2023 |
0.18.1 | 580 | 11/11/2022 |
0.18.0 | 463 | 11/7/2022 |
0.17.0 | 547 | 9/11/2022 |
0.16.5 | 550 | 7/29/2022 |
0.16.4 | 551 | 6/13/2022 |
0.16.3 | 640 | 5/7/2022 |
0.16.2 | 586 | 5/6/2022 |
0.16.1 | 576 | 5/5/2022 |
0.16.0 | 616 | 4/13/2022 |
0.15.1 | 602 | 4/4/2022 |
0.15.0 | 578 | 3/20/2022 |
0.14.3 | 595 | 2/27/2022 |
0.14.2 | 587 | 2/18/2022 |
0.14.1 | 619 | 1/26/2022 |
0.14.0 | 571 | 1/26/2022 |
0.13.8 | 591 | 1/14/2022 |
0.13.7 | 619 | 1/13/2022 |
0.13.6 | 579 | 1/13/2022 |
0.13.5 | 608 | 1/12/2022 |
0.13.4 | 595 | 1/11/2022 |
0.13.3 | 585 | 1/10/2022 |
0.13.2 | 403 | 12/24/2021 |
0.13.1 | 424 | 12/24/2021 |
0.13.0 | 431 | 12/23/2021 |
0.12.0 | 452 | 12/6/2021 |
0.11.5 | 517 | 10/17/2021 |
0.11.4 | 486 | 10/17/2021 |
0.11.3 | 476 | 9/28/2021 |
0.11.2 | 450 | 9/26/2021 |
0.11.1 | 465 | 9/25/2021 |
0.11.0 | 505 | 9/24/2021 |
0.10.0 | 535 | 9/9/2021 |
0.8.9 | 443 | 8/13/2021 |
0.8.8 | 436 | 8/5/2021 |
0.8.7 | 439 | 7/20/2021 |
0.8.6 | 471 | 7/13/2021 |
0.8.5 | 441 | 7/6/2021 |
0.8.4 | 424 | 6/24/2021 |
0.8.3 | 521 | 6/13/2021 |
0.8.2 | 446 | 6/8/2021 |
0.8.1 | 462 | 6/2/2021 |
# trcombine
Combine two grammars into one.
One grammar must be a lexer grammar, the other a parser grammar,
order is irrelevant. The output is parse tree data.
# Usage
trcombine <grammar1> <grammar2>
# Details
`trcombine` combines grammars that are known as "split grammars"
(separate Antlr4 lexer and parser grammars)
into one grammar, known as a "combined grammar". This refactoring is
useful if a simplified grammar grammar is wanted, and if possible if
the split grammar does not use the "superClass" option in one or the other
grammars. The opposite refactoring is implemented by
[trsplit](https://github.com/kaby76/Domemtech.Trash/tree/main/trsplit).
The split refactoring performs several operations:
* Combine the two files together, parser grammar first, then lexer grammar.
* Remove the `grammarDecl` for the lexer rules, and change the `grammarDecl`
for the parser rules to be a combined grammar declaration. Rename the name
of the parser grammar to not have "Parser" at the tail of the name.
* Remove the `optionsSpec` for the lexer section.
* Remove any occurrence of "tokenVocab" from the `optionsSpec` of the parser section.
* If the `optionsSpec` is empty, it is removed.
The order of the two grammars is ignored: the parser rules always will appear
before the lexer rules.
Lexer modes will require manual fix-up.
# Example
Consider the following grammar that is split.
_Input to command_
Lexer grammar in ExpressionLexer.g4:
lexer grammar ExpressionLexer;
VARIABLE : VALID_ID_START VALID_ID_CHAR* ;
fragment VALID_ID_START : ('a' .. 'z') | ('A' .. 'Z') | '_' ;
fragment VALID_ID_CHAR : VALID_ID_START | ('0' .. '9') ;
INT : ('0' .. '9')+ ;
MUL : '*' ;
DIV : '/' ;
ADD : '+' ;
SUB : '-' ;
LP : '(' ;
RP : ')' ;
WS : [ \r\n\t] + -> skip ;
Parser grammar in ExpressionParser.g4:
parser grammar ExpressionParser;
e : e ('*' | '/') e
| e ('+' | '-') e
| '(' e ')'
| ('-' | '+')* a
;
a : number | variable ;
number : INT ;
variable : VARIABLE ;
_Command_
trcombine ExpressionLexer.g4 ExpressionParser.g4 | trprint > Expression.g4
Combined grammar in Expression.g4:
grammar Expression;
e : e ('*' | '/') e
| e ('+' | '-') e
| '(' e ')'
| ('-' | '+')* a
;
a : number | variable ;
number : INT ;
variable : VARIABLE ;
VARIABLE : VALID_ID_START VALID_ID_CHAR* ;
fragment VALID_ID_START : ('a' .. 'z') | ('A' .. 'Z') | '_' ;
fragment VALID_ID_CHAR : VALID_ID_START | ('0' .. '9') ;
INT : ('0' .. '9')+ ;
MUL : '*' ;
DIV : '/' ;
ADD : '+' ;
SUB : '-' ;
LP : '(' ;
RP : ')' ;
WS : [ \r\n\t] + -> skip ;
The original grammars are left unchanged.
# Current version
0.16.4 -- Fixes to Java, Dart, Python, PHP templates in trgen; trxgrep results sent now to stdout; changes to trinsert, -a option; changes to Parsing Result Set data; fixes to trparse, trunfold, trinsert, trreplace, trdelete, add trsort.