diff options
Diffstat (limited to 'phpBB/includes/style')
| -rw-r--r-- | phpBB/includes/style/extension_path_provider.php | 36 | ||||
| -rw-r--r-- | phpBB/includes/style/path_provider.php | 16 | ||||
| -rw-r--r-- | phpBB/includes/style/path_provider_interface.php | 7 | ||||
| -rw-r--r-- | phpBB/includes/style/resource_locator.php | 66 | ||||
| -rw-r--r-- | phpBB/includes/style/style.php | 4 | 
5 files changed, 48 insertions, 81 deletions
| diff --git a/phpBB/includes/style/extension_path_provider.php b/phpBB/includes/style/extension_path_provider.php index 1fb6580ce1..4eac300424 100644 --- a/phpBB/includes/style/extension_path_provider.php +++ b/phpBB/includes/style/extension_path_provider.php @@ -82,22 +82,26 @@ class phpbb_style_extension_path_provider extends phpbb_extension_provider imple  		$directories = array();  		$finder = $this->extension_manager->get_finder(); -		foreach ($this->base_path_provider as $path) +		foreach ($this->base_path_provider as $key => $paths)  		{ -			if ($path && !phpbb_is_absolute($path)) +			if ($key == 'style')  			{ -				$directories = array_merge($directories, $finder -					->directory('/' . $this->ext_dir_prefix . $path) -					->get_directories() -				); +				foreach ($paths as $path) +				{ +					$directories['style'][] = $path; +					if ($path && !phpbb_is_absolute($path)) +					{ +						$result = $finder->directory('/' . $this->ext_dir_prefix . $path) +							->get_directories(true, true); +						foreach ($result as $ext => $ext_path) +						{ +							$directories[$ext][] = $ext_path; +						} +					} +				}  			}  		} -		foreach ($this->base_path_provider as $path) -		{ -			$directories[] = $path; -		} -  		return $directories;  	} @@ -112,14 +116,4 @@ class phpbb_style_extension_path_provider extends phpbb_extension_provider imple  		$this->base_path_provider->set_styles($styles);  		$this->items = null;  	} - -	/** -	* Retrieves the path to the main style passed into set_styles() -	* -	* @return string Main style path -	*/ -	public function get_main_style_path() -	{ -		return $this->base_path_provider->get_main_style_path(); -	}  } diff --git a/phpBB/includes/style/path_provider.php b/phpBB/includes/style/path_provider.php index c229af92ba..731d682e88 100644 --- a/phpBB/includes/style/path_provider.php +++ b/phpBB/includes/style/path_provider.php @@ -24,7 +24,6 @@ if (!defined('IN_PHPBB'))  */  class phpbb_style_path_provider implements IteratorAggregate, phpbb_style_path_provider_interface  { -	protected $main_style_name = '';  	protected $paths = array();  	/** @@ -41,25 +40,14 @@ class phpbb_style_path_provider implements IteratorAggregate, phpbb_style_path_p  	* Overwrites the current style paths  	*  	* The first element of the passed styles map, is considered the main -	* style and can be retrieved through get_main_style_path(). +	* style.  	*  	* @param array $styles An array of style paths. The first element is the main style.  	* @return null  	*/  	public function set_styles(array $styles)  	{ -		$this->paths = $styles; -		$this->main_style_path = $this->paths[0]; -	} - -	/** -	* Retrieves the path to the main style passed into set_styles() -	* -	* @return string Main style path -	*/ -	public function get_main_style_path() -	{ -		return $this->main_style_path; +		$this->paths = array('style' => $styles);  	}  	/** diff --git a/phpBB/includes/style/path_provider_interface.php b/phpBB/includes/style/path_provider_interface.php index 7ae94e17f4..1a6153a4d3 100644 --- a/phpBB/includes/style/path_provider_interface.php +++ b/phpBB/includes/style/path_provider_interface.php @@ -39,11 +39,4 @@ interface phpbb_style_path_provider_interface extends Traversable  	* @return null  	*/  	public function set_styles(array $styles); - -	/** -	* Retrieves the path to the main style passed into set_styles() -	* -	* @return string Main style path -	*/ -	public function get_main_style_path();  } diff --git a/phpBB/includes/style/resource_locator.php b/phpBB/includes/style/resource_locator.php index af261534c3..39505cedb5 100644 --- a/phpBB/includes/style/resource_locator.php +++ b/phpBB/includes/style/resource_locator.php @@ -39,12 +39,6 @@ class phpbb_style_resource_locator  	private $roots = array();  	/** -	* Index of the main style in the roots array. -	* @var int -	*/ -	private $main_root_id = 0; - -	/**  	* Location of templates directory within style directories.  	* Must have trailing slash. Empty if templates are stored in root  	* style directory, such as admin control panel templates. @@ -70,17 +64,6 @@ class phpbb_style_resource_locator  	private $filenames = array();  	/** -	* Set main style location (must have been added through set_paths first). -	* -	* @param string $style_path Path to style directory -	* @return null -	*/ -	public function set_main_style($style_path) -	{ -		$this->main_root_id = array_search($style_path, $this->roots, true); -	} - -	/**  	* Sets the list of style paths  	*  	* These paths will be searched for style files in the provided order. @@ -95,16 +78,18 @@ class phpbb_style_resource_locator  		$this->roots = array();  		$this->files = array();  		$this->filenames = array(); -		$this->main_root_id = 0; -		foreach ($style_paths as $path) +		foreach ($style_paths as $key => $paths)  		{ -			// Make sure $path has no ending slash -			if (substr($path, -1) === '/') +			foreach ($paths as $path)  			{ -				$path = substr($path, 0, -1); +				// Make sure $path has no ending slash +				if (substr($path, -1) === '/') +				{ +					$path = substr($path, 0, -1); +				} +				$this->roots[$key][] = $path;  			} -			$this->roots[] = $path;  		}  	} @@ -125,9 +110,12 @@ class phpbb_style_resource_locator  			$this->filename[$handle] = $filename; -			foreach ($this->roots as $root_index => $root) +			foreach ($this->roots as $root_key => $root_paths)  			{ -				$this->files[$root_index][$handle] = $root . '/' . $this->template_path . $filename; +				foreach ($root_paths as $root_index => $root) +				{ +					$this->files[$root_key][$root_index][$handle] = $root . '/' . $this->template_path . $filename; +				}  			}  		}  	} @@ -174,12 +162,12 @@ class phpbb_style_resource_locator  	public function get_virtual_source_file_for_handle($handle)  	{  		// If we don't have a file assigned to this handle, die. -		if (!isset($this->files[$this->main_root_id][$handle])) +		if (!isset($this->files['style'][0][$handle]))  		{  			trigger_error("style resource locator: No file specified for handle $handle", E_USER_ERROR);  		} -		$source_file = $this->files[$this->main_root_id][$handle]; +		$source_file = $this->files['style'][0][$handle];  		return $source_file;  	} @@ -202,26 +190,28 @@ class phpbb_style_resource_locator  	public function get_source_file_for_handle($handle)  	{  		// If we don't have a file assigned to this handle, die. -		if (!isset($this->files[$this->main_root_id][$handle])) +		if (!isset($this->files['style'][0][$handle]))  		{  			trigger_error("style resource locator: No file specified for handle $handle", E_USER_ERROR);  		}  		// locate a source file that exists -		$source_file = $this->files[0][$handle]; +		$source_file = $this->files['style'][0][$handle];  		$tried = $source_file; -		for ($i = 1, $n = count($this->roots); $i < $n && !file_exists($source_file); $i++) +		foreach ($this->roots as $root_key => $root_paths)  		{ -			$source_file = $this->files[$i][$handle]; -			$tried .= ', ' . $source_file; +			foreach ($root_paths as $root_index => $root) +			{ +				$source_file = $this->files[$root_key][$root_index][$handle]; +				if (file_exists($source_file)) +				{ +					return $source_file; +				} +				$tried .= ', ' . $source_file; +			}  		}  		// search failed -		if (!file_exists($source_file)) -		{ -			trigger_error("style resource locator: File for handle $handle does not exist. Could not find: $tried", E_USER_ERROR); -		} - -		return $source_file; +		trigger_error("style resource locator: File for handle $handle does not exist. Could not find: $tried", E_USER_ERROR);  	}  } diff --git a/phpBB/includes/style/style.php b/phpBB/includes/style/style.php index 539a2642ee..dc1e71dff6 100644 --- a/phpBB/includes/style/style.php +++ b/phpBB/includes/style/style.php @@ -92,6 +92,9 @@ class phpbb_style  			$paths[] = $this->get_style_path($dir);  		} +		// Add 'all' path, used as last fallback path by hooks and extensions +		$paths[] = $this->get_style_path('all'); +  		return $this->set_custom_style($style_name, $paths);  	} @@ -113,7 +116,6 @@ class phpbb_style  		$this->provider->set_styles($paths);  		$this->locator->set_paths($this->provider); -		$this->locator->set_main_style($this->provider->get_main_style_path());  		$this->template->cachepath = $this->phpbb_root_path . 'cache/tpl_' . str_replace('_', '-', $name) . '_'; | 
