Merge pull request #83 from simonwelsh/master

PHP5.4 Support
This commit is contained in:
Sam Minnée 2011-10-28 16:20:56 -07:00
commit 0cdf52c09a
6 changed files with 13 additions and 5 deletions

View File

@ -368,6 +368,10 @@ class Controller extends RequestHandler {
*/ */
function can($perm, $member = null) { function can($perm, $member = null) {
if(!$member) $member = Member::currentUser(); if(!$member) $member = Member::currentUser();
if(is_array($perm)) {
$perm = array_map(array($this, 'can'), $perm, array_fill(0, count($perm), $member));
return min($perm);
}
if($this->hasMethod($methodName = 'can' . $perm)) { if($this->hasMethod($methodName = 'can' . $perm)) {
return $this->$methodName($member); return $this->$methodName($member);
} else { } else {

View File

@ -40,7 +40,7 @@
/////////////////////////////////////////////////////////////////////////////// ///////////////////////////////////////////////////////////////////////////////
// ENVIRONMENT CONFIG // ENVIRONMENT CONFIG
if(defined('E_DEPRECATED')) error_reporting(E_ALL ^ E_DEPRECATED); if(defined('E_DEPRECATED')) error_reporting(E_ALL & ~(E_DEPRECATED | E_STRICT));
else error_reporting(E_ALL); else error_reporting(E_ALL);
/* /*
* This is for versions of PHP prior to version 5.2 * This is for versions of PHP prior to version 5.2

View File

@ -136,7 +136,8 @@ class SS_Backtrace {
$args = array(); $args = array();
foreach($item['args'] as $arg) { foreach($item['args'] as $arg) {
if(!is_object($arg) || method_exists($arg, '__toString')) { if(!is_object($arg) || method_exists($arg, '__toString')) {
$args[] = (strlen((string)$arg) > $argCharLimit) ? substr((string)$arg, 0, $argCharLimit) . '...' : (string)$arg; $sarg = is_array($arg) ? 'Array' : strval($arg);
$args[] = (strlen($sarg) > $argCharLimit) ? substr($sarg, 0, $argCharLimit) . '...' : $sarg;
} else { } else {
$args[] = get_class($arg); $args[] = get_class($arg);
} }

View File

@ -107,6 +107,9 @@ require_once("model/DB.php");
// Redirect to the installer if no database is selected // Redirect to the installer if no database is selected
if(!isset($databaseConfig) || !isset($databaseConfig['database']) || !$databaseConfig['database']) { if(!isset($databaseConfig) || !isset($databaseConfig['database']) || !$databaseConfig['database']) {
if(!file_exists(BASE_PATH . '/install.php')) {
die('SilverStripe Framework requires a $databaseConfig defined.');
}
$s = (isset($_SERVER['SSL']) || (isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] != 'off')) ? 's' : ''; $s = (isset($_SERVER['SSL']) || (isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] != 'off')) ? 's' : '';
$installURL = "http$s://" . $_SERVER['HTTP_HOST'] . BASE_URL . '/install.php'; $installURL = "http$s://" . $_SERVER['HTTP_HOST'] . BASE_URL . '/install.php';

View File

@ -218,7 +218,7 @@ class RestfulServiceTest_MockRestfulService extends RestfulService {
public $session = null; public $session = null;
public function request($subURL = '', $method = "GET", $data = null, $headers = null) { public function request($subURL = '', $method = "GET", $data = null, $headers = null, $curlOptions = array()) {
if(!$this->session) { if(!$this->session) {
$this->session = new Session(array()); $this->session = new Session(array());
@ -277,7 +277,7 @@ class RestfulServiceTest_MockRestfulService extends RestfulService {
*/ */
class RestfulServiceTest_MockErrorService extends RestfulService { class RestfulServiceTest_MockErrorService extends RestfulService {
public function curlRequest() { public function curlRequest($url, $method, $data = null, $headers = null, $curlOptions = array()) {
return new RestfulService_Response('<error>HTTP Error</error>', 400); return new RestfulService_Response('<error>HTTP Error</error>', 400);
} }

View File

@ -319,7 +319,7 @@ class SSViewer {
} }
} }
if(substr((string) $templateList,-3) == '.ss') { if(!is_array($templateList) && substr((string) $templateList,-3) == '.ss') {
$this->chosenTemplates['main'] = $templateList; $this->chosenTemplates['main'] = $templateList;
} else { } else {
$this->chosenTemplates = SS_TemplateLoader::instance()->findTemplates( $this->chosenTemplates = SS_TemplateLoader::instance()->findTemplates(