ffi / scalar-utils
PHP FFI 标量工具
1.0.2
2023-01-01 13:50 UTC
Requires
- php: ^7.4|^8.0
- ext-ffi: *
- ext-mbstring: *
Requires (Dev)
- phpunit/phpunit: ^9.5
- squizlabs/php_codesniffer: ^3.7
- vimeo/psalm: ^5.4
README
一套用于与 PHP 和 C 标量类型交互的实用方法。
要求
- PHP >= 7.4
- ext-ffi
安装
库作为 composer 仓库可用,您可以在项目的根目录中使用以下命令进行安装。
$ composer require ffi/scalar-utils
用法
PHP 到 C 的序列化
use FFI\Scalar\Type; Type::int8(42); // object CData<int8_t> { cdata: 42 } Type::int8Array([1, 2, 3]); // object CData<int8_t[3]> { cdata: [1, 2, 3] } Type::uint8(42); // object CData<uint8_t> { cdata: 42 } Type::uint8Array([1, 2, 3]); // object CData<uint8_t[3]> { cdata: [1, 2, 3] } Type::int16(42); // object CData<int16_t> { cdata: 42 } Type::int16Array([1, 2, 3]); // object CData<int16_t[3]> { cdata: [1, 2, 3] } Type::uint16(42); // object CData<uint16_t> { cdata: 42 } Type::uint16Array([1, 2, 3]); // object CData<uint16_t[3]> { cdata: [1, 2, 3] } Type::int32(42); // object CData<int32_t> { cdata: 42 } Type::int32Array([1, 2, 3]); // object CData<int32_t[3]> { cdata: [1, 2, 3] } Type::uint32(42); // object CData<uint32_t> { cdata: 42 } Type::uint32Array([1, 2, 3]); // object CData<uint32_t[3]> { cdata: [1, 2, 3] } Type::int64(42); // object CData<int64_t> { cdata: 42 } Type::int64Array([1, 2, 3]); // object CData<int64_t[3]> { cdata: [1, 2, 3] } Type::uint64(42); // object CData<uint64_t> { cdata: 42 } Type::uint64Array([1, 2, 3]); // object CData<uint64_t[3]> { cdata: [1, 2, 3] } Type::short(42); // object CData<signed short int> { cdata: 42 } Type::shortArray([1, 2, 3]); // object CData<signed short int[3]> { cdata: [1, 2, 3] } Type::ushort(42); // object CData<unsigned short int> { cdata: 42 } Type::ushortArray([1, 2, 3]); // object CData<unsigned short int[3]> { cdata: [1, 2, 3] } Type::int(42); // object CData<signed int> { cdata: 42 } Type::intArray([1, 2, 3]); // object CData<signed int[3]> { cdata: [1, 2, 3] } Type::uint(42); // object CData<unsigned int> { cdata: 42 } Type::uintArray([1, 2, 3]); // object CData<unsigned int[3]> { cdata: [1, 2, 3] } Type::long(42); // object CData<signed long int> { cdata: 42 } Type::longArray([1, 2, 3]); // object CData<signed long int[3]> { cdata: [1, 2, 3] } Type::ulong(42); // object CData<unsigned long int> { cdata: 42 } Type::ulongArray([1, 2, 3]); // object CData<unsigned long int[3]> { cdata: [1, 2, 3] } Type::float(42); // object CData<float> { cdata: 42.0 } Type::floatArray([1, 2, 3]); // object CData<float[3]> { cdata: [1.0, 2.0, 3.0] } Type::double(42); // object CData<double> { cdata: 42.0 } Type::doubleArray([1, 2, 3]); // object CData<double[3]> { cdata: [1.0, 2.0, 3.0] } Type::longDouble(42); // object CData<long double> { cdata: 42.0 } Type::longDoubleArray([1, 2, 3]); // object CData<long double[3]> { cdata: [1.0, 2.0, 3.0] } Type::bool(true); // object CData<bool> { cdata: true } Type::boolArray([true, false, true]); // object CData<bool[3]> { cdata: [true, false, true] } Type::char('c'); // object CData<char> { cdata: 'c' } Type::charArray(['a', 'b', 'c']); // object CData<char[3]> { cdata: ['a', 'b', 'c'] } Type::string('hi'); // object CData<char[3]> { cdata: ['h', 'i', '\0'] } Type::stringArray(['a', 'b']); // object CData<char[2][2]> { cdata: [['a' '\0'], ['b', '\0']] } Type::wideString('hi'); // object CData<wchar_t[3]> { cdata: ['h', 'i', '\0\0'] } Type::wideStringArray(['a', 'b']); // object CData<wchar_t[2][2]> { cdata: [['a' '\0\0'], ['b', '\0\0']] } // Direct API Type::create($ffi->type('example'), $value); // object CData<example> { cdata: ... } Type::array($ffi->type('example'), [$value]); // object CData<example[1]> { cdata: [ ... ] }
C 到 PHP 的序列化
use FFI\Scalar\Type; Type::toString($cdata); // string(x) "..." Type::toWideString($cdata); // string(x) "..." Type::toInt($cdata); // int(x) Type::toFloat($cdata); // float(x) Type::toBool($cdata); // bool(x) Type::toArray($cdata); // array(...)