From af9b327ed0872b4f04a71e2dd3c5efc364db8e55 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?G=C3=A1bor=20Hojtsy?= <gabor@hojtsy.hu> Date: Mon, 21 Jan 2008 21:47:08 +0000 Subject: [PATCH] #206778 follow up by dvessel: better filtering for subtheme files --- includes/theme.inc | 30 +++++++++++++++++++----------- 1 file changed, 19 insertions(+), 11 deletions(-) diff --git a/includes/theme.inc b/includes/theme.inc index 51957186be73..31cda3a8063d 100644 --- a/includes/theme.inc +++ b/includes/theme.inc @@ -754,25 +754,33 @@ function drupal_find_theme_functions($cache, $prefixes) { function drupal_find_theme_templates($cache, $extension, $path) { $templates = array(); - // Escape the periods in the extension. - $regex = str_replace('.', '\.', $extension) .'$'; - - // Collect sub-themes for the current theme. This allows base themes to have - // sub-themes in its folder hierarchy without affecting the base theme. - global $theme; - $sub_themes = array(); + // Collect paths to all sub-themes grouped by base themes. These will be + // used for filtering. This allows base themes to have sub-themes in its + // folder hierarchy without affecting the base themes template discovery. + $theme_paths = array(); foreach (list_themes() as $theme_info) { - if (!empty($theme_info->base_theme) && $theme_info->base_theme == $theme) { - $sub_themes[] = dirname($theme_info->filename); + if (!empty($theme_info->base_theme)) { + $theme_paths[$theme_info->base_theme][$theme_info->name] = dirname($theme_info->filename); + } + } + foreach ($theme_paths as $basetheme => $subthemes) { + foreach ($subthemes as $subtheme => $subtheme_path) { + if (isset($theme_paths[$subtheme])) { + $theme_paths[$basetheme] = array_merge($theme_paths[$basetheme], $theme_paths[$subtheme]); + } } } + global $theme; + $subtheme_paths = isset($theme_paths[$theme]) ? $theme_paths[$theme] : array(); + // Escape the periods in the extension. + $regex = str_replace('.', '\.', $extension) .'$'; // Because drupal_system_listing works the way it does, we check for real // templates separately from checking for patterns. $files = drupal_system_listing($regex, $path, 'name', 0); foreach ($files as $template => $file) { - // Catch sub-themes and skip. - if (strpos($file->filename, str_replace($sub_themes, '', $file->filename)) !== 0) { + // Ignore sub-theme templates for the current theme. + if (strpos($file->filename, str_replace($subtheme_paths, '', $file->filename)) !== 0) { continue; } // Chop off the remaining extensions if there are any. $template already -- GitLab