ekowabaka/clearice
A tool to help in the building of CLI apps. Provides command line parsing and simple console I/O interfaces.
Maintainers
Requires
- php: >=7.1
Requires (Dev)
- mikey179/vfsstream: @stable
- phpunit/phpunit: @stable
Suggests
None
Provides
None
Conflicts
None
Replaces
None
MIT f9ca0a68d617a94c91e090eef58cbce922e61273
- James Ekow Abaka Ainooson <jainooson.woop@gmail.com>
This package is auto-updated.
Last update: 2026-06-07 21:16:58 UTC
README
π Build Status
π Scrutinizer Code Quality
π Code Coverage
π Latest Stable Version
π Total Downloads
ClearIce provides tools for PHP applications to help with parsing command line arguments, and performing interactive I/O sessions. Arguments supplied at the command line or through a shell are validated and supplied to your script in a consistently organized format. And gues what, there's also the added possibility of automatically generating help messages for your applications.
Installing
Although you can directly include the ClearIce scripts into your application, the best way of installing it is through composer.
composer require ekowabaka/clearice
ClearIce has no dependencies other than a PHP interpreter with version 7.1 or better.
Parsing Arguments with ClearICE
Let's get started with an example. If you ever wanted to parse command line arguments you can put ...
<?php require "vendor/autoload.php"; $parser = new \clearice\argparser\ArgumentParser(); $parser->addOption([ 'name' => 'input', 'short_name' => 'i', 'type' => 'string', 'required' => true ]); $parser->addOption([ 'name' => 'output', 'short_name' => 'o', 'type' => 'string', 'default' => '/default/output/path' ]); $options = $parser->parse($argv); print_r($options);
... in a file (which you can for example save as wiki.php). Then when you execute ...
php wiki.php generate --input=/home/james --output=/var/www/cool-wiki
... the output will be ...
Array
(
[input] => /input/path
[output] => /output/path
[__executed] => wiki.php
)
... and so will the following:
php test.php --input /input/path --output /output/path
php test.php -i/input/path -o/output/path
Interactive I/O with ClearICE
If you are interested in interactive I/O, entering this
use clearice\io\Io; $io = new Io(); $name = $io->getResponse('What is your name', ['default' => 'No Name']); $direction = $io->getResponse("Okay $name, where do you want to go", [ 'required' => true, 'answers' => array('north', 'south', 'east', 'west') ] );
could lead to an interaction like this:
What is your name [No Name]: β
Okay No Name, where do you want to go (north/south/east/west) []: β
A value is required.
Okay No Name, where do you want to go (north/south/east/west) []: homeβ
Please provide a valid answer.
Okay No Name, where do you want to go (north/south/east/west) []:
Hope you enjoy using ClearIce!
