Allow GENERAL plugins to have category, and more flexibility
svn: r15699
This commit is contained in:
parent
aca9b9cb5c
commit
f55cd42926
@ -175,6 +175,7 @@ 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)
|
||||||
|
if _module:
|
||||||
self.__success_list.append((filename, _module, pdata))
|
self.__success_list.append((filename, _module, pdata))
|
||||||
self.__modules[filename] = _module
|
self.__modules[filename] = _module
|
||||||
self.__loaded_plugins[pdata.id] = _module
|
self.__loaded_plugins[pdata.id] = _module
|
||||||
@ -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:
|
||||||
|
if pdata.mod_name:
|
||||||
sys.path.insert(0, pdata.fpath)
|
sys.path.insert(0, pdata.fpath)
|
||||||
module = __import__(pdata.mod_name)
|
module = __import__(pdata.mod_name)
|
||||||
sys.path.pop(0)
|
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
|
||||||
|
@ -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)
|
||||||
|
@ -832,6 +832,7 @@ 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)
|
||||||
|
if pdata.fpath and pdata.fname:
|
||||||
open_file_with_default_application(
|
open_file_with_default_application(
|
||||||
os.path.join(pdata.fpath, pdata.fname)
|
os.path.join(pdata.fpath, pdata.fname)
|
||||||
)
|
)
|
||||||
|
Loading…
Reference in New Issue
Block a user