getContext(); if ($c->getDepth() > 0) { return $v; } if (\is_string($var)) { if ('microtime()' !== $c->getName() || !\preg_match('/^0\\.[0-9]{8} [0-9]{10}$/', $var)) { return $v; } $usec = (int) \substr($var, 2, 6); $sec = (int) \substr($var, 11, 10); } else { if ('microtime(...)' !== $c->getName()) { return $v; } $sec = (int) \floor($var); $usec = $var - $sec; $usec = (int) \floor($usec * 1000000); } $time = $sec + ($usec / 1000000); if (null !== self::$last) { $last_time = self::$last[0] + (self::$last[1] / 1000000); $lap = $time - $last_time; ++self::$times; } else { $lap = null; self::$start = $time; } self::$last = [$sec, $usec]; if (null !== $lap) { $total = $time - self::$start; $r = new MicrotimeRepresentation($sec, $usec, self::getGroup(), $lap, $total, self::$times); } else { $r = new MicrotimeRepresentation($sec, $usec, self::getGroup()); } $out = new MicrotimeValue($v); $out->removeRepresentation('contents'); $out->addRepresentation($r); return $out; } /** @psalm-api */ public static function clean(): void { self::$last = null; self::$start = null; self::$times = 0; self::newGroup(); } private static function getGroup(): string { if (null === self::$group) { return self::newGroup(); } return self::$group; } private static function newGroup(): string { return self::$group = \bin2hex(\random_bytes(4)); } }