Make WordPress Core


Ignore:
Timestamp:
10/05/2015 03:05:26 PM (9 years ago)
Author:
boonebgorges
Message:

Use wp_installing() instead of WP_INSTALLING constant.

The WP_INSTALLING constant is a flag that WordPress sets in a number of
places, telling the system that options should be fetched directly from the
database instead of from the cache, that WP should not ping wordpress.org for
updates, that the normal "not installed" checks should be bypassed, and so on.

A constant is generally necessary for this purpose, because the flag is
typically set before the WP bootstrap, meaning that WP functions are not yet
available. However, it is possible - notably, during wpmu_create_blog() -
for the "installing" flag to be set after WP has already loaded. In these
cases, WP_INSTALLING would be set for the remainder of the process, since
there's no way to change a constant once it's defined. This, in turn, polluted
later function calls that ought to have been outside the scope of site
creation, particularly the non-caching of option data. The problem was
particularly evident in the case of the automated tests, where WP_INSTALLING
was set the first time a site was created, and remained set for the rest of the
suite.

The new wp_installing() function allows developers to fetch the current
installation status (when called without any arguments) or to set the
installation status (when called with a boolean true or false). Use of
the WP_INSTALLING constant is still supported; wp_installing() will default
to true if the constant is defined during the bootstrap.

Props boonebgorges, jeremyfelt.
See #31130.

File:
1 edited

Legend:

Unmodified
Added
Removed
  • trunk/src/wp-includes/functions.php

    r34793 r34828  
    12611261
    12621262/**
     1263 * Check or set whether WordPress is in "installation" mode.
     1264 *
     1265 * If the `WP_INSTALLING` constant is defined during the bootstrap, `wp_installing()` will default to `true`.
     1266 *
     1267 * @since 4.4.0
     1268 *
     1269 * @staticvar bool $installing
     1270 *
     1271 * @param bool $is_installing Optional. True to set WP into Installing mode, false to turn Installing mode off.
     1272 *                            Omit this parameter if you only want to fetch the current status.
     1273 * @return bool True if WP is installing, otherwise false. When a `$is_installing` is passed, the function will
     1274 *              report whether WP was in installing mode prior to the change to `$is_installing`.
     1275 */
     1276function wp_installing( $is_installing = null ) {
     1277    static $installing = null;
     1278
     1279    // Support for the `WP_INSTALLING` constant, defined before WP is loaded.
     1280    if ( is_null( $installing ) ) {
     1281        $installing = defined( 'WP_INSTALLING' ) && WP_INSTALLING;
     1282    }
     1283
     1284    if ( ! is_null( $is_installing ) ) {
     1285        $old_installing = $installing;
     1286        $installing = $is_installing;
     1287        return (bool) $old_installing;
     1288    }
     1289
     1290    return (bool) $installing;
     1291}
     1292
     1293/**
    12631294 * Test whether blog is already installed.
    12641295 *
     
    12861317
    12871318    $suppress = $wpdb->suppress_errors();
    1288     if ( ! defined( 'WP_INSTALLING' ) ) {
     1319    if ( ! wp_installing() ) {
    12891320        $alloptions = wp_load_alloptions();
    12901321    }
     
    33383369
    33393370    // If installing or in the admin, provide the verbose message.
    3340     if ( defined('WP_INSTALLING') || defined('WP_ADMIN') )
     3371    if ( wp_installing() || defined( 'WP_ADMIN' ) )
    33413372        wp_die($wpdb->error);
    33423373
Note: See TracChangeset for help on using the changeset viewer.