diff --git a/delphi-frontend/src/main/antlr3/au/com/integradev/delphi/antlr/Delphi.g b/delphi-frontend/src/main/antlr3/au/com/integradev/delphi/antlr/Delphi.g index 731cb86f8..0ad4b759a 100644 --- a/delphi-frontend/src/main/antlr3/au/com/integradev/delphi/antlr/Delphi.g +++ b/delphi-frontend/src/main/antlr3/au/com/integradev/delphi/antlr/Delphi.g @@ -1201,9 +1201,9 @@ TkIntNumber : DigitSeq ( )? )? ; -TkHexNumber : '$' HexDigitSeq +TkHexNumber : '$' ('_' | HexDigit)* ; -TkBinaryNumber : '%' BinaryDigitSeq +TkBinaryNumber : '%' ('_' | BinaryDigit)* ; TkAsmId : { asmMode }? => '@' '@'? (Alpha | '_' | Digit)+ ; @@ -1213,9 +1213,9 @@ TkQuotedString : '\'' ('\'\'' | ~('\''))* '\'' ; TkAsmDoubleQuotedString : { asmMode }? => '"' (~('\"'))* '"' ; -TkCharacterEscapeCode : '#' DigitSeq - | '#' '$' HexDigitSeq - | '#' '%' BinaryDigitSeq +TkCharacterEscapeCode : '#' ('_' | Digit)+ + | '#' '$' ('_' | HexDigit)+ + | '#' '%' ('_' | BinaryDigit)+ ; //---------------------------------------------------------------------------- // Fragments diff --git a/delphi-frontend/src/test/java/au/com/integradev/delphi/antlr/GrammarTest.java b/delphi-frontend/src/test/java/au/com/integradev/delphi/antlr/GrammarTest.java index b263814ac..cd6cd2a78 100644 --- a/delphi-frontend/src/test/java/au/com/integradev/delphi/antlr/GrammarTest.java +++ b/delphi-frontend/src/test/java/au/com/integradev/delphi/antlr/GrammarTest.java @@ -237,4 +237,9 @@ void testEmptyFileShouldThrow() { DelphiFileUtils.mockConfig())) .isInstanceOf(DelphiFileConstructionException.class); } + + @Test + void testUnusualIntegerLiterals() { + parseFile("UnusualIntegerLiterals.pas"); + } } diff --git a/delphi-frontend/src/test/resources/au/com/integradev/delphi/grammar/UnusualIntegerLiterals.pas b/delphi-frontend/src/test/resources/au/com/integradev/delphi/grammar/UnusualIntegerLiterals.pas new file mode 100644 index 000000000..906dedf0c --- /dev/null +++ b/delphi-frontend/src/test/resources/au/com/integradev/delphi/grammar/UnusualIntegerLiterals.pas @@ -0,0 +1,23 @@ +unit UnusualIntegerLiterals; + +interface + +const + HexWithoutDigits = $; + BinaryWithoutDigits = %; + HexStartingWithUnderscore = $_; + BinaryStartingWithUnderscore = %_; + HexStartingWithManyUnderscores = $__; + BinaryStartingWithManyUnderscores = %__; + + CharHexStartingWithUnderscore = #$_; + CharBinaryStartingWithUnderscore = #%_; + CharHexStartingWithManyUnderscores = #$__; + CharBinaryStartingWithManyUnderscores = #%__; + + CharDecimalStartingWithUnderscore = #_; + CharDecimalStartingWithManyUnderscores = #__; + +implementation + +end.