wp/wp-includes/template-loader.php
changeset 16 a86126ab1dd4
parent 9 177826044cd9
--- a/wp/wp-includes/template-loader.php	Tue Oct 22 16:11:46 2019 +0200
+++ b/wp/wp-includes/template-loader.php	Tue Dec 15 13:49:49 2020 +0100
@@ -24,11 +24,11 @@
  * @param bool $exit Whether to exit without generating any content for 'HEAD' requests. Default true.
  */
 if ( 'HEAD' === $_SERVER['REQUEST_METHOD'] && apply_filters( 'exit_on_http_head', true ) ) {
-	exit();
+	exit;
 }
 
 // Process feeds and trackbacks even if not using themes.
-if ( is_robots() ) :
+if ( is_robots() ) {
 	/**
 	 * Fired when the template loader determines a robots.txt request.
 	 *
@@ -36,37 +36,64 @@
 	 */
 	do_action( 'do_robots' );
 	return;
-elseif ( is_feed() ) :
+} elseif ( is_favicon() ) {
+	/**
+	 * Fired when the template loader determines a favicon.ico request.
+	 *
+	 * @since 5.4.0
+	 */
+	do_action( 'do_favicon' );
+	return;
+} elseif ( is_feed() ) {
 	do_feed();
 	return;
-elseif ( is_trackback() ) :
-	include( ABSPATH . 'wp-trackback.php' );
+} elseif ( is_trackback() ) {
+	require ABSPATH . 'wp-trackback.php';
 	return;
-endif;
+}
+
+if ( wp_using_themes() ) {
 
-if ( wp_using_themes() ) :
-	$template = false;
-	if ( is_embed() && $template = get_embed_template() ) :
-	elseif ( is_404() && $template = get_404_template() ) :
-	elseif ( is_search() && $template = get_search_template() ) :
-	elseif ( is_front_page() && $template = get_front_page_template() ) :
-	elseif ( is_home() && $template = get_home_template() ) :
-	elseif ( is_privacy_policy() && $template = get_privacy_policy_template() ) :
-	elseif ( is_post_type_archive() && $template = get_post_type_archive_template() ) :
-	elseif ( is_tax() && $template = get_taxonomy_template() ) :
-	elseif ( is_attachment() && $template = get_attachment_template() ) :
-		remove_filter( 'the_content', 'prepend_attachment' );
-	elseif ( is_single() && $template = get_single_template() ) :
-	elseif ( is_page() && $template = get_page_template() ) :
-	elseif ( is_singular() && $template = get_singular_template() ) :
-	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() ) :
-	else :
+	$tag_templates = array(
+		'is_embed'             => 'get_embed_template',
+		'is_404'               => 'get_404_template',
+		'is_search'            => 'get_search_template',
+		'is_front_page'        => 'get_front_page_template',
+		'is_home'              => 'get_home_template',
+		'is_privacy_policy'    => 'get_privacy_policy_template',
+		'is_post_type_archive' => 'get_post_type_archive_template',
+		'is_tax'               => 'get_taxonomy_template',
+		'is_attachment'        => 'get_attachment_template',
+		'is_single'            => 'get_single_template',
+		'is_page'              => 'get_page_template',
+		'is_singular'          => 'get_singular_template',
+		'is_category'          => 'get_category_template',
+		'is_tag'               => 'get_tag_template',
+		'is_author'            => 'get_author_template',
+		'is_date'              => 'get_date_template',
+		'is_archive'           => 'get_archive_template',
+	);
+	$template      = false;
+
+	// Loop through each of the template conditionals, and find the appropriate template file.
+	foreach ( $tag_templates as $tag => $template_getter ) {
+		if ( call_user_func( $tag ) ) {
+			$template = call_user_func( $template_getter );
+		}
+
+		if ( $template ) {
+			if ( 'is_attachment' === $tag ) {
+				remove_filter( 'the_content', 'prepend_attachment' );
+			}
+
+			break;
+		}
+	}
+
+	if ( ! $template ) {
 		$template = get_index_template();
-	endif;
+	}
+
 	/**
 	 * Filters the path of the current template before including it.
 	 *
@@ -74,8 +101,9 @@
 	 *
 	 * @param string $template The path of the template to include.
 	 */
-	if ( $template = apply_filters( 'template_include', $template ) ) {
-		include( $template );
+	$template = apply_filters( 'template_include', $template );
+	if ( $template ) {
+		include $template;
 	} elseif ( current_user_can( 'switch_themes' ) ) {
 		$theme = wp_get_theme();
 		if ( $theme->errors() ) {
@@ -83,4 +111,4 @@
 		}
 	}
 	return;
-endif;
+}