Current File : /home/bdmcricketindia.in/public_html/wp-includes/class-wp-metadata-lazyloader.php
<?php
/**
 * Meta API: WP_Metadata_Lazyloader class
 *
 * @package WordPress
 * @subpackage Meta
 * @since 4.5.0
 */

/**
 * Core class used for lazy-loading object metadata.
 *
 * When loading many objects of a given type, such as posts in a WP_Query loop, it often makes
 * sense to prime various metadata caches at the beginning of the loop. This means fetching all
 * relevant metadata with a single database query, a technique that has the potential to improve
 * performance dramatically in some cases.
 *
 * In cases where the given metadata may not even be used in the loop, we can improve performance
 * even more by only priming the metadata cache for affected items the first time a piece of metadata
 * is requested - ie, by lazy-loading it. So, for example, comment meta may not be loaded into the
 * cache in the comments section of a post until the first time get_comment_meta() is called in the
 * context of the comment loop.
 *
 * WP uses the WP_Metadata_Lazyloader class to queue objects for metadata cache priming. The class
 * then detects the relevant get_*_meta() function call, and queries the metadata of all queued objects.
 *
 * Do not access this class directly. Use the wp_metadata_lazyloader() function.
 *
 * @since 4.5.0
 */
#[AllowDynamicProperties]
class WP_Metadata_Lazyloader {
	/**
	 * Pending objects queue.
	 *
	 * @since 4.5.0
	 * @var array
	 */
	protected $pending_objects;

	/**
	 * Settings for supported object types.
	 *
	 * @since 4.5.0
	 * @var array
	 */
	protected $settings = array();

	/**
	 * Constructor.
	 *
	 * @since 4.5.0
	 */
	public function __construct() {
		$this->settings = array(
			'term'    => array(
				'filter'   => 'get_term_metadata',
				'callback' => array( $this, 'lazyload_meta_callback' ),
			),
			'comment' => array(
				'filter'   => 'get_comment_metadata',
				'callback' => array( $this, 'lazyload_meta_callback' ),
			),
			'blog'    => array(
				'filter'   => 'get_blog_metadata',
				'callback' => array( $this, 'lazyload_meta_callback' ),
			),
		);
	}

	/**
	 * Adds objects to the metadata lazy-load queue.
	 *
	 * @since 4.5.0
	 *
	 * @param string $object_type Type of object whose meta is to be lazy-loaded. Accepts 'term' or 'comment'.
	 * @param array  $object_ids  Array of object IDs.
	 * @return void|WP_Error WP_Error on failure.
	 */
	public function queue_objects( $object_type, $object_ids ) {
		if ( ! isset( $this->settings[ $object_type ] ) ) {
			return new WP_Error( 'invalid_object_type', __( 'Invalid object type.' ) );
		}

		$type_settings = $this->settings[ $object_type ];

		if ( ! isset( $this->pending_objects[ $object_type ] ) ) {
			$this->pending_objects[ $object_type ] = array();
		}

		foreach ( $object_ids as $object_id ) {
			// Keyed by ID for faster lookup.
			if ( ! isset( $this->pending_objects[ $object_type ][ $object_id ] ) ) {
				$this->pending_objects[ $object_type ][ $object_id ] = 1;
			}
		}

		add_filter( $type_settings['filter'], $type_settings['callback'], 10, 5 );

		/**
		 * Fires after objects are added to the metadata lazy-load queue.
		 *
		 * @since 4.5.0
		 *
		 * @param array                  $object_ids  Array of object IDs.
		 * @param string                 $object_type Type of object being queued.
		 * @param WP_Metadata_Lazyloader $lazyloader  The lazy-loader object.
		 */
		do_action( 'metadata_lazyloader_queued_objects', $object_ids, $object_type, $this );
	}

	/**
	 * Resets lazy-load queue for a given object type.
	 *
	 * @since 4.5.0
	 *
	 * @param string $object_type Object type. Accepts 'comment' or 'term'.
	 * @return void|WP_Error WP_Error on failure.
	 */
	public function reset_queue( $object_type ) {
		if ( ! isset( $this->settings[ $object_type ] ) ) {
			return new WP_Error( 'invalid_object_type', __( 'Invalid object type.' ) );
		}

		$type_settings = $this->settings[ $object_type ];

		$this->pending_objects[ $object_type ] = array();
		remove_filter( $type_settings['filter'], $type_settings['callback'] );
	}

	/**
	 * Lazy-loads term meta for queued terms.
	 *
	 * This method is public so that it can be used as a filter callback. As a rule, there
	 * is no need to invoke it directly.
	 *
	 * @since 4.5.0
	 * @deprecated 6.3.0 Use WP_Metadata_Lazyloader::lazyload_meta_callback() instead.
	 *
	 * @param mixed $check The `$check` param passed from the 'get_term_metadata' hook.
	 * @return mixed In order not to short-circuit `get_metadata()`. Generally, this is `null`, but it could be
	 *               another value if filtered by a plugin.
	 */
	public function lazyload_term_meta( $check ) {
		_deprecated_function( __METHOD__, '6.3.0', 'WP_Metadata_Lazyloader::lazyload_meta_callback' );
		return $this->lazyload_meta_callback( $check, 0, '', false, 'term' );
	}

	/**
	 * Lazy-loads comment meta for queued comments.
	 *
	 * This method is public so that it can be used as a filter callback. As a rule, there is no need to invoke it
	 * directly, from either inside or outside the `WP_Query` object.
	 *
	 * @since 4.5.0
	 * @deprecated 6.3.0 Use WP_Metadata_Lazyloader::lazyload_meta_callback() instead.
	 *
	 * @param mixed $check The `$check` param passed from the {@see 'get_comment_metadata'} hook.
	 * @return mixed The original value of `$check`, so as not to short-circuit `get_comment_metadata()`.
	 */
	public function lazyload_comment_meta( $check ) {
		_deprecated_function( __METHOD__, '6.3.0', 'WP_Metadata_Lazyloader::lazyload_meta_callback' );
		return $this->lazyload_meta_callback( $check, 0, '', false, 'comment' );
	}

	/**
	 * Lazy-loads meta for queued objects.
	 *
	 * This method is public so that it can be used as a filter callback. As a rule, there
	 * is no need to invoke it directly.
	 *
	 * @since 6.3.0
	 *
	 * @param mixed  $check     The `$check` param passed from the 'get_*_metadata' hook.
	 * @param int    $object_id ID of the object metadata is for.
	 * @param string $meta_key  Unused.
	 * @param bool   $single    Unused.
	 * @param string $meta_type Type of object metadata is for. Accepts 'post', 'comment', 'term', 'user',
	 *                          or any other object type with an associated meta table.
	 * @return mixed In order not to short-circuit `get_metadata()`. Generally, this is `null`, but it could be
	 *               another value if filtered by a plugin.
	 */
	public function lazyload_meta_callback( $check, $object_id, $meta_key, $single, $meta_type ) {
		if ( empty( $this->pending_objects[ $meta_type ] ) ) {
			return $check;
		}

		$object_ids = array_keys( $this->pending_objects[ $meta_type ] );
		if ( $object_id && ! in_array( $object_id, $object_ids, true ) ) {
			$object_ids[] = $object_id;
		}

		update_meta_cache( $meta_type, $object_ids );

		// No need to run again for this set of objects.
		$this->reset_queue( $meta_type );

		return $check;
	}
}
1win — регистрация в букмекерской конторе 1вин.3785

1win — регистрация в букмекерской конторе 1вин.3785

1win — регистрация в букмекерской конторе 1вин

▶️ ИГРАТЬ

Содержимое

В мире ставок и азарта 1вин – это имя, которое ассоциируется с надежностью, быстротой и комфортной игрой. Букмекерская контора 1вин – это место, где можно сделать ставку и получить максимум от игры. Но для начала нужно зарегистрироваться.

Регистрация в 1вин – это процесс, который занимает считанные минуты. Для начала вам нужно перейти на официальный сайт 1вин и кликнуть на кнопку “Зарегистрироваться”. Затем вам нужно ввести свои личные данные, включая имя, фамилию, дату рождения и адрес электронной почты.

Важно! Вам нужно выбрать сложный пароль и подтвердить его. Это обеспечит безопасность вашего аккаунта и предотвратит любые попытки хакерства.

После регистрации вы получите доступ к полному спектру услуг 1вин, включая ставки на спорт, киберспорт, политические события и многое другое. Вы сможете делать ставки, получать бонусы и участвовать в различных акциях и турнирах.

1вин – это место, где можно найти что-то для себя. Букмекерская контора предлагает широкий спектр услуг, чтобы обеспечить комфортную игру для своих клиентов. Регистрация в 1вин – это первый шаг к успеху.

Важно! Регистрация в 1вин – это процесс, который занимает считанные минуты. Не откладывайте регистрацию, и вы сможете начать играть уже сегодня.

1вин – это выбор для тех, кто ищет комфортной игры.

1вин – это выбор для тех, кто ищет успеха.

Шаги регистрации в 1win

Для начала регистрации в 1win вам нужно выполнить несколько простых шагов. Вам нужно зарегистрироваться на официальном сайте 1win, чтобы начать играть и получать бонусы.

Шаг 1: Введите данные для регистрации

Вам нужно ввести свои личные данные, такие как имя, фамилия, дата рождения, адрес электронной почты и телефон. Вам также нужно выбрать пароль для вашего аккаунта.

Шаг 2: Введите код подтверждения

После ввода данных для регистрации вам будет отправлен код подтверждения на ваш электронный адрес или телефон. Вам нужно ввести этот код, чтобы подтвердить свою регистрацию.

Шаг 3: Оформите свой аккаунт

После подтверждения регистрации вам 1win официальный сайт будет доступен доступ к вашему аккаунту. Вам нужно оформить свой аккаунт, выбрав валюту, в которой вы хотите играть, и выбрав тип аккаунта (обычный или VIP).

Шаг 4: Вам будет предложен бонус для новых игроков

После оформления аккаунта вам будет предложен бонус для новых игроков. Бонус может быть в виде дополнительных средств для игры или других преимуществ. Вам нужно принять бонус, чтобы начать играть.

Шаг 5: Начните играть

После принятия бонуса вы можете начать играть в любые игры, которые вам понравились. Вам доступны различные виды игр, включая спортивные события, лото, рулетку и другие.

Шаг 6: Управляйте своим аккаунтом

Вам доступны различные функции для управления вашим аккаунтом, включая возможность смотреть историю своих ставок, изменять пароль и получать информацию о своих счетах.

Как начать играть и получать бонусы в 1win

Для начала вам нужно зарегистрироваться в 1win, если вы еще не сделали это. Регистрация в 1win – это простой и быстрый процесс, который займет не более 5 минут. Вам нужно только ввести свои контактные данные, выбрать пароль и подтвердить регистрацию.

После регистрации вы получите доступ к личному кабинету, где можно будет делать ставки, получать бонусы и следить за своим счетом. Вам нужно только ввести свои логин и пароль, и вы будете готовы начать играть.

В 1win есть несколько типов бонусов, которые вы можете получить. Первый тип – это бонус для новых игроков, который выдается при регистрации. Это бонус в размере 100% от суммы первого депозита, но не более 10 000 рублей. Второй тип – это бонус за депозит, который выдается при каждом депозите. Это бонус в размере 50% от суммы депозита, но не более 5 000 рублей.

Кроме того, в 1win есть и другие бонусы, такие как бонус за участие в турнирах, бонус за приглашение друзей и т.д. Все бонусы имеют свои условия и ограничения, поэтому вам нужно прочитать условия бонуса перед его использованием.

Наконец, в 1win есть и другие функции, которые помогут вам начать играть и получать бонусы. Например, вы можете использовать функцию “Live” для ставок на живые события, или функцию “Line” для ставок на спорт. Вы можете также использовать функцию “Casino” для игры в казино.

Важно! Перед началом игры и получения бонусов, вам нужно прочитать условия и правила 1win, чтобыavoid any misunderstandings and ensure a smooth gaming experience.

Check Also

– Официальный сайт Pinco Casino.1586

Пинко Казино – Официальный сайт Pinco Casino ▶️ ИГРАТЬ Содержимое Преимущества игры на официальном сайте …