!C99Shell v. 2.5 [PHP 8 Update] [24.05.2025]!

Software: Apache. PHP/8.1.30 

uname -a: Linux server1.tuhinhossain.com 5.15.0-151-generic #161-Ubuntu SMP Tue Jul 22 14:25:40 UTC
2025 x86_64
 

uid=1002(picotech) gid=1003(picotech) groups=1003(picotech),0(root)  

Safe-mode: OFF (not secure)

/home/picotech/domains/smm.picotech.app/public_html/vendor/psy/psysh/src/Command/   drwxr-xr-x
Free 28.62 GB of 117.98 GB (24.26%)
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Self remove    Logout    


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

/*
 * This file is part of Psy Shell.
 *
 * (c) 2012-2023 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\Context;
use 
Psy\ContextAware;
use 
Psy\Input\CodeArgument;
use 
Psy\ParserFactory;
use 
Psy\VarDumper\Presenter;
use 
Psy\VarDumper\PresenterAware;
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 ContextAwarePresenterAware
{
    
/**
     * Context instance (for ContextAware interface).
     *
     * @var Context
     */
    
protected $context;

    private 
$presenter;
    private 
$parserFactory;
    private 
$parsers;

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

        
parent::__construct($name);
    }

    
/**
     * ContextAware interface.
     *
     * @param Context $context
     */
    
public function setContext(Context $context)
    {
        
$this->context $context;
    }

    
/**
     * PresenterAware interface.
     *
     * @param Presenter $presenter
     */
    
public function setPresenter(Presenter $presenter)
    {
        
$this->presenter = clone $presenter;
        
$this->presenter->addCasters([
            
Node::class => function (Node $node, array $a) {
                
$a = [
                    
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()
    {
        
$kindMsg 'One of PhpParser\\ParserFactory constants: '
            
.\implode(', 'ParserFactory::getPossibleKinds())
            .
" (default is based on current interpreter's version).";

        
$this
            
->setName('parse')
            ->
setDefinition([
            new 
CodeArgument('code'CodeArgument::REQUIRED'PHP code to parse.'),
            new 
InputOption('depth'''InputOption::VALUE_REQUIRED'Depth to parse.'10),
            new 
InputOption('kind'''InputOption::VALUE_REQUIRED$kindMsg$this->parserFactory->getDefaultKind()),
        ])
            ->
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');
        
$parserKind $input->getOption('kind');
        
$depth $input->getOption('depth');

        
$nodes $this->getParser($parserKind)->parse($code);
        
$output->page($this->presenter->present($nodes$depth));

        
$this->context->setReturnValue($nodes);

        return 
0;
    }

    
/**
     * Get (or create) the Parser instance.
     *
     * @param string|null $kind One of Psy\ParserFactory constants (only for PHP parser 2.0 and above)
     */
    
private function getParser(string $kind null): CodeArgumentParser
    
{
        if (!
\array_key_exists($kind$this->parsers)) {
            
$this->parsers[$kind] = new CodeArgumentParser($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.5 [PHP 8 Update] [24.05.2025] | Generation time: 0.0043 ]--