/b-gtk/fix-viz

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/b-gtk/fix-viz

« back to all changes in this revision

Viewing changes to __init__.py

  • Committer: Szilveszter Farkas (Phanatic)
  • Date: 2006-08-07 16:51:21 UTC
  • mto: (0.14.1 main) (93.1.1 win32.bialix)
  • mto: This revision was merged to the branch mainline in revision 83.
  • Revision ID: Szilveszter.Farkas@gmail.com-20060807165121-10fe27c374bbdffd
Added new artwork.

2006-08-07  Szilveszter Farkas <Szilveszter.Farkas@gmail.com>

    * olive.galde: added custom artwork (icons)
    * icons/*: new icons for the toolbar
    * setup.py: install the icons

Show diffs side-by-side

added added

removed removed

Lines of Context:
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
 
 
15
 
"""Graphical support for Bazaar using GTK.
16
 
 
17
 
This plugin includes:
18
 
gannotate         GTK+ annotate.
19
 
gbranch           GTK+ branching.
20
 
gcheckout         GTK+ checkout.
21
 
gcommit           GTK+ commit dialog.
22
 
gconflicts        GTK+ conflicts.
23
 
gdiff             Show differences in working tree in a GTK+ Window.
24
 
ginit             Initialise a new branch.
25
 
gloom             GTK+ loom browse dialog
26
 
gmerge            GTK+ merge dialog
27
 
gmissing          GTK+ missing revisions dialog.
28
 
gpreferences      GTK+ preferences dialog.
29
 
gpush             GTK+ push.
30
 
gsend             GTK+ send merge directive.
31
 
gstatus           GTK+ status dialog.
32
 
gtags             Manage branch tags.
33
 
visualise         Graphically visualise this branch.
34
 
"""
35
 
 
36
 
from __future__ import absolute_import
37
 
 
38
 
import os
39
 
import sys
40
 
 
41
 
if getattr(sys, "frozen", None) is not None: # we run bzr.exe
42
 
 
43
 
    # FIXME: Unless a better packaging solution is found, the following
44
 
    # provides a workaround for https://bugs.launchpad.net/bzr/+bug/388790 Also
45
 
    # see https://code.edge.launchpad.net/~vila/bzr-gtk/388790-windows-setup
46
 
    # for more details about while it's needed.
47
 
 
48
 
    # NOTE: _lib must be ahead of bzrlib or sax.saxutils (in olive) fails
49
 
    here = os.path.dirname(__file__)
50
 
    sys.path.insert(0, os.path.join(here, '_lib'))
51
 
    sys.path.append(os.path.join(here, '_lib/gtk-2.0'))
52
 
 
53
 
 
54
 
import bzrlib
55
 
import bzrlib.api
56
 
from bzrlib import (
57
 
    branch,
58
 
    config,
59
 
    )
60
 
from bzrlib.commands import plugin_cmds
61
 
 
62
 
from bzrlib.plugins.gtk.info import (
63
 
    bzr_plugin_version as version_info,
64
 
    bzr_compatible_versions,
65
 
    )
66
 
 
67
 
if version_info[3] == 'final':
68
 
    version_string = '%d.%d.%d' % version_info[:3]
69
 
else:
70
 
    version_string = '%d.%d.%d%s%d' % version_info
71
 
__version__ = version_string
72
 
 
73
 
bzrlib.api.require_any_api(bzrlib, bzr_compatible_versions)
74
 
 
75
 
if __name__ != 'bzrlib.plugins.gtk':
76
 
    from bzrlib.trace import warning
77
 
    warning("Not running as bzrlib.plugins.gtk, things may break.")
78
 
 
79
 
 
80
 
def set_ui_factory():
81
 
    from bzrlib.plugins.gtk.ui import GtkUIFactory
82
 
    import bzrlib.ui
83
 
    bzrlib.ui.ui_factory = GtkUIFactory()
84
 
 
85
 
 
86
 
def data_basedirs():
87
 
    return [os.path.dirname(__file__),
88
 
             "/usr/share/bzr-gtk", 
89
 
             "/usr/local/share/bzr-gtk"]
90
 
 
91
 
 
92
 
def data_path(*args):
93
 
    for basedir in data_basedirs():
94
 
        path = os.path.join(basedir, *args)
95
 
        if os.path.exists(path):
96
 
            return path
97
 
    return None
98
 
 
99
 
 
100
 
def icon_path(*args):
101
 
    return data_path(os.path.join('icons', *args))
102
 
 
103
 
 
104
 
commands = {
105
 
    "gannotate": ["gblame", "gpraise"],
106
 
    "gbranch": [],
107
 
    "gcheckout": [],
108
 
    "gcommit": ["gci"],
109
 
    "gconflicts": [],
110
 
    "gdiff": [],
111
 
    "ginit": [],
112
 
    "gmerge": [],
113
 
    "gmissing": [],
114
 
    "gpreferences": [],
115
 
    "gpush": [],
116
 
    "gsend": [],
117
 
    "gstatus": ["gst"],
118
 
    "gtags": [],
119
 
    "visualise": ["visualize", "vis", "viz", 'glog'],
120
 
    }
121
 
 
122
 
try:
123
 
    from bzrlib.plugins import loom
124
 
except ImportError:
125
 
    pass # Loom plugin doesn't appear to be present
126
 
else:
127
 
    commands["gloom"] = []
128
 
 
129
 
for cmd, aliases in commands.iteritems():
130
 
    plugin_cmds.register_lazy("cmd_%s" % cmd, aliases,
131
 
                              "bzrlib.plugins.gtk.commands")
132
 
 
133
 
def save_commit_messages(*args):
134
 
    from bzrlib.plugins.gtk import commitmsgs
135
 
    commitmsgs.save_commit_messages(*args)
136
 
 
137
 
branch.Branch.hooks.install_named_hook('post_uncommit',
138
 
                                       save_commit_messages,
139
 
                                       "Saving commit messages for gcommit")
140
 
 
141
 
option_registry = getattr(config, "option_registry", None)
142
 
if option_registry is not None:
143
 
    config.option_registry.register_lazy('nautilus_integration',
144
 
            'bzrlib.plugins.gtk.config', 'opt_nautilus_integration')
145
 
 
146
 
def load_tests(basic_tests, module, loader):
147
 
    testmod_names = [
148
 
        'tests',
149
 
        ]
150
 
    import sys
151
 
    default_encoding = sys.getdefaultencoding()
152
 
    try:
153
 
        result = basic_tests
154
 
        try:
155
 
            import gi.repository.Gtk
156
 
        except ImportError:
157
 
            return basic_tests
158
 
        basic_tests.addTest(loader.loadTestsFromModuleNames(
159
 
                ["%s.%s" % (__name__, tmn) for tmn in testmod_names]))
160
 
    finally:
161
 
        if sys.getdefaultencoding() != default_encoding:
162
 
            reload(sys)
163
 
            sys.setdefaultencoding(default_encoding)
164
 
    return basic_tests
165