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")
}
};

Readme

Keywords

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