Introducing ChatKeeper – For Serious ChatGPT Users
Organize, Search, and Keep Your Conversations Forever.
Designed for researchers, professionals, and anyone who needs a permanent, searchable, local conversation archive fully integrated with their work.
JSAP: the Java Simple Argument Parser
Last Updated August 4, 2006
Source News Changelog Manual Javadocs
Why do we need another command line parser?
Put simply, I got tired of writing simple command line parsers for every java utility program I wrote. I would usually just throw together something simple, requiring a certain number of arguments and deciding that args[0]
would always mean, say, an input file, and args[1]
would be an output file. It was fine for simpler utilities with just a few parameters, but it didn't handle switches - and if I wanted anything other than a String
from the command line, I had to write that parsing into the program, too. What annoyed me was that none of this had anything to do with the actual task for which the utility was intended.
I found several parsers on the Internet, all of which handled switches, but none of which had the versatility I wanted in terms of return types and configuration files. Hence JSAP - the Java Simple Argument Parser.
So what does JSAP actually do, then?
JSAP not only syntactically validates your program's command line arguments, but it converts those arguments into objects you specify. If you tell JSAP that one of your parameters is an Integer, for example, and the user does not provide a String that can be converted to an Integer when invoking the program, JSAP will throw a ParseException
when you have it parse the command line. If no exception is thrown, you are guaranteed an Integer
when you request that parameter's value from your program. There's a pretty big (and growing) list of return types suppored by JSAP, including Integer
s, Float
s, Date
s, URL
s, and even java.awt.Colors
; you can also add your own in a matter of minutes.
JSAP provides not only for default values for its parameters, but for an entire chain of defaults. With a couple extra lines of code, JSAP will, for example:
- Parse the command line.
- For any omitted parameters, look for values in
~/.yourProgramName.conf
- For any still omitted parameters, look for values in
/etc/yourProgramName.conf
- For any still omitted parameters, use the default values (if any) specified by the developer.