2005-06-11 01:15:13 +02:00
|
|
|
<?php
|
2007-12-24 08:09:36 +01:00
|
|
|
/**
|
|
|
|
* Loads the correct template based on the visitor's url
|
|
|
|
* @package WordPress
|
|
|
|
*/
|
2010-02-20 13:58:25 +01:00
|
|
|
if ( defined('WP_USE_THEMES') && WP_USE_THEMES )
|
2013-10-06 20:41:09 +02:00
|
|
|
/**
|
|
|
|
* Fires before determining which template to load.
|
|
|
|
*
|
2013-10-30 15:39:10 +01:00
|
|
|
* @since 1.5.0
|
2013-10-06 20:41:09 +02:00
|
|
|
*/
|
|
|
|
do_action( 'template_redirect' );
|
2010-02-20 13:58:25 +01:00
|
|
|
|
2013-10-06 20:41:09 +02:00
|
|
|
/**
|
|
|
|
* Filter whether to allow 'HEAD' requests to generate content.
|
|
|
|
*
|
|
|
|
* Provides a significant performance bump by exiting before the page
|
|
|
|
* content loads for 'HEAD' requests. See #14348.
|
|
|
|
*
|
|
|
|
* @since 3.5.0
|
|
|
|
*
|
|
|
|
* @param bool $exit Whether to exit without generating any content for 'HEAD' requests. Default true.
|
|
|
|
*/
|
2012-10-31 22:39:23 +01:00
|
|
|
if ( 'HEAD' === $_SERVER['REQUEST_METHOD'] && apply_filters( 'exit_on_http_head', true ) )
|
2012-11-01 00:01:13 +01:00
|
|
|
exit();
|
2012-10-31 22:39:23 +01:00
|
|
|
|
2010-02-20 13:58:25 +01:00
|
|
|
// Process feeds and trackbacks even if not using themes.
|
|
|
|
if ( is_robots() ) :
|
2013-10-06 20:41:09 +02:00
|
|
|
/**
|
|
|
|
* Fired when the template loader determines a robots.txt request.
|
|
|
|
*
|
|
|
|
* @since 2.1.0
|
|
|
|
*/
|
|
|
|
do_action( 'do_robots' );
|
2010-02-20 13:58:25 +01:00
|
|
|
return;
|
|
|
|
elseif ( is_feed() ) :
|
|
|
|
do_feed();
|
|
|
|
return;
|
|
|
|
elseif ( is_trackback() ) :
|
2010-02-21 01:03:42 +01:00
|
|
|
include( ABSPATH . 'wp-trackback.php' );
|
2010-02-20 13:58:25 +01:00
|
|
|
return;
|
Embeds: Add oEmbed provider support.
For the past 6 years, WordPress has operated as an oEmbed consumer, allowing users to easily embed content from other sites. By adding oEmbed provider support, this allows any oEmbed consumer to embed posts from WordPress sites.
In addition to creating an oEmbed provider, WordPress' oEmbed consumer code has been enhanced to work with any site that provides oEmbed data (as long as it matches some strict security rules), and provides a preview from within the post editor.
For security, embeds appear within a sandboxed iframe - the iframe content is a template that can be styled or replaced entirely by the theme on the provider site.
Props swissspidy, pento, melchoyce, netweb, pfefferle, johnbillion, extendwings, davidbinda, danielbachhuber, SergeyBiryukov, afercia
Fixes #32522.
Built from https://develop.svn.wordpress.org/trunk@34903
git-svn-id: http://core.svn.wordpress.org/trunk@34868 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2015-10-07 12:36:25 +02:00
|
|
|
elseif ( is_embed() ) :
|
2016-02-24 21:57:26 +01:00
|
|
|
$template = ABSPATH . WPINC . '/theme-compat/embed.php';
|
Embeds: Add oEmbed provider support.
For the past 6 years, WordPress has operated as an oEmbed consumer, allowing users to easily embed content from other sites. By adding oEmbed provider support, this allows any oEmbed consumer to embed posts from WordPress sites.
In addition to creating an oEmbed provider, WordPress' oEmbed consumer code has been enhanced to work with any site that provides oEmbed data (as long as it matches some strict security rules), and provides a preview from within the post editor.
For security, embeds appear within a sandboxed iframe - the iframe content is a template that can be styled or replaced entirely by the theme on the provider site.
Props swissspidy, pento, melchoyce, netweb, pfefferle, johnbillion, extendwings, davidbinda, danielbachhuber, SergeyBiryukov, afercia
Fixes #32522.
Built from https://develop.svn.wordpress.org/trunk@34903
git-svn-id: http://core.svn.wordpress.org/trunk@34868 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2015-10-07 12:36:25 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Filter the template used for embedded posts.
|
|
|
|
*
|
|
|
|
* @since 4.4.0
|
2016-02-24 21:57:26 +01:00
|
|
|
* @since 4.5.0 The default template path changed to wp-includes/theme-compat/embed.php
|
Embeds: Add oEmbed provider support.
For the past 6 years, WordPress has operated as an oEmbed consumer, allowing users to easily embed content from other sites. By adding oEmbed provider support, this allows any oEmbed consumer to embed posts from WordPress sites.
In addition to creating an oEmbed provider, WordPress' oEmbed consumer code has been enhanced to work with any site that provides oEmbed data (as long as it matches some strict security rules), and provides a preview from within the post editor.
For security, embeds appear within a sandboxed iframe - the iframe content is a template that can be styled or replaced entirely by the theme on the provider site.
Props swissspidy, pento, melchoyce, netweb, pfefferle, johnbillion, extendwings, davidbinda, danielbachhuber, SergeyBiryukov, afercia
Fixes #32522.
Built from https://develop.svn.wordpress.org/trunk@34903
git-svn-id: http://core.svn.wordpress.org/trunk@34868 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2015-10-07 12:36:25 +02:00
|
|
|
*
|
|
|
|
* @param string $template Path to the template file.
|
|
|
|
*/
|
|
|
|
$template = apply_filters( 'embed_template', $template );
|
|
|
|
|
|
|
|
include ( $template );
|
|
|
|
return;
|
2010-02-20 13:58:25 +01:00
|
|
|
endif;
|
|
|
|
|
|
|
|
if ( defined('WP_USE_THEMES') && WP_USE_THEMES ) :
|
|
|
|
$template = false;
|
|
|
|
if ( is_404() && $template = get_404_template() ) :
|
|
|
|
elseif ( is_search() && $template = get_search_template() ) :
|
2010-04-28 09:48:09 +02:00
|
|
|
elseif ( is_front_page() && $template = get_front_page_template() ) :
|
2010-02-20 13:58:25 +01:00
|
|
|
elseif ( is_home() && $template = get_home_template() ) :
|
2013-09-07 01:39:09 +02:00
|
|
|
elseif ( is_post_type_archive() && $template = get_post_type_archive_template() ) :
|
|
|
|
elseif ( is_tax() && $template = get_taxonomy_template() ) :
|
2010-02-20 13:58:25 +01:00
|
|
|
elseif ( is_attachment() && $template = get_attachment_template() ) :
|
2008-03-23 18:02:11 +01:00
|
|
|
remove_filter('the_content', 'prepend_attachment');
|
2010-02-20 13:58:25 +01:00
|
|
|
elseif ( is_single() && $template = get_single_template() ) :
|
|
|
|
elseif ( is_page() && $template = get_page_template() ) :
|
2015-06-18 21:01:26 +02:00
|
|
|
elseif ( is_singular() && $template = get_singular_template() ) :
|
2010-02-20 13:58:25 +01:00
|
|
|
elseif ( is_category() && $template = get_category_template() ) :
|
|
|
|
elseif ( is_tag() && $template = get_tag_template() ) :
|
|
|
|
elseif ( is_author() && $template = get_author_template() ) :
|
|
|
|
elseif ( is_date() && $template = get_date_template() ) :
|
|
|
|
elseif ( is_archive() && $template = get_archive_template() ) :
|
|
|
|
elseif ( is_paged() && $template = get_paged_template() ) :
|
2010-03-26 14:52:43 +01:00
|
|
|
else :
|
|
|
|
$template = get_index_template();
|
2010-02-20 13:58:25 +01:00
|
|
|
endif;
|
2013-10-06 20:41:09 +02:00
|
|
|
/**
|
|
|
|
* Filter the path of the current template before including it.
|
|
|
|
*
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
|
|
|
* @param string $template The path of the template to include.
|
|
|
|
*/
|
2016-01-17 18:29:27 +01:00
|
|
|
if ( $template = apply_filters( 'template_include', $template ) ) {
|
2010-02-20 13:58:25 +01:00
|
|
|
include( $template );
|
2016-01-18 20:57:26 +01:00
|
|
|
} elseif ( current_user_can( 'switch_themes' ) ) {
|
2016-01-17 18:29:27 +01:00
|
|
|
$theme = wp_get_theme();
|
|
|
|
if ( $theme->errors() ) {
|
|
|
|
wp_die( $theme->errors() );
|
|
|
|
}
|
|
|
|
}
|
2010-02-20 13:58:25 +01:00
|
|
|
return;
|
|
|
|
endif;
|