From 63a6147548494b701afa1959550833f489541de6 Mon Sep 17 00:00:00 2001 From: Prashant Sinha Date: Sun, 2 Oct 2016 00:07:05 +0530 Subject: [PATCH] Added docs boilerplates --- docs/assets.sketch | Bin 73728 -> 73728 bytes docs/index.md | 49 +++++++++++++++++++++++++++++++++++++++++++++ mkdocs.yml | 9 +++++++++ requirements.txt | 1 + setup.py | 6 +++--- 5 files changed, 62 insertions(+), 3 deletions(-) create mode 100644 docs/index.md create mode 100644 mkdocs.yml diff --git a/docs/assets.sketch b/docs/assets.sketch index 039b6853915721c0dba579e84dc92bfbae09eb5a..62deaf8ff314e1d40ab8ae50fa8004fdc268822e 100644 GIT binary patch delta 18966 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 E0FQ+{vj6}9 delta 20933 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 F^Z*yLLZ|=$ diff --git a/docs/index.md b/docs/index.md new file mode 100644 index 0000000..e142413 --- /dev/null +++ b/docs/index.md @@ -0,0 +1,49 @@ +# Hues + +This is the 90s and your terminal can display _16_ glorious colors. +Your Python scripts deserve the some color love. `Hues` makes printing +to console in color easy. + +Just grab the package from `PIP`, and your monochromatic days will be a +thing of past! + +## Quickstart + +Go, grab the latest version from PIP. Run: + +```bash +pip install hues +``` + +Then, in your scripts, do this: + +```python +>>> from hues import hue +>>> print(hue('unicorns!').bright_cyan.bold) +``` + + +_whoa!_ + +All the colors, styles and backgrounds are available as object attributes. The chainable syntax is optimized deterministically using a push down automaton, so when you're being particularly indecisive, you can: + +```python +>>> print(hue('MONDAY!').bold.red.bg_green.underline.bright_yellow) +``` + +and there won't be a single trace of `red` in your `bright yellow` message to mondays. + +Each `hue` string is self closing, so you can't accidentally color your whole terminal yellow because you forgot the `reset` escape sequence. + + +## Colors + +All 16 glorious ANSI colors are available for both background and foreground. Assorted text styles such as **`bold`**, _`italics`_ and `underline` are also available. Too many colors? Worry not fam, go to town with `reset` attribute. + + +## Todo +- [ ] Expand this readme. +- [ ] Add screenshots! +- [ ] Unicorns required. + +> Back in my days, we didn't even have colors! diff --git a/mkdocs.yml b/mkdocs.yml new file mode 100644 index 0000000..9aa5a2f --- /dev/null +++ b/mkdocs.yml @@ -0,0 +1,9 @@ +site_name: hues +site_url: https://hues.noop.pw +repo_url: https://github.com/prashnts/hues/ +site_author: Prashant Sinha + +markdown_extensions: + - smarty + - toc: + permalink: True diff --git a/requirements.txt b/requirements.txt index 4e3a371..5ee2766 100644 --- a/requirements.txt +++ b/requirements.txt @@ -3,6 +3,7 @@ coverage==4.2 extras==1.0.0 fixtures==3.0.0 linecache2==1.0.0 +mkdocs==0.15.3 mox3==0.18.0 pbr==1.10.0 py==1.4.31 diff --git a/setup.py b/setup.py index 63af253..718c198 100644 --- a/setup.py +++ b/setup.py @@ -1,6 +1,6 @@ import re -from setuptools import setup, find_packages +from setuptools import setup from codecs import open from os import path @@ -15,8 +15,8 @@ vtp = re.search(rex, fp.read(), re.M).groups() __version__ = '.'.join(vtp) -install_requires = ['PyYAML',] -setup_requires = ['pytest-runner',] +install_requires = ('PyYAML',) +setup_requires = ('pytest-runner',) test_requirements = ['pytest', 'coverage', 'pyfakefs']