GNU Getopt For PHP

In my opinion, the command line interfaces for PHP are sadly lacking. To meet expectations for the user and the programmer it’s best to follow established standards. Whenever possible, a programmer should follow POSIX guidelines. Yet in many cases GNU extensions are preferred and expected. To meet these expectations, I’ve ported GNU Getopt to php.

This package is based on the 1998 Java port of Getopt by Aaron M. Renn. Whenever possible, I tried to remain true to the spirit of his original port. This was a relatively easy task due to the similarities between java and php5. Currently, the only thing it’s lacking is multiple language support. For that feature, I’m hope to get assistance from the international community.

The GNU Getopt package consists of two class files:

To install the package, copt the top-level gnu directory into your inclue path. To find the directories included in that path, run the following at the command line:

php -r "echo ini_get('include_path');"

In my case, the result was ‘.:/usr/share/pear:/usr/share/php’ To install the package, I copied ‘gnu’ into /usr/share/php.

The bundle contains a demo program named ‘optdemo’. Here’s the code from that program:

  $longopt = array();
  $longopt[0] = new LongOpt("help", NO_ARGUMENT, null, 'h');
  $longopt[1] = new LongOpt("about", REQUIRED_ARGUMENT, null, 'a');
  $getopt = new Getopt($argv, "a:bc:d:hW;", $longopt);
  while (($c = $getopt->getopts()) != -1) {
    switch($c) {
    case 'a':
    case 'd':
      $arg = $getopt->getOptarg();
        "You picked $c with an argument of ".(($arg != null) ?
        $arg : "null")."\n"
    case 'b':
    case 'c':
      $arg = $getopt->getOptarg();
        "You picked $c with an argument of ".(($arg != null)
        ? $arg : "null")."\n"
     case 'h':
       print "Usage: test [options] \n";
     case '?':
       break; // getopt() already printed an error
       print("getopt() returned $c\n");
As you can see, the implementation is pretty straight forward. The array of Longopt objects are optional. Each Longopt should contain a corresponding short opt in the Getopt class. Short opts are constructed exactly as you’d expect. Consider the option string “a:bc:d:hW;” Each option proceded by a colon expects an argument. In this case ‘a’, ‘c’ and ‘d’ all require an argument while ‘b’ and ‘h’ do not. The getopts method is an iterator. You can loop through the options and handle them in a loop similar to the one shown in the example.

The software is available here: GNU Getopt For PHP

Happy hacking


Here’s a Croation Translation of this page for our friends in the Balkans….

Posted in | Leave a comment

Leave a Reply

Recent Comments

  • Sebastiaan Giebels: This just opens the way for MITM attacks. Anyone between your client and the server you are...
  • Mike Smith: I’m non-plus’d regarding the “hacker group” called Anonymous. Unless the Anons...
  • Oleg: I see the same errors with: 1) 301 redirects, that doesn’t recorded at transactions hits, but seen at...
  • Jeff Fulmer: With regard to those 301s, if you do something like this: siege -g You’ll see...
  • Pito Salas: Hi there Jeff, I’ve been looking around for a tool just like yours, simple and powerful. In order...