-
-
Notifications
You must be signed in to change notification settings - Fork 10
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
feature: Keep data-attributes of spans #41
Comments
Quick solution: AUTO_REF_RE = re.compile(
r"<span data-(?P<kind>autorefs-identifier|autorefs-optional|autorefs-optional-hover)="
r'("?)(?P<identifier>[^"<>]*)\2(?P<attrs> [^>]*)?>(?P<title>.*?)</span>',
flags=re.DOTALL,
) >>> from mkdocs_autorefs.references import AUTO_REF_RE
>>> AUTO_REF_RE.search('<span data-autorefs-identifier="hey" data-preview data-preview="0" data-preview>hello</span>').groupdict()
{'kind': 'autorefs-identifier', 'identifier': 'hey', 'attrs': ' data-preview data-preview="0" data-preview', 'title': 'hello'} The data-autorefs attribute must still appear first, and the regex now also captures everything after this first attribute and before the closing |
A bigger change that could maybe bring more robustness to future changes and features, would be to use a custom tag to delimitate auto-references, something like AUTO_REF_RE = re.compile(r"<autoref (?P<attrs>.*?)>(?P<title>.*?)</autoref>")
from html.parser import HTMLParser
class AttrsParser(HTMLParser):
def __init__(self):
super().__init__(self)
self.attrs = []
def parse(self, html):
self.attrs.clear()
self.feed(html)
return self.attrs
def handle_starttag(self, tag, attrs):
self.attrs.extend(attrs)
# for each match, build f"<a {match.group("attrs")}></a>" and pass it to the parser
AttrsParser().parse('<a data-preview data-identifier="pathlib.Path" data-other="0">some title</a>')
# [('data-preview', None), ('data-identifier', 'pathlib.Path'), ('data-other', '0')] I don't expect much impact on perfs since we'd only parse the auto-references attributes and nothing else. This change would also let us keep complex HTML inside the autoref tag (see #40). |
The regex approach sounds good to me. AUTO_REF_RE = re.compile(
r"<span data-(?P<kind>autorefs-(?:identifier|optional|optional-hover))="
r'("?)(?P<identifier>[^"<>]+)\2(?P<attrs> [^<>]+)?>(?P<title>.*?)</span>',
flags=re.DOTALL,
) To get you the rest of the way there, you can still use this |
This wouldn't be needed as we already got the kind and identifier from the regex. The rest (attrs) can just be copy-pasted into the anchor 🙂 |
Issue-#41: #41 PR-#42: #42 Co-authored-by: Oleh Prypin <[email protected]>
Is your feature request related to a problem? Please describe.
I'd like to take advantage of mkdocs-material's instant previews, by adding
data-preview
to autorefs spans generated by mkdocstrings-python. Unfortunately, autorefs matches spans with a regex, and this regex is strict and only matches spans with exactly onedata-autorefs-*
attribute.Describe the solution you'd like
I'd like autorefs to allow other data- attributes to appear in its spans, and report them to anchors when it transforms them.
Describe alternatives you've considered
/
Additional context
squidfunk/mkdocs-material#6704
The text was updated successfully, but these errors were encountered: