File tree Expand file tree Collapse file tree 1 file changed +12
-2
lines changed Expand file tree Collapse file tree 1 file changed +12
-2
lines changed Original file line number Diff line number Diff line change 5151
5252 {#- CANONICAL URL (deprecated) #}
5353 {%- if theme_canonical_url and not pageurl %}
54- < link rel ="canonical " href ="{{ theme_canonical_url }}{{ pagename }}.html "/>
54+ < link rel ="canonical " href ="{{ theme_canonical_url }}{{ pagename }}{% if builder == 'dirhtml' %}/{% else %} .html{% endif %} "/>
5555 {%- endif -%}
5656
5757 {#- CANONICAL URL #}
58+ {# NB! pageurl is currently a non-documented template context variable! #}
59+ {# pageurl implementation: https://www.sphinx-doc.org/en/master/_modules/sphinx/builders/html.html #}
5860 {%- if pageurl %}
59- < link rel ="canonical " href ="{{ pageurl|e }} " />
61+ {# pageurl implementation wrongly: adds .html for the dirhtml builder's pageurl #}
62+ {# Workaround for: https://github.com/sphinx-doc/sphinx/issues/9730 #}
63+ {# Once a fix is released in Sphinx, put an upper bound on the Sphinx version for the workaround #}
64+ {% if builder == 'dirhtml' and pageurl.endswith('.html') %}
65+ {# This expression trims away .html and adds a / #}
66+ < link rel ="canonical " href ="{{ (pageurl|e)[:-5] }}/ " />
67+ {% else %}
68+ < link rel ="canonical " href ="{{ pageurl|e }} " />
69+ {% endif %}
6070 {%- endif -%}
6171
6272 {#- JAVASCRIPTS #}
You can’t perform that action at this time.
0 commit comments