1
# Copyright (C) 2007 Jelmer Vernooij <jelmer@samba.org>
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
from bzrlib import errors
18
from bzrlib.plugins.gtk.dialog import (
22
from bzrlib.plugins.gtk.i18n import _i18n
25
def show_bzr_error(unbound):
26
"""Decorator that shows bazaar exceptions. """
27
def convert(*args, **kwargs):
29
unbound(*args, **kwargs)
30
except errors.NotBranchError:
31
error_dialog(_i18n('Directory is not a branch'),
32
_i18n('You can perform this action only in a branch.'))
33
except errors.LocalRequiresBoundBranch:
34
error_dialog(_i18n('Directory is not a checkout'),
35
_i18n('You can perform local commit only on checkouts.'))
36
except errors.PointlessCommit:
37
error_dialog(_i18n('No changes to commit'),
38
_i18n('Try force commit if you want to commit anyway.'))
39
except errors.PointlessMerge:
40
info_dialog(_i18n('No changes to merge'),
41
_i18n('Merge location is already fully merged in working tree.'))
42
except errors.ConflictsInTree:
43
error_dialog(_i18n('Conflicts in tree'),
44
_i18n('You need to resolve the conflicts before committing.'))
45
except errors.StrictCommitFailed:
46
error_dialog(_i18n('Strict commit failed'),
47
_i18n('There are unknown files in the working tree.\nPlease add or delete them.'))
48
except errors.BoundBranchOutOfDate, errmsg:
49
error_dialog(_i18n('Bound branch is out of date'),
50
# FIXME: Really ? Internationalizing %s ?? --vila080505
52
except errors.NotVersionedError:
53
error_dialog(_i18n('File not versioned'),
54
_i18n('The selected file is not versioned.'))
55
except errors.DivergedBranches:
56
error_dialog(_i18n('Branches have been diverged'),
57
_i18n('You cannot push if branches have diverged. Use the\noverwrite option if you want to push anyway.'))
58
except errors.NoSuchFile:
59
error_dialog(_i18n("No diff output"),
60
_i18n("The selected file hasn't changed."))
61
except errors.NoSuchRevision:
62
error_dialog(_i18n('No such revision'),
63
_i18n("The revision you specified doesn't exist."))
64
except errors.FileExists:
65
error_dialog(_i18n('Target already exists'),
66
_i18n("Target directory already exists. Please select another target."))
67
except errors.AlreadyBranchError, errmsg:
68
error_dialog(_i18n('Directory is already a branch'),
69
_i18n('The current directory (%s) is already a branch.\nYou can start using it, or initialize another directory.') % errmsg)
70
except errors.BranchExistsWithoutWorkingTree, errmsg:
71
error_dialog(_i18n('Branch without a working tree'),
72
_i18n('The current directory (%s)\nis a branch without a working tree.') % errmsg)
73
except errors.BzrError, msg:
74
error_dialog(_i18n('Unknown bzr error'), str(msg))
75
except errors.PermissionDenied:
76
error_dialog(_i18n("Permission denied"), _i18n("permission denied."))
77
except Exception, msg:
78
error_dialog(_i18n('Unknown error'), str(msg))
80
convert.__doc__ = unbound.__doc__
81
convert.__name__ = unbound.__name__