diff options
Diffstat (limited to 'engine/lib/elgglib.php')
| -rw-r--r-- | engine/lib/elgglib.php | 31 | 
1 files changed, 24 insertions, 7 deletions
| diff --git a/engine/lib/elgglib.php b/engine/lib/elgglib.php index 74b70f9fb..34111c69d 100644 --- a/engine/lib/elgglib.php +++ b/engine/lib/elgglib.php @@ -93,10 +93,17 @@ function elgg_register_library($name, $location) {   * @return void   * @throws InvalidParameterException   * @since 1.8.0 + * @todo return boolean in 1.9 to indicate whether the library has been loaded   */  function elgg_load_library($name) {  	global $CONFIG; +	static $loaded_libraries = array(); + +	if (in_array($name, $loaded_libraries)) { +		return; +	} +  	if (!isset($CONFIG->libraries)) {  		$CONFIG->libraries = array();  	} @@ -113,6 +120,8 @@ function elgg_load_library($name) {  		);  		throw new InvalidParameterException($error);  	} + +	$loaded_libraries[] = $name;  }  /** @@ -128,7 +137,7 @@ function elgg_load_library($name) {   * @throws SecurityException   */  function forward($location = "", $reason = 'system') { -	if (!headers_sent()) { +	if (!headers_sent($file, $line)) {  		if ($location === REFERER) {  			$location = $_SERVER['HTTP_REFERER'];  		} @@ -147,7 +156,7 @@ function forward($location = "", $reason = 'system') {  			exit;  		}  	} else { -		throw new SecurityException(elgg_echo('SecurityException:ForwardFailedToRedirect')); +		throw new SecurityException(elgg_echo('SecurityException:ForwardFailedToRedirect', array($file, $line)));  	}  } @@ -737,7 +746,7 @@ function elgg_unregister_event_handler($event, $object_type, $callback) {   * @tip When referring to events, the preferred syntax is "event, type".   *   * @internal Only rarely should events be changed, added, or removed in core. - * When making changes to events, be sure to first create a ticket in trac. + * When making changes to events, be sure to first create a ticket on Github.   *   * @internal @tip Think of $object_type as the primary namespace element, and   * $event as the secondary namespace. @@ -1185,6 +1194,11 @@ function elgg_dump($value, $to_screen = TRUE, $level = 'NOTICE') {  		$to_screen = FALSE;  	} +	// Do not want to write to JS or CSS pages +	if (elgg_in_context('js') || elgg_in_context('css')) { +		$to_screen = FALSE; +	} +  	if ($to_screen == TRUE) {  		echo '<pre>';  		print_r($value); @@ -1336,7 +1350,7 @@ function full_url() {  		"" : (":" . $_SERVER["SERVER_PORT"]);  	// This is here to prevent XSS in poorly written browsers used by 80% of the population. -	// {@trac [5813]} +	// https://github.com/Elgg/Elgg/commit/0c947e80f512cb0a482b1864fd0a6965c8a0cd4a  	$quotes = array('\'', '"');  	$encoded = array('%27', '%22'); @@ -1383,8 +1397,8 @@ function elgg_http_build_url(array $parts, $html_encode = TRUE) {   * add tokens to the action.  The form view automatically handles   * tokens.   * - * @param string  $url         Full action URL - * @param bool $html_encode HTML encode the url? (default: false) + * @param string $url         Full action URL + * @param bool   $html_encode HTML encode the url? (default: false)   *   * @return string URL with action tokens   * @since 1.7.0 @@ -1446,7 +1460,7 @@ function elgg_http_remove_url_query_element($url, $element) {   * Adds an element or elements to a URL's query string.   *   * @param string $url      The URL - * @param array $elements Key/value pairs to add to the URL + * @param array  $elements Key/value pairs to add to the URL   *   * @return string The new URL with the query strings added   * @since 1.7.0 @@ -2233,6 +2247,9 @@ function elgg_api_test($hook, $type, $value, $params) {  /**#@+   * Controls access levels on ElggEntity entities, metadata, and annotations.   * + * @warning ACCESS_DEFAULT is a place holder for the input/access view. Do not + * use it when saving an entity. + *   * @var int   */  define('ACCESS_DEFAULT', -1); | 
