gbhorwood / macrame
A library for building command line applications
Installs: 22
Dependents: 0
Suggesters: 0
Security: 0
Stars: 7
Watchers: 1
Forks: 0
Open Issues: 2
pkg:composer/gbhorwood/macrame
Requires
- php: ^7.4|^8.0
- gbhorwood/tabletown: ^1.0
- mikey179/vfsstream: ^1.6
- povils/figlet: ^1.0
Requires (Dev)
- php-mock/php-mock-phpunit: ^2.7
- phpstan/phpstan: ^1.10
- phpunit/phpunit: ^10.2
This package is auto-updated.
Last update: 2025-10-04 18:21:39 UTC
README
Macrame is a library for building interactive command line scripts in PHP. It provides methods to create interactive menus, format text for the terminal, handle command-line arguments, read and validate user input, run processes in the background, and more. Macrame was developed as an internal project for Fruitbat Studios/Cloverhitch Technologies/Kludgetastic Implementations.
Install
Macrame is installed via composer:
composer require gbhorwood/macrame
Documentation and Resources
Full documentation and a set of examples are found on the documentation site, including:
Hello world
The fastest way to get up and running is to use the 'hello world' example and replace the 'output text' line with your custom code.
#!/usr/bin/env php <?php require __DIR__ . '/vendor/autoload.php'; use Gbhorwood\Macrame\Macrame; // instantiate a Macrame object with the script name $macrame = new Macrame("My Script Name"); // only execute if run from the command line if($macrame->running()) { // confirm host is good. die on failure. $macrame->preflight(); // output text to STDOUT $macrame->text("hello world")->write(); // exit cleanly $macrame->exit(); }
A full walkthrough of 'hello world' is given in the quick start.
Requirements
Macrame is a pure PHP library. The requirements are:
- PHP 7.4 or higher
- posixextension
- mbstringextension
Since Macrame is for building command-line applications, it can be difficult to guarantee that the host system meets the minimum requirements. To address this, Macrame provides a preflight() function to validate that the host can run Macrame scripts.
Contributing
Contributions submitted via pull request are welcome and will be fully credited.
- Use PSR-2 style: Using php-cs-fixer is recommended, but any tool is fine. Do not use windows line endings.
- Use gitflow: Create a new feature branch from developfor all new feature work.
- One pull request per feature/fix: Pull requests should only contain work for one feature or fix.
- Use static analysis (phpstan): All code should pass phpstanat level 6. Use thephpstan.neonin the repository.
- Update documentation if needed: If documentation is required, update the daux pages in the documentation/directory.
- Write tests (phpunit): Achieving 100% coverage is difficult, especially for anything that uses animations or forks child processes, but please try.