* Doc: Indicate the language
* Renaming version_switcher to switchers (to add language_switcher).
* Adding language switch.
* Doc switchers: Enhance readability of regex parsing versions.
* Doc switchers: Desambiguate the need of a replace(/\/+$/g, '') by proper naming.
* Doc switchers: py3k can't reach js, it's redirected server-side by nginx.
* Doc switchers: Examples matching actual regexes.
* Doc switchers: Better fallback on unexisting translated version.
(cherry picked from commit dff9b5f9d6
)
This commit is contained in:
parent
88ffff5ddb
commit
245dafca85
|
@ -157,12 +157,12 @@ serve:
|
||||||
|
|
||||||
# for development releases: always build
|
# for development releases: always build
|
||||||
autobuild-dev:
|
autobuild-dev:
|
||||||
make dist SPHINXOPTS='$(SPHINXOPTS) -A daily=1 -A versionswitcher=1'
|
make dist SPHINXOPTS='$(SPHINXOPTS) -A daily=1 -A switchers=1'
|
||||||
-make suspicious
|
-make suspicious
|
||||||
|
|
||||||
# for quick rebuilds (HTML only)
|
# for quick rebuilds (HTML only)
|
||||||
autobuild-dev-html:
|
autobuild-dev-html:
|
||||||
make html SPHINXOPTS='$(SPHINXOPTS) -A daily=1 -A versionswitcher=1'
|
make html SPHINXOPTS='$(SPHINXOPTS) -A daily=1 -A switchers=1'
|
||||||
|
|
||||||
# for stable releases: only build if not in pre-release stage (alpha, beta)
|
# for stable releases: only build if not in pre-release stage (alpha, beta)
|
||||||
# release candidate downloads are okay, since the stable tree can be in that stage
|
# release candidate downloads are okay, since the stable tree can be in that stage
|
||||||
|
|
|
@ -0,0 +1,146 @@
|
||||||
|
(function() {
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
// Parses versions in URL segments like:
|
||||||
|
// "3", "dev", "release/2.7" or "3.6rc2"
|
||||||
|
var version_regexs = [
|
||||||
|
'(?:\\d)',
|
||||||
|
'(?:\\d\\.\\d[\\w\\d\\.]*)',
|
||||||
|
'(?:dev)',
|
||||||
|
'(?:release/\\d.\\d[\\x\\d\\.]*)'];
|
||||||
|
|
||||||
|
var all_versions = {
|
||||||
|
'3.7': 'dev (3.7)',
|
||||||
|
'3.6': '3.6',
|
||||||
|
'3.5': '3.5',
|
||||||
|
'3.4': '3.4',
|
||||||
|
'3.3': '3.3',
|
||||||
|
'2.7': '2.7',
|
||||||
|
};
|
||||||
|
|
||||||
|
var all_languages = {
|
||||||
|
'en': 'English',
|
||||||
|
'fr': 'Français',
|
||||||
|
};
|
||||||
|
|
||||||
|
function build_version_select(current_version, current_release) {
|
||||||
|
var buf = ['<select>'];
|
||||||
|
|
||||||
|
$.each(all_versions, function(version, title) {
|
||||||
|
buf.push('<option value="' + version + '"');
|
||||||
|
if (version == current_version)
|
||||||
|
buf.push(' selected="selected">' + current_release + '</option>');
|
||||||
|
else
|
||||||
|
buf.push('>' + title + '</option>');
|
||||||
|
});
|
||||||
|
|
||||||
|
buf.push('</select>');
|
||||||
|
return buf.join('');
|
||||||
|
}
|
||||||
|
|
||||||
|
function build_language_select(current_language) {
|
||||||
|
var buf = ['<select>'];
|
||||||
|
|
||||||
|
$.each(all_languages, function(language, title) {
|
||||||
|
if (language == current_language)
|
||||||
|
buf.push('<option value="' + language + '" selected="selected">' +
|
||||||
|
all_languages[current_language] + '</option>');
|
||||||
|
else
|
||||||
|
buf.push('<option value="' + language + '">' + title + '</option>');
|
||||||
|
});
|
||||||
|
buf.push('</select>');
|
||||||
|
return buf.join('');
|
||||||
|
}
|
||||||
|
|
||||||
|
function navigate_to_first_existing(urls) {
|
||||||
|
// Navigate to the first existing URL in urls.
|
||||||
|
var url = urls.shift();
|
||||||
|
if (urls.length == 0) {
|
||||||
|
window.location.href = url;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
$.ajax({
|
||||||
|
url: url,
|
||||||
|
success: function() {
|
||||||
|
window.location.href = url;
|
||||||
|
},
|
||||||
|
error: function() {
|
||||||
|
navigate_to_first_existing(urls);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
function on_version_switch() {
|
||||||
|
var selected_version = $(this).children('option:selected').attr('value') + '/';
|
||||||
|
var url = window.location.href;
|
||||||
|
var current_language = language_segment_from_url(url);
|
||||||
|
var current_version = version_segment_in_url(url);
|
||||||
|
var new_url = url.replace('.org/' + current_language + current_version,
|
||||||
|
'.org/' + current_language + selected_version);
|
||||||
|
if (new_url != url) {
|
||||||
|
navigate_to_first_existing([
|
||||||
|
new_url,
|
||||||
|
url.replace('.org/' + current_language + current_version,
|
||||||
|
'.org/' + selected_version),
|
||||||
|
'https://docs.python.org/' + current_language + selected_version,
|
||||||
|
'https://docs.python.org/' + selected_version,
|
||||||
|
'https://docs.python.org/'
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function on_language_switch() {
|
||||||
|
var selected_language = $(this).children('option:selected').attr('value') + '/';
|
||||||
|
var url = window.location.href;
|
||||||
|
var current_language = language_segment_from_url(url);
|
||||||
|
var current_version = version_segment_in_url(url);
|
||||||
|
if (selected_language == 'en/') // Special 'default' case for english.
|
||||||
|
selected_language = '';
|
||||||
|
var new_url = url.replace('.org/' + current_language + current_version,
|
||||||
|
'.org/' + selected_language + current_version);
|
||||||
|
if (new_url != url) {
|
||||||
|
navigate_to_first_existing([
|
||||||
|
new_url,
|
||||||
|
'https://docs.python.org/'
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Returns the path segment of the language as a string, like 'fr/'
|
||||||
|
// or '' if not found.
|
||||||
|
function language_segment_from_url(url) {
|
||||||
|
var language_regexp = '\.org/(' + Object.keys(all_languages).join('|') + '/)';
|
||||||
|
var match = url.match(language_regexp);
|
||||||
|
if (match !== null)
|
||||||
|
return match[1];
|
||||||
|
return '';
|
||||||
|
}
|
||||||
|
|
||||||
|
// Returns the path segment of the version as a string, like '3.6/'
|
||||||
|
// or '' if not found.
|
||||||
|
function version_segment_in_url(url) {
|
||||||
|
var language_segment = '(?:(?:' + Object.keys(all_languages).join('|') + ')/)';
|
||||||
|
var version_segment = '(?:(?:' + version_regexs.join('|') + ')/)';
|
||||||
|
var version_regexp = '\\.org/' + language_segment + '?(' + version_segment + ')';
|
||||||
|
var match = url.match(version_regexp);
|
||||||
|
if (match !== null)
|
||||||
|
return match[1];
|
||||||
|
return ''
|
||||||
|
}
|
||||||
|
|
||||||
|
$(document).ready(function() {
|
||||||
|
var release = DOCUMENTATION_OPTIONS.VERSION;
|
||||||
|
var language_segment = language_segment_from_url(window.location.href);
|
||||||
|
var current_language = language_segment.replace(/\/+$/g, '') || 'en';
|
||||||
|
var version = release.substr(0, 3);
|
||||||
|
var version_select = build_version_select(version, release);
|
||||||
|
|
||||||
|
$('.version_switcher_placeholder').html(version_select);
|
||||||
|
$('.version_switcher_placeholder select').bind('change', on_version_switch);
|
||||||
|
|
||||||
|
var language_select = build_language_select(current_language);
|
||||||
|
|
||||||
|
$('.language_switcher_placeholder').html(language_select);
|
||||||
|
$('.language_switcher_placeholder select').bind('change', on_language_switch);
|
||||||
|
});
|
||||||
|
})();
|
|
@ -1,67 +0,0 @@
|
||||||
(function() {
|
|
||||||
'use strict';
|
|
||||||
|
|
||||||
var all_versions = {
|
|
||||||
'3.7': 'dev (3.7)',
|
|
||||||
'3.6': '3.6',
|
|
||||||
'3.5': '3.5',
|
|
||||||
'3.4': '3.4',
|
|
||||||
'3.3': '3.3',
|
|
||||||
'2.7': '2.7',
|
|
||||||
};
|
|
||||||
|
|
||||||
function build_select(current_version, current_release) {
|
|
||||||
var buf = ['<select>'];
|
|
||||||
|
|
||||||
$.each(all_versions, function(version, title) {
|
|
||||||
buf.push('<option value="' + version + '"');
|
|
||||||
if (version == current_version)
|
|
||||||
buf.push(' selected="selected">' + current_release + '</option>');
|
|
||||||
else
|
|
||||||
buf.push('>' + title + '</option>');
|
|
||||||
});
|
|
||||||
|
|
||||||
buf.push('</select>');
|
|
||||||
return buf.join('');
|
|
||||||
}
|
|
||||||
|
|
||||||
function patch_url(url, new_version) {
|
|
||||||
var url_re = /\.org\/(\d|py3k|dev|((release\/)?\d\.\d[\w\d\.]*))\//,
|
|
||||||
new_url = url.replace(url_re, '.org/' + new_version + '/');
|
|
||||||
|
|
||||||
if (new_url == url && !new_url.match(url_re)) {
|
|
||||||
// python 2 url without version?
|
|
||||||
new_url = url.replace(/\.org\//, '.org/' + new_version + '/');
|
|
||||||
}
|
|
||||||
return new_url;
|
|
||||||
}
|
|
||||||
|
|
||||||
function on_switch() {
|
|
||||||
var selected = $(this).children('option:selected').attr('value');
|
|
||||||
|
|
||||||
var url = window.location.href,
|
|
||||||
new_url = patch_url(url, selected);
|
|
||||||
|
|
||||||
if (new_url != url) {
|
|
||||||
// check beforehand if url exists, else redirect to version's start page
|
|
||||||
$.ajax({
|
|
||||||
url: new_url,
|
|
||||||
success: function() {
|
|
||||||
window.location.href = new_url;
|
|
||||||
},
|
|
||||||
error: function() {
|
|
||||||
window.location.href = 'https://docs.python.org/' + selected;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
$(document).ready(function() {
|
|
||||||
var release = DOCUMENTATION_OPTIONS.VERSION;
|
|
||||||
var version = release.substr(0, 3);
|
|
||||||
var select = build_select(version, release);
|
|
||||||
|
|
||||||
$('.version_switcher_placeholder').html(select);
|
|
||||||
$('.version_switcher_placeholder select').bind('change', on_switch);
|
|
||||||
});
|
|
||||||
})();
|
|
|
@ -4,7 +4,8 @@
|
||||||
style="vertical-align: middle; margin-top: -1px"/></li>
|
style="vertical-align: middle; margin-top: -1px"/></li>
|
||||||
<li><a href="https://www.python.org/">Python</a>{{ reldelim1 }}</li>
|
<li><a href="https://www.python.org/">Python</a>{{ reldelim1 }}</li>
|
||||||
<li>
|
<li>
|
||||||
{%- if versionswitcher is defined %}
|
{%- if switchers is defined %}
|
||||||
|
<span class="language_switcher_placeholder">{{ language or 'en' }}</span>
|
||||||
<span class="version_switcher_placeholder">{{ release }}</span>
|
<span class="version_switcher_placeholder">{{ release }}</span>
|
||||||
<a href="{{ pathto('index') }}">{% trans %}Documentation{% endtrans %}</a>{{ reldelim1 }}
|
<a href="{{ pathto('index') }}">{% trans %}Documentation{% endtrans %}</a>{{ reldelim1 }}
|
||||||
{%- else %}
|
{%- else %}
|
||||||
|
@ -18,7 +19,7 @@
|
||||||
<link rel="shortcut icon" type="image/png" href="{{ pathto('_static/py.png', 1) }}" />
|
<link rel="shortcut icon" type="image/png" href="{{ pathto('_static/py.png', 1) }}" />
|
||||||
<link rel="canonical" href="https://docs.python.org/2/{{pagename}}.html" />
|
<link rel="canonical" href="https://docs.python.org/2/{{pagename}}.html" />
|
||||||
{% if not embedded %}<script type="text/javascript" src="{{ pathto('_static/copybutton.js', 1) }}"></script>{% endif %}
|
{% if not embedded %}<script type="text/javascript" src="{{ pathto('_static/copybutton.js', 1) }}"></script>{% endif %}
|
||||||
{% if versionswitcher is defined and not embedded %}<script type="text/javascript" src="{{ pathto('_static/version_switch.js', 1) }}"></script>{% endif %}
|
{% if switchers is defined and not embedded %}<script type="text/javascript" src="{{ pathto('_static/switchers.js', 1) }}"></script>{% endif %}
|
||||||
{{ super() }}
|
{{ super() }}
|
||||||
{% if builder == 'qthelp' %}
|
{% if builder == 'qthelp' %}
|
||||||
<style type="text/css">
|
<style type="text/css">
|
||||||
|
|
Loading…
Reference in New Issue