From 35efb56d790b122c6d0f7f588641fc2f15f5122b Mon Sep 17 00:00:00 2001 From: Santhosh Thottingal Date: Thu, 16 Apr 2009 20:48:51 +0530 Subject: Module info introspection --- silpa/common/modulemanager.py | 20 +++++++++++++++++--- 1 file changed, 17 insertions(+), 3 deletions(-) (limited to 'silpa') diff --git a/silpa/common/modulemanager.py b/silpa/common/modulemanager.py index 028c4ae..8f9c79d 100644 --- a/silpa/common/modulemanager.py +++ b/silpa/common/modulemanager.py @@ -9,16 +9,21 @@ class ModuleManager: obj= sys.modules[name] except KeyError: obj = __import__(".".join(parts[:-1])) - print "Loading " , obj if(len(parts)>1): for part in parts[1:]: - obj = getattr(obj,part) + try: + obj = getattr(obj,part) + except: + obj = None return obj def getModuleInstance(self,action): module_name = self.find_module(action) if(module_name): - return self.import_module(module_name).getInstance() + try: + return self.import_module(module_name).getInstance() + except: + print dir(self.import_module(module_name)) else: return None def find_module(self,action): @@ -26,6 +31,15 @@ class ModuleManager: return getModulesList()[action] except: return None + def getModulesInfoAsHTML(self): + module_dict=getModulesList () + response = "

Available Modules

" + response = response+"" + for action in module_dict: + module_instance=self.getModuleInstance(action) + response = response+"" + response = response+"" + return response+"
ModuleDescriptionStatus
"+module_instance.get_module_name()+""+module_instance.get_info()+"OK
" if __name__ == '__main__': mm=ModuleManager() print mm.getModuleInstance("lemmatize") -- cgit