2005-10-15 06:22:12 +08:00
|
|
|
# Wrapper for loading templates from eggs via pkg_resources.resource_string.
|
2012-08-14 18:09:45 +08:00
|
|
|
from __future__ import unicode_literals
|
2005-10-15 06:22:12 +08:00
|
|
|
|
2015-03-04 05:48:26 +08:00
|
|
|
import warnings
|
|
|
|
|
2013-12-24 19:25:17 +08:00
|
|
|
from django.apps import apps
|
2015-04-25 03:35:30 +08:00
|
|
|
from django.template import Origin, TemplateDoesNotExist
|
2012-08-14 18:09:45 +08:00
|
|
|
from django.utils import six
|
2015-06-23 01:54:35 +08:00
|
|
|
from django.utils.deprecation import RemovedInDjango20Warning
|
2005-10-15 06:22:12 +08:00
|
|
|
|
2014-11-16 01:35:02 +08:00
|
|
|
from .base import Loader as BaseLoader
|
|
|
|
|
2015-01-28 20:35:27 +08:00
|
|
|
try:
|
|
|
|
from pkg_resources import resource_string
|
|
|
|
except ImportError:
|
|
|
|
resource_string = None
|
|
|
|
|
2015-07-16 21:32:42 +08:00
|
|
|
warnings.warn('The egg template loader is deprecated.', RemovedInDjango20Warning)
|
|
|
|
|
2013-11-03 08:37:15 +08:00
|
|
|
|
2015-03-04 05:48:26 +08:00
|
|
|
class EggOrigin(Origin):
|
|
|
|
|
|
|
|
def __init__(self, app_name, pkg_name, *args, **kwargs):
|
|
|
|
self.app_name = app_name
|
|
|
|
self.pkg_name = pkg_name
|
2015-06-30 04:41:56 +08:00
|
|
|
super(EggOrigin, self).__init__(*args, **kwargs)
|
2015-03-04 05:48:26 +08:00
|
|
|
|
|
|
|
|
2009-12-14 20:08:23 +08:00
|
|
|
class Loader(BaseLoader):
|
2015-02-04 05:35:55 +08:00
|
|
|
|
|
|
|
def __init__(self, engine):
|
|
|
|
if resource_string is None:
|
|
|
|
raise RuntimeError("Setuptools must be installed to use the egg loader")
|
|
|
|
super(Loader, self).__init__(engine)
|
2009-12-14 20:08:23 +08:00
|
|
|
|
2015-03-04 05:48:26 +08:00
|
|
|
def get_contents(self, origin):
|
|
|
|
try:
|
|
|
|
source = resource_string(origin.app_name, origin.pkg_name)
|
|
|
|
except:
|
|
|
|
raise TemplateDoesNotExist(origin)
|
|
|
|
|
|
|
|
if six.PY2:
|
|
|
|
source = source.decode(self.engine.file_charset)
|
|
|
|
|
|
|
|
return source
|
|
|
|
|
|
|
|
def get_template_sources(self, template_name):
|
|
|
|
pkg_name = 'templates/' + template_name
|
|
|
|
for app_config in apps.get_app_configs():
|
|
|
|
yield EggOrigin(
|
|
|
|
app_name=app_config.name,
|
|
|
|
pkg_name=pkg_name,
|
|
|
|
name="egg:%s:%s" % (app_config.name, pkg_name),
|
|
|
|
template_name=template_name,
|
|
|
|
loader=self,
|
|
|
|
)
|
|
|
|
|
2009-12-14 20:08:23 +08:00
|
|
|
def load_template_source(self, template_name, template_dirs=None):
|
|
|
|
"""
|
|
|
|
Loads templates from Python eggs via pkg_resource.resource_string.
|
|
|
|
|
|
|
|
For every installed app, it tries to get the resource (app, template_name).
|
|
|
|
"""
|
2015-03-04 05:48:26 +08:00
|
|
|
warnings.warn(
|
|
|
|
'The load_template_sources() method is deprecated. Use '
|
|
|
|
'get_template() or get_contents() instead.',
|
2015-06-23 01:54:35 +08:00
|
|
|
RemovedInDjango20Warning,
|
2015-03-04 05:48:26 +08:00
|
|
|
)
|
|
|
|
for origin in self.get_template_sources(template_name):
|
2015-02-04 05:35:55 +08:00
|
|
|
try:
|
2015-03-04 05:48:26 +08:00
|
|
|
return self.get_contents(origin), origin.name
|
|
|
|
except TemplateDoesNotExist:
|
|
|
|
pass
|
2010-01-11 02:36:20 +08:00
|
|
|
raise TemplateDoesNotExist(template_name)
|