Skip to content

Commit

Permalink
DOC: Format role and directive cross-references in ReST format
Browse files Browse the repository at this point in the history
  • Loading branch information
timhoffm committed Oct 8, 2024
1 parent 886bb94 commit 6a82098
Show file tree
Hide file tree
Showing 2 changed files with 9 additions and 2 deletions.
4 changes: 2 additions & 2 deletions sphinx/domains/rst.py
Original file line number Diff line number Diff line change
Expand Up @@ -230,8 +230,8 @@ class ReSTDomain(Domain):
'role': ReSTRole,
}
roles = {
'dir': XRefRole(),
'role': XRefRole(),
'dir': XRefRole(title_fmt=".. {title}::"),
'role': XRefRole(title_fmt=":{title}:"),
}
initial_data: dict[str, dict[tuple[str, str], str]] = {
'objects': {}, # fullname -> docname, objtype
Expand Down
7 changes: 7 additions & 0 deletions sphinx/roles.py
Original file line number Diff line number Diff line change
Expand Up @@ -61,6 +61,9 @@ class XRefRole(ReferenceRole):
* `lowercase` to lowercase the target
* `nodeclass` and `innernodeclass` select the node classes for
the reference and the content node
* `title_fmt`: an optional format string using one ``{title}`` variable
that can be used to customize the rendered text, e.g.
``title_fmt=":{title}:"`
* Subclassing and overwriting `process_link()` and/or `result_nodes()`.
"""
Expand All @@ -75,6 +78,7 @@ def __init__(
nodeclass: type[Element] | None = None,
innernodeclass: type[TextElement] | None = None,
warn_dangling: bool = False,
title_fmt: str | None = None
) -> None:
self.fix_parens = fix_parens
self.lowercase = lowercase
Expand All @@ -83,6 +87,7 @@ def __init__(
self.nodeclass = nodeclass
if innernodeclass is not None:
self.innernodeclass = innernodeclass
self.title_fmt = title_fmt

super().__init__()

Expand Down Expand Up @@ -145,6 +150,8 @@ def create_xref_node(self) -> tuple[list[Node], list[system_message]]:
self.env, refnode, self.has_explicit_title, title, target
)
refnode['reftarget'] = target
if self.title_fmt is not None:
title = self.title_fmt.format(title=title)
refnode += self.innernodeclass(self.rawtext, title, classes=self.classes)

return self.result_nodes(self.inliner.document, self.env, refnode, is_ref=True)
Expand Down

0 comments on commit 6a82098

Please sign in to comment.