HEX
Server: nginx/1.27.1
System: Linux in-3 5.15.0-161-generic #171-Ubuntu SMP Sat Oct 11 08:17:01 UTC 2025 x86_64
User: ivenus-clone (3297)
PHP: 7.4.33
Disabled: exec,passthru,shell_exec,system,proc_open,popen,parse_ini_file,show_source
Upload Files
File: /storage/v4513/ivenusin/public_html/wp-content/plugins/amp/src/Instrumentation/StopWatchEvent.php
<?php
/**
 * Class StopWatchEvent.
 *
 * @package AmpProject\AmpWP
 */

namespace AmpProject\AmpWP\Instrumentation;

/**
 * Record the timing of a single event.
 *
 * @package AmpProject\AmpWP
 * @since 2.0
 * @internal
 */
final class StopWatchEvent {

	/**
	 * Start time in milliseconds.
	 *
	 * @var float
	 */
	private $start;

	/**
	 * End time in milliseconds.
	 *
	 * @var float|null
	 */
	private $end;

	/**
	 * StopWatchEvent constructor.
	 */
	public function __construct() {
		$this->start = $this->get_now();
	}

	/**
	 * Stop the event.
	 */
	public function stop() {
		$this->end = $this->get_now();
	}

	/**
	 * Get the duration of the event in milliseconds.
	 *
	 * @return float Duration in milliseconds.
	 */
	public function get_duration() {
		if ( null === $this->end ) {
			return 0.0;
		}

		return $this->end - $this->start;
	}

	/**
	 * Get the current time in milliseconds.
	 *
	 * @return float Current time in milliseconds.
	 */
	private function get_now() {
		return microtime( true ) * 1000;
	}
}