Skip to content

Commit

Permalink
Merge pull request #901 from macshome/PrettyPrinterPerformance
Browse files Browse the repository at this point in the history
PrettyPrinterPerformance Optimized the PrettyPrinter for #894
  • Loading branch information
ahoppen authored Dec 19, 2024
2 parents cd042df + bb5b4c9 commit f334bb3
Showing 1 changed file with 10 additions and 9 deletions.
19 changes: 10 additions & 9 deletions Sources/SwiftFormat/PrettyPrint/PrettyPrintBuffer.swift
Original file line number Diff line number Diff line change
Expand Up @@ -122,16 +122,17 @@ struct PrettyPrintBuffer {
// In case of comments, we may get a multi-line string.
// To account for that case, we need to correct the lineNumber count.
// The new column is only the position within the last line.
let lines = text.split(separator: "\n")
lineNumber += lines.count - 1
if lines.count > 1 {
// in case we have inserted new lines, we need to reset the column
column = lines.last?.count ?? 0
} else {
// in case it is an end of line comment or a single line comment,
// we just add to the current column
column += lines.last?.count ?? 0
var lastLength = 0
// We are only interested in "\n" we can use the UTF8 view and skip the grapheme clustering.
for element in text.utf8 {
if element == UInt8(ascii: "\n") {
lineNumber += 1
lastLength = 0
} else {
lastLength += 1
}
}
column += lastLength
}

/// Request that the given number of spaces be printed out before the next text token.
Expand Down

0 comments on commit f334bb3

Please sign in to comment.