Update dependencies
This commit is contained in:
parent
6405f1c7b9
commit
d9af97eab2
|
@ -3,3 +3,4 @@
|
||||||
.php_cs.cache
|
.php_cs.cache
|
||||||
vendor/
|
vendor/
|
||||||
.phpunit.cache/
|
.phpunit.cache/
|
||||||
|
tools/php-cs-fixer/vendor/
|
||||||
|
|
|
@ -1,11 +1,12 @@
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
$finder = PhpCsFixer\Finder::create()
|
use PhpCsFixer\Config;
|
||||||
->in(__DIR__)
|
|
||||||
->exclude('var')
|
|
||||||
;
|
|
||||||
|
|
||||||
return PhpCsFixer\Config::create()
|
$finder = PhpCsFixer\Finder::create()
|
||||||
|
->in(__DIR__ . '/src')
|
||||||
|
->in(__DIR__ . '/tests')
|
||||||
|
;
|
||||||
|
return (new Config())
|
||||||
->setRules([
|
->setRules([
|
||||||
'@Symfony' => true,
|
'@Symfony' => true,
|
||||||
'array_syntax' => ['syntax' => 'short'],
|
'array_syntax' => ['syntax' => 'short'],
|
|
@ -3,13 +3,11 @@
|
||||||
"description": "Implements _getch and _ungetch for windows and linux using ffi",
|
"description": "Implements _getch and _ungetch for windows and linux using ffi",
|
||||||
"type": "library",
|
"type": "library",
|
||||||
"require": {
|
"require": {
|
||||||
"php": ">=7.4",
|
"php": "^8.2",
|
||||||
"ext-ffi": "*"
|
"ext-ffi": "*"
|
||||||
},
|
},
|
||||||
"require-dev": {
|
"require-dev": {
|
||||||
"friendsofphp/php-cs-fixer": "^2.18",
|
"phpunit/phpunit": "^9.6"
|
||||||
"jetbrains/phpstorm-stubs": "dev-master",
|
|
||||||
"phpunit/phpunit": "^9.5"
|
|
||||||
},
|
},
|
||||||
"autoload": {
|
"autoload": {
|
||||||
"psr-4": {
|
"psr-4": {
|
||||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -15,19 +15,15 @@ declare(strict_types=1);
|
||||||
use Sikofitt\Console\Getch;
|
use Sikofitt\Console\Getch;
|
||||||
|
|
||||||
if (!function_exists('getch')) {
|
if (!function_exists('getch')) {
|
||||||
function getch(string $linuxLibrary = null): int
|
function getch(?string $linuxLibrary = null): int
|
||||||
{
|
{
|
||||||
$g = new Getch($linuxLibrary);
|
return (new Getch($linuxLibrary))->getch();
|
||||||
|
|
||||||
return $g->getch();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!function_exists('ungetch')) {
|
if (!function_exists('ungetch')) {
|
||||||
function ungetch($char, string $linuxLibrary = null): int
|
function ungetch($char, ?string $linuxLibrary = null): int
|
||||||
{
|
{
|
||||||
$g = new Getch($linuxLibrary);
|
return (new Getch($linuxLibrary))->ungetch($char);
|
||||||
|
|
||||||
return $g->ungetch($char);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
<?xml version="1.0" encoding="UTF-8"?>
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
<phpunit xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
<phpunit xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
||||||
xsi:noNamespaceSchemaLocation="https://schema.phpunit.de/9.5/phpunit.xsd"
|
xsi:noNamespaceSchemaLocation="https://schema.phpunit.de/9.6/phpunit.xsd"
|
||||||
bootstrap="vendor/autoload.php"
|
bootstrap="vendor/autoload.php"
|
||||||
cacheResultFile=".phpunit.cache/test-results"
|
cacheResultFile=".phpunit.cache/test-results"
|
||||||
executionOrder="depends,defects"
|
executionOrder="depends,defects"
|
||||||
|
|
|
@ -15,7 +15,6 @@ declare(strict_types=1);
|
||||||
namespace Sikofitt\Console;
|
namespace Sikofitt\Console;
|
||||||
|
|
||||||
use FFI;
|
use FFI;
|
||||||
use RuntimeException;
|
|
||||||
|
|
||||||
final class Getch
|
final class Getch
|
||||||
{
|
{
|
||||||
|
@ -60,10 +59,10 @@ final class Getch
|
||||||
|
|
||||||
public static function resetFFI(): void
|
public static function resetFFI(): void
|
||||||
{
|
{
|
||||||
static::$ffi = null;
|
self::$ffi = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function __construct(string $linuxLibrary = null)
|
public function __construct(?string $linuxLibrary = null)
|
||||||
{
|
{
|
||||||
if (null === $linuxLibrary) {
|
if (null === $linuxLibrary) {
|
||||||
$linuxLibrary = self::LINUX_LIBRARY;
|
$linuxLibrary = self::LINUX_LIBRARY;
|
||||||
|
@ -76,12 +75,12 @@ final class Getch
|
||||||
self::$ffi = FFI::cdef($declarations, self::WINDOWS_LIBRARY);
|
self::$ffi = FFI::cdef($declarations, self::WINDOWS_LIBRARY);
|
||||||
} elseif ('Linux' === $osFamily) {
|
} elseif ('Linux' === $osFamily) {
|
||||||
if (!file_exists($linuxLibrary)) {
|
if (!file_exists($linuxLibrary)) {
|
||||||
throw new RuntimeException(sprintf('Could not find library file %s.', $linuxLibrary));
|
throw new \RuntimeException(sprintf('Could not find library file %s.', $linuxLibrary));
|
||||||
}
|
}
|
||||||
$declarations = self::DECLARATIONS.' int cinPeek();';
|
$declarations = self::DECLARATIONS.' int cinPeek();';
|
||||||
self::$ffi = FFI::cdef($declarations, $linuxLibrary);
|
self::$ffi = FFI::cdef($declarations, $linuxLibrary);
|
||||||
} else {
|
} else {
|
||||||
throw new RuntimeException(sprintf('Sorry, %s is not supported yet.', $osFamily));
|
throw new \RuntimeException(sprintf('Sorry, %s is not supported yet.', $osFamily));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -89,9 +88,9 @@ final class Getch
|
||||||
public function peek(): int
|
public function peek(): int
|
||||||
{
|
{
|
||||||
if (PHP_OS_FAMILY === 'Windows') {
|
if (PHP_OS_FAMILY === 'Windows') {
|
||||||
if ($ffi->_kbhit()) {
|
if (self::$ffi->_kbhit()) {
|
||||||
$result = $ffi->_getch();
|
$result = self::$ffi->_getch();
|
||||||
$ffi->_ungetch($result);
|
self::$ffi->_ungetch($result);
|
||||||
|
|
||||||
return $result;
|
return $result;
|
||||||
}
|
}
|
||||||
|
@ -99,7 +98,7 @@ final class Getch
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
return $ffi->cinPeek();
|
return self::$ffi->cinPeek();
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getch(): int
|
public function getch(): int
|
||||||
|
@ -107,11 +106,8 @@ final class Getch
|
||||||
return self::$ffi->_getch();
|
return self::$ffi->_getch();
|
||||||
}
|
}
|
||||||
|
|
||||||
public function ungetch($char): int
|
public function ungetch(string|int $char): int
|
||||||
{
|
{
|
||||||
if (!is_string($char) && !is_int($char)) {
|
|
||||||
throw new \TypeError('ungetch takes a parameter of int or string.');
|
|
||||||
}
|
|
||||||
|
|
||||||
if (is_string($char)) {
|
if (is_string($char)) {
|
||||||
$char = ord($char[0]);
|
$char = ord($char[0]);
|
||||||
|
|
|
@ -23,7 +23,9 @@ class GetchTest extends TestCase
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @preserveGlobalState disabled
|
* @preserveGlobalState disabled
|
||||||
|
*
|
||||||
* @backupStaticAttributes false
|
* @backupStaticAttributes false
|
||||||
|
*
|
||||||
* @backupGlobals false
|
* @backupGlobals false
|
||||||
*/
|
*/
|
||||||
public function testFailureOnInvalidLibrary()
|
public function testFailureOnInvalidLibrary()
|
||||||
|
|
|
@ -0,0 +1,5 @@
|
||||||
|
{
|
||||||
|
"require-dev": {
|
||||||
|
"friendsofphp/php-cs-fixer": "^3.59"
|
||||||
|
}
|
||||||
|
}
|
File diff suppressed because it is too large
Load Diff
Loading…
Reference in New Issue