mirror of
https://github.com/flynx/argv.js.git
synced 2025-10-28 18:30:07 +00:00
Signed-off-by: Alex A. Naanou <alex.nanou@gmail.com>
argv.js
Simple argv parser
Motivation
I needed a new argv parser for a quick and dirty project I was working on
and evaluating and selecting the propper existing parser and then learining its
API, quirks and adapting the architecture to it seemd to be more complicated,
require more effort and far less fun than putting together a trivial parser
myself in a couple of hours.
This code is an evolution of that parser.
Features
- Simple
- Supports both the option (a-la
find) and command (a-lagit) paradigms - Nestable – parsers can be nested as option/command handlers defining independent nested contexts
- Option expansion –
-abcexpands to-a -b -cif-abcis not defined - Option/command value passing
- Environment variable option/command values – env can control option defaults
- Reasonable defaults
-helpgenerator- common option aliases
- Extensible:
- Hooks for option value conversion (XXX should this be implemented???)
- Hooks for dynamic option/command handling
- Customizable error and stop condition handling
Installation
$ npm install ig-argv
Basic usage
Create a script and make it runnable
$ toch script.js
$ chmod +x script.js
Now for the code
#!/usr/bin/env node
// compatible with both node's and RequireJS' require(..)
var argv = require('ig-argv')
var parser = argv.Parser({
// XXX
})
.then(function(){
// XXX
})
// run the parser only if script.js is run directly...
if(__filename == require.main){
parser(process.argv) }
This will create a parser that supports the folowing:
$ ./script.js --help
License
Copyright (c) 2016-2020, Alex A. Naanou,
All rights reserved.
Description
Languages
JavaScript
100%