1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 | # utils/context_processors.py
import sys
from django.conf import settings as django_settings
class SettingsProcessor(object):
def __getattr__(self, attr):
if attr == '__file__':
# autoreload support in dev server
return __file__
else:
return lambda request: {attr: getattr(django_settings, attr)}
sys.modules[__name__ + '.settings'] = SettingsProcessor()
# in settings.py
TEMPLATE_CONTEXT_PROCESSORS = (
# ....
'utils.context_processors.settings.GOOGLEMAPS_KEY',
'utils.context_processors.settings.TEMPLATE_DEBUG',
'utils.context_processors.settings.MAXMIND_URL',
)
|
More like this
- Django ChoiceField with "other" choice by sciyoshi 4 years, 10 months ago
- Using Akismet/TypePad AntiSpam with Django's new comments framework by sciyoshi 4 years, 8 months ago
- Custom Django manager that excludes subclasses by sciyoshi 4 years, 9 months ago
- Prevent Django newcomments spam with Akismet (reloaded) by sciyoshi 3 years, 10 months ago
- Rails-like MVC Controllers for Django by sciyoshi 4 years, 6 months ago
Comments
I'm sorry, but this seems crazy. I heard about this snippet because of a bug report that it breaks coverage.py (https://bitbucket.org/ned/coveragepy/issue/192)
Why not write a simple context processor that does what you want, like this:
#