diff --git a/src/antsibull/data/docsite/list_of_collections_by_namespace.rst.j2 b/src/antsibull/data/docsite/list_of_collections_by_namespace.rst.j2 index 248a53c6c..20ec25a9f 100644 --- a/src/antsibull/data/docsite/list_of_collections_by_namespace.rst.j2 +++ b/src/antsibull/data/docsite/list_of_collections_by_namespace.rst.j2 @@ -2,6 +2,9 @@ :orphan: {% endif %} +.. |equalsign| unicode:: 0x3D .. equal sign + :trim: + .. _list_of_collections_@{ namespace }@: {% set title = 'Collections in the ' ~ (namespace | title) ~ ' Namespace' | rst_ify -%} diff --git a/src/antsibull/data/docsite/list_of_plugins.rst.j2 b/src/antsibull/data/docsite/list_of_plugins.rst.j2 index dcefed989..4d482713c 100644 --- a/src/antsibull/data/docsite/list_of_plugins.rst.j2 +++ b/src/antsibull/data/docsite/list_of_plugins.rst.j2 @@ -1,5 +1,8 @@ :orphan: +.. |equalsign| unicode:: 0x3D .. equal sign + :trim: + .. _list_of_@{ plugin_type }@_plugins: {% if plugin_type == 'module' %} diff --git a/src/antsibull/data/docsite/plugin-deprecation.rst.j2 b/src/antsibull/data/docsite/plugin-deprecation.rst.j2 index 5156f0bd9..92069bd54 100644 --- a/src/antsibull/data/docsite/plugin-deprecation.rst.j2 +++ b/src/antsibull/data/docsite/plugin-deprecation.rst.j2 @@ -3,6 +3,9 @@ {# avoids rST "isn't included in any toctree" errors for module docs #} :orphan: +.. |equalsign| unicode:: 0x3D .. equal sign + :trim: + .. _@{ module }@_@{ plugin_type }@_alias_@{ alias }@: {% if short_description %} diff --git a/src/antsibull/data/docsite/plugin-redirect.rst.j2 b/src/antsibull/data/docsite/plugin-redirect.rst.j2 index 50148dcad..47262bed4 100644 --- a/src/antsibull/data/docsite/plugin-redirect.rst.j2 +++ b/src/antsibull/data/docsite/plugin-redirect.rst.j2 @@ -2,6 +2,9 @@ :orphan: +.. |equalsign| unicode:: 0x3D .. equal sign + :trim: + .. Anchors .. _ansible_collections.@{plugin_name}@_@{plugin_type}@: diff --git a/src/antsibull/data/docsite/plugin-tombstone.rst.j2 b/src/antsibull/data/docsite/plugin-tombstone.rst.j2 index 6f4cc686a..dc546e1d9 100644 --- a/src/antsibull/data/docsite/plugin-tombstone.rst.j2 +++ b/src/antsibull/data/docsite/plugin-tombstone.rst.j2 @@ -2,6 +2,9 @@ :orphan: +.. |equalsign| unicode:: 0x3D .. equal sign + :trim: + .. Anchors .. _ansible_collections.@{plugin_name}@_@{plugin_type}@: diff --git a/src/antsibull/data/docsite/plugin.rst.j2 b/src/antsibull/data/docsite/plugin.rst.j2 index 719acdfed..63c4b722d 100644 --- a/src/antsibull/data/docsite/plugin.rst.j2 +++ b/src/antsibull/data/docsite/plugin.rst.j2 @@ -7,6 +7,9 @@ .. |antsibull-internal-nbsp| unicode:: 0xA0 :trim: +.. |equalsign| unicode:: 0x3D .. equal sign + :trim: + .. role:: ansible-attribute-support-label .. role:: ansible-attribute-support-property .. role:: ansible-attribute-support-full diff --git a/src/antsibull/data/docsite/plugins_by_collection.rst.j2 b/src/antsibull/data/docsite/plugins_by_collection.rst.j2 index 234ef87b3..951e9da02 100644 --- a/src/antsibull/data/docsite/plugins_by_collection.rst.j2 +++ b/src/antsibull/data/docsite/plugins_by_collection.rst.j2 @@ -2,6 +2,9 @@ :orphan: {% endif %} +.. |equalsign| unicode:: 0x3D .. equal sign + :trim: + {% macro list_plugins(plugin_type) %} {% for name, desc in plugin_maps[plugin_type].items() | sort %} * :ref:`@{ name }@ ` -- @{ desc | rst_ify | indent(width=2) }@ diff --git a/src/antsibull/data/docsite/role.rst.j2 b/src/antsibull/data/docsite/role.rst.j2 index e68c5d5e2..17b9606d2 100644 --- a/src/antsibull/data/docsite/role.rst.j2 +++ b/src/antsibull/data/docsite/role.rst.j2 @@ -3,6 +3,9 @@ :orphan: +.. |equalsign| unicode:: 0x3D .. equal sign + :trim: + .. role:: ansible-option-type .. role:: ansible-option-elements .. role:: ansible-option-required diff --git a/src/antsibull/jinja2/filters.py b/src/antsibull/jinja2/filters.py index 7074b39c2..41ebc7a55 100644 --- a/src/antsibull/jinja2/filters.py +++ b/src/antsibull/jinja2/filters.py @@ -19,13 +19,24 @@ _ITALIC = re.compile(r"\bI\(([^)]+)\)") _BOLD = re.compile(r"\bB\(([^)]+)\)") _MODULE = re.compile(r"\bM\(([^).]+)\.([^).]+)\.([^)]+)\)") +_PLUGIN = re.compile(r"\bP\(([^).]+)\.([^).]+)\.([^)]+)#([a-z]+)\)") _URL = re.compile(r"\bU\(([^)]+)\)") _LINK = re.compile(r"\bL\(([^)]+), *([^)]+)\)") _REF = re.compile(r"\bR\(([^)]+), *([^)]+)\)") _CONST = re.compile(r"\bC\(([^)]+)\)") +_SEM_OPTION_NAME = re.compile(r"\bO\(([^)]+)\)") +_SEM_OPTION_VALUE = re.compile(r"\bV\(([^)]+)\)") +_SEM_ENV_VARIABLE = re.compile(r"\bE\(([^)]+)\)") _RULER = re.compile(r"\bHORIZONTALLINE\b") +def _option_name_html(matcher): + parts = matcher.group(1).split('=', 1) + if len(parts) == 1: + return f'{parts[0]}' + return f'{parts[0]}={parts[1]}' + + def html_ify(text): ''' convert symbols like I(this is in italics) to valid HTML ''' @@ -38,10 +49,15 @@ def html_ify(text): text, _counts['bold'] = _BOLD.subn(r"\1", text) text, _counts['module'] = _MODULE.subn( r"\1.\2.\3", text) + text, _counts['plugin'] = _PLUGIN.subn( + r"\1.\2.\3", text) text, _counts['url'] = _URL.subn(r"\1", text) text, _counts['ref'] = _REF.subn(r"\1", text) text, _counts['link'] = _LINK.subn(r"\1", text) text, _counts['const'] = _CONST.subn(r"\1", text) + text, _counts['option-name'] = _SEM_OPTION_NAME.subn(_option_name_html, text) + text, _counts['option-value'] = _SEM_OPTION_VALUE.subn(r"\1", text) + text, _counts['environment-var'] = _SEM_ENV_VARIABLE.subn(r"\1", text) text, _counts['ruler'] = _RULER.subn(r"
", text) text = text.strip() @@ -71,6 +87,13 @@ def do_max(seq): return max(seq) +def _option_name_rst(matcher): + parts = matcher.group(1).split('=', 1) + if len(parts) == 1: + return f'*{parts[0]}*' + return f'*{parts[0]}* |equalsign| ``{parts[1]}``' + + def rst_ify(text): ''' convert symbols like I(this is in italics) to valid restructured text ''' @@ -82,10 +105,15 @@ def rst_ify(text): text, _counts['bold'] = _BOLD.subn(r"**\1**", text) text, _counts['module'] = _MODULE.subn( r":ref:`\1.\2.\3 `", text) + text, _counts['plugin'] = _PLUGIN.subn( + r":ref:`\1.\2.\3 `", text) text, _counts['url'] = _LINK.subn(r"`\1 <\2>`__", text) text, _counts['ref'] = _URL.subn(r"\1", text) text, _counts['link'] = _REF.subn(r":ref:`\1 <\2>`", text) text, _counts['const'] = _CONST.subn(r"``\1``", text) + text, _counts['option-name'] = _SEM_OPTION_NAME.subn(_option_name_rst, text) + text, _counts['option-value'] = _SEM_OPTION_VALUE.subn(r"``\1``", text) + text, _counts['environment-var'] = _SEM_ENV_VARIABLE.subn(r"``\1``", text) text, _counts['ruler'] = _RULER.subn('\n\n.. raw:: html\n\n
\n\n', text) flog.fields(counts=_counts).info('Number of macros converted to rst equivalents')