当前位置: 首页>>代码示例>>Python>>正文


Python nodes.Keyword方法代码示例

本文整理汇总了Python中jinja2.nodes.Keyword方法的典型用法代码示例。如果您正苦于以下问题:Python nodes.Keyword方法的具体用法?Python nodes.Keyword怎么用?Python nodes.Keyword使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在jinja2.nodes的用法示例。


在下文中一共展示了nodes.Keyword方法的5个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Python代码示例。

示例1: parse_autoescape

# 需要导入模块: from jinja2 import nodes [as 别名]
# 或者: from jinja2.nodes import Keyword [as 别名]
def parse_autoescape(self):
        node = nodes.ScopedEvalContextModifier(lineno=next(self.stream).lineno)
        node.options = [
            nodes.Keyword('autoescape', self.parse_expression())
        ]
        node.body = self.parse_statements(('name:endautoescape',),
                                            drop_needle=True)
        return nodes.Scope([node]) 
开发者ID:remg427,项目名称:misp42splunk,代码行数:10,代码来源:parser.py

示例2: parse

# 需要导入模块: from jinja2 import nodes [as 别名]
# 或者: from jinja2.nodes import Keyword [as 别名]
def parse(self, parser):
        node = nodes.ScopedEvalContextModifier(lineno=next(parser.stream).lineno)
        node.options = [
            nodes.Keyword('autoescape', parser.parse_expression())
        ]
        node.body = parser.parse_statements(('name:endautoescape',),
                                            drop_needle=True)
        return nodes.Scope([node]) 
开发者ID:jpush,项目名称:jbox,代码行数:10,代码来源:ext.py

示例3: parse_args

# 需要导入模块: from jinja2 import nodes [as 别名]
# 或者: from jinja2.nodes import Keyword [as 别名]
def parse_args(self, parser):
        args = []
        kwargs = []

        stream = parser.stream

        while stream.current.type != 'block_end':
            if stream.current.type == 'name' \
                    and stream.look().type == 'assign':
                key = stream.current.value
                if key not in self.allowed_kwargs:
                    parser.fail(
                        "'%s' is not a valid keyword argument "
                        "for {%% cache %%}" % key,
                        stream.current.lineno)
                stream.skip(2)
                value = parser.parse_expression()
                kwargs.append(Keyword(key, value, lineno=value.lineno))
            else:
                args.append(parser.parse_expression())

            if stream.current.type == 'block_end':
                break

            parser.stream.expect('comma')

        return args, kwargs 
开发者ID:noripyt,项目名称:django-cachalot,代码行数:29,代码来源:jinja2ext.py

示例4: parse

# 需要导入模块: from jinja2 import nodes [as 别名]
# 或者: from jinja2.nodes import Keyword [as 别名]
def parse(self, parser):
        tag = parser.stream.current.value
        lineno = next(parser.stream).lineno
        args, kwargs = self.parse_args(parser)
        default_cache_key = (None if parser.filename is None
                             else '%s:%d' % (parser.filename, lineno))
        kwargs.append(Keyword('default_cache_key', Const(default_cache_key),
                              lineno=lineno))
        body = parser.parse_statements(['name:end' + tag], drop_needle=True)

        return CallBlock(self.call_method('cache', args, kwargs),
                         [], [], body).set_lineno(lineno) 
开发者ID:noripyt,项目名称:django-cachalot,代码行数:14,代码来源:jinja2ext.py

示例5: parse

# 需要导入模块: from jinja2 import nodes [as 别名]
# 或者: from jinja2.nodes import Keyword [as 别名]
def parse(self, parser):
        lineno = next(parser.stream).lineno
        expr = parser.parse_expression()
        args = [expr]
        kwargs = [nodes.Keyword('func', expr)]
        if parser.stream.skip_if('comma'):
            # Optional 'note' for function docstring
            if (
                parser.stream.current.type == 'name' and
                parser.stream.current.value in (
                    'note', 'cond_for', 'depends_on'
                )
            ):
                stream_type = parser.stream.current.value
                next(parser.stream)
                parser.stream.expect('assign')
                # Depends meta is always a list
                if stream_type == 'depends_on':
                    c_expr = parser.parse_list()
                else:
                    c_expr = parser.parse_expression()
                args.append(c_expr)
                kwargs.append(nodes.Keyword(stream_type, c_expr))

        body = parser.parse_statements(
            ['name:endsql', 'name:endquery'], drop_needle=True
        )
        raw_template = self.environment.sql_params['raws'][parser.name]

        # Lines range of original raw template
        raw_lines = slice(lineno, parser.stream.current.lineno-1)
        self.environment.sql_params.setdefault('funcs', {}).update({
            expr.value: {'raw_sql': '\n '.join(raw_template[raw_lines])}
        })
        call_node = nodes.Call(
            self.attr('_sql_process', lineno=lineno),
            args, kwargs, None, None
        )
        return nodes.CallBlock(call_node, [], [], body) 
开发者ID:semirook,项目名称:snaql,代码行数:41,代码来源:factory.py


注:本文中的jinja2.nodes.Keyword方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。