Download the PHP package clue/arguments without Composer

On this page you can find all versions of the php package clue/arguments. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.

FAQ

After the download, you have to make one include require_once('vendor/autoload.php');. After that you have to import the classes with use statements.

Example:
If you use only one package a project is not needed. But if you use more then one package, without a project it is not possible to import the classes with use statements.

In general, it is recommended to use always a project to download your libraries. In an application normally there is more than one library needed.
Some PHP packages are not free to download and because of that hosted in private repositories. In this case some credentials are needed to access such packages. Please use the auth.json textarea to insert credentials, if a package is coming from a private repository. You can look here for more information.

  • Some hosting areas are not accessible by a terminal or SSH. Then it is not possible to use Composer.
  • To use Composer is sometimes complicated. Especially for beginners.
  • Composer needs much resources. Sometimes they are not available on a simple webspace.
  • If you are using private repositories you don't need to share your credentials. You can set up everything on our site and then you provide a simple download link to your team member.
  • Simplify your Composer build process. Use our own command line tool to download the vendor folder as binary. This makes your build process faster and you don't need to expose your credentials for private repositories.
Please rate this library. Is it a good library?

Informations about the package arguments

clue/arguments

CI status installs on Packagist

The simple way to split your command line string into an array of command arguments in PHP.

You want to build an interactive command line interface (CLI) tool in PHP which reads line based user input from STDIN and you now want to break this command line down to its individual command arguments? Then this library is for you!

This is similar to what your bash (or your terminal of choice) does for you when you execute ./example.php "hello world" which then spawns your script and passes it a single argument. If you only need this during startup, then using your $argv may be sufficient. But many other tools may need similar parsing during their runtime.

Table of contents

Support us

We invest a lot of time developing, maintaining and updating our awesome open-source projects. You can help us sustain this high-quality of our work by becoming a sponsor on GitHub. Sponsors get numerous benefits in return, see our sponsoring page for details.

Let's take these projects to the next level together! 🚀

Quickstart example

The following example code demonstrates how this library can be used to build a very simple interactive command line interface (CLI) tool that accepts a command line from user input (via STDIN) and then executes some very simple demo commands:

See also the examples.

Usage

This lightweight library consists only of a single simple function. Everything resides under the Clue\Arguments namespace.

The below examples assume you use an import statement similar to this:

Alternatively, you can also refer to them with their fully-qualified name:

split()

The split(string $line) : array function can be used to split the given command line string into any array of individual command argument strings.

For the following example, let's assume we want to handle a simple addUser command like this:

While this simple example may look like a job for a simple $args = explode(' ', $line) call, the split() function is actually way more sophisticated. It also supports parsing the following:

For example, this means that the following also parses as expected:

Validating any of the arguments (checking lengths or value ranges etc.) is left up to higher levels, i.e. the consumer of this library. This also allows you to explicitly pass empty arguments like this:

Parsing an empty input line or one with only whitespace will return an empty array:

Parsing an input line that has unbalanced quotes (i.e. a quoted argument started without passing ending quotes), this will throw an UnclosedQuotesException. This can be useful to ask the user to correct their input:

See also the following chapter if you want to (try to) correct the user input line automatically.

UnclosedQuotesException

The UnclosedQuotesException will be raised by the split() function when the input line has unbalanced quotes (i.e. a quoted argument started without passing ending quotes).

This class extends PHP's InvalidArgumentException.

The getQuotes(): string method can be used to get the quotes this argument started with:

For example, this can be used to (try to) correct the user input line like this:

Note: The input line may end with a backslash in which case the appended closing quotes will actually be marked as escaped. Either handle these yourself or wrap this block in another try-catch.

The getPosition(): int method can be used to get the character position of the quotes within the input string. In the previous example, this will be at $line[9]:

Install

The recommended way to install this library is through Composer. New to Composer?

This project follows SemVer. This will install the latest supported version:

See also the CHANGELOG for details about version upgrades.

This project aims to run on any platform and thus does not require any PHP extensions and supports running on legacy PHP 5.3 through current PHP 8+ and HHVM. It's highly recommended to use the latest supported PHP version for this project.

Tests

To run the test suite, you first need to clone this repo and then install all dependencies through Composer:

To run the test suite, go to the project root and run:

License

This project is released under the permissive MIT license.

Did you know that I offer custom development services and issuing invoices for sponsorships of releases and for contributions? Contact me (@clue) for details.

More


All versions of arguments with dependencies

PHP Build Version
Package Version
Requires php Version >=5.3
Composer command for our command line client (download client) This client runs in each environment. You don't need a specific PHP version etc. The first 20 API calls are free. Standard composer command

The package clue/arguments contains the following files

Loading the files please wait ....