aboutsummaryrefslogtreecommitdiffstats
path: root/vendor/github.com/daixiang0/gci/pkg/section/parser.go
diff options
context:
space:
mode:
authorTaras Madan <tarasmadan@google.com>2022-09-05 14:27:54 +0200
committerGitHub <noreply@github.com>2022-09-05 12:27:54 +0000
commitb2f2446b46bf02821d90ebedadae2bf7ae0e880e (patch)
tree923cf42842918d6bebca1d6bbdc08abed54d274d /vendor/github.com/daixiang0/gci/pkg/section/parser.go
parente6654faff4bcca4be92e9a8596fd4b77f747c39e (diff)
go.mod, vendor: update (#3358)
* go.mod, vendor: remove unnecessary dependencies Commands: 1. go mod tidy 2. go mod vendor * go.mod, vendor: update cloud.google.com/go Commands: 1. go get -u cloud.google.com/go 2. go mod tidy 3. go mod vendor * go.mod, vendor: update cloud.google.com/* Commands: 1. go get -u cloud.google.com/storage cloud.google.com/logging 2. go mod tidy 3. go mod vendor * go.mod, .golangci.yml, vendor: update *lint* Commands: 1. go get -u golang.org/x/tools github.com/golangci/golangci-lint@v1.47.0 2. go mod tidy 3. go mod vendor 4. edit .golangci.yml to suppress new errors (resolved in the same PR later) * all: fix lint errors hash.go: copy() recommended by gosimple parse.go: ent is never nil verifier.go: signal.Notify() with unbuffered channel is bad. Have no idea why. * .golangci.yml: adjust godot rules check-all is deprecated, but still work if you're hesitating too - I'll remove this commit
Diffstat (limited to 'vendor/github.com/daixiang0/gci/pkg/section/parser.go')
-rw-r--r--vendor/github.com/daixiang0/gci/pkg/section/parser.go44
1 files changed, 44 insertions, 0 deletions
diff --git a/vendor/github.com/daixiang0/gci/pkg/section/parser.go b/vendor/github.com/daixiang0/gci/pkg/section/parser.go
new file mode 100644
index 000000000..9834dcd13
--- /dev/null
+++ b/vendor/github.com/daixiang0/gci/pkg/section/parser.go
@@ -0,0 +1,44 @@
+package section
+
+import (
+ "errors"
+ "fmt"
+ "strings"
+)
+
+func Parse(data []string) (SectionList, error) {
+ if len(data) == 0 {
+ return nil, nil
+ }
+
+ var list SectionList
+ var errString string
+ for _, d := range data {
+ s := strings.ToLower(d)
+ if len(s) == 0 {
+ return nil, nil
+ }
+
+ if s == "default" {
+ list = append(list, Default{})
+ } else if s == "standard" {
+ list = append(list, Standard{})
+ } else if s == "newline" {
+ list = append(list, NewLine{})
+ } else if strings.HasPrefix(s, "prefix(") && len(d) > 8 {
+ list = append(list, Custom{d[7 : len(d)-1]})
+ } else if strings.HasPrefix(s, "commentline(") && len(d) > 13 {
+ list = append(list, Custom{d[12 : len(d)-1]})
+ } else if s == "dot" {
+ list = append(list, Dot{})
+ } else if s == "blank" {
+ list = append(list, Blank{})
+ } else {
+ errString += fmt.Sprintf(" %s", s)
+ }
+ }
+ if errString != "" {
+ return nil, errors.New(fmt.Sprintf("invalid params:%s", errString))
+ }
+ return list, nil
+}