clop-crystal

CLI generator for Crystal

clop-crystal

A CLI generator for Crystal

Installation

You need to place clop.cr in your Crystal's require search path.

If you know how to use shard, add this to your application's shard.yml:

dependencies:
  clop:
    github: jmakino/clop-crystal

Getting started

Download clopsample.cr and

crystal clopsample.cr  -- -h

should show the auto-generated help message for clopsample.cr.

If you use shards, I guess you can write

require "clop"

instead of

require "./clop.cr"

To use clop.cr, first define some string variable which contains the description in YAML-like (slightly enhanced) format. If the name of the variable is "optionstr", add the following two lines:

clop_init(__LINE__, __FILE__, __DIR__, "optionstr")
options=CLOP.new(optionstr,ARGV)

after optionstr is defined. the CLOP class is automatically generated and initialized to contain the option parameters described in the text.

crystal clopsample.cr  -- -n 10

should show

options # => #<CLOP:0x7facd305f680
 @eps=0.0,
 @iv=[3, -1, 5, 6, 7],
 @n_particles=10,
 @output_file_name="",
 @vcom=[3.0, 4.0, 5.0],
 @xdiag=false>
a.class # => Float64
a # => 0.0

We can see that eps, n_particles, and other member variables have types specified in the option description text and have values either default or given in command line parameters. Since they have proper types, type inference works for assignments like the following,

a= options.eps

and a has the type Float64 (determined at the compile time).

Structure of the option description text

A minimal example would be:

  Description: Command line option parser sample code
  Long description:
    Test program for the class Clop (Command line option parser),
    (c) 2020, Jun Makino
     By running the file (typing "crystal clopsample.cr"), you can check whether
    it still behaves correctly.  Maximum help is provided with --help
    ("crystal clopsample.cr -- --help").
 

  Short name: -s
  Long name:		--softening_length
  Value type:		float
  Default value: 	0.0
  Variable name: 	eps             
  Description:		Softening length
      Plummer softening, where rs2=r**2+eps**2 is used in place of r**2.
  Long description:                        
      This option sets the softening length used to calculate the force
      between two particles.  The calculation scheme conforms to standard

The text should contain Description and Long description tags as the first two entries in usual YAML format. After that, blocks with Short name, Long name ... can appear multiple times.

Short name: short option. actually can be of whatever length.

Long name: long option. actually can be of whatever length.

Value type: At present, int, float, float vector (actually float array), int, int vector, bool, and string are supported and recognized

Default value: the default value. If "none" is given as the default value, this option becomes a required one.

Variable name: the name of instance variable within class CLOP.

Limitation

  • Short option with value without whitespace (such as -n10) is not supported.
  • No way to use same option multiple times (such as -s 1 -s 2 ...). You can use string as -s 1,2 and then decode it.
  • Indentation of the description text should be two. Also, each entry such as "Short name:" should contain two leading white spaces.

To do

  • give some human-readable error message for problems of option definition text
Repository

clop-crystal

Owner
Statistic
  • 0
  • 0
  • 0
  • 3
  • 0
  • over 2 years ago
  • March 14, 2020
License

MIT License

Links
Synced at

Wed, 22 Jan 2025 21:53:27 GMT

Languages