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