class FunctionLoader(BaseLoader):
A loader that is passed a function which does the loading. The
function receives the name of the template and has to return either
a string with the template source, a tuple in the form (source,
filename, uptodatefunc) or None
if the template does not exist.
>>> def load_template(name): ... if name == 'index.html': ... return '...' ... >>> loader = FunctionLoader(load_template)
The uptodatefunc
is a function that is called if autoreload is enabled
and has to return True
if the template is still up to date. For more
details have a look at BaseLoader.get_source
which has the same
return value.
Method | __init__ |
Undocumented |
Method | get_source |
No summary |
Instance Variable | load_func |
Undocumented |
Inherited from BaseLoader
:
Method | list_templates |
Iterates over all templates. If the loader does not support that it should raise a TypeError which is the default behavior. |
Method | load |
No summary |
Class Variable | has_source_access |
Undocumented |
Undocumented
Parameters | |
load_func:t.Callable[ | Undocumented |
jinja2.loaders.BaseLoader.get_source
Get the template source, filename and reload helper for a template.
It's passed the environment and template name and has to return a
tuple in the form (source, filename, uptodate) or raise a
TemplateNotFound
error if it can't locate the template.
The source part of the returned tuple must be the source of the template as a string. The filename should be the name of the file on the filesystem if it was loaded from there, otherwise None. The filename is used by Python for the tracebacks if no loader extension is used.
The last item in the tuple is the uptodate
function. If auto
reloading is enabled it's always called to check if the template
changed. No arguments are passed so the function must store the
old state somewhere (for example in a closure). If it returns False
the template will be reloaded.
Parameters | |
environment:Environment | Undocumented |
template:str | Undocumented |
Returns | |
t.Tuple[ | Undocumented |