本文整理匯總了Python中jinja2.exceptions.TemplateSyntaxError方法的典型用法代碼示例。如果您正苦於以下問題:Python exceptions.TemplateSyntaxError方法的具體用法?Python exceptions.TemplateSyntaxError怎麽用?Python exceptions.TemplateSyntaxError使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類jinja2.exceptions
的用法示例。
在下文中一共展示了exceptions.TemplateSyntaxError方法的6個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: expect
# 需要導入模塊: from jinja2 import exceptions [as 別名]
# 或者: from jinja2.exceptions import TemplateSyntaxError [as 別名]
def expect(self, expr):
"""Expect a given token type and return it. This accepts the same
argument as :meth:`jinja2.lexer.Token.test`.
"""
if not self.current.test(expr):
expr = describe_token_expr(expr)
if self.current.type is TOKEN_EOF:
raise TemplateSyntaxError('unexpected end of template, '
'expected %r.' % expr,
self.current.lineno,
self.name, self.filename)
raise TemplateSyntaxError("expected token %r, got %r" %
(expr, describe_token(self.current)),
self.current.lineno,
self.name, self.filename)
try:
return self.current
finally:
next(self)
示例2: generate_by_context
# 需要導入模塊: from jinja2 import exceptions [as 別名]
# 或者: from jinja2.exceptions import TemplateSyntaxError [as 別名]
def generate_by_context(self, context):
if context is None:
raise RuntimeError('Can\'t generate templates from None context')
templates = self._preprocess_templates(context.get('templates', []))
if len(templates) == 0:
templates = context.get('kubectl', [])
if len(templates) == 0:
return
output = []
for template in self._iterate_entries(templates):
try:
path = self._generate_file(template, settings.TEMP_DIR, context)
log.info('File "{}" successfully generated'.format(path))
output.append(path)
except TemplateNotFound as e:
raise TemplateRenderingError(
"Processing {}: template {} hasn't been found".format(template['template'], e.name))
except (UndefinedError, TemplateSyntaxError) as e:
raise TemplateRenderingError('Unable to render {}, due to: {}'.format(template, e))
return output
示例3: __init__
# 需要導入模塊: from jinja2 import exceptions [as 別名]
# 或者: from jinja2.exceptions import TemplateSyntaxError [as 別名]
def __init__(self, message, cls=TemplateSyntaxError):
self.message = message
self.error_class = cls
示例4: wrap
# 需要導入模塊: from jinja2 import exceptions [as 別名]
# 或者: from jinja2.exceptions import TemplateSyntaxError [as 別名]
def wrap(self, stream, name=None, filename=None):
"""This is called with the stream as returned by `tokenize` and wraps
every token in a :class:`Token` and converts the value.
"""
for lineno, token, value in stream:
if token in ignored_tokens:
continue
elif token == 'linestatement_begin':
token = 'block_begin'
elif token == 'linestatement_end':
token = 'block_end'
# we are not interested in those tokens in the parser
elif token in ('raw_begin', 'raw_end'):
continue
elif token == 'data':
value = self._normalize_newlines(value)
elif token == 'keyword':
token = value
elif token == 'name':
value = str(value)
if check_ident and not value.isidentifier():
raise TemplateSyntaxError(
'Invalid character in identifier',
lineno, name, filename)
elif token == 'string':
# try to unescape string
try:
value = self._normalize_newlines(value[1:-1]) \
.encode('ascii', 'backslashreplace') \
.decode('unicode-escape')
except Exception as e:
msg = str(e).split(':')[-1].strip()
raise TemplateSyntaxError(msg, lineno, name, filename)
elif token == 'integer':
value = int(value)
elif token == 'float':
value = float(value)
elif token == 'operator':
token = operators[value]
yield Token(lineno, token, value)
示例5: is_template_syntax_error
# 需要導入模塊: from jinja2 import exceptions [as 別名]
# 或者: from jinja2.exceptions import TemplateSyntaxError [as 別名]
def is_template_syntax_error(self):
"""`True` if this is a template syntax error."""
return isinstance(self.exc_value, TemplateSyntaxError)
示例6: make_traceback
# 需要導入模塊: from jinja2 import exceptions [as 別名]
# 或者: from jinja2.exceptions import TemplateSyntaxError [as 別名]
def make_traceback(exc_info, source_hint=None):
"""Creates a processed traceback object from the exc_info."""
exc_type, exc_value, tb = exc_info
if isinstance(exc_value, TemplateSyntaxError):
exc_info = translate_syntax_error(exc_value, source_hint)
initial_skip = 0
else:
initial_skip = 1
return translate_exception(exc_info, initial_skip)