Skip to content

Commit

Permalink
safer err handling
Browse files Browse the repository at this point in the history
  • Loading branch information
mauricedesaxe committed Jul 19, 2024
1 parent 4920137 commit 3342e3d
Showing 1 changed file with 31 additions and 10 deletions.
41 changes: 31 additions & 10 deletions main.go
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
package main

import (
"errors"
"flag"
"log"
"os"
Expand Down Expand Up @@ -91,7 +92,13 @@ func templCSSSort(flags Flags) {
originalContent := string(content)
assert(originalContent != "", "File is empty")

newContent := processContent(originalContent)
newContent, err := processContent(originalContent)
if err != nil {
if err.Error() == "no_classes_found" {
continue
}
log.Fatal(err)
}

// write the modified content back to the file
err = os.WriteFile(file, []byte(newContent), 0644)
Expand All @@ -103,29 +110,39 @@ func templCSSSort(flags Flags) {
log.Println("Done in", time.Since(start))
}

func processContent(content string) string {
func processContent(content string) (string, error) {
// find all classes in content
re := regexp.MustCompile(`class="([^"]+)"`)
matches := re.FindAllStringSubmatch(content, -1)
assert(len(matches) > 0, "No classes found")
if len(matches) == 0 {
return "", errors.New("no_classes_found")
}

for _, match := range matches {
classList := match[1]
assert(classList != "", "Class list is empty")
if classList == "" {
continue
}

// trim in place
classList = strings.TrimSpace(classList)
assert(classList != "", "Class list is empty")
if classList == "" {
continue
}

// any whitespace bigger then 1 char, reduce to 1 char
for strings.Contains(classList, " ") {
classList = strings.ReplaceAll(classList, " ", " ")
}
assert(classList != "", "Class list is empty")
if classList == "" {
continue
}

// split
classes := strings.Split(classList, " ")
assert(len(classes) > 0, "No classes found")
if len(classes) == 0 {
continue
}

// sort
sort.Strings(classes)
Expand All @@ -135,14 +152,18 @@ func processContent(content string) string {

// create new class list string
newClassList := strings.Join(classes, " ")
assert(newClassList != "", "New class list is empty")
if newClassList == "" {
continue
}

// replace class list in file
content = strings.Replace(content, match[0], "class=\""+newClassList+"\"", -1)
assert(content != "", "New content is empty")
if content == "" {
continue
}
}

return content
return content, nil
}

func removeDuplicates(slice []string) []string {
Expand Down

0 comments on commit 3342e3d

Please sign in to comment.