# -*- coding: utf-8 -*- """ jinja2.exceptions ~~~~~~~~~~~~~~~~~ Jinja exceptions. :copyright: (c) 2017 by the Jinja Team. :license: BSD, see LICENSE for more details. """ from jinja2._compat import imap, text_type, PY2, implements_to_string class TemplateError(Exception): """Baseclass for all template errors.""" if PY2: def __init__(self, message=None): if message is not None: message = text_type(message).encode('utf-8') Exception.__init__(self, message) @property def message(self): if self.args: message = self.args[0] if message is not None: return message.decode('utf-8', 'replace') def __unicode__(self): return self.message or u'' else: def __init__(self, message=None): Exception.__init__(self, message) @property def message(self): if self.args: message = self.args[0] if message is not None: return message @implements_to_string class TemplateNotFound(IOError, LookupError, TemplateError): """Raised if a template does not exist.""" # looks weird, but removes the warning descriptor that just # bogusly warns us about message being deprecated message = None def __init__(self, name, message=None): IOError.__init__(self) if message is None: message = name self.message = message self.name = name self.templates = [name] def __str__(self): return self.message class TemplatesNotFound(TemplateNotFound): """Like :class:`TemplateNotFound` but raised if multiple templates are selected. This is a subclass of :class:`TemplateNotFound` exception, so just catching the base exception will catch both. .. versionadded:: 2.2 """ def __init__(self, names=(), message=None): if message is None: message = u'none of the templates given were found: ' + \ u', '.join(imap(text_type, names)) TemplateNotFound.__init__(self, names and names[-1] or None, message) self.templates = list(names) @implements_to_string class TemplateSyntaxError(TemplateError): """Raised to tell the user that there is a problem with the template.""" def __init__(self, message, lineno, name=None, filename=None): TemplateError.__init__(self, message) self.lineno = lineno self.name = name self.filename = filename self.source = None # this is set to True if the debug.translate_syntax_error # function translated the syntax error into a new traceback self.translated = False def __str__(self): # for translated errors we only return the message if self.translated: return self.message # otherwise attach some stuff location = 'line %d' % self.lineno name = self.filename or self.name if name: location = 'File "%s", %s' % (name, location) lines = [self.message, ' ' + location] # if the source is set, add the line to the output if self.source is not None: try: line = self.source.splitlines()[self.lineno - 1] except IndexError: line = None if line: lines.append(' ' + line.strip()) return u'\n'.join(lines) class TemplateAssertionError(TemplateSyntaxError): """Like a template syntax error, but covers cases where something in the template caused an error at compile time that wasn't necessarily caused by a syntax error. However it's a direct subclass of :exc:`TemplateSyntaxError` and has the same attributes. """ class TemplateRuntimeError(TemplateError): """A generic runtime error in the template engine. Under some situations Jinja may raise this exception. """ class UndefinedError(TemplateRuntimeError): """Raised if a template tries to operate on :class:`Undefined`.""" class SecurityError(TemplateRuntimeError): """Raised if a template tries to do something insecure if the sandbox is enabled. """ class FilterArgumentError(TemplateRuntimeError): """This error is raised if a filter was called with inappropriate arguments """
Name | Type | Size | Permission | Actions |
---|---|---|---|---|
__pycache__ | Folder | 0755 |
|
|
__init__.py | File | 2.55 KB | 0644 |
|
_compat.py | File | 2.54 KB | 0644 |
|
_identifier.py | File | 1.69 KB | 0644 |
|
asyncfilters.py | File | 4.05 KB | 0644 |
|
asyncsupport.py | File | 7.69 KB | 0644 |
|
bccache.py | File | 12.49 KB | 0644 |
|
compiler.py | File | 63.85 KB | 0644 |
|
constants.py | File | 1.59 KB | 0644 |
|
debug.py | File | 11.76 KB | 0644 |
|
defaults.py | File | 1.37 KB | 0644 |
|
environment.py | File | 49.66 KB | 0644 |
|
exceptions.py | File | 4.32 KB | 0644 |
|
ext.py | File | 23.93 KB | 0644 |
|
filters.py | File | 36.36 KB | 0644 |
|
idtracking.py | File | 8.98 KB | 0644 |
|
lexer.py | File | 27.89 KB | 0644 |
|
loaders.py | File | 16.97 KB | 0644 |
|
meta.py | File | 4.24 KB | 0644 |
|
nativetypes.py | File | 7.14 KB | 0644 |
|
nodes.py | File | 30.13 KB | 0644 |
|
optimizer.py | File | 1.68 KB | 0644 |
|
parser.py | File | 35.03 KB | 0644 |
|
runtime.py | File | 27.1 KB | 0644 |
|
sandbox.py | File | 16.71 KB | 0644 |
|
tests.py | File | 4.14 KB | 0644 |
|
utils.py | File | 20.29 KB | 0644 |
|
visitor.py | File | 3.24 KB | 0644 |
|