]> git.openstreetmap.org Git - osqa.git/commitdiff
take another approach to the settings import from modules
authorjordan <jordan@0cfe37f9-358a-4d5e-be75-b63607b5c754>
Thu, 28 Jul 2011 16:20:02 +0000 (16:20 +0000)
committerjordan <jordan@0cfe37f9-358a-4d5e-be75-b63607b5c754>
Thu, 28 Jul 2011 16:20:02 +0000 (16:20 +0000)
git-svn-id: http://svn.osqa.net/svnroot/osqa/trunk@1130 0cfe37f9-358a-4d5e-be75-b63607b5c754

forum/settings/__init__.py

index 87b80a183595dfe06596b701e3fb569fa5fb1d2e..218f1140f609f8f14df6856b4029af8066fa8eee 100644 (file)
@@ -1,11 +1,13 @@
 import os.path
-from base import Setting, SettingSet
+from base import Setting, SettingSet, BaseSetting
 
 from django.forms.widgets import Textarea
 from django.utils.translation import ugettext_lazy as _
 from django.conf import settings as djsettings
 from django.utils.version import get_svn_revision
 
+from forum.modules import get_modules_script_implementations
+
 OSQA_VERSION = "Development Build"
 
 SVN_REVISION = get_svn_revision(djsettings.SITE_SRC_ROOT)
@@ -48,14 +50,15 @@ from urls import *
 from accept import *
 from sitemaps import *
 
+__all__ = locals().keys()
+
 # Be able to import all module settings as well
-for m in djsettings.MODULE_LIST:
-    try:
-        exec 'from %s.settings import *' % m.__name__
-    except:
-        pass
+for k,v in get_modules_script_implementations('settings', BaseSetting).items():
+   if not k in __all__:
+        __all__.append(k)
+        exec "%s = v" % k
+
 
 BADGES_SET = SettingSet('badges', _('Badges config'), _("Configure badges on your OSQA site."), 500)
 
-#__all__ = locals().keys()