Merge branch 'development' of github.com:RealOrangeOne/Printr
This commit is contained in:
commit
7a4aed96c0
13 changed files with 101 additions and 72 deletions
3
.gitignore
vendored
3
.gitignore
vendored
|
@ -58,4 +58,5 @@ target/
|
||||||
|
|
||||||
|
|
||||||
# Other
|
# Other
|
||||||
MANIFEST
|
MANIFEST
|
||||||
|
README.rst
|
13
README.md
13
README.md
|
@ -4,10 +4,21 @@ Printr is a simple PyPi module that allows for print statements to be replaces w
|
||||||
|
|
||||||
|
|
||||||
## Installation
|
## Installation
|
||||||
Installation can be done using pip in the standard way;
|
Installation can be done using pip in the standard way:
|
||||||
```
|
```
|
||||||
pip install python-printr
|
pip install python-printr
|
||||||
```
|
```
|
||||||
If you have python 3 installed, then install using `pip3`. There are no dependancies for this package, so installation should go ahead fine.
|
If you have python 3 installed, then install using `pip3`. There are no dependancies for this package, so installation should go ahead fine.
|
||||||
|
|
||||||
|
Alternatively, you can download directly from Pypi [here](https://pypi.python.org/pypi/Python-Printr/).
|
||||||
|
|
||||||
|
## Usage
|
||||||
|
```
|
||||||
|
import printr
|
||||||
|
|
||||||
|
printr.get_version()
|
||||||
|
>>> 0.0.3
|
||||||
|
```
|
||||||
|
The printr module contains various different printrs to assist you. You can find more information about these printrs on the wiki.
|
||||||
|
|
||||||
|
The main reason I wrote this project was to simplify status output for my projects, and because I'd never written a PyPi package before.
|
|
@ -1 +1 @@
|
||||||
pandoc --from=markdown --to=rst --output=README README.md
|
pandoc --from=markdown --to=rst --output=README.rst README.md
|
18
details.json
18
details.json
|
@ -1,11 +1,11 @@
|
||||||
{
|
{
|
||||||
'name' : 'Python-Printr',
|
"name": "Python-Printr",
|
||||||
'packages' : ['printr'],
|
"packages": ["printr"],
|
||||||
'version' : '0.0.1',
|
"version": "0.0.3",
|
||||||
'description' : 'Python module to allow a print line to be updated after printing',
|
"description": "Python module to allow a print line to be updated after printing",
|
||||||
'author' : 'Jake Howard',
|
"author": "Jake Howard",
|
||||||
'author_email' : 'me@theorangeone.net ',
|
"author_email": "me@theorangeone.net ",
|
||||||
'url' : 'https://github.com/RealOrangeOne/Printr',
|
"url": "https://github.com/RealOrangeOne/Printr",
|
||||||
'license':'MIT',
|
"license": "MIT",
|
||||||
'platforms':['any']
|
"platforms": ["any"]
|
||||||
}
|
}
|
32
printr/EllipsisPrintr/__init__.py
Normal file
32
printr/EllipsisPrintr/__init__.py
Normal file
|
@ -0,0 +1,32 @@
|
||||||
|
from printr.utils import write
|
||||||
|
|
||||||
|
class EllipsisPrintr():
|
||||||
|
def __init__(self, string, max=3, erase_after=False):
|
||||||
|
self.string = string
|
||||||
|
self.max = max
|
||||||
|
self.count = -1
|
||||||
|
self.erase_after = erase_after
|
||||||
|
|
||||||
|
def update(self, commit=False):
|
||||||
|
self.clear()
|
||||||
|
ellipsis = "." * self.count
|
||||||
|
write(self.string + ellipsis, commit=commit)
|
||||||
|
if self.count >= self.max:
|
||||||
|
self.zero()
|
||||||
|
self.count += 1
|
||||||
|
|
||||||
|
def zero(self):
|
||||||
|
self.count = -1
|
||||||
|
|
||||||
|
def commit(self):
|
||||||
|
print()
|
||||||
|
|
||||||
|
def clear(self):
|
||||||
|
print(' ' * (len(self.string) + self.max), end='\r')
|
||||||
|
|
||||||
|
def __enter__(self):
|
||||||
|
return self
|
||||||
|
def __exit__(self, type, value, traceback):
|
||||||
|
if self.erase_after:
|
||||||
|
self.clear()
|
||||||
|
self.commit()
|
|
@ -1,3 +1,7 @@
|
||||||
|
from printr.exceptions import FormattingError
|
||||||
|
from printr.utils import write
|
||||||
|
|
||||||
|
|
||||||
class ItterPrintr():
|
class ItterPrintr():
|
||||||
def __init__(self, string, maxValue, start, diff=1):
|
def __init__(self, string, maxValue, start, diff=1):
|
||||||
self.string = string
|
self.string = string
|
||||||
|
@ -8,16 +12,18 @@ class ItterPrintr():
|
||||||
self.buildString()
|
self.buildString()
|
||||||
|
|
||||||
def buildString(self):
|
def buildString(self):
|
||||||
return self.string.format(c=self.value, m=self.maxValue)
|
try:
|
||||||
|
return self.string.format(c=self.value, m=self.maxValue)
|
||||||
|
except:
|
||||||
|
raise FormattingError()
|
||||||
|
|
||||||
def reachedLimit(self):
|
def reachedLimit(self):
|
||||||
return self.maxValue <= self.value
|
return self.maxValue <= self.value
|
||||||
|
|
||||||
def update(self, inc=True):
|
def update(self, inc=True):
|
||||||
ending = '\r' if not self.reachedLimit() else '\n'
|
write(self.buildString(), commit=(not self.reachedLimit()))
|
||||||
print(self.buildString(), end=ending)
|
|
||||||
if inc:
|
if inc:
|
||||||
self.inc()
|
self.inc()
|
||||||
|
|
||||||
def inc(self):
|
def inc(self):
|
||||||
self.value += self.diff
|
self.value += self.diff
|
|
@ -1,17 +1,13 @@
|
||||||
# Import python modules
|
|
||||||
import os
|
import os
|
||||||
from json import loads as json_loads
|
from json import load as json_load
|
||||||
|
|
||||||
# Import Printr Modules
|
|
||||||
from .simplePrintr import SimplePrintr
|
|
||||||
from .itterPrintr import ItterPrintr
|
|
||||||
from .ellipsisPrintr import EllipsisPrintr
|
|
||||||
|
|
||||||
# Initialise
|
|
||||||
PRINTR_PATH = os.path.dirname(os.path.abspath(__file__))
|
PRINTR_PATH = os.path.dirname(os.path.abspath(__file__))
|
||||||
|
|
||||||
with open(PRINTR_PATH + '/details.json') as file:
|
from .ItterPrintr import ItterPrintr
|
||||||
PRINTR_DETAILS = json_loads(file)
|
from .EllipsisPrintr import EllipsisPrintr
|
||||||
|
|
||||||
|
with open(PRINTR_PATH + '/../details.json') as file:
|
||||||
|
PRINTR_DETAILS = json_load(file)
|
||||||
|
|
||||||
|
|
||||||
def get_version():
|
def get_version():
|
||||||
|
|
|
@ -1,23 +0,0 @@
|
||||||
class EllipsisPrintr():
|
|
||||||
def __init__(self, string, max=5):
|
|
||||||
self.string = string
|
|
||||||
self.max = max
|
|
||||||
self.count = -1
|
|
||||||
|
|
||||||
def update(self, commit=False):
|
|
||||||
self.clear()
|
|
||||||
ellipsis = "." * self.count
|
|
||||||
ending = '\r' if not commit else '\n'
|
|
||||||
print(self.string + ellipsis, end=ending)
|
|
||||||
if self.count >= self.max:
|
|
||||||
self.zero()
|
|
||||||
self.count += 1
|
|
||||||
|
|
||||||
def zero(self):
|
|
||||||
self.count = -1
|
|
||||||
|
|
||||||
def commit(self):
|
|
||||||
print()
|
|
||||||
|
|
||||||
def clear(self):
|
|
||||||
print(' ' * (len(self.string) + self.max), end='\r')
|
|
5
printr/exceptions.py
Normal file
5
printr/exceptions.py
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
class FormattingError(Exception):
|
||||||
|
message = "Provided string doesn't contain formatting placeholders for {c} and/or {m}"
|
||||||
|
def __init__(self):
|
||||||
|
super().__init__(self.message)
|
||||||
|
|
|
@ -1,11 +0,0 @@
|
||||||
class SimplePrintr():
|
|
||||||
@classmethod
|
|
||||||
def write(string, commit=False):
|
|
||||||
if commit:
|
|
||||||
print(string)
|
|
||||||
else:
|
|
||||||
print(string, end='\r')
|
|
||||||
|
|
||||||
@classmethod
|
|
||||||
def commit():
|
|
||||||
print()
|
|
6
printr/utils.py
Normal file
6
printr/utils.py
Normal file
|
@ -0,0 +1,6 @@
|
||||||
|
def write(string, commit=False):
|
||||||
|
ending = '\n' if commit else '\r'
|
||||||
|
print(string, end=ending)
|
||||||
|
|
||||||
|
def commit():
|
||||||
|
print()
|
23
setup.py
23
setup.py
|
@ -1,5 +1,5 @@
|
||||||
from distutils.core import setup
|
from distutils.core import setup
|
||||||
from json import loads as json_loads
|
from json import load as json_load
|
||||||
LONG_DESCRIPTION = None
|
LONG_DESCRIPTION = None
|
||||||
try:
|
try:
|
||||||
LONG_DESCRIPTION = open('README.md').read()
|
LONG_DESCRIPTION = open('README.md').read()
|
||||||
|
@ -8,17 +8,16 @@ except:
|
||||||
|
|
||||||
DETAILS = None
|
DETAILS = None
|
||||||
with open('details.json') as file:
|
with open('details.json') as file:
|
||||||
DETAILS = json_loads(file)
|
DETAILS = json_load(file)
|
||||||
|
|
||||||
setup(
|
setup(
|
||||||
name = DETAILS.name,
|
name = DETAILS['name'],
|
||||||
packages = DETAILS.packages,
|
packages = DETAILS['packages'],
|
||||||
version = DETAILS.version,
|
version = DETAILS['version'],
|
||||||
description = DETAILS.description,
|
description = DETAILS['description'],
|
||||||
long_description = LONG_DESCRIPTION,
|
long_description = LONG_DESCRIPTION,
|
||||||
author = DETAILS.author,
|
author = DETAILS['author'],
|
||||||
author_email = DETAILS.author_email,
|
author_email = DETAILS['author_email'],
|
||||||
url = DETAILS.url,
|
url = DETAILS['url'],
|
||||||
license = DETAILS.license,
|
license = DETAILS['license'],
|
||||||
platforms = DETAILS.platform
|
platforms = DETAILS['platforms']
|
||||||
)
|
)
|
7
tests/context_manager.py
Normal file
7
tests/context_manager.py
Normal file
|
@ -0,0 +1,7 @@
|
||||||
|
from printr import EllipsisPrintr
|
||||||
|
from time import sleep
|
||||||
|
|
||||||
|
with EllipsisPrintr('Printing') as p:
|
||||||
|
for i in range(30):
|
||||||
|
p.update()
|
||||||
|
sleep(0.1)
|
Reference in a new issue