d90857a08c
* lang/python/helpers.c (pygpgme_stash_callback_exception): New function. (pygpgme_raise_callback_exception): Likewise. (pyPassphraseCb): Stash python errors. * lang/python/helpers.h (pygpgme_raise_callback_exception): New prototype. * lang/python/pyme/core.py ({Context,Data}.__init__): Move common initialization to superclass. (Context.set_progress_cb): Hand in 'self'. * lang/python/pyme/util.py (GpgmeWrapper.__init__): New function. (GpgmeWrapper.__getattr__): Raise stashed exceptions. * lang/python/tests/Makefile.am (py_tests): Add new test. * lang/python/tests/t-callbacks.py: New file. Signed-off-by: Justus Winter <justus@gnupg.org>
108 lines
3.7 KiB
Python
108 lines
3.7 KiB
Python
# $Id$
|
|
# Copyright (C) 2004,2008 Igor Belyi <belyi@users.sourceforge.net>
|
|
# Copyright (C) 2002 John Goerzen <jgoerzen@complete.org>
|
|
#
|
|
# This library is free software; you can redistribute it and/or
|
|
# modify it under the terms of the GNU Lesser General Public
|
|
# License as published by the Free Software Foundation; either
|
|
# version 2.1 of the License, or (at your option) any later version.
|
|
#
|
|
# This library is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
# Lesser General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU Lesser General Public
|
|
# License along with this library; if not, write to the Free Software
|
|
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
|
|
from . import pygpgme
|
|
from .errors import errorcheck
|
|
|
|
def process_constants(starttext, dict):
|
|
"""Called by the constant libraries to load up the appropriate constants
|
|
from the C library."""
|
|
index = len(starttext)
|
|
for identifier in dir(pygpgme):
|
|
if not identifier.startswith(starttext):
|
|
continue
|
|
name = identifier[index:]
|
|
dict[name] = getattr(pygpgme, identifier)
|
|
|
|
class GpgmeWrapper(object):
|
|
"""Base class all Pyme wrappers for GPGME functionality. Not to be
|
|
instantiated directly."""
|
|
|
|
def __init__(self, wrapped):
|
|
self._callback_excinfo = None
|
|
self.wrapped = wrapped
|
|
|
|
def __repr__(self):
|
|
return '<instance of %s.%s with GPG object at %s>' % \
|
|
(__name__, self.__class__.__name__,
|
|
self.wrapped)
|
|
|
|
def __str__(self):
|
|
return repr(self)
|
|
|
|
def __hash__(self):
|
|
return hash(repr(self.wrapped))
|
|
|
|
def __eq__(self, other):
|
|
if other == None:
|
|
return False
|
|
else:
|
|
return repr(self.wrapped) == repr(other.wrapped)
|
|
|
|
def _getctype(self):
|
|
"""Must be implemented by child classes.
|
|
|
|
Must return the name of the c type."""
|
|
raise NotImplementedError()
|
|
|
|
def _getnameprepend(self):
|
|
"""Must be implemented by child classes.
|
|
|
|
Must return the prefix of all c functions mapped to methods of
|
|
this class."""
|
|
raise NotImplementedError()
|
|
|
|
def _errorcheck(self, name):
|
|
"""Must be implemented by child classes.
|
|
|
|
This function must return a trueish value for all c functions
|
|
returning gpgme_error_t."""
|
|
raise NotImplementedError()
|
|
|
|
def __getattr__(self, key):
|
|
"""On-the-fly function generation."""
|
|
if key[0] == '_' or self._getnameprepend() == None:
|
|
return None
|
|
name = self._getnameprepend() + key
|
|
func = getattr(pygpgme, name)
|
|
|
|
if self._errorcheck(name):
|
|
def _funcwrap(slf, *args, **kwargs):
|
|
result = func(slf.wrapped, *args, **kwargs)
|
|
if slf._callback_excinfo:
|
|
pygpgme.pygpgme_raise_callback_exception(slf)
|
|
return errorcheck(result, "Invocation of " + name)
|
|
else:
|
|
def _funcwrap(slf, *args, **kwargs):
|
|
result = func(slf.wrapped, *args, **kwargs)
|
|
if slf._callback_excinfo:
|
|
pygpgme.pygpgme_raise_callback_exception(slf)
|
|
return result
|
|
|
|
_funcwrap.__doc__ = getattr(func, "__doc__")
|
|
|
|
# Monkey-patch the class.
|
|
setattr(self.__class__, key, _funcwrap)
|
|
|
|
# Bind the method to 'self'.
|
|
def wrapper(*args, **kwargs):
|
|
return _funcwrap(self, *args, **kwargs)
|
|
_funcwrap.__doc__ = getattr(func, "__doc__")
|
|
|
|
return wrapper
|