PHP 8.2.31
Preview: DeprecatedClassFacade.php Size: 2.30 KB
/home/nshryvcy/himaltourism.com/wp-content/plugins/woocommerce/src/Admin/DeprecatedClassFacade.php

<?php
/**
 * A facade to allow deprecating an entire class. Calling instance or static
 * functions on the facade triggers a deprecation notice before calling the
 * underlying function.
 *
 * Use it by extending DeprecatedClassFacade in your facade class, setting the
 * static $facade_over_classname string to the name of the class to build
 * a facade over, and setting the static $deprecated_in_version to the version
 * that the class was deprecated in. Eg.:
 *
 * class DeprecatedGoose extends DeprecatedClassFacade {
 *     static $facade_over_classname = 'Goose';
 *     static $deprecated_in_version = '1.7.0';
 * }
 */

namespace Automattic\WooCommerce\Admin;

defined( 'ABSPATH' ) || exit;

// phpcs:disable WordPress.Security.EscapeOutput.OutputNotEscaped

/**
 * A facade to allow deprecating an entire class.
 */
class DeprecatedClassFacade {
	/**
	 * The instance that this facade covers over.
	 *
	 * @var object
	 */
	protected $instance;

	/**
	 * Constructor.
	 */
	public function __construct() {
		$this->instance = new static::$facade_over_classname();
	}

	/**
	 * Log a deprecation to the error log.
	 *
	 * @param string $function The name of the deprecated function being called.
	 */
	private static function log_deprecation( $function ) {
		error_log( // phpcs:ignore
			sprintf(
				'%1$s is deprecated since version %2$s! Use %3$s instead.',
				static::class . '::' . $function,
				static::$deprecated_in_version,
				static::$facade_over_classname . '::' . $function
			)
		);
	}

	/**
	 * Executes when calling any function on an instance of this class.
	 *
	 * @param string $name      The name of the function being called.
	 * @param array  $arguments An array of the arguments to the function call.
	 */
	public function __call( $name, $arguments ) {
		self::log_deprecation( $name );

		return call_user_func_array(
			array(
				$this->instance,
				$name,
			),
			$arguments
		);
	}

	/**
	 * Executes when calling any static function on this class.
	 *
	 * @param string $name      The name of the function being called.
	 * @param array  $arguments An array of the arguments to the function call.
	 */
	public static function __callStatic( $name, $arguments ) {
		self::log_deprecation( $name );

		return call_user_func_array(
			array(
				static::$facade_over_classname,
				$name,
			),
			$arguments
		);
	}
}

Directory Contents

Dirs: 10 × Files: 12

Name Size Perms Modified Actions
API DIR
- drwxr-xr-x 2026-03-03 06:10:19
Edit Download
Composer DIR
- drwxr-xr-x 2026-03-03 06:10:19
Edit Download
- drwxr-xr-x 2026-03-03 06:10:19
Edit Download
Features DIR
- drwxr-xr-x 2026-03-03 06:10:19
Edit Download
Marketing DIR
- drwxr-xr-x 2026-03-03 06:10:19
Edit Download
Notes DIR
- drwxr-xr-x 2026-03-03 06:10:19
Edit Download
Overrides DIR
- drwxr-xr-x 2026-03-03 06:10:19
Edit Download
- drwxr-xr-x 2026-03-03 06:10:19
Edit Download
- drwxr-xr-x 2026-03-03 06:10:19
Edit Download
- drwxr-xr-x 2026-03-03 06:10:19
Edit Download
6.00 KB lrw-r--r-- 2026-03-03 06:10:19
Edit Download
2.30 KB lrw-r--r-- 2026-03-03 06:10:19
Edit Download
955 B lrw-r--r-- 2026-03-03 06:10:19
Edit Download
2.69 KB lrw-r--r-- 2026-03-03 06:10:19
Edit Download
16.99 KB lrw-r--r-- 2026-03-03 06:10:19
Edit Download
12.07 KB lrw-r--r-- 2026-03-03 06:10:19
Edit Download
3.36 KB lrw-r--r-- 2026-03-03 06:10:19
Edit Download
3.57 KB lrw-r--r-- 2026-03-03 06:10:19
Edit Download
9.50 KB lrw-r--r-- 2026-03-03 06:10:19
Edit Download
6.28 KB lrw-r--r-- 2026-03-03 06:10:19
Edit Download
5.94 KB lrw-r--r-- 2026-03-03 06:10:19
Edit Download
2.70 KB lrw-r--r-- 2026-03-03 06:10:19
Edit Download

If ZipArchive is unavailable, a .tar will be created (no compression).