weew / console-formatter
Formatter for command line output.
Installs: 12 167
Dependents: 1
Suggesters: 0
Security: 0
Stars: 0
Watchers: 2
Forks: 0
Open Issues: 0
Requires
- weew/helpers-array: ^1.2
- weew/helpers-string: ^1.7
Requires (Dev)
- henrikbjorn/phpspec-code-coverage: ^2.0
- phpspec/phpspec: ^2.4
- satooshi/php-coveralls: ^0.6.1
- weew/helpers-phpspec: ^1.0
This package is not auto-updated.
Last update: 2025-01-14 23:32:00 UTC
README
Table of contents
Installation
composer require weew/console-formatter
Introduction
This package allows you to format text for terminal, using very simple and html like syntax. You will be able to change text color, text background and text format.
This package has not been tested on windows and I do not intend to do so. Contributions for windows support are highly appreciated.
Adding styles
Before you'll be able to use styles, you must created them first.
$formatter = new ConsoleFormatter(); $style = (new ConsoleStyle('alert')) ->setColor(ConsoleColor::WHITE) ->setBackground(ConsoleBackground::RED) ->setFormat([ConsoleFormat::BOLD, ConsoleFormat::UNDERLINE]); $formatter->addStyle($style); // or $formatter->style('alert') ->setColor(ConsoleColor::WHITE) ->setBackground(ConsoleBackground::RED) ->setFormat([ConsoleFormat::BOLD, ConsoleFormat::UNDERLINE]); // or $formatter->style('alert') ->parseStyle('clr=white bg=red fmt=bold,underline');
Using styles
As soon as you've register a style, it will be applied to matching tags. If a style is unknown, the tag will be ignored. Example below will output properly formatted text.
echo $formatter->format('<alert>text</alert>');
Using inline styles
You can apply styling inline, without having to register a new style. To do that you must use the <style></style>
tag.
echo $formatter->format('<style clr=red bg=white>red text on white background</style>');
You can also use inline styling on predefined styles.
$formatter->format('<alert clr=yellow>alert style with yellow text</alert>');
Style isolation
Whenever you have nested styles, one style might inherit from the parent. This is disabled by default to prevent unwanted styles changes. You can enable it for each style separately.
$formatter->style('name') ->setAllowInheritance(true);
Disabling ANSI
If you're working with a terminal that does not support ANSI, you can disable formatting. All known style tags will be removed from the string.
$formatter->setEnableAnsi(false); // will return: alert <unknown>tag</unknown> $formatter->format('<style clr=red><alert>alert <unknown>tag</unknown></alert></style>');
Examples
You can run the examples.php
file to see if it works on your system.