From 8eb708e8b2e7ffe3daef782880140dc3ba7a75c3 Mon Sep 17 00:00:00 2001 From: James Knight Date: Sun, 6 Oct 2024 20:17:39 -0400 Subject: [PATCH] validation: adding linkcode example Adding an example of the linkcode extension into the validation set. Signed-off-by: James Knight --- tests/test_validation.py | 11 +++++ tests/validation-sets/extensions/index.rst | 1 + tests/validation-sets/extensions/linkcode.rst | 43 +++++++++++++++++++ 3 files changed, 55 insertions(+) create mode 100644 tests/validation-sets/extensions/linkcode.rst diff --git a/tests/test_validation.py b/tests/test_validation.py index 5e09d346..14e2aa98 100644 --- a/tests/test_validation.py +++ b/tests/test_validation.py @@ -35,6 +35,7 @@ def setUpClass(cls): space_key = os.getenv(SPACE_ENV_KEY, DEFAULT_TEST_SPACE) cls.config = prepare_conf() cls.config['extensions'].append('sphinx.ext.ifconfig') + cls.config['extensions'].append('sphinx.ext.linkcode') cls.config['confluence_api_token'] = os.getenv(AUTH_ENV_KEY) cls.config['confluence_full_width'] = False cls.config['confluence_page_generation_notice'] = True @@ -59,6 +60,16 @@ def setUpClass(cls): cls.test_key = os.getenv(TESTKEY_ENV_KEY, DEFAULT_TEST_KEY) cls.test_version = os.getenv(TESTKEY_ENV_VERSION, DEFAULT_TEST_VERSION) + def linkcode_resolve(domain, info): + module = info.get('module', None) + if module != 'linkcode_example': + return None + name = info.get('fullname', None) + if not name: + return None + return f'https://example.org/src/{name}' + cls.config['linkcode_resolve'] = linkcode_resolve + # overrides from user try: from validation_test_overrides import config_overrides diff --git a/tests/validation-sets/extensions/index.rst b/tests/validation-sets/extensions/index.rst index 893b603b..6d40dcce 100644 --- a/tests/validation-sets/extensions/index.rst +++ b/tests/validation-sets/extensions/index.rst @@ -11,4 +11,5 @@ found inside the internal tree. autosummary graphviz inheritance_diagram + linkcode todo diff --git a/tests/validation-sets/extensions/linkcode.rst b/tests/validation-sets/extensions/linkcode.rst new file mode 100644 index 00000000..db9c414f --- /dev/null +++ b/tests/validation-sets/extensions/linkcode.rst @@ -0,0 +1,43 @@ +sphinx.ext.linkcode +=================== + +.. hint:: + + This requires registering the ``sphinx.ext.linkcode`` extension in the + documentation's configuration file. + +This page shows an example of the linkcode_ extension's capabilities. A +project configuration defines a ``linkcode_resolve`` function: + +.. code-block:: python + + def linkcode_resolve(domain, info): + name = info.get('fullname', None) + if not name: + return None + return "https://example.org/src/%s" % name + +When documents include object descriptions such as the following, source +links should be included: + +.. code-block:: none + + .. class:: ExampleModule + + This is an example. + +Output +------ + +The following shows an example of linkcode: + +.. module:: linkcode_example + +.. class:: ExampleModule + + This is an example. + + +.. references ------------------------------------------------------------------ + +.. _linkcode: https://www.sphinx-doc.org/en/master/usage/extensions/linkcode.html