Skip to content

Commit

Permalink
Off by one errors on javadoc
Browse files Browse the repository at this point in the history
Signed-off-by: Rob Stryker <[email protected]>
  • Loading branch information
Rob Stryker authored and robstryker committed Apr 17, 2024
1 parent 11d84f6 commit 61765fd
Showing 1 changed file with 16 additions and 2 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -778,11 +778,10 @@ private void setJavadocForNode(JCTree javac, ASTNode node) {
String[] split = jdStringContents.split("\n");
int runningTally = 0;
TagElement previousTag = null;
// TODO Now split by line? TODO there's much more to do here
for( int i = 0; i < split.length; i++ ) {
String line = split[i];
int leadingTrimmedFromLine = line.length() - trimLeadingWhiteAndStars(line).length();
int trailingTrimmedFromLine = line.length() - trimLeadingWhiteAndStars(new StringBuffer(line).reverse().toString()).length();
int trailingTrimmedFromLine = line.length() - trimJavadocLineEndings(line).length();
int lineStart = contentsStart + runningTally;
int lineTrimmedStart = contentsStart + leadingTrimmedFromLine + runningTally;
int lineTrimmedEnd = lineStart + line.length() - trailingTrimmedFromLine;
Expand Down Expand Up @@ -815,7 +814,22 @@ private void setJavadocForNode(JCTree javac, ASTNode node) {
}
}

private String trimJavadocLineEndings(String l) {
String stripTrailingSpaces = l.stripTrailing();
if( stripTrailingSpaces.endsWith("*")) {
int length = stripTrailingSpaces.length();
for( int i = length - 1; i > 0; i-- ) {
if(stripTrailingSpaces.charAt(i) != '*') {
return stripTrailingSpaces.substring(0, i);
}
}
}
return l;
}
private String trimLeadingWhiteAndStars(String line) {
if( line.stripLeading().startsWith("*")) {

}
int length = line.length();
for( int i = 0; i < length; i++ ) {
if( !Character.isWhitespace(line.charAt(i)) && line.charAt(i) != '*') {
Expand Down

0 comments on commit 61765fd

Please sign in to comment.