Skip to content

Commit

Permalink
Preprocess unicode escapes when parsing using JavaParser (#6632)
Browse files Browse the repository at this point in the history
  • Loading branch information
kelloggm committed Jun 3, 2024
1 parent 959822a commit c85eb69
Show file tree
Hide file tree
Showing 2 changed files with 13 additions and 0 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -61,6 +61,7 @@ public class JavaParserUtil {
public static CompilationUnit parseCompilationUnit(InputStream inputStream) {
ParserConfiguration parserConfiguration = new ParserConfiguration();
parserConfiguration.setLanguageLevel(DEFAULT_LANGUAGE_LEVEL);
parserConfiguration.setPreprocessUnicodeEscapes(true);
JavaParser javaParser = new JavaParser(parserConfiguration);
ParseResult<CompilationUnit> parseResult = javaParser.parse(inputStream);
if (parseResult.isSuccessful() && parseResult.getResult().isPresent()) {
Expand All @@ -86,6 +87,7 @@ public static CompilationUnit parseCompilationUnit(InputStream inputStream) {
public static CompilationUnit parseCompilationUnit(File file) throws FileNotFoundException {
ParserConfiguration configuration = new ParserConfiguration();
configuration.setLanguageLevel(DEFAULT_LANGUAGE_LEVEL);
configuration.setPreprocessUnicodeEscapes(true);
JavaParser javaParser = new JavaParser(configuration);
ParseResult<CompilationUnit> parseResult = javaParser.parse(file);
if (parseResult.isSuccessful() && parseResult.getResult().isPresent()) {
Expand Down Expand Up @@ -142,6 +144,7 @@ public static StubUnit parseStubUnit(InputStream inputStream) {
configuration.setLexicalPreservationEnabled(false);
configuration.setAttributeComments(false);
configuration.setDetectOriginalLineSeparator(false);
configuration.setPreprocessUnicodeEscapes(true);
JavaParser javaParser = new JavaParser(configuration);
ParseResult<StubUnit> parseResult = javaParser.parseStubUnit(inputStream);
if (parseResult.isSuccessful() && parseResult.getResult().isPresent()) {
Expand Down Expand Up @@ -188,6 +191,7 @@ public static Expression parseExpression(String expression, LanguageLevel langua
configuration.setLexicalPreservationEnabled(false);
configuration.setAttributeComments(false);
configuration.setDetectOriginalLineSeparator(false);
configuration.setPreprocessUnicodeEscapes(true);
JavaParser javaParser = new JavaParser(configuration);
ParseResult<Expression> parseResult = javaParser.parseExpression(expression);
if (parseResult.isSuccessful() && parseResult.getResult().isPresent()) {
Expand Down
9 changes: 9 additions & 0 deletions framework/tests/all-systems/UnicodeEscape.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
// Test case for https://github.com/typetools/checker-framework/issues/6631.

public class UnicodeEscape {
void foo() {
while (true) {
System.out.print("Enter an expression like \u005c"1+(2+3)*4;\u005c" :");
}
}
}

0 comments on commit c85eb69

Please sign in to comment.