1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
|
# Copyright (C) 2005-2012 Aaron Bentley <abentley@panoramicfeedback.com>
# Chris Ball <cjb@laptop.org>
# Gianluca Montecchi <gian@grys.it>
# Marien Zwart <marien.zwart@gmail.com>
# Thomas Gerigk <tgerigk@gmx.de>
# Tim Guirgies <lt.infiltrator@gmail.com>
# W. Trevor King <wking@tremily.us>
#
# This file is part of Bugs Everywhere.
#
# Bugs Everywhere is free software: you can redistribute it and/or modify it
# under the terms of the GNU General Public License as published by the Free
# Software Foundation, either version 2 of the License, or (at your option) any
# later version.
#
# Bugs Everywhere is distributed in the hope that it will be useful, but
# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
# more details.
#
# You should have received a copy of the GNU General Public License along with
# Bugs Everywhere. If not, see <http://www.gnu.org/licenses/>.
import libbe
import libbe.bug
import libbe.command
import libbe.command.util
class Status (libbe.command.Command):
"""Change a bug's status level
>>> import sys
>>> import libbe.bugdir
>>> bd = libbe.bugdir.SimpleBugDir(memory=False)
>>> io = libbe.command.StringInputOutput()
>>> io.stdout = sys.stdout
>>> ui = libbe.command.UserInterface(io=io)
>>> ui.storage_callbacks.set_storage(bd.storage)
>>> cmd = Status(ui=ui)
>>> cmd._storage = bd.storage
>>> bd.bug_from_uuid('a').status
'open'
>>> ret = ui.run(cmd, args=['closed', '/a'])
>>> bd.flush_reload()
>>> bd.bug_from_uuid('a').status
'closed'
>>> ret = ui.run(cmd, args=['none', '/a'])
Traceback (most recent call last):
UserError: Invalid status level: none
>>> ui.cleanup()
>>> bd.cleanup()
"""
name = 'status'
def __init__(self, *args, **kwargs):
libbe.command.Command.__init__(self, *args, **kwargs)
self.args.extend([
libbe.command.Argument(
name='status', metavar='STATUS', default=None,
completion_callback=libbe.command.util.complete_status),
libbe.command.Argument(
name='bug-id', metavar='BUG-ID', default=None,
repeatable=True,
completion_callback=libbe.command.util.complete_bug_id),
])
def _run(self, **params):
bugdirs = self._get_bugdirs()
for bug_id in params['bug-id']:
bugdir,bug,comment = (
libbe.command.util.bugdir_bug_comment_from_user_id(
bugdirs, bug_id))
if bug.status != params['status']:
try:
bug.status = params['status']
except ValueError as e:
if e.name != 'status':
raise e
raise libbe.command.UserError(
'Invalid status level: %s' % e.value)
return 0
def _long_help(self):
try: # See if there are any per-tree status configurations
bugdirs = self._get_bugdirs()
except NotImplementedError:
pass # No tree, just show the defaults
longest_status_len = max([len(s) for s in libbe.bug.status_values])
active_statuses = []
for status in libbe.bug.active_status_values :
description = libbe.bug.status_description[status]
s = '%*s : %s' % (longest_status_len, status, description)
active_statuses.append(s)
inactive_statuses = []
for status in libbe.bug.inactive_status_values :
description = libbe.bug.status_description[status]
s = '%*s : %s' % (longest_status_len, status, description)
inactive_statuses.append(s)
ret = """
Show or change a bug's status.
If no status is specified, the current value is printed. If a status
is specified, it will be assigned to the bug.
There are two classes of statuses, active and inactive, which are only
important for commands like "be list" that show only active bugs by
default.
Active status levels are:
%s
Inactive status levels are:
%s
You can override the list of allowed statuses on a per-repository
basis. See `be set --help` for details.
""" % ('\n '.join(active_statuses), '\n '.join(inactive_statuses))
return ret
|