~abentley/bzrtools/bzrtools.dev

14 by abentley
GPLed the project, ignored files
1
# Copyright (C) 2005 Aaron Bentley
2
# <aaron.bentley@utoronto.ca>
3
#
4
#    This program is free software; you can redistribute it and/or modify
5
#    it under the terms of the GNU General Public License as published by
6
#    the Free Software Foundation; either version 2 of the License, or
7
#    (at your option) any later version.
8
#
9
#    This program is distributed in the hope that it will be useful,
10
#    but WITHOUT ANY WARRANTY; without even the implied warranty of
11
#    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12
#    GNU General Public License for more details.
13
#
14
#    You should have received a copy of the GNU General Public License
15
#    along with this program; if not, write to the Free Software
16
#    Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
17
11 by abentley
refactored out progress.py
18
import sys
14 by abentley
GPLed the project, ignored files
19
11 by abentley
refactored out progress.py
20
class Progress(object):
21
    def __init__(self, units, current, total=None):
22
        self.units = units
23
        self.current = current
24
        self.total = total
25
        self.percent = None
26
        if self.total is not None:
27
            self.percent = 100.0 * current / total
28
29
    def __str__(self):
30
        if self.total is not None:
31
            return "%i of %i %s %.1f%%" % (self.current, self.total, self.units,
32
                                         self.percent)
33
        else:
34
            return "%i %s" (self.current, self.units) 
35
36
37
def progress_bar(progress):
38
    fmt = " %i of %i %s (%.1f%%)"
39
    f = fmt % (progress.total, progress.total, progress.units, 100.0)
40
    max = len(f)
41
    cols = 77 - max
42
    markers = int (float(cols) * progress.current / progress.total)
43
    txt = fmt % (progress.current, progress.total, progress.units,
44
                 progress.percent)
32 by Aaron Bentley
Made progress bars use stderr
45
    sys.stderr.write("\r[%s%s]%s" % ('='*markers, ' '*(cols-markers), txt))
11 by abentley
refactored out progress.py
46
47
def clear_progress_bar():
32 by Aaron Bentley
Made progress bars use stderr
48
    sys.stderr.write('\r%s\r' % (' '*79))
11 by abentley
refactored out progress.py
49
33 by Aaron Bentley
Added spinner progress indicator
50
def spinner_str(progress, show_text=False):
51
    """
52
    Produces the string for a textual "spinner" progress indicator
53
    :param progress: an object represinting current progress
54
    :param show_text: If true, show progress text as well
55
    :return: The spinner string
56
57
    >>> spinner_str(Progress("baloons", 0))
58
    '|'
59
    >>> spinner_str(Progress("baloons", 5))
60
    '/'
61
    >>> spinner_str(Progress("baloons", 6), show_text=True)
62
    '- 6 baloons'
63
    """
64
    positions = ('|', '/', '-', '\\')
65
    text = positions[progress.current % 4]
66
    if show_text:
67
        text+=" %i %s" % (progress.current, progress.units)
68
    return text
69
70
def spinner(progress, show_text=False, output=sys.stderr):
71
    """
72
    Update a spinner progress indicator on an output
73
    :param progress: The progress to display
74
    :param show_text: If true, show text as well as spinner
75
    :param output: The output to write to
76
77
    >>> spinner(Progress("baloons", 6), show_text=True, output=sys.stdout)
78
    \r- 6 baloons
79
    """
80
    output.write('\r%s' % spinner_str(progress, show_text))
81
82
def run_tests():
83
    import doctest
84
    result = doctest.testmod()
85
    if result[1] > 0:
86
        if result[0] == 0:
87
            print "All tests passed"
88
    else:
89
        print "No tests to run"
90
if __name__ == "__main__":
91
    run_tests()