當前位置: 首頁>>代碼示例>>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;未經允許,請勿轉載。