/b-gtk/fix-viz

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/b-gtk/fix-viz
49 by Jelmer Vernooij
Merge in Dan Loda's gannotate plugin and put it in annotate/
1
# This program is free software; you can redistribute it and/or modify
2
# it under the terms of the GNU General Public License as published by
3
# the Free Software Foundation; either version 2 of the License, or
4
# (at your option) any later version.
5
6
# This program is distributed in the hope that it will be useful,
7
# but WITHOUT ANY WARRANTY; without even the implied warranty of
8
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
9
# GNU General Public License for more details.
10
11
# You should have received a copy of the GNU General Public License
12
# along with this program; if not, write to the Free Software
13
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
14
208.2.1 by Robert Collins
Better module docstring.
15
"""Graphical support for Bazaar using GTK.
16
17
This plugin includes:
18
gannotate         GTK+ annotate. 
19
gbranch           GTK+ branching. 
20
gcheckout         GTK+ checkout. 
323 by Jelmer Vernooij
Add gsend command.
21
gcommit           GTK+ commit dialog.
242.1.2 by Adeodato Simó
Fix gconflicts docstring.
22
gconflicts        GTK+ conflicts. 
208.2.1 by Robert Collins
Better module docstring.
23
gdiff             Show differences in working tree in a GTK+ Window. 
24
ginit             Initialise a new branch.
592.4.1 by Jasper Groenewegen
Add ginfo command to bzr, shows info dialog
25
ginfo             GTK+ branch info dialog
580.1.1 by Jelmer Vernooij
Add gloom command.
26
gloom             GTK+ loom browse dialog
571.1.1 by Jasper Groenewegen
Add gmerge command and change MergeDialog to set parent as default if available
27
gmerge            GTK+ merge dialog
208.2.1 by Robert Collins
Better module docstring.
28
gmissing          GTK+ missing revisions dialog. 
29
gpreferences      GTK+ preferences dialog. 
323 by Jelmer Vernooij
Add gsend command.
30
gpush             GTK+ push.
31
gsend             GTK+ send merge directive.
32
gstatus           GTK+ status dialog.
208.2.1 by Robert Collins
Better module docstring.
33
gtags             Manage branch tags.
34
visualise         Graphically visualise this branch. 
35
"""
73 by Jelmer Vernooij
Release 0.9, list myself as maintainer.
36
137 by Jelmer Vernooij
Warn about incompatible versions (taken from bzrtools, thanks Aaron).
37
import bzrlib
625.1.1 by Jelmer Vernooij
Use bzrlib.api.require_any_version() rather than doing our own version checking.
38
import bzrlib.api
625.2.1 by Jelmer Vernooij
Move commands to a separate module and register them lazily.
39
from bzrlib import errors
40
from bzrlib.commands import plugin_cmds
41
42
import os.path
137 by Jelmer Vernooij
Warn about incompatible versions (taken from bzrtools, thanks Aaron).
43
590 by Jelmer Vernooij
Open 0.96.0 for development.
44
version_info = (0, 96, 0, 'dev', 1)
137 by Jelmer Vernooij
Warn about incompatible versions (taken from bzrtools, thanks Aaron).
45
287 by Jelmer Vernooij
Use standard version tuple.
46
if version_info[3] == 'final':
47
    version_string = '%d.%d.%d' % version_info[:3]
48
else:
49
    version_string = '%d.%d.%d%s%d' % version_info
50
__version__ = version_string
137 by Jelmer Vernooij
Warn about incompatible versions (taken from bzrtools, thanks Aaron).
51
625.1.1 by Jelmer Vernooij
Use bzrlib.api.require_any_version() rather than doing our own version checking.
52
COMPATIBLE_BZR_VERSIONS = [(1, 6, 0), (1, 7, 0), (1, 8, 0), (1, 9, 0),
628.1.2 by Vincent Ladeuil
Upgrade COMPATIBLE_BZR_VERSIONS.
53
                           (1, 10, 0), (1, 11, 0), (1, 12, 0), (1, 13, 0),
54
                           (1, 15, 0),]
625.1.1 by Jelmer Vernooij
Use bzrlib.api.require_any_version() rather than doing our own version checking.
55
56
bzrlib.api.require_any_api(bzrlib, COMPATIBLE_BZR_VERSIONS)
137 by Jelmer Vernooij
Warn about incompatible versions (taken from bzrtools, thanks Aaron).
57
146 by Jelmer Vernooij
Move more code to top-level directory.
58
if __name__ != 'bzrlib.plugins.gtk':
625.2.1 by Jelmer Vernooij
Move commands to a separate module and register them lazily.
59
    from bzrlib.trace import warning
146 by Jelmer Vernooij
Move more code to top-level directory.
60
    warning("Not running as bzrlib.plugins.gtk, things may break.")
61
66.2.20 by Aaron Bentley
Nicer error when PyGTK not installed
62
def import_pygtk():
63
    try:
64
        import pygtk
65
    except ImportError:
66
        raise errors.BzrCommandError("PyGTK not installed.")
67
    pygtk.require('2.0')
68
    return pygtk
69
70
133 by Jelmer Vernooij
Actually use the ui factory.
71
def set_ui_factory():
177 by Jelmer Vernooij
Register commands all at once.
72
    import_pygtk()
142 by Jelmer Vernooij
Move some files to the top-level directory, add first test.
73
    from ui import GtkUIFactory
133 by Jelmer Vernooij
Actually use the ui factory.
74
    import bzrlib.ui
75
    bzrlib.ui.ui_factory = GtkUIFactory()
76
77
531.6.1 by Jelmer Vernooij
Try harder to find license and credits files.
78
def data_basedirs():
79
    return [os.path.dirname(__file__),
399.1.19 by Jelmer Vernooij
Add utility function for finding icon paths.
80
             "/usr/share/bzr-gtk", 
81
             "/usr/local/share/bzr-gtk"]
531.6.1 by Jelmer Vernooij
Try harder to find license and credits files.
82
83
84
def data_path(*args):
85
    for basedir in data_basedirs():
86
        path = os.path.join(basedir, *args)
399.1.19 by Jelmer Vernooij
Add utility function for finding icon paths.
87
        if os.path.exists(path):
88
            return path
89
    return None
90
91
531.6.1 by Jelmer Vernooij
Try harder to find license and credits files.
92
def icon_path(*args):
93
    return data_path(os.path.join('icons', *args))
94
95
505.1.1 by Jelmer Vernooij
Make handle-patch not dependend on the users name being abentley and install it.
96
def open_display():
97
    pygtk = import_pygtk()
98
    try:
99
        import gtk
100
    except RuntimeError, e:
101
        if str(e) == "could not open display":
102
            raise NoDisplayError
103
    set_ui_factory()
104
    return gtk
105
 
106
625.2.1 by Jelmer Vernooij
Move commands to a separate module and register them lazily.
107
commands = {
108
    "gannotate": ["gblame", "gpraise"],
109
    "gbranch": [],
110
    "gcheckout": [], 
111
    "gcommit": ["gci"], 
112
    "gconflicts": [], 
113
    "gdiff": [],
114
    "ginit": [],
115
    "ginfo": [],
116
    "gmerge": [],
117
    "gmissing": [], 
118
    "gpreferences": [], 
119
    "gpush": [], 
120
    "gselftest": [],
121
    "gsend": [],
122
    "gstatus": ["gst"],
123
    "gtags": [],
124
    "visualise": ["visualize", "vis", "viz"],
125
    }
177 by Jelmer Vernooij
Register commands all at once.
126
580.1.5 by Jelmer Vernooij
Try to import rather than use getattr to avoid problems wrt the order in which plugins are loaded.
127
try:
128
    from bzrlib.plugins import loom
129
except ImportError:
130
    pass # Loom plugin doesn't appear to be present
131
else:
625.2.1 by Jelmer Vernooij
Move commands to a separate module and register them lazily.
132
    commands["gloom"] = []
133
134
for cmd, aliases in commands.iteritems():
135
    plugin_cmds.register_lazy("cmd_%s" % cmd, aliases, "bzrlib.plugins.gtk.commands")
249 by Aaron Bentley
Add gselftest command
136
137
152 by Jelmer Vernooij
Cleanup some more code.
138
import gettext
139
gettext.install('olive-gtk')
140
475.1.2 by Vincent Ladeuil
Fix bug #187283 fix replacing _() by _i18n().
141
# Let's create a specialized alias to protect '_' from being erased by other
142
# uses of '_' as an anonymous variable (think pdb for one).
143
_i18n = gettext.gettext
173.1.2 by Robert Collins
Minor refactoring of __init__ to have less duplication.
144
625.2.1 by Jelmer Vernooij
Move commands to a separate module and register them lazily.
145
class NoDisplayError(errors.BzrCommandError):
55.1.2 by Jelmer Vernooij
Move commands to top-level __init__
146
    """gtk could not find a proper display"""
147
148
    def __str__(self):
133 by Jelmer Vernooij
Actually use the ui factory.
149
        return "No DISPLAY. Unable to run GTK+ application."
150
173.1.2 by Robert Collins
Minor refactoring of __init__ to have less duplication.
151
140 by Jelmer Vernooij
add framework for tests.
152
def test_suite():
153
    from unittest import TestSuite
154
    import tests
163 by Aaron Bentley
Prevent test suite from causing default-encoding changes
155
    import sys
156
    default_encoding = sys.getdefaultencoding()
157
    try:
158
        result = TestSuite()
330.6.4 by Aaron Bentley
Allow test suite to run without pygtk
159
        try:
160
            import_pygtk()
161
        except errors.BzrCommandError:
162
            return result
163 by Aaron Bentley
Prevent test suite from causing default-encoding changes
163
        result.addTest(tests.test_suite())
164
    finally:
170.1.2 by Aaron Bentley
Test suite only fixes encoding if it's changed. Fixes test_selftest bug.
165
        if sys.getdefaultencoding() != default_encoding:
166
            reload(sys)
167
            sys.setdefaultencoding(default_encoding)
140 by Jelmer Vernooij
add framework for tests.
168
    return result