Allow GENERAL plugins to have category, and more flexibility

svn: r15699
This commit is contained in:
Doug Blank 2010-08-10 13:14:09 +00:00
parent aca9b9cb5c
commit f55cd42926
3 changed files with 24 additions and 16 deletions

View File

@ -175,10 +175,11 @@ class BasePluginManager(object):
# results in success. Then reload reveals the actual error. # results in success. Then reload reveals the actual error.
# Looks like a bug in Python. # Looks like a bug in Python.
_module = self.reload(_module, pdata) _module = self.reload(_module, pdata)
self.__success_list.append((filename, _module, pdata)) if _module:
self.__modules[filename] = _module self.__success_list.append((filename, _module, pdata))
self.__loaded_plugins[pdata.id] = _module self.__modules[filename] = _module
self.__mod2text[_module.__name__] = pdata.description self.__loaded_plugins[pdata.id] = _module
self.__mod2text[_module.__name__] = pdata.description
return _module return _module
except: except:
import traceback import traceback
@ -192,14 +193,18 @@ class BasePluginManager(object):
Rather than just __import__(id), this will add the pdata.fpath Rather than just __import__(id), this will add the pdata.fpath
to sys.path first (if needed), import, and then reset path. to sys.path first (if needed), import, and then reset path.
""" """
module = None
if isinstance(pdata, basestring): if isinstance(pdata, basestring):
pdata = self.get_plugin(pdata) pdata = self.get_plugin(pdata)
if not pdata: if not pdata:
return None return None
if pdata.fpath not in sys.path: if pdata.fpath not in sys.path:
sys.path.insert(0, pdata.fpath) if pdata.mod_name:
module = __import__(pdata.mod_name) sys.path.insert(0, pdata.fpath)
sys.path.pop(0) module = __import__(pdata.mod_name)
sys.path.pop(0)
else:
print "WARNING: module cannot be loaded"
else: else:
module = __import__(pdata.mod_name) module = __import__(pdata.mod_name)
return module return module

View File

@ -360,8 +360,9 @@ class PluginData(object):
self._reportclass = None self._reportclass = None
self._require_active = True self._require_active = True
self._report_modes = [REPORT_MODE_GUI] self._report_modes = [REPORT_MODE_GUI]
#REPORT and TOOL attr #REPORT and TOOL and GENERAL attr
self._category = None self._category = None
#REPORT and TOOL attr
self._optionclass = None self._optionclass = None
#TOOL attr #TOOL attr
self._toolclass = None self._toolclass = None
@ -597,12 +598,11 @@ class PluginData(object):
def _get_report_modes(self): def _get_report_modes(self):
return self._report_modes return self._report_modes
#REPORT OR TOOL OR QUICKREPORT attributes #REPORT or TOOL or QUICKREPORT or GENERAL attributes
def _set_category(self, category): def _set_category(self, category):
if not (self._ptype == REPORT or self._ptype == TOOL or if self._ptype not in [REPORT, TOOL, QUICKREPORT, VIEW, GENERAL]:
self._ptype == QUICKREPORT or self._ptype == VIEW):
raise ValueError, 'category may only be set for ' \ raise ValueError, 'category may only be set for ' \
'REPORT/TOOL/QUICKREPORT/VIEW plugins' 'REPORT/TOOL/QUICKREPORT/VIEW/GENERAL plugins'
self._category = category self._category = category
def _get_category(self): def _get_category(self):
@ -959,7 +959,7 @@ def make_environment(**kwargs):
'GRAMPSVERSION': GRAMPSVERSION, 'GRAMPSVERSION': GRAMPSVERSION,
'START': START, 'START': START,
'END': END, 'END': END,
'IMAGE_DIR': IMAGE_DIR 'IMAGE_DIR': IMAGE_DIR,
} }
env.update(kwargs) env.update(kwargs)
return env return env
@ -1062,6 +1062,8 @@ class PluginRegister(object):
and not __debug__: and not __debug__:
rmlist.append(ind) rmlist.append(ind)
continue continue
if plugin.fname is None:
continue
match = pymod.match(plugin.fname) match = pymod.match(plugin.fname)
if not match: if not match:
rmlist.append(ind) rmlist.append(ind)

View File

@ -832,9 +832,10 @@ Location: %(fpath)s
return return
id = model.get_value(node, id_col) id = model.get_value(node, id_col)
pdata = self.__preg.get_plugin(id) pdata = self.__preg.get_plugin(id)
open_file_with_default_application( if pdata.fpath and pdata.fname:
os.path.join(pdata.fpath, pdata.fname) open_file_with_default_application(
) os.path.join(pdata.fpath, pdata.fname)
)
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
# #