| 2 | | # $Id$ |
| 3 | | # |
| 4 | | # Copyright (c) 2005 John Peterson |
| 5 | | # |
| 6 | | # Permission is hereby granted, free of charge, to any person obtaining |
| 7 | | # a copy of this software and associated documentation files (the |
| 8 | | # "Software"), to deal in the Software without restriction, including |
| 9 | | # without limitation the rights to use, copy, modify, merge, publish, |
| 10 | | # distribute, sublicense, and/or sell copies of the Software, and to |
| 11 | | # permit persons to whom the Software is furnished to do so, subject to |
| 12 | | # the following conditions: |
| 13 | | # |
| 14 | | # The above copyright notice and this permission notice shall be |
| 15 | | # included in all copies or substantial portions of the Software. |
| 16 | | # |
| 17 | | # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, |
| 18 | | # EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF |
| 19 | | # MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND |
| 20 | | # NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE |
| 21 | | # LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION |
| 22 | | # OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION |
| 23 | | # WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. |
| 24 | | |
| 25 | | |
| | 2 | /** |
| | 3 | * File containing the TraxGenerator class |
| | 4 | * |
| | 5 | * (PHP 5) |
| | 6 | * |
| | 7 | * @package PHPonTrax |
| | 8 | * @version $Id$ |
| | 9 | * @copyright (c) 2005 John Peterson |
| | 10 | * |
| | 11 | * Permission is hereby granted, free of charge, to any person obtaining |
| | 12 | * a copy of this software and associated documentation files (the |
| | 13 | * "Software"), to deal in the Software without restriction, including |
| | 14 | * without limitation the rights to use, copy, modify, merge, publish, |
| | 15 | * distribute, sublicense, and/or sell copies of the Software, and to |
| | 16 | * permit persons to whom the Software is furnished to do so, subject to |
| | 17 | * the following conditions: |
| | 18 | * |
| | 19 | * The above copyright notice and this permission notice shall be |
| | 20 | * included in all copies or substantial portions of the Software. |
| | 21 | * |
| | 22 | * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, |
| | 23 | * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF |
| | 24 | * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND |
| | 25 | * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE |
| | 26 | * LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION |
| | 27 | * OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION |
| | 28 | * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. |
| | 29 | */ |
| | 30 | |
| | 31 | /** |
| | 32 | * Implement the commands of {@link generate.php script/generate.php} |
| | 33 | * |
| | 34 | * <p>Legal commands:</p> |
| | 35 | * <ul> |
| | 36 | * <li>{@link generate_controller() controller}</li> |
| | 37 | * <li>{@link generate_model() model}</li> |
| | 38 | * <li>{@link generate_scaffold() scaffold}</li> |
| | 39 | * </ul> |
| | 40 | * |
| | 41 | * @package PHPonTrax |
| | 42 | */ |
| | 137 | /** |
| | 138 | * Implement "generate controller" command |
| | 139 | * |
| | 140 | * <p>Example:<br><samp>php script/generate.php controller</samp> |
| | 141 | * <i>SomeName</i><br> |
| | 142 | * will generate:</p> |
| | 143 | * <ul> |
| | 144 | * <li>a file |
| | 145 | * <samp>app/controllers/</samp><i>some_name</i><samp>_controller.php</samp><br> |
| | 146 | * containing the class definition<br> |
| | 147 | * <samp>class</samp> <i>SomeName</i><samp>Controller extends |
| | 148 | * ApplicationController {}</samp></li> |
| | 149 | * <li>a file |
| | 150 | * <samp>app/helpers/</samp><i>some_name</i><samp>_helper.php</samp></li> |
| | 151 | * <li>a directory |
| | 152 | * <samp>app/views/</samp><i>some_name</i></li> |
| | 153 | * </ul> |
| | 154 | * |
| | 155 | * <p>Optionally, one or more views can be appended to the command:<br> |
| | 156 | * <samp>php script/generate.php controller</samp> |
| | 157 | * <i>SomeName view1 view2</i><br> |
| | 158 | * which will additionally generate files:<br> |
| | 159 | * <samp>app/views/</samp><i>some_name/view1</i><samp>.phtml</samp><br> |
| | 160 | * <samp>app/views/</samp><i>some_name/view2</i><samp>.phtml</samp></p> |
| | 161 | * |
| | 162 | * @param string $name Name of the controller to generate in camel case |
| | 163 | * @param string $views Optional list of views to generate |
| | 164 | * @param boolean $scaffolding |
| | 165 | */ |