2010-07-07 03:34:48 +02:00
|
|
|
<?php
|
2008-02-25 03:10:37 +01:00
|
|
|
/**
|
2008-09-30 01:41:50 +02:00
|
|
|
* This file is the Sapphire bootstrap. It will get your environment ready to call Director::direct().
|
2008-02-25 03:10:37 +01:00
|
|
|
*
|
2008-09-30 01:41:50 +02:00
|
|
|
* It takes care of:
|
2013-07-22 03:53:40 +02:00
|
|
|
* - Including Constants.php to include _ss_environment and initialise necessary constants
|
2008-09-30 01:41:50 +02:00
|
|
|
* - Checking of PHP memory limit
|
|
|
|
* - Including all the files needed to get the manifest built
|
|
|
|
* - Building and including the manifest
|
2013-07-22 03:53:40 +02:00
|
|
|
*
|
2008-09-30 01:41:50 +02:00
|
|
|
* @todo This file currently contains a lot of bits and pieces, and its various responsibilities should probably be
|
2013-07-22 03:53:40 +02:00
|
|
|
* moved into different subsystems.
|
|
|
|
* @todo A lot of this stuff is very order-dependent. This could be decoupled.
|
|
|
|
*
|
2008-02-25 03:10:37 +01:00
|
|
|
* @package sapphire
|
|
|
|
* @subpackage core
|
|
|
|
*/
|
|
|
|
|
2008-09-30 01:41:50 +02:00
|
|
|
|
2013-07-22 03:53:40 +02:00
|
|
|
/**
|
|
|
|
* Set up error reporting
|
|
|
|
*/
|
2011-08-26 06:12:57 +02:00
|
|
|
if(defined('E_DEPRECATED')) error_reporting(E_ALL & ~(E_DEPRECATED | E_STRICT));
|
2009-06-26 04:46:14 +02:00
|
|
|
else error_reporting(E_ALL);
|
2013-07-22 03:53:40 +02:00
|
|
|
|
2010-01-21 01:36:04 +01:00
|
|
|
/*
|
|
|
|
* This is for versions of PHP prior to version 5.2
|
|
|
|
* Creating this here will allow both web requests and cron jobs to inherit it.
|
|
|
|
*/
|
|
|
|
if (!function_exists('array_fill_keys')) {
|
|
|
|
function array_fill_keys($keys,$value) {
|
|
|
|
//Sometimes we get passed an empty array, and if that's the case, you'll get an error message
|
|
|
|
if(sizeof($keys)==0)
|
|
|
|
return Array();
|
|
|
|
else
|
|
|
|
return array_combine($keys,array_fill(0,count($keys),$value));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2008-09-30 01:41:50 +02:00
|
|
|
/**
|
2013-07-22 03:53:40 +02:00
|
|
|
* Include Constants (if it hasn't already been included) to pull in BASE_PATH, etc
|
2008-09-30 01:41:50 +02:00
|
|
|
*/
|
2013-07-22 03:53:40 +02:00
|
|
|
require_once dirname(__FILE__).'/Constants.php';
|
2008-09-29 01:03:28 +02:00
|
|
|
|
2008-09-29 14:33:07 +02:00
|
|
|
/**
|
|
|
|
* Priorities definition. These constants are used in calls to _t() as an optional argument
|
|
|
|
*/
|
|
|
|
define('PR_HIGH',100);
|
|
|
|
define('PR_MEDIUM',50);
|
|
|
|
define('PR_LOW',10);
|
|
|
|
|
2008-09-30 01:41:50 +02:00
|
|
|
/**
|
|
|
|
* Ensure we have enough memory
|
|
|
|
*/
|
2009-06-17 13:36:49 +02:00
|
|
|
increase_memory_limit_to('64M');
|
2008-09-30 01:41:50 +02:00
|
|
|
|
2010-09-21 22:29:04 +02:00
|
|
|
/**
|
|
|
|
* Sapphire class autoloader. Requires the ManifestBuilder to work.
|
|
|
|
* $_CLASS_MANIFEST must have been loaded up by ManifestBuilder for this to successfully load
|
|
|
|
* classes. Classes will be loaded from any PHP file within the application.
|
|
|
|
* If your class contains an underscore, for example, Page_Controller, then the filename is
|
|
|
|
* expected to be the stuff before the underscore. In this case, Page.php.
|
|
|
|
*
|
|
|
|
* Class names are converted to lowercase for lookup to adhere to PHP's case-insensitive
|
|
|
|
* way of dealing with them.
|
|
|
|
*/
|
2010-11-18 22:37:20 +01:00
|
|
|
function sapphire_autoload($className) {
|
2010-09-21 22:29:04 +02:00
|
|
|
global $_CLASS_MANIFEST;
|
|
|
|
$lClassName = strtolower($className);
|
|
|
|
if(isset($_CLASS_MANIFEST[$lClassName])) include_once($_CLASS_MANIFEST[$lClassName]);
|
|
|
|
else if(isset($_CLASS_MANIFEST[$className])) include_once($_CLASS_MANIFEST[$className]);
|
|
|
|
}
|
|
|
|
|
|
|
|
spl_autoload_register('sapphire_autoload');
|
|
|
|
|
2010-01-28 06:10:32 +01:00
|
|
|
require_once("core/ManifestBuilder.php");
|
|
|
|
require_once("core/ClassInfo.php");
|
|
|
|
require_once('core/Object.php');
|
|
|
|
require_once('core/control/Director.php');
|
|
|
|
require_once('filesystem/Filesystem.php');
|
|
|
|
require_once("core/Session.php");
|
|
|
|
|
2008-09-30 01:41:50 +02:00
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
// MANIFEST
|
|
|
|
|
|
|
|
/**
|
2008-11-06 05:51:25 +01:00
|
|
|
* Include the manifest
|
2008-09-30 01:41:50 +02:00
|
|
|
*/
|
2008-11-06 05:51:25 +01:00
|
|
|
ManifestBuilder::include_manifest();
|
2008-09-30 01:41:50 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* ?debugmanifest=1 hook
|
|
|
|
*/
|
|
|
|
if(isset($_GET['debugmanifest'])) Debug::show(file_get_contents(MANIFEST_FILE));
|
|
|
|
|
2008-10-08 05:35:28 +02:00
|
|
|
// If this is a dev site, enable php error reporting
|
|
|
|
// This is necessary to force developers to acknowledge and fix
|
|
|
|
// notice level errors (you can override this directive in your _config.php)
|
|
|
|
if (Director::isLive()) {
|
2012-10-16 12:37:30 +02:00
|
|
|
if(defined('E_DEPRECATED')) error_reporting(E_ALL & ~(E_NOTICE | E_DEPRECATED | E_STRICT));
|
|
|
|
else error_reporting(E_ALL & ~E_NOTICE);
|
2008-10-08 05:35:28 +02:00
|
|
|
}
|
2008-09-30 01:41:50 +02:00
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
// POST-MANIFEST COMMANDS
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Load error handlers
|
|
|
|
*/
|
|
|
|
Debug::loadErrorHandlers();
|
|
|
|
|
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
// HELPER FUNCTIONS
|
|
|
|
|
2007-07-19 12:40:28 +02:00
|
|
|
/**
|
2010-05-17 05:22:07 +02:00
|
|
|
* Return the file where that class is stored.
|
|
|
|
*
|
|
|
|
* @param String $className Case-insensitive lookup.
|
|
|
|
* @return String
|
2007-07-19 12:40:28 +02:00
|
|
|
*/
|
|
|
|
function getClassFile($className) {
|
|
|
|
global $_CLASS_MANIFEST;
|
2010-03-16 04:56:59 +01:00
|
|
|
$lClassName = strtolower($className);
|
|
|
|
if(isset($_CLASS_MANIFEST[$lClassName])) return $_CLASS_MANIFEST[$lClassName];
|
|
|
|
else if(isset($_CLASS_MANIFEST[$className])) return $_CLASS_MANIFEST[$className];
|
2007-07-19 12:40:28 +02:00
|
|
|
}
|
|
|
|
|
2009-03-31 21:32:19 +02:00
|
|
|
/**
|
|
|
|
* Creates a class instance by the "singleton" design pattern.
|
|
|
|
* It will always return the same instance for this class,
|
|
|
|
* which can be used for performance reasons and as a simple
|
|
|
|
* way to access instance methods which don't rely on instance
|
|
|
|
* data (e.g. the custom SilverStripe static handling).
|
|
|
|
*
|
|
|
|
* @uses Object::strong_create()
|
|
|
|
*
|
|
|
|
* @param string $className
|
|
|
|
* @return Object
|
|
|
|
*/
|
2007-07-19 12:40:28 +02:00
|
|
|
function singleton($className) {
|
2009-03-31 21:32:19 +02:00
|
|
|
global $_SINGLETONS;
|
2007-07-19 12:40:28 +02:00
|
|
|
if(!isset($className)) user_error("singleton() Called without a class", E_USER_ERROR);
|
2008-11-18 02:48:37 +01:00
|
|
|
if(!is_string($className)) user_error("singleton() passed bad class_name: " . var_export($className,true), E_USER_ERROR);
|
2007-07-19 12:40:28 +02:00
|
|
|
if(!isset($_SINGLETONS[$className])) {
|
2010-11-18 22:37:20 +01:00
|
|
|
if(!class_exists($className)) user_error("Bad class to singleton() - $className", E_USER_ERROR);
|
2007-07-19 12:40:28 +02:00
|
|
|
$_SINGLETONS[$className] = Object::strong_create($className,null, true);
|
|
|
|
if(!$_SINGLETONS[$className]) user_error("singleton() Unknown class '$className'", E_USER_ERROR);
|
|
|
|
}
|
|
|
|
return $_SINGLETONS[$className];
|
|
|
|
}
|
|
|
|
|
|
|
|
function project() {
|
|
|
|
global $project;
|
|
|
|
return $project;
|
|
|
|
}
|
|
|
|
|
2007-09-15 02:12:28 +02:00
|
|
|
/**
|
2008-10-17 17:40:59 +02:00
|
|
|
* @see i18n::_t()
|
2007-09-15 02:12:28 +02:00
|
|
|
*/
|
2007-09-15 02:21:51 +02:00
|
|
|
function _t($entity, $string = "", $priority = 40, $context = "") {
|
2008-10-17 17:40:59 +02:00
|
|
|
return i18n::_t($entity, $string, $priority, $context);
|
2007-09-15 02:12:28 +02:00
|
|
|
}
|
2007-09-15 02:19:29 +02:00
|
|
|
|
2009-06-17 13:36:49 +02:00
|
|
|
/**
|
|
|
|
* Increase the memory limit to the given level if it's currently too low.
|
2009-06-28 04:36:46 +02:00
|
|
|
* @param A memory limit string, such as "64M". If omitted, unlimited memory will be set.
|
2009-06-17 13:36:49 +02:00
|
|
|
*/
|
2009-06-28 04:36:46 +02:00
|
|
|
function increase_memory_limit_to($memoryLimit = -1) {
|
|
|
|
$curLimit = ini_get('memory_limit');
|
|
|
|
|
|
|
|
// Can't go higher than infinite
|
|
|
|
if($curLimit == -1) return;
|
|
|
|
|
2009-06-17 13:36:49 +02:00
|
|
|
// Increase the memory limit if it's too low
|
2009-06-28 04:36:46 +02:00
|
|
|
if($memoryLimit == -1 || translate_memstring($memoryLimit) > translate_memstring($curLimit)) {
|
2009-06-17 13:36:49 +02:00
|
|
|
ini_set('memory_limit', $memoryLimit);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Turn a memory string, such as 512M into an actual number of bytes.
|
|
|
|
* @param A memory limit string, such as "64M"
|
|
|
|
*/
|
|
|
|
function translate_memstring($memString) {
|
|
|
|
switch(strtolower(substr($memString, -1))) {
|
|
|
|
case "k": return round(substr($memString, 0, -1)*1024);
|
|
|
|
case "m": return round(substr($memString, 0, -1)*1024*1024);
|
|
|
|
case "g": return round(substr($memString, 0, -1)*1024*1024*1024);
|
|
|
|
default: return round($memString);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2009-06-28 04:36:46 +02:00
|
|
|
/**
|
|
|
|
* Increase the time limit of this script. By default, the time will be unlimited.
|
|
|
|
* @param $timeLimit The time limit in seconds. If omitted, no time limit will be set.
|
|
|
|
*/
|
|
|
|
function increase_time_limit_to($timeLimit = null) {
|
|
|
|
if(!ini_get('safe_mode')) {
|
|
|
|
if(!$timeLimit) {
|
|
|
|
set_time_limit(0);
|
|
|
|
} else {
|
|
|
|
$currTimeLimit = ini_get('max_execution_time');
|
|
|
|
if($currTimeLimit && $currTimeLimit < $timeLimit) {
|
|
|
|
set_time_limit($timeLimit);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|