Compare commits
15 Commits
fead8bbbbc
...
a278fd6400
Author | SHA1 | Date |
---|---|---|
R. Eric Wheeler | a278fd6400 | |
R. Eric Wheeler | 24e53cd2cc | |
R. Eric Wheeler | 0f1cca15df | |
R. Eric Wheeler | 48420375b4 | |
R. Eric Wheeler | d9af97eab2 | |
R. Eric Wheeler | 6405f1c7b9 | |
R. Eric Wheeler | 2ed1abf0fc | |
R. Eric Wheeler | aa72be226d | |
R. Eric Wheeler | ba09e1d356 | |
R. Eric Wheeler | e06f9e0cc7 | |
R. Eric Wheeler | c7459a7d47 | |
R. Eric Wheeler | a918fd2cac | |
R. Eric Wheeler | be74c6f097 | |
R. Eric Wheeler | ad7928afde | |
R. Eric Wheeler | de1084eed1 |
|
@ -3,3 +3,4 @@
|
|||
.php_cs.cache
|
||||
vendor/
|
||||
.phpunit.cache/
|
||||
tools/php-cs-fixer/vendor/
|
||||
|
|
|
@ -0,0 +1,18 @@
|
|||
<?php
|
||||
|
||||
use PhpCsFixer\Config;
|
||||
|
||||
$header = file_exists(__DIR__.'/header.txt') ? file_get_contents(__DIR__.'/header.txt') : '';
|
||||
$finder = PhpCsFixer\Finder::create()
|
||||
->in(__DIR__ . '/src')
|
||||
->in(__DIR__ . '/tests')
|
||||
;
|
||||
return (new Config())
|
||||
|
||||
->setRules([
|
||||
'@Symfony' => true,
|
||||
'array_syntax' => ['syntax' => 'short'],
|
||||
'header_comment' => ['header' => $header],
|
||||
])
|
||||
->setFinder($finder)
|
||||
;
|
14
.php_cs.dist
14
.php_cs.dist
|
@ -1,14 +0,0 @@
|
|||
<?php
|
||||
|
||||
$finder = PhpCsFixer\Finder::create()
|
||||
->in(__DIR__)
|
||||
->exclude('var')
|
||||
;
|
||||
|
||||
return PhpCsFixer\Config::create()
|
||||
->setRules([
|
||||
'@Symfony' => true,
|
||||
'array_syntax' => ['syntax' => 'short'],
|
||||
])
|
||||
->setFinder($finder)
|
||||
;
|
|
@ -2,10 +2,6 @@
|
|||
|
||||
This simply uses the FFI extension to enable _getch and _ungetch in Windows and linux.
|
||||
|
||||
[![Pipeline status](https://code.bgemi.net/olive/PHP/getch/badges/1.x/pipeline.svg)](https://code.bgemi.net/olive/PHP/getch/-/commits/1.x)
|
||||
[![Coverage report](https://code.bgemi.net/olive/PHP/getch/badges/1.x/coverage.svg)](https://code.bgemi.net/olive/PHP/getch/-/commits/1.x)
|
||||
[![Latest Release](https://code.bgemi.net/olive/PHP/getch/-/badges/release.svg)](https://code.bgemi.net/olive/PHP/getch/-/releases)
|
||||
|
||||
```shell script
|
||||
$ composer require olivebbs/getch
|
||||
```
|
||||
|
|
|
@ -1,19 +1,17 @@
|
|||
{
|
||||
"name": "olivebbs/getch",
|
||||
"name": "sikofitt/getch",
|
||||
"description": "Implements _getch and _ungetch for windows and linux using ffi",
|
||||
"type": "library",
|
||||
"keywords": ["getch", "windows", "conio", "linux", "console", "conio.h", "hotkey", "termios"],
|
||||
"require": {
|
||||
"php": ">=7.4",
|
||||
"php": "^8.2",
|
||||
"ext-ffi": "*"
|
||||
},
|
||||
"require-dev": {
|
||||
"friendsofphp/php-cs-fixer": "^2.18",
|
||||
"phpunit/phpunit": "^9.5"
|
||||
"phpunit/phpunit": "^9.6"
|
||||
},
|
||||
"autoload": {
|
||||
"psr-4": {
|
||||
"Olive\\Console\\": "src/Console/"
|
||||
"Sikofitt\\Console\\": "src/Console/"
|
||||
},
|
||||
"files": [
|
||||
"functions.php"
|
||||
|
@ -21,7 +19,7 @@
|
|||
},
|
||||
"autoload-dev": {
|
||||
"psr-4": {
|
||||
"Olive\\Tests\\Console\\": "tests/"
|
||||
"Sikofitt\\Tests\\Console\\": "tests/"
|
||||
}
|
||||
},
|
||||
"license": "MPL-2.0",
|
||||
|
@ -30,8 +28,5 @@
|
|||
"name": "R. Eric Wheeler",
|
||||
"email": "sikofitt@gmail.com"
|
||||
}
|
||||
],
|
||||
"conflict": {
|
||||
"sikofitt/getch": "*"
|
||||
}
|
||||
]
|
||||
}
|
||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -3,7 +3,7 @@
|
|||
declare(strict_types=1);
|
||||
|
||||
/*
|
||||
* Copyright (c) 2020 https://rewiv.com sikofitt@gmail.com
|
||||
* Copyright (c) 2020-2024 https://sikofitt.com sikofitt@gmail.com
|
||||
*
|
||||
* This Source Code Form is subject to the
|
||||
* terms of the Mozilla Public License, v. 2.0.
|
||||
|
@ -15,19 +15,15 @@ declare(strict_types=1);
|
|||
use Olive\Console\Getch;
|
||||
|
||||
if (!function_exists('getch')) {
|
||||
function getch(string $linuxLibrary = null): int
|
||||
function getch(?string $linuxLibrary = null): int
|
||||
{
|
||||
$g = new Getch($linuxLibrary);
|
||||
|
||||
return $g->getch();
|
||||
return (new Getch($linuxLibrary))->getch();
|
||||
}
|
||||
}
|
||||
|
||||
if (!function_exists('ungetch')) {
|
||||
function ungetch($char, string $linuxLibrary = null): int
|
||||
function ungetch($char, ?string $linuxLibrary = null): int
|
||||
{
|
||||
$g = new Getch($linuxLibrary);
|
||||
|
||||
return $g->ungetch($char);
|
||||
return (new Getch($linuxLibrary))->ungetch($char);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
Copyright (c) 2020 https://rewiv.com sikofitt@gmail.com
|
||||
Copyright (c) 2020-2024 https://sikofitt.com sikofitt@gmail.com
|
||||
|
||||
This Source Code Form is subject to the
|
||||
terms of the Mozilla Public License, v. 2.0.
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<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"
|
||||
cacheResultFile=".phpunit.cache/test-results"
|
||||
executionOrder="depends,defects"
|
||||
|
|
|
@ -3,7 +3,7 @@
|
|||
declare(strict_types=1);
|
||||
|
||||
/*
|
||||
* Copyright (c) 2020 https://rewiv.com sikofitt@gmail.com
|
||||
* Copyright (c) 2020-2024 https://sikofitt.com sikofitt@gmail.com
|
||||
*
|
||||
* This Source Code Form is subject to the
|
||||
* terms of the Mozilla Public License, v. 2.0.
|
||||
|
@ -12,10 +12,7 @@ declare(strict_types=1);
|
|||
* You can obtain one at https://mozilla.org/MPL/2.0/.
|
||||
*/
|
||||
|
||||
namespace Olive\Console;
|
||||
|
||||
use FFI;
|
||||
use RuntimeException;
|
||||
namespace Sikofitt\Console;
|
||||
|
||||
final class Getch
|
||||
{
|
||||
|
@ -25,7 +22,7 @@ final class Getch
|
|||
public const KEY_E0 = 0;
|
||||
public const KEY_E1 = 224;
|
||||
|
||||
// Supported scan scodes.
|
||||
// Supported scan codes.
|
||||
public const KEY_F1 = 59;
|
||||
public const KEY_F2 = 60;
|
||||
public const KEY_F3 = 61;
|
||||
|
@ -56,14 +53,14 @@ final class Getch
|
|||
int _ungetch(int c);
|
||||
DECLARATIONS;
|
||||
|
||||
private static ?FFI $ffi = null;
|
||||
private static ?\FFI $ffi = null;
|
||||
|
||||
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) {
|
||||
$linuxLibrary = self::LINUX_LIBRARY;
|
||||
|
@ -73,15 +70,15 @@ final class Getch
|
|||
$osFamily = PHP_OS_FAMILY;
|
||||
if ('Windows' === $osFamily) {
|
||||
$declarations = self::DECLARATIONS.' int _kbhit();';
|
||||
self::$ffi = FFI::cdef($declarations, self::WINDOWS_LIBRARY);
|
||||
self::$ffi = \FFI::cdef($declarations, self::WINDOWS_LIBRARY);
|
||||
} elseif ('Linux' === $osFamily) {
|
||||
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();';
|
||||
self::$ffi = FFI::cdef($declarations, $linuxLibrary);
|
||||
self::$ffi = \FFI::cdef($declarations, $linuxLibrary);
|
||||
} 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 +86,9 @@ final class Getch
|
|||
public function peek(): int
|
||||
{
|
||||
if (PHP_OS_FAMILY === 'Windows') {
|
||||
if ($ffi->_kbhit()) {
|
||||
$result = $ffi->_getch();
|
||||
$ffi->_ungetch($result);
|
||||
if (self::$ffi->_kbhit()) {
|
||||
$result = self::$ffi->_getch();
|
||||
self::$ffi->_ungetch($result);
|
||||
|
||||
return $result;
|
||||
}
|
||||
|
@ -99,7 +96,7 @@ final class Getch
|
|||
return -1;
|
||||
}
|
||||
|
||||
return $ffi->cinPeek();
|
||||
return self::$ffi->cinPeek();
|
||||
}
|
||||
|
||||
public function getch(): int
|
||||
|
@ -107,12 +104,8 @@ final class 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)) {
|
||||
$char = ord($char[0]);
|
||||
}
|
||||
|
|
|
@ -1,9 +1,19 @@
|
|||
<?php
|
||||
|
||||
namespace Olive\Tests\Console\Getch;
|
||||
/*
|
||||
* Copyright (c) 2020-2024 https://sikofitt.com sikofitt@gmail.com
|
||||
*
|
||||
* This Source Code Form is subject to the
|
||||
* terms of the Mozilla Public License, v. 2.0.
|
||||
*
|
||||
* If a copy of the MPL was not distributed with this file,
|
||||
* You can obtain one at https://mozilla.org/MPL/2.0/.
|
||||
*/
|
||||
|
||||
namespace Sikofitt\Tests\Console\Getch;
|
||||
|
||||
use PHPUnit\Framework\TestCase;
|
||||
use Olive\Console\Getch;
|
||||
use Sikofitt\Console\Getch;
|
||||
|
||||
class GetchTest extends TestCase
|
||||
{
|
||||
|
@ -23,7 +33,9 @@ class GetchTest extends TestCase
|
|||
|
||||
/**
|
||||
* @preserveGlobalState disabled
|
||||
*
|
||||
* @backupStaticAttributes false
|
||||
*
|
||||
* @backupGlobals false
|
||||
*/
|
||||
public function testFailureOnInvalidLibrary()
|
||||
|
|
|
@ -1,9 +1,19 @@
|
|||
<?php
|
||||
|
||||
namespace Olive\Tests\Console\Ungetch;
|
||||
/*
|
||||
* Copyright (c) 2020-2024 https://sikofitt.com sikofitt@gmail.com
|
||||
*
|
||||
* This Source Code Form is subject to the
|
||||
* terms of the Mozilla Public License, v. 2.0.
|
||||
*
|
||||
* If a copy of the MPL was not distributed with this file,
|
||||
* You can obtain one at https://mozilla.org/MPL/2.0/.
|
||||
*/
|
||||
|
||||
namespace Sikofitt\Tests\Console\Ungetch;
|
||||
|
||||
use PHPUnit\Framework\TestCase;
|
||||
use Olive\Console\Getch;
|
||||
use Sikofitt\Console\Getch;
|
||||
|
||||
class UngetchTest extends TestCase
|
||||
{
|
||||
|
|
|
@ -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