strings.go 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189
  1. package sprig
  2. import (
  3. "encoding/base32"
  4. "encoding/base64"
  5. "fmt"
  6. "reflect"
  7. "strconv"
  8. "strings"
  9. )
  10. func base64encode(v string) string {
  11. return base64.StdEncoding.EncodeToString([]byte(v))
  12. }
  13. func base64decode(v string) string {
  14. data, err := base64.StdEncoding.DecodeString(v)
  15. if err != nil {
  16. return err.Error()
  17. }
  18. return string(data)
  19. }
  20. func base32encode(v string) string {
  21. return base32.StdEncoding.EncodeToString([]byte(v))
  22. }
  23. func base32decode(v string) string {
  24. data, err := base32.StdEncoding.DecodeString(v)
  25. if err != nil {
  26. return err.Error()
  27. }
  28. return string(data)
  29. }
  30. func quote(str ...any) string {
  31. out := make([]string, 0, len(str))
  32. for _, s := range str {
  33. if s != nil {
  34. out = append(out, fmt.Sprintf("%q", strval(s)))
  35. }
  36. }
  37. return strings.Join(out, " ")
  38. }
  39. func squote(str ...any) string {
  40. out := make([]string, 0, len(str))
  41. for _, s := range str {
  42. if s != nil {
  43. out = append(out, fmt.Sprintf("'%v'", s))
  44. }
  45. }
  46. return strings.Join(out, " ")
  47. }
  48. func cat(v ...any) string {
  49. v = removeNilElements(v)
  50. r := strings.TrimSpace(strings.Repeat("%v ", len(v)))
  51. return fmt.Sprintf(r, v...)
  52. }
  53. func indent(spaces int, v string) string {
  54. pad := strings.Repeat(" ", spaces)
  55. return pad + strings.Replace(v, "\n", "\n"+pad, -1)
  56. }
  57. func nindent(spaces int, v string) string {
  58. return "\n" + indent(spaces, v)
  59. }
  60. func replace(old, new, src string) string {
  61. return strings.Replace(src, old, new, -1)
  62. }
  63. func plural(one, many string, count int) string {
  64. if count == 1 {
  65. return one
  66. }
  67. return many
  68. }
  69. func strslice(v any) []string {
  70. switch v := v.(type) {
  71. case []string:
  72. return v
  73. case []any:
  74. b := make([]string, 0, len(v))
  75. for _, s := range v {
  76. if s != nil {
  77. b = append(b, strval(s))
  78. }
  79. }
  80. return b
  81. default:
  82. val := reflect.ValueOf(v)
  83. switch val.Kind() {
  84. case reflect.Array, reflect.Slice:
  85. l := val.Len()
  86. b := make([]string, 0, l)
  87. for i := 0; i < l; i++ {
  88. value := val.Index(i).Interface()
  89. if value != nil {
  90. b = append(b, strval(value))
  91. }
  92. }
  93. return b
  94. default:
  95. if v == nil {
  96. return []string{}
  97. }
  98. return []string{strval(v)}
  99. }
  100. }
  101. }
  102. func removeNilElements(v []any) []any {
  103. newSlice := make([]any, 0, len(v))
  104. for _, i := range v {
  105. if i != nil {
  106. newSlice = append(newSlice, i)
  107. }
  108. }
  109. return newSlice
  110. }
  111. func strval(v any) string {
  112. switch v := v.(type) {
  113. case string:
  114. return v
  115. case []byte:
  116. return string(v)
  117. case error:
  118. return v.Error()
  119. case fmt.Stringer:
  120. return v.String()
  121. default:
  122. return fmt.Sprintf("%v", v)
  123. }
  124. }
  125. func trunc(c int, s string) string {
  126. if c < 0 && len(s)+c > 0 {
  127. return s[len(s)+c:]
  128. }
  129. if c >= 0 && len(s) > c {
  130. return s[:c]
  131. }
  132. return s
  133. }
  134. func join(sep string, v any) string {
  135. return strings.Join(strslice(v), sep)
  136. }
  137. func split(sep, orig string) map[string]string {
  138. parts := strings.Split(orig, sep)
  139. res := make(map[string]string, len(parts))
  140. for i, v := range parts {
  141. res["_"+strconv.Itoa(i)] = v
  142. }
  143. return res
  144. }
  145. func splitn(sep string, n int, orig string) map[string]string {
  146. parts := strings.SplitN(orig, sep, n)
  147. res := make(map[string]string, len(parts))
  148. for i, v := range parts {
  149. res["_"+strconv.Itoa(i)] = v
  150. }
  151. return res
  152. }
  153. // substring creates a substring of the given string.
  154. //
  155. // If start is < 0, this calls string[:end].
  156. //
  157. // If start is >= 0 and end < 0 or end bigger than s length, this calls string[start:]
  158. //
  159. // Otherwise, this calls string[start, end].
  160. func substring(start, end int, s string) string {
  161. if start < 0 {
  162. return s[:end]
  163. }
  164. if end < 0 || end > len(s) {
  165. return s[start:]
  166. }
  167. return s[start:end]
  168. }