!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/public_html/phpmyadmin/vendor/symfony/dependency-injection/Compiler/   drwxr-xr-x
Free 28.14 GB of 117.98 GB (23.85%)
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Self remove    Logout    


Viewing file:     InlineServiceDefinitionsPass.php (7.46 KB)      -rwxr-x---
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
<?php

/*
 * This file is part of the Symfony package.
 *
 * (c) Fabien Potencier <fabien@symfony.com>
 *
 * For the full copyright and license information, please view the LICENSE
 * file that was distributed with this source code.
 */

namespace Symfony\Component\DependencyInjection\Compiler;

use 
Symfony\Component\DependencyInjection\Argument\ArgumentInterface;
use 
Symfony\Component\DependencyInjection\ContainerBuilder;
use 
Symfony\Component\DependencyInjection\Definition;
use 
Symfony\Component\DependencyInjection\Exception\ServiceCircularReferenceException;
use 
Symfony\Component\DependencyInjection\Reference;

/**
 * Inline service definitions where this is possible.
 *
 * @author Johannes M. Schmitt <schmittjoh@gmail.com>
 */
class InlineServiceDefinitionsPass extends AbstractRecursivePass
{
    private 
$analyzingPass;
    private 
$cloningIds = [];
    private 
$connectedIds = [];
    private 
$notInlinedIds = [];
    private 
$inlinedIds = [];
    private 
$notInlinableIds = [];
    private 
$graph;

    public function 
__construct(AnalyzeServiceReferencesPass $analyzingPass null)
    {
        
$this->analyzingPass $analyzingPass;
    }

    public function 
process(ContainerBuilder $container)
    {
        
$this->container $container;
        if (
$this->analyzingPass) {
            
$analyzedContainer = new ContainerBuilder();
            
$analyzedContainer->setAliases($container->getAliases());
            
$analyzedContainer->setDefinitions($container->getDefinitions());
            foreach (
$container->getExpressionLanguageProviders() as $provider) {
                
$analyzedContainer->addExpressionLanguageProvider($provider);
            }
        } else {
            
$analyzedContainer $container;
        }
        try {
            
$remainingInlinedIds = [];
            
$this->connectedIds $this->notInlinedIds $container->getDefinitions();
            do {
                if (
$this->analyzingPass) {
                    
$analyzedContainer->setDefinitions(array_intersect_key($analyzedContainer->getDefinitions(), $this->connectedIds));
                    
$this->analyzingPass->process($analyzedContainer);
                }
                
$this->graph $analyzedContainer->getCompiler()->getServiceReferenceGraph();
                
$notInlinedIds $this->notInlinedIds;
                
$this->connectedIds $this->notInlinedIds $this->inlinedIds = [];

                foreach (
$analyzedContainer->getDefinitions() as $id => $definition) {
                    if (!
$this->graph->hasNode($id)) {
                        continue;
                    }
                    foreach (
$this->graph->getNode($id)->getOutEdges() as $edge) {
                        if (isset(
$notInlinedIds[$edge->getSourceNode()->getId()])) {
                            
$this->currentId $id;
                            
$this->processValue($definitiontrue);
                            break;
                        }
                    }
                }

                foreach (
$this->inlinedIds as $id => $isPublicOrNotShared) {
                    if (
$isPublicOrNotShared) {
                        
$remainingInlinedIds[$id] = $id;
                    } else {
                        
$container->removeDefinition($id);
                        
$analyzedContainer->removeDefinition($id);
                    }
                }
            } while (
$this->inlinedIds && $this->analyzingPass);

            foreach (
$remainingInlinedIds as $id) {
                if (isset(
$this->notInlinableIds[$id])) {
                    continue;
                }

                
$definition $container->getDefinition($id);

                if (!
$definition->isShared() && !$definition->isPublic()) {
                    
$container->removeDefinition($id);
                }
            }
        } finally {
            
$this->container null;
            
$this->connectedIds $this->notInlinedIds $this->inlinedIds = [];
            
$this->notInlinableIds = [];
            
$this->graph null;
        }
    }

    
/**
     * {@inheritdoc}
     */
    
protected function processValue($valuebool $isRoot false)
    {
        if (
$value instanceof ArgumentInterface) {
            
// References found in ArgumentInterface::getValues() are not inlineable
            
return $value;
        }

        if (
$value instanceof Definition && $this->cloningIds) {
            if (
$value->isShared()) {
                return 
$value;
            }
            
$value = clone $value;
        }

        if (!
$value instanceof Reference) {
            return 
parent::processValue($value$isRoot);
        } elseif (!
$this->container->hasDefinition($id = (string) $value)) {
            return 
$value;
        }

        
$definition $this->container->getDefinition($id);

        if (!
$this->isInlineableDefinition($id$definition)) {
            
$this->notInlinableIds[$id] = true;

            return 
$value;
        }

        
$this->container->log($thissprintf('Inlined service "%s" to "%s".'$id$this->currentId));
        
$this->inlinedIds[$id] = $definition->isPublic() || !$definition->isShared();
        
$this->notInlinedIds[$this->currentId] = true;

        if (
$definition->isShared()) {
            return 
$definition;
        }

        if (isset(
$this->cloningIds[$id])) {
            
$ids array_keys($this->cloningIds);
            
$ids[] = $id;

            throw new 
ServiceCircularReferenceException($id\array_slice($idsarray_search($id$ids)));
        }

        
$this->cloningIds[$id] = true;
        try {
            return 
$this->processValue($definition);
        } finally {
            unset(
$this->cloningIds[$id]);
        }
    }

    
/**
     * Checks if the definition is inlineable.
     */
    
private function isInlineableDefinition(string $idDefinition $definition): bool
    
{
        if (
$definition->hasErrors() || $definition->isDeprecated() || $definition->isLazy() || $definition->isSynthetic() || $definition->hasTag('container.do_not_inline')) {
            return 
false;
        }

        if (!
$definition->isShared()) {
            if (!
$this->graph->hasNode($id)) {
                return 
true;
            }

            foreach (
$this->graph->getNode($id)->getInEdges() as $edge) {
                
$srcId $edge->getSourceNode()->getId();
                
$this->connectedIds[$srcId] = true;
                if (
$edge->isWeak() || $edge->isLazy()) {
                    return !
$this->connectedIds[$id] = true;
                }
            }

            return 
true;
        }

        if (
$definition->isPublic()) {
            return 
false;
        }

        if (!
$this->graph->hasNode($id)) {
            return 
true;
        }

        if (
$this->currentId == $id) {
            return 
false;
        }
        
$this->connectedIds[$id] = true;

        
$srcIds = [];
        
$srcCount 0;
        foreach (
$this->graph->getNode($id)->getInEdges() as $edge) {
            
$srcId $edge->getSourceNode()->getId();
            
$this->connectedIds[$srcId] = true;
            if (
$edge->isWeak() || $edge->isLazy()) {
                return 
false;
            }
            
$srcIds[$srcId] = true;
            ++
$srcCount;
        }

        if (
!== \count($srcIds)) {
            
$this->notInlinedIds[$id] = true;

            return 
false;
        }

        if (
$srcCount && \is_array($factory $definition->getFactory()) && ($factory[0] instanceof Reference || $factory[0] instanceof Definition)) {
            return 
false;
        }

        return 
$this->container->getDefinition($srcId)->isShared();
    }
}

:: 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.0037 ]--