A command-line-tool beautifier.
Project description
Ecstasy is here to make your command-line tool beautiful and fancy.
Your command-line tool’s output without ecstasy:
Your command-line tool’s output with (on?) ecstasy:
Usage
To use ecstasy, you mark up a standard Python string using ecstasy’s special syntax, chose some sassy styling and formatting flags, pass them on to the package-level beautify() method and, in return, get your beautified string, ready to kick ass when printed to your command-line:
import ecstasy
# <...> is a normal phrase, its style is determined by its position
# <(x)...> is a phrase with an argument, its style is the one at index 'x'
# <<...> <...>> is a phrase with nested phrases, their styles cascade
text = "<Cats> are <(0)just> <<small>, furry <elephants>>!"
# Beautify text by specifying styles via flag combinations
text = ecstasy.beautify(text,
ecstasy.Style.Blink | ecstasy.Color.Red,
ecstasy.Style.Bold | ecstasy.Fill.Blue,
ecstasy.Color.Magenta | ecstasy.Style.Underline,
small=ecstasy.Style.Invert | ecstasy.Color.White)
# Keyword arguments (small=...) cause all phrases matching the string of
# the key to have the style specified by the keyword argument's value.
print(text)
Running this in a script from a command-line outputs:
Installation
Now that you’re convinced, you can install ecstasy with pip:
$ pip install ecstasy
… and get crackin’.
Documentation
Full documentation and usage descriptions specifying all possible options and possibilities of how you can beautify your strings with ecstasy can be found here.
Compatibility
Python Versions
Built with Python 3.4 and Python 2.7. Additionally successfully backported to and tested with Python 2.6, 3.2 and also 3.3. See what Travis has to say about it.
Terminal Support
Works out of the box with your Mac’s terminal. For more information, please enjoy this table:
Terminal |
Bold |
Dim |
Underlined |
Blink |
Invert |
Hidden |
Color |
---|---|---|---|---|---|---|---|
aTerm |
✓ |
X |
✓ |
X |
✓ |
X |
✓ |
Eterm |
(1) |
X |
✓ |
X |
✓ |
X |
✓ |
GNOME |
✓ |
✓ |
✓ |
X |
✓ |
✓ |
✓ |
Guake |
✓ |
✓ |
✓ |
X |
✓ |
✓ |
✓ |
Konsole |
✓ |
X |
✓ |
✓ |
✓ |
X |
✓ |
Nautilus |
✓ |
✓ |
✓ |
X |
✓ |
✓ |
✓ |
rxvt |
✓ |
X |
✓ |
(2) |
✓ |
X |
✓ |
Terminator |
✓ |
✓ |
✓ |
X |
✓ |
✓ |
✓ |
Tilda |
✓ |
X |
✓ |
X |
✓ |
X |
✓ |
XFCE4 |
✓ |
✓ |
✓ |
X |
✓ |
✓ |
✓ |
XTerm |
✓ |
X |
✓ |
✓ |
✓ |
✓ |
✓ |
xvt |
✓ |
X |
✓ |
X |
✓ |
X |
X |
Linux TTY |
✓ |
X |
X |
X |
✓ |
X |
✓ |
VTE |
✓ |
✓ |
✓ |
X |
✓ |
✓ |
✓ |
(1) Lighter colors instead of bold.
(2) Lighter colors instead of blink.
License
Ecstasy is released under the MIT license.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file ecstasy-0.1.3.tar.gz
.
File metadata
- Download URL: ecstasy-0.1.3.tar.gz
- Upload date:
- Size: 15.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 3c535dc6a2b3500114a4e6f44f8e33f0c7e1296444f080ed1c26c4a8dc16bd06 |
|
MD5 | e459d7e017b6c8a94e078b6fe55bf4f5 |
|
BLAKE2b-256 | b473467c727fd071c85e77052ab3d964afab4fa28b0dd86eb162affe299f8c89 |
File details
Details for the file ecstasy-0.1.3-py2.py3-none-any.whl
.
File metadata
- Download URL: ecstasy-0.1.3-py2.py3-none-any.whl
- Upload date:
- Size: 19.0 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 216dda6e5bd33fd6dc3962f6e60894010300ad19764f59f0036bace044115b31 |
|
MD5 | e43dea3fa18f69e3d41fea919964d4f8 |
|
BLAKE2b-256 | 28babc2a56f1322218489d18d5d0e1c1d91cdfaf65ca60e31cfe10b83d5d845b |