austere

0.0.5 • Public • Published

Austere

A no-frills cli argument parser for reason. Forked from minimist.re, which is inspired by minimist and yargs.

Unlike minimist.re, this only targets Javascript/Node and has no bs-native dependency.

Example

let parse = Austere.parse(~alias=[("h", "help")], ~presence=["help"], ~multi=["rename"], ~strings=["base"]);

let help = {|
# pack.re - a simple js bundler for reason

Usage: pack.re [options] entry-file.js > bundle.js

  --base (default: current directory)
      expected to contain node_modules
  --rename newName=realName (can be defined multiple times)
      maps `require("newName")` to a node_module called "realName"
  -h, --help
      print this help
|};

let fail = (msg) => {
  Js.log(msg);
  Js.log(help);
  exit(1);
};

let args = List.tl(Array.to_list(Sys.argv));
/* Some example args for you */
let args = ["--base", "awesome", "some-entry.js"];

switch (parse(args)) {
| Austere.Error(err) => fail(Austere.report(err))
| Ok(opts) =>
if (Austere.StrSet.mem("help", opts.presence)) {
  Js.log(help); exit(0);
} else switch (opts.rest) {
  | [] => fail("Expected entry file as final argument")
  | [entry] => {
    let base = Austere.get(opts.strings, "base");
    let renames = Austere.multi(opts.multi, "rename");
    Js.log("All good!")
  }
  | _ => fail("Only one entry file allowed")
}
};

/austere/

    Package Sidebar

    Install

    npm i austere

    Weekly Downloads

    0

    Version

    0.0.5

    License

    MIT

    Unpacked Size

    109 kB

    Total Files

    16

    Last publish

    Collaborators

    • rawtoast