[ Index ]

PHP Cross Reference of WordPress Trunk (Updated Daily)

Search

title

Body

[close]

/wp-includes/ -> template.php (source)

   1  <?php
   2  /**
   3   * Template loading functions.
   4   *
   5   * @package WordPress
   6   * @subpackage Template
   7   */
   8  
   9  /**
  10   * Retrieves path to a template.
  11   *
  12   * Used to quickly retrieve the path of a template without including the file
  13   * extension. It will also check the parent theme, if the file exists, with
  14   * the use of locate_template(). Allows for more generic template location
  15   * without the use of the other get_*_template() functions.
  16   *
  17   * @since 1.5.0
  18   *
  19   * @param string   $type      Filename without extension.
  20   * @param string[] $templates An optional list of template candidates.
  21   * @return string Full path to template file.
  22   */
  23  function get_query_template( $type, $templates = array() ) {
  24      $type = preg_replace( '|[^a-z0-9-]+|', '', $type );
  25  
  26      if ( empty( $templates ) ) {
  27          $templates = array( "{$type}.php" );
  28      }
  29  
  30      /**
  31       * Filters the list of template filenames that are searched for when retrieving a template to use.
  32       *
  33       * The dynamic portion of the hook name, `$type`, refers to the filename -- minus the file
  34       * extension and any non-alphanumeric characters delimiting words -- of the file to load.
  35       * The last element in the array should always be the fallback template for this query type.
  36       *
  37       * Possible hook names include:
  38       *
  39       *  - `404_template_hierarchy`
  40       *  - `archive_template_hierarchy`
  41       *  - `attachment_template_hierarchy`
  42       *  - `author_template_hierarchy`
  43       *  - `category_template_hierarchy`
  44       *  - `date_template_hierarchy`
  45       *  - `embed_template_hierarchy`
  46       *  - `frontpage_template_hierarchy`
  47       *  - `home_template_hierarchy`
  48       *  - `index_template_hierarchy`
  49       *  - `page_template_hierarchy`
  50       *  - `paged_template_hierarchy`
  51       *  - `privacypolicy_template_hierarchy`
  52       *  - `search_template_hierarchy`
  53       *  - `single_template_hierarchy`
  54       *  - `singular_template_hierarchy`
  55       *  - `tag_template_hierarchy`
  56       *  - `taxonomy_template_hierarchy`
  57       *
  58       * @since 4.7.0
  59       *
  60       * @param string[] $templates A list of template candidates, in descending order of priority.
  61       */
  62      $templates = apply_filters( "{$type}_template_hierarchy", $templates );
  63  
  64      $template = locate_template( $templates );
  65  
  66      $template = locate_block_template( $template, $type, $templates );
  67  
  68      /**
  69       * Filters the path of the queried template by type.
  70       *
  71       * The dynamic portion of the hook name, `$type`, refers to the filename -- minus the file
  72       * extension and any non-alphanumeric characters delimiting words -- of the file to load.
  73       * This hook also applies to various types of files loaded as part of the Template Hierarchy.
  74       *
  75       * Possible hook names include:
  76       *
  77       *  - `404_template`
  78       *  - `archive_template`
  79       *  - `attachment_template`
  80       *  - `author_template`
  81       *  - `category_template`
  82       *  - `date_template`
  83       *  - `embed_template`
  84       *  - `frontpage_template`
  85       *  - `home_template`
  86       *  - `index_template`
  87       *  - `page_template`
  88       *  - `paged_template`
  89       *  - `privacypolicy_template`
  90       *  - `search_template`
  91       *  - `single_template`
  92       *  - `singular_template`
  93       *  - `tag_template`
  94       *  - `taxonomy_template`
  95       *
  96       * @since 1.5.0
  97       * @since 4.8.0 The `$type` and `$templates` parameters were added.
  98       *
  99       * @param string   $template  Path to the template. See locate_template().
 100       * @param string   $type      Sanitized filename without extension.
 101       * @param string[] $templates A list of template candidates, in descending order of priority.
 102       */
 103      return apply_filters( "{$type}_template", $template, $type, $templates );
 104  }
 105  
 106  /**
 107   * Retrieves path of index template in current or parent template.
 108   *
 109   * The template hierarchy and template path are filterable via the {@see '$type_template_hierarchy'}
 110   * and {@see '$type_template'} dynamic hooks, where `$type` is 'index'.
 111   *
 112   * @since 3.0.0
 113   *
 114   * @see get_query_template()
 115   *
 116   * @return string Full path to index template file.
 117   */
 118  function get_index_template() {
 119      return get_query_template( 'index' );
 120  }
 121  
 122  /**
 123   * Retrieves path of 404 template in current or parent template.
 124   *
 125   * The template hierarchy and template path are filterable via the {@see '$type_template_hierarchy'}
 126   * and {@see '$type_template'} dynamic hooks, where `$type` is '404'.
 127   *
 128   * @since 1.5.0
 129   *
 130   * @see get_query_template()
 131   *
 132   * @return string Full path to 404 template file.
 133   */
 134  function get_404_template() {
 135      return get_query_template( '404' );
 136  }
 137  
 138  /**
 139   * Retrieves path of archive template in current or parent template.
 140   *
 141   * The template hierarchy and template path are filterable via the {@see '$type_template_hierarchy'}
 142   * and {@see '$type_template'} dynamic hooks, where `$type` is 'archive'.
 143   *
 144   * @since 1.5.0
 145   *
 146   * @see get_query_template()
 147   *
 148   * @return string Full path to archive template file.
 149   */
 150  function get_archive_template() {
 151      $post_types = array_filter( (array) get_query_var( 'post_type' ) );
 152  
 153      $templates = array();
 154  
 155      if ( count( $post_types ) === 1 ) {
 156          $post_type   = reset( $post_types );
 157          $templates[] = "archive-{$post_type}.php";
 158      }
 159      $templates[] = 'archive.php';
 160  
 161      return get_query_template( 'archive', $templates );
 162  }
 163  
 164  /**
 165   * Retrieves path of post type archive template in current or parent template.
 166   *
 167   * The template hierarchy and template path are filterable via the {@see '$type_template_hierarchy'}
 168   * and {@see '$type_template'} dynamic hooks, where `$type` is 'archive'.
 169   *
 170   * @since 3.7.0
 171   *
 172   * @see get_archive_template()
 173   *
 174   * @return string Full path to archive template file.
 175   */
 176  function get_post_type_archive_template() {
 177      $post_type = get_query_var( 'post_type' );
 178      if ( is_array( $post_type ) ) {
 179          $post_type = reset( $post_type );
 180      }
 181  
 182      $obj = get_post_type_object( $post_type );
 183      if ( ! ( $obj instanceof WP_Post_Type ) || ! $obj->has_archive ) {
 184          return '';
 185      }
 186  
 187      return get_archive_template();
 188  }
 189  
 190  /**
 191   * Retrieves path of author template in current or parent template.
 192   *
 193   * The hierarchy for this template looks like:
 194   *
 195   * 1. author-{nicename}.php
 196   * 2. author-{id}.php
 197   * 3. author.php
 198   *
 199   * An example of this is:
 200   *
 201   * 1. author-john.php
 202   * 2. author-1.php
 203   * 3. author.php
 204   *
 205   * The template hierarchy and template path are filterable via the {@see '$type_template_hierarchy'}
 206   * and {@see '$type_template'} dynamic hooks, where `$type` is 'author'.
 207   *
 208   * @since 1.5.0
 209   *
 210   * @see get_query_template()
 211   *
 212   * @return string Full path to author template file.
 213   */
 214  function get_author_template() {
 215      $author = get_queried_object();
 216  
 217      $templates = array();
 218  
 219      if ( $author instanceof WP_User ) {
 220          $templates[] = "author-{$author->user_nicename}.php";
 221          $templates[] = "author-{$author->ID}.php";
 222      }
 223      $templates[] = 'author.php';
 224  
 225      return get_query_template( 'author', $templates );
 226  }
 227  
 228  /**
 229   * Retrieves path of category template in current or parent template.
 230   *
 231   * The hierarchy for this template looks like:
 232   *
 233   * 1. category-{slug}.php
 234   * 2. category-{id}.php
 235   * 3. category.php
 236   *
 237   * An example of this is:
 238   *
 239   * 1. category-news.php
 240   * 2. category-2.php
 241   * 3. category.php
 242   *
 243   * The template hierarchy and template path are filterable via the {@see '$type_template_hierarchy'}
 244   * and {@see '$type_template'} dynamic hooks, where `$type` is 'category'.
 245   *
 246   * @since 1.5.0
 247   * @since 4.7.0 The decoded form of `category-{slug}.php` was added to the top of the
 248   *              template hierarchy when the category slug contains multibyte characters.
 249   *
 250   * @see get_query_template()
 251   *
 252   * @return string Full path to category template file.
 253   */
 254  function get_category_template() {
 255      $category = get_queried_object();
 256  
 257      $templates = array();
 258  
 259      if ( ! empty( $category->slug ) ) {
 260  
 261          $slug_decoded = urldecode( $category->slug );
 262          if ( $slug_decoded !== $category->slug ) {
 263              $templates[] = "category-{$slug_decoded}.php";
 264          }
 265  
 266          $templates[] = "category-{$category->slug}.php";
 267          $templates[] = "category-{$category->term_id}.php";
 268      }
 269      $templates[] = 'category.php';
 270  
 271      return get_query_template( 'category', $templates );
 272  }
 273  
 274  /**
 275   * Retrieves path of tag template in current or parent template.
 276   *
 277   * The hierarchy for this template looks like:
 278   *
 279   * 1. tag-{slug}.php
 280   * 2. tag-{id}.php
 281   * 3. tag.php
 282   *
 283   * An example of this is:
 284   *
 285   * 1. tag-wordpress.php
 286   * 2. tag-3.php
 287   * 3. tag.php
 288   *
 289   * The template hierarchy and template path are filterable via the {@see '$type_template_hierarchy'}
 290   * and {@see '$type_template'} dynamic hooks, where `$type` is 'tag'.
 291   *
 292   * @since 2.3.0
 293   * @since 4.7.0 The decoded form of `tag-{slug}.php` was added to the top of the
 294   *              template hierarchy when the tag slug contains multibyte characters.
 295   *
 296   * @see get_query_template()
 297   *
 298   * @return string Full path to tag template file.
 299   */
 300  function get_tag_template() {
 301      $tag = get_queried_object();
 302  
 303      $templates = array();
 304  
 305      if ( ! empty( $tag->slug ) ) {
 306  
 307          $slug_decoded = urldecode( $tag->slug );
 308          if ( $slug_decoded !== $tag->slug ) {
 309              $templates[] = "tag-{$slug_decoded}.php";
 310          }
 311  
 312          $templates[] = "tag-{$tag->slug}.php";
 313          $templates[] = "tag-{$tag->term_id}.php";
 314      }
 315      $templates[] = 'tag.php';
 316  
 317      return get_query_template( 'tag', $templates );
 318  }
 319  
 320  /**
 321   * Retrieves path of custom taxonomy term template in current or parent template.
 322   *
 323   * The hierarchy for this template looks like:
 324   *
 325   * 1. taxonomy-{taxonomy_slug}-{term_slug}.php
 326   * 2. taxonomy-{taxonomy_slug}.php
 327   * 3. taxonomy.php
 328   *
 329   * An example of this is:
 330   *
 331   * 1. taxonomy-location-texas.php
 332   * 2. taxonomy-location.php
 333   * 3. taxonomy.php
 334   *
 335   * The template hierarchy and template path are filterable via the {@see '$type_template_hierarchy'}
 336   * and {@see '$type_template'} dynamic hooks, where `$type` is 'taxonomy'.
 337   *
 338   * @since 2.5.0
 339   * @since 4.7.0 The decoded form of `taxonomy-{taxonomy_slug}-{term_slug}.php` was added to the top of the
 340   *              template hierarchy when the term slug contains multibyte characters.
 341   *
 342   * @see get_query_template()
 343   *
 344   * @return string Full path to custom taxonomy term template file.
 345   */
 346  function get_taxonomy_template() {
 347      $term = get_queried_object();
 348  
 349      $templates = array();
 350  
 351      if ( ! empty( $term->slug ) ) {
 352          $taxonomy = $term->taxonomy;
 353  
 354          $slug_decoded = urldecode( $term->slug );
 355          if ( $slug_decoded !== $term->slug ) {
 356              $templates[] = "taxonomy-$taxonomy-{$slug_decoded}.php";
 357          }
 358  
 359          $templates[] = "taxonomy-$taxonomy-{$term->slug}.php";
 360          $templates[] = "taxonomy-$taxonomy.php";
 361      }
 362      $templates[] = 'taxonomy.php';
 363  
 364      return get_query_template( 'taxonomy', $templates );
 365  }
 366  
 367  /**
 368   * Retrieves path of date template in current or parent template.
 369   *
 370   * The template hierarchy and template path are filterable via the {@see '$type_template_hierarchy'}
 371   * and {@see '$type_template'} dynamic hooks, where `$type` is 'date'.
 372   *
 373   * @since 1.5.0
 374   *
 375   * @see get_query_template()
 376   *
 377   * @return string Full path to date template file.
 378   */
 379  function get_date_template() {
 380      return get_query_template( 'date' );
 381  }
 382  
 383  /**
 384   * Retrieves path of home template in current or parent template.
 385   *
 386   * The template hierarchy and template path are filterable via the {@see '$type_template_hierarchy'}
 387   * and {@see '$type_template'} dynamic hooks, where `$type` is 'home'.
 388   *
 389   * @since 1.5.0
 390   *
 391   * @see get_query_template()
 392   *
 393   * @return string Full path to home template file.
 394   */
 395  function get_home_template() {
 396      $templates = array( 'home.php', 'index.php' );
 397  
 398      return get_query_template( 'home', $templates );
 399  }
 400  
 401  /**
 402   * Retrieves path of front page template in current or parent template.
 403   *
 404   * The template hierarchy and template path are filterable via the {@see '$type_template_hierarchy'}
 405   * and {@see '$type_template'} dynamic hooks, where `$type` is 'frontpage'.
 406   *
 407   * @since 3.0.0
 408   *
 409   * @see get_query_template()
 410   *
 411   * @return string Full path to front page template file.
 412   */
 413  function get_front_page_template() {
 414      $templates = array( 'front-page.php' );
 415  
 416      return get_query_template( 'frontpage', $templates );
 417  }
 418  
 419  /**
 420   * Retrieves path of Privacy Policy page template in current or parent template.
 421   *
 422   * The template hierarchy and template path are filterable via the {@see '$type_template_hierarchy'}
 423   * and {@see '$type_template'} dynamic hooks, where `$type` is 'privacypolicy'.
 424   *
 425   * @since 5.2.0
 426   *
 427   * @see get_query_template()
 428   *
 429   * @return string Full path to privacy policy template file.
 430   */
 431  function get_privacy_policy_template() {
 432      $templates = array( 'privacy-policy.php' );
 433  
 434      return get_query_template( 'privacypolicy', $templates );
 435  }
 436  
 437  /**
 438   * Retrieves path of page template in current or parent template.
 439   *
 440   * Note: For block themes, use locate_block_template() function instead.
 441   *
 442   * The hierarchy for this template looks like:
 443   *
 444   * 1. {Page Template}.php
 445   * 2. page-{page_name}.php
 446   * 3. page-{id}.php
 447   * 4. page.php
 448   *
 449   * An example of this is:
 450   *
 451   * 1. page-templates/full-width.php
 452   * 2. page-about.php
 453   * 3. page-4.php
 454   * 4. page.php
 455   *
 456   * The template hierarchy and template path are filterable via the {@see '$type_template_hierarchy'}
 457   * and {@see '$type_template'} dynamic hooks, where `$type` is 'page'.
 458   *
 459   * @since 1.5.0
 460   * @since 4.7.0 The decoded form of `page-{page_name}.php` was added to the top of the
 461   *              template hierarchy when the page name contains multibyte characters.
 462   *
 463   * @see get_query_template()
 464   *
 465   * @return string Full path to page template file.
 466   */
 467  function get_page_template() {
 468      $id       = get_queried_object_id();
 469      $template = get_page_template_slug();
 470      $pagename = get_query_var( 'pagename' );
 471  
 472      if ( ! $pagename && $id ) {
 473          /*
 474           * If a static page is set as the front page, $pagename will not be set.
 475           * Retrieve it from the queried object.
 476           */
 477          $post = get_queried_object();
 478          if ( $post ) {
 479              $pagename = $post->post_name;
 480          }
 481      }
 482  
 483      $templates = array();
 484      if ( $template && 0 === validate_file( $template ) ) {
 485          $templates[] = $template;
 486      }
 487      if ( $pagename ) {
 488          $pagename_decoded = urldecode( $pagename );
 489          if ( $pagename_decoded !== $pagename ) {
 490              $templates[] = "page-{$pagename_decoded}.php";
 491          }
 492          $templates[] = "page-{$pagename}.php";
 493      }
 494      if ( $id ) {
 495          $templates[] = "page-{$id}.php";
 496      }
 497      $templates[] = 'page.php';
 498  
 499      return get_query_template( 'page', $templates );
 500  }
 501  
 502  /**
 503   * Retrieves path of search template in current or parent template.
 504   *
 505   * The template hierarchy and template path are filterable via the {@see '$type_template_hierarchy'}
 506   * and {@see '$type_template'} dynamic hooks, where `$type` is 'search'.
 507   *
 508   * @since 1.5.0
 509   *
 510   * @see get_query_template()
 511   *
 512   * @return string Full path to search template file.
 513   */
 514  function get_search_template() {
 515      return get_query_template( 'search' );
 516  }
 517  
 518  /**
 519   * Retrieves path of single template in current or parent template. Applies to single Posts,
 520   * single Attachments, and single custom post types.
 521   *
 522   * The hierarchy for this template looks like:
 523   *
 524   * 1. {Post Type Template}.php
 525   * 2. single-{post_type}-{post_name}.php
 526   * 3. single-{post_type}.php
 527   * 4. single.php
 528   *
 529   * An example of this is:
 530   *
 531   * 1. templates/full-width.php
 532   * 2. single-post-hello-world.php
 533   * 3. single-post.php
 534   * 4. single.php
 535   *
 536   * The template hierarchy and template path are filterable via the {@see '$type_template_hierarchy'}
 537   * and {@see '$type_template'} dynamic hooks, where `$type` is 'single'.
 538   *
 539   * @since 1.5.0
 540   * @since 4.4.0 `single-{post_type}-{post_name}.php` was added to the top of the template hierarchy.
 541   * @since 4.7.0 The decoded form of `single-{post_type}-{post_name}.php` was added to the top of the
 542   *              template hierarchy when the post name contains multibyte characters.
 543   * @since 4.7.0 `{Post Type Template}.php` was added to the top of the template hierarchy.
 544   *
 545   * @see get_query_template()
 546   *
 547   * @return string Full path to single template file.
 548   */
 549  function get_single_template() {
 550      $object = get_queried_object();
 551  
 552      $templates = array();
 553  
 554      if ( ! empty( $object->post_type ) ) {
 555          $template = get_page_template_slug( $object );
 556          if ( $template && 0 === validate_file( $template ) ) {
 557              $templates[] = $template;
 558          }
 559  
 560          $name_decoded = urldecode( $object->post_name );
 561          if ( $name_decoded !== $object->post_name ) {
 562              $templates[] = "single-{$object->post_type}-{$name_decoded}.php";
 563          }
 564  
 565          $templates[] = "single-{$object->post_type}-{$object->post_name}.php";
 566          $templates[] = "single-{$object->post_type}.php";
 567      }
 568  
 569      $templates[] = 'single.php';
 570  
 571      return get_query_template( 'single', $templates );
 572  }
 573  
 574  /**
 575   * Retrieves an embed template path in the current or parent template.
 576   *
 577   * The hierarchy for this template looks like:
 578   *
 579   * 1. embed-{post_type}-{post_format}.php
 580   * 2. embed-{post_type}.php
 581   * 3. embed.php
 582   *
 583   * An example of this is:
 584   *
 585   * 1. embed-post-audio.php
 586   * 2. embed-post.php
 587   * 3. embed.php
 588   *
 589   * The template hierarchy and template path are filterable via the {@see '$type_template_hierarchy'}
 590   * and {@see '$type_template'} dynamic hooks, where `$type` is 'embed'.
 591   *
 592   * @since 4.5.0
 593   *
 594   * @see get_query_template()
 595   *
 596   * @return string Full path to embed template file.
 597   */
 598  function get_embed_template() {
 599      $object = get_queried_object();
 600  
 601      $templates = array();
 602  
 603      if ( ! empty( $object->post_type ) ) {
 604          $post_format = get_post_format( $object );
 605          if ( $post_format ) {
 606              $templates[] = "embed-{$object->post_type}-{$post_format}.php";
 607          }
 608          $templates[] = "embed-{$object->post_type}.php";
 609      }
 610  
 611      $templates[] = 'embed.php';
 612  
 613      return get_query_template( 'embed', $templates );
 614  }
 615  
 616  /**
 617   * Retrieves the path of the singular template in current or parent template.
 618   *
 619   * The template hierarchy and template path are filterable via the {@see '$type_template_hierarchy'}
 620   * and {@see '$type_template'} dynamic hooks, where `$type` is 'singular'.
 621   *
 622   * @since 4.3.0
 623   *
 624   * @see get_query_template()
 625   *
 626   * @return string Full path to singular template file
 627   */
 628  function get_singular_template() {
 629      return get_query_template( 'singular' );
 630  }
 631  
 632  /**
 633   * Retrieves path of attachment template in current or parent template.
 634   *
 635   * The hierarchy for this template looks like:
 636   *
 637   * 1. {mime_type}-{sub_type}.php
 638   * 2. {sub_type}.php
 639   * 3. {mime_type}.php
 640   * 4. attachment.php
 641   *
 642   * An example of this is:
 643   *
 644   * 1. image-jpeg.php
 645   * 2. jpeg.php
 646   * 3. image.php
 647   * 4. attachment.php
 648   *
 649   * The template hierarchy and template path are filterable via the {@see '$type_template_hierarchy'}
 650   * and {@see '$type_template'} dynamic hooks, where `$type` is 'attachment'.
 651   *
 652   * @since 2.0.0
 653   * @since 4.3.0 The order of the mime type logic was reversed so the hierarchy is more logical.
 654   *
 655   * @see get_query_template()
 656   *
 657   * @return string Full path to attachment template file.
 658   */
 659  function get_attachment_template() {
 660      $attachment = get_queried_object();
 661  
 662      $templates = array();
 663  
 664      if ( $attachment ) {
 665          if ( str_contains( $attachment->post_mime_type, '/' ) ) {
 666              list( $type, $subtype ) = explode( '/', $attachment->post_mime_type );
 667          } else {
 668              list( $type, $subtype ) = array( $attachment->post_mime_type, '' );
 669          }
 670  
 671          if ( ! empty( $subtype ) ) {
 672              $templates[] = "{$type}-{$subtype}.php";
 673              $templates[] = "{$subtype}.php";
 674          }
 675          $templates[] = "{$type}.php";
 676      }
 677      $templates[] = 'attachment.php';
 678  
 679      return get_query_template( 'attachment', $templates );
 680  }
 681  
 682  /**
 683   * Set up the globals used for template loading.
 684   *
 685   * @since 6.5.0
 686   *
 687   * @global string $wp_stylesheet_path Path to current theme's stylesheet directory.
 688   * @global string $wp_template_path   Path to current theme's template directory.
 689   */
 690  function wp_set_template_globals() {
 691      global $wp_stylesheet_path, $wp_template_path;
 692  
 693      $wp_stylesheet_path = get_stylesheet_directory();
 694      $wp_template_path   = get_template_directory();
 695  }
 696  
 697  /**
 698   * Retrieves the name of the highest priority template file that exists.
 699   *
 700   * Searches in the stylesheet directory before the template directory and
 701   * wp-includes/theme-compat so that themes which inherit from a parent theme
 702   * can just overload one file.
 703   *
 704   * @since 2.7.0
 705   * @since 5.5.0 The `$args` parameter was added.
 706   *
 707   * @global string $wp_stylesheet_path Path to current theme's stylesheet directory.
 708   * @global string $wp_template_path   Path to current theme's template directory.
 709   *
 710   * @param string|array $template_names Template file(s) to search for, in order.
 711   * @param bool         $load           If true the template file will be loaded if it is found.
 712   * @param bool         $load_once      Whether to require_once or require. Has no effect if `$load` is false.
 713   *                                     Default true.
 714   * @param array        $args           Optional. Additional arguments passed to the template.
 715   *                                     Default empty array.
 716   * @return string The template filename if one is located.
 717   */
 718  function locate_template( $template_names, $load = false, $load_once = true, $args = array() ) {
 719      global $wp_stylesheet_path, $wp_template_path;
 720  
 721      if ( ! isset( $wp_stylesheet_path ) || ! isset( $wp_template_path ) ) {
 722          wp_set_template_globals();
 723      }
 724  
 725      $is_child_theme = is_child_theme();
 726  
 727      $located = '';
 728      foreach ( (array) $template_names as $template_name ) {
 729          if ( ! $template_name ) {
 730              continue;
 731          }
 732          if ( file_exists( $wp_stylesheet_path . '/' . $template_name ) ) {
 733              $located = $wp_stylesheet_path . '/' . $template_name;
 734              break;
 735          } elseif ( $is_child_theme && file_exists( $wp_template_path . '/' . $template_name ) ) {
 736              $located = $wp_template_path . '/' . $template_name;
 737              break;
 738          } elseif ( file_exists( ABSPATH . WPINC . '/theme-compat/' . $template_name ) ) {
 739              $located = ABSPATH . WPINC . '/theme-compat/' . $template_name;
 740              break;
 741          }
 742      }
 743  
 744      if ( $load && '' !== $located ) {
 745          load_template( $located, $load_once, $args );
 746      }
 747  
 748      return $located;
 749  }
 750  
 751  /**
 752   * Requires the template file with WordPress environment.
 753   *
 754   * The globals are set up for the template file to ensure that the WordPress
 755   * environment is available from within the function. The query variables are
 756   * also available.
 757   *
 758   * @since 1.5.0
 759   * @since 5.5.0 The `$args` parameter was added.
 760   *
 761   * @global array      $posts
 762   * @global WP_Post    $post          Global post object.
 763   * @global bool       $wp_did_header
 764   * @global WP_Query   $wp_query      WordPress Query object.
 765   * @global WP_Rewrite $wp_rewrite    WordPress rewrite component.
 766   * @global wpdb       $wpdb          WordPress database abstraction object.
 767   * @global string     $wp_version
 768   * @global WP         $wp            Current WordPress environment instance.
 769   * @global int        $id
 770   * @global WP_Comment $comment       Global comment object.
 771   * @global int        $user_ID
 772   *
 773   * @param string $_template_file Path to template file.
 774   * @param bool   $load_once      Whether to require_once or require. Default true.
 775   * @param array  $args           Optional. Additional arguments passed to the template.
 776   *                               Default empty array.
 777   */
 778  function load_template( $_template_file, $load_once = true, $args = array() ) {
 779      global $posts, $post, $wp_did_header, $wp_query, $wp_rewrite, $wpdb, $wp_version, $wp, $id, $comment, $user_ID;
 780  
 781      if ( is_array( $wp_query->query_vars ) ) {
 782          /*
 783           * This use of extract() cannot be removed. There are many possible ways that
 784           * templates could depend on variables that it creates existing, and no way to
 785           * detect and deprecate it.
 786           *
 787           * Passing the EXTR_SKIP flag is the safest option, ensuring globals and
 788           * function variables cannot be overwritten.
 789           */
 790          // phpcs:ignore WordPress.PHP.DontExtract.extract_extract
 791          extract( $wp_query->query_vars, EXTR_SKIP );
 792      }
 793  
 794      if ( isset( $s ) ) {
 795          $s = esc_attr( $s );
 796      }
 797  
 798      /**
 799       * Fires before a template file is loaded.
 800       *
 801       * @since 6.1.0
 802       *
 803       * @param string $_template_file The full path to the template file.
 804       * @param bool   $load_once      Whether to require_once or require.
 805       * @param array  $args           Additional arguments passed to the template.
 806       */
 807      do_action( 'wp_before_load_template', $_template_file, $load_once, $args );
 808  
 809      if ( $load_once ) {
 810          require_once $_template_file;
 811      } else {
 812          require $_template_file;
 813      }
 814  
 815      /**
 816       * Fires after a template file is loaded.
 817       *
 818       * @since 6.1.0
 819       *
 820       * @param string $_template_file The full path to the template file.
 821       * @param bool   $load_once      Whether to require_once or require.
 822       * @param array  $args           Additional arguments passed to the template.
 823       */
 824      do_action( 'wp_after_load_template', $_template_file, $load_once, $args );
 825  }


Generated : Tue Jan 21 08:20:01 2025 Cross-referenced by PHPXref