7061: User.progress

docstrings

svn: r23093
This commit is contained in:
Vassilii Khachaturov 2013-09-12 17:51:42 +00:00
parent dd8263a6e8
commit 299235a687

View File

@ -42,6 +42,8 @@ class User():
def begin_progress(self, title, message, steps): def begin_progress(self, title, message, steps):
""" """
Start showing a progress indicator to the user. Start showing a progress indicator to the user.
Don't use this method directly, use progress instead.
@param title: the title of the progress meter @param title: the title of the progress meter
@type title: str @type title: str
@ -58,6 +60,8 @@ class User():
def step_progress(self): def step_progress(self):
""" """
Advance the progress meter. Advance the progress meter.
Don't use this method directly, use progress instead.
""" """
pass pass
@ -82,12 +86,26 @@ class User():
def end_progress(self): def end_progress(self):
""" """
Stop showing the progress indicator to the user. Stop showing the progress indicator to the user.
Don't use this method directly, use progress instead.
""" """
pass pass
# Context-manager wrapper of the begin/step/end_progress above # Context-manager wrapper of the begin/step/end_progress above
@contextmanager @contextmanager
def progress(self, *args, **kwargs): def progress(self, *args, **kwargs):
"""
Preferred form of context reporting.
Parameters: same as for begin_progress.
Usage example (see gramps/cli/test/user_test.py):
with self.user.progress("Foo", "Bar", 0) as step:
for i in range(10):
step()
Ensures end_progress will be called even if an exception was thrown.
"""
self.begin_progress(*args, **kwargs) self.begin_progress(*args, **kwargs)
try: try:
yield self.step_progress yield self.step_progress