Script 'mail_helper' called by obssrc
Hello community,

here is the log from the commit of package python-python-docs-theme for 
openSUSE:Factory checked in at 2022-01-22 08:17:53
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Comparing /work/SRC/openSUSE:Factory/python-python-docs-theme (Old)
 and      /work/SRC/openSUSE:Factory/.python-python-docs-theme.new.1938 (New)
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

Package is "python-python-docs-theme"

Sat Jan 22 08:17:53 2022 rev:3 rq:947585 version:2022.1

Changes:
--------
--- 
/work/SRC/openSUSE:Factory/python-python-docs-theme/python-python-docs-theme.changes
        2020-03-23 12:50:42.071961716 +0100
+++ 
/work/SRC/openSUSE:Factory/.python-python-docs-theme.new.1938/python-python-docs-theme.changes
      2022-01-22 08:18:04.562947469 +0100
@@ -1,0 +2,24 @@
+Wed Jan 19 23:41:38 UTC 2022 - Matej Cepl <mc...@suse.com>
+
+- Update to 2022.1:
+  - Add a configuration for license URL.
+  - Exclude the floating navbar from CHM help.
+  - Make sidebar scrollable and sticky (on modern browsers)
+  - Fix monospace again, on buggy Google Chrome
+  - Add the copyright_url variable in the theme
+  - Improve readability
+  - Remove #searchbox on mobile to fix a layout bug
+  - Fix the appearance of version/language selects
+  - Make the theme responsive
+  - Use default pygments theme
+  - Test Github action to validate the theme against docsbuild scripts.
+  - Add the copy button to pycon3 highlighted code blocks.
+  - Updated the readme, to remind user to install the package in a virtual 
environment.
+  - Updated the package url, using the GitHub repository instead of 
docs.python.org
+  - Added license information to the footer of the doc
+  - Fixed typo in the footer
+  - Added information on how to use the package
+  - Fixed code formatting
+  - Fixed code bgcolor and codetextcolor for Sphinx 3.1.0+
+
+-------------------------------------------------------------------

Old:
----
  python-docs-theme-2020.1.tar.gz

New:
----
  python-docs-theme-2022.1.tar.gz

++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

Other differences:
------------------
++++++ python-python-docs-theme.spec ++++++
--- /var/tmp/diff_new_pack.BukbJ7/_old  2022-01-22 08:18:05.070944046 +0100
+++ /var/tmp/diff_new_pack.BukbJ7/_new  2022-01-22 08:18:05.078943992 +0100
@@ -1,7 +1,7 @@
 #
 # spec file for package python-python-docs-theme
 #
-# Copyright (c) 2020 SUSE LLC
+# Copyright (c) 2022 SUSE LLC
 #
 # All modifications and additions to the file contributed by third parties
 # remain the property of their copyright owners, unless otherwise agreed
@@ -18,14 +18,16 @@
 
 %{?!python_module:%define python_module() python-%{**} python3-%{**}}
 Name:           python-python-docs-theme
-Version:        2020.1
+Version:        2022.1
 Release:        0
 Summary:        The Sphinx theme for the CPython docs and related projects
 License:        Python-2.0
 Group:          Development/Languages/Python
 URL:            https://docs.python.org
 Source:         
https://files.pythonhosted.org/packages/source/p/python-docs-theme/python-docs-theme-%{version}.tar.gz
+BuildRequires:  %{python_module pip}
 BuildRequires:  %{python_module setuptools}
+BuildRequires:  %{python_module wheel}
 BuildRequires:  fdupes
 BuildRequires:  python-rpm-macros
 BuildArch:      noarch
@@ -38,10 +40,10 @@
 %setup -q -n python-docs-theme-%{version}
 
 %build
-%python_build
+%pyproject_wheel
 
 %install
-%python_install
+%pyproject_install
 %python_expand %fdupes %{buildroot}%{$python_sitelib}
 
 %files %{python_files}

++++++ python-docs-theme-2020.1.tar.gz -> python-docs-theme-2022.1.tar.gz ++++++
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' 
'--exclude=.svnignore' old/python-docs-theme-2020.1/PKG-INFO 
new/python-docs-theme-2022.1/PKG-INFO
--- old/python-docs-theme-2020.1/PKG-INFO       2020-01-14 21:04:23.000000000 
+0100
+++ new/python-docs-theme-2022.1/PKG-INFO       2022-01-11 10:45:51.167946600 
+0100
@@ -1,27 +1,11 @@
-Metadata-Version: 1.1
+Metadata-Version: 2.1
 Name: python-docs-theme
-Version: 2020.1
+Version: 2022.1
 Summary: The Sphinx theme for the CPython docs and related projects
-Home-page: https://docs.python.org
+Home-page: https://github.com/python/python-docs-theme/
 Author: PyPA
 Author-email: distutils-...@python.org
 License: UNKNOWN
-Description: Python Docs Sphinx Theme
-        =========================
-        
-        This is the theme for the Python documentation.
-        
-        Note that when adopting this theme, you're also borrowing an element 
of the
-        trust and credibility established by the CPython core developers over 
the
-        years. That's fine, and you're welcome to do so for other Python 
community
-        projects if you so choose, but please keep in mind that in doing so 
you're also
-        choosing to accept some of the responsibility for maintaining that 
collective
-        trust.
-        
-        To use the theme, install it into your docs build environment via 
``pip``::
-        
-            pip install python-docs-theme
-        
 Platform: UNKNOWN
 Classifier: Intended Audience :: Developers
 Classifier: License :: OSI Approved :: Python Software Foundation License
@@ -30,3 +14,31 @@
 Classifier: Topic :: Software Development :: Documentation
 Classifier: Programming Language :: Python
 Classifier: Programming Language :: Python :: 3
+License-File: LICENSE
+
+Python Docs Sphinx Theme
+=========================
+
+This is the theme for the Python documentation.
+
+Note that when adopting this theme, you're also borrowing an element of the
+trust and credibility established by the CPython core developers over the
+years. That's fine, and you're welcome to do so for other Python community
+projects if you so choose, but please keep in mind that in doing so you're also
+choosing to accept some of the responsibility for maintaining that collective
+trust.
+
+To use the theme, install it into your docs build environment via ``pip`` 
+(preferably in a virtual environment).
+
+
+Configuration options
+---------------------
+
+To use this theme, add the following to ``conf.py``:
+
+- ``html_theme = 'python_docs_theme'``
+
+- ``html_sidebars``, defaults taken from 
http://www.sphinx-doc.org/en/stable/config.html#confval-html_sidebars
+
+
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' 
'--exclude=.svnignore' old/python-docs-theme-2020.1/README.rst 
new/python-docs-theme-2022.1/README.rst
--- old/python-docs-theme-2020.1/README.rst     2018-06-05 04:32:29.000000000 
+0200
+++ new/python-docs-theme-2022.1/README.rst     2021-04-12 17:38:41.000000000 
+0200
@@ -10,6 +10,15 @@
 choosing to accept some of the responsibility for maintaining that collective
 trust.
 
-To use the theme, install it into your docs build environment via ``pip``::
+To use the theme, install it into your docs build environment via ``pip`` 
+(preferably in a virtual environment).
 
-    pip install python-docs-theme
+
+Configuration options
+---------------------
+
+To use this theme, add the following to ``conf.py``:
+
+- ``html_theme = 'python_docs_theme'``
+
+- ``html_sidebars``, defaults taken from 
http://www.sphinx-doc.org/en/stable/config.html#confval-html_sidebars
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' 
'--exclude=.svnignore' old/python-docs-theme-2020.1/pyproject.toml 
new/python-docs-theme-2022.1/pyproject.toml
--- old/python-docs-theme-2020.1/pyproject.toml 1970-01-01 01:00:00.000000000 
+0100
+++ new/python-docs-theme-2022.1/pyproject.toml 2021-05-10 09:47:02.000000000 
+0200
@@ -0,0 +1,7 @@
+[build-system]
+requires = [
+    "setuptools>=42",
+    "wheel"
+]
+build-backend = "setuptools.build_meta"
+
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' 
'--exclude=.svnignore' 
old/python-docs-theme-2020.1/python_docs_theme/layout.html 
new/python-docs-theme-2022.1/python_docs_theme/layout.html
--- old/python-docs-theme-2020.1/python_docs_theme/layout.html  2020-01-14 
20:54:13.000000000 +0100
+++ new/python-docs-theme-2022.1/python_docs_theme/layout.html  2022-01-11 
10:28:52.000000000 +0100
@@ -1,58 +1,141 @@
 {% extends "classic/layout.html" %}
 
-{% block rootrellink %}
-    <li><img src="{{ pathto('_static/' + theme_root_icon, 1) }}" alt=""
-             style="vertical-align: middle; margin-top: -1px"/></li>
-    <li><a href="{{theme_root_url}}">{{theme_root_name}}</a>{{ reldelim1 
}}</li>
-    {% if theme_root_include_title %}
-    <a href="{{ pathto('index') }}">{{ shorttitle }}</a>{{ reldelim1 }}
-    {% endif %}
-{% endblock %}
+{%- macro relbar() %}
+{# modified from sphinx/themes/basic/layout.html #}
+    <div class="related" role="navigation" aria-label="related navigation">
+      <h3>{{ _('Navigation') }}</h3>
+      <ul>
+          {%- for rellink in rellinks %}
+          <li class="right" {% if loop.first %}style="margin-right: 10px"{% 
endif %}>
+              <a href="{{ pathto(rellink[0])|e }}" title="{{ 
rellink[1]|striptags|e }}"
+                 {{ accesskey(rellink[2]) }}>{{ rellink[3] }}
+              </a>
+              {%- if not loop.first %}{{ reldelim2 }}{% endif %}
+          </li>
+          {%- endfor %}
+          {%- block rootrellink %}
+          <li><img src="{{ pathto('_static/py.svg', 1) }}" alt="python logo" 
style="vertical-align: middle; margin-top: -1px"/></li>
+          <li><a href="{{theme_root_url}}">{{theme_root_name}}</a>{{ reldelim1 
}}</li>
+          <li class="switchers">
+            <div class="language_switcher_placeholder"></div>
+            <div class="version_switcher_placeholder"></div>
+          </li>
+          <li>
+              {% if theme_root_include_title %}
+              <a href="{{ pathto('index') }}">{{ shorttitle }}</a>{{ reldelim1 
}}
+              {% endif %}
+          </li>
+          {%- endblock %}
+            {%- for parent in parents %}
+                <li class="nav-item nav-item-{{ loop.index }}"><a href="{{ 
parent.link|e }}" {% if loop.last %}{{ accesskey("U") }}{% endif %}>{{ 
parent.title }}</a>{{ reldelim1 }}</li>
+                {%- endfor %}
+                <li class="nav-item nav-item-this"><a href="{{ link|e }}">{{ 
title }}</a></li>
+            {% block relbaritems %}
+            {%- if pagename != "search" and builder != "singlehtml" and 
builder != "htmlhelp" %}
+                <li class="right">
+                    {{ searchbox() }}
+                    {{ reldelim2 }}
+                </li>
+            {%- endif %}
+            {% endblock %}
+      </ul>
+    </div>
+{%- endmacro %}
 
 {%- macro searchbox() %}
 {# modified from sphinx/themes/basic/searchbox.html #}
     {%- if builder != "htmlhelp" %}
-    <div class="inline-search" style="display: none" role="search">
+    <div class="inline-search" role="search">
         <form class="inline-search" action="{{ pathto('search') }}" 
method="get">
-          <input placeholder="{{ _('Quick search') }}" type="text" name="q" />
+          <input placeholder="{{ _('Quick search') }}" aria-label="{{ _('Quick 
search') }}" type="text" name="q" />
           <input type="submit" value="{{ _('Go') }}" />
           <input type="hidden" name="check_keywords" value="yes" />
           <input type="hidden" name="area" value="default" />
         </form>
     </div>
-    <script type="text/javascript">$('.inline-search').show(0);</script>
     {%- endif %}
 {%- endmacro %}
 
 {% block relbar1 %} {% if builder != 'qthelp' %} {{ relbar() }} {% endif %} {% 
endblock %}
 {% block relbar2 %} {% if builder != 'qthelp' %} {{ relbar() }} {% endif %} {% 
endblock %}
-{% block relbaritems %}
-    {%- if pagename != "search" and builder != "singlehtml" and builder != 
"htmlhelp" %}
-    <li class="right">
-        {{ searchbox() }}
-        {{ reldelim2 }}
-    </li>
-    {%- endif %}
-{% endblock %}
 
-{% block extrahead %}
+
+{%- block extrahead -%}
     <link rel="shortcut icon" type="image/png" href="{{ pathto('_static/' + 
theme_root_icon, 1) }}" />
-    {% if builder != "htmlhelp" %}
-    {% if not embedded %}<script type="text/javascript" src="{{ 
pathto('_static/copybutton.js', 1) }}"></script>{% endif %}
-    {% endif %}
+    {%- if builder != "htmlhelp" %}
+        {%- if not embedded %}
+            <script type="text/javascript" src="{{ 
pathto('_static/copybutton.js', 1) }}"></script>
+            <script type="text/javascript" src="{{ pathto('_static/menu.js', 
1) }}"></script>
+        {%- endif -%}
+    {%- endif -%}
     {{ super() }}
+{%- endblock -%}
+
+{%- block css -%}
+    <meta name="viewport" content="width=device-width, initial-scale=1.0">
+    {{ super() }}
+{%- endblock -%}
+
+{%- block body_tag %}
+{{ super() }}
+{%- if builder != 'htmlhelp' %}
+<div class="mobile-nav">
+    <input type="checkbox" id="menuToggler" class="toggler__input" 
aria-controls="navigation"
+           aria-pressed="false" aria-expanded="false" role="button" 
aria-label="{{ _('Menu')}}" />
+    <label for="menuToggler" class="toggler__label">
+        <span></span>
+    </label>
+    <nav class="nav-content" role="navigation">
+         <a href="{{ theme_root_url }}" class="nav-logo">
+             <img src="{{ pathto('_static/py.svg', 1) }}" alt="Logo"/>
+         </a>
+        <div class="version_switcher_placeholder"></div>
+        {%- if pagename != "search" and builder != "singlehtml" %}
+        <form role="search" class="search" action="{{ pathto('search') }}" 
method="get">
+            <svg xmlns="http://www.w3.org/2000/svg"; width="20" height="20" 
viewBox="0 0 24 24" class="search-icon">
+                <path fill-rule="nonzero"
+                        d="M15.5 14h-.79l-.28-.27a6.5 6.5 0 
001.48-5.34c-.47-2.78-2.79-5-5.59-5.34a6.505 6.505 0 00-7.27 7.27c.34 2.8 2.56 
5.12 5.34 5.59a6.5 6.5 0 005.34-1.48l.27.28v.79l4.25 4.25c.41.41 1.08.41 1.49 0 
.41-.41.41-1.08 0-1.49L15.5 14zm-6 0C7.01 14 5 11.99 5 9.5S7.01 5 9.5 5 14 7.01 
14 9.5 11.99 14 9.5 14z" fill="#444"></path>
+            </svg>
+            <input type="text" name="q" aria-label="{{ _('Quick search') }}"/>
+            <input type="submit" value="{{ _('Go') }}"/>
+        </form>
+        {%- endif %}
+    </nav>
+    <div class="menu-wrapper">
+        <nav class="menu" role="navigation" aria-label="main navigation">
+            <div class="language_switcher_placeholder"></div>
+            {%- if logo %}
+            <p class="logo">
+                <a href="{{ pathto('index') }}">
+                <img class="logo" src="{{ pathto('_static/' + logo, 1)|e }}" 
alt="Logo"/>
+                </a>
+            </p>
+            {%- endif %}
+            {%- for sidebartemplate in sidebars %}
+            {%- include sidebartemplate %}
+            {%- endfor %}
+        </nav>
+    </div>
+</div>
+{% endif -%}
 {% endblock %}
 
 {% block footer %}
     <div class="footer">
-    &copy; <a href="{{ pathto('copyright') }}">{% trans %}Copyright{% endtrans 
%}</a> {{ copyright|e }}.
+    &copy; {% if theme_copyright_url or hasdoc('copyright') %}<a href="{% if 
theme_copyright_url %}{{ theme_copyright_url }}{% else %}{{ pathto('copyright') 
}}{% endif %}">{% endif %}{% trans %}Copyright{% endtrans %}{% if 
theme_copyright_url or hasdoc('copyright') %}</a>{% endif %} {{ copyright|e }}.
+    <br />
+    {% trans %}This page is licensed under the Python Software Foundation 
License Version 2.{% endtrans %}
+    <br />
+    {% trans %}Examples, recipes, and other code in the documentation are 
additionally licensed under the Zero Clause BSD License.{% endtrans %}
+    <br />
+    {% if theme_license_url %}{% trans license_file=theme_license_url %}See <a 
href="{{ license_file }}">History and License</a> for more information.{% 
endtrans %}<br />{% endif %}
     <br />
 
     {% include "footerdonate.html" %}
     <br />
 
     {% trans last_updated=last_updated|e %}Last updated on {{ last_updated 
}}.{% endtrans %}
-    {% if theme_issues_url %}{% trans pathto_bugs=theme_issues_url %}<a 
href="{{ theme_issues_url }}">Found a bug</a>?{% endtrans %}{% endif %}
+    {% if theme_issues_url %}{% trans %}<a href="{{ theme_issues_url }}">Found 
a bug</a>?{% endtrans %}{% endif %}
     <br />
 
     {% trans sphinx_version=sphinx_version|e %}Created using <a 
href="https://www.sphinx-doc.org/";>Sphinx</a> {{ sphinx_version }}.{% endtrans 
%}
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' 
'--exclude=.svnignore' 
old/python-docs-theme-2020.1/python_docs_theme/static/caret-down.svg 
new/python-docs-theme-2022.1/python_docs_theme/static/caret-down.svg
--- old/python-docs-theme-2020.1/python_docs_theme/static/caret-down.svg        
1970-01-01 01:00:00.000000000 +0100
+++ new/python-docs-theme-2022.1/python_docs_theme/static/caret-down.svg        
2021-05-10 09:47:02.000000000 +0200
@@ -0,0 +1 @@
+<svg viewBox="0 0 30 30" xmlns="http://www.w3.org/2000/svg";><path d="M7.45896 
11.25H22.5351c1.043 0 1.5645 1.2598.8262 1.998l-7.5352 
7.5411c-.457.457-1.2011.457-1.6582 0L6.63279 
13.248c-.73828-.7382-.2168-1.998.82617-1.998z" fill="#444"/></svg>
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' 
'--exclude=.svnignore' 
old/python-docs-theme-2020.1/python_docs_theme/static/copybutton.js 
new/python-docs-theme-2022.1/python_docs_theme/static/copybutton.js
--- old/python-docs-theme-2020.1/python_docs_theme/static/copybutton.js 
2020-01-14 20:54:13.000000000 +0100
+++ new/python-docs-theme-2022.1/python_docs_theme/static/copybutton.js 
2021-04-12 17:38:45.000000000 +0200
@@ -5,6 +5,7 @@
     var div = $('.highlight-python .highlight,' +
                 '.highlight-python3 .highlight,' +
                 '.highlight-pycon .highlight,' +
+                '.highlight-pycon3 .highlight,' +
                 '.highlight-default .highlight');
     var pre = div.find('pre');
 
@@ -61,4 +62,3 @@
         }
     });
 });
-
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' 
'--exclude=.svnignore' 
old/python-docs-theme-2020.1/python_docs_theme/static/menu.js 
new/python-docs-theme-2022.1/python_docs_theme/static/menu.js
--- old/python-docs-theme-2020.1/python_docs_theme/static/menu.js       
1970-01-01 01:00:00.000000000 +0100
+++ new/python-docs-theme-2022.1/python_docs_theme/static/menu.js       
2021-05-10 09:47:02.000000000 +0200
@@ -0,0 +1,55 @@
+document.addEventListener('DOMContentLoaded', function () {
+
+    // Make tables responsive by wrapping them in a div and making them 
scrollable
+    const tables = document.querySelectorAll('table.docutils');
+    tables.forEach(function(table){
+        table.outerHTML = '<div class="responsive-table__container">' + 
table.outerHTML + '</div>'
+    });
+
+    const togglerInput = document.querySelector('.toggler__input');
+    const togglerLabel = document.querySelector('.toggler__label');
+    const sideMenu = document.querySelector('.menu-wrapper');
+    const menuItems = document.querySelectorAll('.menu')
+    const doc = document.querySelector('.document');
+    const body = document.querySelector('body');
+
+    function closeMenu() {
+        togglerInput.checked = false;
+        sideMenu.setAttribute("aria-expanded", 'false');
+        sideMenu.setAttribute('aria-hidden', 'true');
+        togglerLabel.setAttribute('aria-pressed', 'false');
+        body.style.overflow = 'visible';
+    }
+    function openMenu() {
+        togglerInput.checked = true;
+        sideMenu.setAttribute("aria-expanded", 'true');
+        sideMenu.setAttribute('aria-hidden', 'false');
+        togglerLabel.setAttribute('aria-pressed', 'true');
+        body.style.overflow = 'hidden';
+    }
+
+    // Close menu when link on the sideMenu is clicked
+    sideMenu.addEventListener('click', function (event) {
+        let target = event.target;
+        if (target.tagName.toLowerCase() !== 'a') return;
+        closeMenu();
+    })
+    // Add accessibility data when sideMenu is opened/closed
+    togglerInput.addEventListener('change', function (e) {
+        togglerInput.checked ? openMenu() : closeMenu();
+    });
+    // Make sideMenu links tabbable only when visible
+    for(let menuItem of menuItems) {
+        if(togglerInput.checked) {
+          menuItem.setAttribute('tabindex', '0');
+        } else {
+          menuItem.setAttribute('tabindex', '-1');
+        }
+    }
+    // Close sideMenu when document body is clicked
+    doc.addEventListener('click', function () {
+        if (togglerInput.checked) {
+            closeMenu();
+        }
+    })
+})
\ No newline at end of file
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' 
'--exclude=.svnignore' 
old/python-docs-theme-2020.1/python_docs_theme/static/py.svg 
new/python-docs-theme-2022.1/python_docs_theme/static/py.svg
--- old/python-docs-theme-2020.1/python_docs_theme/static/py.svg        
1970-01-01 01:00:00.000000000 +0100
+++ new/python-docs-theme-2022.1/python_docs_theme/static/py.svg        
2021-05-10 09:47:02.000000000 +0200
@@ -0,0 +1,14 @@
+<svg width="16" height="16" viewBox="0 0 16 16" fill="none" 
xmlns="http://www.w3.org/2000/svg";>
+<path d="M7.90472 0.00013087C7.24498 0.00316295 6.61493 0.0588153 6.06056 
0.15584C4.42744 0.441207 4.13093 1.0385 4.13093 
2.14002V3.59479H7.99018V4.07971H4.13093H2.68259C1.56098 4.07971 0.578874 4.7465 
0.271682 6.01495C-0.0826595 7.4689 -0.0983765 8.37618 0.271682 9.89434C0.546011 
11.0244 1.20115 11.8296 2.32275 11.8296H3.64965V10.0856C3.64965 8.82574 4.75178 
7.71441 6.06056 7.71441H9.91531C10.9883 7.71441 11.8449 6.84056 11.8449 
5.77472V2.14002C11.8449 1.10556 10.9626 0.328486 9.91531 0.15584C9.25235 
0.046687 8.56447 -0.00290121 7.90472 0.00013087ZM5.81767 1.17017C6.2163 1.17017 
6.54184 1.49742 6.54184 1.89978C6.54184 2.30072 6.2163 2.62494 5.81767 
2.62494C5.41761 2.62494 5.0935 2.30072 5.0935 1.89978C5.0935 1.49742 5.41761 
1.17017 5.81767 1.17017Z" fill="url(#paint0_linear)"/>
+<path d="M12.3262 4.07971V5.77472C12.3262 7.08883 11.1998 8.19488 9.9153 
8.19488H6.06055C5.00466 8.19488 4.13092 9.0887 4.13092 10.1346V13.7693C4.13092 
14.8037 5.04038 15.4122 6.06055 15.709C7.28217 16.0642 8.45364 16.1285 9.9153 
15.709C10.8869 15.4307 11.8449 14.8708 11.8449 
13.7693V12.3145H7.99017V11.8296H11.8449H13.7746C14.8962 11.8296 15.3141 11.0558 
15.7042 9.89434C16.1071 8.69865 16.09 7.5488 15.7042 6.01495C15.427 4.91058 
14.8976 4.07971 13.7746 4.07971H12.3262ZM10.1582 13.2843C10.5583 13.2843 
10.8824 13.6086 10.8824 14.0095C10.8824 14.4119 10.5583 14.7391 10.1582 
14.7391C9.75955 14.7391 9.43402 14.4119 9.43402 14.0095C9.43402 13.6086 9.75955 
13.2843 10.1582 13.2843Z" fill="url(#paint1_linear)"/>
+<defs>
+<linearGradient id="paint0_linear" x1="1.25961e-08" y1="1.08223e-08" 
x2="8.81664" y2="7.59597" gradientUnits="userSpaceOnUse">
+<stop stop-color="#5A9FD4"/>
+<stop offset="1" stop-color="#306998"/>
+</linearGradient>
+<linearGradient id="paint1_linear" x1="10.0654" y1="13.8872" x2="6.91912" 
y2="9.42957" gradientUnits="userSpaceOnUse">
+<stop stop-color="#FFD43B"/>
+<stop offset="1" stop-color="#FFE873"/>
+</linearGradient>
+</defs>
+</svg>
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' 
'--exclude=.svnignore' 
old/python-docs-theme-2020.1/python_docs_theme/static/pydoctheme.css 
new/python-docs-theme-2022.1/python_docs_theme/static/pydoctheme.css
--- old/python-docs-theme-2020.1/python_docs_theme/static/pydoctheme.css        
2020-01-14 20:54:13.000000000 +0100
+++ new/python-docs-theme-2022.1/python_docs_theme/static/pydoctheme.css        
2022-01-11 10:28:52.000000000 +0100
@@ -6,10 +6,15 @@
     margin-right: 1em;
 }
 
+.mobile-nav,
+.menu-wrapper {
+    display: none;
+}
+
 div.related {
     margin-bottom: 1.2em;
     padding: 0.5em 0;
-    border-top: 1px solid #ccc;
+    border-bottom: 1px solid #ccc;
     margin-top: 0.5em;
 }
 
@@ -17,9 +22,23 @@
     color: #0095C4;
 }
 
-div.related:first-child {
-    border-top: 0;
-    border-bottom: 1px solid #ccc;
+div.related ~ div.related {
+    border-top: 1px solid #ccc;
+    border-bottom: none;
+}
+
+.related .switchers {
+    display: inline-flex;
+}
+
+.switchers > div {
+    margin-right: 5px;
+}
+
+.version_switcher_placeholder,
+.language_switcher_placeholder {
+    padding-left: 5px;
+    background-color: white;
 }
 
 .inline-search {
@@ -32,7 +51,15 @@
     width: 40px;
 }
 
+div.document {
+    display: flex;
+}
+
 div.sphinxsidebar {
+    float: none;
+    position: sticky;
+    top: 0;
+    max-height: 100vh;
     background-color: #eeeeee;
     border-radius: 5px;
     line-height: 130%;
@@ -43,6 +70,13 @@
     margin-top: 1.5em;
 }
 
+div.sphinxsidebarwrapper {
+    box-sizing: border-box;
+    height: 100%;
+    overflow-x: hidden;
+    overflow-y: auto;
+}
+
 div.sphinxsidebarwrapper > h3:first-child {
     margin-top: 0.2em;
 }
@@ -71,10 +105,10 @@
     padding: 0 0 0 1.2em;
 }
 
-div.body p {
-    line-height: 140%;
+div.body p, div.body dd, div.body li, div.body blockquote {
+    text-align: left;
+    line-height: 1.4;
 }
-
 div.body h1, div.body h2, div.body h3, div.body h4, div.body h5, div.body h6 {
     margin: 0;
     border: 0;
@@ -117,7 +151,7 @@
 }
 
 tt, code, pre {
-    font-family: monospace, sans-serif;
+    font-family: "monospace", monospace;
     font-size: 96.5%;
 }
 
@@ -189,5 +223,302 @@
 }
 
 dl > dt span ~ em {
-    font-family: monospace, sans-serif;
+    font-family: "monospace", monospace;
+}
+
+.toctree-wrapper ul {
+    padding-left: 20px;
+}
+
+@media (max-width: 1023px) {
+    /* Body layout */
+    div.body {
+        min-width: 100%;
+        padding: 0;
+        font-size: 0.875rem;
+    }
+    div.bodywrapper {
+        margin: 0;
+    }
+    /* Typography */
+    div.body h1 {
+        font-size: 1.625rem;
+    }
+    div.body h2 {
+        font-size: 1.25rem;
+    }
+    div.body h3, div.body h4, div.body h5 {
+        font-size: 1rem;
+    }
+    /* Override default styles to make more readable */
+    div.body ul {
+        padding-inline-start: 1rem;
+    }
+    div.body blockquote {
+        margin-inline-start: 1rem;
+        margin-inline-end: 0;
+    }
+    /* Remove sidebar and top related bar */
+    div.related, .sphinxsidebar {
+        display: none;
+    }
+    /* Anchorlinks are not hidden by fixed-positioned navbar when scrolled to 
*/
+    html {
+        scroll-padding-top: 40px;
+    }
+
+    /* Top navigation bar */
+    .mobile-nav {
+        display: block;
+        height: 40px;
+        width: 100%;
+        position: fixed;
+        top: 0;
+        left: 0;
+        background-color: white;
+        box-shadow: rgba(0, 0, 0, 0.25) 0 0 2px 0;
+        z-index: 1;
+    }
+    .mobile-nav * {
+        box-sizing: border-box;
+    }
+    .nav-content {
+        position: absolute;
+        z-index: 2;
+        left: 0;
+        top: 0;
+        height: 40px;
+        width: 100%;
+        max-width: 100vw;
+        padding: 0 1rem 0 45px;
+        display: flex;
+        align-items: center;
+        background-color: white;
+    }
+    .nav-logo {
+        margin-right: 0.7rem;
+        display: flex;
+        flex: 0 0 auto;
+    }
+    .nav-content img {
+        width: 20px;
+        height: auto;
+    }
+    .version_switcher_placeholder {
+        flex: 0 1 0;
+        margin-right: 1rem;
+    }
+    .nav-content .search {
+        display: flex;
+        flex: 1 1 auto;
+        align-items: center;
+        padding: 0 0 0 2px;
+        border: 1px solid #a9a9a9;
+        height: 30px;
+        overflow: hidden;
+    }
+    .nav-content .search:hover {
+        box-shadow: 0 1px 6px 0 rgba(32,33,36,0.28);
+        border-color: rgba(223,225,229,0);
+    }
+    .nav-content .search input[type=text] {
+        border: 0;
+        outline: 0;
+        box-shadow: none;
+        width: 40px;
+        height: 28px;
+        flex: 1 1 auto;
+    }
+    .nav-content .search input[type=submit] {
+        height: 100%;
+        appearance: none;
+        -webkit-appearance: none;
+        border: 1px solid transparent;
+        border-left-color: #a9a9a9;
+        box-shadow: none;
+        cursor: pointer;
+        background-color: #f0f0f0;
+        margin-right: 0;
+    }
+    .nav-content .search input[type=submit]:hover {
+        border-color: #a9a9a9;
+    }
+    .nav-content .search svg {
+        flex: 0 0 20px;
+        fill: #333;
+    }
+    .toggler__input {
+        width: 40px;
+        height: 40px;
+        left: 0;
+        opacity: 0;
+        position: absolute;
+        z-index: 3;
+        margin: 0;
+    }
+    .toggler__label {
+        width: 40px;
+        height: 40px;
+        margin: 0;
+        position: absolute;
+        cursor: pointer;
+        top: 0;
+        left: 0;
+        background-color: transparent;
+        border: 1px solid white;
+        box-shadow: none;
+        z-index: 3;
+        display: flex;
+        align-items: center;
+        justify-content: center;
+        padding: 0 8px;
+    }
+    .toggler__label:focus {
+        background-color: #eee;
+        border: 1px solid #ededed;
+        box-shadow: rgba(0, 0, 0, 0.25) 1px 0 2px 0;
+    }
+    .toggler__label:hover {
+        background-color: #eee;
+        border: 1px solid #ededed;
+        box-shadow: rgba(0, 0, 0, 0.25) 1px 0 2px 0;
+    }
+    .toggler__label > span {
+        position: relative;
+        flex: none;
+        height: 2px;
+        width: 100%;
+        background: #444;
+        transition: all 400ms ease;
+    }
+    .toggler__label > span::before,
+    .toggler__label > span::after {
+        content: '';
+        height: 2px;
+        width: 100%;
+        background: inherit;
+        position: absolute;
+        left: 0;
+        top: -8px;
+    }
+    .toggler__label > span::after {
+        top: 8px;
+    }
+    .toggler__input:checked ~ .toggler__label span {
+        transform: rotate(135deg);
+    }
+    .toggler__input:checked ~ .toggler__label span::before {
+        transform: rotate(90deg);
+    }
+    .toggler__input:checked ~ .toggler__label span::before,
+    .toggler__input:checked ~ .toggler__label span::after {
+        top: 0;
+    }
+    .toggler__input:checked:hover ~ .toggler__label span {
+        transform: rotate(315deg);
+    }
+    .toggler__input:checked ~ .menu-wrapper {
+        visibility: visible;
+        left: 0;
+    }
+
+    /* Sliding side menu */
+    .menu-wrapper {
+        display: block;
+        position: fixed;
+        top: 0;
+        transition: left 400ms ease;
+        left: -310px;
+        width: 300px;
+        height: 100%;
+        background-color: #eee;
+        box-shadow: 0 0 10px rgba(0, 0, 0, 0.2);
+        overflow-y: auto;
+    }
+    .menu-wrapper.open {
+        visibility: visible;
+        left: 0;
+    }
+    .menu {
+        padding: 40px 10px 30px 20px;
+    }
+    .menu-wrapper h3,
+    .menu-wrapper h4 {
+        margin-bottom: 0;
+        font-weight: normal;
+    }
+    .menu-wrapper h4 {
+        font-size: 1.3em;
+    }
+    .menu-wrapper h3 {
+        color: #444444;
+        font-size: 1.4em;
+    }
+    .menu-wrapper h3 + p,
+    .menu-wrapper h4 + p {
+        margin-top: 0.5rem;
+    }
+    .menu a {
+        font-size: smaller;
+        color: #444444;
+        text-decoration: none;
+    }
+    .menu ul {
+        list-style: none;
+        line-height: 1.4;
+        overflow-wrap: break-word;
+        padding-left: 0;
+    }
+    .menu ul ul {
+        margin-left: 20px;
+        list-style: square;
+    }
+    .menu ul li {
+        margin-bottom: 0.5rem;
+    }
+    .language_switcher_placeholder,
+    .version_switcher_placeholder {
+        position: relative;
+        border: 1px solid #a8a8a8;
+        height: 30px;
+        padding-right: 7px;
+    }
+    .language_switcher_placeholder {
+        margin-top: 2rem;
+    }
+    .language_switcher_placeholder::after,
+    .version_switcher_placeholder::after {
+        content: url('../_static/caret-down.svg');
+        position: absolute;
+        top: 7px;
+        width: 15px;
+        height: 15px;
+        right: 0;
+        pointer-events: none;
+    }
+    .language_switcher_placeholder select,
+    .version_switcher_placeholder select {
+        -webkit-appearance: none;
+        appearance: none;
+        border: 0;
+        height: 100%;
+        background-color: white;
+    }
+    .language_switcher_placeholder:focus-visible,
+    .version_switcher_placeholder:focus-visible {
+        outline-offset: 5px;
+    }
+    .language_switcher_placeholder select {
+        width: 100%;
+    }
+    .document {
+        padding-top: 40px;
+        position: relative;
+        z-index: 0;
+    }
+    /*Responsive tables*/
+    .responsive-table__container {
+        width: 100%;
+        overflow-x: auto;
+    }
 }
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' 
'--exclude=.svnignore' 
old/python-docs-theme-2020.1/python_docs_theme/static/sidebar.js 
new/python-docs-theme-2022.1/python_docs_theme/static/sidebar.js
--- old/python-docs-theme-2020.1/python_docs_theme/static/sidebar.js    
2018-06-05 04:32:29.000000000 +0200
+++ new/python-docs-theme-2022.1/python_docs_theme/static/sidebar.js    
2022-01-11 10:28:52.000000000 +0100
@@ -2,8 +2,8 @@
  * sidebar.js
  * ~~~~~~~~~~
  *
- * This script makes the Sphinx sidebar collapsible and implements intelligent
- * scrolling. This is a slightly modified version of Sphinx's own sidebar.js.
+ * This script makes the Sphinx sidebar collapsible. This is a slightly
+ * modified version of Sphinx's own sidebar.js.
  *
  * .sphinxsidebar contains .sphinxsidebarwrapper.  This script adds in
  * .sphixsidebar, after .sphinxsidebarwrapper, the #sidebarbutton used to
@@ -25,10 +25,7 @@
   // global elements used by the functions.
   // the 'sidebarbutton' element is defined as global after its
   // creation, in the add_sidebar_button function
-  var jwindow = $(window);
-  var jdocument = $(document);
   var bodywrapper = $('.bodywrapper');
-  var documentwrapper = $('.documentwrapper');
   var sidebar = $('.sphinxsidebar');
   var sidebarwrapper = $('.sphinxsidebarwrapper');
 
@@ -46,13 +43,6 @@
   var dark_color = '#AAAAAA';
   var light_color = '#CCCCCC';
 
-  function get_viewport_height() {
-    if (window.innerHeight)
-      return window.innerHeight;
-    else
-      return jwindow.height();
-  }
-
   function sidebar_is_collapsed() {
     return sidebarwrapper.is(':not(:visible)');
   }
@@ -62,8 +52,6 @@
       expand_sidebar();
     else
       collapse_sidebar();
-    // adjust the scrolling of the sidebar
-    scroll_sidebar();
   }
 
   function collapse_sidebar() {
@@ -72,7 +60,6 @@
     bodywrapper.css('margin-left', bw_margin_collapsed);
     sidebarbutton.css({
         'margin-left': '0',
-        'height': documentwrapper.height(),
         'border-radius': '5px'
     });
     sidebarbutton.find('span').text('??');
@@ -86,13 +73,10 @@
     sidebarwrapper.show();
     sidebarbutton.css({
         'margin-left': ssb_width_expanded-12,
-        'height': Math.max(sidebarwrapper.height(), documentwrapper.height()),
         'border-radius': '0 5px 5px 0'
     });
     sidebarbutton.find('span').text('??');
     sidebarbutton.attr('title', _('Collapse sidebar'));
-    //sidebarwrapper.css({'padding-top':
-    //  Math.max(window.pageYOffset - sidebarwrapper.offset().top, 10)});
     document.cookie = 'sidebar=expanded';
   }
 
@@ -100,21 +84,17 @@
     sidebarwrapper.css({
         'float': 'left',
         'margin-right': '0',
-        'width': ssb_width_expanded - 28
+        'width': ssb_width_expanded - 13
     });
     // create the button
     sidebar.append(
       '<div id="sidebarbutton"><span>&laquo;</span></div>'
     );
     var sidebarbutton = $('#sidebarbutton');
-    // find the height of the viewport to center the '<<' in the page
-    var viewport_height = get_viewport_height();
-    var sidebar_offset = sidebar.offset().top;
-    var sidebar_height = Math.max(documentwrapper.height(), sidebar.height());
     sidebarbutton.find('span').css({
         'display': 'block',
         'position': 'fixed',
-        'top': Math.min(viewport_height/2, sidebar_height/2 + sidebar_offset) 
- 10
+        'top': '50%'
     });
 
     sidebarbutton.click(toggle_sidebar);
@@ -125,8 +105,7 @@
         'background-color': '#CCCCCC',
         'font-size': '1.2em',
         'cursor': 'pointer',
-        'height': sidebar_height,
-        'padding-top': '1px',
+        'height': '100%',
         'padding-left': '1px',
         'margin-left': ssb_width_expanded - 12
     });
@@ -161,34 +140,4 @@
   add_sidebar_button();
   var sidebarbutton = $('#sidebarbutton');
   set_position_from_cookie();
-
-
-  /* intelligent scrolling */
-  function scroll_sidebar() {
-    var sidebar_height = sidebarwrapper.height();
-    var viewport_height = get_viewport_height();
-    var offset = sidebar.position()['top'];
-    var wintop = jwindow.scrollTop();
-    var winbot = wintop + viewport_height;
-    var curtop = sidebarwrapper.position()['top'];
-    var curbot = curtop + sidebar_height;
-    // does sidebar fit in window?
-    if (sidebar_height < viewport_height) {
-      // yes: easy case -- always keep at the top
-      sidebarwrapper.css('top', $u.min([$u.max([0, wintop - offset - 10]),
-                            jdocument.height() - sidebar_height - 200]));
-    }
-    else {
-      // no: only scroll if top/bottom edge of sidebar is at
-      // top/bottom edge of window
-      if (curtop > wintop && curbot > winbot) {
-        sidebarwrapper.css('top', $u.max([wintop - offset - 10, 0]));
-      }
-      else if (curtop < wintop && curbot < winbot) {
-        sidebarwrapper.css('top', $u.min([winbot - sidebar_height - offset - 
20,
-                              jdocument.height() - sidebar_height - 200]));
-      }
-    }
-  }
-  jwindow.scroll(scroll_sidebar);
 });
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' 
'--exclude=.svnignore' 
old/python-docs-theme-2020.1/python_docs_theme/theme.conf 
new/python-docs-theme-2022.1/python_docs_theme/theme.conf
--- old/python-docs-theme-2020.1/python_docs_theme/theme.conf   2018-06-05 
04:32:29.000000000 +0200
+++ new/python-docs-theme-2022.1/python_docs_theme/theme.conf   2022-01-11 
10:31:34.000000000 +0100
@@ -1,7 +1,7 @@
 [theme]
 inherit = default
-stylesheet = pydoctheme.css
-pygments_style = sphinx
+stylesheet = pydoctheme.css?2022.1
+pygments_style = default
 
 [options]
 bodyfont = 'Lucida Grande', Arial, sans-serif
@@ -21,9 +21,13 @@
 headtextcolor = #1a1a1a
 headbgcolor = white
 headlinkcolor = #aaaaaa
+codebgcolor = #eeffcc
+codetextcolor = #333333
 
-issues_url = 
+issues_url =
+license_url =
 root_name = Python
 root_url = https://www.python.org/
-root_icon = py.png
+root_icon = py.svg
 root_include_title = True
+copyright_url =
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' 
'--exclude=.svnignore' 
old/python-docs-theme-2020.1/python_docs_theme.egg-info/PKG-INFO 
new/python-docs-theme-2022.1/python_docs_theme.egg-info/PKG-INFO
--- old/python-docs-theme-2020.1/python_docs_theme.egg-info/PKG-INFO    
2020-01-14 21:04:23.000000000 +0100
+++ new/python-docs-theme-2022.1/python_docs_theme.egg-info/PKG-INFO    
2022-01-11 10:45:51.000000000 +0100
@@ -1,27 +1,11 @@
-Metadata-Version: 1.1
+Metadata-Version: 2.1
 Name: python-docs-theme
-Version: 2020.1
+Version: 2022.1
 Summary: The Sphinx theme for the CPython docs and related projects
-Home-page: https://docs.python.org
+Home-page: https://github.com/python/python-docs-theme/
 Author: PyPA
 Author-email: distutils-...@python.org
 License: UNKNOWN
-Description: Python Docs Sphinx Theme
-        =========================
-        
-        This is the theme for the Python documentation.
-        
-        Note that when adopting this theme, you're also borrowing an element 
of the
-        trust and credibility established by the CPython core developers over 
the
-        years. That's fine, and you're welcome to do so for other Python 
community
-        projects if you so choose, but please keep in mind that in doing so 
you're also
-        choosing to accept some of the responsibility for maintaining that 
collective
-        trust.
-        
-        To use the theme, install it into your docs build environment via 
``pip``::
-        
-            pip install python-docs-theme
-        
 Platform: UNKNOWN
 Classifier: Intended Audience :: Developers
 Classifier: License :: OSI Approved :: Python Software Foundation License
@@ -30,3 +14,31 @@
 Classifier: Topic :: Software Development :: Documentation
 Classifier: Programming Language :: Python
 Classifier: Programming Language :: Python :: 3
+License-File: LICENSE
+
+Python Docs Sphinx Theme
+=========================
+
+This is the theme for the Python documentation.
+
+Note that when adopting this theme, you're also borrowing an element of the
+trust and credibility established by the CPython core developers over the
+years. That's fine, and you're welcome to do so for other Python community
+projects if you so choose, but please keep in mind that in doing so you're also
+choosing to accept some of the responsibility for maintaining that collective
+trust.
+
+To use the theme, install it into your docs build environment via ``pip`` 
+(preferably in a virtual environment).
+
+
+Configuration options
+---------------------
+
+To use this theme, add the following to ``conf.py``:
+
+- ``html_theme = 'python_docs_theme'``
+
+- ``html_sidebars``, defaults taken from 
http://www.sphinx-doc.org/en/stable/config.html#confval-html_sidebars
+
+
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' 
'--exclude=.svnignore' 
old/python-docs-theme-2020.1/python_docs_theme.egg-info/SOURCES.txt 
new/python-docs-theme-2022.1/python_docs_theme.egg-info/SOURCES.txt
--- old/python-docs-theme-2020.1/python_docs_theme.egg-info/SOURCES.txt 
2020-01-14 21:04:23.000000000 +0100
+++ new/python-docs-theme-2022.1/python_docs_theme.egg-info/SOURCES.txt 
2022-01-11 10:45:51.000000000 +0100
@@ -1,6 +1,7 @@
 LICENSE
 MANIFEST.in
 README.rst
+pyproject.toml
 setup.cfg
 setup.py
 python_docs_theme/__init__.py
@@ -12,7 +13,10 @@
 python_docs_theme.egg-info/dependency_links.txt
 python_docs_theme.egg-info/entry_points.txt
 python_docs_theme.egg-info/top_level.txt
+python_docs_theme/static/caret-down.svg
 python_docs_theme/static/copybutton.js
+python_docs_theme/static/menu.js
 python_docs_theme/static/py.png
+python_docs_theme/static/py.svg
 python_docs_theme/static/pydoctheme.css
 python_docs_theme/static/sidebar.js
\ No newline at end of file
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' 
'--exclude=.svnignore' old/python-docs-theme-2020.1/setup.cfg 
new/python-docs-theme-2022.1/setup.cfg
--- old/python-docs-theme-2020.1/setup.cfg      2020-01-14 21:04:23.000000000 
+0100
+++ new/python-docs-theme-2022.1/setup.cfg      2022-01-11 10:45:51.167946600 
+0100
@@ -4,5 +4,4 @@
 [egg_info]
 tag_build = 
 tag_date = 0
-tag_svn_revision = 0
 
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' 
'--exclude=.svnignore' old/python-docs-theme-2020.1/setup.py 
new/python-docs-theme-2022.1/setup.py
--- old/python-docs-theme-2020.1/setup.py       2020-01-14 21:03:30.000000000 
+0100
+++ new/python-docs-theme-2022.1/setup.py       2022-01-11 10:31:40.000000000 
+0100
@@ -5,34 +5,34 @@
 from setuptools import setup
 
 # README into long description
-with io.open('README.rst', encoding='utf-8') as readme_file:
+with io.open("README.rst", encoding="utf-8") as readme_file:
     long_description = readme_file.read()
 
 
 setup(
-    name='python-docs-theme',
+    name="python-docs-theme",
     # Version is date based as year.month[.serial], where serial is used
     # if multiple releases are needed to address build failures.
-    version='2020.1',
-    description='The Sphinx theme for the CPython docs and related projects',
+    version="2022.1",
+    description="The Sphinx theme for the CPython docs and related projects",
     long_description=long_description,
-    author='PyPA',
-    author_email='distutils-...@python.org',
-    url='https://docs.python.org',
-    packages=['python_docs_theme'],
+    author="PyPA",
+    author_email="distutils-...@python.org",
+    url="https://github.com/python/python-docs-theme/";,
+    packages=["python_docs_theme"],
     include_package_data=True,
     entry_points={
-        'sphinx.html_themes': [
-            'python_docs_theme = python_docs_theme',
+        "sphinx.html_themes": [
+            "python_docs_theme = python_docs_theme",
         ]
     },
     classifiers=[
-        'Intended Audience :: Developers',
-        'License :: OSI Approved :: Python Software Foundation License',
-        'Operating System :: OS Independent',
-        'Topic :: Documentation',
-        'Topic :: Software Development :: Documentation',
-        'Programming Language :: Python',
-        'Programming Language :: Python :: 3',
+        "Intended Audience :: Developers",
+        "License :: OSI Approved :: Python Software Foundation License",
+        "Operating System :: OS Independent",
+        "Topic :: Documentation",
+        "Topic :: Software Development :: Documentation",
+        "Programming Language :: Python",
+        "Programming Language :: Python :: 3",
     ],
 )

Reply via email to