首页 >后端开发 >php教程 >每天laravel-20160719|Parser

每天laravel-20160719|Parser

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB原创
2016-06-20 12:31:12897浏览

<?phpnamespace Illuminate\Console;use Illuminate\Support\Str;use InvalidArgumentException;use Symfony\Component\Console\Input\InputOption;use Symfony\Component\Console\Input\InputArgument;// my name spaceclass Parser{    /**     * Parse the given console command definition into an array.     *     * @param  string  $expression     * @return array     *     * @throws \InvalidArgumentException     */    public static function parse($expression)//Parse the given console command definition into array.    {        if (trim($expression) === '') {            throw new InvalidArgumentException('Console command definition is empty.');        }// trim the expression ,if have the null       // throw new        preg_match('/[^\s]+/', $expression, $matches);// get you  want value in the big date.        if (isset($matches[0])) {// is has the match value ,only get one            $name = $matches[0];// use the name to save the matches[0] value        } else {            throw new InvalidArgumentException('Unable to determine command name from signature.');        }// else throw new trouble.        preg_match_all('/\{\s*(.*?)\s*\}/', $expression, $matches);// get all the value that be match        $tokens = isset($matches[1]) ? $matches[1] : [];// $tokens check the matches        if (count($tokens)) {// count($tokens) count array(); this is the matches results            return array_merge([$name], static::parameters($tokens));// array_merge  parameters ,change the parameters        }        return [$name, [], []];// return the result    }// this is  a change the   // the $name to    /**     * Extract all of the parameters from the tokens.     *     * @param  array  $tokens     * @return array     */    protected static function parameters(array $tokens)//Extract all of the parameters from the tokens.    {        $arguments = [];// store the arguments        $options = [];// store the options        foreach ($tokens as $token) {// all the tokens as token            if (! Str::startsWith($token, '--')) {// !Str::starsWith() get the true of false                $arguments[] = static::parseArgument($token);//            } else {                $options[] = static::parseOption(ltrim($token, '-'));// get the options            }        }        return [$arguments, $options];// back the result from tokens    }// one is arguments,   // one is options    /**     * Parse an argument expression.     *     * @param  string  $token     * @return \Symfony\Component\Console\Input\InputArgument     */    protected static function parseArgument($token)//Parse an argument expression.    {        $description = null;// a store string        if (Str::contains($token, ' : ')) {// a function to get the token get the result true or false            list($token, $description) = explode(' : ', $token, 2);// extract the list array to the token and description            $token = trim($token);// trim the token            $description = trim($description);// trim the description        }        switch (true) {// true is value , and the value no break            case Str::endsWith($token, '?*'):// case 1 set the flag                return new InputArgument(trim($token, '?*'), InputArgument::IS_ARRAY, $description);            case Str::endsWith($token, '*'):// case 2 set the flag                return new InputArgument(trim($token, '*'), InputArgument::IS_ARRAY | InputArgument::REQUIRED, $description);            case Str::endsWith($token, '?'):// case 3 set the flag                return new InputArgument(trim($token, '?'), InputArgument::OPTIONAL, $description);            case preg_match('/(.+)\=(.+)/', $token, $matches):// case 4 more different matches                return new InputArgument($matches[1], InputArgument::OPTIONAL, $description, $matches[2]);            default:                return new InputArgument($token, InputArgument::REQUIRED, $description);        }// change the InputArgument value    }    /**     * Parse an option expression.     *     * @param  string  $token     * @return \Symfony\Component\Console\Input\InputOption     */    protected static function parseOption($token)//Parse an option expression    {        $description = null;// ParseOption        if (Str::contains($token, ' : ')) {// check the str            list($token, $description) = explode(' : ', $token);// list the each()            $token = trim($token);            $description = trim($description);        }// back the token description        $shortcut = null;// null shortcut        $matches = preg_split('/\s*\|\s*/', $token, 2);// split the str by preg.        if (isset($matches[1])) {            $shortcut = $matches[0];            $token = $matches[1];        }// get the value from the token        switch (true) {            case Str::endsWith($token, '='):// case 1                return new InputOption(trim($token, '='), $shortcut, InputOption::VALUE_OPTIONAL, $description);            case Str::endsWith($token, '=*'):// case 2                return new InputOption(trim($token, '=*'), $shortcut, InputOption::VALUE_OPTIONAL | InputOption::VALUE_IS_ARRAY, $description);            case preg_match('/(.+)\=(.+)/', $token, $matches):                return new InputOption($matches[1], $shortcut, InputOption::VALUE_OPTIONAL, $description, $matches[2]);            default:                return new InputOption($token, $shortcut, InputOption::VALUE_NONE, $description);        }// input Option    }// at last you will found is a safe way to get you  input argument or option from a token}


声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn