Issue #1397882 by sun, kbasarab, catch, pingers: Fixed system_theme_settings_submit...
authorDavid Rothstein
Sat, 15 Sep 2012 20:33:23 +0000 (16:33 -0400)
committerDavid Rothstein
Sat, 15 Sep 2012 20:33:23 +0000 (16:33 -0400)
CHANGELOG.txt
modules/system/system.admin.inc

index 3cc01b7..6f1ca3a 100644 (file)
@@ -1,6 +1,8 @@
 
 Drupal 7.16, xxxx-xx-xx (development version)
 -----------------------
+- Fixed the theme settings form to properly clean up submitted values in
+  $form_state['values'] when the form is submitted (data structure change).
 - Updated various admin tables to use the default "empty table" text UX
   pattern.
 - Added proxy server support to drupal_http_request().
index 23a975b..c9d623c 100644 (file)
@@ -691,8 +691,16 @@ function _system_theme_settings_validate_path($path) {
  * Process system_theme_settings form submissions.
  */
 function system_theme_settings_submit($form, &$form_state) {
+  // Exclude unnecessary elements before saving.
+  form_state_values_clean($form_state);
+
   $values = $form_state['values'];
 
+  // Extract the name of the theme from the submitted form values, then remove
+  // it from the array so that it is not saved as part of the variable.
+  $key = $values['var'];
+  unset($values['var']);
+
   // If the user uploaded a new logo or favicon, save it to a permanent location
   // and use it in place of the default theme-provided file.
   if ($file = $values['logo_upload']) {
@@ -722,10 +730,7 @@ function system_theme_settings_submit($form, &$form_state) {
   if (empty($values['default_favicon']) && !empty($values['favicon_path'])) {
     $values['favicon_mimetype'] = file_get_mimetype($values['favicon_path']);
   }
-  $key = $values['var'];
 
-  // Exclude unnecessary elements before saving.
-  unset($values['var'], $values['submit'], $values['reset'], $values['form_id'], $values['op'], $values['form_build_id'], $values['form_token']);
   variable_set($key, $values);
   drupal_set_message(t('The configuration options have been saved.'));