GitXplorerGitXplorer
m

pirate

public
7 stars
1 forks
0 issues

Commits

List of commits on branch master.
Unverified
6fd81c2ecce00375f2615f3f549ed99c7494ad33

updated for the future

mmosesn committed 10 years ago
Unverified
906c1442006fe21d767131e66b1d19c2b58b5b94

Merge pull request #1 from zmallen/master

mmosesn committed 11 years ago
Unverified
187b40b23753d3eb3eb233ee336d5a40671b47dd

Changed version to 0.1.1 to reflect changes in the sonatype resolver db

committed 11 years ago
Unverified
1617ef3c36f39dbe4cb8be65d5439a0340d5bc0c

includes information on how to use it with java.

mmosesn committed 12 years ago
Unverified
070f177c6ac6071622048abcbe36800217f7dc38

readme screwed up

mmosesn committed 12 years ago
Unverified
95ea5db087a280f456ead13f4a5e7994f31056bf

correct repository this time

mmosesn committed 12 years ago

README

The README file for this repository.

#pirate pirate parses arrrrguments.

##Idea The idea behind pirate is that option parsing for command line tools should
be easier. The best mechanism that I've seen so far for command line tool
option parsing has been a builder python pattern (I forget what it's called)
and it seemed like a pain in the ass even with it as simple as it was. What
I wanted was to be able to just give a program the help text and for it to
figure out how to parse the arguments. The format should be:

import com.mosesn.pirate.Pirate

val helpText = "[ -fad ]"
val arguments = " -a".split(" ")
Pirate(helpText)(arguments)

##Examples ###wc

import com.mosesn.pirate.Pirate

val helpText = "[ -clmw ] [file]"
val arguments = " -l /usr/share/dict/words".split(" ")
Pirate(helpText)(arguments)

###uniq

import com.mosesn.pirate.Pirate

val helpText = "[-cdu] [-i] [-f int] [-s int] [input_file [output_file]]"
val arguments = "-c -i -f 3 sorted_file".split(" ")
Pirate(helpText)(arguments)

###ls

import com.mosesn.pirate.Pirate

val helpText = "[-ABCFGHLOPRSTUWabcdefghiklmnopqrstuwx] [file]"
val arguments = " -a -l ".split(" ")
Pirate(helpText)(arguments)

###Java You can also use Pirate in java. However, the curried functions are turned into methods with
two arguments, and the values on the Arguments object are turned into methods.

import com.mosesn.pirate.Pirate;
import com.mosesn.pirate.Arguments;

public class Main {
    public static void main(String[] args) {
        Arguments arg = Pirate.apply("[ -f ]", args);
        System.out.println(arg.flags().size());
    }
}

Install

So you want to install pirate, eh? Put this in your build.sbt file:

resolvers += "sonatype" at "https://oss.sonatype.org/content/repositories/releases/"

libraryDependencies ++= Seq("com.mosesn" %% "pirate" % "0.1.1")

##Help Text Help text comes in several different flavors. There are flags, values, and strings.

###Flags A flag looks like this: "-f". Flags can be put together, like "-fad". These flags
mean that you expect a boolean value, whether the argument "-f" or any one or more
of the arguments in "-fad" are passed to you.

###Values A value looks like this: "-v type" where type is the datatype you expect to have passed in.
An example might be, "-n int" or "-D double". The different types that are supported are
int, double, and string.

###Strings There are also named strings, which is especially useful for filenames. A string can be
named anything except for the reserved keywords int, string, and double, and may look like
"input".

###Options You may not want to pass in flags all of the time, so there is the option to not pass in flags.
This is denoted with square brackets. These can wrap anything, and always mean that passing them
in is optional.

##Arguments Should be an array of Strings of flags, no square brackets, started by a hyphen.
Example: " -faddd " (whitespace is fine, except in the flags).

###Flags At least one flag must be passed in for a group of flags to be considered covered. Multiple
flags can be passed in either by repeating them, or by passing multiple flags back together.
An example of that would be for " -acdf ", you can turn on both a and d by passing back either

  • "-a -d"
  • "-ad" which are both considered valid.

###Optional Arguments However, if you have one thing inside of the square brackets, you are
expected to match everything. For example, if you have "[ -ab -cd ]", valid strings to
pass in would be "-a -c", "-ab -d", "-dc -ba", "-d -d -b -a" and "". However, "-ab"
would NOT be valid, because you don't include any of the flags from "-cd".

###Order Flags can be passed in any order, and multiple times. All times will be considered valid. Values
can only be passed in once, but they are also in any order. However, they can only be passed
in any order within their "context". For example, in "[ -a [ -c -d ]]", valid arguments are all
strings where:

  • The empty string is passed in.
  • Only the -a argument is passed in.
  • Both the -a and the -c and -d arguments are passed in, where -c and -d are always next to each other.
    An example of the simplest invalid string with all of the right flags, just in the wrong order, is
    "-c -a -d".

##TODO I have been following the suggestions on how to handle arguments from The Art of Unix Programming.

The UNIX style of parsing arguments is basically completely implemented, with only small adjustments
that might be desirable, such as adding the option of specifying which values are mutually exclusive,
although since there isn't a preexisting way of showing that in help text, it isn't a high priority.

However, GNU style arguments haven't been implemented at all. If there is interest, I don't think they
will be very hard to do, but I personally prefer UNIX style, so if no one else is using this, I won't
bother. If you would like the functionality, feel free to file a github issue on me or email me about it.

##Contributors Moses Nakamura