From 4dafb3953cabb0911286e6d683b495f6e1c43238 Mon Sep 17 00:00:00 2001 From: Angie Byron Date: Sun, 28 Jun 2009 03:56:43 +0000 Subject: #482346 by Berdir: Move module installation logic to module_enable() to prevent errors upon enabling modules. --- includes/install.inc | 6 +----- includes/module.inc | 13 ++++++++++++- 2 files changed, 13 insertions(+), 6 deletions(-) (limited to 'includes') diff --git a/includes/install.inc b/includes/install.inc index b618594c8..450f7cd55 100644 --- a/includes/install.inc +++ b/includes/install.inc @@ -516,11 +516,7 @@ function drupal_install_modules($module_list = array(), $disable_modules_install } while ($moved); asort($module_list); $module_list = array_keys($module_list); - $modules_installed = array_filter($module_list, '_drupal_install_module'); - if (!$disable_modules_installed_hook && !empty($modules_installed)) { - module_invoke_all('modules_installed', $modules_installed); - } - module_enable($module_list); + module_enable($module_list, $disable_modules_installed_hook); } /** diff --git a/includes/module.inc b/includes/module.inc index a8a878cb6..ce8470962 100644 --- a/includes/module.inc +++ b/includes/module.inc @@ -177,9 +177,15 @@ function module_load_all_includes($type, $name = NULL) { * * @param $module_list * An array of module names. + * @param $disable_modules_installed_hook + * Normally just testing wants to set this to TRUE. */ -function module_enable($module_list) { +function module_enable($module_list, $disable_modules_installed_hook = FALSE) { $invoke_modules = array(); + + // Try to install the enabled modules and collect which were installed. + // $module_list is not changed and already installed modules are ignored. + $modules_installed = array_filter($module_list, '_drupal_install_module'); foreach ($module_list as $module) { $existing = db_query("SELECT status FROM {system} WHERE type = :type AND name = :name", array( ':type' => 'module', @@ -203,6 +209,11 @@ function module_enable($module_list) { module_list(TRUE); // Force to regenerate the stored list of hook implementations. registry_rebuild(); + + // If any modules were newly installed, execute the hook for them. + if (!$disable_modules_installed_hook && !empty($modules_installed)) { + module_invoke_all('modules_installed', $modules_installed); + } } foreach ($invoke_modules as $module) { -- cgit v1.2.3