Mercurial > hg > rc1
comparison vendor/pear/console_commandline/docs/examples/ex3.php @ 0:1e000243b222
vanilla 1.3.3 distro, I hope
author | Charlie Root |
---|---|
date | Thu, 04 Jan 2018 15:50:29 -0500 |
parents | |
children |
comparison
equal
deleted
inserted
replaced
-1:000000000000 | 0:1e000243b222 |
---|---|
1 <?php | |
2 | |
3 /* vim: set expandtab tabstop=4 shiftwidth=4 softtabstop=4: */ | |
4 | |
5 /** | |
6 * This file is part of the PEAR Console_CommandLine package. | |
7 * | |
8 * A simple example demonstrating the use of subcommands. | |
9 * | |
10 * PHP version 5 | |
11 * | |
12 * LICENSE: This source file is subject to the MIT license that is available | |
13 * through the world-wide-web at the following URI: | |
14 * http://opensource.org/licenses/mit-license.php | |
15 * | |
16 * @category Console | |
17 * @package Console_CommandLine | |
18 * @author David JEAN LOUIS <izimobil@gmail.com> | |
19 * @copyright 2007 David JEAN LOUIS | |
20 * @license http://opensource.org/licenses/mit-license.php MIT License | |
21 * @version CVS: $Id$ | |
22 * @link http://pear.php.net/package/Console_CommandLine | |
23 * @since File available since release 0.1.0 | |
24 */ | |
25 | |
26 // Include the Console_CommandLine package. | |
27 require_once 'Console/CommandLine.php'; | |
28 | |
29 // create the parser | |
30 $parser = new Console_CommandLine(array( | |
31 'description' => 'A great program that can foo and bar !', | |
32 'version' => '1.0.0' | |
33 )); | |
34 | |
35 // add a global option to make the program verbose | |
36 $parser->addOption('verbose', array( | |
37 'short_name' => '-v', | |
38 'long_name' => '--verbose', | |
39 'action' => 'StoreTrue', | |
40 'description' => 'turn on verbose output' | |
41 )); | |
42 | |
43 // add the foo subcommand | |
44 $foo_cmd = $parser->addCommand('foo', array( | |
45 'description' => 'output the given string with a foo prefix' | |
46 )); | |
47 $foo_cmd->addOption('reverse', array( | |
48 'short_name' => '-r', | |
49 'long_name' => '--reverse', | |
50 'action' => 'StoreTrue', | |
51 'description' => 'reverse the given string before echoing it' | |
52 )); | |
53 $foo_cmd->addArgument('text', array( | |
54 'description' => 'the text to output' | |
55 )); | |
56 | |
57 // add the bar subcommand with a "baz" alias | |
58 $bar_cmd = $parser->addCommand('bar', array( | |
59 'description' => 'output the given string with a bar prefix', | |
60 'aliases' => array('baz'), | |
61 )); | |
62 $bar_cmd->addOption('reverse', array( | |
63 'short_name' => '-r', | |
64 'long_name' => '--reverse', | |
65 'action' => 'StoreTrue', | |
66 'description' => 'reverse the given string before echoing it' | |
67 )); | |
68 $bar_cmd->addArgument('text', array( | |
69 'description' => 'the text to output' | |
70 )); | |
71 | |
72 // run the parser | |
73 try { | |
74 $result = $parser->parse(); | |
75 if ($result->command_name) { | |
76 $st = $result->command->options['reverse'] | |
77 ? strrev($result->command->args['text']) | |
78 : $result->command->args['text']; | |
79 if ($result->command_name == 'foo') { | |
80 echo "Foo says: $st\n"; | |
81 } else if ($result->command_name == 'bar') { | |
82 echo "Bar says: $st\n"; | |
83 } | |
84 } | |
85 } catch (Exception $exc) { | |
86 $parser->displayError($exc->getMessage()); | |
87 } | |
88 | |
89 ?> |