From 0be56b294f0abdd2376a5196ee14dbdeb504de72 Mon Sep 17 00:00:00 2001 From: Jim Garrison Date: Mon, 21 Oct 2024 03:47:38 -0400 Subject: [PATCH] Fix GitHub source code links for decorated functions (#17) * Fix GitHub source code links for decorated functions * style updates --------- Co-authored-by: Eric Arellano <14852634+Eric-Arellano@users.noreply.github.com> (cherry picked from commit c3c4ee941c8db3c9269fa4bb5b67817e0c6a205b) --- docs/conf.py | 15 +++++++++++---- 1 file changed, 11 insertions(+), 4 deletions(-) diff --git a/docs/conf.py b/docs/conf.py index ad8c91f..63960cd 100644 --- a/docs/conf.py +++ b/docs/conf.py @@ -150,17 +150,24 @@ def linkcode_resolve(domain, info): if module is None or "qiskit_addon_mpf" not in module_name: return None + def is_valid_code_object(obj): + return inspect.isclass(obj) or inspect.ismethod(obj) or inspect.isfunction(obj) + obj = module for part in info["fullname"].split("."): try: obj = getattr(obj, part) except AttributeError: return None - is_valid_code_object = ( - inspect.isclass(obj) or inspect.ismethod(obj) or inspect.isfunction(obj) - ) - if not is_valid_code_object: + if not is_valid_code_object(obj): + return None + + # Unwrap decorators. This requires they used `functools.wrap()`. + while hasattr(obj, "__wrapped__"): + obj = obj.__wrapped__ + if not is_valid_code_object(obj): return None + try: full_file_name = inspect.getsourcefile(obj) except TypeError: