Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mblumtritt/parse-argv
A command line parser that only needs your help text.
https://github.com/mblumtritt/parse-argv
argv argv-parser cli parse parser ruby ruby-gem
Last synced: about 1 month ago
JSON representation
A command line parser that only needs your help text.
- Host: GitHub
- URL: https://github.com/mblumtritt/parse-argv
- Owner: mblumtritt
- License: bsd-3-clause
- Created: 2022-10-23T19:24:13.000Z (about 2 years ago)
- Default Branch: main
- Last Pushed: 2023-12-29T20:19:10.000Z (about 1 year ago)
- Last Synced: 2024-09-15T22:29:43.316Z (4 months ago)
- Topics: argv, argv-parser, cli, parse, parser, ruby, ruby-gem
- Language: Ruby
- Homepage:
- Size: 137 KB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# ParseArgv ![version](https://img.shields.io/gem/v/parse-argv?label=)
A command line parser that only needs your help text.
- Gem: [rubygems.org](https://rubygems.org/gems/parse-argv)
- Source: [github.com](https://github.com/mblumtritt/parse-argv)
- Help: [rubydoc.info](https://rubydoc.info/gems/parse-argv/ParseArgv)## Description
Just write the help text for your application and ParseArgv will take care of your command line. It works sort of the other way around than OptParse, where you write a lot of code to get a command line parser and generated help text. ParseArgv simply takes your help text and parses the command line and presents you the results.
You can use ParseArgv for simpler programs just as well as for CLI with multi-level sub-commands (git-like commands). ParseArgv is easy to use, fast and also helps you convert the data types of command line arguments.
## Example
The given help text
```
usage: test [options] []This is just a demonstration.
options:
-f, --format specify the format
--verbose enable verbose mode
-h, --help print this help text
```will be interpreted as
- there is a command "test"
- which requires and argument "infile"
- optionally accepts an second argument "outfile"
- accepts an option named "format" when `-f` or `--format` are given
- defines the boolean option "verbose" when `--verbose` is given
- defines the boolean option "help" when `-h` or `--help` are given## How To Use
Please, see the [Gem's help](https://rubydoc.info/gems/parse-argv/ParseArgv) for detailed information, or have a look at the [`./examples`](./examples) directory which contains some commands to play around.
The supported help text syntax and the command line interface syntax are described in the [syntax help](./syntax.md).
In general you just specify the help text and get the parsed command line:
```ruby
require 'parse-argv'args = ParseArgv.from <<~HELP
usage: test [options] []This is just a demonstration.
options:
-f, --format specify the format
--verbose enable verbose mode
-h, --help print this help text
HELPargs.verbose?
#=> true, when "--verbose" argument was specified
#=> false, when "--verbose" argument was not specifiedargs[:infile].as(File, :readable)
#=> file nameargs.outfile?
#=> true, when second argument was specified
args.outfile
#=> second argument or nil when not specified
```## Installation
Use [Bundler](http://gembundler.com/) to add ParseArgv in your own project:
Include in your `Gemfile`:
```ruby
gem 'parse-argv'
```and install it by running Bundler:
```bash
bundle
```To install the gem globally use:
```bash
gem install parse-argv
```After that you need only a single line of code in your project to have it on board:
```ruby
require 'parse-argv'
```