D7net
Home
Console
Upload
information
Create File
Create Folder
About
Tools
:
/
proc
/
thread-self
/
root
/
opt
/
alt
/
php54
/
usr
/
share
/
pear
/
ezc
/
ConsoleTools
/
options
/
Filename :
menu_dialog.php
back
Copy
<?php /** * File containing the ezcConsoleMenuDialogOptions class. * * @package ConsoleTools * @version 1.6.1 * @copyright Copyright (C) 2005-2010 eZ Systems AS. All rights reserved. * @license http://ez.no/licenses/new_bsd New BSD License * @filesource */ /** * Basic options class for ezcConsoleDialog implementations. * * @package ConsoleTools * @version 1.6.1 * * @property string $text * The text to display before the menu. * @property string $formatString * The format string for each menu element. * @property string $selectText * The test to display after the menu to indicate the user that he * should select an item. * @property ezcConsoleMenuDialogValidator $validator * The validator to use with this menu. * @property string $format * The output format for the dialog. */ class ezcConsoleMenuDialogOptions extends ezcConsoleDialogOptions { /** * Construct a new options object. * Options are constructed from an option array by default. The constructor * automatically passes the given options to the __set() method to set them * in the class. * * @throws ezcBasePropertyNotFoundException * If trying to access a non existent property. * @throws ezcBaseValueException * If the value for a property is out of range. * @param array(string=>mixed) $options The initial options to set. */ public function __construct( array $options = array() ) { $this->properties["text"] = "Please choose an item."; $this->properties["formatString"] = "%3s) %s\n"; $this->properties["selectText"] = "Select: "; $this->properties["validator"] = new ezcConsoleMenuDialogDefaultValidator(); parent::__construct( $options ); } /** * Property write access. * * @param string $propertyName Name of the property. * @param mixed $propertyValue The value for the property. * * @throws ezcBasePropertyPermissionException * If the property you try to access is read-only. * @throws ezcBasePropertyNotFoundException * If the the desired property is not found. * @ignore */ public function __set( $propertyName, $propertyValue ) { switch ( $propertyName ) { case "text": if ( is_string( $propertyValue ) === false || strlen( $propertyValue ) < 1 ) { throw new ezcBaseValueException( $propertyName, $propertyValue, "string, length > 0" ); } break; case "selectText": if ( is_string( $propertyValue ) === false ) { throw new ezcBaseValueException( $propertyName, $propertyValue, "string" ); } break; case "formatString": if ( is_string( $propertyValue ) === false ) { throw new ezcBaseValueException( $propertyName, $propertyValue, "string" ); } break; case "validator": if ( ( $propertyValue instanceof ezcConsoleMenuDialogValidator ) === false ) { throw new ezcBaseValueException( $propertyName, $propertyValue, "ezcConsoleMenuDialogValidator" ); } default: parent::__set( $propertyName, $propertyValue ); } $this->properties[$propertyName] = $propertyValue; } } ?>