mirror of
https://codeberg.org/forgejo/forgejo.git
synced 2026-05-13 06:20:24 +00:00
- Go has a suite of small linters that helps with modernizing Go code by using newer functions and catching small mistakes, https://pkg.go.dev/golang.org/x/tools/go/analysis/passes/modernize. - Enable this linter in golangci-lint. - There's also [`go fix`](https://go.dev/blog/gofix), which is not yet released as a linter in golangci-lint: https://github.com/golangci/golangci-lint/pull/6385 Reviewed-on: https://codeberg.org/forgejo/forgejo/pulls/11936 Reviewed-by: Mathieu Fenniak <mfenniak@noreply.codeberg.org> Co-authored-by: Gusted <postmaster@gusted.xyz> Co-committed-by: Gusted <postmaster@gusted.xyz>
65 lines
1.6 KiB
Go
65 lines
1.6 KiB
Go
// Copyright 2021 The Gitea Authors. All rights reserved.
|
|
// SPDX-License-Identifier: MIT
|
|
|
|
package util
|
|
|
|
import (
|
|
"strings"
|
|
"unicode/utf8"
|
|
)
|
|
|
|
// in UTF8 "…" is 3 bytes so doesn't really gain us anything...
|
|
const (
|
|
utf8Ellipsis = "…"
|
|
asciiEllipsis = "..."
|
|
)
|
|
|
|
// SplitStringAtByteN splits a string at byte n accounting for rune boundaries. (Combining characters are not accounted for.)
|
|
func SplitStringAtByteN(input string, n int) (left, right string) {
|
|
if len(input) <= n {
|
|
return input, ""
|
|
}
|
|
|
|
if !utf8.ValidString(input) {
|
|
if n-3 < 0 {
|
|
return input, ""
|
|
}
|
|
return input[:n-3] + asciiEllipsis, asciiEllipsis + input[n-3:]
|
|
}
|
|
|
|
end := 0
|
|
for end <= n-3 {
|
|
_, size := utf8.DecodeRuneInString(input[end:])
|
|
if end+size > n-3 {
|
|
break
|
|
}
|
|
end += size
|
|
}
|
|
|
|
return input[:end] + utf8Ellipsis, utf8Ellipsis + input[end:]
|
|
}
|
|
|
|
// SplitTrimSpace splits the string at given separator and trims leading and trailing space
|
|
func SplitTrimSpace(input, sep string) []string {
|
|
// Trim initial leading & trailing space
|
|
input = strings.TrimSpace(input)
|
|
// replace CRLF with LF
|
|
input = strings.ReplaceAll(input, "\r\n", "\n")
|
|
|
|
var stringList []string
|
|
for s := range strings.SplitSeq(input, sep) {
|
|
// trim leading and trailing space
|
|
stringList = append(stringList, strings.TrimSpace(s))
|
|
}
|
|
|
|
return stringList
|
|
}
|
|
|
|
// TruncateRunes returns a truncated string with given rune limit,
|
|
// it returns input string if its rune length doesn't exceed the limit.
|
|
func TruncateRunes(str string, limit int) string {
|
|
if utf8.RuneCountInString(str) < limit {
|
|
return str
|
|
}
|
|
return string([]rune(str)[:limit])
|
|
}
|