晋太元中,武陵人捕鱼为业。缘溪行,忘路之远近。忽逢桃花林,夹岸数百步,中无杂树,芳草鲜美,落英缤纷。渔人甚异之,复前行,欲穷其林。 林尽水源,便得一山,山有小口,仿佛若有光。便舍船,从口入。初极狭,才通人。复行数十步,豁然开朗。土地平旷,屋舍俨然,有良田、美池、桑竹之属。阡陌交通,鸡犬相闻。其中往来种作,男女衣着,悉如外人。黄发垂髫,并怡然自乐。 见渔人,乃大惊,问所从来。具答之。便要还家,设酒杀鸡作食。村中闻有此人,咸来问讯。自云先世避秦时乱,率妻子邑人来此绝境,不复出焉,遂与外人间隔。问今是何世,乃不知有汉,无论魏晋。此人一一为具言所闻,皆叹惋。余人各复延至其家,皆出酒食。停数日,辞去。此中人语云:“不足为外人道也。”(间隔 一作:隔绝) 既出,得其船,便扶向路,处处志之。及郡下,诣太守,说如此。太守即遣人随其往,寻向所志,遂迷,不复得路。 南阳刘子骥,高尚士也,闻之,欣然规往。未果,寻病终。后遂无问津者。
| DIR:/opt/cloudlinux/alt-php54/root/usr/share/pear/ezc/ConsoleTools/ |
| Current File : //opt/cloudlinux/alt-php54/root/usr/share/pear/ezc/ConsoleTools/statusbar.php |
<?php
/**
* File containing the ezcConsoleStatusbar 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
*/
/**
* Creating and maintaining status-bars to be printed to the console.
*
* <code>
* // Construction
* $status = new ezcConsoleStatusbar( new ezcConsoleOutput() );
*
* // Set option
* $status->options['successChar'] = '*';
*
* // Run statusbar
* foreach ( $files as $file )
* {
* $res = $file->upload();
* // Add status if form of bool true/false to statusbar.
* $status->add( $res ); // $res is true or false
* }
*
* // Retreive and display final statusbar results
* $msg = $status->getSuccess() . ' succeeded, ' . $status->getFailure() . ' failed.';
* $out->outputText( "Finished uploading files: $msg\n" );
* </code>
*
* @property ezcConsoleStatusbarOptions $options
* Contains the options for this class.
*
* @package ConsoleTools
* @version 1.6.1
* @mainclass
*/
class ezcConsoleStatusbar
{
/**
* Container to hold the properties
*
* @var array(string=>mixed)
*/
protected $properties;
/**
* The ezcConsoleOutput object to use.
*
* @var ezcConsoleOutput
*/
protected $outputHandler;
/**
* Counter for success and failure outputs.
*
* @var array(bool=>int)
*/
protected $counter = array(
true => 0,
false => 0,
);
/**
* Creates a new status bar.
*
* @param ezcConsoleOutput $outHandler Handler to utilize for output
* @param array(string=>string) $options Options
*
* @see ezcConsoleStatusbar::$options
*/
public function __construct( ezcConsoleOutput $outHandler, array $options = array() )
{
$this->outputHandler = $outHandler;
$this->properties['options'] = new ezcConsoleStatusbarOptions( $options );
}
/**
* Property read access.
*
* @param string $key Name of the property.
* @return mixed Value of the property or null.
*
* @throws ezcBasePropertyNotFoundException
* If the the desired property is not found.
* @ignore
*/
public function __get( $key )
{
switch ( $key )
{
case 'options':
return $this->properties['options'];
break;
}
if ( isset( $this->properties['options']->$key ) )
{
return $this->properties['options']->$key;
}
throw new ezcBasePropertyNotFoundException( $key );
}
/**
* Set new options.
* This method allows you to change the options of a statusbar.
*
* @param array(string=>string)|ezcConsoleOutputOptions $options The options to set.
*
* @throws ezcBaseSettingNotFoundException
* If you tried to set a non-existent option value.
* @throws ezcBaseSettingValueException
* If the value is not valid for the desired option.
* @throws ezcBaseValueException
* If you submit neither an array nor an instance of
* ezcConsoleOutputOptions.
*/
public function setOptions( $options )
{
if ( is_array( $options ) )
{
$this->properties['options']->merge( $options );
}
else if ( $options instanceof ezcConsoleStatusbarOptions )
{
$this->properties['options'] = $options;
}
else
{
throw new ezcBaseValueException( "options", $options, "instance of ezcConsoleStatusbarOptions" );
}
}
/**
* Property write access.
*
* @param string $key Name of the property.
* @param mixed $val The value for the property.
*
* @throws ezcBasePropertyNotFoundException
* If a desired property could not be found.
* @throws ezcBaseValueException
* If a desired property value is out of range.
* @ignore
*/
public function __set( $key, $val )
{
switch ( $key )
{
// Those two are here for BC reasons only, it is proper to
// use $statusbar->options->successChar instead of just
// $statusbar->successChar.
case 'successChar':
case 'failureChar':
// No checks necessary here, already performed in
// ezcConsoleStatusbarOptions
break;
case "options":
if ( ( $val instanceof ezcConsoleStatusbarOptions ) === false )
{
throw new ezcBaseValueException( $key, $val, 'ezcConsoleStatusbarOptions' );
}
$this->properties[$key] = $val;
return;
default:
throw new ezcBasePropertyNotFoundException( $key );
}
$this->properties['options'][$key] = $val;
}
/**
* Property isset access.
*
* @param string $key Name of the property.
* @return bool True is the property is set, otherwise false.
* @ignore
*/
public function __isset( $key )
{
return isset( $this->properties['options'][$key] ) || isset( $this->properties[$key] );
}
/**
* Returns the current options.
* Returns the options currently set for this progressbar.
*
* @return ezcConsoleStatusbarOptions The current options.
*/
public function getOptions()
{
return $this->properties['options'];
}
/**
* Add a status to the status bar.
* Adds a new status to the bar which is printed immediately. If the
* cursor is currently not at the beginning of a line, it will move to
* the next line.
*
* @param bool $status Print successChar on true, failureChar on false.
* @return void
*/
public function add( $status )
{
if ( is_bool( $status ) === false )
{
trigger_error( 'Unknown status '.var_export( $status, true ).'.', E_USER_WARNING );
$status = (bool) $status;
}
switch ( $status )
{
case true:
$this->outputHandler->outputText( $this->properties['options']['successChar'], 'success' );
break;
case false:
$this->outputHandler->outputText( $this->properties['options']['failureChar'], 'failure' );
break;
}
$this->counter[$status]++;
}
/**
* Reset the state of the status-bar object to its initial one.
*
* @return void
*/
public function reset()
{
foreach ( $this->counter as $status => $count )
{
$this->counter[$status] = 0;
}
}
/**
* Returns number of successes during the run.
* Returns the number of success characters printed from this status bar.
*
* @return int Number of successes.
*/
public function getSuccessCount()
{
return $this->counter[true];
}
/**
* Returns number of failures during the run.
* Returns the number of failure characters printed from this status bar.
*
* @return int Number of failures.
*/
public function getFailureCount()
{
return $this->counter[false];
}
}
?>
|