Docstrings
This page showcase the mkdocsstrings extension with its own code.
Todo
Make a dedicated demo package to have just what is needed to style
mkdocstrings
mkdocstrings package.
Automatic documentation from sources, for MkDocs.
Modules:
-
extension–Deprecated. Import from
mkdocstringsdirectly. -
handlers–Deprecated. Import from
mkdocstringsdirectly. -
inventory–Deprecated. Import from
mkdocstringsdirectly. -
loggers–Deprecated. Import from
mkdocstringsdirectly. -
plugin–Deprecated. Import from
mkdocstringsdirectly.
Classes:
-
AutoDocProcessor–Our "autodoc" Markdown block processor.
-
BaseHandler–The base handler class.
-
CollectionError–An exception raised when some collection of data failed.
-
Handlers–A collection of handlers.
-
HeadingShiftingTreeprocessor–Shift levels of all Markdown headings according to the configured base level.
-
Highlighter–Code highlighter that tries to match the Markdown configuration.
-
IdPrependingTreeprocessor–Prepend the configured prefix to IDs of all HTML elements.
-
Inventory–Inventory of collected and rendered objects.
-
InventoryItem–Inventory item.
-
LoggerAdapter–A logger adapter to prefix messages.
-
MkdocstringsExtension–Our Markdown extension.
-
MkdocstringsInnerExtension–Extension that should always be added to Markdown sub-documents that handlers request (and only them).
-
MkdocstringsPlugin–An
mkdocsplugin. -
ParagraphStrippingTreeprocessor–Unwraps the
<p>element around the whole output. -
PluginConfig–The configuration options of
mkdocstrings, written inmkdocs.yml. -
TemplateLogger–A wrapper class to allow logging in templates.
-
ThemeNotSupported–An exception raised to tell a theme is not supported.
Functions:
-
do_any–Check if at least one of the item in the sequence evaluates to true.
-
get_logger–Return a pre-configured logger.
-
get_template_logger–Return a logger usable in templates.
-
get_template_logger_function–Create a wrapper function that automatically receives the Jinja template context.
-
get_template_path–Return the path to the template currently using the given context.
Attributes:
-
CollectorItem–The type of the item returned by the
collectmethod of a handler. -
HandlerConfig–The type of the configuration of a handler.
-
HandlerOptions–The type of the options passed to a handler.
-
TEMPLATES_DIRS(Sequence[Path]) –The directories where the handler templates are located.
CollectorItem
module-attribute
CollectorItem = Any
The type of the item returned by the collect method of a handler.
TEMPLATES_DIRS
module-attribute
The directories where the handler templates are located.
AutoDocProcessor
Bases: BlockProcessor
Our "autodoc" Markdown block processor.
It has a test method that tells if a block matches a criterion,
and a run method that processes it.
It also has utility methods allowing to get handlers and their configuration easily, useful when processing a matched block.
Parameters:
-
(mdMarkdown) –A
markdown.Markdowninstance. -
(handlersHandlers) –The handlers container.
-
(autorefsAutorefsPlugin) –The autorefs plugin instance.
Methods:
Attributes:
Source code in .venv/lib/python3.14/site-packages/mkdocstrings/_internal/extension.py
regex
class-attribute
instance-attribute
The regular expression to match our autodoc instructions.
run
run(parent: Element, blocks: MutableSequence[str]) -> None
Run code on the matched blocks.
The identifier and configuration lines are retrieved from a matched block and used to collect and render an object.
Parameters:
-
(parentElement) –The parent element in the XML tree.
-
(blocksMutableSequence[str]) –The rest of the blocks to be processed.
Source code in .venv/lib/python3.14/site-packages/mkdocstrings/_internal/extension.py
test
Match our autodoc instructions.
Parameters:
Returns:
-
bool–Whether this block should be processed or not.
Source code in .venv/lib/python3.14/site-packages/mkdocstrings/_internal/extension.py
BaseHandler
The base handler class.
Inherit from this class to implement a handler.
You will have to implement the collect and render methods.
You can also implement the teardown method,
and override the update_env method, to add more filters to the Jinja environment,
making them available in your Jinja templates.
To define a fallback theme, add a fallback_theme class-variable.
To add custom CSS, add an extra_css variable or create an 'style.css' file beside the templates.
If the given theme is not supported (it does not exist), it will look for a fallback_theme attribute
in self to use as a fallback theme.
Other Parameters:
-
theme(str) –The theme to use.
-
custom_templates(str | None) –The path to custom templates.
-
mdx(list[str | Extension]) –A list of Markdown extensions to use.
-
mdx_config(Mapping[str, Mapping[str, Any]]) –Configuration for the Markdown extensions.
Methods:
-
collect–Collect data given an identifier and user configuration.
-
do_convert_markdown–Render Markdown text; for use inside templates.
-
do_heading–Render an HTML heading and register it for the table of contents. For use inside templates.
-
get_aliases–Return the possible aliases for a given identifier.
-
get_extended_templates_dirs–Load template extensions for the given handler, return their templates directories.
-
get_headings–Return and clear the headings gathered so far.
-
get_inventory_urls–Return the URLs (and configuration options) of the inventory files to download.
-
get_options–Get combined options.
-
get_templates_dir–Return the path to the handler's templates directory.
-
load_inventory–Yield items and their URLs from an inventory file streamed from
in_file. -
render–Render a template using provided data and configuration options.
-
render_backlinks–Render backlinks.
-
teardown–Teardown the handler.
-
update_env–Update the Jinja environment.
Attributes:
-
custom_templates–The path to custom templates.
-
domain(str) –The handler's domain, used to register objects in the inventory, for example "py".
-
enable_inventory(bool) –Whether the inventory creation is enabled.
-
env–The Jinja environment.
-
extra_css(str) –Extra CSS.
-
fallback_config(dict) –Fallback configuration when searching anchors for identifiers.
-
fallback_theme(str) –Fallback theme to use when a template isn't found in the configured theme.
-
md(Markdown) –The Markdown instance.
-
mdx–The Markdown extensions to use.
-
mdx_config–The configuration for the Markdown extensions.
-
name(str) –The handler's name, for example "python".
-
outer_layer(bool) –Whether we're in the outer Markdown conversion layer.
-
theme–The selected theme.
Source code in .venv/lib/python3.14/site-packages/mkdocstrings/_internal/handlers/base.py
128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 | |
custom_templates
instance-attribute
The path to custom templates.
domain
class-attribute
domain: str = ''
The handler's domain, used to register objects in the inventory, for example "py".
enable_inventory
class-attribute
enable_inventory: bool = False
Whether the inventory creation is enabled.
env
instance-attribute
The Jinja environment.
fallback_config
class-attribute
fallback_config: dict = {}
Fallback configuration when searching anchors for identifiers.
fallback_theme
class-attribute
fallback_theme: str = ''
Fallback theme to use when a template isn't found in the configured theme.
md
property
mdx_config
instance-attribute
The configuration for the Markdown extensions.
collect
collect(identifier: str, options: HandlerOptions) -> CollectorItem
Collect data given an identifier and user configuration.
In the implementation, you typically call a subprocess that returns JSON, and load that JSON again into a Python dictionary for example, though the implementation is completely free.
Parameters:
-
(identifierstr) –An identifier for which to collect data. For example, in Python, it would be 'mkdocstrings.handlers' to collect documentation about the handlers module. It can be anything that you can feed to the tool of your choice.
-
(optionsHandlerOptions) –The final configuration options.
Returns:
-
CollectorItem–Anything you want, as long as you can feed it to the handler's
rendermethod.
Source code in .venv/lib/python3.14/site-packages/mkdocstrings/_internal/handlers/base.py
do_convert_markdown
do_convert_markdown(text: str, heading_level: int, html_id: str = '', *, strip_paragraph: bool = False, autoref_hook: AutorefsHookInterface | None = None) -> Markup
Render Markdown text; for use inside templates.
Parameters:
-
(textstr) –The text to convert.
-
(heading_levelint) –The base heading level to start all Markdown headings from.
-
(html_idstr, default:'') –The HTML id of the element that's considered the parent of this element.
-
(strip_paragraphbool, default:False) –Whether to exclude the
<p>tag from around the whole output.
Returns:
-
Markup–An HTML string.
Source code in .venv/lib/python3.14/site-packages/mkdocstrings/_internal/handlers/base.py
do_heading
do_heading(content: Markup, heading_level: int, *, role: str | None = None, hidden: bool = False, toc_label: str | None = None, skip_inventory: bool = False, **attributes: str) -> Markup
Render an HTML heading and register it for the table of contents. For use inside templates.
Parameters:
-
(contentMarkup) –The HTML within the heading.
-
(heading_levelint) –The level of heading (e.g. 3 ->
h3). -
(rolestr | None, default:None) –An optional role for the object bound to this heading.
-
(hiddenbool, default:False) –If True, only register it for the table of contents, don't render anything.
-
(toc_labelstr | None, default:None) –The title to use in the table of contents ('data-toc-label' attribute).
-
(skip_inventorybool, default:False) –Flag element to not be registered in the inventory (by setting a
data-skip-inventoryattribute). -
(**attributesstr, default:{}) –Any extra HTML attributes of the heading.
Returns:
-
Markup–An HTML string.
Source code in .venv/lib/python3.14/site-packages/mkdocstrings/_internal/handlers/base.py
get_aliases
get_aliases(identifier: str) -> tuple[str, ...]
Return the possible aliases for a given identifier.
Parameters:
-
(identifierstr) –The identifier to get the aliases of.
Returns:
Source code in .venv/lib/python3.14/site-packages/mkdocstrings/_internal/handlers/base.py
get_extended_templates_dirs
Load template extensions for the given handler, return their templates directories.
Parameters:
-
(handlerstr) –The name of the handler to get the extended templates directory of.
Returns:
Source code in .venv/lib/python3.14/site-packages/mkdocstrings/_internal/handlers/base.py
get_headings
Return and clear the headings gathered so far.
Returns:
Source code in .venv/lib/python3.14/site-packages/mkdocstrings/_internal/handlers/base.py
get_inventory_urls
Return the URLs (and configuration options) of the inventory files to download.
get_options
get_options(local_options: Mapping[str, Any]) -> HandlerOptions
Get combined options.
Override this method to customize how options are combined,
for example by merging the global options with the local options.
By combining options here, you don't have to do it twice in collect and render.
Parameters:
Returns:
-
HandlerOptions–The combined options.
Source code in .venv/lib/python3.14/site-packages/mkdocstrings/_internal/handlers/base.py
get_templates_dir
Return the path to the handler's templates directory.
Override to customize how the templates directory is found.
Parameters:
-
(handlerstr | None, default:None) –The name of the handler to get the templates directory of.
Raises:
-
ModuleNotFoundError–When no such handler is installed.
-
FileNotFoundError–When the templates directory cannot be found.
Returns:
-
Path–The templates directory path.
Source code in .venv/lib/python3.14/site-packages/mkdocstrings/_internal/handlers/base.py
load_inventory
classmethod
load_inventory(in_file: BinaryIO, url: str, base_url: str | None = None, **kwargs: Any) -> Iterator[tuple[str, str]]
Yield items and their URLs from an inventory file streamed from in_file.
Parameters:
-
(in_fileBinaryIO) –The binary file-like object to read the inventory from.
-
(urlstr) –The URL that this file is being streamed from (used to guess
base_url). -
(base_urlstr | None, default:None) –The URL that this inventory's sub-paths are relative to.
-
(**kwargsAny, default:{}) –Ignore additional arguments passed from the config.
Yields:
Source code in .venv/lib/python3.14/site-packages/mkdocstrings/_internal/handlers/base.py
render
render(data: CollectorItem, options: HandlerOptions, *, locale: str | None = None) -> str
Render a template using provided data and configuration options.
Parameters:
-
(dataCollectorItem) –The collected data to render.
-
(optionsHandlerOptions) –The final configuration options.
-
(localestr | None, default:None) –The locale to use for translations, if any.
Returns:
-
str–The rendered template as HTML.
Source code in .venv/lib/python3.14/site-packages/mkdocstrings/_internal/handlers/base.py
render_backlinks
Render backlinks.
Parameters:
-
(backlinksMapping[str, Iterable[Backlink]]) –A mapping of identifiers to backlinks.
-
(localestr | None, default:None) –The locale to use for translations, if any.
Returns:
-
str–The rendered backlinks as HTML.
Source code in .venv/lib/python3.14/site-packages/mkdocstrings/_internal/handlers/base.py
teardown
Teardown the handler.
This method should be implemented to, for example, terminate a subprocess that was started when creating the handler instance.
update_env
Update the Jinja environment.
Source code in .venv/lib/python3.14/site-packages/mkdocstrings/_internal/handlers/base.py
CollectionError
Bases: Exception
An exception raised when some collection of data failed.
Handlers
Handlers(*, theme: str, default: str, inventory_project: str, inventory_version: str = '0.0.0', handlers_config: dict[str, HandlerConfig] | None = None, custom_templates: str | None = None, mdx: Sequence[str | Extension] | None = None, mdx_config: Mapping[str, Any] | None = None, locale: str = 'en', tool_config: Any)
A collection of handlers.
Do not instantiate this directly. The plugin will keep one instance of this for the purpose of caching. Use mkdocstrings.MkdocstringsPlugin.get_handler for convenient access.
Parameters:
-
(themestr) –The theme to use.
-
(defaultstr) –The default handler to use.
-
(inventory_projectstr) –The project name to use in the inventory.
-
(inventory_versionstr, default:'0.0.0') –The project version to use in the inventory.
-
(handlers_configdict[str, HandlerConfig] | None, default:None) –The handlers configuration.
-
(custom_templatesstr | None, default:None) –The path to custom templates.
-
(mdxSequence[str | Extension] | None, default:None) –A list of Markdown extensions to use.
-
(mdx_configMapping[str, Any] | None, default:None) –Configuration for the Markdown extensions.
-
(localestr, default:'en') –The locale to use for translations.
-
(tool_configAny) –Tool configuration to pass down to handlers.
Methods:
-
get_anchors–Return the canonical HTML anchor for the identifier, if any of the seen handlers can collect it.
-
get_handler–Get a handler thanks to its name.
-
get_handler_config–Return the global configuration of the given handler.
-
get_handler_name–Return the handler name defined in an "autodoc" instruction YAML configuration, or the global default handler.
-
teardown–Teardown all cached handlers and clear the cache.
Attributes:
-
inventory(Inventory) –The objects inventory.
-
seen_handlers(Iterable[BaseHandler]) –Get the handlers that were encountered so far throughout the build.
Source code in .venv/lib/python3.14/site-packages/mkdocstrings/_internal/handlers/base.py
inventory
instance-attribute
inventory: Inventory = Inventory(project=inventory_project, version=inventory_version)
The objects inventory.
seen_handlers
property
seen_handlers: Iterable[BaseHandler]
Get the handlers that were encountered so far throughout the build.
Returns:
-
Iterable[BaseHandler]–An iterable of instances of
BaseHandler -
Iterable[BaseHandler]–(usable only to loop through it).
get_anchors
get_anchors(identifier: str) -> tuple[str, ...]
Return the canonical HTML anchor for the identifier, if any of the seen handlers can collect it.
Parameters:
Returns:
-
tuple[str, ...]–A tuple of strings - anchors without '#', or an empty tuple if there isn't any identifier familiar with it.
Source code in .venv/lib/python3.14/site-packages/mkdocstrings/_internal/handlers/base.py
get_handler
get_handler(name: str, handler_config: dict | None = None) -> BaseHandler
Get a handler thanks to its name.
This function dynamically imports a module named "mkdocstrings.handlers.NAME", calls its
get_handler method to get an instance of a handler, and caches it in dictionary.
It means that during one run (for each reload when serving, or once when building),
a handler is instantiated only once, and reused for each "autodoc" instruction asking for it.
Parameters:
-
(namestr) –The name of the handler. Really, it's the name of the Python module holding it.
-
(handler_configdict | None, default:None) –Configuration passed to the handler.
Returns:
-
BaseHandler–An instance of a subclass of
BaseHandler, as instantiated by theget_handlermethod of the handler's module.
Source code in .venv/lib/python3.14/site-packages/mkdocstrings/_internal/handlers/base.py
get_handler_config
Return the global configuration of the given handler.
Parameters:
-
(namestr) –The name of the handler to get the global configuration of.
Returns:
-
dict–The global configuration of the given handler. It can be an empty dictionary.
Source code in .venv/lib/python3.14/site-packages/mkdocstrings/_internal/handlers/base.py
get_handler_name
Return the handler name defined in an "autodoc" instruction YAML configuration, or the global default handler.
Parameters:
-
(configdict) –A configuration dictionary, obtained from YAML below the "autodoc" instruction.
Returns:
-
str–The name of the handler to use.
Source code in .venv/lib/python3.14/site-packages/mkdocstrings/_internal/handlers/base.py
teardown
Teardown all cached handlers and clear the cache.
Source code in .venv/lib/python3.14/site-packages/mkdocstrings/_internal/handlers/base.py
HeadingShiftingTreeprocessor
Bases: Treeprocessor
Shift levels of all Markdown headings according to the configured base level.
Parameters:
-
(mdMarkdown) –A
markdown.Markdowninstance. -
(shift_byint) –The number of heading "levels" to add to every heading.
Methods:
-
run–Shift the levels of all headings in the document.
Attributes:
-
name(str) –The name of the treeprocessor.
-
regex(Pattern) –The regex to match heading tags.
-
shift_by(int) –The number of heading "levels" to add to every heading.
<h2>withshift_by = 3becomes<h5>.
Source code in .venv/lib/python3.14/site-packages/mkdocstrings/_internal/handlers/rendering.py
name
class-attribute
instance-attribute
name: str = 'mkdocstrings_headings'
The name of the treeprocessor.
regex
class-attribute
instance-attribute
The regex to match heading tags.
shift_by
instance-attribute
The number of heading "levels" to add to every heading. <h2> with shift_by = 3 becomes <h5>.
run
run(root: Element) -> None
Shift the levels of all headings in the document.
Source code in .venv/lib/python3.14/site-packages/mkdocstrings/_internal/handlers/rendering.py
Highlighter
Highlighter(md: Markdown)
Bases: Highlight
Code highlighter that tries to match the Markdown configuration.
Picking up the global config and defaults works only if you use the codehilite or
pymdownx.highlight (recommended) Markdown extension.
-
If you use
pymdownx.highlight, highlighting settings are picked up from it, and the default CSS class is.highlight. This also means the default ofguess_lang: false. -
Otherwise, if you use the
codehiliteextension, settings are picked up from it, and the default CSS class is.codehilite. Also consider settingguess_lang: false. -
If neither are added to
markdown_extensions, highlighting is enabled anyway. This is for backwards compatibility. If you really want to disable highlighting even in mkdocstrings, add one of these extensions anyway and setuse_pygments: false.
The underlying implementation is pymdownx.highlight regardless.
Parameters:
-
(mdMarkdown) –The Markdown instance to read configs from.
Methods:
-
highlight–Highlight a code-snippet.
Source code in .venv/lib/python3.14/site-packages/mkdocstrings/_internal/handlers/rendering.py
highlight
highlight(src: str, language: str | None = None, *, inline: bool = False, dedent: bool = True, linenums: bool | None = None, **kwargs: Any) -> str
Highlight a code-snippet.
Parameters:
-
(srcstr) –The code to highlight.
-
(languagestr | None, default:None) –Explicitly tell what language to use for highlighting.
-
(inlinebool, default:False) –Whether to highlight as inline.
-
(dedentbool, default:True) –Whether to dedent the code before highlighting it or not.
-
(linenumsbool | None, default:None) –Whether to add line numbers in the result.
-
(**kwargsAny, default:{}) –Pass on to
pymdownx.highlight.Highlight.highlight.
Returns:
-
str–The highlighted code as HTML text, marked safe (not escaped for HTML).
Source code in .venv/lib/python3.14/site-packages/mkdocstrings/_internal/handlers/rendering.py
IdPrependingTreeprocessor
Bases: Treeprocessor
Prepend the configured prefix to IDs of all HTML elements.
Parameters:
-
(mdMarkdown) –A
markdown.Markdowninstance. -
(id_prefixstr) –The prefix to add to every ID. It is prepended without any separator.
Methods:
-
run–Prepend the configured prefix to all IDs in the document.
Attributes:
-
id_prefix(str) –The prefix to add to every ID. It is prepended without any separator; specify your own separator if needed.
-
name(str) –The name of the treeprocessor.
Source code in .venv/lib/python3.14/site-packages/mkdocstrings/_internal/handlers/rendering.py
id_prefix
instance-attribute
The prefix to add to every ID. It is prepended without any separator; specify your own separator if needed.
name
class-attribute
instance-attribute
name: str = 'mkdocstrings_ids'
The name of the treeprocessor.
Inventory
Inventory(items: list[InventoryItem] | None = None, project: str = 'project', version: str = '0.0.0')
Bases: dict
Inventory of collected and rendered objects.
Parameters:
-
(itemslist[InventoryItem] | None, default:None) –A list of items.
-
(projectstr, default:'project') –The project name.
-
(versionstr, default:'0.0.0') –The project version.
Methods:
-
format_sphinx–Format this inventory as a Sphinx
objects.invfile. -
parse_sphinx–Parse a Sphinx v2 inventory file and return an
Inventoryfrom it. -
register–Create and register an item.
Attributes:
Source code in .venv/lib/python3.14/site-packages/mkdocstrings/_internal/inventory.py
format_sphinx
format_sphinx() -> bytes
Format this inventory as a Sphinx objects.inv file.
Returns:
-
bytes–The inventory as bytes.
Source code in .venv/lib/python3.14/site-packages/mkdocstrings/_internal/inventory.py
parse_sphinx
classmethod
parse_sphinx(in_file: BinaryIO, *, domain_filter: Collection[str] = ()) -> Inventory
Parse a Sphinx v2 inventory file and return an Inventory from it.
Parameters:
-
(in_fileBinaryIO) –The binary file-like object to read from.
-
(domain_filterCollection[str], default:()) –A collection of domain values to allow (and filter out all other ones).
Returns:
-
Inventory–An inventory containing the collected items.
Source code in .venv/lib/python3.14/site-packages/mkdocstrings/_internal/inventory.py
register
register(name: str, domain: str, role: str, uri: str, priority: int = 1, dispname: str | None = None) -> None
Create and register an item.
Parameters:
-
(namestr) –The item name.
-
(domainstr) –The item domain, like 'python' or 'crystal'.
-
(rolestr) –The item role, like 'class' or 'method'.
-
(uristr) –The item URI.
-
(priorityint, default:1) –The item priority. Only used internally by mkdocstrings and Sphinx.
-
(dispnamestr | None, default:None) –The item display name.
Source code in .venv/lib/python3.14/site-packages/mkdocstrings/_internal/inventory.py
InventoryItem
InventoryItem(name: str, domain: str, role: str, uri: str, priority: int = 1, dispname: str | None = None)
Inventory item.
Parameters:
-
(namestr) –The item name.
-
(domainstr) –The item domain, like 'python' or 'crystal'.
-
(rolestr) –The item role, like 'class' or 'method'.
-
(uristr) –The item URI.
-
(priorityint, default:1) –The item priority. Only used internally by mkdocstrings and Sphinx.
-
(dispnamestr | None, default:None) –The item display name.
Methods:
-
format_sphinx–Format this item as a Sphinx inventory line.
-
parse_sphinx–Parse a line from a Sphinx v2 inventory file and return an
InventoryItemfrom it.
Attributes:
-
dispname(str) –The item display name.
-
domain(str) –The item domain.
-
name(str) –The item name.
-
priority(int) –The item priority.
-
role(str) –The item role.
-
sphinx_item_regex–Regex to parse a Sphinx v2 inventory line.
-
uri(str) –The item URI.
Source code in .venv/lib/python3.14/site-packages/mkdocstrings/_internal/inventory.py
sphinx_item_regex
class-attribute
instance-attribute
sphinx_item_regex = compile('^(.+?)\\s+(\\S+):(\\S+)\\s+(-?\\d+)\\s+(\\S+)\\s*(.*)$')
Regex to parse a Sphinx v2 inventory line.
format_sphinx
format_sphinx() -> str
Format this item as a Sphinx inventory line.
Returns:
-
str–A line formatted for an
objects.invfile.
Source code in .venv/lib/python3.14/site-packages/mkdocstrings/_internal/inventory.py
parse_sphinx
classmethod
parse_sphinx(line: str, *, return_none: Literal[False]) -> InventoryItem
parse_sphinx(line: str, *, return_none: Literal[True]) -> InventoryItem | None
parse_sphinx(line: str, *, return_none: bool = False) -> InventoryItem | None
Parse a line from a Sphinx v2 inventory file and return an InventoryItem from it.
Source code in .venv/lib/python3.14/site-packages/mkdocstrings/_internal/inventory.py
LoggerAdapter
Bases: LoggerAdapter
A logger adapter to prefix messages.
This adapter also adds an additional parameter to logging methods
called once: if True, the message will only be logged once.
Examples:
In Python code:
>>> logger = get_logger("myplugin")
>>> logger.debug("This is a debug message.")
>>> logger.info("This is an info message.", once=True)
In Jinja templates (logger available in context as log):
Parameters:
-
(prefixstr) –The string to insert in front of every message.
-
(loggerLogger) –The logger instance.
Methods:
Attributes:
-
prefix–The prefix to insert in front of every message.
Source code in .venv/lib/python3.14/site-packages/mkdocstrings/_internal/loggers.py
log
Log a message.
Parameters:
-
(levelint) –The logging level.
-
(msgobject) –The message.
-
(*argsobject, default:()) –Additional arguments passed to parent method.
-
(**kwargsobject, default:{}) –Additional keyword arguments passed to parent method.
Source code in .venv/lib/python3.14/site-packages/mkdocstrings/_internal/loggers.py
process
Process the message.
Parameters:
-
(msgstr) –The message:
-
(kwargsMutableMapping[str, Any]) –Remaining arguments.
Returns:
Source code in .venv/lib/python3.14/site-packages/mkdocstrings/_internal/loggers.py
MkdocstringsExtension
Bases: Extension
Our Markdown extension.
It cannot work outside of mkdocstrings.
Parameters:
-
(handlersHandlers) –The handlers container.
-
(autorefsAutorefsPlugin) –The autorefs plugin instance.
-
(**kwargsAny, default:{}) –Keyword arguments used by
markdown.extensions.Extension.
Methods:
-
extendMarkdown–Register the extension.
Source code in .venv/lib/python3.14/site-packages/mkdocstrings/_internal/extension.py
extendMarkdown
extendMarkdown(md: Markdown) -> None
Register the extension.
Add an instance of our AutoDocProcessor to the Markdown parser.
Parameters:
-
(mdMarkdown) –A
markdown.Markdowninstance.
Source code in .venv/lib/python3.14/site-packages/mkdocstrings/_internal/extension.py
MkdocstringsInnerExtension
Bases: Extension
Extension that should always be added to Markdown sub-documents that handlers request (and only them).
Parameters:
-
(headingslist[Element]) –A list that will be populated with all HTML heading elements encountered in the document.
Methods:
-
extendMarkdown–Register the extension.
Attributes:
-
headings–The list that will be populated with all HTML heading elements encountered in the document.
Source code in .venv/lib/python3.14/site-packages/mkdocstrings/_internal/handlers/rendering.py
headings
instance-attribute
headings = headings
The list that will be populated with all HTML heading elements encountered in the document.
extendMarkdown
extendMarkdown(md: Markdown) -> None
Register the extension.
Parameters:
-
(mdMarkdown) –A
markdown.Markdowninstance.
Source code in .venv/lib/python3.14/site-packages/mkdocstrings/_internal/handlers/rendering.py
MkdocstringsPlugin
Bases: BasePlugin[PluginConfig]
An mkdocs plugin.
This plugin defines the following event hooks:
on_configon_envon_post_build
Check the Developing Plugins page of mkdocs
for more information about its plugin system.
Methods:
-
get_handler–Get a handler by its name. See mkdocstrings.Handlers.get_handler.
-
on_config–Instantiate our Markdown extension.
-
on_post_build–Teardown the handlers.
Attributes:
-
css_filename(str) –The path of the CSS file to write in the site directory.
-
handlers(Handlers) –Get the instance of mkdocstrings.Handlers for this plugin/build.
-
inventory_enabled(bool) –Tell if the inventory is enabled or not.
-
on_env–Extra actions that need to happen after all Markdown-to-HTML page rendering.
-
plugin_enabled(bool) –Tell if the plugin is enabled or not.
Source code in .venv/lib/python3.14/site-packages/mkdocstrings/_internal/plugin.py
css_filename
class-attribute
instance-attribute
css_filename: str = 'assets/_mkdocstrings.css'
The path of the CSS file to write in the site directory.
handlers
property
handlers: Handlers
Get the instance of mkdocstrings.Handlers for this plugin/build.
Raises:
-
RuntimeError–If the plugin hasn't been initialized with a config.
Returns:
-
Handlers–An instance of mkdocstrings.Handlers (the same throughout the build).
inventory_enabled
property
inventory_enabled: bool
on_env
class-attribute
instance-attribute
on_env = CombinedEvent(_on_env_load_inventories, _on_env_add_css, _on_env_write_inventory, _on_env_apply_backlinks)
Extra actions that need to happen after all Markdown-to-HTML page rendering.
Hook for the on_env event.
- Gather results from background inventory download tasks.
- Write mkdocstrings' extra files (CSS, inventory) into the site directory.
- Apply backlinks to the HTML output of each page.
plugin_enabled
property
plugin_enabled: bool
get_handler
get_handler(handler_name: str) -> BaseHandler
Get a handler by its name. See mkdocstrings.Handlers.get_handler.
Parameters:
-
(handler_namestr) –The name of the handler.
Returns:
-
BaseHandler–An instance of a subclass of
BaseHandler.
Source code in .venv/lib/python3.14/site-packages/mkdocstrings/_internal/plugin.py
on_config
on_config(config: MkDocsConfig) -> MkDocsConfig | None
Instantiate our Markdown extension.
Hook for the on_config event.
In this hook, we instantiate our MkdocstringsExtension
and add it to the list of Markdown extensions used by mkdocs.
We pass this plugin's configuration dictionary to the extension when instantiating it (it will need it later when processing markdown to get handlers and their global configurations).
Parameters:
-
(configMkDocsConfig) –The MkDocs config object.
Returns:
-
MkDocsConfig | None–The modified config.
Source code in .venv/lib/python3.14/site-packages/mkdocstrings/_internal/plugin.py
on_post_build
Teardown the handlers.
Hook for the on_post_build event.
This hook is used to teardown all the handlers that were instantiated and cached during documentation buildup.
For example, a handler could open a subprocess in the background and keep it open
to feed it "autodoc" instructions and get back JSON data. If so, it should then close the subprocess at some point:
the proper place to do this is in the handler's teardown method, which is indirectly called by this hook.
Parameters:
-
(configMkDocsConfig) –The MkDocs config object.
-
(**kwargsAny, default:{}) –Additional arguments passed by MkDocs.
Source code in .venv/lib/python3.14/site-packages/mkdocstrings/_internal/plugin.py
ParagraphStrippingTreeprocessor
Bases: Treeprocessor
Unwraps the <p> element around the whole output.
Methods:
-
run–Unwrap the root element if it's a single
<p>element.
Attributes:
name
class-attribute
instance-attribute
name: str = 'mkdocstrings_strip_paragraph'
The name of the treeprocessor.
run
Unwrap the root element if it's a single <p> element.
Source code in .venv/lib/python3.14/site-packages/mkdocstrings/_internal/handlers/rendering.py
PluginConfig
Bases: Config
The configuration options of mkdocstrings, written in mkdocs.yml.
Attributes:
-
custom_templates–Location of custom templates to use when rendering API objects.
-
default_handler–The default handler to use. The value is the name of the handler module. Default is "python".
-
enable_inventory–Whether to enable object inventory creation.
-
enabled–Whether to enable the plugin. Default is true. If false, mkdocstrings will not collect or render anything.
-
handlers–Global configuration of handlers.
-
locale–The locale to use for translations.
custom_templates
class-attribute
instance-attribute
Location of custom templates to use when rendering API objects.
Value should be the path of a directory relative to the MkDocs configuration file.
default_handler
class-attribute
instance-attribute
default_handler = Type(str, default='python')
The default handler to use. The value is the name of the handler module. Default is "python".
enable_inventory
class-attribute
instance-attribute
enable_inventory = Optional(Type(bool))
Whether to enable object inventory creation.
enabled
class-attribute
instance-attribute
enabled = Type(bool, default=True)
Whether to enable the plugin. Default is true. If false, mkdocstrings will not collect or render anything.
handlers
class-attribute
instance-attribute
handlers = Type(dict, default={})
locale
class-attribute
instance-attribute
locale = Optional(Type(str))
The locale to use for translations.
TemplateLogger
TemplateLogger(logger: LoggerAdapter)
A wrapper class to allow logging in templates.
The logging methods provided by this class all accept two parameters:
msg: The message to log.once: IfTrue, the message will only be logged once.
Methods:
-
debug–Function to log a DEBUG message.
-
info–Function to log an INFO message.
-
warning–Function to log a WARNING message.
-
error–Function to log an ERROR message.
-
critical–Function to log a CRITICAL message.
Parameters:
-
(loggerLoggerAdapter) –A logger adapter.
Attributes:
-
critical–Log a CRITICAL message.
-
debug–Log a DEBUG message.
-
error–Log an ERROR message.
-
info–Log an INFO message.
-
warning–Log a WARNING message.
Source code in .venv/lib/python3.14/site-packages/mkdocstrings/_internal/loggers.py
critical
instance-attribute
critical = get_template_logger_function(critical)
Log a CRITICAL message.
ThemeNotSupported
Bases: Exception
An exception raised to tell a theme is not supported.
do_any
Check if at least one of the item in the sequence evaluates to true.
The any builtin as a filter for Jinja templates.
Parameters:
-
(seqSequence) –An iterable object.
-
(attributestr | None, default:None) –The attribute name to use on each object of the iterable.
Returns:
-
bool–A boolean telling if any object of the iterable evaluated to True.
Source code in .venv/lib/python3.14/site-packages/mkdocstrings/_internal/handlers/base.py
get_logger
get_logger(name: str) -> LoggerAdapter
Return a pre-configured logger.
Parameters:
-
(namestr) –The name to use with
logging.getLogger.
Returns:
-
LoggerAdapter–A logger configured to work well in MkDocs.
Source code in .venv/lib/python3.14/site-packages/mkdocstrings/_internal/loggers.py
get_template_logger
get_template_logger(handler_name: str | None = None) -> TemplateLogger
Return a logger usable in templates.
Parameters:
-
(handler_namestr | None, default:None) –The name of the handler.
Returns:
-
TemplateLogger–A template logger.
Source code in .venv/lib/python3.14/site-packages/mkdocstrings/_internal/loggers.py
get_template_logger_function
get_template_logger_function(logger_func: Callable) -> Callable
Create a wrapper function that automatically receives the Jinja template context.
Parameters:
-
(logger_funcCallable) –The logger function to use within the wrapper.
Returns:
-
Callable–A function.
Source code in .venv/lib/python3.14/site-packages/mkdocstrings/_internal/loggers.py
get_template_path
Return the path to the template currently using the given context.
Parameters:
-
(contextContext) –The template context.
Returns:
-
str–The relative path to the template.