Apply filters consistently in get_*_template() functions. Fixes #14310

git-svn-id: http://svn.automattic.com/wordpress/trunk@15611 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
scribu 2010-09-12 18:46:18 +00:00
parent 8bdad118fe
commit 4c7deb41e7
1 changed files with 29 additions and 33 deletions

View File

@ -687,32 +687,28 @@ function get_theme_root_uri( $stylesheet_or_template = false ) {
} }
/** /**
* Retrieve path to file without the use of extension. * Retrieve path to a template
* *
* Used to quickly retrieve the path of file without including the file * Used to quickly retrieve the path of a template without including the file
* extension. It will also check the parent template, if the file exists, with * extension. It will also check the parent theme, if the file exists, with
* the use of {@link locate_template()}. Allows for more generic file location * the use of {@link locate_template()}. Allows for more generic template location
* without the use of the other get_*_template() functions. * without the use of the other get_*_template() functions.
* *
* Can be used with include() or require() to retrieve path.
* <code>
* if( '' != get_query_template( '404' ) )
* include( get_query_template( '404' ) );
* </code>
* or the same can be accomplished with
* <code>
* if( '' != get_404_template() )
* include( get_404_template() );
* </code>
*
* @since 1.5.0 * @since 1.5.0
* *
* @param string $type Filename without extension. * @param string $type Filename without extension.
* @param array $templates An optional list of template candidates
* @return string Full path to file. * @return string Full path to file.
*/ */
function get_query_template($type) { function get_query_template( $type, $templates = array() ) {
$type = preg_replace( '|[^a-z0-9-]+|', '', $type ); $type = preg_replace( '|[^a-z0-9-]+|', '', $type );
return apply_filters("{$type}_template", locate_template(array("{$type}.php")));
if ( empty( $templates ) )
$templates = array("{$type}.php");
$templates = apply_filters( "{$type}_template_hierarchy", $templates );
return apply_filters( "{$type}_template", locate_template( $templates ) );
} }
/** /**
@ -768,8 +764,7 @@ function get_author_template() {
$templates[] = "author-{$author_id}.php"; $templates[] = "author-{$author_id}.php";
$templates[] = 'author.php'; $templates[] = 'author.php';
$template = locate_template( $templates ); return get_query_template( 'author', $templates );
return apply_filters( 'author_template', $template );
} }
/** /**
@ -790,14 +785,13 @@ function get_category_template() {
$templates = array(); $templates = array();
if ( !is_wp_error($category) ) if ( !is_wp_error( $category ) )
$templates[] = "category-{$category->slug}.php"; $templates[] = "category-{$category->slug}.php";
$templates[] = "category-$cat_ID.php"; $templates[] = "category-$cat_ID.php";
$templates[] = "category.php"; $templates[] = "category.php";
$template = locate_template($templates); return get_query_template( 'category', $templates );
return apply_filters('category_template', $template);
} }
/** /**
@ -824,8 +818,7 @@ function get_tag_template() {
$templates[] = "tag-$tag_id.php"; $templates[] = "tag-$tag_id.php";
$templates[] = "tag.php"; $templates[] = "tag.php";
$template = locate_template($templates); return get_query_template( 'tag', $templates );
return apply_filters('tag_template', $template);
} }
/** /**
@ -857,8 +850,7 @@ function get_taxonomy_template() {
$templates[] = "taxonomy.php"; $templates[] = "taxonomy.php";
$template = locate_template($templates); return get_query_template( 'taxonomy', $templates );
return apply_filters('taxonomy_template', $template);
} }
/** /**
@ -885,8 +877,9 @@ function get_date_template() {
* @return string * @return string
*/ */
function get_home_template() { function get_home_template() {
$template = locate_template(array('home.php', 'index.php')); $templates = array( 'home.php', 'index.php' );
return apply_filters('home_template', $template);
return get_query_template( 'home', $templates );
} }
/** /**
@ -900,7 +893,9 @@ function get_home_template() {
* @return string * @return string
*/ */
function get_front_page_template() { function get_front_page_template() {
return apply_filters( 'front_page_template', locate_template( array('front-page.php') ) ); $templates = array('front-page.php');
return get_query_template( 'front_page', $templates );
} }
/** /**
@ -939,7 +934,7 @@ function get_page_template() {
$templates[] = "page-$id.php"; $templates[] = "page-$id.php";
$templates[] = "page.php"; $templates[] = "page.php";
return apply_filters('page_template', locate_template($templates)); return get_query_template( 'page', $templates );
} }
/** /**
@ -976,7 +971,8 @@ function get_single_template() {
$object = $wp_query->get_queried_object(); $object = $wp_query->get_queried_object();
$templates = array('single-' . $object->post_type . '.php', 'single.php'); $templates = array('single-' . $object->post_type . '.php', 'single.php');
return apply_filters('single_template', locate_template($templates));
return get_query_template( 'single', $templates );
} }
/** /**
@ -1019,13 +1015,13 @@ function get_attachment_template() {
* @return string * @return string
*/ */
function get_comments_popup_template() { function get_comments_popup_template() {
$template = locate_template(array("comments-popup.php")); $template = get_query_template( 'comments_popup', array( 'comments-popup.php' ) );
// Backward compat code will be removed in a future release // Backward compat code will be removed in a future release
if ('' == $template) if ('' == $template)
$template = ABSPATH . WPINC . '/theme-compat/comments-popup.php'; $template = ABSPATH . WPINC . '/theme-compat/comments-popup.php';
return apply_filters('comments_popup_template', $template); return $template;
} }
/** /**