From cafcffbb7412d8a80200d288d6819bd4a6779399 Mon Sep 17 00:00:00 2001 From: Santhosh Thottingal Date: Thu, 26 Mar 2009 22:42:30 +0530 Subject: Adding plugin manager --- silpa/common/modulemanager.py | 33 +++++++++++++++++++++++++++++++++ 1 file changed, 33 insertions(+) create mode 100644 silpa/common/modulemanager.py (limited to 'silpa/common/modulemanager.py') diff --git a/silpa/common/modulemanager.py b/silpa/common/modulemanager.py new file mode 100644 index 0000000..028c4ae --- /dev/null +++ b/silpa/common/modulemanager.py @@ -0,0 +1,33 @@ +#! /usr/bin/env python +# -*- coding: utf-8 -*- +import sys +from utils import * +class ModuleManager: + def import_module(self,name): + parts = name.split(".") + try: + 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) + return obj + + def getModuleInstance(self,action): + module_name = self.find_module(action) + if(module_name): + return self.import_module(module_name).getInstance() + else: + return None + def find_module(self,action): + try: + return getModulesList()[action] + except: + return None +if __name__ == '__main__': + mm=ModuleManager() + print mm.getModuleInstance("lemmatize") + print mm.import_module("modules.lemmatizer").getInstance() + -- cgit 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/common/modulemanager.py') 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 From 550f1ef9f4cd12f6a75090fa14490effc1230631 Mon Sep 17 00:00:00 2001 From: Santhosh Thottingal Date: Wed, 22 Apr 2009 23:42:35 +0530 Subject: Bug Fixes --- silpa/common/modulemanager.py | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) (limited to 'silpa/common/modulemanager.py') diff --git a/silpa/common/modulemanager.py b/silpa/common/modulemanager.py index 8f9c79d..a3e9f1b 100644 --- a/silpa/common/modulemanager.py +++ b/silpa/common/modulemanager.py @@ -18,6 +18,7 @@ class ModuleManager: return obj def getModuleInstance(self,action): + action=action.replace(" ","_") module_name = self.find_module(action) if(module_name): try: @@ -37,8 +38,12 @@ class ModuleManager: response = response+"" for action in module_dict: module_instance=self.getModuleInstance(action) - response = response+"" - response = response+"" + if(module_instance!=None): + response = response+"" + response = response+"" + else: + response = response+"" + response = response+"" return response+"
ModuleDescriptionStatus
"+module_instance.get_module_name()+""+module_instance.get_info()+"OK
"+module_instance.get_module_name()+""+module_instance.get_info()+"OK
"+action.replace("_"," ")+"Error while retrieving module detailsFail
" if __name__ == '__main__': mm=ModuleManager() -- cgit From f1182c8bc123e9b6690f3fbdc0021468e60ba05d Mon Sep 17 00:00:00 2001 From: Santhosh Thottingal Date: Tue, 12 May 2009 20:40:32 +0530 Subject: Various fixes on silpa and new modules-Inexact search --- silpa/common/modulemanager.py | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) (limited to 'silpa/common/modulemanager.py') diff --git a/silpa/common/modulemanager.py b/silpa/common/modulemanager.py index a3e9f1b..c6185dd 100644 --- a/silpa/common/modulemanager.py +++ b/silpa/common/modulemanager.py @@ -35,15 +35,15 @@ class ModuleManager: def getModulesInfoAsHTML(self): module_dict=getModulesList () response = "

Available Modules

" - response = response+"" + response = response+"
ModuleDescriptionStatus
" for action in module_dict: module_instance=self.getModuleInstance(action) if(module_instance!=None): - response = response+"" - response = response+"" + response = response+"" + response = response+"" else: response = response+"" - response = response+"" + response = response+"" return response+"
ModuleDescription
"+module_instance.get_module_name()+""+module_instance.get_info()+"OK
"+module_instance.get_module_name()+""+module_instance.get_info()+"
"+action.replace("_"," ")+"Error while retrieving module detailsFail
Error while retrieving module details
" if __name__ == '__main__': mm=ModuleManager() -- cgit