Skip to content

HTTPS clone URL

Subversion checkout URL

You can clone with HTTPS or Subversion.

Download ZIP
Newer
Older
100644 445 lines (380 sloc) 13.472 kb
0bc8613 b2config.php replaced with wp-config.sample.php
mikelittle authored
1 <?php
75dc778 phpdoc for wp-settings.php. Fixes #5211 props darkdragon.
westi authored
2 /**
3 * Used to setup and fix common variables and include
4 * the WordPress procedural and class library.
5 *
479fc2e phpdoc tuneup from darkdragon. see #5611
ryan authored
6 * You should not have to change this file and allows
7 * for some configuration in wp-config.php.
75dc778 phpdoc for wp-settings.php. Fixes #5211 props darkdragon.
westi authored
8 *
9 * @package WordPress
10 */
11
12 /**
479fc2e phpdoc tuneup from darkdragon. see #5611
ryan authored
13 * wp_unregister_GLOBALS() - Turn register globals off
75dc778 phpdoc for wp-settings.php. Fixes #5211 props darkdragon.
westi authored
14 *
15 * @access private
479fc2e phpdoc tuneup from darkdragon. see #5611
ryan authored
16 * @since 2.1.0
75dc778 phpdoc for wp-settings.php. Fixes #5211 props darkdragon.
westi authored
17 * @return null Will return null if register_globals PHP directive was disabled
18 */
d4f95b7 Accidental commit. Props Nazgul. fixes #4437
rob1n authored
19 function wp_unregister_GLOBALS() {
20 if ( !ini_get('register_globals') )
21 return;
dce5220 Typos and more secure unsetting. Hat tip: Stefen Esser
matt authored
22
d4f95b7 Accidental commit. Props Nazgul. fixes #4437
rob1n authored
23 if ( isset($_REQUEST['GLOBALS']) )
24 die('GLOBALS overwrite attempt detected');
25
26 // Variables that shouldn't be unset
27 $noUnset = array('GLOBALS', '_GET', '_POST', '_COOKIE', '_REQUEST', '_SERVER', '_ENV', '_FILES', 'table_prefix');
28
29 $input = array_merge($_GET, $_POST, $_COOKIE, $_SERVER, $_ENV, $_FILES, isset($_SESSION) && is_array($_SESSION) ? $_SESSION : array());
321c310 Remove trailing whitespace
ryan authored
30 foreach ( $input as $k => $v )
d4f95b7 Accidental commit. Props Nazgul. fixes #4437
rob1n authored
31 if ( !in_array($k, $noUnset) && isset($GLOBALS[$k]) ) {
9323d39 Zend hash del key or index fix. PRops MarkJaquith.
ryan authored
32 $GLOBALS[$k] = NULL;
d4f95b7 Accidental commit. Props Nazgul. fixes #4437
rob1n authored
33 unset($GLOBALS[$k]);
9323d39 Zend hash del key or index fix. PRops MarkJaquith.
ryan authored
34 }
2919fe2 That last thing didn't work at all.
matt authored
35 }
877e6a7 Turn register globals off. Hat tip: Christian Schmidt
matt authored
36
321c310 Remove trailing whitespace
ryan authored
37 wp_unregister_GLOBALS();
d4f95b7 Accidental commit. Props Nazgul. fixes #4437
rob1n authored
38
479fc2e phpdoc tuneup from darkdragon. see #5611
ryan authored
39 unset( $wp_filter, $cache_lastcommentmodified, $cache_lastpostdate );
376ec4d Tweak
matt authored
40
75dc778 phpdoc for wp-settings.php. Fixes #5211 props darkdragon.
westi authored
41 /**
42 * The $blog_id global, which you can change in the config allows you to create a simple
43 * multiple blog installation using just one WordPress and changing $blog_id around.
44 *
45 * @global int $blog_id
479fc2e phpdoc tuneup from darkdragon. see #5611
ryan authored
46 * @since 2.0.0
75dc778 phpdoc for wp-settings.php. Fixes #5211 props darkdragon.
westi authored
47 */
d4f95b7 Accidental commit. Props Nazgul. fixes #4437
rob1n authored
48 if ( ! isset($blog_id) )
85723b8 Object caching, round one.
ryan authored
49 $blog_id = 1;
50
a18a23e Work around IIS' lack of REQUEST_URI
saxmatt authored
51 // Fix for IIS, which doesn't set REQUEST_URI
40a7d9d Fixes #1488
matt authored
52 if ( empty( $_SERVER['REQUEST_URI'] ) ) {
dd202ce Death to trailing tabs. Props Mark J. fixes #2405
ryan authored
53
54639a3 Set REQUEST_URI for IIS in more situations. props snakefoot. fixes #35...
markjaquith authored
54 // IIS Mod-Rewrite
55 if (isset($_SERVER['HTTP_X_ORIGINAL_URL'])) {
56 $_SERVER['REQUEST_URI'] = $_SERVER['HTTP_X_ORIGINAL_URL'];
57 }
58 // IIS Isapi_Rewrite
59 else if (isset($_SERVER['HTTP_X_REWRITE_URL'])) {
60 $_SERVER['REQUEST_URI'] = $_SERVER['HTTP_X_REWRITE_URL'];
61 }
c698c97 IIS REQUEST_URI-setting fixes from snakefoot. fixes #5160 for trunk
markjaquith authored
62 else
63 {
64 // Some IIS + PHP configurations puts the script-name in the path-info (No need to append it twice)
65 if ( $_SERVER['PATH_INFO'] == $_SERVER['SCRIPT_NAME'] )
6a1c63e Correctly set REQUEST_URI for IIS setups that put that info into SCRIPT_...
markjaquith authored
66 $_SERVER['REQUEST_URI'] = $_SERVER['PATH_INFO'];
54639a3 Set REQUEST_URI for IIS in more situations. props snakefoot. fixes #35...
markjaquith authored
67 else
68 $_SERVER['REQUEST_URI'] = $_SERVER['SCRIPT_NAME'] . $_SERVER['PATH_INFO'];
87c4f3a Strip lines that contain only whitespace down to newlines.
ryan authored
69
54639a3 Set REQUEST_URI for IIS in more situations. props snakefoot. fixes #35...
markjaquith authored
70 // Append the query string if it exists and isn't null
71 if (isset($_SERVER['QUERY_STRING']) && !empty($_SERVER['QUERY_STRING'])) {
72 $_SERVER['REQUEST_URI'] .= '?' . $_SERVER['QUERY_STRING'];
73 }
720316d Do not touch REQUEST_URI if it is already set by the server.
rboren authored
74 }
12b4069 Fix REQUEST_URI construction for IIS. Bug 389. Patch from Dennis Willi...
rboren authored
75 }
a18a23e Work around IIS' lack of REQUEST_URI
saxmatt authored
76
c50e7da Fixes #1591 (again)
matt authored
77 // Fix for PHP as CGI hosts that set SCRIPT_FILENAME to something ending in php.cgi for all requests
c1ed565 Check if SCRIPT_FILENAME is set to avoid warnings. fixes #2227
ryan authored
78 if ( isset($_SERVER['SCRIPT_FILENAME']) && ( strpos($_SERVER['SCRIPT_FILENAME'], 'php.cgi') == strlen($_SERVER['SCRIPT_FILENAME']) - 7 ) )
c50e7da Fixes #1591 (again)
matt authored
79 $_SERVER['SCRIPT_FILENAME'] = $_SERVER['PATH_TRANSLATED'];
80
885ee8f This should fix permalinks, but may break the PHP as CGI funkiness again
matt authored
81 // Fix for Dreamhost and other PHP as CGI hosts
3320dd1 Use strpos instead of strstr where ever possible, for speed. Props rob1...
markjaquith authored
82 if (strpos($_SERVER['SCRIPT_NAME'], 'php.cgi') !== false)
c50e7da Fixes #1591 (again)
matt authored
83 unset($_SERVER['PATH_INFO']);
84
38f4fca Move PHP_SELF setup to wp-settings.php. #2153
ryan authored
85 // Fix empty PHP_SELF
86 $PHP_SELF = $_SERVER['PHP_SELF'];
87 if ( empty($PHP_SELF) )
88 $_SERVER['PHP_SELF'] = $PHP_SELF = preg_replace("/(\?.*)?$/",'',$_SERVER["REQUEST_URI"]);
885ee8f This should fix permalinks, but may break the PHP as CGI funkiness again
matt authored
89
629dde8 Actually check for PHP 4.2. Props nbachiyski. fixes #4336
rob1n authored
90 if ( version_compare( '4.2', phpversion(), '>' ) ) {
91 die( 'Your server is running PHP version ' . phpversion() . ' but WordPress requires at least 4.2.' );
92 }
da4a0d9 Fix for empty plugin strings, class include moved for timing.
saxmatt authored
93
172bfb8 Don't enforce presence of mysql system if custom DB class is being used....
ryan authored
94 if ( !extension_loaded('mysql') && !file_exists(ABSPATH . 'wp-content/db.php') )
fa1ec4e Don't wp_die() before functions.php is loaded.
ryan authored
95 die( 'Your PHP installation appears to be missing the MySQL which is required for WordPress.' );
0d040b3 Sanity check mysql.
saxmatt authored
96
75dc778 phpdoc for wp-settings.php. Fixes #5211 props darkdragon.
westi authored
97 /**
479fc2e phpdoc tuneup from darkdragon. see #5611
ryan authored
98 * timer_start() - PHP 4 standard microtime start capture
75dc778 phpdoc for wp-settings.php. Fixes #5211 props darkdragon.
westi authored
99 *
100 * @access private
479fc2e phpdoc tuneup from darkdragon. see #5611
ryan authored
101 * @since 0.71
75dc778 phpdoc for wp-settings.php. Fixes #5211 props darkdragon.
westi authored
102 * @global int $timestart Seconds and Microseconds added together from when function is called
103 * @return bool Always returns true
104 */
551e52f Code cleanup and some fixes from the WP Japan folks.
saxmatt authored
105 function timer_start() {
106 global $timestart;
107 $mtime = explode(' ', microtime() );
108 $mtime = $mtime[1] + $mtime[0];
109 $timestart = $mtime;
110 return true;
111 }
0f7bb42 timer_stop() wanted to be near timer_start().
ryan authored
112
75dc778 phpdoc for wp-settings.php. Fixes #5211 props darkdragon.
westi authored
113 /**
479fc2e phpdoc tuneup from darkdragon. see #5611
ryan authored
114 * timer_stop() - Return and/or display the time from the page start to when function is called.
75dc778 phpdoc for wp-settings.php. Fixes #5211 props darkdragon.
westi authored
115 *
116 * You can get the results and print them by doing:
117 * <code>
118 * $nTimePageTookToExecute = timer_stop();
119 * echo $nTimePageTookToExecute;
120 * </code>
121 *
122 * Or instead, you can do:
123 * <code>
124 * timer_stop(1);
125 * </code>
126 * which will do what the above does. If you need the result, you can assign it to a variable, but
127 * most cases, you only need to echo it.
128 *
6950e28 Fix @since for timer_start and timer_stop. See #5211.
westi authored
129 * @since 0.71
75dc778 phpdoc for wp-settings.php. Fixes #5211 props darkdragon.
westi authored
130 * @global int $timestart Seconds and Microseconds added together from when timer_start() is called
131 * @global int $timeend Seconds and Microseconds added together from when function is called
132 *
133 * @param int $display Use '0' or null to not echo anything and 1 to echo the total time
134 * @param int $precision The amount of digits from the right of the decimal to display. Default is 3.
135 * @return float The "second.microsecond" finished time calculation
136 */
0f7bb42 timer_stop() wanted to be near timer_start().
ryan authored
137 function timer_stop($display = 0, $precision = 3) { //if called like timer_stop(1), will echo $timetotal
138 global $timestart, $timeend;
139 $mtime = microtime();
140 $mtime = explode(' ',$mtime);
141 $mtime = $mtime[1] + $mtime[0];
142 $timeend = $mtime;
143 $timetotal = $timeend-$timestart;
4f6b825 Make sure number_format_i18n() is available before calling it in timer_s...
markjaquith authored
144 $r = ( function_exists('number_format_i18n') ) ? number_format_i18n($timetotal, $precision) : number_format($timetotal, $precision);
0f7bb42 timer_stop() wanted to be near timer_start().
ryan authored
145 if ( $display )
a9d23d4 allow timer_stop() to use number_format() when returning. Props mdawaff...
markjaquith authored
146 echo $r;
147 return $r;
0f7bb42 timer_stop() wanted to be near timer_start().
ryan authored
148 }
551e52f Code cleanup and some fixes from the WP Japan folks.
saxmatt authored
149 timer_start();
da4a0d9 Fix for empty plugin strings, class include moved for timing.
saxmatt authored
150
f3e26c6 s/WPDEBUG/WP_DEBUG/g Fixes #5033
westi authored
151 // Add define('WP_DEBUG',true); to wp-config.php to enable display of notices during development.
152 if (defined('WP_DEBUG') and WP_DEBUG == true) {
479fc2e phpdoc tuneup from darkdragon. see #5611
ryan authored
153 error_reporting(E_ALL);
2bcddfc Enable developers to turn on notices from wp-config.php. Relates #3155. ...
westi authored
154 } else {
479fc2e phpdoc tuneup from darkdragon. see #5611
ryan authored
155 error_reporting(E_ALL ^ E_NOTICE ^ E_USER_NOTICE);
2bcddfc Enable developers to turn on notices from wp-config.php. Relates #3155. ...
westi authored
156 }
9b09572 Turn down error reporting.
saxmatt authored
157
70a449d Allow for plugins to kick in before everything if define in wp-config
saxmatt authored
158 // For an advanced caching plugin to use, static because you would only want one
159 if ( defined('WP_CACHE') )
a45c3a3 Don't fail when the user don't set WP-Cache up correctly. Props Denis de...
rob1n authored
160 @include ABSPATH . 'wp-content/advanced-cache.php';
70a449d Allow for plugins to kick in before everything if define in wp-config
saxmatt authored
161
75dc778 phpdoc for wp-settings.php. Fixes #5211 props darkdragon.
westi authored
162 /**
163 * Stores the location of the WordPress directory of functions, classes, and core content.
164 *
479fc2e phpdoc tuneup from darkdragon. see #5611
ryan authored
165 * @since 1.0.0
75dc778 phpdoc for wp-settings.php. Fixes #5211 props darkdragon.
westi authored
166 */
edc7d7c Installation cleanup.
saxmatt authored
167 define('WPINC', 'wp-includes');
54d7ccb make /languages/ directory default to /wp-content/languages/ with fallba...
markjaquith authored
168
169 if ( !defined('LANGDIR') ) {
75dc778 phpdoc for wp-settings.php. Fixes #5211 props darkdragon.
westi authored
170 /**
171 * Stores the location of the language directory. First looks for language folder in wp-content
172 * and uses that folder if it exists. Or it uses the "languages" folder in WPINC.
173 *
479fc2e phpdoc tuneup from darkdragon. see #5611
ryan authored
174 * @since 2.1.0
75dc778 phpdoc for wp-settings.php. Fixes #5211 props darkdragon.
westi authored
175 */
54d7ccb make /languages/ directory default to /wp-content/languages/ with fallba...
markjaquith authored
176 if ( file_exists(ABSPATH . 'wp-content/languages') && @is_dir(ABSPATH . 'wp-content/languages') )
177 define('LANGDIR', 'wp-content/languages'); // no leading slash, no trailing slash
178 else
179 define('LANGDIR', WPINC . '/languages'); // no leading slash, no trailing slash
180 }
181
75dc778 phpdoc for wp-settings.php. Fixes #5211 props darkdragon.
westi authored
182 /**
183 * Allows for the plugins directory to be moved from the default location.
184 *
479fc2e phpdoc tuneup from darkdragon. see #5611
ryan authored
185 * This isn't used everywhere. Constant is not used in plugin_basename()
186 * which might cause conflicts with changing this.
187 *
75dc778 phpdoc for wp-settings.php. Fixes #5211 props darkdragon.
westi authored
188 * @since 2.1
189 */
7a03234 Turn hard-coded paths to defines. Pull gettext includes int wp-settings....
ryan authored
190 if ( !defined('PLUGINDIR') )
191 define('PLUGINDIR', 'wp-content/plugins'); // no leading slash, no trailing slash
b36471d Use wp_die() for WPDB bails. Send 500 response and no-cache headers so ...
markjaquith authored
192
193 require (ABSPATH . WPINC . '/compat.php');
194 require (ABSPATH . WPINC . '/functions.php');
1d0bf72 AJAX for link category add and delete. Props mdawaffe. fixes #5291
ryan authored
195 require (ABSPATH . WPINC . '/classes.php');
b36471d Use wp_die() for WPDB bails. Send 500 response and no-cache headers so ...
markjaquith authored
196
61f8b8f Move database class loading to a shared function to ensure all of WordPr...
westi authored
197 require_wp_db();
e8dc869 Custom DB error page. fixes #5500 for 2.4
ryan authored
198
199 if ( !empty($wpdb->error) )
200 dead_db();
201
1d0bf72 AJAX for link category add and delete. Props mdawaffe. fixes #5291
ryan authored
202 $prefix = $wpdb->set_prefix($table_prefix);
71a2674 Use $wpdb->prefix when defining table names
markjaquith authored
203
1d0bf72 AJAX for link category add and delete. Props mdawaffe. fixes #5291
ryan authored
204 if ( is_wp_error($prefix) )
42def10 Use ' not " so we don't expand. Fixes #5546 props takayukister.
westi authored
205 wp_die('<strong>ERROR</strong>: <code>$table_prefix</code> in <code>wp-config.php</code> can only contain numbers, letters, and underscores.');
cde68f9 Exit gracefully with a warning if the table_prefix uses disallowed chars...
markjaquith authored
206
85723b8 Object caching, round one.
ryan authored
207 if ( file_exists(ABSPATH . 'wp-content/object-cache.php') )
b3d3d73 Require once only. Props masquerade. fixes #4192
rob1n authored
208 require_once (ABSPATH . 'wp-content/object-cache.php');
85723b8 Object caching, round one.
ryan authored
209 else
b3d3d73 Require once only. Props masquerade. fixes #4192
rob1n authored
210 require_once (ABSPATH . WPINC . '/cache.php');
85723b8 Object caching, round one.
ryan authored
211
212 wp_cache_init();
213
6d7717e Move plugin API to plugin.php. #2525
ryan authored
214 require (ABSPATH . WPINC . '/plugin.php');
81e7d92 Some filter action and cleanup
saxmatt authored
215 require (ABSPATH . WPINC . '/default-filters.php');
acc5602 Always load gettext.
ryan authored
216 include_once(ABSPATH . WPINC . '/streams.php');
217 include_once(ABSPATH . WPINC . '/gettext.php');
62927ab Remove wp- prefix from wp-l10n.php
ryan authored
218 require_once (ABSPATH . WPINC . '/l10n.php');
1bd4057 Bug fixes
saxmatt authored
219
3320dd1 Use strpos instead of strstr where ever possible, for speed. Props rob1...
markjaquith authored
220 if ( !is_blog_installed() && (strpos($_SERVER['PHP_SELF'], 'install.php') === false && !defined('WP_INSTALLING')) ) {
25abcd1 More streamlined install process. Obeys WP_SITEURL if defined. fixes #4...
markjaquith authored
221 if ( defined('WP_SITEURL') )
321c310 Remove trailing whitespace
ryan authored
222 $link = WP_SITEURL . '/wp-admin/install.php';
25abcd1 More streamlined install process. Obeys WP_SITEURL if defined. fixes #4...
markjaquith authored
223 elseif (strpos($_SERVER['PHP_SELF'], 'wp-admin') !== false)
224 $link = preg_replace('|/wp-admin/?.*?$|', '/', $_SERVER['PHP_SELF']) . 'wp-admin/install.php';
ca2815f If we're already in wp-admin don't recursive link
saxmatt authored
225 else
25abcd1 More streamlined install process. Obeys WP_SITEURL if defined. fixes #4...
markjaquith authored
226 $link = preg_replace('|/[^/]+?$|', '/', $_SERVER['PHP_SELF']) . 'wp-admin/install.php';
227 require_once(ABSPATH . WPINC . '/kses.php');
228 require_once(ABSPATH . WPINC . '/pluggable.php');
229 wp_redirect($link);
230 die(); // have to die here ~ Mark
ca2815f If we're already in wp-admin don't recursive link
saxmatt authored
231 }
1bd4057 Bug fixes
saxmatt authored
232
c93efa8 Include file renames. #2525
ryan authored
233 require (ABSPATH . WPINC . '/formatting.php');
a6ade4a Role/capability system. Round one. Props: Owen Winkler
ryan authored
234 require (ABSPATH . WPINC . '/capabilities.php');
9303053 Move WP_Query and its wrapper functions to query.php. #2525
ryan authored
235 require (ABSPATH . WPINC . '/query.php');
40b2e61 Move theme functions to theme.php. #2525
ryan authored
236 require (ABSPATH . WPINC . '/theme.php');
c56e62f Move user functions to user.php. Relocate more post functions to post.p...
ryan authored
237 require (ABSPATH . WPINC . '/user.php');
c93efa8 Include file renames. #2525
ryan authored
238 require (ABSPATH . WPINC . '/general-template.php');
239 require (ABSPATH . WPINC . '/link-template.php');
c56e62f Move user functions to user.php. Relocate more post functions to post.p...
ryan authored
240 require (ABSPATH . WPINC . '/author-template.php');
3c8ed76 Reworg post/page/attachment functions. #2525
ryan authored
241 require (ABSPATH . WPINC . '/post.php');
242 require (ABSPATH . WPINC . '/post-template.php');
0f5dc0f Reorg category functions. #2525
ryan authored
243 require (ABSPATH . WPINC . '/category.php');
244 require (ABSPATH . WPINC . '/category-template.php');
6027cfa Reorg comment functions. #2525
ryan authored
245 require (ABSPATH . WPINC . '/comment.php');
246 require (ABSPATH . WPINC . '/comment-template.php');
6970a75 Rewrite API additions and improvements from David House. #2433
ryan authored
247 require (ABSPATH . WPINC . '/rewrite.php');
c93efa8 Include file renames. #2525
ryan authored
248 require (ABSPATH . WPINC . '/feed.php');
19ea5fb Reorg bookmark functions. #2525
ryan authored
249 require (ABSPATH . WPINC . '/bookmark.php');
250 require (ABSPATH . WPINC . '/bookmark-template.php');
9dc65ab Cleaning up some includes.
saxmatt authored
251 require (ABSPATH . WPINC . '/kses.php');
fb1e531 Cron improvements from masquerade. #2425
ryan authored
252 require (ABSPATH . WPINC . '/cron.php');
2520d8e Include cleanups
saxmatt authored
253 require (ABSPATH . WPINC . '/version.php');
ca92bb4 Move deprecated functions to deprecated.php. #2520
ryan authored
254 require (ABSPATH . WPINC . '/deprecated.php');
4d49e98 Script loader from mdawaffe. #2701
ryan authored
255 require (ABSPATH . WPINC . '/script-loader.php');
634a33c Very rough initial commit of taxonomy for everyone's hacking pleasure. ...
ryan authored
256 require (ABSPATH . WPINC . '/taxonomy.php');
7c2dbb9 First pass at upgrade notification for core, see #1476. Also includes so...
matt authored
257 require (ABSPATH . WPINC . '/update.php');
6fc031d Canonical URLs, first swing. Props to Scott Yang, Ryan and Matt. see #...
markjaquith authored
258 require (ABSPATH . WPINC . '/canonical.php');
da4a0d9 Fix for empty plugin strings, class include moved for timing.
saxmatt authored
259
3320dd1 Use strpos instead of strstr where ever possible, for speed. Props rob1...
markjaquith authored
260 if (strpos($_SERVER['PHP_SELF'], 'install.php') === false) {
75dc778 phpdoc for wp-settings.php. Fixes #5211 props darkdragon.
westi authored
261 // Used to guarantee unique hash cookies
262 $cookiehash = md5(get_option('siteurl'));
263 /**
264 * Used to guarantee unique hash cookies
265 * @since 1.5
266 */
321c310 Remove trailing whitespace
ryan authored
267 define('COOKIEHASH', $cookiehash);
3320dd1 Use strpos instead of strstr where ever possible, for speed. Props rob1...
markjaquith authored
268 }
5c97b54 Smilie fix from Jaykul, changed fool's siteurl fix to use faster preg_re...
saxmatt authored
269
75dc778 phpdoc for wp-settings.php. Fixes #5211 props darkdragon.
westi authored
270 /**
271 * It is possible to define this in wp-config.php
479fc2e phpdoc tuneup from darkdragon. see #5611
ryan authored
272 * @since 2.0.0
75dc778 phpdoc for wp-settings.php. Fixes #5211 props darkdragon.
westi authored
273 */
41afea2 Let advanced users override cookies.
matt authored
274 if ( !defined('USER_COOKIE') )
29ef8b6 New secure cookie protocol. see #5367
ryan authored
275 define('USER_COOKIE', 'wordpressuser_' . COOKIEHASH);
75dc778 phpdoc for wp-settings.php. Fixes #5211 props darkdragon.
westi authored
276
277 /**
278 * It is possible to define this in wp-config.php
479fc2e phpdoc tuneup from darkdragon. see #5611
ryan authored
279 * @since 2.0.0
75dc778 phpdoc for wp-settings.php. Fixes #5211 props darkdragon.
westi authored
280 */
41afea2 Let advanced users override cookies.
matt authored
281 if ( !defined('PASS_COOKIE') )
29ef8b6 New secure cookie protocol. see #5367
ryan authored
282 define('PASS_COOKIE', 'wordpresspass_' . COOKIEHASH);
75dc778 phpdoc for wp-settings.php. Fixes #5211 props darkdragon.
westi authored
283
284 /**
285 * It is possible to define this in wp-config.php
479fc2e phpdoc tuneup from darkdragon. see #5611
ryan authored
286 * @since 2.5
75dc778 phpdoc for wp-settings.php. Fixes #5211 props darkdragon.
westi authored
287 */
29ef8b6 New secure cookie protocol. see #5367
ryan authored
288 if ( !defined('AUTH_COOKIE') )
289 define('AUTH_COOKIE', 'wordpress_' . COOKIEHASH);
75dc778 phpdoc for wp-settings.php. Fixes #5211 props darkdragon.
westi authored
290
291 /**
292 * It is possible to define this in wp-config.php
479fc2e phpdoc tuneup from darkdragon. see #5611
ryan authored
293 * @since 2.3.0
75dc778 phpdoc for wp-settings.php. Fixes #5211 props darkdragon.
westi authored
294 */
2662be2 Inform the user when cookies are disabled and login fails. Fixed #2039 p...
westi authored
295 if ( !defined('TEST_COOKIE') )
296 define('TEST_COOKIE', 'wordpress_test_cookie');
75dc778 phpdoc for wp-settings.php. Fixes #5211 props darkdragon.
westi authored
297
298 /**
299 * It is possible to define this in wp-config.php
479fc2e phpdoc tuneup from darkdragon. see #5611
ryan authored
300 * @since 1.2.0
75dc778 phpdoc for wp-settings.php. Fixes #5211 props darkdragon.
westi authored
301 */
41afea2 Let advanced users override cookies.
matt authored
302 if ( !defined('COOKIEPATH') )
849a0d2 Use get_option instead of get_settings. Just 'cause.
ryan authored
303 define('COOKIEPATH', preg_replace('|https?://[^/]+|i', '', get_option('home') . '/' ) );
75dc778 phpdoc for wp-settings.php. Fixes #5211 props darkdragon.
westi authored
304
305 /**
306 * It is possible to define this in wp-config.php
479fc2e phpdoc tuneup from darkdragon. see #5611
ryan authored
307 * @since 1.5.0
75dc778 phpdoc for wp-settings.php. Fixes #5211 props darkdragon.
westi authored
308 */
41afea2 Let advanced users override cookies.
matt authored
309 if ( !defined('SITECOOKIEPATH') )
849a0d2 Use get_option instead of get_settings. Just 'cause.
ryan authored
310 define('SITECOOKIEPATH', preg_replace('|https?://[^/]+|i', '', get_option('siteurl') . '/' ) );
75dc778 phpdoc for wp-settings.php. Fixes #5211 props darkdragon.
westi authored
311
312 /**
313 * It is possible to define this in wp-config.php
479fc2e phpdoc tuneup from darkdragon. see #5611
ryan authored
314 * @since 2.0.0
75dc778 phpdoc for wp-settings.php. Fixes #5211 props darkdragon.
westi authored
315 */
41afea2 Let advanced users override cookies.
matt authored
316 if ( !defined('COOKIE_DOMAIN') )
317 define('COOKIE_DOMAIN', false);
318
9dc65ab Cleaning up some includes.
saxmatt authored
319 require (ABSPATH . WPINC . '/vars.php');
edc7d7c Installation cleanup.
saxmatt authored
320
c26991b Move hack file include.
saxmatt authored
321 // Check for hacks file if the option is enabled
849a0d2 Use get_option instead of get_settings. Just 'cause.
ryan authored
322 if (get_option('hack_file')) {
764f50b ABSPATH already has a trailing slash. Props Nazgul. fixes #4607
markjaquith authored
323 if (file_exists(ABSPATH . 'my-hacks.php'))
324 require(ABSPATH . 'my-hacks.php');
c26991b Move hack file include.
saxmatt authored
325 }
326
849a0d2 Use get_option instead of get_settings. Just 'cause.
ryan authored
327 if ( get_option('active_plugins') ) {
328 $current_plugins = get_option('active_plugins');
11f5bb3 Add a precautionary is_array() check around the plugin loading loop. ht...
ryan authored
329 if ( is_array($current_plugins) ) {
330 foreach ($current_plugins as $plugin) {
8311272 Use PLUGINDIR. Props z720 and Nazgul. fixes #3909
ryan authored
331 if ('' != $plugin && file_exists(ABSPATH . PLUGINDIR . '/' . $plugin))
332 include_once(ABSPATH . PLUGINDIR . '/' . $plugin);
11f5bb3 Add a precautionary is_array() check around the plugin loading loop. ht...
ryan authored
333 }
e733249 Functional plugin implementation.
saxmatt authored
334 }
335 }
1127059 shutdown action hook.
saxmatt authored
336
c93efa8 Include file renames. #2525
ryan authored
337 require (ABSPATH . WPINC . '/pluggable.php');
08b02d9 Move plugin replacebale functions to pluggable-functions.php. http://mo...
ryan authored
338
70a449d Allow for plugins to kick in before everything if define in wp-config
saxmatt authored
339 if ( defined('WP_CACHE') && function_exists('wp_cache_postload') )
340 wp_cache_postload();
341
342 do_action('plugins_loaded');
343
91efba1 Use wpdb->escape instead of addslashes to prepare DB bound data.
ryan authored
344 // If already slashed, strip.
345 if ( get_magic_quotes_gpc() ) {
6cbb6fe Stripslashes doesn't work on arrays. Add stripslashes_deep(). Props: ...
ryan authored
346 $_GET = stripslashes_deep($_GET );
347 $_POST = stripslashes_deep($_POST );
348 $_COOKIE = stripslashes_deep($_COOKIE);
65bbec7 Comments refactoring and cleanup
saxmatt authored
349 }
350
91efba1 Use wpdb->escape instead of addslashes to prepare DB bound data.
ryan authored
351 // Escape with wpdb.
352 $_GET = add_magic_quotes($_GET );
353 $_POST = add_magic_quotes($_POST );
354 $_COOKIE = add_magic_quotes($_COOKIE);
355 $_SERVER = add_magic_quotes($_SERVER);
356
1034767 wp_get_current_commenter()
ryan authored
357 do_action('sanitize_comment_cookies');
358
75dc778 phpdoc for wp-settings.php. Fixes #5211 props darkdragon.
westi authored
359 /**
360 * WordPress Query object
361 * @global object $wp_the_query
479fc2e phpdoc tuneup from darkdragon. see #5611
ryan authored
362 * @since 2.0.0
75dc778 phpdoc for wp-settings.php. Fixes #5211 props darkdragon.
westi authored
363 */
22bee1c Preserve the original query object as wp_the_query so that it's not stom...
ryan authored
364 $wp_the_query =& new WP_Query();
75dc778 phpdoc for wp-settings.php. Fixes #5211 props darkdragon.
westi authored
365
366 /**
367 * Holds the reference to @see $wp_the_query
368 * Use this global for WordPress queries
369 * @global object $wp_query
479fc2e phpdoc tuneup from darkdragon. see #5611
ryan authored
370 * @since 1.5.0
75dc778 phpdoc for wp-settings.php. Fixes #5211 props darkdragon.
westi authored
371 */
22bee1c Preserve the original query object as wp_the_query so that it's not stom...
ryan authored
372 $wp_query =& $wp_the_query;
75dc778 phpdoc for wp-settings.php. Fixes #5211 props darkdragon.
westi authored
373
374 /**
375 * Holds the WordPress Rewrite object for creating pretty URLs
376 * @global object $wp_rewrite
479fc2e phpdoc tuneup from darkdragon. see #5611
ryan authored
377 * @since 1.5.0
75dc778 phpdoc for wp-settings.php. Fixes #5211 props darkdragon.
westi authored
378 */
22bee1c Preserve the original query object as wp_the_query so that it's not stom...
ryan authored
379 $wp_rewrite =& new WP_Rewrite();
75dc778 phpdoc for wp-settings.php. Fixes #5211 props darkdragon.
westi authored
380
381 /**
382 * WordPress Object
383 * @global object $wp
479fc2e phpdoc tuneup from darkdragon. see #5611
ryan authored
384 * @since 2.0.0
75dc778 phpdoc for wp-settings.php. Fixes #5211 props darkdragon.
westi authored
385 */
22bee1c Preserve the original query object as wp_the_query so that it's not stom...
ryan authored
386 $wp =& new WP();
1baf503 Break blog header up into functional chunks. Stick it all in a WP class...
ryan authored
387
75dc778 phpdoc for wp-settings.php. Fixes #5211 props darkdragon.
westi authored
388
389 /**
390 * Web Path to the current active template directory
391 * @since 1.5
392 */
98aa7f5 Rearrange load order. Init classes before loading the text domain and s...
ryan authored
393 define('TEMPLATEPATH', get_template_directory());
75dc778 phpdoc for wp-settings.php. Fixes #5211 props darkdragon.
westi authored
394
395 /**
396 * Web Path to the current active template stylesheet directory
397 * @since 2.1
398 */
b55b6aa Allow stylesheet only themes to provide functions.php. Props skeltoac. ...
ryan authored
399 define('STYLESHEETPATH', get_stylesheet_directory());
98aa7f5 Rearrange load order. Init classes before loading the text domain and s...
ryan authored
400
401 // Load the default text localization domain.
402 load_default_textdomain();
403
479fc2e phpdoc tuneup from darkdragon. see #5611
ryan authored
404 /**
405 * The locale of the blog
406 * @since 1.5.0
407 */
3e26469 Load locale specific php code in global context. fixes #3488
ryan authored
408 $locale = get_locale();
409 $locale_file = ABSPATH . LANGDIR . "/$locale.php";
410 if ( is_readable($locale_file) )
411 require_once($locale_file);
412
98aa7f5 Rearrange load order. Init classes before loading the text domain and s...
ryan authored
413 // Pull in locale data after loading text domain.
414 require_once(ABSPATH . WPINC . '/locale.php');
415
75dc778 phpdoc for wp-settings.php. Fixes #5211 props darkdragon.
westi authored
416 /**
417 * WordPress Locale object for loading locale domain date and various strings.
418 * @global object $wp_locale
479fc2e phpdoc tuneup from darkdragon. see #5611
ryan authored
419 * @since 2.1.0
75dc778 phpdoc for wp-settings.php. Fixes #5211 props darkdragon.
westi authored
420 */
92421de Ref more singletons.
ryan authored
421 $wp_locale =& new WP_Locale();
3d2347a WP_Locale. Props Sewar. fixes #2568
ryan authored
422
c369310 Better support for theme plugins. add_theme_page() and active theme fun...
ryan authored
423 // Load functions for active theme.
b55b6aa Allow stylesheet only themes to provide functions.php. Props skeltoac. ...
ryan authored
424 if ( TEMPLATEPATH !== STYLESHEETPATH && file_exists(STYLESHEETPATH . '/functions.php') )
425 include(STYLESHEETPATH . '/functions.php');
426 if ( file_exists(TEMPLATEPATH . '/functions.php') )
427 include(TEMPLATEPATH . '/functions.php');
c369310 Better support for theme plugins. add_theme_page() and active theme fun...
ryan authored
428
75dc778 phpdoc for wp-settings.php. Fixes #5211 props darkdragon.
westi authored
429 /**
479fc2e phpdoc tuneup from darkdragon. see #5611
ryan authored
430 * shutdown_action_hook() - Runs just before PHP shuts down execution.
75dc778 phpdoc for wp-settings.php. Fixes #5211 props darkdragon.
westi authored
431 *
432 * @access private
479fc2e phpdoc tuneup from darkdragon. see #5611
ryan authored
433 * @since 1.2
75dc778 phpdoc for wp-settings.php. Fixes #5211 props darkdragon.
westi authored
434 */
98aa7f5 Rearrange load order. Init classes before loading the text domain and s...
ryan authored
435 function shutdown_action_hook() {
436 do_action('shutdown');
84da5fc Save cache after the shutdown hook runs. fixes #2232
ryan authored
437 wp_cache_close();
98aa7f5 Rearrange load order. Init classes before loading the text domain and s...
ryan authored
438 }
439 register_shutdown_function('shutdown_action_hook');
440
1baf503 Break blog header up into functional chunks. Stick it all in a WP class...
ryan authored
441 // Everything is loaded and initialized.
9838608 Allow multiple args to be passed to apply_filters and do_action. Move s...
rboren authored
442 do_action('init');
06a0fc3 Formatting
matt authored
443
629dde8 Actually check for PHP 4.2. Props nbachiyski. fixes #4336
rob1n authored
444 ?>
Something went wrong with that request. Please try again.