mirror of
https://github.com/coredns/coredns.git
synced 2025-10-27 16:24:19 -04:00
* perf: avoid string concatenation in loops Apply perfpsrint linter Signed-off-by: Philippe Antoine <contact@catenacyber.fr> * ci: enable perfsprint Signed-off-by: Philippe Antoine <contact@catenacyber.fr> --------- Signed-off-by: Philippe Antoine <contact@catenacyber.fr>
24 lines
558 B
Go
24 lines
558 B
Go
package auto
|
|
|
|
import (
|
|
"strings"
|
|
)
|
|
|
|
// rewriteToExpand rewrites our template string to one that we can give to regexp.ExpandString. This basically
|
|
// involves prefixing any '{' with a '$'.
|
|
func rewriteToExpand(s string) string {
|
|
// Pretty dumb at the moment, every { will get a $ prefixed.
|
|
// Also wasteful as we build the string with +=. This is OKish
|
|
// as we do this during config parsing.
|
|
|
|
var copySb strings.Builder
|
|
for _, c := range s {
|
|
if c == '{' {
|
|
copySb.WriteString("$")
|
|
}
|
|
copySb.WriteString(string(c))
|
|
}
|
|
|
|
return copySb.String()
|
|
}
|