3
# This program is free software; you can redistribute it and/or modify
4
# it under the terms of the GNU General Public License as published by
5
# the Free Software Foundation; either version 2 of the License, or
6
# (at your option) any later version.
8
# This program is distributed in the hope that it will be useful,
9
# but WITHOUT ANY WARRANTY; without even the implied warranty of
10
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11
# GNU General Public License for more details.
13
# You should have received a copy of the GNU General Public License
14
# along with this program; if not, write to the Free Software
15
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
17
"""GTK+ frontends to Bazaar commands """
18
from bzrlib.commands import Command, register_command, display_command
19
from bzrlib.errors import NotVersionedError, BzrCommandError, NoSuchFile
20
from bzrlib.commands import Command, register_command
21
from bzrlib.option import Option
22
from bzrlib.branch import Branch
23
from bzrlib.workingtree import WorkingTree
24
from bzrlib.bzrdir import BzrDir
26
class cmd_gbranch(Command):
36
except RuntimeError, e:
37
if str(e) == "could not open display":
40
from clone import CloneDialog
42
window = CloneDialog()
43
if window.run() == gtk.RESPONSE_OK:
44
bzrdir = BzrDir.open(window.url)
45
bzrdir.sprout(window.dest_path)
47
register_command(cmd_gbranch)
49
class cmd_gdiff(Command):
50
"""Show differences in working tree in a GTK+ Window.
52
Otherwise, all changes for the tree are listed.
54
takes_args = ['filename?']
55
takes_options = ['revision']
58
def run(self, revision=None, filename=None):
59
wt = WorkingTree.open_containing(".")[0]
61
if revision is not None:
62
if len(revision) == 1:
64
revision_id = revision[0].in_history(branch).rev_id
65
tree2 = branch.repository.revision_tree(revision_id)
66
elif len(revision) == 2:
67
revision_id_0 = revision[0].in_history(branch).rev_id
68
tree2 = branch.repository.revision_tree(revision_id_0)
69
revision_id_1 = revision[1].in_history(branch).rev_id
70
tree1 = branch.repository.revision_tree(revision_id_1)
73
tree2 = tree1.basis_tree()
75
from bzrlib.plugins.gtk.viz.diffwin import DiffWindow
78
window.connect("destroy", lambda w: gtk.main_quit())
79
window.set_diff("Working Tree", tree1, tree2)
80
if filename is not None:
81
tree_filename = tree1.relpath(filename)
83
window.set_file(tree_filename)
85
if (tree1.inventory.path2id(tree_filename) is None and
86
tree2.inventory.path2id(tree_filename) is None):
87
raise NotVersionedError(filename)
88
raise BzrCommandError('No changes found for file "%s"' %
94
register_command(cmd_gdiff)
96
class cmd_visualise(Command):
97
"""Graphically visualise this branch.
99
Opens a graphical window to allow you to see the history of the branch
100
and relationships between revisions in a visual manner,
102
The default starting point is latest revision on the branch, you can
103
specify a starting point with -r revision.
107
Option('limit', "maximum number of revisions to display",
109
takes_args = [ "location?" ]
110
aliases = [ "visualize", "vis", "viz" ]
112
def run(self, location=".", revision=None, limit=None):
113
(branch, path) = Branch.open_containing(location)
115
branch.repository.lock_read()
118
revid = branch.last_revision()
122
(revno, revid) = revision[0].in_history(branch)
124
from viz.bzrkapp import BzrkApp
127
app.show(branch, revid, limit)
129
branch.repository.unlock()
134
register_command(cmd_visualise)
136
class cmd_gannotate(Command):
139
Browse changes to FILENAME line by line in a GTK+ window.
142
takes_args = ["filename", "line?"]
144
Option("all", help="show annotations on all lines"),
145
Option("plain", help="don't highlight annotation lines"),
146
Option("line", type=int, argname="lineno",
147
help="jump to specified line number")
149
aliases = ["gblame", "gpraise"]
151
def run(self, filename, all=False, plain=False, line='1'):
157
except RuntimeError, e:
158
if str(e) == "could not open display":
164
raise BzrCommandError('Line argument ("%s") is not a number.' %
167
from annotate.gannotate import GAnnotateWindow
168
from annotate.config import GAnnotateConfig
170
(wt, path) = WorkingTree.open_containing(filename)
173
file_id = wt.path2id(path)
176
raise NotVersionedError(filename)
178
window = GAnnotateWindow(all, plain)
179
window.connect("destroy", lambda w: gtk.main_quit())
180
window.set_title(path + " - gannotate")
181
config = GAnnotateConfig(window)
185
window.annotate(branch, file_id)
188
window.jump_to_line(line)
192
register_command(cmd_gannotate)
194
class cmd_gcommit(Command):
195
"""GTK+ commit dialog
197
Graphical user interface for committing revisions"""
202
def run(self, filename=None):
208
except RuntimeError, e:
209
if str(e) == "could not open display":
212
from commit import GCommitDialog
213
from bzrlib.commit import Commit
214
from bzrlib.errors import (BzrCommandError, PointlessCommit, ConflictsInTree,
217
(wt, path) = WorkingTree.open_containing(filename)
220
file_id = wt.path2id(path)
223
raise NotVersionedError(filename)
225
dialog = GCommitDialog(wt)
226
dialog.set_title(path + " - Commit")
227
if dialog.run() != gtk.RESPONSE_CANCEL:
228
Commit().commit(working_tree=wt,message=dialog.message,
229
specific_files=dialog.specific_files)
231
register_command(cmd_gcommit)
233
class NoDisplayError(BzrCommandError):
234
"""gtk could not find a proper display"""
237
return "No DISPLAY. gannotate is disabled."