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