晋太元中,武陵人捕鱼为业。缘溪行,忘路之远近。忽逢桃花林,夹岸数百步,中无杂树,芳草鲜美,落英缤纷。渔人甚异之,复前行,欲穷其林。 林尽水源,便得一山,山有小口,仿佛若有光。便舍船,从口入。初极狭,才通人。复行数十步,豁然开朗。土地平旷,屋舍俨然,有良田、美池、桑竹之属。阡陌交通,鸡犬相闻。其中往来种作,男女衣着,悉如外人。黄发垂髫,并怡然自乐。 见渔人,乃大惊,问所从来。具答之。便要还家,设酒杀鸡作食。村中闻有此人,咸来问讯。自云先世避秦时乱,率妻子邑人来此绝境,不复出焉,遂与外人间隔。问今是何世,乃不知有汉,无论魏晋。此人一一为具言所闻,皆叹惋。余人各复延至其家,皆出酒食。停数日,辞去。此中人语云:“不足为外人道也。”(间隔 一作:隔绝) 既出,得其船,便扶向路,处处志之。及郡下,诣太守,说如此。太守即遣人随其往,寻向所志,遂迷,不复得路。 南阳刘子骥,高尚士也,闻之,欣然规往。未果,寻病终。后遂无问津者。
| DIR:/opt/cloudlinux/alt-php55/root/usr/share/pear/ezc/ConsoleTools/input/ |
| Current File : //opt/cloudlinux/alt-php55/root/usr/share/pear/ezc/ConsoleTools/input/arguments.php |
<?php
/**
* File containing the ezcConsoleArguments collection 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
*/
/**
* Collection class for ezcConsoleArgument objects. Used in {@link ezcConsoleInput}.
*
* @package ConsoleTools
* @version 1.6.1
*/
class ezcConsoleArguments implements ArrayAccess, Iterator, Countable
{
/**
* Ordered list of arguments.
*
* @var array(ezcConsoleArgument)
*/
protected $ordered = array();
/**
* Named list of arguments.
*
* @var array(string=>ezcConsoleArgument)
*/
protected $named = array();
/**
* Returns if the given offset exists.
* This method is part of the ArrayAccess interface to allow access to the
* data of this object as if it was an array. Valid offsets are integers or
* strings. If an integer is used, it refers to the position in the command
* line. A string refers to the arguments name property.
*
* @param mixed $offset The offset to check.
* @return bool True when the offset exists, otherwise false.
*
* @throws ezcBaseValueException
* If the provided offset is neither an integer, nor a string.
*/
public function offsetExists( $offset )
{
switch ( gettype( $offset ) )
{
case "string":
return array_key_exists( $offset, $this->named );
case "integer":
return array_key_exists( $offset, $this->ordered );
default:
throw new ezcBaseValueException( "offset", $offset, "string or int" );
}
}
/**
* Returns the element with the given offset.
* This method is part of the ArrayAccess interface to allow access to the
* data of this object as if it was an array. Valid offsets are integers or
* strings. If an integer is used, it refers to the position in the command
* line. A string refers to the arguments name property.
*
* @param string|integer $offset The offset to check.
* @return ezcConsoleArgument
*
* @throws ezcBaseValueException
* If the provided offset is neither an integer, nor a string.
*/
public function offsetGet( $offset )
{
switch ( gettype( $offset ) )
{
case "string":
if ( isset( $this[$offset] ) )
{
return $this->named[$offset];
}
break;
case "integer":
if ( isset( $this[$offset] ) )
{
return $this->ordered[$offset];
}
break;
default:
throw new ezcBaseValueException( "offset", $offset, "string or int" );
}
throw new ezcBasePropertyNotFoundException( $offset );
}
/**
* Set the element with the given offset.
* This method is part of the ArrayAccess interface to allow access to the
* data of this object as if it was an array. In contrast to the other
* ArrayAccess implementations of this class, this method allows only integer
* keys.
*
* @param int $offset The offset to assign an item to.
* @param ezcConsoleArgument $value The argument object to register.
* @return void
*
* @throws ezcBaseValueException
* If a non integer offset is provided.
* @throws ezcBaseValueException
* If the provided value is not of type {@ling ezcConsoleTableRow}.
* @throws ezcConsoleArgumentAlreadyRegisteredException
* If an argument with the given offset or name is already registered.
*/
public function offsetSet( $offset, $value )
{
// Determine key if not set (using $obj[] = ...)
if ( $offset === null )
{
$offset = count( $this->ordered ) === 0 ? 0 : max( array_keys( $this->ordered ) ) + 1;
}
// Set access only allowed with integer values
if ( !is_int( $offset ) )
{
throw new ezcBaseValueException( "offset", $offset, "int" );
}
switch ( true )
{
case ( $value instanceof ezcConsoleArgument ):
if ( isset( $this->ordered[$offset] ) )
{
throw new ezcConsoleArgumentAlreadyRegisteredException( $offset, ezcConsoleArgumentAlreadyRegisteredException::ORDERED );
}
if ( isset( $this->named[$value->name] ) )
{
throw new ezcConsoleArgumentAlreadyRegisteredException( $value->name, ezcConsoleArgumentAlreadyRegisteredException::NAMED );
}
$this->named[$value->name] = $value;
$this->ordered[$offset] = $value;
break;
case ( $value === null ):
// Aliasing unset() with assignement to null
unset( $this->named[$this->ordered[$offset]->name] );
unset( $this->ordered[$offset] );
break;
default:
throw new ezcBaseValueException( "value", $value, "ezcConsoleArgument or null" );
}
}
/**
* Unset the element with the given offset.
* This method is part of the ArrayAccess interface to allow access to the
* data of this object as if it was an array. In contrast to the other
* ArrayAccess implementations of this class, this method allows only integer
* keys.
*
* @param int $offset The offset to unset the value for.
* @return void
*
* @throws ezcBaseValueException
* If a non numeric row offset is used.
*/
public function offsetUnset( $offset )
{
// Set access only allowed with integer values
if ( is_int( $offset ) === false )
{
throw new ezcBaseValueException( "offset", $offset, "int" );
}
unset( $this->named[$this->ordered[$offset]->name] );
unset( $this->ordered[$offset] );
}
/**
* Returns the currently selected argument from the list.
* Used by foreach-Loops.
*
* @return ezcConsoleArgument
*/
public function current()
{
return current( $this->ordered );
}
/**
* Returns the key of the currently selected argument from the list.
* Used by foreach-Loops. In contrast to the iteration direction, which is
* defined by the ordered list of arguments, this is the name of the
* argument.
*
* @return string
*/
public function key()
{
return key( $this->ordered );
}
/**
* Advances the internal pointer to the next argument and returns it.
* Used by foreach-Loops.
*
* @return ezcConsoleArgument
*/
public function next()
{
return next( $this->ordered );
}
/**
* Rewinds the internal pointer to the first argument and returns it.
* Used by foreach-Loops.
*
* @return ezcConsoleArgument
*/
public function rewind()
{
// Called before foreach
ksort( $this->ordered );
return reset( $this->ordered );
}
/**
* Checks if the current position is valid.
* Used by foreach-Loops.
*
* @return bool
*/
public function valid()
{
return ( current( $this->ordered ) !== false );
}
/**
* Returns the number of registered arguments.
*
* @return int
*/
public function count()
{
return count( $this->ordered );
}
}
?>
|