diff options
author | Vincent Ambo <mail@tazj.in> | 2021-12-13T22·51+0300 |
---|---|---|
committer | Vincent Ambo <mail@tazj.in> | 2021-12-13T23·15+0300 |
commit | 019f8fd2113df4c5247c3969c60fd4f0e08f91f7 (patch) | |
tree | 76a857f61aa88f62a30e854651e8439db77fd0ea /users/wpcarro/tools/run/main.go | |
parent | 464bbcb15c09813172c79820bcf526bb10cf4208 (diff) | |
parent | 6123e976928ca3d8d93f0b2006b10b5f659eb74d (diff) |
subtree(users/wpcarro): docking briefcase at '24f5a642' r/3226
git-subtree-dir: users/wpcarro git-subtree-mainline: 464bbcb15c09813172c79820bcf526bb10cf4208 git-subtree-split: 24f5a642af3aa1627bbff977f0a101907a02c69f Change-Id: I6105b3762b79126b3488359c95978cadb3efa789
Diffstat (limited to 'users/wpcarro/tools/run/main.go')
-rw-r--r-- | users/wpcarro/tools/run/main.go | 49 |
1 files changed, 49 insertions, 0 deletions
diff --git a/users/wpcarro/tools/run/main.go b/users/wpcarro/tools/run/main.go new file mode 100644 index 000000000000..04906ece91f7 --- /dev/null +++ b/users/wpcarro/tools/run/main.go @@ -0,0 +1,49 @@ +package main + +import ( + "encoding/json" + "fmt" + "io/ioutil" + "log" + "os" + "os/exec" + "path/filepath" + "strings" + "utils" +) + +func main() { + if len(os.Args) != 2 { + log.Fatal("You can only call run with a single file at a time.") + } + + rulesPath := utils.Resolve("run.json", []string{"/home/wpcarro/.config/run/run.json"}) + b, err := ioutil.ReadFile(rulesPath) + if err != nil { + log.Fatal("Could not locate a run.json file: ", err) + } + rules := map[string]string{} + err = json.Unmarshal(b, &rules) + if err != nil { + log.Fatal("Could not decode run.json as JSON: ", err) + } + + fileName := os.Args[1] + ext := filepath.Ext(fileName) + cmd, ok := rules[ext] + + if !ok { + log.Fatalf("No rules for extension, %s, have been defined.", ext) + } + + // TODO(wpcarro): Support more sophisticated parsing than just string + // splitting. To handle 'cases like this'. + tokens := strings.Split(strings.Replace(cmd, "$file", fileName, 1), " ") + c := exec.Command(tokens[0], tokens[1:]...) + err = c.Start() + // TODO(wpcarro): Forward STDERR and STDOUT. + if err != nil { + log.Fatal(err) + } + fmt.Println(c.Wait()) +} |