summaryrefslogtreecommitdiff
path: root/vendor/sebastian/cli-parser/src
diff options
context:
space:
mode:
authorsupahgreg <supahgreg@users.noreply.github.com>2025-10-09 02:49:56 +0000
committersupahgreg <supahgreg@users.noreply.github.com>2025-10-09 03:08:30 +0000
commite41d6361221a30ca9d996cde7591111e626b7e1c (patch)
tree4572f61f37bbc76192ad60e0940c281483bc03af /vendor/sebastian/cli-parser/src
parentab0aabf8548c206f3f624de5451a9b6abbde90be (diff)
Remove dev dependencies and update the rest.
Diffstat (limited to 'vendor/sebastian/cli-parser/src')
-rw-r--r--vendor/sebastian/cli-parser/src/Parser.php204
-rw-r--r--vendor/sebastian/cli-parser/src/exceptions/AmbiguousOptionException.php26
-rw-r--r--vendor/sebastian/cli-parser/src/exceptions/Exception.php16
-rw-r--r--vendor/sebastian/cli-parser/src/exceptions/OptionDoesNotAllowArgumentException.php26
-rw-r--r--vendor/sebastian/cli-parser/src/exceptions/RequiredOptionArgumentMissingException.php26
-rw-r--r--vendor/sebastian/cli-parser/src/exceptions/UnknownOptionException.php26
6 files changed, 0 insertions, 324 deletions
diff --git a/vendor/sebastian/cli-parser/src/Parser.php b/vendor/sebastian/cli-parser/src/Parser.php
deleted file mode 100644
index a4f728bc6..000000000
--- a/vendor/sebastian/cli-parser/src/Parser.php
+++ /dev/null
@@ -1,204 +0,0 @@
-<?php declare(strict_types=1);
-/*
- * This file is part of sebastian/cli-parser.
- *
- * (c) Sebastian Bergmann <sebastian@phpunit.de>
- *
- * For the full copyright and license information, please view the LICENSE
- * file that was distributed with this source code.
- */
-namespace SebastianBergmann\CliParser;
-
-use function array_map;
-use function array_merge;
-use function array_shift;
-use function array_slice;
-use function assert;
-use function count;
-use function current;
-use function explode;
-use function is_array;
-use function is_int;
-use function is_string;
-use function key;
-use function next;
-use function preg_replace;
-use function reset;
-use function sort;
-use function strlen;
-use function strpos;
-use function strstr;
-use function substr;
-
-final class Parser
-{
- /**
- * @psalm-param list<string> $argv
- * @psalm-param list<string> $longOptions
- *
- * @throws AmbiguousOptionException
- * @throws RequiredOptionArgumentMissingException
- * @throws OptionDoesNotAllowArgumentException
- * @throws UnknownOptionException
- */
- public function parse(array $argv, string $shortOptions, array $longOptions = null): array
- {
- if (empty($argv)) {
- return [[], []];
- }
-
- $options = [];
- $nonOptions = [];
-
- if ($longOptions) {
- sort($longOptions);
- }
-
- if (isset($argv[0][0]) && $argv[0][0] !== '-') {
- array_shift($argv);
- }
-
- reset($argv);
-
- $argv = array_map('trim', $argv);
-
- while (false !== $arg = current($argv)) {
- $i = key($argv);
-
- assert(is_int($i));
-
- next($argv);
-
- if ($arg === '') {
- continue;
- }
-
- if ($arg === '--') {
- $nonOptions = array_merge($nonOptions, array_slice($argv, $i + 1));
-
- break;
- }
-
- if ($arg[0] !== '-' || (strlen($arg) > 1 && $arg[1] === '-' && !$longOptions)) {
- $nonOptions[] = $arg;
-
- continue;
- }
-
- if (strlen($arg) > 1 && $arg[1] === '-' && is_array($longOptions)) {
- $this->parseLongOption(
- substr($arg, 2),
- $longOptions,
- $options,
- $argv
- );
- } else {
- $this->parseShortOption(
- substr($arg, 1),
- $shortOptions,
- $options,
- $argv
- );
- }
- }
-
- return [$options, $nonOptions];
- }
-
- /**
- * @throws RequiredOptionArgumentMissingException
- */
- private function parseShortOption(string $arg, string $shortOptions, array &$opts, array &$args): void
- {
- $argLength = strlen($arg);
-
- for ($i = 0; $i < $argLength; $i++) {
- $option = $arg[$i];
- $optionArgument = null;
-
- if ($arg[$i] === ':' || ($spec = strstr($shortOptions, $option)) === false) {
- throw new UnknownOptionException('-' . $option);
- }
-
- assert(is_string($spec));
-
- if (strlen($spec) > 1 && $spec[1] === ':') {
- if ($i + 1 < $argLength) {
- $opts[] = [$option, substr($arg, $i + 1)];
-
- break;
- }
-
- if (!(strlen($spec) > 2 && $spec[2] === ':')) {
- $optionArgument = current($args);
-
- if (!$optionArgument) {
- throw new RequiredOptionArgumentMissingException('-' . $option);
- }
-
- assert(is_string($optionArgument));
-
- next($args);
- }
- }
-
- $opts[] = [$option, $optionArgument];
- }
- }
-
- /**
- * @psalm-param list<string> $longOptions
- *
- * @throws AmbiguousOptionException
- * @throws RequiredOptionArgumentMissingException
- * @throws OptionDoesNotAllowArgumentException
- * @throws UnknownOptionException
- */
- private function parseLongOption(string $arg, array $longOptions, array &$opts, array &$args): void
- {
- $count = count($longOptions);
- $list = explode('=', $arg);
- $option = $list[0];
- $optionArgument = null;
-
- if (count($list) > 1) {
- $optionArgument = $list[1];
- }
-
- $optionLength = strlen($option);
-
- foreach ($longOptions as $i => $longOption) {
- $opt_start = substr($longOption, 0, $optionLength);
-
- if ($opt_start !== $option) {
- continue;
- }
-
- $opt_rest = substr($longOption, $optionLength);
-
- if ($opt_rest !== '' && $i + 1 < $count && $option[0] !== '=' && strpos($longOptions[$i + 1], $option) === 0) {
- throw new AmbiguousOptionException('--' . $option);
- }
-
- if (substr($longOption, -1) === '=') {
- /* @noinspection StrlenInEmptyStringCheckContextInspection */
- if (substr($longOption, -2) !== '==' && !strlen((string) $optionArgument)) {
- if (false === $optionArgument = current($args)) {
- throw new RequiredOptionArgumentMissingException('--' . $option);
- }
-
- next($args);
- }
- } elseif ($optionArgument) {
- throw new OptionDoesNotAllowArgumentException('--' . $option);
- }
-
- $fullOption = '--' . preg_replace('/={1,2}$/', '', $longOption);
- $opts[] = [$fullOption, $optionArgument];
-
- return;
- }
-
- throw new UnknownOptionException('--' . $option);
- }
-}
diff --git a/vendor/sebastian/cli-parser/src/exceptions/AmbiguousOptionException.php b/vendor/sebastian/cli-parser/src/exceptions/AmbiguousOptionException.php
deleted file mode 100644
index a99f63697..000000000
--- a/vendor/sebastian/cli-parser/src/exceptions/AmbiguousOptionException.php
+++ /dev/null
@@ -1,26 +0,0 @@
-<?php declare(strict_types=1);
-/*
- * This file is part of sebastian/cli-parser.
- *
- * (c) Sebastian Bergmann <sebastian@phpunit.de>
- *
- * For the full copyright and license information, please view the LICENSE
- * file that was distributed with this source code.
- */
-namespace SebastianBergmann\CliParser;
-
-use function sprintf;
-use RuntimeException;
-
-final class AmbiguousOptionException extends RuntimeException implements Exception
-{
- public function __construct(string $option)
- {
- parent::__construct(
- sprintf(
- 'Option "%s" is ambiguous',
- $option
- )
- );
- }
-}
diff --git a/vendor/sebastian/cli-parser/src/exceptions/Exception.php b/vendor/sebastian/cli-parser/src/exceptions/Exception.php
deleted file mode 100644
index f35ad2457..000000000
--- a/vendor/sebastian/cli-parser/src/exceptions/Exception.php
+++ /dev/null
@@ -1,16 +0,0 @@
-<?php declare(strict_types=1);
-/*
- * This file is part of sebastian/cli-parser.
- *
- * (c) Sebastian Bergmann <sebastian@phpunit.de>
- *
- * For the full copyright and license information, please view the LICENSE
- * file that was distributed with this source code.
- */
-namespace SebastianBergmann\CliParser;
-
-use Throwable;
-
-interface Exception extends Throwable
-{
-}
diff --git a/vendor/sebastian/cli-parser/src/exceptions/OptionDoesNotAllowArgumentException.php b/vendor/sebastian/cli-parser/src/exceptions/OptionDoesNotAllowArgumentException.php
deleted file mode 100644
index 0aad29ac0..000000000
--- a/vendor/sebastian/cli-parser/src/exceptions/OptionDoesNotAllowArgumentException.php
+++ /dev/null
@@ -1,26 +0,0 @@
-<?php declare(strict_types=1);
-/*
- * This file is part of sebastian/cli-parser.
- *
- * (c) Sebastian Bergmann <sebastian@phpunit.de>
- *
- * For the full copyright and license information, please view the LICENSE
- * file that was distributed with this source code.
- */
-namespace SebastianBergmann\CliParser;
-
-use function sprintf;
-use RuntimeException;
-
-final class OptionDoesNotAllowArgumentException extends RuntimeException implements Exception
-{
- public function __construct(string $option)
- {
- parent::__construct(
- sprintf(
- 'Option "%s" does not allow an argument',
- $option
- )
- );
- }
-}
diff --git a/vendor/sebastian/cli-parser/src/exceptions/RequiredOptionArgumentMissingException.php b/vendor/sebastian/cli-parser/src/exceptions/RequiredOptionArgumentMissingException.php
deleted file mode 100644
index d2a930b62..000000000
--- a/vendor/sebastian/cli-parser/src/exceptions/RequiredOptionArgumentMissingException.php
+++ /dev/null
@@ -1,26 +0,0 @@
-<?php declare(strict_types=1);
-/*
- * This file is part of sebastian/cli-parser.
- *
- * (c) Sebastian Bergmann <sebastian@phpunit.de>
- *
- * For the full copyright and license information, please view the LICENSE
- * file that was distributed with this source code.
- */
-namespace SebastianBergmann\CliParser;
-
-use function sprintf;
-use RuntimeException;
-
-final class RequiredOptionArgumentMissingException extends RuntimeException implements Exception
-{
- public function __construct(string $option)
- {
- parent::__construct(
- sprintf(
- 'Required argument for option "%s" is missing',
- $option
- )
- );
- }
-}
diff --git a/vendor/sebastian/cli-parser/src/exceptions/UnknownOptionException.php b/vendor/sebastian/cli-parser/src/exceptions/UnknownOptionException.php
deleted file mode 100644
index e98d9fd02..000000000
--- a/vendor/sebastian/cli-parser/src/exceptions/UnknownOptionException.php
+++ /dev/null
@@ -1,26 +0,0 @@
-<?php declare(strict_types=1);
-/*
- * This file is part of sebastian/cli-parser.
- *
- * (c) Sebastian Bergmann <sebastian@phpunit.de>
- *
- * For the full copyright and license information, please view the LICENSE
- * file that was distributed with this source code.
- */
-namespace SebastianBergmann\CliParser;
-
-use function sprintf;
-use RuntimeException;
-
-final class UnknownOptionException extends RuntimeException implements Exception
-{
- public function __construct(string $option)
- {
- parent::__construct(
- sprintf(
- 'Unknown option "%s"',
- $option
- )
- );
- }
-}