2018-09-05 02:59:34 +02:00
|
|
|
# This file is part of Gajim.
|
|
|
|
#
|
|
|
|
# Gajim is free software; you can redistribute it and/or modify
|
|
|
|
# it under the terms of the GNU General Public License as published
|
|
|
|
# by the Free Software Foundation; version 3 only.
|
|
|
|
#
|
|
|
|
# Gajim 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 General Public License for more details.
|
|
|
|
#
|
|
|
|
# You should have received a copy of the GNU General Public License
|
|
|
|
# along with Gajim. If not, see <http://www.gnu.org/licenses/>.
|
2008-06-02 01:33:51 +02:00
|
|
|
|
|
|
|
'''
|
|
|
|
Helper code related to plug-ins management system.
|
|
|
|
|
|
|
|
:author: Mateusz Biliński <mateusz@bilinski.it>
|
2008-07-18 09:05:07 +02:00
|
|
|
:since: 30th May 2008
|
2008-06-02 01:33:51 +02:00
|
|
|
:copyright: Copyright (2008) Mateusz Biliński <mateusz@bilinski.it>
|
|
|
|
:license: GPL
|
|
|
|
'''
|
|
|
|
|
|
|
|
__all__ = ['log', 'log_calls', 'Singleton']
|
|
|
|
|
|
|
|
import logging
|
2011-01-03 22:30:42 +01:00
|
|
|
import functools
|
|
|
|
|
2008-06-02 01:33:51 +02:00
|
|
|
log = logging.getLogger('gajim.plugin_system')
|
|
|
|
'''
|
|
|
|
Logger for code related to plug-in system.
|
|
|
|
|
|
|
|
:type: logging.Logger
|
|
|
|
'''
|
|
|
|
|
2010-11-01 21:22:43 +01:00
|
|
|
class GajimPluginActivateException(Exception):
|
|
|
|
'''
|
|
|
|
Raised when activation failed
|
|
|
|
'''
|
|
|
|
pass
|
|
|
|
|
2018-09-16 11:56:56 +02:00
|
|
|
class log_calls:
|
2008-06-02 01:33:51 +02:00
|
|
|
'''
|
|
|
|
Decorator class for functions to easily log when they are entered and left.
|
|
|
|
'''
|
2010-04-08 01:20:17 +02:00
|
|
|
|
2009-06-07 00:00:03 +02:00
|
|
|
filter_out_classes = ['GajimPluginConfig', 'PluginManager',
|
2008-08-03 15:29:11 +02:00
|
|
|
'GajimPluginConfigDialog', 'PluginsWindow']
|
2008-07-29 21:09:28 +02:00
|
|
|
'''
|
|
|
|
List of classes from which no logs should be emited when methods are called,
|
2018-06-21 01:46:16 +02:00
|
|
|
even though `log_calls` decorator is used.
|
2008-07-29 21:09:28 +02:00
|
|
|
'''
|
2010-04-08 01:20:17 +02:00
|
|
|
|
2018-09-16 17:11:52 +02:00
|
|
|
def __init__(self, classname=''):
|
2008-06-02 01:33:51 +02:00
|
|
|
'''
|
|
|
|
:Keywords:
|
|
|
|
classname : str
|
|
|
|
Name of class to prefix function name (if function is a method).
|
|
|
|
log : logging.Logger
|
2018-06-21 01:46:16 +02:00
|
|
|
Logger to use when outputting debug information on when function has
|
2008-06-02 01:33:51 +02:00
|
|
|
been entered and when left. By default: `plugins.helpers.log`
|
2010-04-08 01:20:17 +02:00
|
|
|
is used.
|
2008-06-02 01:33:51 +02:00
|
|
|
'''
|
2010-04-08 01:20:17 +02:00
|
|
|
|
2008-06-02 01:33:51 +02:00
|
|
|
self.full_func_name = ''
|
|
|
|
'''
|
2010-04-08 01:20:17 +02:00
|
|
|
Full name of function, with class name (as prefix) if given
|
2008-06-02 01:33:51 +02:00
|
|
|
to decorator.
|
2010-04-08 01:20:17 +02:00
|
|
|
|
2008-06-02 01:33:51 +02:00
|
|
|
Otherwise, it's only function name retrieved from function object
|
|
|
|
for which decorator was called.
|
2010-04-08 01:20:17 +02:00
|
|
|
|
2008-06-02 01:33:51 +02:00
|
|
|
:type: str
|
|
|
|
'''
|
2008-07-29 21:09:28 +02:00
|
|
|
self.log_this_class = True
|
|
|
|
'''
|
|
|
|
Determines whether wrapper of given function should log calls of this
|
|
|
|
function or not.
|
2010-04-08 01:20:17 +02:00
|
|
|
|
2008-07-29 21:09:28 +02:00
|
|
|
:type: bool
|
|
|
|
'''
|
2010-04-08 01:20:17 +02:00
|
|
|
|
2008-06-02 01:33:51 +02:00
|
|
|
if classname:
|
|
|
|
self.full_func_name = classname+'.'
|
2010-04-08 01:20:17 +02:00
|
|
|
|
2008-07-29 21:09:28 +02:00
|
|
|
if classname in self.filter_out_classes:
|
|
|
|
self.log_this_class = False
|
2010-04-08 01:20:17 +02:00
|
|
|
|
2008-06-02 01:33:51 +02:00
|
|
|
def __call__(self, f):
|
|
|
|
'''
|
|
|
|
:param f: function to be wrapped with logging statements
|
2010-04-08 01:20:17 +02:00
|
|
|
|
2008-06-02 01:33:51 +02:00
|
|
|
:return: given function wrapped by *log.debug* statements
|
|
|
|
:rtype: function
|
|
|
|
'''
|
2010-04-08 01:20:17 +02:00
|
|
|
|
2013-01-02 13:54:02 +01:00
|
|
|
self.full_func_name += f.__name__
|
2008-07-29 21:09:28 +02:00
|
|
|
if self.log_this_class:
|
|
|
|
@functools.wraps(f)
|
|
|
|
def wrapper(*args, **kwargs):
|
2010-04-08 01:20:17 +02:00
|
|
|
|
2018-09-17 18:57:00 +02:00
|
|
|
log.debug('%s() <entered>', self.full_func_name)
|
2008-07-29 21:09:28 +02:00
|
|
|
result = f(*args, **kwargs)
|
2018-09-17 18:57:00 +02:00
|
|
|
log.debug('%s() <left>', self.full_func_name)
|
2008-07-29 21:09:28 +02:00
|
|
|
return result
|
|
|
|
else:
|
|
|
|
@functools.wraps(f)
|
|
|
|
def wrapper(*args, **kwargs):
|
|
|
|
result = f(*args, **kwargs)
|
|
|
|
return result
|
2010-04-08 01:20:17 +02:00
|
|
|
|
2008-06-02 01:33:51 +02:00
|
|
|
return wrapper
|
|
|
|
|
|
|
|
class Singleton(type):
|
|
|
|
'''
|
|
|
|
Singleton metaclass.
|
|
|
|
'''
|
2010-04-08 01:20:17 +02:00
|
|
|
def __init__(cls, name, bases, dic):
|
|
|
|
super(Singleton, cls).__init__(name, bases, dic)
|
2008-06-02 01:33:51 +02:00
|
|
|
cls.instance=None
|
2010-04-08 01:20:17 +02:00
|
|
|
|
2008-06-02 01:33:51 +02:00
|
|
|
def __call__(cls,*args,**kw):
|
|
|
|
if cls.instance is None:
|
2010-04-08 01:20:17 +02:00
|
|
|
cls.instance=super(Singleton, cls).__call__(*args,**kw)
|
2008-08-03 15:29:11 +02:00
|
|
|
#log.debug('%(classname)s - new instance created'%{
|
|
|
|
#'classname' : cls.__name__})
|
2008-06-02 01:33:51 +02:00
|
|
|
else:
|
2008-08-03 15:29:11 +02:00
|
|
|
pass
|
|
|
|
#log.debug('%(classname)s - returning already existing instance'%{
|
|
|
|
#'classname' : cls.__name__})
|
2010-04-08 01:20:17 +02:00
|
|
|
|
|
|
|
return cls.instance
|