0.0
Low commit activity in last 3 years
A long-lived project that still receives updates
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.
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Runtime

~> 0.23, >= 0.23.0.2
~> 0.39
 Project Readme

libCLImate.Ruby

libCLImate, for Ruby

Gem Version

Table of Contents

  1. Introduction
  2. Installation
  3. Components
  4. Examples
  5. Project Information

Introduction

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.

Installation

Install via gem as in:

	gem install libclimate-ruby

or add it to your Gemfile.

Use via require, as in:

require 'libclimate'

Components

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

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.

Project Information

Where to get help

GitHub Page

Contribution guidelines

Defect reports, feature requests, and pull requests are welcome on https://github.com/synesissoftware/libCLImate.Ruby.

Dependencies

libCLImate.Ruby depends on:

Related projects

License

libCLImate.Ruby is released under the 3-clause BSD license. See LICENSE for details.