Skip to content

Commit

Permalink
Merge pull request #323 from commonmark/prepare-line
Browse files Browse the repository at this point in the history
Simplify `prepareLine`
  • Loading branch information
robinst authored Apr 27, 2024
2 parents 124edae + 80d7929 commit 7dcc85b
Show file tree
Hide file tree
Showing 2 changed files with 11 additions and 29 deletions.
Original file line number Diff line number Diff line change
@@ -1,9 +1,9 @@
package org.commonmark.internal;

import org.commonmark.parser.beta.InlineContentParserFactory;
import org.commonmark.internal.util.Parsing;
import org.commonmark.node.*;
import org.commonmark.parser.*;
import org.commonmark.parser.beta.InlineContentParserFactory;
import org.commonmark.parser.block.*;
import org.commonmark.parser.delimiter.DelimiterProcessor;
import org.commonmark.text.Characters;
Expand Down Expand Up @@ -126,7 +126,7 @@ public Document parse(String input) {
lineStart = lineBreak + 1;
}
}
if (input.length() > 0 && (lineStart == 0 || lineStart < input.length())) {
if (!input.isEmpty() && (lineStart == 0 || lineStart < input.length())) {
String line = input.substring(lineStart);
parseLine(line);
}
Expand Down Expand Up @@ -189,7 +189,7 @@ public BlockParser getActiveBlockParser() {
* Analyze a line of text and update the document appropriately. We parse markdown text by calling this on each
* line of input, then finalizing the document.
*/
private void parseLine(CharSequence ln) {
private void parseLine(String ln) {
setLine(ln);

// For each containing block, try to parse the associated line start.
Expand Down Expand Up @@ -314,13 +314,13 @@ private void parseLine(CharSequence ln) {
}
}

private void setLine(CharSequence ln) {
private void setLine(String ln) {
lineIndex++;
index = 0;
column = 0;
columnIsInTab = false;

CharSequence lineContent = prepareLine(ln);
String lineContent = prepareLine(ln);
SourceSpan sourceSpan = null;
if (includeSourceSpans != IncludeSourceSpans.NONE) {
sourceSpan = SourceSpan.of(lineIndex, 0, lineContent.length());
Expand Down Expand Up @@ -550,29 +550,11 @@ private void closeBlockParsers(int count) {
/**
* Prepares the input line replacing {@code \0}
*/
private static CharSequence prepareLine(CharSequence line) {
// Avoid building a new string in the majority of cases (no \0)
StringBuilder sb = null;
int length = line.length();
for (int i = 0; i < length; i++) {
char c = line.charAt(i);
if (c == '\0') {
if (sb == null) {
sb = new StringBuilder(length);
sb.append(line, 0, i);
}
sb.append('\uFFFD');
} else {
if (sb != null) {
sb.append(c);
}
}
}

if (sb != null) {
return sb.toString();
} else {
private static String prepareLine(String line) {
if (line.indexOf('\0') == -1) {
return line;
} else {
return line.replace('\0', '\uFFFD');
}
}

Expand Down
4 changes: 2 additions & 2 deletions pom.xml
Original file line number Diff line number Diff line change
Expand Up @@ -168,12 +168,12 @@
<dependency>
<groupId>org.openjdk.jmh</groupId>
<artifactId>jmh-core</artifactId>
<version>1.17.5</version>
<version>1.37</version>
</dependency>
<dependency>
<groupId>org.openjdk.jmh</groupId>
<artifactId>jmh-generator-annprocess</artifactId>
<version>1.17.5</version>
<version>1.37</version>
</dependency>
</dependencies>
</dependencyManagement>
Expand Down

0 comments on commit 7dcc85b

Please sign in to comment.