Index: update_advanced.module =================================================================== RCS file: /cvs/drupal-contrib/contributions/modules/update_advanced/update_advanced.module,v retrieving revision 1.3 diff -u -p -r1.3 update_advanced.module --- update_advanced.module 14 Aug 2008 18:23:00 -0000 1.3 +++ update_advanced.module 14 Apr 2009 03:46:04 -0000 @@ -37,6 +37,70 @@ function update_advanced_form_alter(&$fo } /** + * Duplicate function of _update_process_info_list for disabled projects. + */ +function _update_advanced_process_disabled_info_list(&$projects, $list, $project_type) { + foreach ($list as $file) { + if (!empty($file->status)) { + // Skip enabled modules or themes. + continue; + } + + // Skip if the .info file is broken. + if (empty($file->info)) { + continue; + } + + // If the .info doesn't define the 'project', try to figure it out. + if (!isset($file->info['project'])) { + $file->info['project'] = update_get_project_name($file); + } + + // If we still don't know the 'project', give up. + if (empty($file->info['project'])) { + continue; + } + + // If we don't already know it, grab the change time on the .info file + // itself. Note: we need to use the ctime, not the mtime (modification + // time) since many (all?) tar implementations will go out of their way to + // set the mtime on the files it creates to the timestamps recorded in the + // tarball. We want to see the last time the file was changed on disk, + // which is left alone by tar and correctly set to the time the .info file + // was unpacked. + if (!isset($file->info['_info_file_ctime'])) { + $info_filename = dirname($file->filename) .'/'. $file->name .'.info'; + $file->info['_info_file_ctime'] = filectime($info_filename); + } + + $project_name = $file->info['project']; + if (!isset($projects[$project_name])) { + // Only process this if we haven't done this project, since a single + // project can have multiple modules or themes. + $projects[$project_name] = array( + 'name' => $project_name, + 'info' => $file->info, + 'datestamp' => isset($file->info['datestamp']) ? $file->info['datestamp'] : 0, + 'includes' => array($file->name => $file->info['name']), + 'project_type' => $project_name == 'drupal' ? 'core' : $project_type, + ); + } + else { + $projects[$project_name]['includes'][$file->name] = $file->info['name']; + $projects[$project_name]['info']['_info_file_ctime'] = max($projects[$project_name]['info']['_info_file_ctime'], $file->info['_info_file_ctime']); + } + } +} + +/** + * Implementation of hook_update_projects_alter(). + */ +function update_advanced_update_projects_alter(&$projects) { + _update_advanced_process_disabled_info_list($projects, module_rebuild_cache(), 'disabled-module'); + _update_advanced_process_disabled_info_list($projects, system_theme_data(), 'disabled-theme'); +} + +/** * Implementation of hook_update_status_alter(). * * This compares the array of computed information about projects that are