Skip to content

Commit

Permalink
8319339: Internal error on spurious markup in a hybrid snippet
Browse files Browse the repository at this point in the history
Reviewed-by: jjg
  • Loading branch information
pavelrappo committed Nov 10, 2023
1 parent ea1ffa3 commit c9077b8
Show file tree
Hide file tree
Showing 3 changed files with 142 additions and 9 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -376,9 +376,10 @@ private Content generateContent(Element holder, DocTree tag)
StyledText externalSnippet = null;

try {
Diags d = (text, pos) -> {
Diags d = (key, pos) -> {
var path = utils.getCommentHelper(holder)
.getDocTreePath(snippetTag.getBody());
var text = resources.getText(key);
config.getReporter().print(Diagnostic.Kind.WARNING,
path, pos, pos, pos, text);
};
Expand All @@ -397,7 +398,7 @@ private Content generateContent(Element holder, DocTree tag)

try {
var finalFileObject = fileObject;
Diags d = (text, pos) -> messages.warning(finalFileObject, pos, pos, pos, text);
Diags d = (key, pos) -> messages.warning(finalFileObject, pos, pos, pos, key);
if (externalContent != null) {
externalSnippet = parse(resources, d, language, externalContent);
}
Expand Down Expand Up @@ -484,7 +485,7 @@ private StyledText parse(Resources resources, Diags diags, Optional<Language> la
}

public interface Diags {
void warn(String text, int pos);
void warn(String key, int pos);
}

private static String stringValueOf(AttributeTree at) throws BadSnippetException {
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
/*
* Copyright (c) 2020, 2022, Oracle and/or its affiliates. All rights reserved.
* Copyright (c) 2020, 2023, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
Expand Down Expand Up @@ -161,7 +161,7 @@ record OffsetAndLine(int offset, String line) { }
}
}
if (parsedTags.isEmpty()) { // (2)
diags.warn(resources.getText("doclet.snippet.markup.spurious"), next.offset() + markedUpLine.start("markup"));
diags.warn("doclet.snippet.markup.spurious", next.offset() + markedUpLine.start("markup"));
line = rawLine + (addLineTerminator ? "\n" : "");
} else { // (3)
hasMarkup = true;
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
/*
* Copyright (c) 2021, 2022, Oracle and/or its affiliates. All rights reserved.
* Copyright (c) 2021, 2023, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
Expand All @@ -23,7 +23,7 @@

/*
* @test
* @bug 8266666 8281969
* @bug 8266666 8281969 8319339
* @summary Implementation for snippets
* @library /tools/lib ../../lib
* @modules jdk.compiler/com.sun.tools.javac.api
Expand Down Expand Up @@ -259,8 +259,12 @@ public void testNegativeInlineExternalHybridTagMarkup_NextLinePutOnLastLine(Path
Path srcDir = base.resolve("src");
Path outDir = base.resolve("out");
var goodFile = "good.txt";
// use two files that differ in name but not content, to work around
// error deduplication, whereby an error related to coordinates
// (file, pos) reported before is suppressed; see:
// com.sun.tools.javac.util.Log.shouldReport(JavaFileObject, int)
var badFile = "bad.txt";
var badFile2 = "bad2.txt"; // to workaround error deduplication
var badFile2 = "bad2.txt";
new ClassBuilder(tb, "pkg.A")
.setModifiers("public", "class")
.addMembers(
Expand Down Expand Up @@ -625,7 +629,7 @@ public void testPositiveInlineTagMarkup_BlankLinesFromNextLineMarkup(Path base)
}

@Test
public void testPositiveInlineTagMarkup_FalseMarkup(Path base) throws Exception {
public void testPositiveInlineTagMarkup_SpuriousMarkup(Path base) throws Exception {
var testCases = List.of(
new TestCase(
"""
Expand Down Expand Up @@ -661,6 +665,134 @@ public void testPositiveInlineTagMarkup_FalseMarkup(Path base) throws Exception
""")
);
testPositive(base, testCases);
checkOutput(Output.OUT, true, """
A.java:6: warning: spurious markup
// @formatter:off
^""","""
A.java:9: warning: spurious markup
// @formatter:on
^""","""
A.java:17: warning: spurious markup
// @formatter:off
^""","""
A.java:22: warning: spurious markup
// @formatter:on
^""");
}

/*
* If spurious markup appears in an external snippet or either side of a
* hybrid snippet, then all of the below is true:
*
* - no error is raised
* - relevant warnings are emitted
* - spurious markup is output literally
*/
@Test
public void testPositiveExternalHybridTagMarkup_SpuriousMarkup(Path base) throws Exception {
Path srcDir = base.resolve("src");
Path outDir = base.resolve("out");
var plain = "plain.txt";
var withRegion = "withRegion.txt";
new ClassBuilder(tb, "pkg.A")
.setModifiers("public", "class")
.addMembers(
ClassBuilder.MethodBuilder
.parse("public void external() { }")
.setComments("""
{@snippet file="%s"}
""".formatted(plain)))
.addMembers(
ClassBuilder.MethodBuilder
.parse("public void hybrid1() { }")
.setComments("""
{@snippet file="%s":
First line
// @formatter:off
Second Line
Third line
// @formatter:on
Fourth line
}
""".formatted(plain)))
.addMembers(
ClassBuilder.MethodBuilder
.parse("public void hybrid2() { }")
.setComments("""
{@snippet file="%s" region="showThis" :
Second Line
Third line
}
""".formatted(withRegion)))
.addMembers(
ClassBuilder.MethodBuilder
.parse("public void hybrid3() { }")
.setComments("""
{@snippet file="%s" region="showThis" :
First line
// @formatter:off
Second Line // @start region=showThis
Third line
// @end
// @formatter:on
Fourth line
}
""".formatted(withRegion)))
.write(srcDir);

addSnippetFile(srcDir, "pkg", plain, """
First line
// @formatter:off
Second Line
Third line
// @formatter:on
Fourth line
""");
addSnippetFile(srcDir, "pkg", withRegion, """
First line
// @formatter:off
Second Line // @start region=showThis
Third line
// @end
// @formatter:on
Fourth line
""");
javadoc("-d", outDir.toString(),
"-sourcepath", srcDir.toString(),
"pkg");
checkExit(Exit.OK);
checkNoCrashes();
checkOutput(Output.OUT, true, """
%s:2: warning: spurious markup
// @formatter:off
^""".formatted(plain), """
%s:5: warning: spurious markup
// @formatter:on
^""".formatted(plain), """
A.java:11: warning: spurious markup
// @formatter:off
^""", """
A.java:14: warning: spurious markup
// @formatter:on
^""", """
%s:2: warning: spurious markup
// @formatter:off
^""".formatted(plain), """
%s:5: warning: spurious markup
// @formatter:on
^""".formatted(plain), """
%s:2: warning: spurious markup
// @formatter:off
^""".formatted(withRegion), """
%s:6: warning: spurious markup
// @formatter:on
^""".formatted(withRegion), """
A.java:31: warning: spurious markup
// @formatter:off
^""", """
A.java:35: warning: spurious markup
// @formatter:on
^""");
}

@Test
Expand Down

0 comments on commit c9077b8

Please sign in to comment.