Skip to content

Context propagation

Context propagation

MkNodes which are part of the node tree can have a context attached. If this is the case, the context gets propagated to all children of given node.

The most common case is to have one single context for one website. That context usually contains information about the package you want to document. It is set automatically for the root nav.

def build(project):
    root = project.get_root()
    assert root.ctx.metadata.distribution_name == "mknodes"

Once a node has access to the context, that context will become injected into the jinja2 namespace of given node.

@nav.route_page("My page")
def _(page):
    node = mk.MkText(">=3.12", render_jinja=True)
    assert str(node) == ""  # not connected to any context, so returns empty string
    page += node  # Add node to the nav and allow accessing its context (assuming that nav is connected to root nav).
    assert str(node) != ""  # this now returns the required python version for the context.

Some nodes will also show the context metadata by default if no other data is explicitely set.

@nav.route_page("My page")
def _(page):
    node = MkLicense()
    assert str(node) == ""  # not connected to any context, so returns empty string
    page += node  # Add MkLicense to the nav and allow accessing its context (assuming that nav is connected to root nav).
    assert str(node) != ""  # this now returns the license text for the context.

The following graph illustrates how the context propagation works. Any element from the tree can be attached to a context, no matter whether it is a nav, a page or any other node.

flowchart
  style 437499 fill:#0000AA
  style 553415 fill:#0000AA
  style 618757 fill:#660000
  style 683622 fill:#660000
  style 332511 fill:#9f00df
  style 893065 fill:#9f00df
  714252["MkNav"] --- 463152["MkPage"]
  553415[("Project X")] --- 714252
  618757[("Project Y")] --- 471096["Root MkNav"]
  471096 --- 714252
  332511[("Project Z")] --- 463152
  subgraph 683622["Context Y"]
    310485["MkNav"] --- 831529["MkPage"]
    831529 --- 412394["MkNode"]
    831529 --- 591080["..."]
    167774["MkPage"] --- 512291["MkNode"]
    167774 --- 545444["..."]
    471096 --- 310485
    471096 --- 167774
  end
  subgraph 437499["Context X"]
    103229["MkPage"] --- 601764["MkNode"]
    103229 --- 769363["..."]
    714252 --- 103229
  end
  subgraph 893065["Context Z"]
    463152 --- 920059["MkNode"]
    463152 --- 503161["..."]
    920059 --- 645054["MkNode"]
    920059 --- 549467["..."]
  end
Page info
Code for this page
mknodes.manual.navs_section._
@nav.route.page("Context propagation")
def _(page: mk.MkPage):
    page += mk.MkTemplate("context_propagation.jinja")
Resources
Resources(css=[],
          markdown_extensions={'attr_list': {},
                               'md_in_html': {},
                               'pymdownx.emoji': {'emoji_generator': <function to_svg at 0x7fdd9aa4e520>,
                                                  'emoji_index': <function twemoji at 0x7fdd9aa4e3e0>},
                               'pymdownx.magiclink': {'repo': 'mknodes',
                                                      'repo_url_shorthand': True,
                                                      'user': 'phil65'}},
          plugins=[],
          js=[],
          assets=[],
          packages=[])
Metadata
created:
  source_filename: /home/runner/work/mknodes/mknodes/mknodes/manual/navs_section.py
  source_function: null
  source_line_no: 59
template: SUMMARY.html
title: Context propagation