Add template_include filter, to modify the template path before it is included. Fixes #11242

git-svn-id: http://svn.automattic.com/wordpress/trunk@13252 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
nacin 2010-02-20 12:58:25 +00:00
parent 687e7d1ccd
commit 8ad91e8b54
1 changed files with 37 additions and 69 deletions

View File

@ -3,76 +3,44 @@
* Loads the correct template based on the visitor's url * Loads the correct template based on the visitor's url
* @package WordPress * @package WordPress
*/ */
if ( defined('WP_USE_THEMES') && WP_USE_THEMES ) { if ( defined('WP_USE_THEMES') && WP_USE_THEMES )
do_action('template_redirect'); do_action('template_redirect');
if ( is_robots() ) {
do_action('do_robots'); // Process feeds and trackbacks even if not using themes.
return; if ( is_robots() ) :
} else if ( is_feed() ) { do_action('do_robots');
do_feed(); return;
return; elseif ( is_feed() ) :
} else if ( is_trackback() ) { do_feed();
include(ABSPATH . 'wp-trackback.php'); return;
return; elseif ( is_trackback() ) :
} else if ( is_404() && $template = get_404_template() ) { include( ABSPATH . 'wp-trackback.php' );
include($template); return;
return; endif;
} else if ( is_search() && $template = get_search_template() ) {
include($template); if ( defined('WP_USE_THEMES') && WP_USE_THEMES ) :
return; $template = false;
} else if ( is_tax() && $template = get_taxonomy_template()) { if ( is_404() && $template = get_404_template() ) :
include($template); elseif ( is_search() && $template = get_search_template() ) :
return; elseif ( is_tax() && $template = get_taxonomy_template() ) :
} else if ( is_home() && $template = get_home_template() ) { elseif ( is_home() && $template = get_home_template() ) :
include($template); elseif ( is_attachment() && $template = get_attachment_template() ) :
return;
} else if ( is_attachment() && $template = get_attachment_template() ) {
remove_filter('the_content', 'prepend_attachment'); remove_filter('the_content', 'prepend_attachment');
include($template); elseif ( is_single() && $template = get_single_template() ) :
return; elseif ( is_page() && $template = get_page_template() ) :
} else if ( is_single() && $template = get_single_template() ) { elseif ( is_category() && $template = get_category_template() ) :
include($template); elseif ( is_tag() && $template = get_tag_template() ) :
return; elseif ( is_author() && $template = get_author_template() ) :
} else if ( is_page() && $template = get_page_template() ) { elseif ( is_date() && $template = get_date_template() ) :
include($template); elseif ( is_archive() && $template = get_archive_template() ) :
return; elseif ( is_comments_popup() && $template = get_comments_popup_template() ) :
} else if ( is_category() && $template = get_category_template()) { elseif ( is_paged() && $template = get_paged_template() ) :
include($template); elseif ( file_exists( TEMPLATEPATH . '/index.php' ) ) :
return; $template = TEMPLATEPATH . '/index.php';
} else if ( is_tag() && $template = get_tag_template()) { endif;
include($template); if ( $template = apply_filters( 'template_include', $template ) )
return; include( $template );
} else if ( is_author() && $template = get_author_template() ) { return;
include($template); endif;
return;
} else if ( is_date() && $template = get_date_template() ) {
include($template);
return;
} else if ( is_archive() && $template = get_archive_template() ) {
include($template);
return;
} else if ( is_comments_popup() && $template = get_comments_popup_template() ) {
include($template);
return;
} else if ( is_paged() && $template = get_paged_template() ) {
include($template);
return;
} else if ( file_exists(TEMPLATEPATH . "/index.php") ) {
include(TEMPLATEPATH . "/index.php");
return;
}
} else {
// Process feeds and trackbacks even if not using themes.
if ( is_robots() ) {
do_action('do_robots');
return;
} else if ( is_feed() ) {
do_feed();
return;
} else if ( is_trackback() ) {
include(ABSPATH . 'wp-trackback.php');
return;
}
}
?> ?>