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 | |
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')
-rw-r--r-- | users/wpcarro/tools/run/.envrc | 2 | ||||
-rw-r--r-- | users/wpcarro/tools/run/README.md | 30 | ||||
-rw-r--r-- | users/wpcarro/tools/run/default.nix | 11 | ||||
-rw-r--r-- | users/wpcarro/tools/run/main.go | 49 | ||||
-rw-r--r-- | users/wpcarro/tools/run/shell.nix | 10 |
5 files changed, 102 insertions, 0 deletions
diff --git a/users/wpcarro/tools/run/.envrc b/users/wpcarro/tools/run/.envrc new file mode 100644 index 000000000000..a4a62da526d3 --- /dev/null +++ b/users/wpcarro/tools/run/.envrc @@ -0,0 +1,2 @@ +source_up +use_nix diff --git a/users/wpcarro/tools/run/README.md b/users/wpcarro/tools/run/README.md new file mode 100644 index 000000000000..d3cccecf910c --- /dev/null +++ b/users/wpcarro/tools/run/README.md @@ -0,0 +1,30 @@ +# run + +Simplify the commands you call to run scripts on the command line. + +```shell +> run path/to/file.py +> run path/to/file.ts +``` + +## How? + +Define a run.json configuration mapping commands to filename extensions like +so: +```json +{ + ".ts": "npx ts-node $file", + ".py": "python3 $file" +} +``` + +Then call `run path/to/some/file.ts` on the command line, and `npx ts-node +file.ts` will run. + +## Installation + +Install `run` using Nix. + +```shell +> nix-env -iA briefcase.run +``` diff --git a/users/wpcarro/tools/run/default.nix b/users/wpcarro/tools/run/default.nix new file mode 100644 index 000000000000..7d772c3f9079 --- /dev/null +++ b/users/wpcarro/tools/run/default.nix @@ -0,0 +1,11 @@ +{ pkgs, depot, briefcase, ... }: + +depot.buildGo.program { + name = "run"; + srcs = [ + ./main.go + ]; + deps = with briefcase.gopkgs; [ + utils + ]; +} 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()) +} diff --git a/users/wpcarro/tools/run/shell.nix b/users/wpcarro/tools/run/shell.nix new file mode 100644 index 000000000000..e14bffae487c --- /dev/null +++ b/users/wpcarro/tools/run/shell.nix @@ -0,0 +1,10 @@ +let + briefcase = import <briefcase> {}; + pkgs = briefcase.third_party.pkgs; +in pkgs.mkShell { + buildInputs = with pkgs; [ + go + goimports + godef + ]; +} |