From d5968378ace8c13bf1d4b9d8365d725de76e0d75 Mon Sep 17 00:00:00 2001 From: Angie Byron <webchick@24967.no-reply.drupal.org> Date: Thu, 22 Jan 2009 03:56:12 +0000 Subject: [PATCH] #345973 by aaron and Rob Loach: Move parameter on drupal_add_css/js to a 'type' instead, to clean up calling code. --- includes/common.inc | 56 +++++++++++++++------------- modules/simpletest/tests/common.test | 14 +++++-- 2 files changed, 42 insertions(+), 28 deletions(-) diff --git a/includes/common.inc b/includes/common.inc index 8c0dd1311e54..66d41bb9cc5d 100644 --- a/includes/common.inc +++ b/includes/common.inc @@ -1987,13 +1987,17 @@ function drupal_add_link($attributes) { * file added to the list, if exists in the same directory. This CSS file * should contain overrides for properties which should be reversed or * otherwise different in a right-to-left display. + * + * Note that if $options or $options['type'] is 'reset', then $path will be + * ignored. * @param $options * (optional) A string defining the type of CSS that is being added in the * $path parameter ('module' or 'theme'), or an associative array of * additional options, with the following keys: * - 'type' - * The type of stylesheet that is being added. Types are: module or - * theme. Defaults to 'module'. + * The type of stylesheet that is being added. Types are: 'module', + * 'theme', or 'reset'. Defaults to 'module'. If the type is 'reset', + * then the CSS will be reset, ignoring $path and other $options. * - 'media' * The media type for the stylesheet, e.g., all, print, screen. Defaults * to 'all'. @@ -2020,32 +2024,31 @@ function drupal_add_link($attributes) { * * Typical candidates for caching are for example styles for nodes across * the site, or used in the theme. - * @param $reset - * (optional) Resets the currently loaded cascading stylesheets. * @return * An array of CSS files. */ -function drupal_add_css($path = NULL, $options = NULL, $reset = FALSE) { +function drupal_add_css($path = NULL, $options = NULL) { static $css = array(); global $language; + // Construct the options, taking the defaults into consideration. + if (isset($options)) { + if (!is_array($options)) { + $options = array('type' => $options); + } + } + else { + $options = array(); + } + // Request made to reset the CSS added so far. - if ($reset) { - $css = array(); + if (isset($options['type']) && $options['type'] == 'reset') { + return $css = array(); } // Create an array of CSS files for each media type first, since each type needs to be served // to the browser differently. if (isset($path)) { - // Construct the options, taking the defaults into consideration. - if (isset($options)) { - if (!is_array($options)) { - $options = array('type' => $options); - } - } - else { - $options = array(); - } $options += array( 'type' => 'module', 'media' => 'all', @@ -2347,6 +2350,8 @@ function drupal_clear_css_cache() { * array is directly placed in Drupal.settings. All modules should wrap * their actual configuration settings in another variable to prevent * the pollution of the Drupal.settings namespace. + * - 'reset': Anything in $data will be ignored and the JavaScript added so + * far will be reset. * @param $options * (optional) A string defining the type of JavaScript that is being added * in the $data parameter ('file'/'setting'/'inline'), or an array which @@ -2354,7 +2359,10 @@ function drupal_clear_css_cache() { * always pass the string 'setting' only. * - type * The type of JavaScript that is to be added to the page. Allowed - * values are 'file', 'inline' or 'setting'. Defaults to 'file'. + * values are 'file', 'inline', 'setting', or 'reset'. Defaults to + * 'file'. Note that if type is 'reset', then $data and all other + * $options will be ignored and the JavaScript added so far will be + * reset. * - scope * The location in which you want to place the script. Possible values * are 'header' or 'footer'. If your theme implements different regions, @@ -2387,13 +2395,11 @@ function drupal_clear_css_cache() { * - preprocess * Aggregate the JavaScript if the JavaScript optimization setting has * been toggled in admin/settings/performance. Defaults to TRUE. - * @param $reset - * (optional) Resets the currently loaded JavaScript. * @return * The contructed array of JavaScript files. * @see drupal_get_js() */ -function drupal_add_js($data = NULL, $options = NULL, $reset = FALSE) { +function drupal_add_js($data = NULL, $options = NULL) { static $javascript = array(); // Construct the options, taking the defaults into consideration. @@ -2407,14 +2413,14 @@ function drupal_add_js($data = NULL, $options = NULL, $reset = FALSE) { } $options += drupal_js_defaults($data); + if ($options['type'] == 'reset') { + // Request made to reset the JavaScript added so far + return $javascript = array(); + } + // Preprocess can only be set if caching is enabled. $options['preprocess'] = $options['cache'] ? $options['preprocess'] : FALSE; - // Request made to reset the JavaScript added so far. - if ($reset) { - $javascript = array(); - } - if (isset($data)) { // Add jquery.js and drupal.js, as well as the basePath setting, the // first time a Javascript file is added. diff --git a/modules/simpletest/tests/common.test b/modules/simpletest/tests/common.test index 8f0ede2905f2..78dc9f7698b9 100644 --- a/modules/simpletest/tests/common.test +++ b/modules/simpletest/tests/common.test @@ -170,7 +170,7 @@ class CascadingStylesheetsTestCase extends DrupalWebTestCase { function setUp() { parent::setUp(); // Reset drupal_add_css() before each test. - drupal_add_css(NULL, NULL, TRUE); + drupal_add_css(NULL, 'reset'); } /** @@ -189,6 +189,14 @@ class CascadingStylesheetsTestCase extends DrupalWebTestCase { $this->assertEqual($css['all']['module'][$path], TRUE, t('Adding a CSS file caches it properly.')); } + /** + * Makes sure that reseting the CSS empties the cache. + */ + function testReset() { + drupal_add_css(NULL, 'reset'); + $this->assertEqual(array(), drupal_add_css(), t('Resetting the CSS empties the cache.')); + } + /** * Tests rendering the stylesheets. */ @@ -352,7 +360,7 @@ class JavaScriptTestCase extends DrupalWebTestCase { variable_set('preprocess_js', 0); // Reset drupal_add_js() before each test. - drupal_add_js(NULL, NULL, TRUE); + drupal_add_js(NULL, 'reset'); } function tearDown() { @@ -404,7 +412,7 @@ class JavaScriptTestCase extends DrupalWebTestCase { */ function testReset() { drupal_add_js('misc/collapse.js'); - drupal_add_js(NULL, NULL, TRUE); + drupal_add_js(NULL, 'reset'); $this->assertEqual(array(), drupal_add_js(), t('Resetting the JavaScript correctly empties the cache.')); } -- GitLab