<?php
/**
* Class with static methods for loading classes and files
*
* PHP version 5
*
* LICENSE:
*
* Copyright (c) 2006-2014, Alexey Borzov <avb@php.net>,
* Bertrand Mansion <golgote@mamasam.com>
* 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.
* * The names of the authors may not 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.
*
* @category HTML
* @package HTML_QuickForm2
* @author Alexey Borzov <avb@php.net>
* @author Bertrand Mansion <golgote@mamasam.com>
* @license http://opensource.org/licenses/bsd-license.php New BSD License
* @link http://pear.php.net/package/HTML_QuickForm2
*/
/**
* Exception classes for HTML_QuickForm2
*/
require_once 'HTML/QuickForm2/Exception.php';
/**
* Class with static methods for loading classes and files
*
* @category HTML
* @package HTML_QuickForm2
* @author Alexey Borzov <avb@php.net>
* @author Bertrand Mansion <golgote@mamasam.com>
* @license http://opensource.org/licenses/bsd-license.php New BSD License
* @version Release: 2.0.2
* @link http://pear.php.net/package/HTML_QuickForm2
*/
class HTML_QuickForm2_Loader
{
/**
* Tries to load a given class
*
* If no $includeFile was provided, $className will be used with underscores
* replaced with path separators and '.php' extension appended
*
* @param string $className Class name to load
* @param string $includeFile Name of the file (supposedly) containing the given class
*
* @throws HTML_QuickForm2_NotFoundException If the file either can't be
* loaded or doesn't contain the given class
*/
public static function loadClass($className, $includeFile = null)
{
if (class_exists($className, false) || interface_exists($className, false)) {
return;
}
if (empty($includeFile)) {
$includeFile = str_replace('_', DIRECTORY_SEPARATOR, $className) . '.php';
}
// Do not silence the errors with @, parse errors will not be seen
include $includeFile;
// Still no class?
if (!class_exists($className, false) && !interface_exists($className, false)) {
if (!self::fileExists($includeFile)) {
throw new HTML_QuickForm2_NotFoundException(
"File '$includeFile' was not found"
);
} else {
throw new HTML_QuickForm2_NotFoundException(
"Class '$className' was not found within file '$includeFile'"
);
}
}
}
/**
* Checks whether the file exists in the include path
*
* @param string $fileName file name
*
* @return bool
*/
public static function fileExists($fileName)
{
$fp = @fopen($fileName, 'r', true);
if (is_resource($fp)) {
fclose($fp);
return true;
}
return false;
}
/**
* Loading of HTML_QuickForm2_* classes suitable for SPL autoload mechanism
*
* This method will only try to load a class if its name starts with
* HTML_QuickForm2. Register with the following:
* <code>
* spl_autoload_register(array('HTML_QuickForm2_Loader', 'autoload'));
* </code>
*
* @param string $class Class name
*
* @return bool Whether class loaded successfully
*/
public static function autoload($class)
{
if (0 !== strpos($class, 'HTML_QuickForm2')) {
return false;
}
try {
@self::loadClass($class);
return true;
} catch (Exception $e) {
return false;
}
}
}
?>
Copyright 2K16 - 2K18 Indonesian Hacker Rulez