[ Index ]

PHP Cross Reference of WordPress

title

Body

[close]

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

   1  <?php
   2  /**
   3   * WordPress Query API
   4   *
   5   * The query API attempts to get which part of WordPress the user is on. It
   6   * also provides functionality for getting URL query information.
   7   *
   8   * @link https://developer.wordpress.org/themes/basics/the-loop/ More information on The Loop.
   9   *
  10   * @package WordPress
  11   * @subpackage Query
  12   */
  13  
  14  /**
  15   * Retrieves the value of a query variable in the WP_Query class.
  16   *
  17   * @since 1.5.0
  18   * @since 3.9.0 The `$default` argument was introduced.
  19   *
  20   * @global WP_Query $wp_query WordPress Query object.
  21   *
  22   * @param string $var       The variable key to retrieve.
  23   * @param mixed  $default   Optional. Value to return if the query variable is not set. Default empty.
  24   * @return mixed Contents of the query variable.
  25   */
  26  function get_query_var( $var, $default = '' ) {
  27      global $wp_query;
  28      return $wp_query->get( $var, $default );
  29  }
  30  
  31  /**
  32   * Retrieves the currently queried object.
  33   *
  34   * Wrapper for WP_Query::get_queried_object().
  35   *
  36   * @since 3.1.0
  37   *
  38   * @global WP_Query $wp_query WordPress Query object.
  39   *
  40   * @return WP_Term|WP_Post_Type|WP_Post|WP_User|null The queried object.
  41   */
  42  function get_queried_object() {
  43      global $wp_query;
  44      return $wp_query->get_queried_object();
  45  }
  46  
  47  /**
  48   * Retrieves the ID of the currently queried object.
  49   *
  50   * Wrapper for WP_Query::get_queried_object_id().
  51   *
  52   * @since 3.1.0
  53   *
  54   * @global WP_Query $wp_query WordPress Query object.
  55   *
  56   * @return int ID of the queried object.
  57   */
  58  function get_queried_object_id() {
  59      global $wp_query;
  60      return $wp_query->get_queried_object_id();
  61  }
  62  
  63  /**
  64   * Sets the value of a query variable in the WP_Query class.
  65   *
  66   * @since 2.2.0
  67   *
  68   * @global WP_Query $wp_query WordPress Query object.
  69   *
  70   * @param string $var   Query variable key.
  71   * @param mixed  $value Query variable value.
  72   */
  73  function set_query_var( $var, $value ) {
  74      global $wp_query;
  75      $wp_query->set( $var, $value );
  76  }
  77  
  78  /**
  79   * Sets up The Loop with query parameters.
  80   *
  81   * Note: This function will completely override the main query and isn't intended for use
  82   * by plugins or themes. Its overly-simplistic approach to modifying the main query can be
  83   * problematic and should be avoided wherever possible. In most cases, there are better,
  84   * more performant options for modifying the main query such as via the {@see 'pre_get_posts'}
  85   * action within WP_Query.
  86   *
  87   * This must not be used within the WordPress Loop.
  88   *
  89   * @since 1.5.0
  90   *
  91   * @global WP_Query $wp_query WordPress Query object.
  92   *
  93   * @param array|string $query Array or string of WP_Query arguments.
  94   * @return WP_Post[]|int[] Array of post objects or post IDs.
  95   */
  96  function query_posts( $query ) {
  97      $GLOBALS['wp_query'] = new WP_Query();
  98      return $GLOBALS['wp_query']->query( $query );
  99  }
 100  
 101  /**
 102   * Destroys the previous query and sets up a new query.
 103   *
 104   * This should be used after query_posts() and before another query_posts().
 105   * This will remove obscure bugs that occur when the previous WP_Query object
 106   * is not destroyed properly before another is set up.
 107   *
 108   * @since 2.3.0
 109   *
 110   * @global WP_Query $wp_query     WordPress Query object.
 111   * @global WP_Query $wp_the_query Copy of the global WP_Query instance created during wp_reset_query().
 112   */
 113  function wp_reset_query() {
 114      $GLOBALS['wp_query'] = $GLOBALS['wp_the_query'];
 115      wp_reset_postdata();
 116  }
 117  
 118  /**
 119   * After looping through a separate query, this function restores
 120   * the $post global to the current post in the main query.
 121   *
 122   * @since 3.0.0
 123   *
 124   * @global WP_Query $wp_query WordPress Query object.
 125   */
 126  function wp_reset_postdata() {
 127      global $wp_query;
 128  
 129      if ( isset( $wp_query ) ) {
 130          $wp_query->reset_postdata();
 131      }
 132  }
 133  
 134  /*
 135   * Query type checks.
 136   */
 137  
 138  /**
 139   * Determines whether the query is for an existing archive page.
 140   *
 141   * Archive pages include category, tag, author, date, custom post type,
 142   * and custom taxonomy based archives.
 143   *
 144   * For more information on this and similar theme functions, check out
 145   * the {@link https://developer.wordpress.org/themes/basics/conditional-tags/
 146   * Conditional Tags} article in the Theme Developer Handbook.
 147   *
 148   * @since 1.5.0
 149   *
 150   * @see is_category()
 151   * @see is_tag()
 152   * @see is_author()
 153   * @see is_date()
 154   * @see is_post_type_archive()
 155   * @see is_tax()
 156   * @global WP_Query $wp_query WordPress Query object.
 157   *
 158   * @return bool Whether the query is for an existing archive page.
 159   */
 160  function is_archive() {
 161      global $wp_query;
 162  
 163      if ( ! isset( $wp_query ) ) {
 164          _doing_it_wrong( __FUNCTION__, __( 'Conditional query tags do not work before the query is run. Before then, they always return false.' ), '3.1.0' );
 165          return false;
 166      }
 167  
 168      return $wp_query->is_archive();
 169  }
 170  
 171  /**
 172   * Determines whether the query is for an existing post type archive page.
 173   *
 174   * For more information on this and similar theme functions, check out
 175   * the {@link https://developer.wordpress.org/themes/basics/conditional-tags/
 176   * Conditional Tags} article in the Theme Developer Handbook.
 177   *
 178   * @since 3.1.0
 179   *
 180   * @global WP_Query $wp_query WordPress Query object.
 181   *
 182   * @param string|string[] $post_types Optional. Post type or array of posts types
 183   *                                    to check against. Default empty.
 184   * @return bool Whether the query is for an existing post type archive page.
 185   */
 186  function is_post_type_archive( $post_types = '' ) {
 187      global $wp_query;
 188  
 189      if ( ! isset( $wp_query ) ) {
 190          _doing_it_wrong( __FUNCTION__, __( 'Conditional query tags do not work before the query is run. Before then, they always return false.' ), '3.1.0' );
 191          return false;
 192      }
 193  
 194      return $wp_query->is_post_type_archive( $post_types );
 195  }
 196  
 197  /**
 198   * Determines whether the query is for an existing attachment page.
 199   *
 200   * For more information on this and similar theme functions, check out
 201   * the {@link https://developer.wordpress.org/themes/basics/conditional-tags/
 202   * Conditional Tags} article in the Theme Developer Handbook.
 203   *
 204   * @since 2.0.0
 205   *
 206   * @global WP_Query $wp_query WordPress Query object.
 207   *
 208   * @param int|string|int[]|string[] $attachment Optional. Attachment ID, title, slug, or array of such
 209   *                                              to check against. Default empty.
 210   * @return bool Whether the query is for an existing attachment page.
 211   */
 212  function is_attachment( $attachment = '' ) {
 213      global $wp_query;
 214  
 215      if ( ! isset( $wp_query ) ) {
 216          _doing_it_wrong( __FUNCTION__, __( 'Conditional query tags do not work before the query is run. Before then, they always return false.' ), '3.1.0' );
 217          return false;
 218      }
 219  
 220      return $wp_query->is_attachment( $attachment );
 221  }
 222  
 223  /**
 224   * Determines whether the query is for an existing author archive page.
 225   *
 226   * If the $author parameter is specified, this function will additionally
 227   * check if the query is for one of the authors specified.
 228   *
 229   * For more information on this and similar theme functions, check out
 230   * the {@link https://developer.wordpress.org/themes/basics/conditional-tags/
 231   * Conditional Tags} article in the Theme Developer Handbook.
 232   *
 233   * @since 1.5.0
 234   *
 235   * @global WP_Query $wp_query WordPress Query object.
 236   *
 237   * @param int|string|int[]|string[] $author Optional. User ID, nickname, nicename, or array of such
 238   *                                          to check against. Default empty.
 239   * @return bool Whether the query is for an existing author archive page.
 240   */
 241  function is_author( $author = '' ) {
 242      global $wp_query;
 243  
 244      if ( ! isset( $wp_query ) ) {
 245          _doing_it_wrong( __FUNCTION__, __( 'Conditional query tags do not work before the query is run. Before then, they always return false.' ), '3.1.0' );
 246          return false;
 247      }
 248  
 249      return $wp_query->is_author( $author );
 250  }
 251  
 252  /**
 253   * Determines whether the query is for an existing category archive page.
 254   *
 255   * If the $category parameter is specified, this function will additionally
 256   * check if the query is for one of the categories specified.
 257   *
 258   * For more information on this and similar theme functions, check out
 259   * the {@link https://developer.wordpress.org/themes/basics/conditional-tags/
 260   * Conditional Tags} article in the Theme Developer Handbook.
 261   *
 262   * @since 1.5.0
 263   *
 264   * @global WP_Query $wp_query WordPress Query object.
 265   *
 266   * @param int|string|int[]|string[] $category Optional. Category ID, name, slug, or array of such
 267   *                                            to check against. Default empty.
 268   * @return bool Whether the query is for an existing category archive page.
 269   */
 270  function is_category( $category = '' ) {
 271      global $wp_query;
 272  
 273      if ( ! isset( $wp_query ) ) {
 274          _doing_it_wrong( __FUNCTION__, __( 'Conditional query tags do not work before the query is run. Before then, they always return false.' ), '3.1.0' );
 275          return false;
 276      }
 277  
 278      return $wp_query->is_category( $category );
 279  }
 280  
 281  /**
 282   * Determines whether the query is for an existing tag archive page.
 283   *
 284   * If the $tag parameter is specified, this function will additionally
 285   * check if the query is for one of the tags specified.
 286   *
 287   * For more information on this and similar theme functions, check out
 288   * the {@link https://developer.wordpress.org/themes/basics/conditional-tags/
 289   * Conditional Tags} article in the Theme Developer Handbook.
 290   *
 291   * @since 2.3.0
 292   *
 293   * @global WP_Query $wp_query WordPress Query object.
 294   *
 295   * @param int|string|int[]|string[] $tag Optional. Tag ID, name, slug, or array of such
 296   *                                       to check against. Default empty.
 297   * @return bool Whether the query is for an existing tag archive page.
 298   */
 299  function is_tag( $tag = '' ) {
 300      global $wp_query;
 301  
 302      if ( ! isset( $wp_query ) ) {
 303          _doing_it_wrong( __FUNCTION__, __( 'Conditional query tags do not work before the query is run. Before then, they always return false.' ), '3.1.0' );
 304          return false;
 305      }
 306  
 307      return $wp_query->is_tag( $tag );
 308  }
 309  
 310  /**
 311   * Determines whether the query is for an existing custom taxonomy archive page.
 312   *
 313   * If the $taxonomy parameter is specified, this function will additionally
 314   * check if the query is for that specific $taxonomy.
 315   *
 316   * If the $term parameter is specified in addition to the $taxonomy parameter,
 317   * this function will additionally check if the query is for one of the terms
 318   * specified.
 319   *
 320   * For more information on this and similar theme functions, check out
 321   * the {@link https://developer.wordpress.org/themes/basics/conditional-tags/
 322   * Conditional Tags} article in the Theme Developer Handbook.
 323   *
 324   * @since 2.5.0
 325   *
 326   * @global WP_Query $wp_query WordPress Query object.
 327   *
 328   * @param string|string[]           $taxonomy Optional. Taxonomy slug or slugs to check against.
 329   *                                            Default empty.
 330   * @param int|string|int[]|string[] $term     Optional. Term ID, name, slug, or array of such
 331   *                                            to check against. Default empty.
 332   * @return bool Whether the query is for an existing custom taxonomy archive page.
 333   *              True for custom taxonomy archive pages, false for built-in taxonomies
 334   *              (category and tag archives).
 335   */
 336  function is_tax( $taxonomy = '', $term = '' ) {
 337      global $wp_query;
 338  
 339      if ( ! isset( $wp_query ) ) {
 340          _doing_it_wrong( __FUNCTION__, __( 'Conditional query tags do not work before the query is run. Before then, they always return false.' ), '3.1.0' );
 341          return false;
 342      }
 343  
 344      return $wp_query->is_tax( $taxonomy, $term );
 345  }
 346  
 347  /**
 348   * Determines whether the query is for an existing date archive.
 349   *
 350   * For more information on this and similar theme functions, check out
 351   * the {@link https://developer.wordpress.org/themes/basics/conditional-tags/
 352   * Conditional Tags} article in the Theme Developer Handbook.
 353   *
 354   * @since 1.5.0
 355   *
 356   * @global WP_Query $wp_query WordPress Query object.
 357   *
 358   * @return bool Whether the query is for an existing date archive.
 359   */
 360  function is_date() {
 361      global $wp_query;
 362  
 363      if ( ! isset( $wp_query ) ) {
 364          _doing_it_wrong( __FUNCTION__, __( 'Conditional query tags do not work before the query is run. Before then, they always return false.' ), '3.1.0' );
 365          return false;
 366      }
 367  
 368      return $wp_query->is_date();
 369  }
 370  
 371  /**
 372   * Determines whether the query is for an existing day archive.
 373   *
 374   * A conditional check to test whether the page is a date-based archive page displaying posts for the current day.
 375   *
 376   * For more information on this and similar theme functions, check out
 377   * the {@link https://developer.wordpress.org/themes/basics/conditional-tags/
 378   * Conditional Tags} article in the Theme Developer Handbook.
 379   *
 380   * @since 1.5.0
 381   *
 382   * @global WP_Query $wp_query WordPress Query object.
 383   *
 384   * @return bool Whether the query is for an existing day archive.
 385   */
 386  function is_day() {
 387      global $wp_query;
 388  
 389      if ( ! isset( $wp_query ) ) {
 390          _doing_it_wrong( __FUNCTION__, __( 'Conditional query tags do not work before the query is run. Before then, they always return false.' ), '3.1.0' );
 391          return false;
 392      }
 393  
 394      return $wp_query->is_day();
 395  }
 396  
 397  /**
 398   * Determines whether the query is for a feed.
 399   *
 400   * For more information on this and similar theme functions, check out
 401   * the {@link https://developer.wordpress.org/themes/basics/conditional-tags/
 402   * Conditional Tags} article in the Theme Developer Handbook.
 403   *
 404   * @since 1.5.0
 405   *
 406   * @global WP_Query $wp_query WordPress Query object.
 407   *
 408   * @param string|string[] $feeds Optional. Feed type or array of feed types
 409   *                                         to check against. Default empty.
 410   * @return bool Whether the query is for a feed.
 411   */
 412  function is_feed( $feeds = '' ) {
 413      global $wp_query;
 414  
 415      if ( ! isset( $wp_query ) ) {
 416          _doing_it_wrong( __FUNCTION__, __( 'Conditional query tags do not work before the query is run. Before then, they always return false.' ), '3.1.0' );
 417          return false;
 418      }
 419  
 420      return $wp_query->is_feed( $feeds );
 421  }
 422  
 423  /**
 424   * Is the query for a comments feed?
 425   *
 426   * @since 3.0.0
 427   *
 428   * @global WP_Query $wp_query WordPress Query object.
 429   *
 430   * @return bool Whether the query is for a comments feed.
 431   */
 432  function is_comment_feed() {
 433      global $wp_query;
 434  
 435      if ( ! isset( $wp_query ) ) {
 436          _doing_it_wrong( __FUNCTION__, __( 'Conditional query tags do not work before the query is run. Before then, they always return false.' ), '3.1.0' );
 437          return false;
 438      }
 439  
 440      return $wp_query->is_comment_feed();
 441  }
 442  
 443  /**
 444   * Determines whether the query is for the front page of the site.
 445   *
 446   * This is for what is displayed at your site's main URL.
 447   *
 448   * Depends on the site's "Front page displays" Reading Settings 'show_on_front' and 'page_on_front'.
 449   *
 450   * If you set a static page for the front page of your site, this function will return
 451   * true when viewing that page.
 452   *
 453   * Otherwise the same as @see is_home()
 454   *
 455   * For more information on this and similar theme functions, check out
 456   * the {@link https://developer.wordpress.org/themes/basics/conditional-tags/
 457   * Conditional Tags} article in the Theme Developer Handbook.
 458   *
 459   * @since 2.5.0
 460   *
 461   * @global WP_Query $wp_query WordPress Query object.
 462   *
 463   * @return bool Whether the query is for the front page of the site.
 464   */
 465  function is_front_page() {
 466      global $wp_query;
 467  
 468      if ( ! isset( $wp_query ) ) {
 469          _doing_it_wrong( __FUNCTION__, __( 'Conditional query tags do not work before the query is run. Before then, they always return false.' ), '3.1.0' );
 470          return false;
 471      }
 472  
 473      return $wp_query->is_front_page();
 474  }
 475  
 476  /**
 477   * Determines whether the query is for the blog homepage.
 478   *
 479   * The blog homepage is the page that shows the time-based blog content of the site.
 480   *
 481   * is_home() is dependent on the site's "Front page displays" Reading Settings 'show_on_front'
 482   * and 'page_for_posts'.
 483   *
 484   * If a static page is set for the front page of the site, this function will return true only
 485   * on the page you set as the "Posts page".
 486   *
 487   * For more information on this and similar theme functions, check out
 488   * the {@link https://developer.wordpress.org/themes/basics/conditional-tags/
 489   * Conditional Tags} article in the Theme Developer Handbook.
 490   *
 491   * @since 1.5.0
 492   *
 493   * @see is_front_page()
 494   * @global WP_Query $wp_query WordPress Query object.
 495   *
 496   * @return bool Whether the query is for the blog homepage.
 497   */
 498  function is_home() {
 499      global $wp_query;
 500  
 501      if ( ! isset( $wp_query ) ) {
 502          _doing_it_wrong( __FUNCTION__, __( 'Conditional query tags do not work before the query is run. Before then, they always return false.' ), '3.1.0' );
 503          return false;
 504      }
 505  
 506      return $wp_query->is_home();
 507  }
 508  
 509  /**
 510   * Determines whether the query is for the Privacy Policy page.
 511   *
 512   * The Privacy Policy page is the page that shows the Privacy Policy content of the site.
 513   *
 514   * is_privacy_policy() is dependent on the site's "Change your Privacy Policy page" Privacy Settings 'wp_page_for_privacy_policy'.
 515   *
 516   * This function will return true only on the page you set as the "Privacy Policy page".
 517   *
 518   * For more information on this and similar theme functions, check out
 519   * the {@link https://developer.wordpress.org/themes/basics/conditional-tags/
 520   * Conditional Tags} article in the Theme Developer Handbook.
 521   *
 522   * @since 5.2.0
 523   *
 524   * @global WP_Query $wp_query WordPress Query object.
 525   *
 526   * @return bool Whether the query is for the Privacy Policy page.
 527   */
 528  function is_privacy_policy() {
 529      global $wp_query;
 530  
 531      if ( ! isset( $wp_query ) ) {
 532          _doing_it_wrong( __FUNCTION__, __( 'Conditional query tags do not work before the query is run. Before then, they always return false.' ), '3.1.0' );
 533          return false;
 534      }
 535  
 536      return $wp_query->is_privacy_policy();
 537  }
 538  
 539  /**
 540   * Determines whether the query is for an existing month archive.
 541   *
 542   * For more information on this and similar theme functions, check out
 543   * the {@link https://developer.wordpress.org/themes/basics/conditional-tags/
 544   * Conditional Tags} article in the Theme Developer Handbook.
 545   *
 546   * @since 1.5.0
 547   *
 548   * @global WP_Query $wp_query WordPress Query object.
 549   *
 550   * @return bool Whether the query is for an existing month archive.
 551   */
 552  function is_month() {
 553      global $wp_query;
 554  
 555      if ( ! isset( $wp_query ) ) {
 556          _doing_it_wrong( __FUNCTION__, __( 'Conditional query tags do not work before the query is run. Before then, they always return false.' ), '3.1.0' );
 557          return false;
 558      }
 559  
 560      return $wp_query->is_month();
 561  }
 562  
 563  /**
 564   * Determines whether the query is for an existing single page.
 565   *
 566   * If the $page parameter is specified, this function will additionally
 567   * check if the query is for one of the pages specified.
 568   *
 569   * For more information on this and similar theme functions, check out
 570   * the {@link https://developer.wordpress.org/themes/basics/conditional-tags/
 571   * Conditional Tags} article in the Theme Developer Handbook.
 572   *
 573   * @since 1.5.0
 574   *
 575   * @see is_single()
 576   * @see is_singular()
 577   * @global WP_Query $wp_query WordPress Query object.
 578   *
 579   * @param int|string|int[]|string[] $page Optional. Page ID, title, slug, or array of such
 580   *                                        to check against. Default empty.
 581   * @return bool Whether the query is for an existing single page.
 582   */
 583  function is_page( $page = '' ) {
 584      global $wp_query;
 585  
 586      if ( ! isset( $wp_query ) ) {
 587          _doing_it_wrong( __FUNCTION__, __( 'Conditional query tags do not work before the query is run. Before then, they always return false.' ), '3.1.0' );
 588          return false;
 589      }
 590  
 591      return $wp_query->is_page( $page );
 592  }
 593  
 594  /**
 595   * Determines whether the query is for a paged result and not for the first page.
 596   *
 597   * For more information on this and similar theme functions, check out
 598   * the {@link https://developer.wordpress.org/themes/basics/conditional-tags/
 599   * Conditional Tags} article in the Theme Developer Handbook.
 600   *
 601   * @since 1.5.0
 602   *
 603   * @global WP_Query $wp_query WordPress Query object.
 604   *
 605   * @return bool Whether the query is for a paged result.
 606   */
 607  function is_paged() {
 608      global $wp_query;
 609  
 610      if ( ! isset( $wp_query ) ) {
 611          _doing_it_wrong( __FUNCTION__, __( 'Conditional query tags do not work before the query is run. Before then, they always return false.' ), '3.1.0' );
 612          return false;
 613      }
 614  
 615      return $wp_query->is_paged();
 616  }
 617  
 618  /**
 619   * Determines whether the query is for a post or page preview.
 620   *
 621   * For more information on this and similar theme functions, check out
 622   * the {@link https://developer.wordpress.org/themes/basics/conditional-tags/
 623   * Conditional Tags} article in the Theme Developer Handbook.
 624   *
 625   * @since 2.0.0
 626   *
 627   * @global WP_Query $wp_query WordPress Query object.
 628   *
 629   * @return bool Whether the query is for a post or page preview.
 630   */
 631  function is_preview() {
 632      global $wp_query;
 633  
 634      if ( ! isset( $wp_query ) ) {
 635          _doing_it_wrong( __FUNCTION__, __( 'Conditional query tags do not work before the query is run. Before then, they always return false.' ), '3.1.0' );
 636          return false;
 637      }
 638  
 639      return $wp_query->is_preview();
 640  }
 641  
 642  /**
 643   * Is the query for the robots.txt file?
 644   *
 645   * @since 2.1.0
 646   *
 647   * @global WP_Query $wp_query WordPress Query object.
 648   *
 649   * @return bool Whether the query is for the robots.txt file.
 650   */
 651  function is_robots() {
 652      global $wp_query;
 653  
 654      if ( ! isset( $wp_query ) ) {
 655          _doing_it_wrong( __FUNCTION__, __( 'Conditional query tags do not work before the query is run. Before then, they always return false.' ), '3.1.0' );
 656          return false;
 657      }
 658  
 659      return $wp_query->is_robots();
 660  }
 661  
 662  /**
 663   * Is the query for the favicon.ico file?
 664   *
 665   * @since 5.4.0
 666   *
 667   * @global WP_Query $wp_query WordPress Query object.
 668   *
 669   * @return bool Whether the query is for the favicon.ico file.
 670   */
 671  function is_favicon() {
 672      global $wp_query;
 673  
 674      if ( ! isset( $wp_query ) ) {
 675          _doing_it_wrong( __FUNCTION__, __( 'Conditional query tags do not work before the query is run. Before then, they always return false.' ), '3.1.0' );
 676          return false;
 677      }
 678  
 679      return $wp_query->is_favicon();
 680  }
 681  
 682  /**
 683   * Determines whether the query is for a search.
 684   *
 685   * For more information on this and similar theme functions, check out
 686   * the {@link https://developer.wordpress.org/themes/basics/conditional-tags/
 687   * Conditional Tags} article in the Theme Developer Handbook.
 688   *
 689   * @since 1.5.0
 690   *
 691   * @global WP_Query $wp_query WordPress Query object.
 692   *
 693   * @return bool Whether the query is for a search.
 694   */
 695  function is_search() {
 696      global $wp_query;
 697  
 698      if ( ! isset( $wp_query ) ) {
 699          _doing_it_wrong( __FUNCTION__, __( 'Conditional query tags do not work before the query is run. Before then, they always return false.' ), '3.1.0' );
 700          return false;
 701      }
 702  
 703      return $wp_query->is_search();
 704  }
 705  
 706  /**
 707   * Determines whether the query is for an existing single post.
 708   *
 709   * Works for any post type, except attachments and pages
 710   *
 711   * If the $post parameter is specified, this function will additionally
 712   * check if the query is for one of the Posts specified.
 713   *
 714   * For more information on this and similar theme functions, check out
 715   * the {@link https://developer.wordpress.org/themes/basics/conditional-tags/
 716   * Conditional Tags} article in the Theme Developer Handbook.
 717   *
 718   * @since 1.5.0
 719   *
 720   * @see is_page()
 721   * @see is_singular()
 722   * @global WP_Query $wp_query WordPress Query object.
 723   *
 724   * @param int|string|int[]|string[] $post Optional. Post ID, title, slug, or array of such
 725   *                                        to check against. Default empty.
 726   * @return bool Whether the query is for an existing single post.
 727   */
 728  function is_single( $post = '' ) {
 729      global $wp_query;
 730  
 731      if ( ! isset( $wp_query ) ) {
 732          _doing_it_wrong( __FUNCTION__, __( 'Conditional query tags do not work before the query is run. Before then, they always return false.' ), '3.1.0' );
 733          return false;
 734      }
 735  
 736      return $wp_query->is_single( $post );
 737  }
 738  
 739  /**
 740   * Determines whether the query is for an existing single post of any post type
 741   * (post, attachment, page, custom post types).
 742   *
 743   * If the $post_types parameter is specified, this function will additionally
 744   * check if the query is for one of the Posts Types specified.
 745   *
 746   * For more information on this and similar theme functions, check out
 747   * the {@link https://developer.wordpress.org/themes/basics/conditional-tags/
 748   * Conditional Tags} article in the Theme Developer Handbook.
 749   *
 750   * @since 1.5.0
 751   *
 752   * @see is_page()
 753   * @see is_single()
 754   * @global WP_Query $wp_query WordPress Query object.
 755   *
 756   * @param string|string[] $post_types Optional. Post type or array of post types
 757   *                                    to check against. Default empty.
 758   * @return bool Whether the query is for an existing single post
 759   *              or any of the given post types.
 760   */
 761  function is_singular( $post_types = '' ) {
 762      global $wp_query;
 763  
 764      if ( ! isset( $wp_query ) ) {
 765          _doing_it_wrong( __FUNCTION__, __( 'Conditional query tags do not work before the query is run. Before then, they always return false.' ), '3.1.0' );
 766          return false;
 767      }
 768  
 769      return $wp_query->is_singular( $post_types );
 770  }
 771  
 772  /**
 773   * Determines whether the query is for a specific time.
 774   *
 775   * For more information on this and similar theme functions, check out
 776   * the {@link https://developer.wordpress.org/themes/basics/conditional-tags/
 777   * Conditional Tags} article in the Theme Developer Handbook.
 778   *
 779   * @since 1.5.0
 780   *
 781   * @global WP_Query $wp_query WordPress Query object.
 782   *
 783   * @return bool Whether the query is for a specific time.
 784   */
 785  function is_time() {
 786      global $wp_query;
 787  
 788      if ( ! isset( $wp_query ) ) {
 789          _doing_it_wrong( __FUNCTION__, __( 'Conditional query tags do not work before the query is run. Before then, they always return false.' ), '3.1.0' );
 790          return false;
 791      }
 792  
 793      return $wp_query->is_time();
 794  }
 795  
 796  /**
 797   * Determines whether the query is for a trackback endpoint call.
 798   *
 799   * For more information on this and similar theme functions, check out
 800   * the {@link https://developer.wordpress.org/themes/basics/conditional-tags/
 801   * Conditional Tags} article in the Theme Developer Handbook.
 802   *
 803   * @since 1.5.0
 804   *
 805   * @global WP_Query $wp_query WordPress Query object.
 806   *
 807   * @return bool Whether the query is for a trackback endpoint call.
 808   */
 809  function is_trackback() {
 810      global $wp_query;
 811  
 812      if ( ! isset( $wp_query ) ) {
 813          _doing_it_wrong( __FUNCTION__, __( 'Conditional query tags do not work before the query is run. Before then, they always return false.' ), '3.1.0' );
 814          return false;
 815      }
 816  
 817      return $wp_query->is_trackback();
 818  }
 819  
 820  /**
 821   * Determines whether the query is for an existing year archive.
 822   *
 823   * For more information on this and similar theme functions, check out
 824   * the {@link https://developer.wordpress.org/themes/basics/conditional-tags/
 825   * Conditional Tags} article in the Theme Developer Handbook.
 826   *
 827   * @since 1.5.0
 828   *
 829   * @global WP_Query $wp_query WordPress Query object.
 830   *
 831   * @return bool Whether the query is for an existing year archive.
 832   */
 833  function is_year() {
 834      global $wp_query;
 835  
 836      if ( ! isset( $wp_query ) ) {
 837          _doing_it_wrong( __FUNCTION__, __( 'Conditional query tags do not work before the query is run. Before then, they always return false.' ), '3.1.0' );
 838          return false;
 839      }
 840  
 841      return $wp_query->is_year();
 842  }
 843  
 844  /**
 845   * Determines whether the query has resulted in a 404 (returns no results).
 846   *
 847   * For more information on this and similar theme functions, check out
 848   * the {@link https://developer.wordpress.org/themes/basics/conditional-tags/
 849   * Conditional Tags} article in the Theme Developer Handbook.
 850   *
 851   * @since 1.5.0
 852   *
 853   * @global WP_Query $wp_query WordPress Query object.
 854   *
 855   * @return bool Whether the query is a 404 error.
 856   */
 857  function is_404() {
 858      global $wp_query;
 859  
 860      if ( ! isset( $wp_query ) ) {
 861          _doing_it_wrong( __FUNCTION__, __( 'Conditional query tags do not work before the query is run. Before then, they always return false.' ), '3.1.0' );
 862          return false;
 863      }
 864  
 865      return $wp_query->is_404();
 866  }
 867  
 868  /**
 869   * Is the query for an embedded post?
 870   *
 871   * @since 4.4.0
 872   *
 873   * @global WP_Query $wp_query WordPress Query object.
 874   *
 875   * @return bool Whether the query is for an embedded post.
 876   */
 877  function is_embed() {
 878      global $wp_query;
 879  
 880      if ( ! isset( $wp_query ) ) {
 881          _doing_it_wrong( __FUNCTION__, __( 'Conditional query tags do not work before the query is run. Before then, they always return false.' ), '3.1.0' );
 882          return false;
 883      }
 884  
 885      return $wp_query->is_embed();
 886  }
 887  
 888  /**
 889   * Determines whether the query is the main query.
 890   *
 891   * For more information on this and similar theme functions, check out
 892   * the {@link https://developer.wordpress.org/themes/basics/conditional-tags/
 893   * Conditional Tags} article in the Theme Developer Handbook.
 894   *
 895   * @since 3.3.0
 896   *
 897   * @global WP_Query $wp_query WordPress Query object.
 898   *
 899   * @return bool Whether the query is the main query.
 900   */
 901  function is_main_query() {
 902      global $wp_query;
 903  
 904      if ( 'pre_get_posts' === current_filter() ) {
 905          _doing_it_wrong(
 906              __FUNCTION__,
 907              sprintf(
 908                  /* translators: 1: pre_get_posts, 2: WP_Query->is_main_query(), 3: is_main_query(), 4: Documentation URL. */
 909                  __( 'In %1$s, use the %2$s method, not the %3$s function. See %4$s.' ),
 910                  '<code>pre_get_posts</code>',
 911                  '<code>WP_Query->is_main_query()</code>',
 912                  '<code>is_main_query()</code>',
 913                  __( 'https://developer.wordpress.org/reference/functions/is_main_query/' )
 914              ),
 915              '3.7.0'
 916          );
 917      }
 918  
 919      return $wp_query->is_main_query();
 920  }
 921  
 922  /*
 923   * The Loop. Post loop control.
 924   */
 925  
 926  /**
 927   * Determines whether current WordPress query has posts to loop over.
 928   *
 929   * @since 1.5.0
 930   *
 931   * @global WP_Query $wp_query WordPress Query object.
 932   *
 933   * @return bool True if posts are available, false if end of the loop.
 934   */
 935  function have_posts() {
 936      global $wp_query;
 937      return $wp_query->have_posts();
 938  }
 939  
 940  /**
 941   * Determines whether the caller is in the Loop.
 942   *
 943   * For more information on this and similar theme functions, check out
 944   * the {@link https://developer.wordpress.org/themes/basics/conditional-tags/
 945   * Conditional Tags} article in the Theme Developer Handbook.
 946   *
 947   * @since 2.0.0
 948   *
 949   * @global WP_Query $wp_query WordPress Query object.
 950   *
 951   * @return bool True if caller is within loop, false if loop hasn't started or ended.
 952   */
 953  function in_the_loop() {
 954      global $wp_query;
 955      return $wp_query->in_the_loop;
 956  }
 957  
 958  /**
 959   * Rewind the loop posts.
 960   *
 961   * @since 1.5.0
 962   *
 963   * @global WP_Query $wp_query WordPress Query object.
 964   */
 965  function rewind_posts() {
 966      global $wp_query;
 967      $wp_query->rewind_posts();
 968  }
 969  
 970  /**
 971   * Iterate the post index in the loop.
 972   *
 973   * @since 1.5.0
 974   *
 975   * @global WP_Query $wp_query WordPress Query object.
 976   */
 977  function the_post() {
 978      global $wp_query;
 979      $wp_query->the_post();
 980  }
 981  
 982  /*
 983   * Comments loop.
 984   */
 985  
 986  /**
 987   * Determines whether current WordPress query has comments to loop over.
 988   *
 989   * @since 2.2.0
 990   *
 991   * @global WP_Query $wp_query WordPress Query object.
 992   *
 993   * @return bool True if comments are available, false if no more comments.
 994   */
 995  function have_comments() {
 996      global $wp_query;
 997      return $wp_query->have_comments();
 998  }
 999  
1000  /**
1001   * Iterate comment index in the comment loop.
1002   *
1003   * @since 2.2.0
1004   *
1005   * @global WP_Query $wp_query WordPress Query object.
1006   *
1007   * @return null
1008   */
1009  function the_comment() {
1010      global $wp_query;
1011      return $wp_query->the_comment();
1012  }
1013  
1014  /**
1015   * Redirect old slugs to the correct permalink.
1016   *
1017   * Attempts to find the current slug from the past slugs.
1018   *
1019   * @since 2.1.0
1020   */
1021  function wp_old_slug_redirect() {
1022      if ( is_404() && '' !== get_query_var( 'name' ) ) {
1023          // Guess the current post type based on the query vars.
1024          if ( get_query_var( 'post_type' ) ) {
1025              $post_type = get_query_var( 'post_type' );
1026          } elseif ( get_query_var( 'attachment' ) ) {
1027              $post_type = 'attachment';
1028          } elseif ( get_query_var( 'pagename' ) ) {
1029              $post_type = 'page';
1030          } else {
1031              $post_type = 'post';
1032          }
1033  
1034          if ( is_array( $post_type ) ) {
1035              if ( count( $post_type ) > 1 ) {
1036                  return;
1037              }
1038              $post_type = reset( $post_type );
1039          }
1040  
1041          // Do not attempt redirect for hierarchical post types.
1042          if ( is_post_type_hierarchical( $post_type ) ) {
1043              return;
1044          }
1045  
1046          $id = _find_post_by_old_slug( $post_type );
1047  
1048          if ( ! $id ) {
1049              $id = _find_post_by_old_date( $post_type );
1050          }
1051  
1052          /**
1053           * Filters the old slug redirect post ID.
1054           *
1055           * @since 4.9.3
1056           *
1057           * @param int $id The redirect post ID.
1058           */
1059          $id = apply_filters( 'old_slug_redirect_post_id', $id );
1060  
1061          if ( ! $id ) {
1062              return;
1063          }
1064  
1065          $link = get_permalink( $id );
1066  
1067          if ( get_query_var( 'paged' ) > 1 ) {
1068              $link = user_trailingslashit( trailingslashit( $link ) . 'page/' . get_query_var( 'paged' ) );
1069          } elseif ( is_embed() ) {
1070              $link = user_trailingslashit( trailingslashit( $link ) . 'embed' );
1071          }
1072  
1073          /**
1074           * Filters the old slug redirect URL.
1075           *
1076           * @since 4.4.0
1077           *
1078           * @param string $link The redirect URL.
1079           */
1080          $link = apply_filters( 'old_slug_redirect_url', $link );
1081  
1082          if ( ! $link ) {
1083              return;
1084          }
1085  
1086          wp_redirect( $link, 301 ); // Permanent redirect.
1087          exit;
1088      }
1089  }
1090  
1091  /**
1092   * Find the post ID for redirecting an old slug.
1093   *
1094   * @since 4.9.3
1095   * @access private
1096   *
1097   * @see wp_old_slug_redirect()
1098   * @global wpdb $wpdb WordPress database abstraction object.
1099   *
1100   * @param string $post_type The current post type based on the query vars.
1101   * @return int The Post ID.
1102   */
1103  function _find_post_by_old_slug( $post_type ) {
1104      global $wpdb;
1105  
1106      $query = $wpdb->prepare( "SELECT post_id FROM $wpdb->postmeta, $wpdb->posts WHERE ID = post_id AND post_type = %s AND meta_key = '_wp_old_slug' AND meta_value = %s", $post_type, get_query_var( 'name' ) );
1107  
1108      // If year, monthnum, or day have been specified, make our query more precise
1109      // just in case there are multiple identical _wp_old_slug values.
1110      if ( get_query_var( 'year' ) ) {
1111          $query .= $wpdb->prepare( ' AND YEAR(post_date) = %d', get_query_var( 'year' ) );
1112      }
1113      if ( get_query_var( 'monthnum' ) ) {
1114          $query .= $wpdb->prepare( ' AND MONTH(post_date) = %d', get_query_var( 'monthnum' ) );
1115      }
1116      if ( get_query_var( 'day' ) ) {
1117          $query .= $wpdb->prepare( ' AND DAYOFMONTH(post_date) = %d', get_query_var( 'day' ) );
1118      }
1119  
1120      $id = (int) $wpdb->get_var( $query );
1121  
1122      return $id;
1123  }
1124  
1125  /**
1126   * Find the post ID for redirecting an old date.
1127   *
1128   * @since 4.9.3
1129   * @access private
1130   *
1131   * @see wp_old_slug_redirect()
1132   * @global wpdb $wpdb WordPress database abstraction object.
1133   *
1134   * @param string $post_type The current post type based on the query vars.
1135   * @return int The Post ID.
1136   */
1137  function _find_post_by_old_date( $post_type ) {
1138      global $wpdb;
1139  
1140      $date_query = '';
1141      if ( get_query_var( 'year' ) ) {
1142          $date_query .= $wpdb->prepare( ' AND YEAR(pm_date.meta_value) = %d', get_query_var( 'year' ) );
1143      }
1144      if ( get_query_var( 'monthnum' ) ) {
1145          $date_query .= $wpdb->prepare( ' AND MONTH(pm_date.meta_value) = %d', get_query_var( 'monthnum' ) );
1146      }
1147      if ( get_query_var( 'day' ) ) {
1148          $date_query .= $wpdb->prepare( ' AND DAYOFMONTH(pm_date.meta_value) = %d', get_query_var( 'day' ) );
1149      }
1150  
1151      $id = 0;
1152      if ( $date_query ) {
1153          $id = (int) $wpdb->get_var( $wpdb->prepare( "SELECT post_id FROM $wpdb->postmeta AS pm_date, $wpdb->posts WHERE ID = post_id AND post_type = %s AND meta_key = '_wp_old_date' AND post_name = %s" . $date_query, $post_type, get_query_var( 'name' ) ) );
1154  
1155          if ( ! $id ) {
1156              // Check to see if an old slug matches the old date.
1157              $id = (int) $wpdb->get_var( $wpdb->prepare( "SELECT ID FROM $wpdb->posts, $wpdb->postmeta AS pm_slug, $wpdb->postmeta AS pm_date WHERE ID = pm_slug.post_id AND ID = pm_date.post_id AND post_type = %s AND pm_slug.meta_key = '_wp_old_slug' AND pm_slug.meta_value = %s AND pm_date.meta_key = '_wp_old_date'" . $date_query, $post_type, get_query_var( 'name' ) ) );
1158          }
1159      }
1160  
1161      return $id;
1162  }
1163  
1164  /**
1165   * Set up global post data.
1166   *
1167   * @since 1.5.0
1168   * @since 4.4.0 Added the ability to pass a post ID to `$post`.
1169   *
1170   * @global WP_Query $wp_query WordPress Query object.
1171   *
1172   * @param WP_Post|object|int $post WP_Post instance or Post ID/object.
1173   * @return bool True when finished.
1174   */
1175  function setup_postdata( $post ) {
1176      global $wp_query;
1177  
1178      if ( ! empty( $wp_query ) && $wp_query instanceof WP_Query ) {
1179          return $wp_query->setup_postdata( $post );
1180      }
1181  
1182      return false;
1183  }
1184  
1185  /**
1186   * Generates post data.
1187   *
1188   * @since 5.2.0
1189   *
1190   * @global WP_Query $wp_query WordPress Query object.
1191   *
1192   * @param WP_Post|object|int $post WP_Post instance or Post ID/object.
1193   * @return array|false Elements of post, or false on failure.
1194   */
1195  function generate_postdata( $post ) {
1196      global $wp_query;
1197  
1198      if ( ! empty( $wp_query ) && $wp_query instanceof WP_Query ) {
1199          return $wp_query->generate_postdata( $post );
1200      }
1201  
1202      return false;
1203  }


Generated: Fri Jan 24 01:00:03 2025 Cross-referenced by PHPXref 0.7.1