Deploying to gh-pages from @ DCC-EX/CommandStation-EX@c993f5a4a9 🚀
@ -1,4 +0,0 @@
|
|||||||
# Sphinx build info version 1
|
|
||||||
# This file records the configuration used when building these files. When it is not found, a full rebuild will be done.
|
|
||||||
config: e132f85ac5790b47db176af8b0a03bac
|
|
||||||
tags: 645f666f9bcd5a90fca523b33c5a78b7
|
|
@ -1,15 +0,0 @@
|
|||||||
EXRAIL Language documentation
|
|
||||||
=============================
|
|
||||||
|
|
||||||
Introduction
|
|
||||||
------------
|
|
||||||
|
|
||||||
EXRAIL - Extended Railroad Automation Instruction Language
|
|
||||||
|
|
||||||
This page is a reference to all EXRAIL commands available with EX-CommandStation.
|
|
||||||
|
|
||||||
Macros
|
|
||||||
------
|
|
||||||
|
|
||||||
.. doxygenfile:: EXRAIL2MacroReset.h
|
|
||||||
:project: EXRAIL Language
|
|
@ -1,123 +0,0 @@
|
|||||||
/* Compatability shim for jQuery and underscores.js.
|
|
||||||
*
|
|
||||||
* Copyright Sphinx contributors
|
|
||||||
* Released under the two clause BSD licence
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* small helper function to urldecode strings
|
|
||||||
*
|
|
||||||
* See https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/decodeURIComponent#Decoding_query_parameters_from_a_URL
|
|
||||||
*/
|
|
||||||
jQuery.urldecode = function(x) {
|
|
||||||
if (!x) {
|
|
||||||
return x
|
|
||||||
}
|
|
||||||
return decodeURIComponent(x.replace(/\+/g, ' '));
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* small helper function to urlencode strings
|
|
||||||
*/
|
|
||||||
jQuery.urlencode = encodeURIComponent;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* This function returns the parsed url parameters of the
|
|
||||||
* current request. Multiple values per key are supported,
|
|
||||||
* it will always return arrays of strings for the value parts.
|
|
||||||
*/
|
|
||||||
jQuery.getQueryParameters = function(s) {
|
|
||||||
if (typeof s === 'undefined')
|
|
||||||
s = document.location.search;
|
|
||||||
var parts = s.substr(s.indexOf('?') + 1).split('&');
|
|
||||||
var result = {};
|
|
||||||
for (var i = 0; i < parts.length; i++) {
|
|
||||||
var tmp = parts[i].split('=', 2);
|
|
||||||
var key = jQuery.urldecode(tmp[0]);
|
|
||||||
var value = jQuery.urldecode(tmp[1]);
|
|
||||||
if (key in result)
|
|
||||||
result[key].push(value);
|
|
||||||
else
|
|
||||||
result[key] = [value];
|
|
||||||
}
|
|
||||||
return result;
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* highlight a given string on a jquery object by wrapping it in
|
|
||||||
* span elements with the given class name.
|
|
||||||
*/
|
|
||||||
jQuery.fn.highlightText = function(text, className) {
|
|
||||||
function highlight(node, addItems) {
|
|
||||||
if (node.nodeType === 3) {
|
|
||||||
var val = node.nodeValue;
|
|
||||||
var pos = val.toLowerCase().indexOf(text);
|
|
||||||
if (pos >= 0 &&
|
|
||||||
!jQuery(node.parentNode).hasClass(className) &&
|
|
||||||
!jQuery(node.parentNode).hasClass("nohighlight")) {
|
|
||||||
var span;
|
|
||||||
var isInSVG = jQuery(node).closest("body, svg, foreignObject").is("svg");
|
|
||||||
if (isInSVG) {
|
|
||||||
span = document.createElementNS("http://www.w3.org/2000/svg", "tspan");
|
|
||||||
} else {
|
|
||||||
span = document.createElement("span");
|
|
||||||
span.className = className;
|
|
||||||
}
|
|
||||||
span.appendChild(document.createTextNode(val.substr(pos, text.length)));
|
|
||||||
node.parentNode.insertBefore(span, node.parentNode.insertBefore(
|
|
||||||
document.createTextNode(val.substr(pos + text.length)),
|
|
||||||
node.nextSibling));
|
|
||||||
node.nodeValue = val.substr(0, pos);
|
|
||||||
if (isInSVG) {
|
|
||||||
var rect = document.createElementNS("http://www.w3.org/2000/svg", "rect");
|
|
||||||
var bbox = node.parentElement.getBBox();
|
|
||||||
rect.x.baseVal.value = bbox.x;
|
|
||||||
rect.y.baseVal.value = bbox.y;
|
|
||||||
rect.width.baseVal.value = bbox.width;
|
|
||||||
rect.height.baseVal.value = bbox.height;
|
|
||||||
rect.setAttribute('class', className);
|
|
||||||
addItems.push({
|
|
||||||
"parent": node.parentNode,
|
|
||||||
"target": rect});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else if (!jQuery(node).is("button, select, textarea")) {
|
|
||||||
jQuery.each(node.childNodes, function() {
|
|
||||||
highlight(this, addItems);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
var addItems = [];
|
|
||||||
var result = this.each(function() {
|
|
||||||
highlight(this, addItems);
|
|
||||||
});
|
|
||||||
for (var i = 0; i < addItems.length; ++i) {
|
|
||||||
jQuery(addItems[i].parent).before(addItems[i].target);
|
|
||||||
}
|
|
||||||
return result;
|
|
||||||
};
|
|
||||||
|
|
||||||
/*
|
|
||||||
* backward compatibility for jQuery.browser
|
|
||||||
* This will be supported until firefox bug is fixed.
|
|
||||||
*/
|
|
||||||
if (!jQuery.browser) {
|
|
||||||
jQuery.uaMatch = function(ua) {
|
|
||||||
ua = ua.toLowerCase();
|
|
||||||
|
|
||||||
var match = /(chrome)[ \/]([\w.]+)/.exec(ua) ||
|
|
||||||
/(webkit)[ \/]([\w.]+)/.exec(ua) ||
|
|
||||||
/(opera)(?:.*version|)[ \/]([\w.]+)/.exec(ua) ||
|
|
||||||
/(msie) ([\w.]+)/.exec(ua) ||
|
|
||||||
ua.indexOf("compatible") < 0 && /(mozilla)(?:.*? rv:([\w.]+)|)/.exec(ua) ||
|
|
||||||
[];
|
|
||||||
|
|
||||||
return {
|
|
||||||
browser: match[ 1 ] || "",
|
|
||||||
version: match[ 2 ] || "0"
|
|
||||||
};
|
|
||||||
};
|
|
||||||
jQuery.browser = {};
|
|
||||||
jQuery.browser[jQuery.uaMatch(navigator.userAgent).browser] = true;
|
|
||||||
}
|
|
@ -1,914 +0,0 @@
|
|||||||
/*
|
|
||||||
* Sphinx stylesheet -- basic theme.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* -- main layout ----------------------------------------------------------- */
|
|
||||||
|
|
||||||
div.clearer {
|
|
||||||
clear: both;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.section::after {
|
|
||||||
display: block;
|
|
||||||
content: '';
|
|
||||||
clear: left;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* -- relbar ---------------------------------------------------------------- */
|
|
||||||
|
|
||||||
div.related {
|
|
||||||
width: 100%;
|
|
||||||
font-size: 90%;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.related h3 {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.related ul {
|
|
||||||
margin: 0;
|
|
||||||
padding: 0 0 0 10px;
|
|
||||||
list-style: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.related li {
|
|
||||||
display: inline;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.related li.right {
|
|
||||||
float: right;
|
|
||||||
margin-right: 5px;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* -- sidebar --------------------------------------------------------------- */
|
|
||||||
|
|
||||||
div.sphinxsidebarwrapper {
|
|
||||||
padding: 10px 5px 0 10px;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.sphinxsidebar {
|
|
||||||
float: left;
|
|
||||||
width: 230px;
|
|
||||||
margin-left: -100%;
|
|
||||||
font-size: 90%;
|
|
||||||
word-wrap: break-word;
|
|
||||||
overflow-wrap : break-word;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.sphinxsidebar ul {
|
|
||||||
list-style: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.sphinxsidebar ul ul,
|
|
||||||
div.sphinxsidebar ul.want-points {
|
|
||||||
margin-left: 20px;
|
|
||||||
list-style: square;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.sphinxsidebar ul ul {
|
|
||||||
margin-top: 0;
|
|
||||||
margin-bottom: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.sphinxsidebar form {
|
|
||||||
margin-top: 10px;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.sphinxsidebar input {
|
|
||||||
border: 1px solid #98dbcc;
|
|
||||||
font-family: sans-serif;
|
|
||||||
font-size: 1em;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.sphinxsidebar #searchbox form.search {
|
|
||||||
overflow: hidden;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.sphinxsidebar #searchbox input[type="text"] {
|
|
||||||
float: left;
|
|
||||||
width: 80%;
|
|
||||||
padding: 0.25em;
|
|
||||||
box-sizing: border-box;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.sphinxsidebar #searchbox input[type="submit"] {
|
|
||||||
float: left;
|
|
||||||
width: 20%;
|
|
||||||
border-left: none;
|
|
||||||
padding: 0.25em;
|
|
||||||
box-sizing: border-box;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
img {
|
|
||||||
border: 0;
|
|
||||||
max-width: 100%;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* -- search page ----------------------------------------------------------- */
|
|
||||||
|
|
||||||
ul.search {
|
|
||||||
margin-top: 10px;
|
|
||||||
}
|
|
||||||
|
|
||||||
ul.search li {
|
|
||||||
padding: 5px 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
ul.search li a {
|
|
||||||
font-weight: bold;
|
|
||||||
}
|
|
||||||
|
|
||||||
ul.search li p.context {
|
|
||||||
color: #888;
|
|
||||||
margin: 2px 0 0 30px;
|
|
||||||
text-align: left;
|
|
||||||
}
|
|
||||||
|
|
||||||
ul.keywordmatches li.goodmatch a {
|
|
||||||
font-weight: bold;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* -- index page ------------------------------------------------------------ */
|
|
||||||
|
|
||||||
table.contentstable {
|
|
||||||
width: 90%;
|
|
||||||
margin-left: auto;
|
|
||||||
margin-right: auto;
|
|
||||||
}
|
|
||||||
|
|
||||||
table.contentstable p.biglink {
|
|
||||||
line-height: 150%;
|
|
||||||
}
|
|
||||||
|
|
||||||
a.biglink {
|
|
||||||
font-size: 1.3em;
|
|
||||||
}
|
|
||||||
|
|
||||||
span.linkdescr {
|
|
||||||
font-style: italic;
|
|
||||||
padding-top: 5px;
|
|
||||||
font-size: 90%;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* -- general index --------------------------------------------------------- */
|
|
||||||
|
|
||||||
table.indextable {
|
|
||||||
width: 100%;
|
|
||||||
}
|
|
||||||
|
|
||||||
table.indextable td {
|
|
||||||
text-align: left;
|
|
||||||
vertical-align: top;
|
|
||||||
}
|
|
||||||
|
|
||||||
table.indextable ul {
|
|
||||||
margin-top: 0;
|
|
||||||
margin-bottom: 0;
|
|
||||||
list-style-type: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
table.indextable > tbody > tr > td > ul {
|
|
||||||
padding-left: 0em;
|
|
||||||
}
|
|
||||||
|
|
||||||
table.indextable tr.pcap {
|
|
||||||
height: 10px;
|
|
||||||
}
|
|
||||||
|
|
||||||
table.indextable tr.cap {
|
|
||||||
margin-top: 10px;
|
|
||||||
background-color: #f2f2f2;
|
|
||||||
}
|
|
||||||
|
|
||||||
img.toggler {
|
|
||||||
margin-right: 3px;
|
|
||||||
margin-top: 3px;
|
|
||||||
cursor: pointer;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.modindex-jumpbox {
|
|
||||||
border-top: 1px solid #ddd;
|
|
||||||
border-bottom: 1px solid #ddd;
|
|
||||||
margin: 1em 0 1em 0;
|
|
||||||
padding: 0.4em;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.genindex-jumpbox {
|
|
||||||
border-top: 1px solid #ddd;
|
|
||||||
border-bottom: 1px solid #ddd;
|
|
||||||
margin: 1em 0 1em 0;
|
|
||||||
padding: 0.4em;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* -- domain module index --------------------------------------------------- */
|
|
||||||
|
|
||||||
table.modindextable td {
|
|
||||||
padding: 2px;
|
|
||||||
border-collapse: collapse;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* -- general body styles --------------------------------------------------- */
|
|
||||||
|
|
||||||
div.body {
|
|
||||||
min-width: 360px;
|
|
||||||
max-width: 800px;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.body p, div.body dd, div.body li, div.body blockquote {
|
|
||||||
-moz-hyphens: auto;
|
|
||||||
-ms-hyphens: auto;
|
|
||||||
-webkit-hyphens: auto;
|
|
||||||
hyphens: auto;
|
|
||||||
}
|
|
||||||
|
|
||||||
a.headerlink {
|
|
||||||
visibility: hidden;
|
|
||||||
}
|
|
||||||
|
|
||||||
a:visited {
|
|
||||||
color: #551A8B;
|
|
||||||
}
|
|
||||||
|
|
||||||
h1:hover > a.headerlink,
|
|
||||||
h2:hover > a.headerlink,
|
|
||||||
h3:hover > a.headerlink,
|
|
||||||
h4:hover > a.headerlink,
|
|
||||||
h5:hover > a.headerlink,
|
|
||||||
h6:hover > a.headerlink,
|
|
||||||
dt:hover > a.headerlink,
|
|
||||||
caption:hover > a.headerlink,
|
|
||||||
p.caption:hover > a.headerlink,
|
|
||||||
div.code-block-caption:hover > a.headerlink {
|
|
||||||
visibility: visible;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.body p.caption {
|
|
||||||
text-align: inherit;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.body td {
|
|
||||||
text-align: left;
|
|
||||||
}
|
|
||||||
|
|
||||||
.first {
|
|
||||||
margin-top: 0 !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
p.rubric {
|
|
||||||
margin-top: 30px;
|
|
||||||
font-weight: bold;
|
|
||||||
}
|
|
||||||
|
|
||||||
img.align-left, figure.align-left, .figure.align-left, object.align-left {
|
|
||||||
clear: left;
|
|
||||||
float: left;
|
|
||||||
margin-right: 1em;
|
|
||||||
}
|
|
||||||
|
|
||||||
img.align-right, figure.align-right, .figure.align-right, object.align-right {
|
|
||||||
clear: right;
|
|
||||||
float: right;
|
|
||||||
margin-left: 1em;
|
|
||||||
}
|
|
||||||
|
|
||||||
img.align-center, figure.align-center, .figure.align-center, object.align-center {
|
|
||||||
display: block;
|
|
||||||
margin-left: auto;
|
|
||||||
margin-right: auto;
|
|
||||||
}
|
|
||||||
|
|
||||||
img.align-default, figure.align-default, .figure.align-default {
|
|
||||||
display: block;
|
|
||||||
margin-left: auto;
|
|
||||||
margin-right: auto;
|
|
||||||
}
|
|
||||||
|
|
||||||
.align-left {
|
|
||||||
text-align: left;
|
|
||||||
}
|
|
||||||
|
|
||||||
.align-center {
|
|
||||||
text-align: center;
|
|
||||||
}
|
|
||||||
|
|
||||||
.align-default {
|
|
||||||
text-align: center;
|
|
||||||
}
|
|
||||||
|
|
||||||
.align-right {
|
|
||||||
text-align: right;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* -- sidebars -------------------------------------------------------------- */
|
|
||||||
|
|
||||||
div.sidebar,
|
|
||||||
aside.sidebar {
|
|
||||||
margin: 0 0 0.5em 1em;
|
|
||||||
border: 1px solid #ddb;
|
|
||||||
padding: 7px;
|
|
||||||
background-color: #ffe;
|
|
||||||
width: 40%;
|
|
||||||
float: right;
|
|
||||||
clear: right;
|
|
||||||
overflow-x: auto;
|
|
||||||
}
|
|
||||||
|
|
||||||
p.sidebar-title {
|
|
||||||
font-weight: bold;
|
|
||||||
}
|
|
||||||
|
|
||||||
nav.contents,
|
|
||||||
aside.topic,
|
|
||||||
div.admonition, div.topic, blockquote {
|
|
||||||
clear: left;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* -- topics ---------------------------------------------------------------- */
|
|
||||||
|
|
||||||
nav.contents,
|
|
||||||
aside.topic,
|
|
||||||
div.topic {
|
|
||||||
border: 1px solid #ccc;
|
|
||||||
padding: 7px;
|
|
||||||
margin: 10px 0 10px 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
p.topic-title {
|
|
||||||
font-size: 1.1em;
|
|
||||||
font-weight: bold;
|
|
||||||
margin-top: 10px;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* -- admonitions ----------------------------------------------------------- */
|
|
||||||
|
|
||||||
div.admonition {
|
|
||||||
margin-top: 10px;
|
|
||||||
margin-bottom: 10px;
|
|
||||||
padding: 7px;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.admonition dt {
|
|
||||||
font-weight: bold;
|
|
||||||
}
|
|
||||||
|
|
||||||
p.admonition-title {
|
|
||||||
margin: 0px 10px 5px 0px;
|
|
||||||
font-weight: bold;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.body p.centered {
|
|
||||||
text-align: center;
|
|
||||||
margin-top: 25px;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* -- content of sidebars/topics/admonitions -------------------------------- */
|
|
||||||
|
|
||||||
div.sidebar > :last-child,
|
|
||||||
aside.sidebar > :last-child,
|
|
||||||
nav.contents > :last-child,
|
|
||||||
aside.topic > :last-child,
|
|
||||||
div.topic > :last-child,
|
|
||||||
div.admonition > :last-child {
|
|
||||||
margin-bottom: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.sidebar::after,
|
|
||||||
aside.sidebar::after,
|
|
||||||
nav.contents::after,
|
|
||||||
aside.topic::after,
|
|
||||||
div.topic::after,
|
|
||||||
div.admonition::after,
|
|
||||||
blockquote::after {
|
|
||||||
display: block;
|
|
||||||
content: '';
|
|
||||||
clear: both;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* -- tables ---------------------------------------------------------------- */
|
|
||||||
|
|
||||||
table.docutils {
|
|
||||||
margin-top: 10px;
|
|
||||||
margin-bottom: 10px;
|
|
||||||
border: 0;
|
|
||||||
border-collapse: collapse;
|
|
||||||
}
|
|
||||||
|
|
||||||
table.align-center {
|
|
||||||
margin-left: auto;
|
|
||||||
margin-right: auto;
|
|
||||||
}
|
|
||||||
|
|
||||||
table.align-default {
|
|
||||||
margin-left: auto;
|
|
||||||
margin-right: auto;
|
|
||||||
}
|
|
||||||
|
|
||||||
table caption span.caption-number {
|
|
||||||
font-style: italic;
|
|
||||||
}
|
|
||||||
|
|
||||||
table caption span.caption-text {
|
|
||||||
}
|
|
||||||
|
|
||||||
table.docutils td, table.docutils th {
|
|
||||||
padding: 1px 8px 1px 5px;
|
|
||||||
border-top: 0;
|
|
||||||
border-left: 0;
|
|
||||||
border-right: 0;
|
|
||||||
border-bottom: 1px solid #aaa;
|
|
||||||
}
|
|
||||||
|
|
||||||
th {
|
|
||||||
text-align: left;
|
|
||||||
padding-right: 5px;
|
|
||||||
}
|
|
||||||
|
|
||||||
table.citation {
|
|
||||||
border-left: solid 1px gray;
|
|
||||||
margin-left: 1px;
|
|
||||||
}
|
|
||||||
|
|
||||||
table.citation td {
|
|
||||||
border-bottom: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
th > :first-child,
|
|
||||||
td > :first-child {
|
|
||||||
margin-top: 0px;
|
|
||||||
}
|
|
||||||
|
|
||||||
th > :last-child,
|
|
||||||
td > :last-child {
|
|
||||||
margin-bottom: 0px;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* -- figures --------------------------------------------------------------- */
|
|
||||||
|
|
||||||
div.figure, figure {
|
|
||||||
margin: 0.5em;
|
|
||||||
padding: 0.5em;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.figure p.caption, figcaption {
|
|
||||||
padding: 0.3em;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.figure p.caption span.caption-number,
|
|
||||||
figcaption span.caption-number {
|
|
||||||
font-style: italic;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.figure p.caption span.caption-text,
|
|
||||||
figcaption span.caption-text {
|
|
||||||
}
|
|
||||||
|
|
||||||
/* -- field list styles ----------------------------------------------------- */
|
|
||||||
|
|
||||||
table.field-list td, table.field-list th {
|
|
||||||
border: 0 !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.field-list ul {
|
|
||||||
margin: 0;
|
|
||||||
padding-left: 1em;
|
|
||||||
}
|
|
||||||
|
|
||||||
.field-list p {
|
|
||||||
margin: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
.field-name {
|
|
||||||
-moz-hyphens: manual;
|
|
||||||
-ms-hyphens: manual;
|
|
||||||
-webkit-hyphens: manual;
|
|
||||||
hyphens: manual;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* -- hlist styles ---------------------------------------------------------- */
|
|
||||||
|
|
||||||
table.hlist {
|
|
||||||
margin: 1em 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
table.hlist td {
|
|
||||||
vertical-align: top;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* -- object description styles --------------------------------------------- */
|
|
||||||
|
|
||||||
.sig {
|
|
||||||
font-family: 'Consolas', 'Menlo', 'DejaVu Sans Mono', 'Bitstream Vera Sans Mono', monospace;
|
|
||||||
}
|
|
||||||
|
|
||||||
.sig-name, code.descname {
|
|
||||||
background-color: transparent;
|
|
||||||
font-weight: bold;
|
|
||||||
}
|
|
||||||
|
|
||||||
.sig-name {
|
|
||||||
font-size: 1.1em;
|
|
||||||
}
|
|
||||||
|
|
||||||
code.descname {
|
|
||||||
font-size: 1.2em;
|
|
||||||
}
|
|
||||||
|
|
||||||
.sig-prename, code.descclassname {
|
|
||||||
background-color: transparent;
|
|
||||||
}
|
|
||||||
|
|
||||||
.optional {
|
|
||||||
font-size: 1.3em;
|
|
||||||
}
|
|
||||||
|
|
||||||
.sig-paren {
|
|
||||||
font-size: larger;
|
|
||||||
}
|
|
||||||
|
|
||||||
.sig-param.n {
|
|
||||||
font-style: italic;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* C++ specific styling */
|
|
||||||
|
|
||||||
.sig-inline.c-texpr,
|
|
||||||
.sig-inline.cpp-texpr {
|
|
||||||
font-family: unset;
|
|
||||||
}
|
|
||||||
|
|
||||||
.sig.c .k, .sig.c .kt,
|
|
||||||
.sig.cpp .k, .sig.cpp .kt {
|
|
||||||
color: #0033B3;
|
|
||||||
}
|
|
||||||
|
|
||||||
.sig.c .m,
|
|
||||||
.sig.cpp .m {
|
|
||||||
color: #1750EB;
|
|
||||||
}
|
|
||||||
|
|
||||||
.sig.c .s, .sig.c .sc,
|
|
||||||
.sig.cpp .s, .sig.cpp .sc {
|
|
||||||
color: #067D17;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* -- other body styles ----------------------------------------------------- */
|
|
||||||
|
|
||||||
ol.arabic {
|
|
||||||
list-style: decimal;
|
|
||||||
}
|
|
||||||
|
|
||||||
ol.loweralpha {
|
|
||||||
list-style: lower-alpha;
|
|
||||||
}
|
|
||||||
|
|
||||||
ol.upperalpha {
|
|
||||||
list-style: upper-alpha;
|
|
||||||
}
|
|
||||||
|
|
||||||
ol.lowerroman {
|
|
||||||
list-style: lower-roman;
|
|
||||||
}
|
|
||||||
|
|
||||||
ol.upperroman {
|
|
||||||
list-style: upper-roman;
|
|
||||||
}
|
|
||||||
|
|
||||||
:not(li) > ol > li:first-child > :first-child,
|
|
||||||
:not(li) > ul > li:first-child > :first-child {
|
|
||||||
margin-top: 0px;
|
|
||||||
}
|
|
||||||
|
|
||||||
:not(li) > ol > li:last-child > :last-child,
|
|
||||||
:not(li) > ul > li:last-child > :last-child {
|
|
||||||
margin-bottom: 0px;
|
|
||||||
}
|
|
||||||
|
|
||||||
ol.simple ol p,
|
|
||||||
ol.simple ul p,
|
|
||||||
ul.simple ol p,
|
|
||||||
ul.simple ul p {
|
|
||||||
margin-top: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
ol.simple > li:not(:first-child) > p,
|
|
||||||
ul.simple > li:not(:first-child) > p {
|
|
||||||
margin-top: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
ol.simple p,
|
|
||||||
ul.simple p {
|
|
||||||
margin-bottom: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
aside.footnote > span,
|
|
||||||
div.citation > span {
|
|
||||||
float: left;
|
|
||||||
}
|
|
||||||
aside.footnote > span:last-of-type,
|
|
||||||
div.citation > span:last-of-type {
|
|
||||||
padding-right: 0.5em;
|
|
||||||
}
|
|
||||||
aside.footnote > p {
|
|
||||||
margin-left: 2em;
|
|
||||||
}
|
|
||||||
div.citation > p {
|
|
||||||
margin-left: 4em;
|
|
||||||
}
|
|
||||||
aside.footnote > p:last-of-type,
|
|
||||||
div.citation > p:last-of-type {
|
|
||||||
margin-bottom: 0em;
|
|
||||||
}
|
|
||||||
aside.footnote > p:last-of-type:after,
|
|
||||||
div.citation > p:last-of-type:after {
|
|
||||||
content: "";
|
|
||||||
clear: both;
|
|
||||||
}
|
|
||||||
|
|
||||||
dl.field-list {
|
|
||||||
display: grid;
|
|
||||||
grid-template-columns: fit-content(30%) auto;
|
|
||||||
}
|
|
||||||
|
|
||||||
dl.field-list > dt {
|
|
||||||
font-weight: bold;
|
|
||||||
word-break: break-word;
|
|
||||||
padding-left: 0.5em;
|
|
||||||
padding-right: 5px;
|
|
||||||
}
|
|
||||||
|
|
||||||
dl.field-list > dd {
|
|
||||||
padding-left: 0.5em;
|
|
||||||
margin-top: 0em;
|
|
||||||
margin-left: 0em;
|
|
||||||
margin-bottom: 0em;
|
|
||||||
}
|
|
||||||
|
|
||||||
dl {
|
|
||||||
margin-bottom: 15px;
|
|
||||||
}
|
|
||||||
|
|
||||||
dd > :first-child {
|
|
||||||
margin-top: 0px;
|
|
||||||
}
|
|
||||||
|
|
||||||
dd ul, dd table {
|
|
||||||
margin-bottom: 10px;
|
|
||||||
}
|
|
||||||
|
|
||||||
dd {
|
|
||||||
margin-top: 3px;
|
|
||||||
margin-bottom: 10px;
|
|
||||||
margin-left: 30px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.sig dd {
|
|
||||||
margin-top: 0px;
|
|
||||||
margin-bottom: 0px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.sig dl {
|
|
||||||
margin-top: 0px;
|
|
||||||
margin-bottom: 0px;
|
|
||||||
}
|
|
||||||
|
|
||||||
dl > dd:last-child,
|
|
||||||
dl > dd:last-child > :last-child {
|
|
||||||
margin-bottom: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
dt:target, span.highlighted {
|
|
||||||
background-color: #fbe54e;
|
|
||||||
}
|
|
||||||
|
|
||||||
rect.highlighted {
|
|
||||||
fill: #fbe54e;
|
|
||||||
}
|
|
||||||
|
|
||||||
dl.glossary dt {
|
|
||||||
font-weight: bold;
|
|
||||||
font-size: 1.1em;
|
|
||||||
}
|
|
||||||
|
|
||||||
.versionmodified {
|
|
||||||
font-style: italic;
|
|
||||||
}
|
|
||||||
|
|
||||||
.system-message {
|
|
||||||
background-color: #fda;
|
|
||||||
padding: 5px;
|
|
||||||
border: 3px solid red;
|
|
||||||
}
|
|
||||||
|
|
||||||
.footnote:target {
|
|
||||||
background-color: #ffa;
|
|
||||||
}
|
|
||||||
|
|
||||||
.line-block {
|
|
||||||
display: block;
|
|
||||||
margin-top: 1em;
|
|
||||||
margin-bottom: 1em;
|
|
||||||
}
|
|
||||||
|
|
||||||
.line-block .line-block {
|
|
||||||
margin-top: 0;
|
|
||||||
margin-bottom: 0;
|
|
||||||
margin-left: 1.5em;
|
|
||||||
}
|
|
||||||
|
|
||||||
.guilabel, .menuselection {
|
|
||||||
font-family: sans-serif;
|
|
||||||
}
|
|
||||||
|
|
||||||
.accelerator {
|
|
||||||
text-decoration: underline;
|
|
||||||
}
|
|
||||||
|
|
||||||
.classifier {
|
|
||||||
font-style: oblique;
|
|
||||||
}
|
|
||||||
|
|
||||||
.classifier:before {
|
|
||||||
font-style: normal;
|
|
||||||
margin: 0 0.5em;
|
|
||||||
content: ":";
|
|
||||||
display: inline-block;
|
|
||||||
}
|
|
||||||
|
|
||||||
abbr, acronym {
|
|
||||||
border-bottom: dotted 1px;
|
|
||||||
cursor: help;
|
|
||||||
}
|
|
||||||
|
|
||||||
.translated {
|
|
||||||
background-color: rgba(207, 255, 207, 0.2)
|
|
||||||
}
|
|
||||||
|
|
||||||
.untranslated {
|
|
||||||
background-color: rgba(255, 207, 207, 0.2)
|
|
||||||
}
|
|
||||||
|
|
||||||
/* -- code displays --------------------------------------------------------- */
|
|
||||||
|
|
||||||
pre {
|
|
||||||
overflow: auto;
|
|
||||||
overflow-y: hidden; /* fixes display issues on Chrome browsers */
|
|
||||||
}
|
|
||||||
|
|
||||||
pre, div[class*="highlight-"] {
|
|
||||||
clear: both;
|
|
||||||
}
|
|
||||||
|
|
||||||
span.pre {
|
|
||||||
-moz-hyphens: none;
|
|
||||||
-ms-hyphens: none;
|
|
||||||
-webkit-hyphens: none;
|
|
||||||
hyphens: none;
|
|
||||||
white-space: nowrap;
|
|
||||||
}
|
|
||||||
|
|
||||||
div[class*="highlight-"] {
|
|
||||||
margin: 1em 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
td.linenos pre {
|
|
||||||
border: 0;
|
|
||||||
background-color: transparent;
|
|
||||||
color: #aaa;
|
|
||||||
}
|
|
||||||
|
|
||||||
table.highlighttable {
|
|
||||||
display: block;
|
|
||||||
}
|
|
||||||
|
|
||||||
table.highlighttable tbody {
|
|
||||||
display: block;
|
|
||||||
}
|
|
||||||
|
|
||||||
table.highlighttable tr {
|
|
||||||
display: flex;
|
|
||||||
}
|
|
||||||
|
|
||||||
table.highlighttable td {
|
|
||||||
margin: 0;
|
|
||||||
padding: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
table.highlighttable td.linenos {
|
|
||||||
padding-right: 0.5em;
|
|
||||||
}
|
|
||||||
|
|
||||||
table.highlighttable td.code {
|
|
||||||
flex: 1;
|
|
||||||
overflow: hidden;
|
|
||||||
}
|
|
||||||
|
|
||||||
.highlight .hll {
|
|
||||||
display: block;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.highlight pre,
|
|
||||||
table.highlighttable pre {
|
|
||||||
margin: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.code-block-caption + div {
|
|
||||||
margin-top: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.code-block-caption {
|
|
||||||
margin-top: 1em;
|
|
||||||
padding: 2px 5px;
|
|
||||||
font-size: small;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.code-block-caption code {
|
|
||||||
background-color: transparent;
|
|
||||||
}
|
|
||||||
|
|
||||||
table.highlighttable td.linenos,
|
|
||||||
span.linenos,
|
|
||||||
div.highlight span.gp { /* gp: Generic.Prompt */
|
|
||||||
user-select: none;
|
|
||||||
-webkit-user-select: text; /* Safari fallback only */
|
|
||||||
-webkit-user-select: none; /* Chrome/Safari */
|
|
||||||
-moz-user-select: none; /* Firefox */
|
|
||||||
-ms-user-select: none; /* IE10+ */
|
|
||||||
}
|
|
||||||
|
|
||||||
div.code-block-caption span.caption-number {
|
|
||||||
padding: 0.1em 0.3em;
|
|
||||||
font-style: italic;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.code-block-caption span.caption-text {
|
|
||||||
}
|
|
||||||
|
|
||||||
div.literal-block-wrapper {
|
|
||||||
margin: 1em 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
code.xref, a code {
|
|
||||||
background-color: transparent;
|
|
||||||
font-weight: bold;
|
|
||||||
}
|
|
||||||
|
|
||||||
h1 code, h2 code, h3 code, h4 code, h5 code, h6 code {
|
|
||||||
background-color: transparent;
|
|
||||||
}
|
|
||||||
|
|
||||||
.viewcode-link {
|
|
||||||
float: right;
|
|
||||||
}
|
|
||||||
|
|
||||||
.viewcode-back {
|
|
||||||
float: right;
|
|
||||||
font-family: sans-serif;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.viewcode-block:target {
|
|
||||||
margin: -1px -10px;
|
|
||||||
padding: 0 10px;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* -- math display ---------------------------------------------------------- */
|
|
||||||
|
|
||||||
img.math {
|
|
||||||
vertical-align: middle;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.body div.math p {
|
|
||||||
text-align: center;
|
|
||||||
}
|
|
||||||
|
|
||||||
span.eqno {
|
|
||||||
float: right;
|
|
||||||
}
|
|
||||||
|
|
||||||
span.eqno a.headerlink {
|
|
||||||
position: absolute;
|
|
||||||
z-index: 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.math:hover a.headerlink {
|
|
||||||
visibility: visible;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* -- printout stylesheet --------------------------------------------------- */
|
|
||||||
|
|
||||||
@media print {
|
|
||||||
div.document,
|
|
||||||
div.documentwrapper,
|
|
||||||
div.bodywrapper {
|
|
||||||
margin: 0 !important;
|
|
||||||
width: 100%;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.sphinxsidebar,
|
|
||||||
div.related,
|
|
||||||
div.footer,
|
|
||||||
#top-link {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
}
|
|
@ -1 +0,0 @@
|
|||||||
.clearfix{*zoom:1}.clearfix:after,.clearfix:before{display:table;content:""}.clearfix:after{clear:both}@font-face{font-family:FontAwesome;font-style:normal;font-weight:400;src:url(fonts/fontawesome-webfont.eot?674f50d287a8c48dc19ba404d20fe713?#iefix) format("embedded-opentype"),url(fonts/fontawesome-webfont.woff2?af7ae505a9eed503f8b8e6982036873e) format("woff2"),url(fonts/fontawesome-webfont.woff?fee66e712a8a08eef5805a46892932ad) format("woff"),url(fonts/fontawesome-webfont.ttf?b06871f281fee6b241d60582ae9369b9) format("truetype"),url(fonts/fontawesome-webfont.svg?912ec66d7572ff821749319396470bde#FontAwesome) format("svg")}.fa:before{font-family:FontAwesome;font-style:normal;font-weight:400;line-height:1}.fa:before,a .fa{text-decoration:inherit}.fa:before,a .fa,li .fa{display:inline-block}li .fa-large:before{width:1.875em}ul.fas{list-style-type:none;margin-left:2em;text-indent:-.8em}ul.fas li .fa{width:.8em}ul.fas li .fa-large:before{vertical-align:baseline}.fa-book:before,.icon-book:before{content:"\f02d"}.fa-caret-down:before,.icon-caret-down:before{content:"\f0d7"}.fa-caret-up:before,.icon-caret-up:before{content:"\f0d8"}.fa-caret-left:before,.icon-caret-left:before{content:"\f0d9"}.fa-caret-right:before,.icon-caret-right:before{content:"\f0da"}.rst-versions{position:fixed;bottom:0;left:0;width:300px;color:#fcfcfc;background:#1f1d1d;font-family:Lato,proxima-nova,Helvetica Neue,Arial,sans-serif;z-index:400}.rst-versions a{color:#2980b9;text-decoration:none}.rst-versions .rst-badge-small{display:none}.rst-versions .rst-current-version{padding:12px;background-color:#272525;display:block;text-align:right;font-size:90%;cursor:pointer;color:#27ae60}.rst-versions .rst-current-version:after{clear:both;content:"";display:block}.rst-versions .rst-current-version .fa{color:#fcfcfc}.rst-versions .rst-current-version .fa-book,.rst-versions .rst-current-version .icon-book{float:left}.rst-versions .rst-current-version.rst-out-of-date{background-color:#e74c3c;color:#fff}.rst-versions .rst-current-version.rst-active-old-version{background-color:#f1c40f;color:#000}.rst-versions.shift-up{height:auto;max-height:100%;overflow-y:scroll}.rst-versions.shift-up .rst-other-versions{display:block}.rst-versions .rst-other-versions{font-size:90%;padding:12px;color:grey;display:none}.rst-versions .rst-other-versions hr{display:block;height:1px;border:0;margin:20px 0;padding:0;border-top:1px solid #413d3d}.rst-versions .rst-other-versions dd{display:inline-block;margin:0}.rst-versions .rst-other-versions dd a{display:inline-block;padding:6px;color:#fcfcfc}.rst-versions .rst-other-versions .rtd-current-item{font-weight:700}.rst-versions.rst-badge{width:auto;bottom:20px;right:20px;left:auto;border:none;max-width:300px;max-height:90%}.rst-versions.rst-badge .fa-book,.rst-versions.rst-badge .icon-book{float:none;line-height:30px}.rst-versions.rst-badge.shift-up .rst-current-version{text-align:right}.rst-versions.rst-badge.shift-up .rst-current-version .fa-book,.rst-versions.rst-badge.shift-up .rst-current-version .icon-book{float:left}.rst-versions.rst-badge>.rst-current-version{width:auto;height:30px;line-height:30px;padding:0 6px;display:block;text-align:center}@media screen and (max-width:768px){.rst-versions{width:85%;display:none}.rst-versions.shift{display:block}}#flyout-search-form{padding:6px}
|
|
@ -1,884 +0,0 @@
|
|||||||
@import url(https://fonts.googleapis.com/css?family=Audiowide);
|
|
||||||
@import url(https://fonts.googleapis.com/css?family=Roboto);
|
|
||||||
|
|
||||||
h1, .h1 {
|
|
||||||
font-family: Audiowide,Helvetica,Arial,sans-serif !important;
|
|
||||||
font-weight: 500 !important;
|
|
||||||
color: #00353d !important;
|
|
||||||
/* font-size: 200% !important; */
|
|
||||||
font-size: 180% !important;
|
|
||||||
text-shadow: 1px 1px #ffffff78;
|
|
||||||
}
|
|
||||||
html[data-theme='dark'] h1, .h1 {
|
|
||||||
color: #ffffff !important;
|
|
||||||
text-shadow: 1px 1px #00353d;
|
|
||||||
}
|
|
||||||
|
|
||||||
h2, .h2 {
|
|
||||||
font-family: Roboto,Helvetica,Arial,sans-serif !important;
|
|
||||||
color: #00353d !important;
|
|
||||||
/* font-size: 190% !important; */
|
|
||||||
font-size: 160% !important;
|
|
||||||
text-shadow: 1px 1px #ffffff78;
|
|
||||||
}
|
|
||||||
html[data-theme='dark'] h2, .h2 {
|
|
||||||
color: #ffffff !important;
|
|
||||||
text-shadow: 1px 1px #00353d;
|
|
||||||
}
|
|
||||||
html[data-theme='dark'] h2 a,
|
|
||||||
html[data-theme='dark'] h2 a:visited {
|
|
||||||
color: #00a3b9ff !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
h3, .h3 {
|
|
||||||
font-family: Roboto,Helvetica,Arial,sans-serif !important;
|
|
||||||
color: #00353d !important;
|
|
||||||
/* font-size: 160% !important; */
|
|
||||||
font-size: 140% !important;
|
|
||||||
font-style: italic !important;
|
|
||||||
text-shadow: 1px 1px #ffffff78;
|
|
||||||
}
|
|
||||||
html[data-theme='dark'] h3, .h3 {
|
|
||||||
color: #ffffff !important;
|
|
||||||
text-shadow: 1px 1px #00353d;
|
|
||||||
}
|
|
||||||
html[data-theme='dark'] h3 a,
|
|
||||||
html[data-theme='dark'] h3 a:visited {
|
|
||||||
color: #00a3b9ff !important;
|
|
||||||
}
|
|
||||||
h4, .h4 {
|
|
||||||
font-family: Roboto,Helvetica,Arial,sans-serif !important;
|
|
||||||
color: #00353d !important;
|
|
||||||
/* font-size: 130% !important; */
|
|
||||||
font-size: 120% !important;
|
|
||||||
text-shadow: 1px 1px #ffffff78;
|
|
||||||
}
|
|
||||||
html[data-theme='dark'] h4, .h4 {
|
|
||||||
color: #00a3b9ff !important;
|
|
||||||
text-shadow: 1px 1px #00353d;
|
|
||||||
}
|
|
||||||
html[data-theme='dark'] h4 a,
|
|
||||||
html[data-theme='dark'] h4 a:visited {
|
|
||||||
color: #00a3b9ff !important;
|
|
||||||
text-shadow: 1px 1px #00353d;
|
|
||||||
}
|
|
||||||
h5, .h5 {
|
|
||||||
font-family: Roboto,Helvetica,Arial,sans-serif !important;
|
|
||||||
color: #00a3b9ff !important;
|
|
||||||
/* font-size: 110% !important; */
|
|
||||||
font-size: 100% !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
h6, .h6 {
|
|
||||||
font-family: Roboto,Helvetica,Arial,sans-serif !important;
|
|
||||||
color: #00a3b9ff !important;
|
|
||||||
font-size: 90% !important;
|
|
||||||
font-style: italic !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.clearer {
|
|
||||||
clear: both;
|
|
||||||
}
|
|
||||||
|
|
||||||
.wy-nav-side {
|
|
||||||
background: #031c20 !important;
|
|
||||||
/* background: #031214 !important; */
|
|
||||||
}
|
|
||||||
|
|
||||||
.caption-text {
|
|
||||||
color: #00a3b9ff !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.wy-nav-top {
|
|
||||||
background:#00a3b9ff !important;
|
|
||||||
font-size: 80% !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.wy-nav-top a {
|
|
||||||
font-family: Audiowide,Helvetica,Arial,sans-serif !important;
|
|
||||||
font-weight: 100 !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.wy-nav-content {
|
|
||||||
max-width: 1024px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.wy-breadcrumbs {
|
|
||||||
font-family: Roboto,Helvetica,Arial,sans-serif !important;
|
|
||||||
font-size: 80% !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.wy-side-nav-search>a img.logo {
|
|
||||||
width: 100%;
|
|
||||||
}
|
|
||||||
|
|
||||||
.rst-content table.docutils th {
|
|
||||||
background-color: #F3F6F6;
|
|
||||||
}
|
|
||||||
|
|
||||||
.rst-content table.docutils td {
|
|
||||||
background-color: #F3F6F6;
|
|
||||||
}
|
|
||||||
|
|
||||||
.rst-content table.docutils:not(.field-list) tr:nth-child(2n-1) td {
|
|
||||||
background-color: #E0E0E0;
|
|
||||||
}
|
|
||||||
html[data-theme='dark'] .rst-content table.docutils:not(.field-list) tr:nth-child(2n-1) td {
|
|
||||||
background-color: #ffffff08 !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.caption-number {
|
|
||||||
font-size: small !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.caption-text {
|
|
||||||
font-size: small !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
table.intro-table {
|
|
||||||
max-width: 600px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.intro-table img {
|
|
||||||
width: 70%;
|
|
||||||
height: auto;
|
|
||||||
margin: 5% 15%;
|
|
||||||
}
|
|
||||||
|
|
||||||
html[data-theme='dark'] .btn-neutral {
|
|
||||||
color: #c1c1c1 !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
#ex-rail-command-summary .wy-table-responsive {
|
|
||||||
overflow: visible;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* product titles */
|
|
||||||
.ex-prefix {
|
|
||||||
font-weight: bold;
|
|
||||||
color: #00a3b9;
|
|
||||||
font-size: 110%;
|
|
||||||
}
|
|
||||||
.ex-suffix {
|
|
||||||
font-weight: bold;
|
|
||||||
color: #00353d;
|
|
||||||
font-size: 110%;
|
|
||||||
}
|
|
||||||
html[data-theme='dark'] .ex-suffix {
|
|
||||||
font-weight: bold;
|
|
||||||
color: #006979;
|
|
||||||
font-size: 110%;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* main dcc-ex text only */
|
|
||||||
.dccex-prefix {
|
|
||||||
font-family: Audiowide,Helvetica,Arial,sans-serif;
|
|
||||||
font-weight: 600;
|
|
||||||
color: #00353d;
|
|
||||||
font-size: 110%;
|
|
||||||
}
|
|
||||||
html[data-theme='dark'] .dccex-prefix {
|
|
||||||
font-family: Audiowide,Helvetica,Arial,sans-serif;
|
|
||||||
font-weight: 600;
|
|
||||||
color: #006979;
|
|
||||||
font-size: 110%;
|
|
||||||
}
|
|
||||||
.dccex-suffix {
|
|
||||||
font-family: Audiowide,Helvetica,Arial,sans-serif;
|
|
||||||
font-weight: 600;
|
|
||||||
color: #00a3b9;
|
|
||||||
font-size: 110%;
|
|
||||||
}
|
|
||||||
|
|
||||||
/***************************/
|
|
||||||
|
|
||||||
.command-table thead th {
|
|
||||||
text-align: center;
|
|
||||||
}
|
|
||||||
|
|
||||||
.command-table tbody td {
|
|
||||||
white-space: normal;
|
|
||||||
margin: 10px;
|
|
||||||
padding: 8px 8px 8px 8px !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.command-table tbody tr:first-child td p code {
|
|
||||||
white-space: nowrap !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.command-table tbody tr td p code {
|
|
||||||
font-size: 110% !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.command-table tbody tr td p {
|
|
||||||
font-size: 90% !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.command-table tbody tr td ol li p {
|
|
||||||
font-size: 90% !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.command-table tbody tr td ol {
|
|
||||||
margin-bottom: 0px !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.command-table .category {
|
|
||||||
display: block;
|
|
||||||
text-align: center;
|
|
||||||
}
|
|
||||||
|
|
||||||
.command-table tr:nth-child(odd) {
|
|
||||||
background-color: #f1f1f1 !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.command-table tr:nth-child(even) {
|
|
||||||
background-color: #f8f8f8 !important;
|
|
||||||
}
|
|
||||||
html[data-theme='dark'] .command-table tr:nth-child(even) {
|
|
||||||
background-color: #ffffff08 !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.command-table td {
|
|
||||||
background-color: #ffffff00 !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* html[data-theme='dark'] .rst-content table.docutils tr:nth-child(odd) {
|
|
||||||
background-color: #ffffff08 !important;
|
|
||||||
} */
|
|
||||||
html[data-theme='dark'] .rst-content table.docutils td, .wy-table-bordered-all td {
|
|
||||||
background-color: #fff40000 !important;
|
|
||||||
}
|
|
||||||
/* html[data-theme='dark'] .rst-content table.docutils .row-odd {
|
|
||||||
background-color: #36ff0000 !important;
|
|
||||||
} */
|
|
||||||
|
|
||||||
html[data-theme='dark'] .rst-content table.docutils th {
|
|
||||||
background-color: #36ff0000 !important;
|
|
||||||
color: white !important;
|
|
||||||
font-style: italic !important;;
|
|
||||||
font-weight: 700 !important;;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* *************************************** */
|
|
||||||
|
|
||||||
html[data-theme='dark'] .sd-card {
|
|
||||||
background-color: #0000008a;
|
|
||||||
box-shadow: 0 0.5rem 1rem rgb(32 88 91 / 25%) !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* *************************************** */
|
|
||||||
|
|
||||||
.dcclink a {
|
|
||||||
background-color: #00a3b9ff;
|
|
||||||
box-shadow: 0 2px 0 #00353dff;
|
|
||||||
color: white !important;
|
|
||||||
padding: 0.5em 0.5em;
|
|
||||||
position: relative;
|
|
||||||
text-decoration: none;
|
|
||||||
text-transform: none;
|
|
||||||
border-radius: 5px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.dcclink-right a {
|
|
||||||
background-color: #00a3b9ff;
|
|
||||||
box-shadow: 0 2px 0 #00353dff;
|
|
||||||
color: white !important;
|
|
||||||
padding: 0.5em 0.5em;
|
|
||||||
position: relative;
|
|
||||||
text-decoration: none;
|
|
||||||
text-transform: none;
|
|
||||||
border-radius: 10px;
|
|
||||||
float:right;
|
|
||||||
margin: 0px 0px 0px 10px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.dcclink a:visited {
|
|
||||||
color: whitesmoke !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.dcclink a:hover {
|
|
||||||
background-color: darkslategrey;
|
|
||||||
cursor: pointer;
|
|
||||||
}
|
|
||||||
|
|
||||||
.dcclink a:active {
|
|
||||||
box-shadow: none;
|
|
||||||
top: 5px;
|
|
||||||
}
|
|
||||||
|
|
||||||
html[data-theme='dark'] .rst-content .guilabel {
|
|
||||||
color: black;
|
|
||||||
}
|
|
||||||
|
|
||||||
.hr-dashed {
|
|
||||||
margin: -10px 0px -10px 0px;
|
|
||||||
border-top: 1px dashed #d2dfe3;
|
|
||||||
}
|
|
||||||
|
|
||||||
.hr-heavy {
|
|
||||||
margin: -10px 0px -10px 0px;
|
|
||||||
border-top: 5px solid #d2dfe3;
|
|
||||||
}
|
|
||||||
|
|
||||||
html[data-theme='dark'] .hr-dashed {
|
|
||||||
border-top: 1px dashed #114759;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* *************************************** */
|
|
||||||
|
|
||||||
a.githublink, .githublink a {
|
|
||||||
background-color: #f7b656;
|
|
||||||
box-shadow: 0 2px 0 #00353dff;
|
|
||||||
color: white;
|
|
||||||
padding: 3px 5px 3px 5px;
|
|
||||||
position: relative;
|
|
||||||
font-size: 90% !important;
|
|
||||||
text-decoration: none;
|
|
||||||
text-transform: none;
|
|
||||||
border-radius: 5px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.githublink-right a {
|
|
||||||
background-color: #f7b656;
|
|
||||||
box-shadow: 0 2px 0 #00353dff;
|
|
||||||
color: white;
|
|
||||||
padding: 3px 5px 3px 5px;
|
|
||||||
position: relative;
|
|
||||||
font-size: 90% !important;
|
|
||||||
text-decoration: none;
|
|
||||||
text-transform: none;
|
|
||||||
border-radius: 10px;
|
|
||||||
float:right;
|
|
||||||
margin: 0px 0px 0px 0px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.githublink a:visited {
|
|
||||||
color: whitesmoke
|
|
||||||
}
|
|
||||||
|
|
||||||
.githublink a:hover {
|
|
||||||
background-color: rgb(172, 95, 7);
|
|
||||||
cursor: pointer;
|
|
||||||
}
|
|
||||||
|
|
||||||
.githublink a:active {
|
|
||||||
box-shadow: none;
|
|
||||||
top: 5px;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* *************************************** */
|
|
||||||
|
|
||||||
svg {
|
|
||||||
max-width: 100%;
|
|
||||||
height: auto;
|
|
||||||
}
|
|
||||||
|
|
||||||
.responsive-image {
|
|
||||||
max-width: 100%;
|
|
||||||
height: auto;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* *************************************** */
|
|
||||||
|
|
||||||
.warning-float-right {
|
|
||||||
float: right;
|
|
||||||
width: 40%;
|
|
||||||
}
|
|
||||||
|
|
||||||
.warning-float-right-narrow {
|
|
||||||
float: right;
|
|
||||||
width: 20%;
|
|
||||||
}
|
|
||||||
|
|
||||||
.warning-float-right-wide {
|
|
||||||
float: right;
|
|
||||||
width: 60%;
|
|
||||||
}
|
|
||||||
|
|
||||||
.note-float-right {
|
|
||||||
float: right;
|
|
||||||
width: 40%;
|
|
||||||
}
|
|
||||||
|
|
||||||
.note-float-right-narrow {
|
|
||||||
float: right;
|
|
||||||
width: 20%;
|
|
||||||
}
|
|
||||||
|
|
||||||
.code-block-float-right {
|
|
||||||
float: right;
|
|
||||||
width: 40%;
|
|
||||||
margin: 0px 0px 0px 24px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.note {
|
|
||||||
background: #f7fcff !important;
|
|
||||||
clear: none !important;
|
|
||||||
}
|
|
||||||
html[data-theme='dark'] .note {
|
|
||||||
background: #ffffff24 !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.note p.admonition-title {
|
|
||||||
background: #cbe1ef !important;
|
|
||||||
}
|
|
||||||
html[data-theme='dark'] .note p.admonition-title {
|
|
||||||
background: #256a97 !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.tip {
|
|
||||||
background: #eef5f4 !important;
|
|
||||||
clear: none !important;
|
|
||||||
}
|
|
||||||
html[data-theme='dark'] .tip {
|
|
||||||
background: #ffffff24 !important;
|
|
||||||
clear: none !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.tip p.admonition-title {
|
|
||||||
background: #9cd7cb !important;
|
|
||||||
}
|
|
||||||
html[data-theme='dark'] .tip p.admonition-title {
|
|
||||||
background: #256a97 !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.admonition-todo {
|
|
||||||
background: #f9f0e0 !important;
|
|
||||||
clear: none !important;
|
|
||||||
}
|
|
||||||
html[data-theme='dark'] .admonition-todo {
|
|
||||||
background: #ffffff24 !important;
|
|
||||||
clear: none !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.admonition-todo p.admonition-title {
|
|
||||||
background: #f7d1b0 !important;
|
|
||||||
}
|
|
||||||
html[data-theme='dark'] .admonition-todo p.admonition-title {
|
|
||||||
background: #6d3403 !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* *************************************** */
|
|
||||||
|
|
||||||
.menuselection {
|
|
||||||
font-style: italic;
|
|
||||||
font-weight: 700;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* *************************************** */
|
|
||||||
|
|
||||||
.wy-table-responsive {
|
|
||||||
margin-bottom: 12px !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* override table width restrictions */
|
|
||||||
.table-wrap-text p, .table-grid-homepage p, .table-list-homepage p {
|
|
||||||
white-space: normal !important;
|
|
||||||
font-size: 110% !important;
|
|
||||||
line-height: 140% !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.table-wrap-text tr:nth-child(odd), .table-grid-homepage tr:nth-child(odd), .table-list-homepage tr:nth-child(odd) {
|
|
||||||
background-color: white !important;
|
|
||||||
border-style: none !important;
|
|
||||||
border-width:0px !important;
|
|
||||||
}
|
|
||||||
html[data-theme='dark'] tr:nth-child(odd), .table-grid-homepage tr:nth-child(odd), .table-list-homepage tr:nth-child(odd) {
|
|
||||||
background-color: #ffffff08 !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.table-wrap-text tr:nth-child(even), .table-grid-homepage tr:nth-child(even), .table-list-homepage tr:nth-child(even) {
|
|
||||||
background-color: #ffffff00 !important;
|
|
||||||
border-style: none !important;
|
|
||||||
border-width:0px !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.table-wrap-text td {
|
|
||||||
background-color: white !important;
|
|
||||||
border-style: none !important;
|
|
||||||
border-width:0px !important;
|
|
||||||
}
|
|
||||||
html[data-theme='dark'] .table-wrap-text td {
|
|
||||||
background-color: ffffff08 !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.table-grid-homepage td, .table-list-homepage td {
|
|
||||||
font-size: 80% !important;
|
|
||||||
color: #666666 !important;
|
|
||||||
vertical-align:top !important;
|
|
||||||
background-color: #ffffff00 !important;
|
|
||||||
border-style: none !important;
|
|
||||||
border-width: 0px !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.table-wrap-text, .table-grid-homepage, .table-list-homepage {
|
|
||||||
margin-bottom: 24px;
|
|
||||||
max-width: 100% !important;
|
|
||||||
overflow: visible !important;
|
|
||||||
border-style: none !important;
|
|
||||||
border-width: 0px !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
@media screen and (max-width: 900px) {
|
|
||||||
.table-grid-homepage {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
.table-list-homepage {
|
|
||||||
display: block;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@media not screen and (max-width: 900px) {
|
|
||||||
.table-grid-homepage {
|
|
||||||
display: block;
|
|
||||||
}
|
|
||||||
.table-list-homepage {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
.table-wrap-text th p, table-wrap-text-align-top th p {
|
|
||||||
margin-bottom: unset;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* *************************************** */
|
|
||||||
|
|
||||||
.image-min-width-144 {
|
|
||||||
min-width: 144px;
|
|
||||||
height: auto !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.image-min-width-72 {
|
|
||||||
min-width: 72px;
|
|
||||||
height: auto !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.image-float-right img {
|
|
||||||
float:right;
|
|
||||||
}
|
|
||||||
|
|
||||||
.image-product-logo-float-right img {
|
|
||||||
float:right;
|
|
||||||
}
|
|
||||||
|
|
||||||
@media screen and (max-width: 1000px) {
|
|
||||||
.image-product-logo-float-right img {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* *************************************** */
|
|
||||||
/* Google search */
|
|
||||||
|
|
||||||
.gsc-input-box {
|
|
||||||
border: 0px !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.gsib_a input {
|
|
||||||
padding: 5px !important;
|
|
||||||
background-color: #141414 !important;
|
|
||||||
color:white !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.gsc-search-button .gsc-search-button-v2 {
|
|
||||||
width: 40px !important;
|
|
||||||
height: 21px !important;
|
|
||||||
padding: 4px 4px !important;
|
|
||||||
background-color: #00a3b9ff !important;
|
|
||||||
border-color: #00a3b9ff !important;
|
|
||||||
border-radius: 5px;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* .gsc-search-button .gsc-search-button-v2 {
|
|
||||||
width: 0px !important;
|
|
||||||
padding: 7px 7px !important;
|
|
||||||
border-color: #009300 !important;
|
|
||||||
background-color: #009300 !important;
|
|
||||||
} */
|
|
||||||
|
|
||||||
/* *************************************** */
|
|
||||||
|
|
||||||
/* sidebar level 3 bullet points */
|
|
||||||
nav#on-this-page ul.simple li ul li p {
|
|
||||||
font-family: Roboto,Helvetica,Arial,sans-serif !important;
|
|
||||||
font-size: 80% !important;
|
|
||||||
line-height: 120% !important;
|
|
||||||
margin-bottom: 0px !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* sidebar level 3 bullet points */
|
|
||||||
nav#on-this-page ul.simple li ul li {
|
|
||||||
font-family: Roboto,Helvetica,Arial,sans-serif !important;
|
|
||||||
line-height: 120% !important;
|
|
||||||
margin-bottom: 0px !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* sidebar level 2 bullet points */
|
|
||||||
nav#on-this-page ul.simple li p {
|
|
||||||
font-family: Roboto,Helvetica,Arial,sans-serif !important;
|
|
||||||
font-size: 80% !important;
|
|
||||||
line-height: 120% !important;
|
|
||||||
margin-bottom: 0px !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* sidebar level 2 bullet points */
|
|
||||||
nav#on-this-page ul.simple li {
|
|
||||||
font-family: Roboto,Helvetica,Arial,sans-serif !important;
|
|
||||||
line-height: 120% !important;
|
|
||||||
margin-bottom: 0px !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
nav#on-this-page ul.simple {
|
|
||||||
font-family: Roboto,Helvetica,Arial,sans-serif !important;
|
|
||||||
margin-bottom: 0px !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
nav#on-this-page p {
|
|
||||||
font-family: Roboto,Helvetica,Arial,sans-serif !important;
|
|
||||||
margin-top: 0px !important;
|
|
||||||
margin-bottom: 6px !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
nav#on-this-page {
|
|
||||||
margin-bottom: 10px !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* in-this-section level 3 bullet points */
|
|
||||||
nav.in-this-section ul.simple li ul li p {
|
|
||||||
font-family: Roboto,Helvetica,Arial,sans-serif !important;
|
|
||||||
font-size: 80% !important;
|
|
||||||
line-height: 120% !important;
|
|
||||||
margin-bottom: 0px !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* in-this-section level 3 bullet points */
|
|
||||||
nav.in-this-section ul.simple li ul li {
|
|
||||||
font-family: Roboto,Helvetica,Arial,sans-serif !important;
|
|
||||||
line-height: 120% !important;
|
|
||||||
margin-bottom: 0px !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* in-this-section level 2 bullet points */
|
|
||||||
nav.in-this-section ul.simple li p {
|
|
||||||
font-family: Roboto,Helvetica,Arial,sans-serif !important;
|
|
||||||
font-size: 80% !important;
|
|
||||||
line-height: 120% !important;
|
|
||||||
margin-bottom: 0px !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* in-this-section level 2 bullet points */
|
|
||||||
nav.in-this-section ul.simple li {
|
|
||||||
font-family: Roboto,Helvetica,Arial,sans-serif !important;
|
|
||||||
line-height: 120% !important;
|
|
||||||
margin-bottom: 0px !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
nav.in-this-section ul.simple {
|
|
||||||
font-family: Roboto,Helvetica,Arial,sans-serif !important;
|
|
||||||
margin-bottom: 0px !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
nav.in-this-section p {
|
|
||||||
font-family: Roboto,Helvetica,Arial,sans-serif !important;
|
|
||||||
font-style: italic;
|
|
||||||
font-size: 90%;
|
|
||||||
margin-top: 0px !important;
|
|
||||||
margin-bottom: 6px !important;
|
|
||||||
margin-left: -30px;
|
|
||||||
}
|
|
||||||
|
|
||||||
nav.in-this-section {
|
|
||||||
margin-bottom: 20px !important;
|
|
||||||
margin-left: 30px;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* sidebars */
|
|
||||||
.rst-content .sidebar {
|
|
||||||
padding: 12px 24px 12px 24px !important;
|
|
||||||
border-radius: 10px;
|
|
||||||
}
|
|
||||||
|
|
||||||
html[data-theme='dark'] .rst-content .sidebar {
|
|
||||||
background: #000000ff !important;
|
|
||||||
border:#000000ff !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.sidebar-title {
|
|
||||||
border-radius: 10px;
|
|
||||||
}
|
|
||||||
|
|
||||||
html[data-theme='dark'] .sidebar-title {
|
|
||||||
background: #002735 !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/* news */
|
|
||||||
section#dcc-ex-model-railroading aside p.sidebar-title {
|
|
||||||
font-size: 110% !important;
|
|
||||||
font-family: Audiowide,Helvetica,Arial,sans-serif !important;
|
|
||||||
font-weight: 500 !important;
|
|
||||||
color: #00a3b9ff;
|
|
||||||
text-shadow: 1px 1px 0 #00353dff;
|
|
||||||
margin: -24px -24px 12px !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* news */
|
|
||||||
p.ablog-post-title {
|
|
||||||
font-family: Roboto,Helvetica,Arial,sans-serif !important;
|
|
||||||
font-size: 90% !important;
|
|
||||||
line-height: 130% !important;
|
|
||||||
margin-bottom: 0px !important;
|
|
||||||
font-weight: bold !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
p.ablog-post-excerpt {
|
|
||||||
font-family: Roboto,Helvetica,Arial,sans-serif !important;
|
|
||||||
font-size: 90% !important;
|
|
||||||
line-height: 130% !important;
|
|
||||||
margin-bottom: 0px !important;
|
|
||||||
margin-top: 6px !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
p.ablog-post-expand {
|
|
||||||
font-family: Roboto,Helvetica,Arial,sans-serif !important;
|
|
||||||
font-size: 80% !important;
|
|
||||||
line-height: 130% !important;
|
|
||||||
margin-bottom: 10px !important;
|
|
||||||
margin-top: 0px !important;
|
|
||||||
margin-left: 20px;
|
|
||||||
}
|
|
||||||
|
|
||||||
li.ablog-post {
|
|
||||||
list-style-type: none !important;
|
|
||||||
margin: 0px !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
img.sd-card-img-top {
|
|
||||||
max-width: 30% !important;
|
|
||||||
display: block !important;
|
|
||||||
margin-left: auto !important;
|
|
||||||
margin-right: auto !important;
|
|
||||||
margin-top: 10px;
|
|
||||||
margin-bottom: -5px !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.sd-card-header {
|
|
||||||
margin-bottom: -10px !important;
|
|
||||||
margin-top: 10px !important;
|
|
||||||
padding-top: 0px !important;
|
|
||||||
padding-bottom: 0px !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.sd-card-header p {
|
|
||||||
line-height: 18px !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
html[data-theme='dark'] .sd-card-header {
|
|
||||||
border-bottom: 1px solid rgb(255 253 253 / 13%);
|
|
||||||
}
|
|
||||||
|
|
||||||
.sd-card-body ul li p {
|
|
||||||
margin-bottom: 5px !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.sd-card-text {
|
|
||||||
margin: 0 0 12px !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* code */
|
|
||||||
.rst-content code {
|
|
||||||
font-size: 100% !important;
|
|
||||||
}
|
|
||||||
.rst-content code.literal, .rst-content tt.literal {
|
|
||||||
color: #ba2121 !important;
|
|
||||||
font-size: 100% important;
|
|
||||||
}
|
|
||||||
html[data-theme='dark'] .rst-content code.literal, .rst-content tt.literal {
|
|
||||||
color: #ff6000 !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* general purpose */
|
|
||||||
|
|
||||||
.dcc-ex-red {
|
|
||||||
color:red;
|
|
||||||
}
|
|
||||||
|
|
||||||
.dcc-ex-red-bold {
|
|
||||||
color:red;
|
|
||||||
font-weight: bold !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.dcc-ex-red-bold-italic {
|
|
||||||
color:red;
|
|
||||||
font-weight: bold !important;
|
|
||||||
font-style: italic !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.dcc-ex-code {
|
|
||||||
color:#ba2121;
|
|
||||||
font-weight: bold !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.dcc-ex-text-size-200pct {
|
|
||||||
font-size: 200% !important;
|
|
||||||
line-height: 110% !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.dcc-ex-text-size-80pct {
|
|
||||||
font-size: 80% !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.dcc-ex-text-size-60pct {
|
|
||||||
font-size: 80% !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.new-in-v5 {
|
|
||||||
font-family: Audiowide,Helvetica,Arial,sans-serif;
|
|
||||||
font-weight: bold;
|
|
||||||
font-style: italic;
|
|
||||||
color: #00a3b9;
|
|
||||||
font-size: 110%;
|
|
||||||
}
|
|
||||||
|
|
||||||
html[data-theme='dark'] .new-in-v5 {
|
|
||||||
font-weight: normal;
|
|
||||||
color: #ffffff;
|
|
||||||
text-shadow: 0px 0px 10px #00a3b9;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* *************************************** */
|
|
||||||
|
|
||||||
@media not screen and (max-width: 900px) {
|
|
||||||
div.rst-footer-buttons {
|
|
||||||
position: fixed;
|
|
||||||
bottom:5px;
|
|
||||||
width:350px;
|
|
||||||
background: #c9c9c999;
|
|
||||||
padding: 10px;
|
|
||||||
border-radius: 10px;
|
|
||||||
border-color: white !important;
|
|
||||||
border: 4px solid;
|
|
||||||
transform: translateX(50%);
|
|
||||||
}
|
|
||||||
html[data-theme='dark'] div.rst-footer-buttons {
|
|
||||||
border-color: #141414 !important;
|
|
||||||
background: #c9c9c92e;
|
|
||||||
}
|
|
||||||
footer {
|
|
||||||
padding-bottom: 40px;
|
|
||||||
font-size: 80% !important;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@media screen and (max-width: 900px) {
|
|
||||||
div.rst-footer-buttons {
|
|
||||||
display:block;
|
|
||||||
font-size: 80% !important;
|
|
||||||
}
|
|
||||||
}
|
|
Before Width: | Height: | Size: 434 KiB |
@ -1,9 +0,0 @@
|
|||||||
/* Override for the sphinx-design extension classes */
|
|
||||||
.sd-card-header {
|
|
||||||
font-size: 110% !important;
|
|
||||||
font-family: Audiowide,Helvetica,Arial,sans-serif !important;
|
|
||||||
font-weight: 500 !important;
|
|
||||||
color: #00a3b9ff;
|
|
||||||
text-shadow: 1px 1px 0 #00353dff;
|
|
||||||
margin-bottom: .5rem !important;
|
|
||||||
}
|
|
@ -1,77 +0,0 @@
|
|||||||
.wy-side-nav-search input[type='text'] {
|
|
||||||
border-radius: 3px;
|
|
||||||
}
|
|
||||||
|
|
||||||
input[type='color'],
|
|
||||||
input[type='date'],
|
|
||||||
input[type='datetime-local'],
|
|
||||||
input[type='datetime'],
|
|
||||||
input[type='email'],
|
|
||||||
input[type='month'],
|
|
||||||
input[type='number'],
|
|
||||||
input[type='password'],
|
|
||||||
input[type='search'],
|
|
||||||
input[type='tel'],
|
|
||||||
input[type='text'],
|
|
||||||
input[type='time'],
|
|
||||||
input[type='url'],
|
|
||||||
input[type='week'] {
|
|
||||||
box-shadow: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
.theme-switcher {
|
|
||||||
border-radius: 50%;
|
|
||||||
position: fixed;
|
|
||||||
right: 1.6em;
|
|
||||||
bottom: 1.4em;
|
|
||||||
z-index: 3;
|
|
||||||
border: none;
|
|
||||||
height: 2.2em;
|
|
||||||
width: 2.2em;
|
|
||||||
background-color: #fcfcfc;
|
|
||||||
font-size: 20px;
|
|
||||||
-webkit-box-shadow: 0px 3px 14px 4px rgba(0, 0, 0, 0.62);
|
|
||||||
box-shadow: 0px 3px 14px 4px rgba(0, 0, 0, 0.62);
|
|
||||||
color: #404040;
|
|
||||||
transition: all 0.3s ease-in-out;
|
|
||||||
}
|
|
||||||
|
|
||||||
.wy-nav-content a,
|
|
||||||
.wy-nav-content a:visited {
|
|
||||||
color: #3091d1;
|
|
||||||
}
|
|
||||||
|
|
||||||
body,
|
|
||||||
.wy-nav-content-wrap,
|
|
||||||
.wy-nav-content,
|
|
||||||
.section,
|
|
||||||
.highlight,
|
|
||||||
.rst-content div[class^='highlight'],
|
|
||||||
.wy-nav-content a,
|
|
||||||
.btn-neutral,
|
|
||||||
.btn,
|
|
||||||
footer,
|
|
||||||
.wy-nav-side,
|
|
||||||
.wy-menu-vertical li,
|
|
||||||
.wy-menu-vertical a,
|
|
||||||
.wy-side-nav-search .wy-dropdown,
|
|
||||||
.wy-side-nav-search a,
|
|
||||||
.wy-side-nav-search input,
|
|
||||||
html.writer-html4 .rst-content dl:not(.docutils) > dt,
|
|
||||||
html.writer-html5
|
|
||||||
.rst-content
|
|
||||||
dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.glossary):not(.simple)
|
|
||||||
> dt,
|
|
||||||
.rst-content code,
|
|
||||||
.rst-content tt,
|
|
||||||
html.writer-html4 .rst-content dl:not(.docutils) dl:not(.field-list) > dt,
|
|
||||||
html.writer-html5
|
|
||||||
.rst-content
|
|
||||||
dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.glossary):not(.simple)
|
|
||||||
dl:not(.field-list)
|
|
||||||
> dt,
|
|
||||||
code,
|
|
||||||
.rst-content code.xref,
|
|
||||||
.rst-content tt.xref {
|
|
||||||
transition: all 0.2s ease-in-out;
|
|
||||||
}
|
|
@ -1,520 +0,0 @@
|
|||||||
:root {
|
|
||||||
--dark-text-color: #c1c1c1;
|
|
||||||
--dark-link-color: #249ee8;
|
|
||||||
}
|
|
||||||
|
|
||||||
html[data-theme="dark"] body {
|
|
||||||
color: #bfbfbf;
|
|
||||||
}
|
|
||||||
|
|
||||||
html[data-theme="dark"] .wy-nav-content-wrap {
|
|
||||||
background-color: #101010;
|
|
||||||
}
|
|
||||||
|
|
||||||
html[data-theme="dark"] .wy-nav-content {
|
|
||||||
background-color: #141414;
|
|
||||||
}
|
|
||||||
|
|
||||||
html[data-theme="dark"] .section {
|
|
||||||
color: var(--dark-text-color);
|
|
||||||
}
|
|
||||||
|
|
||||||
html[data-theme="dark"] .highlight {
|
|
||||||
background-color: #17181c;
|
|
||||||
}
|
|
||||||
|
|
||||||
html[data-theme="dark"] .highlight .nn {
|
|
||||||
color: var(--dark-text-color);
|
|
||||||
}
|
|
||||||
|
|
||||||
html[data-theme="dark"] .highlight .nb {
|
|
||||||
color: #8bb8df;
|
|
||||||
}
|
|
||||||
|
|
||||||
html[data-theme="dark"] .highlight .nv {
|
|
||||||
color: #40ffff;
|
|
||||||
}
|
|
||||||
|
|
||||||
html[data-theme="dark"] .highlight .kn,
|
|
||||||
html[data-theme="dark"] .highlight .kc,
|
|
||||||
html[data-theme="dark"] .highlight .k {
|
|
||||||
color: #41c2ea;
|
|
||||||
}
|
|
||||||
|
|
||||||
html[data-theme="dark"] .highlight .s1,
|
|
||||||
html[data-theme="dark"] .highlight .s2 {
|
|
||||||
color: #b3e87f;
|
|
||||||
}
|
|
||||||
|
|
||||||
html[data-theme="dark"] .highlight .nt {
|
|
||||||
color: #ccb350;
|
|
||||||
}
|
|
||||||
|
|
||||||
html[data-theme="dark"] .highlight .c1 {
|
|
||||||
color: #686868;
|
|
||||||
}
|
|
||||||
|
|
||||||
html[data-theme="dark"] .highlight .hll {
|
|
||||||
background-color: #002c4d;
|
|
||||||
}
|
|
||||||
|
|
||||||
html[data-theme="dark"] .rst-content div[class^="highlight"] {
|
|
||||||
border-color: #1a1a1a;
|
|
||||||
}
|
|
||||||
|
|
||||||
html[data-theme="dark"] .wy-nav-content a,
|
|
||||||
html[data-theme="dark"] .wy-nav-content a:visited {
|
|
||||||
color: var(--dark-link-color);
|
|
||||||
}
|
|
||||||
|
|
||||||
html[data-theme="dark"] .btn-neutral {
|
|
||||||
background-color: #17181c !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
html[data-theme="dark"] .btn-neutral:hover {
|
|
||||||
background-color: #101114 !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
html[data-theme="dark"] .btn-neutral:visited {
|
|
||||||
color: #c1c1c1 !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
html[data-theme="dark"] .btn {
|
|
||||||
box-shadow: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
html[data-theme="dark"] footer {
|
|
||||||
color: #bdbdbd;
|
|
||||||
}
|
|
||||||
|
|
||||||
html[data-theme="dark"] .wy-nav-side {
|
|
||||||
background-color: #0d0d0d;
|
|
||||||
}
|
|
||||||
|
|
||||||
html[data-theme="dark"] .wy-menu-vertical li.current {
|
|
||||||
background-color: #141414;
|
|
||||||
}
|
|
||||||
|
|
||||||
html[data-theme="dark"] .wy-menu-vertical li.current > a,
|
|
||||||
html[data-theme="dark"] .wy-menu-vertical li.on a {
|
|
||||||
background-color: #141415;
|
|
||||||
color: var(--dark-text-color);
|
|
||||||
}
|
|
||||||
|
|
||||||
html[data-theme="dark"] .wy-menu-vertical li.toctree-l1.current > a,
|
|
||||||
html[data-theme="dark"] .wy-menu-vertical li.current a {
|
|
||||||
border-color: #0b0c0d;
|
|
||||||
}
|
|
||||||
|
|
||||||
html[data-theme="dark"] .wy-menu-vertical li.current a {
|
|
||||||
color: #bbb;
|
|
||||||
}
|
|
||||||
|
|
||||||
html[data-theme="dark"] .wy-menu-vertical li.current a:hover {
|
|
||||||
background-color: #222;
|
|
||||||
}
|
|
||||||
|
|
||||||
html[data-theme="dark"] .wy-menu-vertical a:hover,
|
|
||||||
html[data-theme="dark"] .wy-menu-vertical li.current > a:hover,
|
|
||||||
html[data-theme="dark"] .wy-menu-vertical li.on a:hover {
|
|
||||||
background-color: #1e1e1e;
|
|
||||||
}
|
|
||||||
|
|
||||||
html[data-theme="dark"] .wy-menu-vertical li.toctree-l2.current > a,
|
|
||||||
html[data-theme="dark"]
|
|
||||||
.wy-menu-vertical
|
|
||||||
li.toctree-l2.current
|
|
||||||
li.toctree-l3
|
|
||||||
> a {
|
|
||||||
background-color: #18181a;
|
|
||||||
}
|
|
||||||
|
|
||||||
html[data-theme="dark"] .wy-side-nav-search {
|
|
||||||
background-color: #0b152d;
|
|
||||||
}
|
|
||||||
|
|
||||||
html[data-theme="dark"] .wy-side-nav-search .wy-dropdown > a,
|
|
||||||
html[data-theme="dark"] .wy-side-nav-search > a {
|
|
||||||
color: #ddd;
|
|
||||||
}
|
|
||||||
|
|
||||||
html[data-theme="dark"] .wy-side-nav-search input[type="text"] {
|
|
||||||
border-color: #111;
|
|
||||||
background-color: #141414;
|
|
||||||
color: var(--dark-text-color);
|
|
||||||
}
|
|
||||||
|
|
||||||
html[data-theme="dark"] .theme-switcher {
|
|
||||||
background-color: #0b0c0d;
|
|
||||||
color: var(--dark-text-color);
|
|
||||||
}
|
|
||||||
|
|
||||||
html[data-theme="dark"].writer-html4 .rst-content dl:not(.docutils) > dt,
|
|
||||||
html[data-theme="dark"].writer-html5
|
|
||||||
.rst-content
|
|
||||||
dl[class]:not(.option-list):not(.field-list):not(.footnote):not(
|
|
||||||
.glossary
|
|
||||||
):not(.simple)
|
|
||||||
> dt {
|
|
||||||
background-color: #0b0b0b;
|
|
||||||
color: #007dce;
|
|
||||||
border-color: #282828;
|
|
||||||
}
|
|
||||||
|
|
||||||
html[data-theme="dark"] .rst-content code,
|
|
||||||
html[data-theme="dark"] .rst-content tt {
|
|
||||||
color: var(--dark-text-color);
|
|
||||||
}
|
|
||||||
|
|
||||||
html[data-theme="dark"].writer-html4
|
|
||||||
.rst-content
|
|
||||||
dl:not(.docutils)
|
|
||||||
dl:not(.field-list)
|
|
||||||
> dt,
|
|
||||||
html[data-theme="dark"].writer-html5
|
|
||||||
.rst-content
|
|
||||||
dl[class]:not(.option-list):not(.field-list):not(.footnote):not(
|
|
||||||
.glossary
|
|
||||||
):not(.simple)
|
|
||||||
dl:not(.field-list)
|
|
||||||
> dt {
|
|
||||||
background-color: #0f0f0f;
|
|
||||||
color: #959595;
|
|
||||||
border-color: #2b2b2b;
|
|
||||||
}
|
|
||||||
|
|
||||||
html[data-theme="dark"] .rst-content code,
|
|
||||||
html[data-theme="dark"] .rst-content tt,
|
|
||||||
html[data-theme="dark"] code {
|
|
||||||
background-color: #2d2d2d;
|
|
||||||
border-color: #1c1c1c;
|
|
||||||
}
|
|
||||||
|
|
||||||
html[data-theme="dark"] .rst-content code.xref,
|
|
||||||
html[data-theme="dark"] .rst-content tt.xref,
|
|
||||||
html[data-theme="dark"] a .rst-content code,
|
|
||||||
html[data-theme="dark"] a .rst-content tt {
|
|
||||||
color: #cecece;
|
|
||||||
}
|
|
||||||
|
|
||||||
html[data-theme="dark"] .rst-content .hint,
|
|
||||||
html[data-theme="dark"] .rst-content .important,
|
|
||||||
html[data-theme="dark"] .rst-content .tip,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-success.admonition,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-success.admonition-todo,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-success.attention,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-success.caution,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-success.danger,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-success.error,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-success.note,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-success.seealso,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-success.warning,
|
|
||||||
html[data-theme="dark"] .wy-alert.wy-alert-success {
|
|
||||||
background-color: #00392e;
|
|
||||||
}
|
|
||||||
|
|
||||||
html[data-theme="dark"] .rst-content .hint .admonition-title,
|
|
||||||
html[data-theme="dark"] .rst-content .hint .wy-alert-title,
|
|
||||||
html[data-theme="dark"] .rst-content .important .admonition-title,
|
|
||||||
html[data-theme="dark"] .rst-content .important .wy-alert-title,
|
|
||||||
html[data-theme="dark"] .rst-content .tip .admonition-title,
|
|
||||||
html[data-theme="dark"] .rst-content .tip .wy-alert-title,
|
|
||||||
html[data-theme="dark"]
|
|
||||||
.rst-content
|
|
||||||
.wy-alert-success.admonition-todo
|
|
||||||
.admonition-title,
|
|
||||||
html[data-theme="dark"]
|
|
||||||
.rst-content
|
|
||||||
.wy-alert-success.admonition-todo
|
|
||||||
.wy-alert-title,
|
|
||||||
html[data-theme="dark"]
|
|
||||||
.rst-content
|
|
||||||
.wy-alert-success.admonition
|
|
||||||
.admonition-title,
|
|
||||||
html[data-theme="dark"]
|
|
||||||
.rst-content
|
|
||||||
.wy-alert-success.admonition
|
|
||||||
.wy-alert-title,
|
|
||||||
html[data-theme="dark"]
|
|
||||||
.rst-content
|
|
||||||
.wy-alert-success.attention
|
|
||||||
.admonition-title,
|
|
||||||
html[data-theme="dark"]
|
|
||||||
.rst-content
|
|
||||||
.wy-alert-success.attention
|
|
||||||
.wy-alert-title,
|
|
||||||
html[data-theme="dark"]
|
|
||||||
.rst-content
|
|
||||||
.wy-alert-success.caution
|
|
||||||
.admonition-title,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-success.caution .wy-alert-title,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-success.danger .admonition-title,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-success.danger .wy-alert-title,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-success.error .admonition-title,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-success.error .wy-alert-title,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-success.note .admonition-title,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-success.note .wy-alert-title,
|
|
||||||
html[data-theme="dark"]
|
|
||||||
.rst-content
|
|
||||||
.wy-alert-success.seealso
|
|
||||||
.admonition-title,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-success.seealso .wy-alert-title,
|
|
||||||
html[data-theme="dark"]
|
|
||||||
.rst-content
|
|
||||||
.wy-alert-success.warning
|
|
||||||
.admonition-title,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-success.warning .wy-alert-title,
|
|
||||||
html[data-theme="dark"]
|
|
||||||
.rst-content
|
|
||||||
.wy-alert.wy-alert-success
|
|
||||||
.admonition-title,
|
|
||||||
html[data-theme="dark"]
|
|
||||||
.wy-alert.wy-alert-success
|
|
||||||
.rst-content
|
|
||||||
.admonition-title,
|
|
||||||
html[data-theme="dark"] .wy-alert.wy-alert-success .wy-alert-title {
|
|
||||||
background-color: #006a56;
|
|
||||||
}
|
|
||||||
|
|
||||||
html[data-theme="dark"] .rst-content .admonition,
|
|
||||||
html[data-theme="dark"] .rst-content .note,
|
|
||||||
html[data-theme="dark"] .rst-content .seealso,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-info.admonition,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-info.admonition-todo,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-info.attention,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-info.caution,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-info.danger,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-info.error,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-info.hint,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-info.important,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-info.tip,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-info.warning,
|
|
||||||
html[data-theme="dark"] .wy-alert.wy-alert-info {
|
|
||||||
background-color: #002c4d;
|
|
||||||
}
|
|
||||||
|
|
||||||
html[data-theme="dark"] .rst-content .admonition .admonition-title,
|
|
||||||
html[data-theme="dark"] .rst-content .note .admonition-title,
|
|
||||||
html[data-theme="dark"] .rst-content .note .wy-alert-title,
|
|
||||||
html[data-theme="dark"] .rst-content .seealso .admonition-title,
|
|
||||||
html[data-theme="dark"] .rst-content .seealso .wy-alert-title,
|
|
||||||
html[data-theme="dark"]
|
|
||||||
.rst-content
|
|
||||||
.wy-alert-info.admonition-todo
|
|
||||||
.admonition-title,
|
|
||||||
html[data-theme="dark"]
|
|
||||||
.rst-content
|
|
||||||
.wy-alert-info.admonition-todo
|
|
||||||
.wy-alert-title,
|
|
||||||
html[data-theme="dark"]
|
|
||||||
.rst-content
|
|
||||||
.wy-alert-info.admonition
|
|
||||||
.admonition-title,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-info.admonition .wy-alert-title,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-info.attention .admonition-title,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-info.attention .wy-alert-title,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-info.caution .admonition-title,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-info.caution .wy-alert-title,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-info.danger .admonition-title,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-info.danger .wy-alert-title,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-info.error .admonition-title,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-info.error .wy-alert-title,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-info.hint .admonition-title,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-info.hint .wy-alert-title,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-info.important .admonition-title,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-info.important .wy-alert-title,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-info.tip .admonition-title,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-info.tip .wy-alert-title,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-info.warning .admonition-title,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-info.warning .wy-alert-title,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert.wy-alert-info .admonition-title,
|
|
||||||
html[data-theme="dark"] .wy-alert.wy-alert-info .rst-content .admonition-title,
|
|
||||||
html[data-theme="dark"] .wy-alert.wy-alert-info .wy-alert-title {
|
|
||||||
background-color: #004a7b;
|
|
||||||
}
|
|
||||||
|
|
||||||
html[data-theme="dark"] .rst-content .admonition-todo,
|
|
||||||
html[data-theme="dark"] .rst-content .attention,
|
|
||||||
html[data-theme="dark"] .rst-content .caution,
|
|
||||||
html[data-theme="dark"] .rst-content .warning,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-warning.admonition,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-warning.danger,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-warning.error,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-warning.hint,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-warning.important,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-warning.note,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-warning.seealso,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-warning.tip,
|
|
||||||
html[data-theme="dark"] .wy-alert.wy-alert-warning {
|
|
||||||
background-color: #533500;
|
|
||||||
}
|
|
||||||
|
|
||||||
html[data-theme="dark"] .rst-content .admonition-todo .admonition-title,
|
|
||||||
html[data-theme="dark"] .rst-content .admonition-todo .wy-alert-title,
|
|
||||||
html[data-theme="dark"] .rst-content .attention .admonition-title,
|
|
||||||
html[data-theme="dark"] .rst-content .attention .wy-alert-title,
|
|
||||||
html[data-theme="dark"] .rst-content .caution .admonition-title,
|
|
||||||
html[data-theme="dark"] .rst-content .caution .wy-alert-title,
|
|
||||||
html[data-theme="dark"] .rst-content .warning .admonition-title,
|
|
||||||
html[data-theme="dark"] .rst-content .warning .wy-alert-title,
|
|
||||||
html[data-theme="dark"]
|
|
||||||
.rst-content
|
|
||||||
.wy-alert-warning.admonition
|
|
||||||
.admonition-title,
|
|
||||||
html[data-theme="dark"]
|
|
||||||
.rst-content
|
|
||||||
.wy-alert-warning.admonition
|
|
||||||
.wy-alert-title,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-warning.danger .admonition-title,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-warning.danger .wy-alert-title,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-warning.error .admonition-title,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-warning.error .wy-alert-title,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-warning.hint .admonition-title,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-warning.hint .wy-alert-title,
|
|
||||||
html[data-theme="dark"]
|
|
||||||
.rst-content
|
|
||||||
.wy-alert-warning.important
|
|
||||||
.admonition-title,
|
|
||||||
html[data-theme="dark"]
|
|
||||||
.rst-content
|
|
||||||
.wy-alert-warning.important
|
|
||||||
.wy-alert-title,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-warning.note .admonition-title,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-warning.note .wy-alert-title,
|
|
||||||
html[data-theme="dark"]
|
|
||||||
.rst-content
|
|
||||||
.wy-alert-warning.seealso
|
|
||||||
.admonition-title,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-warning.seealso .wy-alert-title,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-warning.tip .admonition-title,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-warning.tip .wy-alert-title,
|
|
||||||
html[data-theme="dark"]
|
|
||||||
.rst-content
|
|
||||||
.wy-alert.wy-alert-warning
|
|
||||||
.admonition-title,
|
|
||||||
html[data-theme="dark"]
|
|
||||||
.wy-alert.wy-alert-warning
|
|
||||||
.rst-content
|
|
||||||
.admonition-title,
|
|
||||||
html[data-theme="dark"] .wy-alert.wy-alert-warning .wy-alert-title {
|
|
||||||
background-color: #803b00;
|
|
||||||
}
|
|
||||||
|
|
||||||
html[data-theme="dark"] .rst-content .danger,
|
|
||||||
html[data-theme="dark"] .rst-content .error,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-danger.admonition,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-danger.admonition-todo,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-danger.attention,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-danger.caution,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-danger.hint,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-danger.important,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-danger.note,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-danger.seealso,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-danger.tip,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-danger.warning,
|
|
||||||
html[data-theme="dark"] .wy-alert.wy-alert-danger {
|
|
||||||
background-color: #82231a;
|
|
||||||
}
|
|
||||||
|
|
||||||
html[data-theme="dark"] .rst-content .danger .admonition-title,
|
|
||||||
html[data-theme="dark"] .rst-content .danger .wy-alert-title,
|
|
||||||
html[data-theme="dark"] .rst-content .error .admonition-title,
|
|
||||||
html[data-theme="dark"] .rst-content .error .wy-alert-title,
|
|
||||||
html[data-theme="dark"]
|
|
||||||
.rst-content
|
|
||||||
.wy-alert-danger.admonition-todo
|
|
||||||
.admonition-title,
|
|
||||||
html[data-theme="dark"]
|
|
||||||
.rst-content
|
|
||||||
.wy-alert-danger.admonition-todo
|
|
||||||
.wy-alert-title,
|
|
||||||
html[data-theme="dark"]
|
|
||||||
.rst-content
|
|
||||||
.wy-alert-danger.admonition
|
|
||||||
.admonition-title,
|
|
||||||
html[data-theme="dark"]
|
|
||||||
.rst-content
|
|
||||||
.wy-alert-danger.admonition
|
|
||||||
.wy-alert-title,
|
|
||||||
html[data-theme="dark"]
|
|
||||||
.rst-content
|
|
||||||
.wy-alert-danger.attention
|
|
||||||
.admonition-title,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-danger.attention .wy-alert-title,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-danger.caution .admonition-title,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-danger.caution .wy-alert-title,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-danger.hint .admonition-title,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-danger.hint .wy-alert-title,
|
|
||||||
html[data-theme="dark"]
|
|
||||||
.rst-content
|
|
||||||
.wy-alert-danger.important
|
|
||||||
.admonition-title,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-danger.important .wy-alert-title,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-danger.note .admonition-title,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-danger.note .wy-alert-title,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-danger.seealso .admonition-title,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-danger.seealso .wy-alert-title,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-danger.tip .admonition-title,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-danger.tip .wy-alert-title,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-danger.warning .admonition-title,
|
|
||||||
html[data-theme="dark"] .rst-content .wy-alert-danger.warning .wy-alert-title,
|
|
||||||
html[data-theme="dark"]
|
|
||||||
.rst-content
|
|
||||||
.wy-alert.wy-alert-danger
|
|
||||||
.admonition-title,
|
|
||||||
html[data-theme="dark"]
|
|
||||||
.wy-alert.wy-alert-danger
|
|
||||||
.rst-content
|
|
||||||
.admonition-title,
|
|
||||||
html[data-theme="dark"] .wy-alert.wy-alert-danger .wy-alert-title {
|
|
||||||
background-color: #b9372b;
|
|
||||||
}
|
|
||||||
|
|
||||||
html[data-theme="dark"] .wy-nav-top {
|
|
||||||
background-color: #0b152d;
|
|
||||||
}
|
|
||||||
|
|
||||||
html[data-theme="dark"] .rst-content table.docutils thead,
|
|
||||||
html[data-theme="dark"] .rst-content table.field-list thead,
|
|
||||||
html[data-theme="dark"] .wy-table thead {
|
|
||||||
color: var(--dark-text-color);
|
|
||||||
}
|
|
||||||
|
|
||||||
html[data-theme="dark"]
|
|
||||||
.rst-content
|
|
||||||
table.docutils:not(.field-list)
|
|
||||||
tr:nth-child(2n-1)
|
|
||||||
td,
|
|
||||||
html[data-theme="dark"] .wy-table-backed,
|
|
||||||
html[data-theme="dark"] html[data-theme="dark"] .wy-table-odd td,
|
|
||||||
html[data-theme="dark"] .wy-table-striped tr:nth-child(2n-1) td {
|
|
||||||
background-color: #181818;
|
|
||||||
}
|
|
||||||
|
|
||||||
html[data-theme="dark"] .rst-content table.docutils td,
|
|
||||||
html[data-theme="dark"] .wy-table-bordered-all td,
|
|
||||||
html[data-theme="dark"].writer-html5 .rst-content table.docutils th,
|
|
||||||
html[data-theme="dark"] .rst-content table.docutils,
|
|
||||||
html[data-theme="dark"] .wy-table-bordered-all {
|
|
||||||
border-color: #262626;
|
|
||||||
}
|
|
||||||
|
|
||||||
html[data-theme="dark"] .rst-content table.docutils caption,
|
|
||||||
html[data-theme="dark"] .rst-content table.field-list caption,
|
|
||||||
html[data-theme="dark"] .wy-table caption {
|
|
||||||
color: var(--dark-text-color);
|
|
||||||
}
|
|
||||||
|
|
||||||
html[data-theme="dark"] .wy-menu-vertical li.toctree-l3.current > a,
|
|
||||||
html[data-theme="dark"]
|
|
||||||
.wy-menu-vertical
|
|
||||||
li.toctree-l3.current
|
|
||||||
li.toctree-l4
|
|
||||||
> a {
|
|
||||||
background-color: #18181a;
|
|
||||||
}
|
|
||||||
|
|
||||||
html[data-theme="dark"] .guilabel {
|
|
||||||
background-color: #343434;
|
|
||||||
border-color: #4d4d4d;
|
|
||||||
}
|
|
@ -1,68 +0,0 @@
|
|||||||
input[type='color'],
|
|
||||||
input[type='date'],
|
|
||||||
input[type='datetime-local'],
|
|
||||||
input[type='datetime'],
|
|
||||||
input[type='email'],
|
|
||||||
input[type='month'],
|
|
||||||
input[type='number'],
|
|
||||||
input[type='password'],
|
|
||||||
input[type='search'],
|
|
||||||
input[type='tel'],
|
|
||||||
input[type='text'],
|
|
||||||
input[type='time'],
|
|
||||||
input[type='url'],
|
|
||||||
input[type='week'] {
|
|
||||||
box-shadow: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
.theme-switcher {
|
|
||||||
border-radius: 50%;
|
|
||||||
position: fixed;
|
|
||||||
right: 1.6em;
|
|
||||||
bottom: 1.4em;
|
|
||||||
z-index: 3;
|
|
||||||
border: none;
|
|
||||||
height: 2.2em;
|
|
||||||
width: 2.2em;
|
|
||||||
background-color: #fcfcfc;
|
|
||||||
font-size: 20px;
|
|
||||||
-webkit-box-shadow: 0px 3px 14px 4px rgba(0, 0, 0, 0.62);
|
|
||||||
box-shadow: 0px 3px 14px 4px rgba(0, 0, 0, 0.62);
|
|
||||||
color: #404040;
|
|
||||||
transition: all 0.3s ease-in-out;
|
|
||||||
}
|
|
||||||
|
|
||||||
body,
|
|
||||||
.wy-nav-content-wrap,
|
|
||||||
.wy-nav-content,
|
|
||||||
.section,
|
|
||||||
.highlight,
|
|
||||||
.rst-content div[class^='highlight'],
|
|
||||||
.wy-nav-content a,
|
|
||||||
.btn-neutral,
|
|
||||||
.btn,
|
|
||||||
footer,
|
|
||||||
.wy-nav-side,
|
|
||||||
.wy-menu-vertical li,
|
|
||||||
.wy-menu-vertical a,
|
|
||||||
.wy-side-nav-search .wy-dropdown,
|
|
||||||
.wy-side-nav-search a,
|
|
||||||
.wy-side-nav-search input,
|
|
||||||
html.writer-html4 .rst-content dl:not(.docutils) > dt,
|
|
||||||
html.writer-html5
|
|
||||||
.rst-content
|
|
||||||
dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.glossary):not(.simple)
|
|
||||||
> dt,
|
|
||||||
.rst-content code,
|
|
||||||
.rst-content tt,
|
|
||||||
html.writer-html4 .rst-content dl:not(.docutils) dl:not(.field-list) > dt,
|
|
||||||
html.writer-html5
|
|
||||||
.rst-content
|
|
||||||
dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.glossary):not(.simple)
|
|
||||||
dl:not(.field-list)
|
|
||||||
> dt,
|
|
||||||
code,
|
|
||||||
.rst-content code.xref,
|
|
||||||
.rst-content tt.xref {
|
|
||||||
transition: all 0.2s ease-in-out;
|
|
||||||
}
|
|
@ -1,13 +0,0 @@
|
|||||||
const loadTheme = () => {
|
|
||||||
let theme = localStorage.getItem('theme');
|
|
||||||
|
|
||||||
if (theme !== null) {
|
|
||||||
if (theme === 'dark')
|
|
||||||
document.documentElement.setAttribute('data-theme', 'dark');
|
|
||||||
} else {
|
|
||||||
localStorage.setItem('theme', 'dark');
|
|
||||||
document.documentElement.setAttribute('data-theme', 'dark');
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
loadTheme();
|
|
@ -1,13 +0,0 @@
|
|||||||
const loadTheme = () => {
|
|
||||||
let theme = localStorage.getItem('theme');
|
|
||||||
|
|
||||||
if (theme !== null) {
|
|
||||||
if (theme === 'dark')
|
|
||||||
document.documentElement.setAttribute('data-theme', 'dark');
|
|
||||||
} else {
|
|
||||||
localStorage.setItem('theme', 'light');
|
|
||||||
document.documentElement.setAttribute('data-theme', 'light');
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
loadTheme();
|
|
@ -1,39 +0,0 @@
|
|||||||
const createThemeSwitcher = () => {
|
|
||||||
let btn = document.createElement('BUTTON');
|
|
||||||
btn.className = 'theme-switcher';
|
|
||||||
btn.id = 'themeSwitcher';
|
|
||||||
btn.innerHTML =
|
|
||||||
'<i id=themeMoon class="fa fa-moon-o"></i><i id=themeSun class="fa fa-sun-o"></i>';
|
|
||||||
document.body.appendChild(btn);
|
|
||||||
|
|
||||||
if (localStorage.getItem('theme') === 'dark') $('#themeMoon').hide(0);
|
|
||||||
else $('#themeSun').hide(0);
|
|
||||||
};
|
|
||||||
|
|
||||||
$(document).ready(() => {
|
|
||||||
createThemeSwitcher();
|
|
||||||
$('#themeSwitcher').click(switchTheme);
|
|
||||||
|
|
||||||
$('footer').html(
|
|
||||||
$('footer').html() +
|
|
||||||
'<a href="https://github.com/MrDogeBro/sphinx_rtd_dark_mode">Dark theme</a> provided by <a href="http://mrdogebro.com">MrDogeBro</a>.'
|
|
||||||
);
|
|
||||||
});
|
|
||||||
|
|
||||||
const switchTheme = () => {
|
|
||||||
if (localStorage.getItem('theme') === 'dark') {
|
|
||||||
localStorage.setItem('theme', 'light');
|
|
||||||
document.documentElement.setAttribute('data-theme', 'light');
|
|
||||||
|
|
||||||
$('#themeSun').fadeOut(200, () => {
|
|
||||||
$('#themeMoon').fadeIn(200);
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
localStorage.setItem('theme', 'dark');
|
|
||||||
document.documentElement.setAttribute('data-theme', 'dark');
|
|
||||||
|
|
||||||
$('#themeMoon').fadeOut(200, () => {
|
|
||||||
$('#themeSun').fadeIn(200);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
};
|
|
@ -1,149 +0,0 @@
|
|||||||
/*
|
|
||||||
* Base JavaScript utilities for all Sphinx HTML documentation.
|
|
||||||
*/
|
|
||||||
"use strict";
|
|
||||||
|
|
||||||
const BLACKLISTED_KEY_CONTROL_ELEMENTS = new Set([
|
|
||||||
"TEXTAREA",
|
|
||||||
"INPUT",
|
|
||||||
"SELECT",
|
|
||||||
"BUTTON",
|
|
||||||
]);
|
|
||||||
|
|
||||||
const _ready = (callback) => {
|
|
||||||
if (document.readyState !== "loading") {
|
|
||||||
callback();
|
|
||||||
} else {
|
|
||||||
document.addEventListener("DOMContentLoaded", callback);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Small JavaScript module for the documentation.
|
|
||||||
*/
|
|
||||||
const Documentation = {
|
|
||||||
init: () => {
|
|
||||||
Documentation.initDomainIndexTable();
|
|
||||||
Documentation.initOnKeyListeners();
|
|
||||||
},
|
|
||||||
|
|
||||||
/**
|
|
||||||
* i18n support
|
|
||||||
*/
|
|
||||||
TRANSLATIONS: {},
|
|
||||||
PLURAL_EXPR: (n) => (n === 1 ? 0 : 1),
|
|
||||||
LOCALE: "unknown",
|
|
||||||
|
|
||||||
// gettext and ngettext don't access this so that the functions
|
|
||||||
// can safely bound to a different name (_ = Documentation.gettext)
|
|
||||||
gettext: (string) => {
|
|
||||||
const translated = Documentation.TRANSLATIONS[string];
|
|
||||||
switch (typeof translated) {
|
|
||||||
case "undefined":
|
|
||||||
return string; // no translation
|
|
||||||
case "string":
|
|
||||||
return translated; // translation exists
|
|
||||||
default:
|
|
||||||
return translated[0]; // (singular, plural) translation tuple exists
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
ngettext: (singular, plural, n) => {
|
|
||||||
const translated = Documentation.TRANSLATIONS[singular];
|
|
||||||
if (typeof translated !== "undefined")
|
|
||||||
return translated[Documentation.PLURAL_EXPR(n)];
|
|
||||||
return n === 1 ? singular : plural;
|
|
||||||
},
|
|
||||||
|
|
||||||
addTranslations: (catalog) => {
|
|
||||||
Object.assign(Documentation.TRANSLATIONS, catalog.messages);
|
|
||||||
Documentation.PLURAL_EXPR = new Function(
|
|
||||||
"n",
|
|
||||||
`return (${catalog.plural_expr})`
|
|
||||||
);
|
|
||||||
Documentation.LOCALE = catalog.locale;
|
|
||||||
},
|
|
||||||
|
|
||||||
/**
|
|
||||||
* helper function to focus on search bar
|
|
||||||
*/
|
|
||||||
focusSearchBar: () => {
|
|
||||||
document.querySelectorAll("input[name=q]")[0]?.focus();
|
|
||||||
},
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Initialise the domain index toggle buttons
|
|
||||||
*/
|
|
||||||
initDomainIndexTable: () => {
|
|
||||||
const toggler = (el) => {
|
|
||||||
const idNumber = el.id.substr(7);
|
|
||||||
const toggledRows = document.querySelectorAll(`tr.cg-${idNumber}`);
|
|
||||||
if (el.src.substr(-9) === "minus.png") {
|
|
||||||
el.src = `${el.src.substr(0, el.src.length - 9)}plus.png`;
|
|
||||||
toggledRows.forEach((el) => (el.style.display = "none"));
|
|
||||||
} else {
|
|
||||||
el.src = `${el.src.substr(0, el.src.length - 8)}minus.png`;
|
|
||||||
toggledRows.forEach((el) => (el.style.display = ""));
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
const togglerElements = document.querySelectorAll("img.toggler");
|
|
||||||
togglerElements.forEach((el) =>
|
|
||||||
el.addEventListener("click", (event) => toggler(event.currentTarget))
|
|
||||||
);
|
|
||||||
togglerElements.forEach((el) => (el.style.display = ""));
|
|
||||||
if (DOCUMENTATION_OPTIONS.COLLAPSE_INDEX) togglerElements.forEach(toggler);
|
|
||||||
},
|
|
||||||
|
|
||||||
initOnKeyListeners: () => {
|
|
||||||
// only install a listener if it is really needed
|
|
||||||
if (
|
|
||||||
!DOCUMENTATION_OPTIONS.NAVIGATION_WITH_KEYS &&
|
|
||||||
!DOCUMENTATION_OPTIONS.ENABLE_SEARCH_SHORTCUTS
|
|
||||||
)
|
|
||||||
return;
|
|
||||||
|
|
||||||
document.addEventListener("keydown", (event) => {
|
|
||||||
// bail for input elements
|
|
||||||
if (BLACKLISTED_KEY_CONTROL_ELEMENTS.has(document.activeElement.tagName)) return;
|
|
||||||
// bail with special keys
|
|
||||||
if (event.altKey || event.ctrlKey || event.metaKey) return;
|
|
||||||
|
|
||||||
if (!event.shiftKey) {
|
|
||||||
switch (event.key) {
|
|
||||||
case "ArrowLeft":
|
|
||||||
if (!DOCUMENTATION_OPTIONS.NAVIGATION_WITH_KEYS) break;
|
|
||||||
|
|
||||||
const prevLink = document.querySelector('link[rel="prev"]');
|
|
||||||
if (prevLink && prevLink.href) {
|
|
||||||
window.location.href = prevLink.href;
|
|
||||||
event.preventDefault();
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case "ArrowRight":
|
|
||||||
if (!DOCUMENTATION_OPTIONS.NAVIGATION_WITH_KEYS) break;
|
|
||||||
|
|
||||||
const nextLink = document.querySelector('link[rel="next"]');
|
|
||||||
if (nextLink && nextLink.href) {
|
|
||||||
window.location.href = nextLink.href;
|
|
||||||
event.preventDefault();
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// some keyboard layouts may need Shift to get /
|
|
||||||
switch (event.key) {
|
|
||||||
case "/":
|
|
||||||
if (!DOCUMENTATION_OPTIONS.ENABLE_SEARCH_SHORTCUTS) break;
|
|
||||||
Documentation.focusSearchBar();
|
|
||||||
event.preventDefault();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
// quick alias for translations
|
|
||||||
const _ = Documentation.gettext;
|
|
||||||
|
|
||||||
_ready(Documentation.init);
|
|
@ -1,13 +0,0 @@
|
|||||||
const DOCUMENTATION_OPTIONS = {
|
|
||||||
VERSION: '',
|
|
||||||
LANGUAGE: 'en',
|
|
||||||
COLLAPSE_INDEX: false,
|
|
||||||
BUILDER: 'html',
|
|
||||||
FILE_SUFFIX: '.html',
|
|
||||||
LINK_SUFFIX: '.html',
|
|
||||||
HAS_SOURCE: true,
|
|
||||||
SOURCELINK_SUFFIX: '.txt',
|
|
||||||
NAVIGATION_WITH_KEYS: false,
|
|
||||||
SHOW_SEARCH_SUMMARY: true,
|
|
||||||
ENABLE_SEARCH_SHORTCUTS: true,
|
|
||||||
};
|
|
Before Width: | Height: | Size: 627 KiB |
Before Width: | Height: | Size: 286 B |
Before Width: | Height: | Size: 627 KiB |
Before Width: | Height: | Size: 26 KiB |
Before Width: | Height: | Size: 20 KiB |
2
devel/html/_static/jquery.js
vendored
@ -1 +0,0 @@
|
|||||||
!function(e){var t={};function r(n){if(t[n])return t[n].exports;var o=t[n]={i:n,l:!1,exports:{}};return e[n].call(o.exports,o,o.exports,r),o.l=!0,o.exports}r.m=e,r.c=t,r.d=function(e,t,n){r.o(e,t)||Object.defineProperty(e,t,{enumerable:!0,get:n})},r.r=function(e){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},r.t=function(e,t){if(1&t&&(e=r(e)),8&t)return e;if(4&t&&"object"==typeof e&&e&&e.__esModule)return e;var n=Object.create(null);if(r.r(n),Object.defineProperty(n,"default",{enumerable:!0,value:e}),2&t&&"string"!=typeof e)for(var o in e)r.d(n,o,function(t){return e[t]}.bind(null,o));return n},r.n=function(e){var t=e&&e.__esModule?function(){return e.default}:function(){return e};return r.d(t,"a",t),t},r.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},r.p="",r(r.s=4)}({4:function(e,t,r){}});
|
|
@ -1,228 +0,0 @@
|
|||||||
const themeFlyoutDisplay = "hidden";
|
|
||||||
const themeVersionSelector = true;
|
|
||||||
const themeLanguageSelector = true;
|
|
||||||
|
|
||||||
if (themeFlyoutDisplay === "attached") {
|
|
||||||
function renderLanguages(config) {
|
|
||||||
if (!config.projects.translations.length) {
|
|
||||||
return "";
|
|
||||||
}
|
|
||||||
|
|
||||||
// Insert the current language to the options on the selector
|
|
||||||
let languages = config.projects.translations.concat(config.projects.current);
|
|
||||||
languages = languages.sort((a, b) => a.language.name.localeCompare(b.language.name));
|
|
||||||
|
|
||||||
const languagesHTML = `
|
|
||||||
<dl>
|
|
||||||
<dt>Languages</dt>
|
|
||||||
${languages
|
|
||||||
.map(
|
|
||||||
(translation) => `
|
|
||||||
<dd ${translation.slug == config.projects.current.slug ? 'class="rtd-current-item"' : ""}>
|
|
||||||
<a href="${translation.urls.documentation}">${translation.language.code}</a>
|
|
||||||
</dd>
|
|
||||||
`,
|
|
||||||
)
|
|
||||||
.join("\n")}
|
|
||||||
</dl>
|
|
||||||
`;
|
|
||||||
return languagesHTML;
|
|
||||||
}
|
|
||||||
|
|
||||||
function renderVersions(config) {
|
|
||||||
if (!config.versions.active.length) {
|
|
||||||
return "";
|
|
||||||
}
|
|
||||||
const versionsHTML = `
|
|
||||||
<dl>
|
|
||||||
<dt>Versions</dt>
|
|
||||||
${config.versions.active
|
|
||||||
.map(
|
|
||||||
(version) => `
|
|
||||||
<dd ${version.slug === config.versions.current.slug ? 'class="rtd-current-item"' : ""}>
|
|
||||||
<a href="${version.urls.documentation}">${version.slug}</a>
|
|
||||||
</dd>
|
|
||||||
`,
|
|
||||||
)
|
|
||||||
.join("\n")}
|
|
||||||
</dl>
|
|
||||||
`;
|
|
||||||
return versionsHTML;
|
|
||||||
}
|
|
||||||
|
|
||||||
function renderDownloads(config) {
|
|
||||||
if (!Object.keys(config.versions.current.downloads).length) {
|
|
||||||
return "";
|
|
||||||
}
|
|
||||||
const downloadsNameDisplay = {
|
|
||||||
pdf: "PDF",
|
|
||||||
epub: "Epub",
|
|
||||||
htmlzip: "HTML",
|
|
||||||
};
|
|
||||||
|
|
||||||
const downloadsHTML = `
|
|
||||||
<dl>
|
|
||||||
<dt>Downloads</dt>
|
|
||||||
${Object.entries(config.versions.current.downloads)
|
|
||||||
.map(
|
|
||||||
([name, url]) => `
|
|
||||||
<dd>
|
|
||||||
<a href="${url}">${downloadsNameDisplay[name]}</a>
|
|
||||||
</dd>
|
|
||||||
`,
|
|
||||||
)
|
|
||||||
.join("\n")}
|
|
||||||
</dl>
|
|
||||||
`;
|
|
||||||
return downloadsHTML;
|
|
||||||
}
|
|
||||||
|
|
||||||
document.addEventListener("readthedocs-addons-data-ready", function (event) {
|
|
||||||
const config = event.detail.data();
|
|
||||||
|
|
||||||
const flyout = `
|
|
||||||
<div class="rst-versions" data-toggle="rst-versions" role="note">
|
|
||||||
<span class="rst-current-version" data-toggle="rst-current-version">
|
|
||||||
<span class="fa fa-book"> Read the Docs</span>
|
|
||||||
v: ${config.versions.current.slug}
|
|
||||||
<span class="fa fa-caret-down"></span>
|
|
||||||
</span>
|
|
||||||
<div class="rst-other-versions">
|
|
||||||
<div class="injected">
|
|
||||||
${renderLanguages(config)}
|
|
||||||
${renderVersions(config)}
|
|
||||||
${renderDownloads(config)}
|
|
||||||
<dl>
|
|
||||||
<dt>On Read the Docs</dt>
|
|
||||||
<dd>
|
|
||||||
<a href="${config.projects.current.urls.home}">Project Home</a>
|
|
||||||
</dd>
|
|
||||||
<dd>
|
|
||||||
<a href="${config.projects.current.urls.builds}">Builds</a>
|
|
||||||
</dd>
|
|
||||||
<dd>
|
|
||||||
<a href="${config.projects.current.urls.downloads}">Downloads</a>
|
|
||||||
</dd>
|
|
||||||
</dl>
|
|
||||||
<dl>
|
|
||||||
<dt>Search</dt>
|
|
||||||
<dd>
|
|
||||||
<form id="flyout-search-form">
|
|
||||||
<input
|
|
||||||
class="wy-form"
|
|
||||||
type="text"
|
|
||||||
name="q"
|
|
||||||
aria-label="Search docs"
|
|
||||||
placeholder="Search docs"
|
|
||||||
/>
|
|
||||||
</form>
|
|
||||||
</dd>
|
|
||||||
</dl>
|
|
||||||
<hr />
|
|
||||||
<small>
|
|
||||||
<span>Hosted by <a href="https://about.readthedocs.org/?utm_source=&utm_content=flyout">Read the Docs</a></span>
|
|
||||||
</small>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
`;
|
|
||||||
|
|
||||||
// Inject the generated flyout into the body HTML element.
|
|
||||||
document.body.insertAdjacentHTML("beforeend", flyout);
|
|
||||||
|
|
||||||
// Trigger the Read the Docs Addons Search modal when clicking on the "Search docs" input from inside the flyout.
|
|
||||||
document
|
|
||||||
.querySelector("#flyout-search-form")
|
|
||||||
.addEventListener("focusin", () => {
|
|
||||||
const event = new CustomEvent("readthedocs-search-show");
|
|
||||||
document.dispatchEvent(event);
|
|
||||||
});
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
if (themeLanguageSelector || themeVersionSelector) {
|
|
||||||
function onSelectorSwitch(event) {
|
|
||||||
const option = event.target.selectedIndex;
|
|
||||||
const item = event.target.options[option];
|
|
||||||
window.location.href = item.dataset.url;
|
|
||||||
}
|
|
||||||
|
|
||||||
document.addEventListener("readthedocs-addons-data-ready", function (event) {
|
|
||||||
const config = event.detail.data();
|
|
||||||
|
|
||||||
const versionSwitch = document.querySelector(
|
|
||||||
"div.switch-menus > div.version-switch",
|
|
||||||
);
|
|
||||||
if (themeVersionSelector) {
|
|
||||||
let versions = config.versions.active;
|
|
||||||
if (config.versions.current.hidden || config.versions.current.type === "external") {
|
|
||||||
versions.unshift(config.versions.current);
|
|
||||||
}
|
|
||||||
const versionSelect = `
|
|
||||||
<select>
|
|
||||||
${versions
|
|
||||||
.map(
|
|
||||||
(version) => `
|
|
||||||
<option
|
|
||||||
value="${version.slug}"
|
|
||||||
${config.versions.current.slug === version.slug ? 'selected="selected"' : ""}
|
|
||||||
data-url="${version.urls.documentation}">
|
|
||||||
${version.slug}
|
|
||||||
</option>`,
|
|
||||||
)
|
|
||||||
.join("\n")}
|
|
||||||
</select>
|
|
||||||
`;
|
|
||||||
|
|
||||||
versionSwitch.innerHTML = versionSelect;
|
|
||||||
versionSwitch.firstElementChild.addEventListener("change", onSelectorSwitch);
|
|
||||||
}
|
|
||||||
|
|
||||||
const languageSwitch = document.querySelector(
|
|
||||||
"div.switch-menus > div.language-switch",
|
|
||||||
);
|
|
||||||
|
|
||||||
if (themeLanguageSelector) {
|
|
||||||
if (config.projects.translations.length) {
|
|
||||||
// Add the current language to the options on the selector
|
|
||||||
let languages = config.projects.translations.concat(
|
|
||||||
config.projects.current,
|
|
||||||
);
|
|
||||||
languages = languages.sort((a, b) =>
|
|
||||||
a.language.name.localeCompare(b.language.name),
|
|
||||||
);
|
|
||||||
|
|
||||||
const languageSelect = `
|
|
||||||
<select>
|
|
||||||
${languages
|
|
||||||
.map(
|
|
||||||
(language) => `
|
|
||||||
<option
|
|
||||||
value="${language.language.code}"
|
|
||||||
${config.projects.current.slug === language.slug ? 'selected="selected"' : ""}
|
|
||||||
data-url="${language.urls.documentation}">
|
|
||||||
${language.language.name}
|
|
||||||
</option>`,
|
|
||||||
)
|
|
||||||
.join("\n")}
|
|
||||||
</select>
|
|
||||||
`;
|
|
||||||
|
|
||||||
languageSwitch.innerHTML = languageSelect;
|
|
||||||
languageSwitch.firstElementChild.addEventListener("change", onSelectorSwitch);
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
languageSwitch.remove();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
document.addEventListener("readthedocs-addons-data-ready", function (event) {
|
|
||||||
// Trigger the Read the Docs Addons Search modal when clicking on "Search docs" input from the topnav.
|
|
||||||
document
|
|
||||||
.querySelector("[role='search'] input")
|
|
||||||
.addEventListener("focusin", () => {
|
|
||||||
const event = new CustomEvent("readthedocs-search-show");
|
|
||||||
document.dispatchEvent(event);
|
|
||||||
});
|
|
||||||
});
|
|
@ -1,192 +0,0 @@
|
|||||||
/*
|
|
||||||
* This script contains the language-specific data used by searchtools.js,
|
|
||||||
* namely the list of stopwords, stemmer, scorer and splitter.
|
|
||||||
*/
|
|
||||||
|
|
||||||
var stopwords = ["a", "and", "are", "as", "at", "be", "but", "by", "for", "if", "in", "into", "is", "it", "near", "no", "not", "of", "on", "or", "such", "that", "the", "their", "then", "there", "these", "they", "this", "to", "was", "will", "with"];
|
|
||||||
|
|
||||||
|
|
||||||
/* Non-minified version is copied as a separate JS file, if available */
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Porter Stemmer
|
|
||||||
*/
|
|
||||||
var Stemmer = function() {
|
|
||||||
|
|
||||||
var step2list = {
|
|
||||||
ational: 'ate',
|
|
||||||
tional: 'tion',
|
|
||||||
enci: 'ence',
|
|
||||||
anci: 'ance',
|
|
||||||
izer: 'ize',
|
|
||||||
bli: 'ble',
|
|
||||||
alli: 'al',
|
|
||||||
entli: 'ent',
|
|
||||||
eli: 'e',
|
|
||||||
ousli: 'ous',
|
|
||||||
ization: 'ize',
|
|
||||||
ation: 'ate',
|
|
||||||
ator: 'ate',
|
|
||||||
alism: 'al',
|
|
||||||
iveness: 'ive',
|
|
||||||
fulness: 'ful',
|
|
||||||
ousness: 'ous',
|
|
||||||
aliti: 'al',
|
|
||||||
iviti: 'ive',
|
|
||||||
biliti: 'ble',
|
|
||||||
logi: 'log'
|
|
||||||
};
|
|
||||||
|
|
||||||
var step3list = {
|
|
||||||
icate: 'ic',
|
|
||||||
ative: '',
|
|
||||||
alize: 'al',
|
|
||||||
iciti: 'ic',
|
|
||||||
ical: 'ic',
|
|
||||||
ful: '',
|
|
||||||
ness: ''
|
|
||||||
};
|
|
||||||
|
|
||||||
var c = "[^aeiou]"; // consonant
|
|
||||||
var v = "[aeiouy]"; // vowel
|
|
||||||
var C = c + "[^aeiouy]*"; // consonant sequence
|
|
||||||
var V = v + "[aeiou]*"; // vowel sequence
|
|
||||||
|
|
||||||
var mgr0 = "^(" + C + ")?" + V + C; // [C]VC... is m>0
|
|
||||||
var meq1 = "^(" + C + ")?" + V + C + "(" + V + ")?$"; // [C]VC[V] is m=1
|
|
||||||
var mgr1 = "^(" + C + ")?" + V + C + V + C; // [C]VCVC... is m>1
|
|
||||||
var s_v = "^(" + C + ")?" + v; // vowel in stem
|
|
||||||
|
|
||||||
this.stemWord = function (w) {
|
|
||||||
var stem;
|
|
||||||
var suffix;
|
|
||||||
var firstch;
|
|
||||||
var origword = w;
|
|
||||||
|
|
||||||
if (w.length < 3)
|
|
||||||
return w;
|
|
||||||
|
|
||||||
var re;
|
|
||||||
var re2;
|
|
||||||
var re3;
|
|
||||||
var re4;
|
|
||||||
|
|
||||||
firstch = w.substr(0,1);
|
|
||||||
if (firstch == "y")
|
|
||||||
w = firstch.toUpperCase() + w.substr(1);
|
|
||||||
|
|
||||||
// Step 1a
|
|
||||||
re = /^(.+?)(ss|i)es$/;
|
|
||||||
re2 = /^(.+?)([^s])s$/;
|
|
||||||
|
|
||||||
if (re.test(w))
|
|
||||||
w = w.replace(re,"$1$2");
|
|
||||||
else if (re2.test(w))
|
|
||||||
w = w.replace(re2,"$1$2");
|
|
||||||
|
|
||||||
// Step 1b
|
|
||||||
re = /^(.+?)eed$/;
|
|
||||||
re2 = /^(.+?)(ed|ing)$/;
|
|
||||||
if (re.test(w)) {
|
|
||||||
var fp = re.exec(w);
|
|
||||||
re = new RegExp(mgr0);
|
|
||||||
if (re.test(fp[1])) {
|
|
||||||
re = /.$/;
|
|
||||||
w = w.replace(re,"");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else if (re2.test(w)) {
|
|
||||||
var fp = re2.exec(w);
|
|
||||||
stem = fp[1];
|
|
||||||
re2 = new RegExp(s_v);
|
|
||||||
if (re2.test(stem)) {
|
|
||||||
w = stem;
|
|
||||||
re2 = /(at|bl|iz)$/;
|
|
||||||
re3 = new RegExp("([^aeiouylsz])\\1$");
|
|
||||||
re4 = new RegExp("^" + C + v + "[^aeiouwxy]$");
|
|
||||||
if (re2.test(w))
|
|
||||||
w = w + "e";
|
|
||||||
else if (re3.test(w)) {
|
|
||||||
re = /.$/;
|
|
||||||
w = w.replace(re,"");
|
|
||||||
}
|
|
||||||
else if (re4.test(w))
|
|
||||||
w = w + "e";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Step 1c
|
|
||||||
re = /^(.+?)y$/;
|
|
||||||
if (re.test(w)) {
|
|
||||||
var fp = re.exec(w);
|
|
||||||
stem = fp[1];
|
|
||||||
re = new RegExp(s_v);
|
|
||||||
if (re.test(stem))
|
|
||||||
w = stem + "i";
|
|
||||||
}
|
|
||||||
|
|
||||||
// Step 2
|
|
||||||
re = /^(.+?)(ational|tional|enci|anci|izer|bli|alli|entli|eli|ousli|ization|ation|ator|alism|iveness|fulness|ousness|aliti|iviti|biliti|logi)$/;
|
|
||||||
if (re.test(w)) {
|
|
||||||
var fp = re.exec(w);
|
|
||||||
stem = fp[1];
|
|
||||||
suffix = fp[2];
|
|
||||||
re = new RegExp(mgr0);
|
|
||||||
if (re.test(stem))
|
|
||||||
w = stem + step2list[suffix];
|
|
||||||
}
|
|
||||||
|
|
||||||
// Step 3
|
|
||||||
re = /^(.+?)(icate|ative|alize|iciti|ical|ful|ness)$/;
|
|
||||||
if (re.test(w)) {
|
|
||||||
var fp = re.exec(w);
|
|
||||||
stem = fp[1];
|
|
||||||
suffix = fp[2];
|
|
||||||
re = new RegExp(mgr0);
|
|
||||||
if (re.test(stem))
|
|
||||||
w = stem + step3list[suffix];
|
|
||||||
}
|
|
||||||
|
|
||||||
// Step 4
|
|
||||||
re = /^(.+?)(al|ance|ence|er|ic|able|ible|ant|ement|ment|ent|ou|ism|ate|iti|ous|ive|ize)$/;
|
|
||||||
re2 = /^(.+?)(s|t)(ion)$/;
|
|
||||||
if (re.test(w)) {
|
|
||||||
var fp = re.exec(w);
|
|
||||||
stem = fp[1];
|
|
||||||
re = new RegExp(mgr1);
|
|
||||||
if (re.test(stem))
|
|
||||||
w = stem;
|
|
||||||
}
|
|
||||||
else if (re2.test(w)) {
|
|
||||||
var fp = re2.exec(w);
|
|
||||||
stem = fp[1] + fp[2];
|
|
||||||
re2 = new RegExp(mgr1);
|
|
||||||
if (re2.test(stem))
|
|
||||||
w = stem;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Step 5
|
|
||||||
re = /^(.+?)e$/;
|
|
||||||
if (re.test(w)) {
|
|
||||||
var fp = re.exec(w);
|
|
||||||
stem = fp[1];
|
|
||||||
re = new RegExp(mgr1);
|
|
||||||
re2 = new RegExp(meq1);
|
|
||||||
re3 = new RegExp("^" + C + v + "[^aeiouwxy]$");
|
|
||||||
if (re.test(stem) || (re2.test(stem) && !(re3.test(stem))))
|
|
||||||
w = stem;
|
|
||||||
}
|
|
||||||
re = /ll$/;
|
|
||||||
re2 = new RegExp(mgr1);
|
|
||||||
if (re.test(w) && re2.test(w)) {
|
|
||||||
re = /.$/;
|
|
||||||
w = w.replace(re,"");
|
|
||||||
}
|
|
||||||
|
|
||||||
// and turn initial Y back to y
|
|
||||||
if (firstch == "y")
|
|
||||||
w = firstch.toLowerCase() + w.substr(1);
|
|
||||||
return w;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
Before Width: | Height: | Size: 90 B |
Before Width: | Height: | Size: 90 B |
Before Width: | Height: | Size: 20 KiB |
@ -1,75 +0,0 @@
|
|||||||
pre { line-height: 125%; }
|
|
||||||
td.linenos .normal { color: inherit; background-color: transparent; padding-left: 5px; padding-right: 5px; }
|
|
||||||
span.linenos { color: inherit; background-color: transparent; padding-left: 5px; padding-right: 5px; }
|
|
||||||
td.linenos .special { color: #000000; background-color: #ffffc0; padding-left: 5px; padding-right: 5px; }
|
|
||||||
span.linenos.special { color: #000000; background-color: #ffffc0; padding-left: 5px; padding-right: 5px; }
|
|
||||||
.highlight .hll { background-color: #ffffcc }
|
|
||||||
.highlight { background: #f8f8f8; }
|
|
||||||
.highlight .c { color: #3D7B7B; font-style: italic } /* Comment */
|
|
||||||
.highlight .err { border: 1px solid #F00 } /* Error */
|
|
||||||
.highlight .k { color: #008000; font-weight: bold } /* Keyword */
|
|
||||||
.highlight .o { color: #666 } /* Operator */
|
|
||||||
.highlight .ch { color: #3D7B7B; font-style: italic } /* Comment.Hashbang */
|
|
||||||
.highlight .cm { color: #3D7B7B; font-style: italic } /* Comment.Multiline */
|
|
||||||
.highlight .cp { color: #9C6500 } /* Comment.Preproc */
|
|
||||||
.highlight .cpf { color: #3D7B7B; font-style: italic } /* Comment.PreprocFile */
|
|
||||||
.highlight .c1 { color: #3D7B7B; font-style: italic } /* Comment.Single */
|
|
||||||
.highlight .cs { color: #3D7B7B; font-style: italic } /* Comment.Special */
|
|
||||||
.highlight .gd { color: #A00000 } /* Generic.Deleted */
|
|
||||||
.highlight .ge { font-style: italic } /* Generic.Emph */
|
|
||||||
.highlight .ges { font-weight: bold; font-style: italic } /* Generic.EmphStrong */
|
|
||||||
.highlight .gr { color: #E40000 } /* Generic.Error */
|
|
||||||
.highlight .gh { color: #000080; font-weight: bold } /* Generic.Heading */
|
|
||||||
.highlight .gi { color: #008400 } /* Generic.Inserted */
|
|
||||||
.highlight .go { color: #717171 } /* Generic.Output */
|
|
||||||
.highlight .gp { color: #000080; font-weight: bold } /* Generic.Prompt */
|
|
||||||
.highlight .gs { font-weight: bold } /* Generic.Strong */
|
|
||||||
.highlight .gu { color: #800080; font-weight: bold } /* Generic.Subheading */
|
|
||||||
.highlight .gt { color: #04D } /* Generic.Traceback */
|
|
||||||
.highlight .kc { color: #008000; font-weight: bold } /* Keyword.Constant */
|
|
||||||
.highlight .kd { color: #008000; font-weight: bold } /* Keyword.Declaration */
|
|
||||||
.highlight .kn { color: #008000; font-weight: bold } /* Keyword.Namespace */
|
|
||||||
.highlight .kp { color: #008000 } /* Keyword.Pseudo */
|
|
||||||
.highlight .kr { color: #008000; font-weight: bold } /* Keyword.Reserved */
|
|
||||||
.highlight .kt { color: #B00040 } /* Keyword.Type */
|
|
||||||
.highlight .m { color: #666 } /* Literal.Number */
|
|
||||||
.highlight .s { color: #BA2121 } /* Literal.String */
|
|
||||||
.highlight .na { color: #687822 } /* Name.Attribute */
|
|
||||||
.highlight .nb { color: #008000 } /* Name.Builtin */
|
|
||||||
.highlight .nc { color: #00F; font-weight: bold } /* Name.Class */
|
|
||||||
.highlight .no { color: #800 } /* Name.Constant */
|
|
||||||
.highlight .nd { color: #A2F } /* Name.Decorator */
|
|
||||||
.highlight .ni { color: #717171; font-weight: bold } /* Name.Entity */
|
|
||||||
.highlight .ne { color: #CB3F38; font-weight: bold } /* Name.Exception */
|
|
||||||
.highlight .nf { color: #00F } /* Name.Function */
|
|
||||||
.highlight .nl { color: #767600 } /* Name.Label */
|
|
||||||
.highlight .nn { color: #00F; font-weight: bold } /* Name.Namespace */
|
|
||||||
.highlight .nt { color: #008000; font-weight: bold } /* Name.Tag */
|
|
||||||
.highlight .nv { color: #19177C } /* Name.Variable */
|
|
||||||
.highlight .ow { color: #A2F; font-weight: bold } /* Operator.Word */
|
|
||||||
.highlight .w { color: #BBB } /* Text.Whitespace */
|
|
||||||
.highlight .mb { color: #666 } /* Literal.Number.Bin */
|
|
||||||
.highlight .mf { color: #666 } /* Literal.Number.Float */
|
|
||||||
.highlight .mh { color: #666 } /* Literal.Number.Hex */
|
|
||||||
.highlight .mi { color: #666 } /* Literal.Number.Integer */
|
|
||||||
.highlight .mo { color: #666 } /* Literal.Number.Oct */
|
|
||||||
.highlight .sa { color: #BA2121 } /* Literal.String.Affix */
|
|
||||||
.highlight .sb { color: #BA2121 } /* Literal.String.Backtick */
|
|
||||||
.highlight .sc { color: #BA2121 } /* Literal.String.Char */
|
|
||||||
.highlight .dl { color: #BA2121 } /* Literal.String.Delimiter */
|
|
||||||
.highlight .sd { color: #BA2121; font-style: italic } /* Literal.String.Doc */
|
|
||||||
.highlight .s2 { color: #BA2121 } /* Literal.String.Double */
|
|
||||||
.highlight .se { color: #AA5D1F; font-weight: bold } /* Literal.String.Escape */
|
|
||||||
.highlight .sh { color: #BA2121 } /* Literal.String.Heredoc */
|
|
||||||
.highlight .si { color: #A45A77; font-weight: bold } /* Literal.String.Interpol */
|
|
||||||
.highlight .sx { color: #008000 } /* Literal.String.Other */
|
|
||||||
.highlight .sr { color: #A45A77 } /* Literal.String.Regex */
|
|
||||||
.highlight .s1 { color: #BA2121 } /* Literal.String.Single */
|
|
||||||
.highlight .ss { color: #19177C } /* Literal.String.Symbol */
|
|
||||||
.highlight .bp { color: #008000 } /* Name.Builtin.Pseudo */
|
|
||||||
.highlight .fm { color: #00F } /* Name.Function.Magic */
|
|
||||||
.highlight .vc { color: #19177C } /* Name.Variable.Class */
|
|
||||||
.highlight .vg { color: #19177C } /* Name.Variable.Global */
|
|
||||||
.highlight .vi { color: #19177C } /* Name.Variable.Instance */
|
|
||||||
.highlight .vm { color: #19177C } /* Name.Variable.Magic */
|
|
||||||
.highlight .il { color: #666 } /* Literal.Number.Integer.Long */
|
|
@ -1,632 +0,0 @@
|
|||||||
/*
|
|
||||||
* Sphinx JavaScript utilities for the full-text search.
|
|
||||||
*/
|
|
||||||
"use strict";
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Simple result scoring code.
|
|
||||||
*/
|
|
||||||
if (typeof Scorer === "undefined") {
|
|
||||||
var Scorer = {
|
|
||||||
// Implement the following function to further tweak the score for each result
|
|
||||||
// The function takes a result array [docname, title, anchor, descr, score, filename]
|
|
||||||
// and returns the new score.
|
|
||||||
/*
|
|
||||||
score: result => {
|
|
||||||
const [docname, title, anchor, descr, score, filename, kind] = result
|
|
||||||
return score
|
|
||||||
},
|
|
||||||
*/
|
|
||||||
|
|
||||||
// query matches the full name of an object
|
|
||||||
objNameMatch: 11,
|
|
||||||
// or matches in the last dotted part of the object name
|
|
||||||
objPartialMatch: 6,
|
|
||||||
// Additive scores depending on the priority of the object
|
|
||||||
objPrio: {
|
|
||||||
0: 15, // used to be importantResults
|
|
||||||
1: 5, // used to be objectResults
|
|
||||||
2: -5, // used to be unimportantResults
|
|
||||||
},
|
|
||||||
// Used when the priority is not in the mapping.
|
|
||||||
objPrioDefault: 0,
|
|
||||||
|
|
||||||
// query found in title
|
|
||||||
title: 15,
|
|
||||||
partialTitle: 7,
|
|
||||||
// query found in terms
|
|
||||||
term: 5,
|
|
||||||
partialTerm: 2,
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
// Global search result kind enum, used by themes to style search results.
|
|
||||||
class SearchResultKind {
|
|
||||||
static get index() { return "index"; }
|
|
||||||
static get object() { return "object"; }
|
|
||||||
static get text() { return "text"; }
|
|
||||||
static get title() { return "title"; }
|
|
||||||
}
|
|
||||||
|
|
||||||
const _removeChildren = (element) => {
|
|
||||||
while (element && element.lastChild) element.removeChild(element.lastChild);
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* See https://developer.mozilla.org/en-US/docs/Web/JavaScript/Guide/Regular_Expressions#escaping
|
|
||||||
*/
|
|
||||||
const _escapeRegExp = (string) =>
|
|
||||||
string.replace(/[.*+\-?^${}()|[\]\\]/g, "\\$&"); // $& means the whole matched string
|
|
||||||
|
|
||||||
const _displayItem = (item, searchTerms, highlightTerms) => {
|
|
||||||
const docBuilder = DOCUMENTATION_OPTIONS.BUILDER;
|
|
||||||
const docFileSuffix = DOCUMENTATION_OPTIONS.FILE_SUFFIX;
|
|
||||||
const docLinkSuffix = DOCUMENTATION_OPTIONS.LINK_SUFFIX;
|
|
||||||
const showSearchSummary = DOCUMENTATION_OPTIONS.SHOW_SEARCH_SUMMARY;
|
|
||||||
const contentRoot = document.documentElement.dataset.content_root;
|
|
||||||
|
|
||||||
const [docName, title, anchor, descr, score, _filename, kind] = item;
|
|
||||||
|
|
||||||
let listItem = document.createElement("li");
|
|
||||||
// Add a class representing the item's type:
|
|
||||||
// can be used by a theme's CSS selector for styling
|
|
||||||
// See SearchResultKind for the class names.
|
|
||||||
listItem.classList.add(`kind-${kind}`);
|
|
||||||
let requestUrl;
|
|
||||||
let linkUrl;
|
|
||||||
if (docBuilder === "dirhtml") {
|
|
||||||
// dirhtml builder
|
|
||||||
let dirname = docName + "/";
|
|
||||||
if (dirname.match(/\/index\/$/))
|
|
||||||
dirname = dirname.substring(0, dirname.length - 6);
|
|
||||||
else if (dirname === "index/") dirname = "";
|
|
||||||
requestUrl = contentRoot + dirname;
|
|
||||||
linkUrl = requestUrl;
|
|
||||||
} else {
|
|
||||||
// normal html builders
|
|
||||||
requestUrl = contentRoot + docName + docFileSuffix;
|
|
||||||
linkUrl = docName + docLinkSuffix;
|
|
||||||
}
|
|
||||||
let linkEl = listItem.appendChild(document.createElement("a"));
|
|
||||||
linkEl.href = linkUrl + anchor;
|
|
||||||
linkEl.dataset.score = score;
|
|
||||||
linkEl.innerHTML = title;
|
|
||||||
if (descr) {
|
|
||||||
listItem.appendChild(document.createElement("span")).innerHTML =
|
|
||||||
" (" + descr + ")";
|
|
||||||
// highlight search terms in the description
|
|
||||||
if (SPHINX_HIGHLIGHT_ENABLED) // set in sphinx_highlight.js
|
|
||||||
highlightTerms.forEach((term) => _highlightText(listItem, term, "highlighted"));
|
|
||||||
}
|
|
||||||
else if (showSearchSummary)
|
|
||||||
fetch(requestUrl)
|
|
||||||
.then((responseData) => responseData.text())
|
|
||||||
.then((data) => {
|
|
||||||
if (data)
|
|
||||||
listItem.appendChild(
|
|
||||||
Search.makeSearchSummary(data, searchTerms, anchor)
|
|
||||||
);
|
|
||||||
// highlight search terms in the summary
|
|
||||||
if (SPHINX_HIGHLIGHT_ENABLED) // set in sphinx_highlight.js
|
|
||||||
highlightTerms.forEach((term) => _highlightText(listItem, term, "highlighted"));
|
|
||||||
});
|
|
||||||
Search.output.appendChild(listItem);
|
|
||||||
};
|
|
||||||
const _finishSearch = (resultCount) => {
|
|
||||||
Search.stopPulse();
|
|
||||||
Search.title.innerText = _("Search Results");
|
|
||||||
if (!resultCount)
|
|
||||||
Search.status.innerText = Documentation.gettext(
|
|
||||||
"Your search did not match any documents. Please make sure that all words are spelled correctly and that you've selected enough categories."
|
|
||||||
);
|
|
||||||
else
|
|
||||||
Search.status.innerText = Documentation.ngettext(
|
|
||||||
"Search finished, found one page matching the search query.",
|
|
||||||
"Search finished, found ${resultCount} pages matching the search query.",
|
|
||||||
resultCount,
|
|
||||||
).replace('${resultCount}', resultCount);
|
|
||||||
};
|
|
||||||
const _displayNextItem = (
|
|
||||||
results,
|
|
||||||
resultCount,
|
|
||||||
searchTerms,
|
|
||||||
highlightTerms,
|
|
||||||
) => {
|
|
||||||
// results left, load the summary and display it
|
|
||||||
// this is intended to be dynamic (don't sub resultsCount)
|
|
||||||
if (results.length) {
|
|
||||||
_displayItem(results.pop(), searchTerms, highlightTerms);
|
|
||||||
setTimeout(
|
|
||||||
() => _displayNextItem(results, resultCount, searchTerms, highlightTerms),
|
|
||||||
5
|
|
||||||
);
|
|
||||||
}
|
|
||||||
// search finished, update title and status message
|
|
||||||
else _finishSearch(resultCount);
|
|
||||||
};
|
|
||||||
// Helper function used by query() to order search results.
|
|
||||||
// Each input is an array of [docname, title, anchor, descr, score, filename, kind].
|
|
||||||
// Order the results by score (in opposite order of appearance, since the
|
|
||||||
// `_displayNextItem` function uses pop() to retrieve items) and then alphabetically.
|
|
||||||
const _orderResultsByScoreThenName = (a, b) => {
|
|
||||||
const leftScore = a[4];
|
|
||||||
const rightScore = b[4];
|
|
||||||
if (leftScore === rightScore) {
|
|
||||||
// same score: sort alphabetically
|
|
||||||
const leftTitle = a[1].toLowerCase();
|
|
||||||
const rightTitle = b[1].toLowerCase();
|
|
||||||
if (leftTitle === rightTitle) return 0;
|
|
||||||
return leftTitle > rightTitle ? -1 : 1; // inverted is intentional
|
|
||||||
}
|
|
||||||
return leftScore > rightScore ? 1 : -1;
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Default splitQuery function. Can be overridden in ``sphinx.search`` with a
|
|
||||||
* custom function per language.
|
|
||||||
*
|
|
||||||
* The regular expression works by splitting the string on consecutive characters
|
|
||||||
* that are not Unicode letters, numbers, underscores, or emoji characters.
|
|
||||||
* This is the same as ``\W+`` in Python, preserving the surrogate pair area.
|
|
||||||
*/
|
|
||||||
if (typeof splitQuery === "undefined") {
|
|
||||||
var splitQuery = (query) => query
|
|
||||||
.split(/[^\p{Letter}\p{Number}_\p{Emoji_Presentation}]+/gu)
|
|
||||||
.filter(term => term) // remove remaining empty strings
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Search Module
|
|
||||||
*/
|
|
||||||
const Search = {
|
|
||||||
_index: null,
|
|
||||||
_queued_query: null,
|
|
||||||
_pulse_status: -1,
|
|
||||||
|
|
||||||
htmlToText: (htmlString, anchor) => {
|
|
||||||
const htmlElement = new DOMParser().parseFromString(htmlString, 'text/html');
|
|
||||||
for (const removalQuery of [".headerlink", "script", "style"]) {
|
|
||||||
htmlElement.querySelectorAll(removalQuery).forEach((el) => { el.remove() });
|
|
||||||
}
|
|
||||||
if (anchor) {
|
|
||||||
const anchorContent = htmlElement.querySelector(`[role="main"] ${anchor}`);
|
|
||||||
if (anchorContent) return anchorContent.textContent;
|
|
||||||
|
|
||||||
console.warn(
|
|
||||||
`Anchored content block not found. Sphinx search tries to obtain it via DOM query '[role=main] ${anchor}'. Check your theme or template.`
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
// if anchor not specified or not found, fall back to main content
|
|
||||||
const docContent = htmlElement.querySelector('[role="main"]');
|
|
||||||
if (docContent) return docContent.textContent;
|
|
||||||
|
|
||||||
console.warn(
|
|
||||||
"Content block not found. Sphinx search tries to obtain it via DOM query '[role=main]'. Check your theme or template."
|
|
||||||
);
|
|
||||||
return "";
|
|
||||||
},
|
|
||||||
|
|
||||||
init: () => {
|
|
||||||
const query = new URLSearchParams(window.location.search).get("q");
|
|
||||||
document
|
|
||||||
.querySelectorAll('input[name="q"]')
|
|
||||||
.forEach((el) => (el.value = query));
|
|
||||||
if (query) Search.performSearch(query);
|
|
||||||
},
|
|
||||||
|
|
||||||
loadIndex: (url) =>
|
|
||||||
(document.body.appendChild(document.createElement("script")).src = url),
|
|
||||||
|
|
||||||
setIndex: (index) => {
|
|
||||||
Search._index = index;
|
|
||||||
if (Search._queued_query !== null) {
|
|
||||||
const query = Search._queued_query;
|
|
||||||
Search._queued_query = null;
|
|
||||||
Search.query(query);
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
hasIndex: () => Search._index !== null,
|
|
||||||
|
|
||||||
deferQuery: (query) => (Search._queued_query = query),
|
|
||||||
|
|
||||||
stopPulse: () => (Search._pulse_status = -1),
|
|
||||||
|
|
||||||
startPulse: () => {
|
|
||||||
if (Search._pulse_status >= 0) return;
|
|
||||||
|
|
||||||
const pulse = () => {
|
|
||||||
Search._pulse_status = (Search._pulse_status + 1) % 4;
|
|
||||||
Search.dots.innerText = ".".repeat(Search._pulse_status);
|
|
||||||
if (Search._pulse_status >= 0) window.setTimeout(pulse, 500);
|
|
||||||
};
|
|
||||||
pulse();
|
|
||||||
},
|
|
||||||
|
|
||||||
/**
|
|
||||||
* perform a search for something (or wait until index is loaded)
|
|
||||||
*/
|
|
||||||
performSearch: (query) => {
|
|
||||||
// create the required interface elements
|
|
||||||
const searchText = document.createElement("h2");
|
|
||||||
searchText.textContent = _("Searching");
|
|
||||||
const searchSummary = document.createElement("p");
|
|
||||||
searchSummary.classList.add("search-summary");
|
|
||||||
searchSummary.innerText = "";
|
|
||||||
const searchList = document.createElement("ul");
|
|
||||||
searchList.setAttribute("role", "list");
|
|
||||||
searchList.classList.add("search");
|
|
||||||
|
|
||||||
const out = document.getElementById("search-results");
|
|
||||||
Search.title = out.appendChild(searchText);
|
|
||||||
Search.dots = Search.title.appendChild(document.createElement("span"));
|
|
||||||
Search.status = out.appendChild(searchSummary);
|
|
||||||
Search.output = out.appendChild(searchList);
|
|
||||||
|
|
||||||
const searchProgress = document.getElementById("search-progress");
|
|
||||||
// Some themes don't use the search progress node
|
|
||||||
if (searchProgress) {
|
|
||||||
searchProgress.innerText = _("Preparing search...");
|
|
||||||
}
|
|
||||||
Search.startPulse();
|
|
||||||
|
|
||||||
// index already loaded, the browser was quick!
|
|
||||||
if (Search.hasIndex()) Search.query(query);
|
|
||||||
else Search.deferQuery(query);
|
|
||||||
},
|
|
||||||
|
|
||||||
_parseQuery: (query) => {
|
|
||||||
// stem the search terms and add them to the correct list
|
|
||||||
const stemmer = new Stemmer();
|
|
||||||
const searchTerms = new Set();
|
|
||||||
const excludedTerms = new Set();
|
|
||||||
const highlightTerms = new Set();
|
|
||||||
const objectTerms = new Set(splitQuery(query.toLowerCase().trim()));
|
|
||||||
splitQuery(query.trim()).forEach((queryTerm) => {
|
|
||||||
const queryTermLower = queryTerm.toLowerCase();
|
|
||||||
|
|
||||||
// maybe skip this "word"
|
|
||||||
// stopwords array is from language_data.js
|
|
||||||
if (
|
|
||||||
stopwords.indexOf(queryTermLower) !== -1 ||
|
|
||||||
queryTerm.match(/^\d+$/)
|
|
||||||
)
|
|
||||||
return;
|
|
||||||
|
|
||||||
// stem the word
|
|
||||||
let word = stemmer.stemWord(queryTermLower);
|
|
||||||
// select the correct list
|
|
||||||
if (word[0] === "-") excludedTerms.add(word.substr(1));
|
|
||||||
else {
|
|
||||||
searchTerms.add(word);
|
|
||||||
highlightTerms.add(queryTermLower);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
if (SPHINX_HIGHLIGHT_ENABLED) { // set in sphinx_highlight.js
|
|
||||||
localStorage.setItem("sphinx_highlight_terms", [...highlightTerms].join(" "))
|
|
||||||
}
|
|
||||||
|
|
||||||
// console.debug("SEARCH: searching for:");
|
|
||||||
// console.info("required: ", [...searchTerms]);
|
|
||||||
// console.info("excluded: ", [...excludedTerms]);
|
|
||||||
|
|
||||||
return [query, searchTerms, excludedTerms, highlightTerms, objectTerms];
|
|
||||||
},
|
|
||||||
|
|
||||||
/**
|
|
||||||
* execute search (requires search index to be loaded)
|
|
||||||
*/
|
|
||||||
_performSearch: (query, searchTerms, excludedTerms, highlightTerms, objectTerms) => {
|
|
||||||
const filenames = Search._index.filenames;
|
|
||||||
const docNames = Search._index.docnames;
|
|
||||||
const titles = Search._index.titles;
|
|
||||||
const allTitles = Search._index.alltitles;
|
|
||||||
const indexEntries = Search._index.indexentries;
|
|
||||||
|
|
||||||
// Collect multiple result groups to be sorted separately and then ordered.
|
|
||||||
// Each is an array of [docname, title, anchor, descr, score, filename, kind].
|
|
||||||
const normalResults = [];
|
|
||||||
const nonMainIndexResults = [];
|
|
||||||
|
|
||||||
_removeChildren(document.getElementById("search-progress"));
|
|
||||||
|
|
||||||
const queryLower = query.toLowerCase().trim();
|
|
||||||
for (const [title, foundTitles] of Object.entries(allTitles)) {
|
|
||||||
if (title.toLowerCase().trim().includes(queryLower) && (queryLower.length >= title.length/2)) {
|
|
||||||
for (const [file, id] of foundTitles) {
|
|
||||||
const score = Math.round(Scorer.title * queryLower.length / title.length);
|
|
||||||
const boost = titles[file] === title ? 1 : 0; // add a boost for document titles
|
|
||||||
normalResults.push([
|
|
||||||
docNames[file],
|
|
||||||
titles[file] !== title ? `${titles[file]} > ${title}` : title,
|
|
||||||
id !== null ? "#" + id : "",
|
|
||||||
null,
|
|
||||||
score + boost,
|
|
||||||
filenames[file],
|
|
||||||
SearchResultKind.title,
|
|
||||||
]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// search for explicit entries in index directives
|
|
||||||
for (const [entry, foundEntries] of Object.entries(indexEntries)) {
|
|
||||||
if (entry.includes(queryLower) && (queryLower.length >= entry.length/2)) {
|
|
||||||
for (const [file, id, isMain] of foundEntries) {
|
|
||||||
const score = Math.round(100 * queryLower.length / entry.length);
|
|
||||||
const result = [
|
|
||||||
docNames[file],
|
|
||||||
titles[file],
|
|
||||||
id ? "#" + id : "",
|
|
||||||
null,
|
|
||||||
score,
|
|
||||||
filenames[file],
|
|
||||||
SearchResultKind.index,
|
|
||||||
];
|
|
||||||
if (isMain) {
|
|
||||||
normalResults.push(result);
|
|
||||||
} else {
|
|
||||||
nonMainIndexResults.push(result);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// lookup as object
|
|
||||||
objectTerms.forEach((term) =>
|
|
||||||
normalResults.push(...Search.performObjectSearch(term, objectTerms))
|
|
||||||
);
|
|
||||||
|
|
||||||
// lookup as search terms in fulltext
|
|
||||||
normalResults.push(...Search.performTermsSearch(searchTerms, excludedTerms));
|
|
||||||
|
|
||||||
// let the scorer override scores with a custom scoring function
|
|
||||||
if (Scorer.score) {
|
|
||||||
normalResults.forEach((item) => (item[4] = Scorer.score(item)));
|
|
||||||
nonMainIndexResults.forEach((item) => (item[4] = Scorer.score(item)));
|
|
||||||
}
|
|
||||||
|
|
||||||
// Sort each group of results by score and then alphabetically by name.
|
|
||||||
normalResults.sort(_orderResultsByScoreThenName);
|
|
||||||
nonMainIndexResults.sort(_orderResultsByScoreThenName);
|
|
||||||
|
|
||||||
// Combine the result groups in (reverse) order.
|
|
||||||
// Non-main index entries are typically arbitrary cross-references,
|
|
||||||
// so display them after other results.
|
|
||||||
let results = [...nonMainIndexResults, ...normalResults];
|
|
||||||
|
|
||||||
// remove duplicate search results
|
|
||||||
// note the reversing of results, so that in the case of duplicates, the highest-scoring entry is kept
|
|
||||||
let seen = new Set();
|
|
||||||
results = results.reverse().reduce((acc, result) => {
|
|
||||||
let resultStr = result.slice(0, 4).concat([result[5]]).map(v => String(v)).join(',');
|
|
||||||
if (!seen.has(resultStr)) {
|
|
||||||
acc.push(result);
|
|
||||||
seen.add(resultStr);
|
|
||||||
}
|
|
||||||
return acc;
|
|
||||||
}, []);
|
|
||||||
|
|
||||||
return results.reverse();
|
|
||||||
},
|
|
||||||
|
|
||||||
query: (query) => {
|
|
||||||
const [searchQuery, searchTerms, excludedTerms, highlightTerms, objectTerms] = Search._parseQuery(query);
|
|
||||||
const results = Search._performSearch(searchQuery, searchTerms, excludedTerms, highlightTerms, objectTerms);
|
|
||||||
|
|
||||||
// for debugging
|
|
||||||
//Search.lastresults = results.slice(); // a copy
|
|
||||||
// console.info("search results:", Search.lastresults);
|
|
||||||
|
|
||||||
// print the results
|
|
||||||
_displayNextItem(results, results.length, searchTerms, highlightTerms);
|
|
||||||
},
|
|
||||||
|
|
||||||
/**
|
|
||||||
* search for object names
|
|
||||||
*/
|
|
||||||
performObjectSearch: (object, objectTerms) => {
|
|
||||||
const filenames = Search._index.filenames;
|
|
||||||
const docNames = Search._index.docnames;
|
|
||||||
const objects = Search._index.objects;
|
|
||||||
const objNames = Search._index.objnames;
|
|
||||||
const titles = Search._index.titles;
|
|
||||||
|
|
||||||
const results = [];
|
|
||||||
|
|
||||||
const objectSearchCallback = (prefix, match) => {
|
|
||||||
const name = match[4]
|
|
||||||
const fullname = (prefix ? prefix + "." : "") + name;
|
|
||||||
const fullnameLower = fullname.toLowerCase();
|
|
||||||
if (fullnameLower.indexOf(object) < 0) return;
|
|
||||||
|
|
||||||
let score = 0;
|
|
||||||
const parts = fullnameLower.split(".");
|
|
||||||
|
|
||||||
// check for different match types: exact matches of full name or
|
|
||||||
// "last name" (i.e. last dotted part)
|
|
||||||
if (fullnameLower === object || parts.slice(-1)[0] === object)
|
|
||||||
score += Scorer.objNameMatch;
|
|
||||||
else if (parts.slice(-1)[0].indexOf(object) > -1)
|
|
||||||
score += Scorer.objPartialMatch; // matches in last name
|
|
||||||
|
|
||||||
const objName = objNames[match[1]][2];
|
|
||||||
const title = titles[match[0]];
|
|
||||||
|
|
||||||
// If more than one term searched for, we require other words to be
|
|
||||||
// found in the name/title/description
|
|
||||||
const otherTerms = new Set(objectTerms);
|
|
||||||
otherTerms.delete(object);
|
|
||||||
if (otherTerms.size > 0) {
|
|
||||||
const haystack = `${prefix} ${name} ${objName} ${title}`.toLowerCase();
|
|
||||||
if (
|
|
||||||
[...otherTerms].some((otherTerm) => haystack.indexOf(otherTerm) < 0)
|
|
||||||
)
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
let anchor = match[3];
|
|
||||||
if (anchor === "") anchor = fullname;
|
|
||||||
else if (anchor === "-") anchor = objNames[match[1]][1] + "-" + fullname;
|
|
||||||
|
|
||||||
const descr = objName + _(", in ") + title;
|
|
||||||
|
|
||||||
// add custom score for some objects according to scorer
|
|
||||||
if (Scorer.objPrio.hasOwnProperty(match[2]))
|
|
||||||
score += Scorer.objPrio[match[2]];
|
|
||||||
else score += Scorer.objPrioDefault;
|
|
||||||
|
|
||||||
results.push([
|
|
||||||
docNames[match[0]],
|
|
||||||
fullname,
|
|
||||||
"#" + anchor,
|
|
||||||
descr,
|
|
||||||
score,
|
|
||||||
filenames[match[0]],
|
|
||||||
SearchResultKind.object,
|
|
||||||
]);
|
|
||||||
};
|
|
||||||
Object.keys(objects).forEach((prefix) =>
|
|
||||||
objects[prefix].forEach((array) =>
|
|
||||||
objectSearchCallback(prefix, array)
|
|
||||||
)
|
|
||||||
);
|
|
||||||
return results;
|
|
||||||
},
|
|
||||||
|
|
||||||
/**
|
|
||||||
* search for full-text terms in the index
|
|
||||||
*/
|
|
||||||
performTermsSearch: (searchTerms, excludedTerms) => {
|
|
||||||
// prepare search
|
|
||||||
const terms = Search._index.terms;
|
|
||||||
const titleTerms = Search._index.titleterms;
|
|
||||||
const filenames = Search._index.filenames;
|
|
||||||
const docNames = Search._index.docnames;
|
|
||||||
const titles = Search._index.titles;
|
|
||||||
|
|
||||||
const scoreMap = new Map();
|
|
||||||
const fileMap = new Map();
|
|
||||||
|
|
||||||
// perform the search on the required terms
|
|
||||||
searchTerms.forEach((word) => {
|
|
||||||
const files = [];
|
|
||||||
const arr = [
|
|
||||||
{ files: terms[word], score: Scorer.term },
|
|
||||||
{ files: titleTerms[word], score: Scorer.title },
|
|
||||||
];
|
|
||||||
// add support for partial matches
|
|
||||||
if (word.length > 2) {
|
|
||||||
const escapedWord = _escapeRegExp(word);
|
|
||||||
if (!terms.hasOwnProperty(word)) {
|
|
||||||
Object.keys(terms).forEach((term) => {
|
|
||||||
if (term.match(escapedWord))
|
|
||||||
arr.push({ files: terms[term], score: Scorer.partialTerm });
|
|
||||||
});
|
|
||||||
}
|
|
||||||
if (!titleTerms.hasOwnProperty(word)) {
|
|
||||||
Object.keys(titleTerms).forEach((term) => {
|
|
||||||
if (term.match(escapedWord))
|
|
||||||
arr.push({ files: titleTerms[term], score: Scorer.partialTitle });
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// no match but word was a required one
|
|
||||||
if (arr.every((record) => record.files === undefined)) return;
|
|
||||||
|
|
||||||
// found search word in contents
|
|
||||||
arr.forEach((record) => {
|
|
||||||
if (record.files === undefined) return;
|
|
||||||
|
|
||||||
let recordFiles = record.files;
|
|
||||||
if (recordFiles.length === undefined) recordFiles = [recordFiles];
|
|
||||||
files.push(...recordFiles);
|
|
||||||
|
|
||||||
// set score for the word in each file
|
|
||||||
recordFiles.forEach((file) => {
|
|
||||||
if (!scoreMap.has(file)) scoreMap.set(file, {});
|
|
||||||
scoreMap.get(file)[word] = record.score;
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
// create the mapping
|
|
||||||
files.forEach((file) => {
|
|
||||||
if (!fileMap.has(file)) fileMap.set(file, [word]);
|
|
||||||
else if (fileMap.get(file).indexOf(word) === -1) fileMap.get(file).push(word);
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
// now check if the files don't contain excluded terms
|
|
||||||
const results = [];
|
|
||||||
for (const [file, wordList] of fileMap) {
|
|
||||||
// check if all requirements are matched
|
|
||||||
|
|
||||||
// as search terms with length < 3 are discarded
|
|
||||||
const filteredTermCount = [...searchTerms].filter(
|
|
||||||
(term) => term.length > 2
|
|
||||||
).length;
|
|
||||||
if (
|
|
||||||
wordList.length !== searchTerms.size &&
|
|
||||||
wordList.length !== filteredTermCount
|
|
||||||
)
|
|
||||||
continue;
|
|
||||||
|
|
||||||
// ensure that none of the excluded terms is in the search result
|
|
||||||
if (
|
|
||||||
[...excludedTerms].some(
|
|
||||||
(term) =>
|
|
||||||
terms[term] === file ||
|
|
||||||
titleTerms[term] === file ||
|
|
||||||
(terms[term] || []).includes(file) ||
|
|
||||||
(titleTerms[term] || []).includes(file)
|
|
||||||
)
|
|
||||||
)
|
|
||||||
break;
|
|
||||||
|
|
||||||
// select one (max) score for the file.
|
|
||||||
const score = Math.max(...wordList.map((w) => scoreMap.get(file)[w]));
|
|
||||||
// add result to the result list
|
|
||||||
results.push([
|
|
||||||
docNames[file],
|
|
||||||
titles[file],
|
|
||||||
"",
|
|
||||||
null,
|
|
||||||
score,
|
|
||||||
filenames[file],
|
|
||||||
SearchResultKind.text,
|
|
||||||
]);
|
|
||||||
}
|
|
||||||
return results;
|
|
||||||
},
|
|
||||||
|
|
||||||
/**
|
|
||||||
* helper function to return a node containing the
|
|
||||||
* search summary for a given text. keywords is a list
|
|
||||||
* of stemmed words.
|
|
||||||
*/
|
|
||||||
makeSearchSummary: (htmlText, keywords, anchor) => {
|
|
||||||
const text = Search.htmlToText(htmlText, anchor);
|
|
||||||
if (text === "") return null;
|
|
||||||
|
|
||||||
const textLower = text.toLowerCase();
|
|
||||||
const actualStartPosition = [...keywords]
|
|
||||||
.map((k) => textLower.indexOf(k.toLowerCase()))
|
|
||||||
.filter((i) => i > -1)
|
|
||||||
.slice(-1)[0];
|
|
||||||
const startWithContext = Math.max(actualStartPosition - 120, 0);
|
|
||||||
|
|
||||||
const top = startWithContext === 0 ? "" : "...";
|
|
||||||
const tail = startWithContext + 240 < text.length ? "..." : "";
|
|
||||||
|
|
||||||
let summary = document.createElement("p");
|
|
||||||
summary.classList.add("context");
|
|
||||||
summary.textContent = top + text.substr(startWithContext, 240).trim() + tail;
|
|
||||||
|
|
||||||
return summary;
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
_ready(Search.init);
|
|
@ -1,154 +0,0 @@
|
|||||||
/* Highlighting utilities for Sphinx HTML documentation. */
|
|
||||||
"use strict";
|
|
||||||
|
|
||||||
const SPHINX_HIGHLIGHT_ENABLED = true
|
|
||||||
|
|
||||||
/**
|
|
||||||
* highlight a given string on a node by wrapping it in
|
|
||||||
* span elements with the given class name.
|
|
||||||
*/
|
|
||||||
const _highlight = (node, addItems, text, className) => {
|
|
||||||
if (node.nodeType === Node.TEXT_NODE) {
|
|
||||||
const val = node.nodeValue;
|
|
||||||
const parent = node.parentNode;
|
|
||||||
const pos = val.toLowerCase().indexOf(text);
|
|
||||||
if (
|
|
||||||
pos >= 0 &&
|
|
||||||
!parent.classList.contains(className) &&
|
|
||||||
!parent.classList.contains("nohighlight")
|
|
||||||
) {
|
|
||||||
let span;
|
|
||||||
|
|
||||||
const closestNode = parent.closest("body, svg, foreignObject");
|
|
||||||
const isInSVG = closestNode && closestNode.matches("svg");
|
|
||||||
if (isInSVG) {
|
|
||||||
span = document.createElementNS("http://www.w3.org/2000/svg", "tspan");
|
|
||||||
} else {
|
|
||||||
span = document.createElement("span");
|
|
||||||
span.classList.add(className);
|
|
||||||
}
|
|
||||||
|
|
||||||
span.appendChild(document.createTextNode(val.substr(pos, text.length)));
|
|
||||||
const rest = document.createTextNode(val.substr(pos + text.length));
|
|
||||||
parent.insertBefore(
|
|
||||||
span,
|
|
||||||
parent.insertBefore(
|
|
||||||
rest,
|
|
||||||
node.nextSibling
|
|
||||||
)
|
|
||||||
);
|
|
||||||
node.nodeValue = val.substr(0, pos);
|
|
||||||
/* There may be more occurrences of search term in this node. So call this
|
|
||||||
* function recursively on the remaining fragment.
|
|
||||||
*/
|
|
||||||
_highlight(rest, addItems, text, className);
|
|
||||||
|
|
||||||
if (isInSVG) {
|
|
||||||
const rect = document.createElementNS(
|
|
||||||
"http://www.w3.org/2000/svg",
|
|
||||||
"rect"
|
|
||||||
);
|
|
||||||
const bbox = parent.getBBox();
|
|
||||||
rect.x.baseVal.value = bbox.x;
|
|
||||||
rect.y.baseVal.value = bbox.y;
|
|
||||||
rect.width.baseVal.value = bbox.width;
|
|
||||||
rect.height.baseVal.value = bbox.height;
|
|
||||||
rect.setAttribute("class", className);
|
|
||||||
addItems.push({ parent: parent, target: rect });
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else if (node.matches && !node.matches("button, select, textarea")) {
|
|
||||||
node.childNodes.forEach((el) => _highlight(el, addItems, text, className));
|
|
||||||
}
|
|
||||||
};
|
|
||||||
const _highlightText = (thisNode, text, className) => {
|
|
||||||
let addItems = [];
|
|
||||||
_highlight(thisNode, addItems, text, className);
|
|
||||||
addItems.forEach((obj) =>
|
|
||||||
obj.parent.insertAdjacentElement("beforebegin", obj.target)
|
|
||||||
);
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Small JavaScript module for the documentation.
|
|
||||||
*/
|
|
||||||
const SphinxHighlight = {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* highlight the search words provided in localstorage in the text
|
|
||||||
*/
|
|
||||||
highlightSearchWords: () => {
|
|
||||||
if (!SPHINX_HIGHLIGHT_ENABLED) return; // bail if no highlight
|
|
||||||
|
|
||||||
// get and clear terms from localstorage
|
|
||||||
const url = new URL(window.location);
|
|
||||||
const highlight =
|
|
||||||
localStorage.getItem("sphinx_highlight_terms")
|
|
||||||
|| url.searchParams.get("highlight")
|
|
||||||
|| "";
|
|
||||||
localStorage.removeItem("sphinx_highlight_terms")
|
|
||||||
url.searchParams.delete("highlight");
|
|
||||||
window.history.replaceState({}, "", url);
|
|
||||||
|
|
||||||
// get individual terms from highlight string
|
|
||||||
const terms = highlight.toLowerCase().split(/\s+/).filter(x => x);
|
|
||||||
if (terms.length === 0) return; // nothing to do
|
|
||||||
|
|
||||||
// There should never be more than one element matching "div.body"
|
|
||||||
const divBody = document.querySelectorAll("div.body");
|
|
||||||
const body = divBody.length ? divBody[0] : document.querySelector("body");
|
|
||||||
window.setTimeout(() => {
|
|
||||||
terms.forEach((term) => _highlightText(body, term, "highlighted"));
|
|
||||||
}, 10);
|
|
||||||
|
|
||||||
const searchBox = document.getElementById("searchbox");
|
|
||||||
if (searchBox === null) return;
|
|
||||||
searchBox.appendChild(
|
|
||||||
document
|
|
||||||
.createRange()
|
|
||||||
.createContextualFragment(
|
|
||||||
'<p class="highlight-link">' +
|
|
||||||
'<a href="javascript:SphinxHighlight.hideSearchWords()">' +
|
|
||||||
_("Hide Search Matches") +
|
|
||||||
"</a></p>"
|
|
||||||
)
|
|
||||||
);
|
|
||||||
},
|
|
||||||
|
|
||||||
/**
|
|
||||||
* helper function to hide the search marks again
|
|
||||||
*/
|
|
||||||
hideSearchWords: () => {
|
|
||||||
document
|
|
||||||
.querySelectorAll("#searchbox .highlight-link")
|
|
||||||
.forEach((el) => el.remove());
|
|
||||||
document
|
|
||||||
.querySelectorAll("span.highlighted")
|
|
||||||
.forEach((el) => el.classList.remove("highlighted"));
|
|
||||||
localStorage.removeItem("sphinx_highlight_terms")
|
|
||||||
},
|
|
||||||
|
|
||||||
initEscapeListener: () => {
|
|
||||||
// only install a listener if it is really needed
|
|
||||||
if (!DOCUMENTATION_OPTIONS.ENABLE_SEARCH_SHORTCUTS) return;
|
|
||||||
|
|
||||||
document.addEventListener("keydown", (event) => {
|
|
||||||
// bail for input elements
|
|
||||||
if (BLACKLISTED_KEY_CONTROL_ELEMENTS.has(document.activeElement.tagName)) return;
|
|
||||||
// bail with special keys
|
|
||||||
if (event.shiftKey || event.altKey || event.ctrlKey || event.metaKey) return;
|
|
||||||
if (DOCUMENTATION_OPTIONS.ENABLE_SEARCH_SHORTCUTS && (event.key === "Escape")) {
|
|
||||||
SphinxHighlight.hideSearchWords();
|
|
||||||
event.preventDefault();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
_ready(() => {
|
|
||||||
/* Do not call highlightSearchWords() when we are on the search page.
|
|
||||||
* It will highlight words from the *previous* search query.
|
|
||||||
*/
|
|
||||||
if (typeof Search === "undefined") SphinxHighlight.highlightSearchWords();
|
|
||||||
SphinxHighlight.initEscapeListener();
|
|
||||||
});
|
|
@ -1,676 +0,0 @@
|
|||||||
<!-- _templates/layout.html -->
|
|
||||||
|
|
||||||
|
|
||||||
<!DOCTYPE html>
|
|
||||||
<html class="writer-html5" lang="en" data-content_root="./">
|
|
||||||
<head>
|
|
||||||
<meta charset="utf-8" />
|
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
|
|
||||||
<title>Index — EXRAIL Language documentation</title>
|
|
||||||
<link rel="stylesheet" type="text/css" href="_static/pygments.css?v=b86133f3" />
|
|
||||||
<link rel="stylesheet" type="text/css" href="_static/css/theme.css?v=e59714d7" />
|
|
||||||
<link rel="stylesheet" type="text/css" href="_static/css/dccex_theme.css?v=2ceefcef" />
|
|
||||||
<link rel="stylesheet" type="text/css" href="_static/css/sphinx_design_overrides.css?v=de8b2a37" />
|
|
||||||
<link rel="stylesheet" type="text/css" href="_static/dark_mode_css/general.css?v=c0a7eb24" />
|
|
||||||
<link rel="stylesheet" type="text/css" href="_static/dark_mode_css/dark.css?v=70edf1c7" />
|
|
||||||
|
|
||||||
|
|
||||||
<link rel="shortcut icon" href="_static/favicon.ico"/>
|
|
||||||
<link rel="canonical" href="https://dcc-ex.com/CommandStation-EX/devel/genindex.html" />
|
|
||||||
<script src="_static/jquery.js?v=5d32c60e"></script>
|
|
||||||
<script src="_static/_sphinx_javascript_frameworks_compat.js?v=2cd50e6c"></script>
|
|
||||||
<script src="_static/documentation_options.js?v=5929fcd5"></script>
|
|
||||||
<script src="_static/doctools.js?v=9bcbadda"></script>
|
|
||||||
<script src="_static/sphinx_highlight.js?v=dc90522c"></script>
|
|
||||||
<script src="_static/dark_mode_js/default_light.js?v=c2e647ce"></script>
|
|
||||||
<script src="_static/dark_mode_js/theme_switcher.js?v=358d3910"></script>
|
|
||||||
<script src="_static/js/theme.js"></script>
|
|
||||||
<link rel="index" title="Index" href="#" />
|
|
||||||
<link rel="search" title="Search" href="search.html" />
|
|
||||||
</head>
|
|
||||||
|
|
||||||
<body class="wy-body-for-nav">
|
|
||||||
<div class="wy-grid-for-nav">
|
|
||||||
<nav data-toggle="wy-nav-shift" class="wy-nav-side">
|
|
||||||
<div class="wy-side-scroll">
|
|
||||||
<div class="wy-side-nav-search" style="background: white" >
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
<a href="index.html">
|
|
||||||
|
|
||||||
<img src="_static/product-logo-ex-rail.png" class="logo" alt="Logo"/>
|
|
||||||
</a>
|
|
||||||
<div role="search">
|
|
||||||
<form id="rtd-search-form" class="wy-form" action="search.html" method="get">
|
|
||||||
<input type="text" name="q" placeholder="Search docs" aria-label="Search docs" />
|
|
||||||
<input type="hidden" name="check_keywords" value="yes" />
|
|
||||||
<input type="hidden" name="area" value="default" />
|
|
||||||
</form>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="wy-menu wy-menu-vertical" data-spy="affix" role="navigation" aria-label="Navigation menu">
|
|
||||||
<!-- Local TOC -->
|
|
||||||
<div class="local-toc"></div>
|
|
||||||
</div>
|
|
||||||
<div class="sidebar-versions">
|
|
||||||
<div class="version-wrapper">
|
|
||||||
<label for="version-switch">Documentation Version:</label>
|
|
||||||
<select id="version-switch" onchange="window.location.href=this.value">
|
|
||||||
<option value="/CommandStation-EX/">
|
|
||||||
Production
|
|
||||||
</option>
|
|
||||||
<option value="/CommandStation-EX/devel/html/">
|
|
||||||
Development
|
|
||||||
</option>
|
|
||||||
</select>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
</div>
|
|
||||||
</nav>
|
|
||||||
|
|
||||||
<section data-toggle="wy-nav-shift" class="wy-nav-content-wrap"><nav class="wy-nav-top" aria-label="Mobile navigation menu" style="background: white" >
|
|
||||||
<i data-toggle="wy-nav-top" class="fa fa-bars"></i>
|
|
||||||
<a href="index.html">EXRAIL Language</a>
|
|
||||||
</nav>
|
|
||||||
|
|
||||||
<div class="wy-nav-content">
|
|
||||||
<div class="rst-content">
|
|
||||||
<div role="navigation" aria-label="Page navigation">
|
|
||||||
<ul class="wy-breadcrumbs">
|
|
||||||
<li><a href="index.html" class="icon icon-home" aria-label="Home"></a></li>
|
|
||||||
<li class="breadcrumb-item active">Index</li>
|
|
||||||
<li class="wy-breadcrumbs-aside">
|
|
||||||
<a href="https://github.com/DCC-EX/CommandStation-EX/blob/sphinx/docs/genindex" class="fa fa-github"> Edit on GitHub</a>
|
|
||||||
</li>
|
|
||||||
</ul>
|
|
||||||
<hr/>
|
|
||||||
</div>
|
|
||||||
<div role="main" class="document" itemscope="itemscope" itemtype="http://schema.org/Article">
|
|
||||||
<div itemprop="articleBody">
|
|
||||||
|
|
||||||
|
|
||||||
<h1 id="index">Index</h1>
|
|
||||||
|
|
||||||
<div class="genindex-jumpbox">
|
|
||||||
<a href="#A"><strong>A</strong></a>
|
|
||||||
| <a href="#B"><strong>B</strong></a>
|
|
||||||
| <a href="#C"><strong>C</strong></a>
|
|
||||||
| <a href="#D"><strong>D</strong></a>
|
|
||||||
| <a href="#E"><strong>E</strong></a>
|
|
||||||
| <a href="#F"><strong>F</strong></a>
|
|
||||||
| <a href="#G"><strong>G</strong></a>
|
|
||||||
| <a href="#H"><strong>H</strong></a>
|
|
||||||
| <a href="#I"><strong>I</strong></a>
|
|
||||||
| <a href="#J"><strong>J</strong></a>
|
|
||||||
| <a href="#K"><strong>K</strong></a>
|
|
||||||
| <a href="#L"><strong>L</strong></a>
|
|
||||||
| <a href="#M"><strong>M</strong></a>
|
|
||||||
| <a href="#N"><strong>N</strong></a>
|
|
||||||
| <a href="#O"><strong>O</strong></a>
|
|
||||||
| <a href="#P"><strong>P</strong></a>
|
|
||||||
| <a href="#R"><strong>R</strong></a>
|
|
||||||
| <a href="#S"><strong>S</strong></a>
|
|
||||||
| <a href="#T"><strong>T</strong></a>
|
|
||||||
| <a href="#U"><strong>U</strong></a>
|
|
||||||
| <a href="#V"><strong>V</strong></a>
|
|
||||||
| <a href="#W"><strong>W</strong></a>
|
|
||||||
| <a href="#X"><strong>X</strong></a>
|
|
||||||
|
|
||||||
</div>
|
|
||||||
<h2 id="A">A</h2>
|
|
||||||
<table style="width: 100%" class="indextable genindextable"><tr>
|
|
||||||
<td style="width: 33%; vertical-align: top;"><ul>
|
|
||||||
<li><a href="index.html#c.ACOF">ACOF (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.ACON">ACON (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.ACTIVATE">ACTIVATE (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.ACTIVATEL">ACTIVATEL (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.AFTER">AFTER (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.AFTEROVERLOAD">AFTEROVERLOAD (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.ALIAS">ALIAS (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.AMBER">AMBER (C macro)</a>
|
|
||||||
</li>
|
|
||||||
</ul></td>
|
|
||||||
<td style="width: 33%; vertical-align: top;"><ul>
|
|
||||||
<li><a href="index.html#c.ANOUT">ANOUT (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.ASPECT">ASPECT (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.AT">AT (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.ATGTE">ATGTE (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.ATLT">ATLT (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.ATTIMEOUT">ATTIMEOUT (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.AUTOMATION">AUTOMATION (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.AUTOSTART">AUTOSTART (C macro)</a>
|
|
||||||
</li>
|
|
||||||
</ul></td>
|
|
||||||
</tr></table>
|
|
||||||
|
|
||||||
<h2 id="B">B</h2>
|
|
||||||
<table style="width: 100%" class="indextable genindextable"><tr>
|
|
||||||
<td style="width: 33%; vertical-align: top;"><ul>
|
|
||||||
<li><a href="index.html#c.BLINK">BLINK (C macro)</a>
|
|
||||||
</li>
|
|
||||||
</ul></td>
|
|
||||||
<td style="width: 33%; vertical-align: top;"><ul>
|
|
||||||
<li><a href="index.html#c.BROADCAST">BROADCAST (C macro)</a>
|
|
||||||
</li>
|
|
||||||
</ul></td>
|
|
||||||
</tr></table>
|
|
||||||
|
|
||||||
<h2 id="C">C</h2>
|
|
||||||
<table style="width: 100%" class="indextable genindextable"><tr>
|
|
||||||
<td style="width: 33%; vertical-align: top;"><ul>
|
|
||||||
<li><a href="index.html#c.CALL">CALL (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.CLEAR_ALL_STASH">CLEAR_ALL_STASH (C macro)</a>
|
|
||||||
</li>
|
|
||||||
</ul></td>
|
|
||||||
<td style="width: 33%; vertical-align: top;"><ul>
|
|
||||||
<li><a href="index.html#c.CLEAR_STASH">CLEAR_STASH (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.CLOSE">CLOSE (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.CONFIGURE_SERVO">CONFIGURE_SERVO (C macro)</a>
|
|
||||||
</li>
|
|
||||||
</ul></td>
|
|
||||||
</tr></table>
|
|
||||||
|
|
||||||
<h2 id="D">D</h2>
|
|
||||||
<table style="width: 100%" class="indextable genindextable"><tr>
|
|
||||||
<td style="width: 33%; vertical-align: top;"><ul>
|
|
||||||
<li><a href="index.html#c.DCC_SIGNAL">DCC_SIGNAL (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.DCC_TURNTABLE">DCC_TURNTABLE (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.DCCX_SIGNAL">DCCX_SIGNAL (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.DEACTIVATE">DEACTIVATE (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.DEACTIVATEL">DEACTIVATEL (C macro)</a>
|
|
||||||
</li>
|
|
||||||
</ul></td>
|
|
||||||
<td style="width: 33%; vertical-align: top;"><ul>
|
|
||||||
<li><a href="index.html#c.DELAY">DELAY (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.DELAYMINS">DELAYMINS (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.DELAYRANDOM">DELAYRANDOM (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.DONE">DONE (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.DRIVE">DRIVE (C macro)</a>
|
|
||||||
</li>
|
|
||||||
</ul></td>
|
|
||||||
</tr></table>
|
|
||||||
|
|
||||||
<h2 id="E">E</h2>
|
|
||||||
<table style="width: 100%" class="indextable genindextable"><tr>
|
|
||||||
<td style="width: 33%; vertical-align: top;"><ul>
|
|
||||||
<li><a href="index.html#c.ELSE">ELSE (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.ENDEXRAIL">ENDEXRAIL (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.ENDIF">ENDIF (C macro)</a>
|
|
||||||
</li>
|
|
||||||
</ul></td>
|
|
||||||
<td style="width: 33%; vertical-align: top;"><ul>
|
|
||||||
<li><a href="index.html#c.ENDTASK">ENDTASK (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.ESTOP">ESTOP (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.EXRAIL">EXRAIL (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.EXTT_TURNTABLE">EXTT_TURNTABLE (C macro)</a>
|
|
||||||
</li>
|
|
||||||
</ul></td>
|
|
||||||
</tr></table>
|
|
||||||
|
|
||||||
<h2 id="F">F</h2>
|
|
||||||
<table style="width: 100%" class="indextable genindextable"><tr>
|
|
||||||
<td style="width: 33%; vertical-align: top;"><ul>
|
|
||||||
<li><a href="index.html#c.FADE">FADE (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.FOFF">FOFF (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.FOLLOW">FOLLOW (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.FON">FON (C macro)</a>
|
|
||||||
</li>
|
|
||||||
</ul></td>
|
|
||||||
<td style="width: 33%; vertical-align: top;"><ul>
|
|
||||||
<li><a href="index.html#c.FORGET">FORGET (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.FREE">FREE (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.FTOGGLE">FTOGGLE (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.FWD">FWD (C macro)</a>
|
|
||||||
</li>
|
|
||||||
</ul></td>
|
|
||||||
</tr></table>
|
|
||||||
|
|
||||||
<h2 id="G">G</h2>
|
|
||||||
<table style="width: 100%" class="indextable genindextable"><tr>
|
|
||||||
<td style="width: 33%; vertical-align: top;"><ul>
|
|
||||||
<li><a href="index.html#c.GREEN">GREEN (C macro)</a>
|
|
||||||
</li>
|
|
||||||
</ul></td>
|
|
||||||
</tr></table>
|
|
||||||
|
|
||||||
<h2 id="H">H</h2>
|
|
||||||
<table style="width: 100%" class="indextable genindextable"><tr>
|
|
||||||
<td style="width: 33%; vertical-align: top;"><ul>
|
|
||||||
<li><a href="index.html#c.HAL">HAL (C macro)</a>
|
|
||||||
</li>
|
|
||||||
</ul></td>
|
|
||||||
<td style="width: 33%; vertical-align: top;"><ul>
|
|
||||||
<li><a href="index.html#c.HAL_IGNORE_DEFAULTS">HAL_IGNORE_DEFAULTS (C macro)</a>
|
|
||||||
</li>
|
|
||||||
</ul></td>
|
|
||||||
</tr></table>
|
|
||||||
|
|
||||||
<h2 id="I">I</h2>
|
|
||||||
<table style="width: 100%" class="indextable genindextable"><tr>
|
|
||||||
<td style="width: 33%; vertical-align: top;"><ul>
|
|
||||||
<li><a href="index.html#c.IF">IF (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.IFAMBER">IFAMBER (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.IFCLOSED">IFCLOSED (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.IFGREEN">IFGREEN (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.IFGTE">IFGTE (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.IFLOCO">IFLOCO (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.IFLT">IFLT (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.IFNOT">IFNOT (C macro)</a>
|
|
||||||
</li>
|
|
||||||
</ul></td>
|
|
||||||
<td style="width: 33%; vertical-align: top;"><ul>
|
|
||||||
<li><a href="index.html#c.IFRANDOM">IFRANDOM (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.IFRE">IFRE (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.IFRED">IFRED (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.IFRESERVE">IFRESERVE (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.IFTHROWN">IFTHROWN (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.IFTIMEOUT">IFTIMEOUT (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.IFTTPOSITION">IFTTPOSITION (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.INVERT_DIRECTION">INVERT_DIRECTION (C macro)</a>
|
|
||||||
</li>
|
|
||||||
</ul></td>
|
|
||||||
</tr></table>
|
|
||||||
|
|
||||||
<h2 id="J">J</h2>
|
|
||||||
<table style="width: 100%" class="indextable genindextable"><tr>
|
|
||||||
<td style="width: 33%; vertical-align: top;"><ul>
|
|
||||||
<li><a href="index.html#c.JMRI_SENSOR">JMRI_SENSOR (C macro)</a>
|
|
||||||
</li>
|
|
||||||
</ul></td>
|
|
||||||
<td style="width: 33%; vertical-align: top;"><ul>
|
|
||||||
<li><a href="index.html#c.JOIN">JOIN (C macro)</a>
|
|
||||||
</li>
|
|
||||||
</ul></td>
|
|
||||||
</tr></table>
|
|
||||||
|
|
||||||
<h2 id="K">K</h2>
|
|
||||||
<table style="width: 100%" class="indextable genindextable"><tr>
|
|
||||||
<td style="width: 33%; vertical-align: top;"><ul>
|
|
||||||
<li><a href="index.html#c.KILLALL">KILLALL (C macro)</a>
|
|
||||||
</li>
|
|
||||||
</ul></td>
|
|
||||||
</tr></table>
|
|
||||||
|
|
||||||
<h2 id="L">L</h2>
|
|
||||||
<table style="width: 100%" class="indextable genindextable"><tr>
|
|
||||||
<td style="width: 33%; vertical-align: top;"><ul>
|
|
||||||
<li><a href="index.html#c.LATCH">LATCH (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.LCC">LCC (C macro)</a>
|
|
||||||
</li>
|
|
||||||
</ul></td>
|
|
||||||
<td style="width: 33%; vertical-align: top;"><ul>
|
|
||||||
<li><a href="index.html#c.LCCX">LCCX (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.LCD">LCD (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.LCN">LCN (C macro)</a>
|
|
||||||
</li>
|
|
||||||
</ul></td>
|
|
||||||
</tr></table>
|
|
||||||
|
|
||||||
<h2 id="M">M</h2>
|
|
||||||
<table style="width: 100%" class="indextable genindextable"><tr>
|
|
||||||
<td style="width: 33%; vertical-align: top;"><ul>
|
|
||||||
<li><a href="index.html#c.MESSAGE">MESSAGE (C macro)</a>
|
|
||||||
</li>
|
|
||||||
</ul></td>
|
|
||||||
<td style="width: 33%; vertical-align: top;"><ul>
|
|
||||||
<li><a href="index.html#c.MOVETT">MOVETT (C macro)</a>
|
|
||||||
</li>
|
|
||||||
</ul></td>
|
|
||||||
</tr></table>
|
|
||||||
|
|
||||||
<h2 id="N">N</h2>
|
|
||||||
<table style="width: 100%" class="indextable genindextable"><tr>
|
|
||||||
<td style="width: 33%; vertical-align: top;"><ul>
|
|
||||||
<li><a href="index.html#c.NEOPIXEL">NEOPIXEL (C macro)</a>
|
|
||||||
</li>
|
|
||||||
</ul></td>
|
|
||||||
<td style="width: 33%; vertical-align: top;"><ul>
|
|
||||||
<li><a href="index.html#c.NEOPIXEL_SIGNAL">NEOPIXEL_SIGNAL (C macro)</a>
|
|
||||||
</li>
|
|
||||||
</ul></td>
|
|
||||||
</tr></table>
|
|
||||||
|
|
||||||
<h2 id="O">O</h2>
|
|
||||||
<table style="width: 100%" class="indextable genindextable"><tr>
|
|
||||||
<td style="width: 33%; vertical-align: top;"><ul>
|
|
||||||
<li><a href="index.html#c.ONACOF">ONACOF (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.ONACON">ONACON (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.ONACTIVATE">ONACTIVATE (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.ONACTIVATEL">ONACTIVATEL (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.ONAMBER">ONAMBER (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.ONBUTTON">ONBUTTON (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.ONCHANGE">ONCHANGE (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.ONCLOCKMINS">ONCLOCKMINS (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.ONCLOCKTIME">ONCLOCKTIME (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.ONCLOSE">ONCLOSE (C macro)</a>
|
|
||||||
</li>
|
|
||||||
</ul></td>
|
|
||||||
<td style="width: 33%; vertical-align: top;"><ul>
|
|
||||||
<li><a href="index.html#c.ONDEACTIVATE">ONDEACTIVATE (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.ONDEACTIVATEL">ONDEACTIVATEL (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.ONGREEN">ONGREEN (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.ONLCC">ONLCC (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.ONOVERLOAD">ONOVERLOAD (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.ONRED">ONRED (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.ONROTATE">ONROTATE (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.ONSENSOR">ONSENSOR (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.ONTHROW">ONTHROW (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.ONTIME">ONTIME (C macro)</a>
|
|
||||||
</li>
|
|
||||||
</ul></td>
|
|
||||||
</tr></table>
|
|
||||||
|
|
||||||
<h2 id="P">P</h2>
|
|
||||||
<table style="width: 100%" class="indextable genindextable"><tr>
|
|
||||||
<td style="width: 33%; vertical-align: top;"><ul>
|
|
||||||
<li><a href="index.html#c.PARSE">PARSE (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.PAUSE">PAUSE (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.PICKUP_STASH">PICKUP_STASH (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.PIN_TURNOUT">PIN_TURNOUT (C macro)</a>
|
|
||||||
</li>
|
|
||||||
</ul></td>
|
|
||||||
<td style="width: 33%; vertical-align: top;"><ul>
|
|
||||||
<li><a href="index.html#c.POM">POM (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.POWEROFF">POWEROFF (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.POWERON">POWERON (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.PRINT">PRINT (C macro)</a>
|
|
||||||
</li>
|
|
||||||
</ul></td>
|
|
||||||
</tr></table>
|
|
||||||
|
|
||||||
<h2 id="R">R</h2>
|
|
||||||
<table style="width: 100%" class="indextable genindextable"><tr>
|
|
||||||
<td style="width: 33%; vertical-align: top;"><ul>
|
|
||||||
<li><a href="index.html#c.READ_LOCO">READ_LOCO (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.RED">RED (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.RESERVE">RESERVE (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.RESET">RESET (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.RESUME">RESUME (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.RETURN">RETURN (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.REV">REV (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.ROSTER">ROSTER (C macro)</a>
|
|
||||||
</li>
|
|
||||||
</ul></td>
|
|
||||||
<td style="width: 33%; vertical-align: top;"><ul>
|
|
||||||
<li><a href="index.html#c.ROTATE">ROTATE (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.ROTATE_DCC">ROTATE_DCC (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.ROUTE">ROUTE (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.ROUTE_ACTIVE">ROUTE_ACTIVE (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.ROUTE_CAPTION">ROUTE_CAPTION (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.ROUTE_DISABLED">ROUTE_DISABLED (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.ROUTE_HIDDEN">ROUTE_HIDDEN (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.ROUTE_INACTIVE">ROUTE_INACTIVE (C macro)</a>
|
|
||||||
</li>
|
|
||||||
</ul></td>
|
|
||||||
</tr></table>
|
|
||||||
|
|
||||||
<h2 id="S">S</h2>
|
|
||||||
<table style="width: 100%" class="indextable genindextable"><tr>
|
|
||||||
<td style="width: 33%; vertical-align: top;"><ul>
|
|
||||||
<li><a href="index.html#c.SCREEN">SCREEN (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.SENDLOCO">SENDLOCO (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.SEQUENCE">SEQUENCE (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.SERIAL">SERIAL (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.SERIAL1">SERIAL1 (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.SERIAL2">SERIAL2 (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.SERIAL3">SERIAL3 (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.SERIAL4">SERIAL4 (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.SERIAL5">SERIAL5 (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.SERIAL6">SERIAL6 (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.SERVO">SERVO (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.SERVO2">SERVO2 (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.SERVO_SIGNAL">SERVO_SIGNAL (C macro)</a>
|
|
||||||
</li>
|
|
||||||
</ul></td>
|
|
||||||
<td style="width: 33%; vertical-align: top;"><ul>
|
|
||||||
<li><a href="index.html#c.SERVO_TURNOUT">SERVO_TURNOUT (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.SET">SET (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.SET_POWER">SET_POWER (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.SET_TRACK">SET_TRACK (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.SETFREQ">SETFREQ (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.SETLOCO">SETLOCO (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.SIGNAL">SIGNAL (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.SIGNALH">SIGNALH (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.SPEED">SPEED (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.START">START (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.STASH">STASH (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.STEALTH">STEALTH (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.STEALTH_GLOBAL">STEALTH_GLOBAL (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.STOP">STOP (C macro)</a>
|
|
||||||
</li>
|
|
||||||
</ul></td>
|
|
||||||
</tr></table>
|
|
||||||
|
|
||||||
<h2 id="T">T</h2>
|
|
||||||
<table style="width: 100%" class="indextable genindextable"><tr>
|
|
||||||
<td style="width: 33%; vertical-align: top;"><ul>
|
|
||||||
<li><a href="index.html#c.THROW">THROW (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.TOGGLE_TURNOUT">TOGGLE_TURNOUT (C macro)</a>
|
|
||||||
</li>
|
|
||||||
</ul></td>
|
|
||||||
<td style="width: 33%; vertical-align: top;"><ul>
|
|
||||||
<li><a href="index.html#c.TT_ADDPOSITION">TT_ADDPOSITION (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.TURNOUT">TURNOUT (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.TURNOUTL">TURNOUTL (C macro)</a>
|
|
||||||
</li>
|
|
||||||
</ul></td>
|
|
||||||
</tr></table>
|
|
||||||
|
|
||||||
<h2 id="U">U</h2>
|
|
||||||
<table style="width: 100%" class="indextable genindextable"><tr>
|
|
||||||
<td style="width: 33%; vertical-align: top;"><ul>
|
|
||||||
<li><a href="index.html#c.UNJOIN">UNJOIN (C macro)</a>
|
|
||||||
</li>
|
|
||||||
</ul></td>
|
|
||||||
<td style="width: 33%; vertical-align: top;"><ul>
|
|
||||||
<li><a href="index.html#c.UNLATCH">UNLATCH (C macro)</a>
|
|
||||||
</li>
|
|
||||||
</ul></td>
|
|
||||||
</tr></table>
|
|
||||||
|
|
||||||
<h2 id="V">V</h2>
|
|
||||||
<table style="width: 100%" class="indextable genindextable"><tr>
|
|
||||||
<td style="width: 33%; vertical-align: top;"><ul>
|
|
||||||
<li><a href="index.html#c.VIRTUAL_SIGNAL">VIRTUAL_SIGNAL (C macro)</a>
|
|
||||||
</li>
|
|
||||||
</ul></td>
|
|
||||||
<td style="width: 33%; vertical-align: top;"><ul>
|
|
||||||
<li><a href="index.html#c.VIRTUAL_TURNOUT">VIRTUAL_TURNOUT (C macro)</a>
|
|
||||||
</li>
|
|
||||||
</ul></td>
|
|
||||||
</tr></table>
|
|
||||||
|
|
||||||
<h2 id="W">W</h2>
|
|
||||||
<table style="width: 100%" class="indextable genindextable"><tr>
|
|
||||||
<td style="width: 33%; vertical-align: top;"><ul>
|
|
||||||
<li><a href="index.html#c.WAITFOR">WAITFOR (C macro)</a>
|
|
||||||
</li>
|
|
||||||
</ul></td>
|
|
||||||
<td style="width: 33%; vertical-align: top;"><ul>
|
|
||||||
<li><a href="index.html#c.WAITFORTT">WAITFORTT (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.WITHROTTLE">WITHROTTLE (C macro)</a>
|
|
||||||
</li>
|
|
||||||
</ul></td>
|
|
||||||
</tr></table>
|
|
||||||
|
|
||||||
<h2 id="X">X</h2>
|
|
||||||
<table style="width: 100%" class="indextable genindextable"><tr>
|
|
||||||
<td style="width: 33%; vertical-align: top;"><ul>
|
|
||||||
<li><a href="index.html#c.XFOFF">XFOFF (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.XFON">XFON (C macro)</a>
|
|
||||||
</li>
|
|
||||||
</ul></td>
|
|
||||||
<td style="width: 33%; vertical-align: top;"><ul>
|
|
||||||
<li><a href="index.html#c.XFTOGGLE">XFTOGGLE (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.XFWD">XFWD (C macro)</a>
|
|
||||||
</li>
|
|
||||||
<li><a href="index.html#c.XREV">XREV (C macro)</a>
|
|
||||||
</li>
|
|
||||||
</ul></td>
|
|
||||||
</tr></table>
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<footer>
|
|
||||||
|
|
||||||
<hr/>
|
|
||||||
|
|
||||||
<div role="contentinfo">
|
|
||||||
<p>© Copyright 2025 - Peter Cole.</p>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
Built with <a href="https://www.sphinx-doc.org/">Sphinx</a> using a
|
|
||||||
<a href="https://github.com/readthedocs/sphinx_rtd_theme">theme</a>
|
|
||||||
provided by <a href="https://readthedocs.org">Read the Docs</a>.
|
|
||||||
|
|
||||||
|
|
||||||
</footer>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</section>
|
|
||||||
</div>
|
|
||||||
<script>
|
|
||||||
jQuery(function () {
|
|
||||||
SphinxRtdTheme.Navigation.enable(true);
|
|
||||||
});
|
|
||||||
</script>
|
|
||||||
<!-- Theme Analytics -->
|
|
||||||
<script async src="https://www.googletagmanager.com/gtag/js?id=G-L5X0KNBF0W"></script>
|
|
||||||
<script>
|
|
||||||
window.dataLayer = window.dataLayer || [];
|
|
||||||
function gtag(){dataLayer.push(arguments);}
|
|
||||||
gtag('js', new Date());
|
|
||||||
|
|
||||||
gtag('config', 'G-L5X0KNBF0W', {
|
|
||||||
'anonymize_ip': false,
|
|
||||||
});
|
|
||||||
</script>
|
|
||||||
|
|
||||||
</body>
|
|
||||||
</html>
|
|
@ -1,3 +0,0 @@
|
|||||||
User-agent: *
|
|
||||||
|
|
||||||
Sitemap: https://dcc-ex.com/CommandStation-EX/sitemap.xml
|
|
@ -1,153 +0,0 @@
|
|||||||
<!-- _templates/layout.html -->
|
|
||||||
|
|
||||||
|
|
||||||
<!DOCTYPE html>
|
|
||||||
<html class="writer-html5" lang="en" data-content_root="./">
|
|
||||||
<head>
|
|
||||||
<meta charset="utf-8" />
|
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
|
|
||||||
<title>Search — EXRAIL Language documentation</title>
|
|
||||||
<link rel="stylesheet" type="text/css" href="_static/pygments.css?v=b86133f3" />
|
|
||||||
<link rel="stylesheet" type="text/css" href="_static/css/theme.css?v=e59714d7" />
|
|
||||||
<link rel="stylesheet" type="text/css" href="_static/css/dccex_theme.css?v=2ceefcef" />
|
|
||||||
<link rel="stylesheet" type="text/css" href="_static/css/sphinx_design_overrides.css?v=de8b2a37" />
|
|
||||||
<link rel="stylesheet" type="text/css" href="_static/dark_mode_css/general.css?v=c0a7eb24" />
|
|
||||||
<link rel="stylesheet" type="text/css" href="_static/dark_mode_css/dark.css?v=70edf1c7" />
|
|
||||||
|
|
||||||
|
|
||||||
<link rel="shortcut icon" href="_static/favicon.ico"/>
|
|
||||||
<link rel="canonical" href="https://dcc-ex.com/CommandStation-EX/devel/search.html" />
|
|
||||||
|
|
||||||
<script src="_static/jquery.js?v=5d32c60e"></script>
|
|
||||||
<script src="_static/_sphinx_javascript_frameworks_compat.js?v=2cd50e6c"></script>
|
|
||||||
<script src="_static/documentation_options.js?v=5929fcd5"></script>
|
|
||||||
<script src="_static/doctools.js?v=9bcbadda"></script>
|
|
||||||
<script src="_static/sphinx_highlight.js?v=dc90522c"></script>
|
|
||||||
<script src="_static/dark_mode_js/default_light.js?v=c2e647ce"></script>
|
|
||||||
<script src="_static/dark_mode_js/theme_switcher.js?v=358d3910"></script>
|
|
||||||
<script src="_static/js/theme.js"></script>
|
|
||||||
<script src="_static/searchtools.js"></script>
|
|
||||||
<script src="_static/language_data.js"></script>
|
|
||||||
<link rel="index" title="Index" href="genindex.html" />
|
|
||||||
<link rel="search" title="Search" href="#" />
|
|
||||||
</head>
|
|
||||||
|
|
||||||
<body class="wy-body-for-nav">
|
|
||||||
<div class="wy-grid-for-nav">
|
|
||||||
<nav data-toggle="wy-nav-shift" class="wy-nav-side">
|
|
||||||
<div class="wy-side-scroll">
|
|
||||||
<div class="wy-side-nav-search" style="background: white" >
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
<a href="index.html">
|
|
||||||
|
|
||||||
<img src="_static/product-logo-ex-rail.png" class="logo" alt="Logo"/>
|
|
||||||
</a>
|
|
||||||
<div role="search">
|
|
||||||
<form id="rtd-search-form" class="wy-form" action="#" method="get">
|
|
||||||
<input type="text" name="q" placeholder="Search docs" aria-label="Search docs" />
|
|
||||||
<input type="hidden" name="check_keywords" value="yes" />
|
|
||||||
<input type="hidden" name="area" value="default" />
|
|
||||||
</form>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="wy-menu wy-menu-vertical" data-spy="affix" role="navigation" aria-label="Navigation menu">
|
|
||||||
<!-- Local TOC -->
|
|
||||||
<div class="local-toc"></div>
|
|
||||||
</div>
|
|
||||||
<div class="sidebar-versions">
|
|
||||||
<div class="version-wrapper">
|
|
||||||
<label for="version-switch">Documentation Version:</label>
|
|
||||||
<select id="version-switch" onchange="window.location.href=this.value">
|
|
||||||
<option value="/CommandStation-EX/">
|
|
||||||
Production
|
|
||||||
</option>
|
|
||||||
<option value="/CommandStation-EX/devel/html/">
|
|
||||||
Development
|
|
||||||
</option>
|
|
||||||
</select>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
</div>
|
|
||||||
</nav>
|
|
||||||
|
|
||||||
<section data-toggle="wy-nav-shift" class="wy-nav-content-wrap"><nav class="wy-nav-top" aria-label="Mobile navigation menu" style="background: white" >
|
|
||||||
<i data-toggle="wy-nav-top" class="fa fa-bars"></i>
|
|
||||||
<a href="index.html">EXRAIL Language</a>
|
|
||||||
</nav>
|
|
||||||
|
|
||||||
<div class="wy-nav-content">
|
|
||||||
<div class="rst-content">
|
|
||||||
<div role="navigation" aria-label="Page navigation">
|
|
||||||
<ul class="wy-breadcrumbs">
|
|
||||||
<li><a href="index.html" class="icon icon-home" aria-label="Home"></a></li>
|
|
||||||
<li class="breadcrumb-item active">Search</li>
|
|
||||||
<li class="wy-breadcrumbs-aside">
|
|
||||||
</li>
|
|
||||||
</ul>
|
|
||||||
<hr/>
|
|
||||||
</div>
|
|
||||||
<div role="main" class="document" itemscope="itemscope" itemtype="http://schema.org/Article">
|
|
||||||
<div itemprop="articleBody">
|
|
||||||
|
|
||||||
<noscript>
|
|
||||||
<div id="fallback" class="admonition warning">
|
|
||||||
<p class="last">
|
|
||||||
Please activate JavaScript to enable the search functionality.
|
|
||||||
</p>
|
|
||||||
</div>
|
|
||||||
</noscript>
|
|
||||||
|
|
||||||
|
|
||||||
<div id="search-results">
|
|
||||||
|
|
||||||
</div>
|
|
||||||
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<footer>
|
|
||||||
|
|
||||||
<hr/>
|
|
||||||
|
|
||||||
<div role="contentinfo">
|
|
||||||
<p>© Copyright 2025 - Peter Cole.</p>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
Built with <a href="https://www.sphinx-doc.org/">Sphinx</a> using a
|
|
||||||
<a href="https://github.com/readthedocs/sphinx_rtd_theme">theme</a>
|
|
||||||
provided by <a href="https://readthedocs.org">Read the Docs</a>.
|
|
||||||
|
|
||||||
|
|
||||||
</footer>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</section>
|
|
||||||
</div>
|
|
||||||
<script>
|
|
||||||
jQuery(function () {
|
|
||||||
SphinxRtdTheme.Navigation.enable(true);
|
|
||||||
});
|
|
||||||
</script>
|
|
||||||
<!-- Theme Analytics -->
|
|
||||||
<script async src="https://www.googletagmanager.com/gtag/js?id=G-L5X0KNBF0W"></script>
|
|
||||||
<script>
|
|
||||||
window.dataLayer = window.dataLayer || [];
|
|
||||||
function gtag(){dataLayer.push(arguments);}
|
|
||||||
gtag('js', new Date());
|
|
||||||
|
|
||||||
gtag('config', 'G-L5X0KNBF0W', {
|
|
||||||
'anonymize_ip': false,
|
|
||||||
});
|
|
||||||
</script>
|
|
||||||
<script>
|
|
||||||
jQuery(function() { Search.loadIndex("searchindex.js"); });
|
|
||||||
</script>
|
|
||||||
|
|
||||||
<script id="searchindexloader"></script>
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
</body>
|
|
||||||
</html>
|
|
@ -1,2 +0,0 @@
|
|||||||
<?xml version='1.0' encoding='utf-8'?>
|
|
||||||
<urlset xmlns="http://www.sitemaps.org/schemas/sitemap/0.9"><url><loc>https://dcc-ex.com/CommandStation-EX/devel/en/index.html</loc></url><url><loc>https://dcc-ex.com/CommandStation-EX/devel/en/genindex.html</loc></url><url><loc>https://dcc-ex.com/CommandStation-EX/devel/en/search.html</loc></url></urlset>
|
|
@ -1,4 +1,3 @@
|
|||||||
<!-- _templates/layout.html -->
|
|
||||||
|
|
||||||
|
|
||||||
<!DOCTYPE html>
|
<!DOCTYPE html>
|
||||||
@ -48,25 +47,10 @@
|
|||||||
<input type="hidden" name="area" value="default" />
|
<input type="hidden" name="area" value="default" />
|
||||||
</form>
|
</form>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div><div class="wy-menu wy-menu-vertical" data-spy="affix" role="navigation" aria-label="Navigation menu">
|
||||||
<div class="wy-menu wy-menu-vertical" data-spy="affix" role="navigation" aria-label="Navigation menu">
|
|
||||||
<!-- Local TOC -->
|
<!-- Local TOC -->
|
||||||
<div class="local-toc"></div>
|
<div class="local-toc"></div>
|
||||||
</div>
|
</div>
|
||||||
<div class="sidebar-versions">
|
|
||||||
<div class="version-wrapper">
|
|
||||||
<label for="version-switch">Documentation Version:</label>
|
|
||||||
<select id="version-switch" onchange="window.location.href=this.value">
|
|
||||||
<option value="/CommandStation-EX/">
|
|
||||||
Production
|
|
||||||
</option>
|
|
||||||
<option value="/CommandStation-EX/devel/html/">
|
|
||||||
Development
|
|
||||||
</option>
|
|
||||||
</select>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
</nav>
|
</nav>
|
||||||
|
|
||||||
|
18
index.html
@ -1,4 +1,3 @@
|
|||||||
<!-- _templates/layout.html -->
|
|
||||||
|
|
||||||
|
|
||||||
<!DOCTYPE html>
|
<!DOCTYPE html>
|
||||||
@ -49,8 +48,7 @@
|
|||||||
<input type="hidden" name="area" value="default" />
|
<input type="hidden" name="area" value="default" />
|
||||||
</form>
|
</form>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div><div class="wy-menu wy-menu-vertical" data-spy="affix" role="navigation" aria-label="Navigation menu">
|
||||||
<div class="wy-menu wy-menu-vertical" data-spy="affix" role="navigation" aria-label="Navigation menu">
|
|
||||||
<!-- Local TOC -->
|
<!-- Local TOC -->
|
||||||
<div class="local-toc"><ul>
|
<div class="local-toc"><ul>
|
||||||
<li><a class="reference internal" href="#">EXRAIL Language documentation</a><ul>
|
<li><a class="reference internal" href="#">EXRAIL Language documentation</a><ul>
|
||||||
@ -61,20 +59,6 @@
|
|||||||
</ul>
|
</ul>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="sidebar-versions">
|
|
||||||
<div class="version-wrapper">
|
|
||||||
<label for="version-switch">Documentation Version:</label>
|
|
||||||
<select id="version-switch" onchange="window.location.href=this.value">
|
|
||||||
<option value="/CommandStation-EX/">
|
|
||||||
Production
|
|
||||||
</option>
|
|
||||||
<option value="/CommandStation-EX/devel/html/">
|
|
||||||
Development
|
|
||||||
</option>
|
|
||||||
</select>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
</nav>
|
</nav>
|
||||||
|
|
||||||
|
18
search.html
@ -1,4 +1,3 @@
|
|||||||
<!-- _templates/layout.html -->
|
|
||||||
|
|
||||||
|
|
||||||
<!DOCTYPE html>
|
<!DOCTYPE html>
|
||||||
@ -51,25 +50,10 @@
|
|||||||
<input type="hidden" name="area" value="default" />
|
<input type="hidden" name="area" value="default" />
|
||||||
</form>
|
</form>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div><div class="wy-menu wy-menu-vertical" data-spy="affix" role="navigation" aria-label="Navigation menu">
|
||||||
<div class="wy-menu wy-menu-vertical" data-spy="affix" role="navigation" aria-label="Navigation menu">
|
|
||||||
<!-- Local TOC -->
|
<!-- Local TOC -->
|
||||||
<div class="local-toc"></div>
|
<div class="local-toc"></div>
|
||||||
</div>
|
</div>
|
||||||
<div class="sidebar-versions">
|
|
||||||
<div class="version-wrapper">
|
|
||||||
<label for="version-switch">Documentation Version:</label>
|
|
||||||
<select id="version-switch" onchange="window.location.href=this.value">
|
|
||||||
<option value="/CommandStation-EX/">
|
|
||||||
Production
|
|
||||||
</option>
|
|
||||||
<option value="/CommandStation-EX/devel/html/">
|
|
||||||
Development
|
|
||||||
</option>
|
|
||||||
</select>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
</nav>
|
</nav>
|
||||||
|
|
||||||
|