Mercurial > hgsubversion
changeset 673:32089d080ff8
editor: move ieditor decorator into svnwrap.
The Subvertpy wrapper will not need this decorator, and moving the
decorator into svnwrap will allow the wrapper to provide a no-op
replacement.
No functionality change.
author | Dan Villiom Podlaski Christiansen <danchr@gmail.com> |
---|---|
date | Wed, 11 Aug 2010 19:57:35 +0200 (2010-08-11) |
parents | 2cc1342d4476 |
children | a51e50d943b2 |
files | hgsubversion/editor.py hgsubversion/svnwrap/svn_swig_wrapper.py |
diffstat | 2 files changed, 28 insertions(+), 29 deletions(-) [+] |
line wrap: on
line diff
--- a/hgsubversion/editor.py +++ b/hgsubversion/editor.py @@ -9,26 +9,6 @@ from mercurial import node import svnwrap import util -def ieditor(fn): - """Helps identify methods used by the SVN editor interface. - - Stash any exception raised in the method on self. - - This is required because the SWIG bindings just mutate any exception into - a generic Subversion exception with no way of telling what the original was. - This allows the editor object to notice when you try and commit and really - got an exception in the replay process. - """ - def fun(self, *args, **kwargs): - try: - return fn(self, *args, **kwargs) - except: #pragma: no cover - if self.current.exception is not None: - self.current.exception = sys.exc_info() - raise - return fun - - class RevisionData(object): __slots__ = [ @@ -120,7 +100,7 @@ class HgEditor(svnwrap.Editor): self.repo = meta.repo self.current = RevisionData(meta.ui) - @ieditor + @svnwrap.ieditor def delete_entry(self, path, revision_bogus, parent_baton, pool=None): br_path, branch = self.meta.split_branch_path(path)[:2] if br_path == '': @@ -147,7 +127,7 @@ class HgEditor(svnwrap.Editor): self.current.delete(f_p) self.current.delete(path) - @ieditor + @svnwrap.ieditor def open_file(self, path, parent_baton, base_revision, p=None): self.current.file = None fpath, branch = self.meta.split_branch_path(path)[:2] @@ -186,7 +166,7 @@ class HgEditor(svnwrap.Editor): base = 'link ' + base self.current.set(path, base, 'x' in fctx.flags(), 'l' in fctx.flags()) - @ieditor + @svnwrap.ieditor def add_file(self, path, parent_baton=None, copyfrom_path=None, copyfrom_revision=None, file_pool=None): self.current.file = None @@ -229,7 +209,7 @@ class HgEditor(svnwrap.Editor): if util.issamefile(parentctx, ctx, from_file): self.current.copies[path] = from_file - @ieditor + @svnwrap.ieditor def add_directory(self, path, parent_baton, copyfrom_path, copyfrom_revision, dir_pool=None): self.current.batons[path] = path @@ -293,14 +273,14 @@ class HgEditor(svnwrap.Editor): self.current.copies[k] = v return path - @ieditor + @svnwrap.ieditor def change_file_prop(self, file_baton, name, value, pool=None): if name == 'svn:executable': self.current.execfiles[self.current.file] = bool(value is not None) elif name == 'svn:special': self.current.symlinks[self.current.file] = bool(value is not None) - @ieditor + @svnwrap.ieditor def change_dir_prop(self, dir_baton, name, value, pool=None): if dir_baton is None: return @@ -308,7 +288,7 @@ class HgEditor(svnwrap.Editor): if name == 'svn:externals': self.current.externals[path] = value - @ieditor + @svnwrap.ieditor def open_directory(self, path, parent_baton, base_revision, dir_pool=None): self.current.batons[path] = path p_, branch = self.meta.split_branch_path(path)[:2] @@ -317,12 +297,12 @@ class HgEditor(svnwrap.Editor): self.current.emptybranches[branch] = False return path - @ieditor + @svnwrap.ieditor def close_directory(self, dir_baton, dir_pool=None): if dir_baton is not None: del self.current.batons[dir_baton] - @ieditor + @svnwrap.ieditor def apply_textdelta(self, file_baton, base_checksum, pool=None): # We know coming in here the file must be one of the following options: # 1) Deleted (invalid, fail an assertion)
--- a/hgsubversion/svnwrap/svn_swig_wrapper.py +++ b/hgsubversion/svnwrap/svn_swig_wrapper.py @@ -70,6 +70,25 @@ class RaCallbacks(ra.Callbacks): def get_client_string(pool): return 'hgsubversion' +def ieditor(fn): + """Helps identify methods used by the SVN editor interface. + + Stash any exception raised in the method on self. + + This is required because the SWIG bindings just mutate any exception into + a generic Subversion exception with no way of telling what the original was. + This allows the editor object to notice when you try and commit and really + got an exception in the replay process. + """ + def fun(self, *args, **kwargs): + try: + return fn(self, *args, **kwargs) + except: #pragma: no cover + if self.current.exception is not None: + self.current.exception = sys.exc_info() + raise + return fun + def user_pass_prompt(realm, default_username, ms, pool): #pragma: no cover # FIXME: should use getpass() and username() from mercurial.ui creds = core.svn_auth_cred_simple_t()