diff options
| author | nsfisis <nsfisis@gmail.com> | 2024-05-19 14:22:22 +0900 |
|---|---|---|
| committer | nsfisis <nsfisis@gmail.com> | 2024-05-19 14:22:22 +0900 |
| commit | bb904d877f522e196c8223ad10507abce8d7f632 (patch) | |
| tree | 9eb7a15872a6a1b611f74479349fdffeafcddd17 /src/Utility/BinaryConversion.php | |
| parent | 74451aa848d88d1175e52f5c4dd7234cb84fa7f8 (diff) | |
| download | php-waddiwasi-bb904d877f522e196c8223ad10507abce8d7f632.tar.gz php-waddiwasi-bb904d877f522e196c8223ad10507abce8d7f632.tar.zst php-waddiwasi-bb904d877f522e196c8223ad10507abce8d7f632.zip | |
refactor: reinterpret conversions
Diffstat (limited to 'src/Utility/BinaryConversion.php')
| -rw-r--r-- | src/Utility/BinaryConversion.php | 108 |
1 files changed, 108 insertions, 0 deletions
diff --git a/src/Utility/BinaryConversion.php b/src/Utility/BinaryConversion.php new file mode 100644 index 0000000..0ca6927 --- /dev/null +++ b/src/Utility/BinaryConversion.php @@ -0,0 +1,108 @@ +<?php + +declare(strict_types=1); + +namespace Nsfisis\Waddiwasi\Utility; + +use InvalidArgumentException; +use function pack; +use function unpack; + +final readonly class BinaryConversion +{ + public static function reinterpretI32AsF32(int $x): float + { + return self::deserializeF32FromBytes(self::serializeI32ToBytes($x)); + } + + public static function reinterpretI64AsF32(int $x): float + { + return self::deserializeF32FromBytes(self::serializeI64ToBytes($x)); + } + + public static function reinterpretI32AsF64(int $x): float + { + return self::deserializeF64FromBytes(self::serializeI32ToBytes($x)); + } + + public static function reinterpretI64AsF64(int $x): float + { + return self::deserializeF64FromBytes(self::serializeI64ToBytes($x)); + } + + public static function reinterpretF32AsI32(float $x): int + { + return self::deserializeI32FromBytes(self::serializeF32ToBytes($x)); + } + + public static function reinterpretF64AsI32(float $x): int + { + return self::deserializeI32FromBytes(self::serializeF64ToBytes($x)); + } + + public static function reinterpretF32AsI64(float $x): int + { + return self::deserializeI64FromBytes(self::serializeF32ToBytes($x)); + } + + public static function reinterpretF64AsI64(float $x): int + { + return self::deserializeI64FromBytes(self::serializeF64ToBytes($x)); + } + + public static function serializeI32ToBytes(int $x): string + { + return pack('l', $x); + } + + public static function deserializeI32FromBytes(string $s): int + { + $result = unpack('l', $s); + if ($result === false) { + throw new InvalidArgumentException("Failed to unpack i32: $s"); + } + return $result[1]; + } + + public static function serializeI64ToBytes(int $x): string + { + return pack('q', $x); + } + + public static function deserializeI64FromBytes(string $s): int + { + $result = unpack('q', $s); + if ($result === false) { + throw new InvalidArgumentException("Failed to unpack i64: $s"); + } + return $result[1]; + } + + public static function serializeF32ToBytes(float $x): string + { + return pack('f', $x); + } + + public static function deserializeF32FromBytes(string $s): float + { + $result = unpack('f', $s); + if ($result === false) { + throw new InvalidArgumentException("Failed to unpack f32: $s"); + } + return $result[1]; + } + + public static function serializeF64ToBytes(float $x): string + { + return pack('d', $x); + } + + public static function deserializeF64FromBytes(string $s): float + { + $result = unpack('d', $s); + if ($result === false) { + throw new InvalidArgumentException("Failed to unpack f64: $s"); + } + return $result[1]; + } +} |
