libCLImate, for Ruby
libCLImate is a portable, lightweight mini-framework that encapsulates the common aspects of Command-Line Interface boilerplate, including:
- command-line argument parsing and sorting, into flags, options, and values;
- validating given and/or missing arguments;
- a declarative form of specifying the CLI elements for a program, including associating blocks with flag/option specifications;
- provision of de-facto standard CLI facilities, such as responding to '--help' and '--version';
libCLImate.Ruby is the Ruby version.
Install via gem as in:
gem install libclimate-ruby
or add it to your Gemfile
.
Use via require, as in:
require 'libclimate'
In common with several other variants of libCLImate, libCLImate.Ruby revolves around a Climate
class
whose initialiser takes a block and acts as a lightweight DSL for concise definition of a command-line parsing instance, as in:
options = {}
climate = LibCLImate::Climate.new do |cl|
cl.add_flag('--debug', alias: '-d', help: 'runs in Debug mode') do
options[:debug] = true
end
cl.add_option('--verbosity', alias: '-v', help: 'specifies the verbosity', values: [ 'terse', 'quiet', 'silent', 'chatty' ]) do |o, sp|
options[:verbosity] = o.value
end
cl.add_alias('--verbosity=chatty', '-c')
cl.version = [ 0, 1, 0 ]
cl.info_lines = [
'libCLImate.Ruby examples',
:version,
"Illustrates use of libCLImate.Ruby's specification of flags, options, and specifications",
'',
]
cl.constrain_values = 1..2
cl.usage_values = "<dir-1> [ <dir-2> ]"
cl.value_names = [
"first directory",
"second directory",
]
end
Examples are provided in the examples
directory, along with a markdown description for each. A detailed list TOC of them is provided in EXAMPLES.md.
It is instructive to see how much more succinct they are than those (offering precisely the same functionality) presented in CLASP.Ruby.
Defect reports, feature requests, and pull requests are welcome on https://github.com/synesissoftware/libCLImate.Ruby.
libCLImate.Ruby depends on:
- the CLASP.Ruby library; and
- the xqsr3 library.
libCLImate.Ruby is released under the 3-clause BSD license. See LICENSE for details.