WordPress как на ладони
Недорогой хостинг для сайтов на WordPress: wordpress.jino.ru Платформа для конвертации и монетизации трафика
класс не описан

Automattic\Jetpack\Autoloader\jpcd4dc500be73992154ab94f06c9d1b27

Manifest_Handler{} WC 1.0

This class selects the most recent version of a registered path.

Хуков нет.

Возвращает

Null. Ничего.

Использование

$Manifest_Handler = new Manifest_Handler();
// use class methods

Методы

  1. __construct( $active_plugin_paths, $version_selector )
  2. ERROR: no method name found on line ` private $version_selector;`
  3. ERROR: no method name found on line ` private $version_selector;`
  4. register_manifest( $manifest_path, &$path_map )
  5. ERROR: no method name found on line ` }`
  6. ERROR: no method name found on line ` }`
  7. register_plugin_manifests( $manifest_path, &$path_map )
  8. ERROR: no method name found on line ` /**`
  9. ERROR: no method name found on line ` /**`
  10. register_record( $key, $data, &$path_map )
  11. ERROR: no method name found on line ``
  12. ERROR: no method name found on line ``

Код Manifest_Handler{} WC 5.0.0

<?php
class Manifest_Handler {

	/**
	 * An array of the active plugin paths we want to search.
	 *
	 * @var array
	 */
	private $active_plugin_paths;

	/**
	 * The Version_Selector object.
	 *
	 * @var Version_Selector
	 */
	private $version_selector;

	/**
	 * The constructor.
	 *
	 * @param array            $active_plugin_paths An array of the active plugin paths we want to search.
	 * @param Version_Selector $version_selector The Version_Selector object.
	 */
	public function __construct( $active_plugin_paths, $version_selector ) {
		$this->active_plugin_paths = $active_plugin_paths;
		$this->version_selector    = $version_selector;
	}

	/**
	 * Registers all of the paths in a given manifest.
	 *
	 * @param string $manifest_path The path that we're loading the manifest from in each plugin.
	 * @param array  $path_map The path map to add the contents of the manifests to.
	 *
	 * @return array $path_map The path map we've built using the manifests in each plugin.
	 */
	public function register_plugin_manifests( $manifest_path, &$path_map ) {
		$file_paths = array_map(
			function ( $path ) use ( $manifest_path ) {
				return trailingslashit( $path ) . $manifest_path;
			},
			$this->active_plugin_paths
		);

		foreach ( $file_paths as $path ) {
			$this->register_manifest( $path, $path_map );
		}

		return $path_map;
	}

	/**
	 * Registers a plugin's manifest file with the path map.
	 *
	 * @param string $manifest_path The absolute path to the manifest that we're loading.
	 * @param array  $path_map The path map to add the contents of the manifest to.
	 */
	protected function register_manifest( $manifest_path, &$path_map ) {
		if ( ! is_readable( $manifest_path ) ) {
			return;
		}

		$manifest = require $manifest_path;
		if ( ! is_array( $manifest ) ) {
			return;
		}

		foreach ( $manifest as $key => $data ) {
			$this->register_record( $key, $data, $path_map );
		}
	}

	/**
	 * Registers an entry from the manifest in the path map.
	 *
	 * @param string $key The identifier for the entry we're registering.
	 * @param array  $data The data for the entry we're registering.
	 * @param array  $path_map The path map to add the contents of the manifest to.
	 */
	protected function register_record( $key, $data, &$path_map ) {
		if ( isset( $path_map[ $key ]['version'] ) ) {
			$selected_version = $path_map[ $key ]['version'];
		} else {
			$selected_version = null;
		}

		if ( $this->version_selector->is_version_update_required( $selected_version, $data['version'] ) ) {
			$path_map[ $key ] = array(
				'version' => $data['version'],
				'path'    => $data['path'],
			);
		}
	}
}