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