aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMitchell Riedstra <mitch@riedstra.dev>2022-12-28 19:29:42 -0500
committerMitchell Riedstra <mitch@riedstra.dev>2022-12-28 19:29:42 -0500
commitfefe7e5f765967f26d630abe0d09fc20be5f9d49 (patch)
treecea760cf33945a5075060dd1f734254a59f15d41
downloadscripts-fefe7e5f765967f26d630abe0d09fc20be5f9d49.tar.gz
scripts-fefe7e5f765967f26d630abe0d09fc20be5f9d49.tar.xz
initial
-rw-r--r--cmd/chardump/main.go41
-rw-r--r--cmd/fixpths/main.go54
-rw-r--r--go.mod3
3 files changed, 98 insertions, 0 deletions
diff --git a/cmd/chardump/main.go b/cmd/chardump/main.go
new file mode 100644
index 0000000..c275205
--- /dev/null
+++ b/cmd/chardump/main.go
@@ -0,0 +1,41 @@
+package main
+
+import (
+ "bytes"
+ "fmt"
+ "io"
+ "log"
+ "os"
+ "strconv"
+)
+
+var Logger = log.New(os.Stderr, "", 0)
+
+func dumpString(w io.Writer, s string) {
+ n := 0
+ for _, char := range s { // I don't care about the byte number, just chars...
+ // https://go.dev/ref/spec#Rune_literals
+ fmt.Fprintf(w,
+ "Number: %-4d Char: %-6s Unicode: %U Hex Bytes: %+v\n",
+ n,
+ strconv.QuoteRune(char),
+ char,
+ []byte(string(char)))
+ n++
+ }
+}
+
+func main() {
+ buf := &bytes.Buffer{}
+
+ n, err := io.Copy(buf, os.Stdin)
+ if err != io.EOF && err != nil {
+ Logger.Fatalf("Failed to read stdin: %s\n", err)
+ }
+
+ Logger.Println("------------------------")
+ Logger.Printf("Read in %d bytes\n", n)
+ Logger.Println("------------------------")
+
+ dumpString(os.Stdout, buf.String())
+}
diff --git a/cmd/fixpths/main.go b/cmd/fixpths/main.go
new file mode 100644
index 0000000..6730276
--- /dev/null
+++ b/cmd/fixpths/main.go
@@ -0,0 +1,54 @@
+package main
+
+import (
+ "flag"
+ "fmt"
+ "io/fs"
+ "log"
+ "os"
+ "path/filepath"
+ "regexp"
+)
+
+func main() {
+ fl := flag.NewFlagSet("fixpths", flag.ExitOnError)
+ pth := fl.String("p", "", "Path to scan and fix windows incompatible chars on")
+ rename := fl.Bool("rename", false, "Whether or not to actually rename the files to work on windows")
+ fl.Parse(os.Args[1:])
+
+ if *pth == "" {
+ fmt.Println("need a path")
+ os.Exit(2)
+ }
+
+ invalidChars := regexp.MustCompile(`(<|>|:|\||"|\\|\*|\?)`)
+
+ err := filepath.WalkDir(*pth, func(path string, d fs.DirEntry, err error) error {
+ if d.IsDir() {
+ return nil
+ }
+
+ if invalidChars.MatchString(path) {
+ if !*rename {
+ fmt.Printf("%s\n",
+ invalidChars.ReplaceAllString(path, "\033[1;31m${1}\033[0m"))
+ }
+
+ if *rename {
+ npath := invalidChars.ReplaceAllString(path, "_")
+ err := os.Rename(path, npath)
+ fmt.Printf("%s->%s\n", path, npath)
+ if err != nil {
+ log.Println(err)
+ }
+ }
+ }
+
+ return nil
+ })
+
+ if err != nil {
+ log.Println(err)
+ }
+
+}
diff --git a/go.mod b/go.mod
new file mode 100644
index 0000000..ed7cda5
--- /dev/null
+++ b/go.mod
@@ -0,0 +1,3 @@
+module riedstra.dev/go/scripts
+
+go 1.13