ffi / scalar-utils
PHP FFI Scalar Utilities
Installs: 2 052
Dependents: 0
Suggesters: 0
Security: 0
Stars: 6
Watchers: 3
Forks: 0
Open Issues: 0
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
A set of util methods to interact with PHP and C scalar types.
Requirements
- PHP >= 7.4
- ext-ffi
Installation
Library is available as composer repository and can be installed using the following command in a root of your project.
$ composer require ffi/scalar-utils
Usage
PHP To C Marshalling
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 To PHP Marshalling
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(...)