summaryrefslogtreecommitdiffstats
path: root/docs/utils.py
diff options
context:
space:
mode:
Diffstat (limited to 'docs/utils.py')
-rw-r--r--docs/utils.py34
1 files changed, 30 insertions, 4 deletions
diff --git a/docs/utils.py b/docs/utils.py
index e7295798..3f58e767 100644
--- a/docs/utils.py
+++ b/docs/utils.py
@@ -5,9 +5,11 @@ import importlib.util
import inspect
import os
import subprocess
+import types
import typing
from pathlib import Path
+import docstring_parser
import docutils.nodes
import docutils.parsers.rst.states
import git
@@ -25,6 +27,18 @@ def get_build_root() -> Path:
return root
+def is_attribute(module: types.ModuleType, parameter: str) -> bool:
+ """Returns true if `parameter` is an attribute of `module`."""
+ docs = docstring_parser.parse(inspect.getdoc(module), docstring_parser.DocstringStyle.GOOGLE)
+ for param in docs.params:
+ # The docstring_parser library can mis-parse arguments like `arg (:obj:`str`)` as `arg (`
+ # which would create a false-negative below, so we just strip away the extra parenthesis.
+ if param.args[0] == "attribute" and param.arg_name.rstrip(" (") == parameter:
+ return True
+
+ return False
+
+
def linkcode_resolve(repo_link: str, domain: str, info: dict[str, str]) -> typing.Optional[str]:
"""
Function called by linkcode to get the URL for a given resource.
@@ -59,7 +73,15 @@ def linkcode_resolve(repo_link: str, domain: str, info: dict[str, str]) -> typin
symbol = [module]
for name in symbol_name.split("."):
- symbol.append(getattr(symbol[-1], name))
+ try:
+ symbol.append(getattr(symbol[-1], name))
+ except AttributeError as e:
+ # This could be caused by trying to link a class attribute
+ if is_attribute(symbol[-1], name):
+ break
+ else:
+ raise e
+
symbol_name = name
try:
@@ -138,9 +160,13 @@ def cleanup() -> None:
content = file.read_text(encoding="utf-8").splitlines(keepends=True)
# Rename the extension to be less wordy
- # Example: pydis_core.exts -> pydis_core Exts
- title = content[0].split()[0].strip().replace("pydis_core.", "").replace(".", " ").title()
- title = f"{title}\n{'=' * len(title)}\n\n"
+ # Example: pydis_core.exts -> Exts
+ title = content[0].split()[0].strip().replace("\\", "").replace("pydis_core.", "").replace(".", " ")
+ if "pydis_core" in title:
+ # Root title: pydis_core -> pydis core
+ title = title.replace("_", " ")
+
+ title = f"{title.title()}\n{'=' * len(title)}\n\n"
content = title, *content[3:]
file.write_text("".join(content), encoding="utf-8")