當前位置: 首頁>>代碼示例>>Python>>正文


Python addnodes.toctree方法代碼示例

本文整理匯總了Python中sphinx.addnodes.toctree方法的典型用法代碼示例。如果您正苦於以下問題:Python addnodes.toctree方法的具體用法?Python addnodes.toctree怎麽用?Python addnodes.toctree使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在sphinx.addnodes的用法示例。


在下文中一共展示了addnodes.toctree方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: build_full_toctree

# 需要導入模塊: from sphinx import addnodes [as 別名]
# 或者: from sphinx.addnodes import toctree [as 別名]
def build_full_toctree(builder, docname, prune, collapse):
    """Return a single toctree starting from docname containing all
    sub-document doctrees.
    """
    env = builder.env
    doctree = env.get_doctree(env.config.master_doc)
    toctrees = []
    for toctreenode in doctree.traverse(addnodes.toctree):
        toctree = env.resolve_toctree(docname, builder, toctreenode,
                                      collapse=collapse,
                                      prune=prune,
                                      )
        toctrees.append(toctree)
    if not toctrees:
        return None
    result = toctrees[0]
    for toctree in toctrees[1:]:
        if toctree:
            result.extend(toctree.children)
    env.resolve_references(result, docname, builder)
    return result 
開發者ID:sonofeft,項目名稱:RocketCEA,代碼行數:23,代碼來源:fulltoc.py

示例2: get_rendered_toctree

# 需要導入模塊: from sphinx import addnodes [as 別名]
# 或者: from sphinx.addnodes import toctree [as 別名]
def get_rendered_toctree(builder, docname, **kwargs):
    """Build the toctree relative to the named document,
    with the given parameters, and then return the rendered
    HTML fragment.
    """
    
    if kwargs.get('prune', None) is None:
        kwargs['prune'] = False
    if kwargs.get('collapse', None) is None:
        kwargs['collapse'] = True
    
    fulltoc = build_full_toctree(builder,
                                 docname,
                                 **kwargs
                                 )
    rendered_toc = builder.render_partial(fulltoc)['fragment']
    return rendered_toc 
開發者ID:DataBiosphere,項目名稱:toil,代碼行數:19,代碼來源:fulltoc.py

示例3: build_full_toctree

# 需要導入模塊: from sphinx import addnodes [as 別名]
# 或者: from sphinx.addnodes import toctree [as 別名]
def build_full_toctree(builder, docname, prune, collapse, **kwargs):
    """Return a single toctree starting from docname containing all
    sub-document doctrees.
    """
    env = builder.env
    doctree = env.get_doctree(env.config.master_doc)
    toctrees = []
    for toctreenode in doctree.traverse(addnodes.toctree):
        toctree = env.resolve_toctree(docname, builder, toctreenode,
                                      collapse=collapse,
                                      prune=prune,
                                      **kwargs
                                      )
        toctrees.append(toctree)
    if not toctrees:
        return None
    result = toctrees[0]
    for toctree in toctrees[1:]:
        if toctree:
            result.extend(toctree.children)
    env.resolve_references(result, docname, builder)
    return result 
開發者ID:DataBiosphere,項目名稱:toil,代碼行數:24,代碼來源:fulltoc.py

示例4: build_full_toctree

# 需要導入模塊: from sphinx import addnodes [as 別名]
# 或者: from sphinx.addnodes import toctree [as 別名]
def build_full_toctree(builder, docname, prune, collapse):
    """Return a single toctree starting from docname containing all
    sub-document doctrees.
    """
    env = builder.env
    doctree = env.get_doctree(env.config.master_doc)
    toctrees = []
    for toctreenode in doctree.traverse(addnodes.toctree):
        toctree = env.resolve_toctree(docname, builder, toctreenode,
                                      collapse=collapse,
                                      prune=prune,
                                      includehidden=True,
                                      )
        pdb.set_trace()
        if toctree is not None:
            toctrees.append(toctree)

    if not toctrees:
        return None
    result = toctrees[0]
    for toctree in toctrees[1:]:
        if toctree:
            result.extend(toctree.children)
    env.resolve_references(result, docname, builder)
    return result 
開發者ID:wehr-lab,項目名稱:autopilot,代碼行數:27,代碼來源:fulltoc.py

示例5: process_autosummary_toc

# 需要導入模塊: from sphinx import addnodes [as 別名]
# 或者: from sphinx.addnodes import toctree [as 別名]
def process_autosummary_toc(app, doctree):
    """Insert items described in autosummary:: to the TOC tree, but do
    not generate the toctree:: list.
    """
    env = app.builder.env
    crawled = {}
    def crawl_toc(node, depth=1):
        crawled[node] = True
        for j, subnode in enumerate(node):
            try:
                if (isinstance(subnode, autosummary_toc)
                    and isinstance(subnode[0], addnodes.toctree)):
                    env.note_toctree(env.docname, subnode[0])
                    continue
            except IndexError:
                continue
            if not isinstance(subnode, nodes.section):
                continue
            if subnode not in crawled:
                crawl_toc(subnode, depth+1)
    crawl_toc(doctree) 
開發者ID:nguy,項目名稱:artview,代碼行數:23,代碼來源:__init__.py

示例6: get_target_uri

# 需要導入模塊: from sphinx import addnodes [as 別名]
# 或者: from sphinx.addnodes import toctree [as 別名]
def get_target_uri(self, docname, typ=None):
        # print 'GTU',docname,typ
        # FIXME: production lists are not supported yet!
        if typ == 'token':
            # token references are always inside production lists and must be
            # replaced by \token{} in LaTeX
            return '@token'
        if docname not in self.docnames:

            # It can be a 'main' document:
            for doc in self.document_data:
                if doc[0] == docname:
                    return "pdf:" + doc[1] + '.pdf'
            # It can be in some other document's toctree
            for indexname, toctree in self.env.toctree_includes.items():
                if docname in toctree:
                    for doc in self.document_data:
                        if doc[0] == indexname:
                            return "pdf:" + doc[1] + '.pdf'
            # No idea
            raise NoUri
        else:  # Local link
            return "" 
開發者ID:rst2pdf,項目名稱:rst2pdf,代碼行數:25,代碼來源:pdfbuilder.py

示例7: process_autosummary_toc

# 需要導入模塊: from sphinx import addnodes [as 別名]
# 或者: from sphinx.addnodes import toctree [as 別名]
def process_autosummary_toc(app, doctree):
    """Insert items described in autosummary:: to the TOC tree, but do
    not generate the toctree:: list.
    """
    #print "DEBUG: process_autosummary_toc"
    env = app.builder.env
    crawled = {}

    def crawl_toc(node, depth=1):
        crawled[node] = True
        for j, subnode in enumerate(node):
            #print "DEBUG: processing ",(j,subnode)
            try:
                if (isinstance(subnode, autosummary_toc) and
                        isinstance(subnode[0], addnodes.toctree)):
                    env.note_toctree(env.docname, subnode[0])
                    #print "DEBUG: ADDIND DOC!"
                    continue
            except IndexError:
                #print "DEBUG: indexerror"
                continue
            if not isinstance(subnode, nodes.section):
                #print "DEBUG: not instance"
                continue
            if subnode not in crawled:
                crawl_toc(subnode, depth+1)
    crawl_toc(doctree) 
開發者ID:pyGSTio,項目名稱:pyGSTi,代碼行數:29,代碼來源:autosummary__init__.py

示例8: autosummary_toc_visit_html

# 需要導入模塊: from sphinx import addnodes [as 別名]
# 或者: from sphinx.addnodes import toctree [as 別名]
def autosummary_toc_visit_html(self, node):
    """Hide autosummary toctree list in HTML output."""
    #print "DEBUG: SKIPPING ",node
    raise nodes.SkipNode 
開發者ID:pyGSTio,項目名稱:pyGSTi,代碼行數:6,代碼來源:autosummary__init__.py

示例9: run

# 需要導入模塊: from sphinx import addnodes [as 別名]
# 或者: from sphinx.addnodes import toctree [as 別名]
def run(self):
        self.env = env = self.state.document.settings.env
        self.genopt = Options()
        self.warnings = []
        self.result = ViewList()

        names = [x.strip().split()[0] for x in self.content
                 if x.strip() and re.search(r'^[~a-zA-Z_]', x.strip()[0])]
        #print "DEBUG: running for ",names
        items = self.get_items(names)
        nodes = self.get_table(items)

        if 'toctree' in self.options:
            dirname = posixpath.dirname(env.docname)

            tree_prefix = self.options['toctree'].strip()
            docnames = []
            for name, sig, summary, real_name in items:
                docname = posixpath.join(tree_prefix, real_name)
                docname = posixpath.normpath(posixpath.join(dirname, docname))
                if docname not in env.found_docs:
                    self.warn('toctree references unknown document %r'
                              % docname)
                docnames.append(docname)

            tocnode = addnodes.toctree()
            tocnode['includefiles'] = docnames
            tocnode['entries'] = [(None, docn) for docn in docnames]
            tocnode['maxdepth'] = -1
            tocnode['glob'] = None

            tocnode = autosummary_toc('', '', tocnode)
            #print "DEBUG: appending toc node:",tocnode
            nodes.append(tocnode)

        return self.warnings + nodes 
開發者ID:pyGSTio,項目名稱:pyGSTi,代碼行數:38,代碼來源:autosummary__init__.py

示例10: test_empty

# 需要導入模塊: from sphinx import addnodes [as 別名]
# 或者: from sphinx.addnodes import toctree [as 別名]
def test_empty():
    """Local TOC is showing, as toctree was empty"""
    for (app, status, warning) in build_all('test-empty'):
        assert app.env.get_doctree('index').traverse(addnodes.toctree)
        content = open(os.path.join(app.outdir, 'index.html')).read()
        if sphinx.version_info < (1, 4):
            if isinstance(app.builder, SingleFileHTMLBuilder):
                assert '<div class="toctree-wrapper compound">\n</div>' in content
                assert '<div class="local-toc">' in content
            else:
                global_toc = (
                    '<div class="toctree-wrapper compound">\n'
                    '<ul class="simple">\n</ul>\n'
                    '</div>'
                )
                local_toc = (
                    '<div class="local-toc"><ul class="simple">'
                    '</ul>\n</div>'
                )
                assert global_toc in content
                assert local_toc not in content
        else:
            global_toc = '<div class="toctree-wrapper compound">\n</div>'
            local_toc = (
                '<div class="local-toc"><ul>\n'
                '<li><a class="reference internal" href="#">test-empty</a></li>'
                '</ul>\n</div>'
            )
            assert global_toc in content
            assert local_toc not in content 
開發者ID:tirthajyoti,項目名稱:doepy,代碼行數:32,代碼來源:test_builders.py

示例11: test_missing_toctree

# 需要導入模塊: from sphinx import addnodes [as 別名]
# 或者: from sphinx.addnodes import toctree [as 別名]
def test_missing_toctree():
    """Local TOC is showing, as toctree was missing"""
    for (app, status, warning) in build_all('test-missing-toctree'):
        assert app.env.get_doctree('index').traverse(addnodes.toctree) == []
        content = open(os.path.join(app.outdir, 'index.html')).read()
        assert '<div class="toctree' not in content
        assert '<div class="local-toc">' in content 
開發者ID:tirthajyoti,項目名稱:doepy,代碼行數:9,代碼來源:test_builders.py

示例12: fix_toc_entries

# 需要導入模塊: from sphinx import addnodes [as 別名]
# 或者: from sphinx.addnodes import toctree [as 別名]
def fix_toc_entries(app, doctree):
    # Get the docname; I don't know why this isn't just passed in to the
    # callback
    # This seems a bit unreliable as it's undocumented, but it's not "private"
    # either:
    docname = app.builder.env.temp_data['docname']
    if app.builder.env.metadata[docname].get('tocdepth', 0) != 0:
        # We need to reprocess any TOC nodes in the doctree and make sure all
        # the files listed in any TOCs are noted
        for treenode in doctree.traverse(addnodes.toctree):
            app.builder.env.note_toctree(docname, treenode) 
開發者ID:jakevdp,項目名稱:supersmoother,代碼行數:13,代碼來源:tocdepthfix.py

示例13: html_page_context

# 需要導入模塊: from sphinx import addnodes [as 別名]
# 或者: from sphinx.addnodes import toctree [as 別名]
def html_page_context(app, pagename, templatename, context, doctree):
    """Event handler for the html-page-context signal.

    Modifies the context directly.

     - Replaces the 'toc' value created by the HTML builder with one
       that shows all document titles and the local table of contents.
     - Sets display_toc to True so the table of contents is always
       displayed, even on empty pages.
     - Replaces the 'toctree' function with one that uses the entire
       document structure, ignores the maxdepth argument, and uses
       only prune and collapse.
    """
    rendered_toc = get_rendered_toctree(app.builder, pagename)
    context['toc'] = rendered_toc
    context['display_toc'] = True  # force toctree to display

    # Commented out the following on Sept 5, 2015 (sonofeft)
    #   On ReadTheDocs it was causing:
    #  "TypeError: <function make_toctree at 0x7f200cb11b90> is not JSON serializable"
    #def make_toctree(collapse=True):
    #    return get_rendered_toctree(app.builder,
    #                                pagename,
    #                                prune=False,
    #                                collapse=collapse,
    #                                )
    #context['toctree'] = make_toctree 
開發者ID:sonofeft,項目名稱:RocketCEA,代碼行數:29,代碼來源:fulltoc.py

示例14: get_rendered_toctree

# 需要導入模塊: from sphinx import addnodes [as 別名]
# 或者: from sphinx.addnodes import toctree [as 別名]
def get_rendered_toctree(builder, docname, prune=False, collapse=True):
    """Build the toctree relative to the named document,
    with the given parameters, and then return the rendered
    HTML fragment.
    """
    fulltoc = build_full_toctree(builder,
                                 docname,
                                 prune=prune,
                                 collapse=collapse,
                                 )
    rendered_toc = builder.render_partial(fulltoc)['fragment']
    return rendered_toc 
開發者ID:sonofeft,項目名稱:RocketCEA,代碼行數:14,代碼來源:fulltoc.py

示例15: html_page_context

# 需要導入模塊: from sphinx import addnodes [as 別名]
# 或者: from sphinx.addnodes import toctree [as 別名]
def html_page_context(app, pagename, templatename, context, doctree):
    """Event handler for the html-page-context signal.
    Modifies the context directly.
     - Replaces the 'toc' value created by the HTML builder with one
       that shows all document titles and the local table of contents.
     - Sets display_toc to True so the table of contents is always
       displayed, even on empty pages.
     - Replaces the 'toctree' function with one that uses the entire
       document structure, ignores the maxdepth argument, and uses
       only prune and collapse.
    """
    rendered_toc = get_rendered_toctree(app.builder, pagename)
    context['toc'] = rendered_toc
    context['display_toc'] = True  # force toctree to display

    if "toctree" not in context:
        # json builder doesn't use toctree func, so nothing to replace
        return

    def make_toctree(**kwargs):
        kwargs['prune'] = False
        return get_rendered_toctree(app.builder,
                                    pagename,
                                    **kwargs,
                                    )

    context['toctree'] = make_toctree 
開發者ID:DataBiosphere,項目名稱:toil,代碼行數:29,代碼來源:fulltoc.py


注:本文中的sphinx.addnodes.toctree方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。