docs/02-usage.markdown @ 95aa057ce3a4

Everybody gets ONE
author Steve Losh <steve@stevelosh.com>
date Thu, 22 Nov 2018 00:14:20 -0500
parents 152830fa3f85
children 2adae5be4089
Usage
=====

Adopt is a simple library for parsing UNIX-style command line arguments in
Common Lisp.  It was made because none of the other libraries did what I needed.

[TOC]

Package
-------

All core Adopt functions are in the `adopt` package.  You can `:use` that if you
really want to, but it's probably clearer to use namespaced `adopt:…` symbols.

Example
-------

    (define-interface *my-program* "[options] FILES"
      (verbosity
        "Output extra information."
        :short #\v
        :long "verbose"
        :initial-value 0
        :reduce (constantly 1))
      (verbosity
        "Shut up."
        :short #\q
        :long "quiet"
        :reduce (constantly -1))
      (ignore
        "Ignore FILE.  May be specified multiple times."
        :long "ignore"
        :parameter "FILE"
        :reduce #'append1)
      (name
        "Your name.  May be specified many times, last one wins."
        :short #\n
        :long "name"
        :parameter "NAME"
        :reduce #'latest)
      (meows
        "Meow."
        :short #\m
        :long "meow"
        :initial-value 0
        :reduce #'1+))
    
    (pprint
      (multiple-value-list
        (parse-options *my-program*
                       '("-vqn" "steve"
                         "--meow"
                         "-m" "--meow" "foo"
                         "--name=sjl" "more"
                         "--" "--ignore" "bar"
                         ))))