mirror of
https://github.com/sphinx-doc/sphinx.git
synced 2025-02-25 18:55:22 -06:00
Merge pull request #8719 from tk0miya/8714_kbd_capslock
Fix #8714: html: kbd role with "Caps Lock" rendered incorrectly
This commit is contained in:
commit
a71028bf9e
1
CHANGES
1
CHANGES
@ -64,6 +64,7 @@ Bugs fixed
|
|||||||
* #8618: html: kbd role produces incorrect HTML when compound-key separators (-,
|
* #8618: html: kbd role produces incorrect HTML when compound-key separators (-,
|
||||||
+ or ^) are used as keystrokes
|
+ or ^) are used as keystrokes
|
||||||
* #8629: html: A type warning for html_use_opensearch is shown twice
|
* #8629: html: A type warning for html_use_opensearch is shown twice
|
||||||
|
* #8714: html: kbd role with "Caps Lock" rendered incorrectly
|
||||||
* #8665: html theme: Could not override globaltoc_maxdepth in theme.conf
|
* #8665: html theme: Could not override globaltoc_maxdepth in theme.conf
|
||||||
* #4304: linkcheck: Fix race condition that could lead to checking the
|
* #4304: linkcheck: Fix race condition that could lead to checking the
|
||||||
availability of the same URL twice
|
availability of the same URL twice
|
||||||
|
@ -9,7 +9,7 @@
|
|||||||
"""
|
"""
|
||||||
|
|
||||||
import re
|
import re
|
||||||
from typing import Any, Dict
|
from typing import Any, Dict, List
|
||||||
|
|
||||||
from docutils import nodes
|
from docutils import nodes
|
||||||
|
|
||||||
@ -38,18 +38,29 @@ class KeyboardTransform(SphinxPostTransform):
|
|||||||
default_priority = 400
|
default_priority = 400
|
||||||
builders = ('html',)
|
builders = ('html',)
|
||||||
pattern = re.compile(r'(?<=.)(-|\+|\^|\s+)(?=.)')
|
pattern = re.compile(r'(?<=.)(-|\+|\^|\s+)(?=.)')
|
||||||
|
multiwords_keys = (('caps', 'lock'),
|
||||||
|
('page' 'down'),
|
||||||
|
('page', 'up'),
|
||||||
|
('scroll' 'lock'),
|
||||||
|
('num', 'lock'),
|
||||||
|
('sys' 'rq'),
|
||||||
|
('back' 'space'))
|
||||||
|
|
||||||
def run(self, **kwargs: Any) -> None:
|
def run(self, **kwargs: Any) -> None:
|
||||||
matcher = NodeMatcher(nodes.literal, classes=["kbd"])
|
matcher = NodeMatcher(nodes.literal, classes=["kbd"])
|
||||||
for node in self.document.traverse(matcher): # type: nodes.literal
|
for node in self.document.traverse(matcher): # type: nodes.literal
|
||||||
parts = self.pattern.split(node[-1].astext())
|
parts = self.pattern.split(node[-1].astext())
|
||||||
if len(parts) == 1:
|
if len(parts) == 1 or self.is_multiwords_key(parts):
|
||||||
continue
|
continue
|
||||||
|
|
||||||
node['classes'].append('compound')
|
node['classes'].append('compound')
|
||||||
node.pop()
|
node.pop()
|
||||||
while parts:
|
while parts:
|
||||||
key = parts.pop(0)
|
if self.is_multiwords_key(parts):
|
||||||
|
key = ''.join(parts[:3])
|
||||||
|
parts[:3] = []
|
||||||
|
else:
|
||||||
|
key = parts.pop(0)
|
||||||
node += nodes.literal('', key, classes=["kbd"])
|
node += nodes.literal('', key, classes=["kbd"])
|
||||||
|
|
||||||
try:
|
try:
|
||||||
@ -59,6 +70,16 @@ class KeyboardTransform(SphinxPostTransform):
|
|||||||
except IndexError:
|
except IndexError:
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
def is_multiwords_key(self, parts: List[str]) -> bool:
|
||||||
|
if len(parts) >= 3 and parts[1].strip() == '':
|
||||||
|
name = parts[0].lower(), parts[2].lower()
|
||||||
|
if name in self.multiwords_keys:
|
||||||
|
return True
|
||||||
|
else:
|
||||||
|
return False
|
||||||
|
else:
|
||||||
|
return False
|
||||||
|
|
||||||
|
|
||||||
def setup(app: Sphinx) -> Dict[str, Any]:
|
def setup(app: Sphinx) -> Dict[str, Any]:
|
||||||
app.add_post_transform(KeyboardTransform)
|
app.add_post_transform(KeyboardTransform)
|
||||||
|
@ -284,6 +284,13 @@ def get_verifier(verify, verify_re):
|
|||||||
'<p><kbd class="kbd docutils literal notranslate">-</kbd></p>',
|
'<p><kbd class="kbd docutils literal notranslate">-</kbd></p>',
|
||||||
'\\sphinxkeyboard{\\sphinxupquote{\\sphinxhyphen{}}}',
|
'\\sphinxkeyboard{\\sphinxupquote{\\sphinxhyphen{}}}',
|
||||||
),
|
),
|
||||||
|
(
|
||||||
|
# kbd role
|
||||||
|
'verify',
|
||||||
|
':kbd:`Caps Lock`',
|
||||||
|
'<p><kbd class="kbd docutils literal notranslate">Caps Lock</kbd></p>',
|
||||||
|
'\\sphinxkeyboard{\\sphinxupquote{Caps Lock}}',
|
||||||
|
),
|
||||||
(
|
(
|
||||||
# non-interpolation of dashes in option role
|
# non-interpolation of dashes in option role
|
||||||
'verify_re',
|
'verify_re',
|
||||||
|
Loading…
Reference in New Issue
Block a user