diff --git a/pr-preview/pr-92/.buildinfo b/pr-preview/pr-92/.buildinfo new file mode 100644 index 0000000..378a1c1 --- /dev/null +++ b/pr-preview/pr-92/.buildinfo @@ -0,0 +1,4 @@ +# 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: 4fc1d0579f0ff17a6bac8ea7c7801d4c +tags: 645f666f9bcd5a90fca523b33c5a78b7 diff --git a/pr-preview/pr-92/_images/44dcd3c862c0b82e7fd3ad531de26100f34fc95f130a71e6074703ba599dea50.png b/pr-preview/pr-92/_images/44dcd3c862c0b82e7fd3ad531de26100f34fc95f130a71e6074703ba599dea50.png new file mode 100644 index 0000000..51ab019 Binary files /dev/null and b/pr-preview/pr-92/_images/44dcd3c862c0b82e7fd3ad531de26100f34fc95f130a71e6074703ba599dea50.png differ diff --git a/pr-preview/pr-92/_images/b06be5d1f54fca31917e33082dc3377582be8afd99b784493ce56692c7d7e255.png b/pr-preview/pr-92/_images/b06be5d1f54fca31917e33082dc3377582be8afd99b784493ce56692c7d7e255.png new file mode 100644 index 0000000..c4abb46 Binary files /dev/null and b/pr-preview/pr-92/_images/b06be5d1f54fca31917e33082dc3377582be8afd99b784493ce56692c7d7e255.png differ diff --git a/pr-preview/pr-92/_images/encoding_states.png b/pr-preview/pr-92/_images/encoding_states.png new file mode 100644 index 0000000..e9b1196 Binary files /dev/null and b/pr-preview/pr-92/_images/encoding_states.png differ diff --git a/pr-preview/pr-92/_images/super_dense_coding.png b/pr-preview/pr-92/_images/super_dense_coding.png new file mode 100644 index 0000000..a585886 Binary files /dev/null and b/pr-preview/pr-92/_images/super_dense_coding.png differ diff --git a/pr-preview/pr-92/_modules/index.html b/pr-preview/pr-92/_modules/index.html new file mode 100644 index 0000000..fb1f717 --- /dev/null +++ b/pr-preview/pr-92/_modules/index.html @@ -0,0 +1,297 @@ + + + + + + + + Overview: module code - Qiskit-QuantumInspire 0.1.0 documentation + + + + + + + + + + + + + + + + + + Contents + + + + + + Menu + + + + + + + + + Expand + + + + + + Light mode + + + + + + + + + + + + + + Dark mode + + + + + + + Auto light/dark, in light mode + + + + + + + + + + + + + + + Auto light/dark, in dark mode + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +Skip to content + + + +
+
+
+ +
+ +
+
+ +
+ +
+
+ +
+
+
+ + + + + Back to top + +
+
+ +
+ +
+ +
+
+ + +
+
+ + Made with Sphinx and @pradyunsg's + + Furo + +
+
+ +
+
+ +
+
+ +
+
+ + + + + \ No newline at end of file diff --git a/pr-preview/pr-92/_modules/qiskit_quantuminspire/api/authentication.html b/pr-preview/pr-92/_modules/qiskit_quantuminspire/api/authentication.html new file mode 100644 index 0000000..5577529 --- /dev/null +++ b/pr-preview/pr-92/_modules/qiskit_quantuminspire/api/authentication.html @@ -0,0 +1,368 @@ + + + + + + + + qiskit_quantuminspire.api.authentication - Qiskit-QuantumInspire 0.1.0 documentation + + + + + + + + + + + + + + + + + + Contents + + + + + + Menu + + + + + + + + + Expand + + + + + + Light mode + + + + + + + + + + + + + + Dark mode + + + + + + + Auto light/dark, in light mode + + + + + + + + + + + + + + + Auto light/dark, in dark mode + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +Skip to content + + + +
+
+
+ +
+ +
+
+ +
+ +
+
+ +
+
+
+ + + + + Back to top + +
+
+ +
+ +
+
+

Source code for qiskit_quantuminspire.api.authentication

+import time
+from typing import Any, Tuple, cast
+
+import requests
+
+from qiskit_quantuminspire.api.settings import ApiSettings, TokenInfo, Url
+
+
+
+[docs] +class AuthorisationError(Exception): + """Indicates that the authorisation permanently went wrong.""" + + pass
+ + + +
+[docs] +class IdentityProvider: + """Class for interfacing with the IdentityProvider.""" + + def __init__(self, well_known_endpoint: str): + self._well_known_endpoint = well_known_endpoint + self._token_endpoint, self._device_endpoint = self._get_endpoints() + self._headers = {"Content-Type": "application/x-www-form-urlencoded"} + + def _get_endpoints(self) -> Tuple[str, str]: + response = requests.get(self._well_known_endpoint) + response.raise_for_status() + config = response.json() + return config["token_endpoint"], config["device_authorization_endpoint"] + +
+[docs] + def refresh_access_token(self, client_id: str, refresh_token: str) -> dict[str, Any]: + data = { + "grant_type": "refresh_token", + "client_id": client_id, + "refresh_token": refresh_token, + } + response = requests.post(self._token_endpoint, headers=self._headers, data=data) + response.raise_for_status() + return cast(dict[str, Any], response.json())
+
+ + + +
+[docs] +class OauthDeviceSession: + """Class for storing OAuth session information and refreshing tokens when needed.""" + + def __init__(self, host: Url, settings: ApiSettings, identity_provider: IdentityProvider): + self._api_settings = settings + _auth_settings = settings.auths[host] + self._host = host + self._client_id = _auth_settings.client_id + self._token_info = _auth_settings.tokens + self._refresh_time_reduction = 5 # the number of seconds to refresh the expiration time + self._identity_provider = identity_provider + +
+[docs] + def refresh(self) -> TokenInfo: + if self._token_info is None: + raise AuthorisationError("You should authenticate first before you can refresh") + + if self._token_info.access_expires_at > time.time() + self._refresh_time_reduction: + return self._token_info + + try: + self._token_info = TokenInfo( + **self._identity_provider.refresh_access_token(self._client_id, self._token_info.refresh_token) + ) + self._api_settings.store_tokens(self._host, self._token_info) + return self._token_info + except requests.HTTPError as e: + raise AuthorisationError(f"An error occurred during token refresh: {e}")
+
+ +
+
+
+
+ + +
+
+ + Made with Sphinx and @pradyunsg's + + Furo + +
+
+ +
+
+ +
+
+ +
+
+ + + + + \ No newline at end of file diff --git a/pr-preview/pr-92/_modules/qiskit_quantuminspire/api/client.html b/pr-preview/pr-92/_modules/qiskit_quantuminspire/api/client.html new file mode 100644 index 0000000..397925e --- /dev/null +++ b/pr-preview/pr-92/_modules/qiskit_quantuminspire/api/client.html @@ -0,0 +1,351 @@ + + + + + + + + qiskit_quantuminspire.api.client - Qiskit-QuantumInspire 0.1.0 documentation + + + + + + + + + + + + + + + + + + Contents + + + + + + Menu + + + + + + + + + Expand + + + + + + Light mode + + + + + + + + + + + + + + Dark mode + + + + + + + Auto light/dark, in light mode + + + + + + + + + + + + + + + Auto light/dark, in dark mode + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +Skip to content + + + +
+
+
+ +
+ +
+
+ +
+ +
+
+ +
+
+
+ + + + + Back to top + +
+
+ +
+ +
+
+

Source code for qiskit_quantuminspire.api.client

+from typing import Any, Optional
+
+import compute_api_client
+
+from qiskit_quantuminspire.api.authentication import IdentityProvider, OauthDeviceSession
+from qiskit_quantuminspire.api.settings import ApiSettings
+
+
+
+[docs] +class Configuration(compute_api_client.Configuration): # type: ignore[misc] + """Original Configuration class in compute_api_client does not handle refreshing bearer tokens, so we need to add + some functionality.""" + + def __init__(self, host: str, oauth_session: OauthDeviceSession, **kwargs: Any): + self._oauth_session = oauth_session + super().__init__(host=host, **kwargs) + +
+[docs] + def auth_settings(self) -> Any: + token_info = self._oauth_session.refresh() + self.access_token = token_info.access_token + return super().auth_settings()
+
+ + + +_config: Optional[Configuration] = None + + +
+[docs] +def connect() -> None: + """Set connection configuration for the Quantum Inspire API. + + Call after logging in with the CLI. Will remove old configuration. + """ + global _config + settings = ApiSettings.from_config_file() + + tokens = settings.auths[settings.default_host].tokens + + if tokens is None: + raise ValueError("No access token found for the default host. Please connect to Quantum Inspire using the CLI.") + + host = settings.default_host + _config = Configuration( + host=host, + oauth_session=OauthDeviceSession(host, settings, IdentityProvider(settings.auths[host].well_known_endpoint)), + )
+ + + +
+[docs] +def config() -> Configuration: + global _config + if _config is None: + connect() + + assert _config is not None + return _config
+ +
+
+
+
+ + +
+
+ + Made with Sphinx and @pradyunsg's + + Furo + +
+
+ +
+
+ +
+
+ +
+
+ + + + + \ No newline at end of file diff --git a/pr-preview/pr-92/_modules/qiskit_quantuminspire/api/pagination.html b/pr-preview/pr-92/_modules/qiskit_quantuminspire/api/pagination.html new file mode 100644 index 0000000..e8795a9 --- /dev/null +++ b/pr-preview/pr-92/_modules/qiskit_quantuminspire/api/pagination.html @@ -0,0 +1,343 @@ + + + + + + + + qiskit_quantuminspire.api.pagination - Qiskit-QuantumInspire 0.1.0 documentation + + + + + + + + + + + + + + + + + + Contents + + + + + + Menu + + + + + + + + + Expand + + + + + + Light mode + + + + + + + + + + + + + + Dark mode + + + + + + + Auto light/dark, in light mode + + + + + + + + + + + + + + + Auto light/dark, in dark mode + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +Skip to content + + + +
+
+
+ +
+ +
+
+ +
+ +
+
+ +
+
+
+ + + + + Back to top + +
+
+ +
+ +
+
+

Source code for qiskit_quantuminspire.api.pagination

+from typing import Any, Awaitable, Callable, Generic, List, Optional, TypeVar, Union, cast
+
+from pydantic import BaseModel, Field
+from typing_extensions import Annotated
+
+PageType = TypeVar("PageType")
+ItemType = TypeVar("ItemType")
+
+
+
+[docs] +class PageInterface(BaseModel, Generic[ItemType]): + """The page models in the generated API client don't inherit from a common base class, so we have to trick the + typing system a bit with this fake base class.""" + + items: List[ItemType] + total: Optional[Annotated[int, Field(strict=True, ge=0)]] + page: Optional[Annotated[int, Field(strict=True, ge=1)]] + size: Optional[Annotated[int, Field(strict=True, ge=1)]] + pages: Optional[Annotated[int, Field(strict=True, ge=0)]] = None
+ + + +
+[docs] +class PageReader(Generic[PageType, ItemType]): + """Helper class for reading fastapi-pagination style pages returned by the compute_api_client.""" + +
+[docs] + async def get_all(self, api_call: Callable[..., Awaitable[PageType]], **kwargs: Any) -> List[ItemType]: + """Get all items from an API call that supports paging.""" + items: List[ItemType] = [] + page = 1 + + while True: + response = cast(PageInterface[ItemType], await api_call(page=page, **kwargs)) + + items.extend(response.items) + page += 1 + if response.pages is None or page > response.pages: + break + return items
+ + +
+[docs] + async def get_single(self, api_call: Callable[..., Awaitable[PageType]], **kwargs: Any) -> Union[ItemType, None]: + """Get a single item from an API call that supports paging.""" + response = cast(PageInterface[ItemType], await api_call(**kwargs)) + if len(response.items) > 1: + raise RuntimeError(f"Response contains more than one item -> {kwargs}.") + + return response.items[0] if response.items else None
+
+ +
+
+
+
+ + +
+
+ + Made with Sphinx and @pradyunsg's + + Furo + +
+
+ +
+
+ +
+
+ +
+
+ + + + + \ No newline at end of file diff --git a/pr-preview/pr-92/_modules/qiskit_quantuminspire/api/settings.html b/pr-preview/pr-92/_modules/qiskit_quantuminspire/api/settings.html new file mode 100644 index 0000000..a5968da --- /dev/null +++ b/pr-preview/pr-92/_modules/qiskit_quantuminspire/api/settings.html @@ -0,0 +1,370 @@ + + + + + + + + qiskit_quantuminspire.api.settings - Qiskit-QuantumInspire 0.1.0 documentation + + + + + + + + + + + + + + + + + + Contents + + + + + + Menu + + + + + + + + + Expand + + + + + + Light mode + + + + + + + + + + + + + + Dark mode + + + + + + + Auto light/dark, in light mode + + + + + + + + + + + + + + + Auto light/dark, in dark mode + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +Skip to content + + + +
+
+
+ +
+ +
+
+ +
+ +
+
+ +
+
+
+ + + + + Back to top + +
+
+ +
+ +
+
+

Source code for qiskit_quantuminspire.api.settings

+"""Module containing the handler for the Quantum Inspire persistent configuration."""
+
+from __future__ import annotations
+
+import time
+from pathlib import Path
+from typing import Dict, Optional
+
+from pydantic import BaseModel, BeforeValidator, Field, HttpUrl
+from typing_extensions import Annotated
+
+Url = Annotated[str, BeforeValidator(lambda value: str(HttpUrl(value)).rstrip("/"))]
+API_SETTINGS_FILE = Path.joinpath(Path.home(), ".quantuminspire", "config.json")
+
+
+
+[docs] +class TokenInfo(BaseModel): + """A pydantic model for storing all information regarding oauth access and refresh tokens.""" + + access_token: str + expires_in: int # [s] + refresh_token: str + refresh_expires_in: Optional[int] = None # [s] + generated_at: float = Field(default_factory=time.time) + + @property + def access_expires_at(self) -> float: + """Unix timestamp containing the time when the access token will expire.""" + return self.generated_at + self.expires_in
+ + + +
+[docs] +class AuthSettings(BaseModel): + """Pydantic model for storing all auth related settings for a given host.""" + + client_id: str + code_challenge_method: str + code_verifyer_length: int + well_known_endpoint: Url + tokens: Optional[TokenInfo] + team_member_id: Optional[int]
+ + + +
+[docs] +class ApiSettings(BaseModel): + """The settings class for the Quantum Inspire persistent configuration.""" + + auths: Dict[Url, AuthSettings] + default_host: Url + +
+[docs] + def store_tokens(self, host: Url, tokens: TokenInfo, path: Path = API_SETTINGS_FILE) -> None: + """Stores the team_member_id, access and refresh tokens in the config.json file. + + Args: + host: The hostname of the API for which the tokens are intended. + tokens: OAuth access and refresh tokens. + path: The path to the config.json file. Defaults to API_SETTINGS_FILE. + Returns: + None + """ + self.auths[host].tokens = tokens + path.write_text(self.model_dump_json(indent=2))
+ + +
+[docs] + @classmethod + def from_config_file(cls, path: Path = API_SETTINGS_FILE) -> ApiSettings: + """Load the configuration from a file.""" + if not path.is_file(): + raise FileNotFoundError("No configuration file found. Please connect to Quantum Inspire using the CLI.") + + api_settings = path.read_text() + return ApiSettings.model_validate_json(api_settings)
+
+ +
+
+
+
+ + +
+
+ + Made with Sphinx and @pradyunsg's + + Furo + +
+
+ +
+
+ +
+
+ +
+
+ + + + + \ No newline at end of file diff --git a/pr-preview/pr-92/_modules/qiskit_quantuminspire/base_provider.html b/pr-preview/pr-92/_modules/qiskit_quantuminspire/base_provider.html new file mode 100644 index 0000000..928c2c9 --- /dev/null +++ b/pr-preview/pr-92/_modules/qiskit_quantuminspire/base_provider.html @@ -0,0 +1,314 @@ + + + + + + + + qiskit_quantuminspire.base_provider - Qiskit-QuantumInspire 0.1.0 documentation + + + + + + + + + + + + + + + + + + Contents + + + + + + Menu + + + + + + + + + Expand + + + + + + Light mode + + + + + + + + + + + + + + Dark mode + + + + + + + Auto light/dark, in light mode + + + + + + + + + + + + + + + Auto light/dark, in dark mode + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +Skip to content + + + +
+
+
+ +
+ +
+
+ +
+ +
+
+ +
+
+
+ + + + + Back to top + +
+
+ +
+ +
+
+

Source code for qiskit_quantuminspire.base_provider

+from abc import ABC, abstractmethod
+from typing import Optional, Sequence
+
+from qiskit.providers import BackendV2
+
+
+
+[docs] +class BaseProvider(ABC): + """Base class for a provider.""" + +
+[docs] + @abstractmethod + def get_backend(self, name: Optional[str] = None, id: Optional[int] = None) -> BackendV2: + """Get a backend by name.""" + pass
+ + +
+[docs] + @abstractmethod + def backends(self) -> Sequence[BackendV2]: + """Return all backends for this provider.""" + pass
+
+ +
+
+
+
+ + +
+
+ + Made with Sphinx and @pradyunsg's + + Furo + +
+
+ +
+
+ +
+
+ +
+
+ + + + + \ No newline at end of file diff --git a/pr-preview/pr-92/_modules/qiskit_quantuminspire/cqasm.html b/pr-preview/pr-92/_modules/qiskit_quantuminspire/cqasm.html new file mode 100644 index 0000000..1a0135f --- /dev/null +++ b/pr-preview/pr-92/_modules/qiskit_quantuminspire/cqasm.html @@ -0,0 +1,345 @@ + + + + + + + + qiskit_quantuminspire.cqasm - Qiskit-QuantumInspire 0.1.0 documentation + + + + + + + + + + + + + + + + + + Contents + + + + + + Menu + + + + + + + + + Expand + + + + + + Light mode + + + + + + + + + + + + + + Dark mode + + + + + + + Auto light/dark, in light mode + + + + + + + + + + + + + + + Auto light/dark, in dark mode + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +Skip to content + + + +
+
+
+ +
+ +
+
+ +
+ +
+
+ +
+
+
+ + + + + Back to top + +
+
+ +
+ +
+
+

Source code for qiskit_quantuminspire.cqasm

+from opensquirrel import CircuitBuilder
+from opensquirrel.ir import Bit, Float, Qubit
+from opensquirrel.writer import writer
+from qiskit import QuantumCircuit
+
+_QISKIT_TO_OPENSQUIRREL_MAPPING: dict[str, str] = {
+    "id": "I",
+    "h": "H",
+    "x": "X",
+    "y": "Y",
+    "z": "Z",
+    "s": "S",
+    "sdg": "Sdag",
+    "t": "T",
+    "tdg": "Tdag",
+    "rx": "Rx",
+    "ry": "Ry",
+    "rz": "Rz",
+    "cx": "CNOT",
+    "cz": "CZ",
+    "cp": "CR",
+    "swap": "SWAP",
+    "measure": "measure",
+    "reset": "reset",
+}
+
+
+
+[docs] +def dumps(circuit: QuantumCircuit) -> str: + """Return the cQASM representation of the circuit.""" + builder = CircuitBuilder(circuit.num_qubits, circuit.num_clbits) + for circuit_instruction in circuit.data: + operation = circuit_instruction.operation + name = operation.name + params = [Float(param) for param in operation.params] + qubit_operands = [Qubit(qubit._index) for qubit in circuit_instruction.qubits] + clbit_operands = [Bit(clbit._index) for clbit in circuit_instruction.clbits] + + # Only used as circuit compilation directive + if name == "barrier": + continue + + try: + # Get the gate's method in the CircuitBuilder class, call with operands + # All of the builder's methods follow the same pattern, first the qubit operands, then parameters + # Only method with classical bit operands is measure, which does not have parameters + getattr(builder, _QISKIT_TO_OPENSQUIRREL_MAPPING[name])(*qubit_operands, *clbit_operands, *params) + except KeyError: + raise NotImplementedError( + f"Unsupported instruction: {name}. Please edit your circuit or use Qiskit transpilation to support " + + "your selected backend." + ) + + cqasm: str = writer.circuit_to_string(builder.to_circuit()) + + return cqasm
+ +
+
+
+
+ + +
+
+ + Made with Sphinx and @pradyunsg's + + Furo + +
+
+ +
+
+ +
+
+ +
+
+ + + + + \ No newline at end of file diff --git a/pr-preview/pr-92/_modules/qiskit_quantuminspire/qi_backend.html b/pr-preview/pr-92/_modules/qiskit_quantuminspire/qi_backend.html new file mode 100644 index 0000000..27cc277 --- /dev/null +++ b/pr-preview/pr-92/_modules/qiskit_quantuminspire/qi_backend.html @@ -0,0 +1,453 @@ + + + + + + + + qiskit_quantuminspire.qi_backend - Qiskit-QuantumInspire 0.1.0 documentation + + + + + + + + + + + + + + + + + + Contents + + + + + + Menu + + + + + + + + + Expand + + + + + + Light mode + + + + + + + + + + + + + + Dark mode + + + + + + + Auto light/dark, in light mode + + + + + + + + + + + + + + + Auto light/dark, in dark mode + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +Skip to content + + + +
+
+
+ +
+ +
+
+ +
+ +
+
+ +
+
+
+ + + + + Back to top + +
+
+ +
+ +
+
+

Source code for qiskit_quantuminspire.qi_backend

+import logging
+import math
+from pprint import PrettyPrinter
+from typing import Any, List, Union
+
+from compute_api_client import BackendType
+from qiskit.circuit import Instruction, Measure, QuantumCircuit
+from qiskit.circuit.library import (
+    CCXGate,
+    CPhaseGate,
+    CXGate,
+    IGate,
+    RXGate,
+    RYGate,
+    SdgGate,
+    TdgGate,
+    get_standard_gate_name_mapping,
+)
+from qiskit.circuit.parameter import Parameter
+from qiskit.providers import BackendV2 as Backend
+from qiskit.providers.options import Options
+from qiskit.transpiler import CouplingMap, Target
+
+from qiskit_quantuminspire.qi_jobs import QIJob
+from qiskit_quantuminspire.utils import is_coupling_map_complete
+
+# Used for parameterizing Qiskit gates in the gate mapping
+_THETA = Parameter("ϴ")
+
+# Custom gate mapping for gates whose name do not match between cQASM and Qiskit
+_CQASM_QISKIT_GATE_MAPPING: dict[str, Instruction] = {
+    "i": IGate(),
+    "x90": RXGate(math.pi / 2),
+    "mx90": RXGate(-math.pi / 2),
+    "y90": RYGate(math.pi / 2),
+    "my90": RYGate(-math.pi / 2),
+    "toffoli": CCXGate(),
+    "sdag": SdgGate(),
+    "tdag": TdgGate(),
+    "cr": CPhaseGate(_THETA),
+    "cnot": CXGate(),
+    "measure_z": Measure(),
+}
+
+_IGNORED_GATES: list[str] = [
+    # Prep not viewed as separate gates in Qiskit
+    "prep_x",
+    "prep_y",
+    "prep_z",
+    # Measure x and y not natively supported https://github.com/Qiskit/qiskit/issues/3967
+    "measure_x",
+    "measure_y",
+    "measure_all",
+    # May be supportable through parameterized CPhaseGate.
+    # For now, direct usage of CPhaseGate is required
+    "crk",
+]
+
+_ALL_SUPPORTED_GATES: list[str] = list(get_standard_gate_name_mapping().keys()) + list(
+    _CQASM_QISKIT_GATE_MAPPING.keys()
+)
+
+
+# Ignore type checking for QIBackend due to missing Qiskit type stubs,
+# which causes the base class 'Backend' to be treated as 'Any'.
+
+[docs] +class QIBackend(Backend): # type: ignore[misc] + """A wrapper class for QuantumInspire backendtypes to integrate with Qiskit's Backend interface.""" + + _max_shots: int + + def __init__(self, backend_type: BackendType, **kwargs: Any): + super().__init__(name=backend_type.name, description=backend_type.description, **kwargs) + self._id: int = backend_type.id + + self._max_shots: int = backend_type.max_number_of_shots + + # Construct options + self._options = self._default_options() + self.set_options(shots=backend_type.default_number_of_shots) + + if not backend_type.supports_raw_data: + self._options.set_validator("memory", [False]) + + # Construct coupling map + native_gates = [gate.lower() for gate in backend_type.gateset] + available_gates = [gate for gate in native_gates if gate in _ALL_SUPPORTED_GATES] + unknown_gates = set(native_gates) - set(_ALL_SUPPORTED_GATES) - set(_IGNORED_GATES) + coupling_map = CouplingMap(backend_type.topology) + coupling_map_complete = is_coupling_map_complete(coupling_map) + + if len(unknown_gates) > 0: + logging.warning(f"Ignoring unknown native gate(s) {unknown_gates} for backend {backend_type.name}") + + if "toffoli" in available_gates and not coupling_map_complete: + available_gates.remove("toffoli") + logging.warning( + f"Native toffoli gate in backend {backend_type.name} not supported for non-complete topology" + ) + + self._target = Target().from_configuration( + basis_gates=available_gates, + num_qubits=backend_type.nqubits, + coupling_map=None if coupling_map_complete else coupling_map, + custom_name_mapping=_CQASM_QISKIT_GATE_MAPPING, + ) + + def __repr_pretty__(self, p: PrettyPrinter) -> None: + p.pprint(f"QIBackend(name={self.name}, id={self.id})") + + def __repr__(self) -> str: + module_name = self.__class__.__module__ + s = f"<{module_name}.{self.__class__.__name__} object at 0x{id(self):x} (name={self.name}, id={self.id})>" + return s + + @classmethod + def _default_options(cls) -> Options: + """Only options defined here are supported by the backend. + + shots: int: Number of shots for the job. + """ + options = Options(shots=1024, seed_simulator=None, memory=False) + + # Seed_simulator is included in options to enable use of BackendEstimatorV2 in Qiskit, + # but is not actually supported by the backend so any other value than none raises an error. + options.set_validator("seed_simulator", [None]) + + options.set_validator("shots", int) + options.set_validator("memory", bool) + + return options + + @property + def target(self) -> Target: + return self._target + + @property + def max_shots(self) -> int: + return self._max_shots + + @property + def max_circuits(self) -> Union[int, None]: + return None + + @property + def id(self) -> int: + return self._id + +
+[docs] + def run(self, run_input: Union[QuantumCircuit, List[QuantumCircuit]], **options: Any) -> QIJob: + """Create and run a (batch)job on an QuantumInspire Backend. + + Args: + run_input: A single or list of Qiskit QuantumCircuit objects or hybrid algorithms. + + Returns: + QIJob: A reference to the batch job that was submitted. + """ + self.set_options(**options) + job = QIJob(run_input=run_input, backend=self) + job.submit() + return job
+
+ +
+
+
+
+ + +
+
+ + Made with Sphinx and @pradyunsg's + + Furo + +
+
+ +
+
+ +
+
+ +
+
+ + + + + \ No newline at end of file diff --git a/pr-preview/pr-92/_modules/qiskit_quantuminspire/qi_jobs.html b/pr-preview/pr-92/_modules/qiskit_quantuminspire/qi_jobs.html new file mode 100644 index 0000000..380d6c8 --- /dev/null +++ b/pr-preview/pr-92/_modules/qiskit_quantuminspire/qi_jobs.html @@ -0,0 +1,693 @@ + + + + + + + + qiskit_quantuminspire.qi_jobs - Qiskit-QuantumInspire 0.1.0 documentation + + + + + + + + + + + + + + + + + + Contents + + + + + + Menu + + + + + + + + + Expand + + + + + + Light mode + + + + + + + + + + + + + + Dark mode + + + + + + + Auto light/dark, in light mode + + + + + + + + + + + + + + + Auto light/dark, in dark mode + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +Skip to content + + + +
+
+
+ +
+ +
+
+ +
+ +
+
+ +
+
+
+ + + + + Back to top + +
+
+ +
+ +
+
+

Source code for qiskit_quantuminspire.qi_jobs

+import asyncio
+from dataclasses import dataclass
+from functools import cache
+from pathlib import Path
+from typing import Any, List, Optional, Union, cast
+
+from compute_api_client import (
+    Algorithm,
+    AlgorithmIn,
+    AlgorithmsApi,
+    AlgorithmType,
+    ApiClient,
+    BatchJob,
+    BatchJobIn,
+    BatchJobsApi,
+    BatchJobStatus,
+    Commit,
+    CommitIn,
+    CommitsApi,
+    CompileStage,
+    File,
+    FileIn,
+    FilesApi,
+    Job,
+    JobIn,
+    JobsApi,
+    Language,
+    LanguagesApi,
+    PageBatchJob,
+    PageResult,
+    Project,
+    ProjectIn,
+    ProjectsApi,
+    Result as RawJobResult,
+    ResultsApi,
+    ShareType,
+)
+from qiskit import qpy
+from qiskit.circuit import QuantumCircuit
+from qiskit.providers import JobV1
+from qiskit.providers.backend import BackendV2
+from qiskit.providers.jobstatus import JobStatus
+from qiskit.qobj import QobjExperimentHeader
+from qiskit.result.models import ExperimentResult, ExperimentResultData
+from qiskit.result.result import Result
+
+from qiskit_quantuminspire import cqasm
+from qiskit_quantuminspire.api.client import config
+from qiskit_quantuminspire.api.pagination import PageReader
+from qiskit_quantuminspire.api.settings import ApiSettings
+from qiskit_quantuminspire.base_provider import BaseProvider
+from qiskit_quantuminspire.utils import run_async
+
+
+
+[docs] +@dataclass +class CircuitExecutionData: + """Class for book-keeping of individual jobs.""" + + circuit: QuantumCircuit + job_id: Optional[int] = None + results: Optional[RawJobResult] = None
+ + + +# Ignore type checking for QIJob due to missing Qiskit type stubs, +# which causes the base class 'Job' to be treated as 'Any'. +
+[docs] +class QIJob(JobV1): # type: ignore[misc] + """A wrapper class for QuantumInspire batch jobs to integrate with Qiskit's Job interface.""" + + def __init__( + self, + run_input: Union[QuantumCircuit, List[QuantumCircuit]], + backend: Union[BackendV2, None], + **kwargs: Any, + ) -> None: + """Initialize a QIJob instance. + + Args: + run_input: A single/list of Qiskit QuantumCircuit object(s). + backend: The backend on which the job is run. While specified as `Backend` to avoid + circular dependency, it is a `QIBackend`. + **kwargs: Additional keyword arguments passed to the parent `Job` class. + """ + super().__init__(backend, "", **kwargs) + self.circuits_run_data: List[CircuitExecutionData] = ( + [CircuitExecutionData(circuit=run_input)] + if isinstance(run_input, QuantumCircuit) + else [CircuitExecutionData(circuit=circuit) for circuit in run_input] + ) + self.program_name = "Program created by SDK" + self.batch_job_id: Union[int, None] = None + +
+[docs] + def submit(self) -> None: + run_async(self._submit_async())
+ + + async def _submit_async(self) -> None: + """Submit the (batch)job to the quantum inspire backend. + + Use compute-api-client to call the cjm endpoints in the correct order, to submit the jobs. + """ + options = cast(dict[str, Any], self.backend().options) + configuration = config() + settings = ApiSettings.from_config_file() + + # call create algorithm + async with ApiClient(configuration) as api_client: + language = await self._get_language(api_client, "cqasm", "3.0") + if language is None: + raise RuntimeError("No cqasm v3.0 language id returned by the platform") + + team_member_id = settings.auths[settings.default_host].team_member_id + assert isinstance(team_member_id, int) + + project = await self._create_project(api_client, team_member_id) + batch_job = await self._create_batch_job(api_client, backend_type_id=self.backend().id) + + async def job_run_sequence( + in_api_client: ApiClient, + in_project: Project, + in_batch_job: BatchJob, + circuit_data: CircuitExecutionData, + ) -> None: + algorithm = await self._create_algorithm(in_api_client, in_project.id) + commit = await self._create_commit(in_api_client, algorithm.id) + file = await self._create_file(in_api_client, commit.id, language.id, circuit_data.circuit) + job: Job = await self._create_job( + in_api_client, + file.id, + in_batch_job.id, + raw_data_enabled=cast(bool, options.get("memory")), + number_of_shots=options.get("shots"), + ) + circuit_data.job_id = job.id + + # iterate over the circuits + run_coroutines = ( + job_run_sequence(api_client, project, batch_job, circuit_run_data) + for circuit_run_data in self.circuits_run_data + ) + await asyncio.gather(*run_coroutines) + await self._enqueue_batch_job(api_client, batch_job.id) + self.batch_job_id = batch_job.id + + async def _create_project(self, api_client: ApiClient, owner_id: int) -> Project: + api_instance = ProjectsApi(api_client) + obj = ProjectIn( + owner_id=owner_id, + name=self.program_name, + description="Project created by SDK", + starred=False, + ) + return await api_instance.create_project_projects_post(obj) + + async def _create_algorithm(self, api_client: ApiClient, project_id: int) -> Algorithm: + api_instance = AlgorithmsApi(api_client) + obj = AlgorithmIn( + project_id=project_id, type=AlgorithmType.QUANTUM, shared=ShareType.PRIVATE, name=self.program_name + ) + return await api_instance.create_algorithm_algorithms_post(obj) + + async def _create_commit(self, api_client: ApiClient, algorithm_id: int) -> Commit: + api_instance = CommitsApi(api_client) + obj = CommitIn( + description="Commit created by SDK", + algorithm_id=algorithm_id, + ) + return await api_instance.create_commit_commits_post(obj) + + async def _create_file( + self, api_client: ApiClient, commit_id: int, language_id: int, circuit: QuantumCircuit + ) -> File: + api_instance = FilesApi(api_client) + obj = FileIn( + commit_id=commit_id, + content=cqasm.dumps(circuit), + language_id=language_id, + compile_stage=CompileStage.NONE, + compile_properties={}, + ) + return await api_instance.create_file_files_post(obj) + + async def _create_batch_job(self, api_client: ApiClient, backend_type_id: int) -> BatchJob: + api_instance = BatchJobsApi(api_client) + obj = BatchJobIn(backend_type_id=backend_type_id) + return await api_instance.create_batch_job_batch_jobs_post(obj) + + async def _create_job( + self, + api_client: ApiClient, + file_id: int, + batch_job_id: int, + raw_data_enabled: bool, + number_of_shots: Optional[int] = None, + ) -> Job: + api_instance = JobsApi(api_client) + obj = JobIn( + file_id=file_id, + batch_job_id=batch_job_id, + number_of_shots=number_of_shots, + raw_data_enabled=raw_data_enabled, + ) + return await api_instance.create_job_jobs_post(obj) + + async def _enqueue_batch_job(self, api_client: ApiClient, batch_job_id: int) -> BatchJob: + api_instance = BatchJobsApi(api_client) + return await api_instance.enqueue_batch_job_batch_jobs_id_enqueue_patch(batch_job_id) + + async def _get_language( + self, api_client: ApiClient, language_name: str, language_version: str + ) -> Union[Language, None]: + language_api_instance = LanguagesApi(api_client) + languages_page = await language_api_instance.read_languages_languages_get() + for lan in languages_page.items: + if language_name.lower() == lan.name.lower(): + if language_version == lan.version: + return lan + + return None + + async def _fetch_job_results(self) -> None: + """Fetch results for job_ids from CJM using api client.""" + async with ApiClient(config()) as client: + page_reader = PageReader[PageResult, RawJobResult]() + results_api = ResultsApi(client) + pagination_handler = page_reader.get_all + results_handler = results_api.read_results_by_job_id_results_job_job_id_get + + result_tasks = [ + pagination_handler(results_handler, job_id=circuit_data.job_id) + for circuit_data in self.circuits_run_data + ] + result_items = await asyncio.gather(*result_tasks) + + for circuit_data, result_item in zip(self.circuits_run_data, result_items): + circuit_data.results = None if not result_item else result_item[0] + +
+[docs] + @cache + def result(self, wait_for_results: Optional[bool] = True, timeout: float = 60.0) -> Result: + """Return the results of the job.""" + if wait_for_results: + self.wait_for_final_state(timeout=timeout) + elif not self.done(): + raise RuntimeError(f"(Batch)Job status is {self.status()}.") + run_async(self._fetch_job_results()) + return self._process_results()
+ + +
+[docs] + def status(self) -> JobStatus: + """Return the status of the (batch)job, among the values of ``JobStatus``.""" + + # mapping of QI2 BatchJobStatus to Qiskit JobStatus + status_map = { + BatchJobStatus.QUEUED: JobStatus.QUEUED, + BatchJobStatus.RESERVED: JobStatus.QUEUED, + BatchJobStatus.PLANNED: JobStatus.QUEUED, + BatchJobStatus.RUNNING: JobStatus.RUNNING, + BatchJobStatus.FINISHED: JobStatus.DONE, + } + + batch_job = run_async(self._fetch_batchjob_status()) + return status_map[batch_job.status]
+ + + async def _fetch_batchjob_status(self) -> BatchJob: + async with ApiClient(config()) as api_client: + api_instance = BatchJobsApi(api_client) + + page_reader = PageReader[PageBatchJob, BatchJob]() + batch_job = await page_reader.get_single(api_instance.read_batch_jobs_batch_jobs_get, id=self.batch_job_id) + if batch_job is None: + raise RuntimeError(f"No (batch)job with id {self.batch_job_id}") + + return batch_job + +
+[docs] + def serialize(self, file_path: Union[str, Path]) -> None: + """Serialize job information in this class to a file. + + Uses Qiskit serialization to write circuits to a .qpy file, and includes + backend and and batch_job information in the metadata so that we can recover + the associated data later. + + Args: + file_path: The path to the file where the job information will be stored. + """ + if len(self.circuits_run_data) == 0: + raise ValueError("No circuits to serialize") + + with open(file_path, "wb") as file: + for circuit_data in self.circuits_run_data: + circuit_data.circuit.metadata["job_id"] = circuit_data.job_id + circuit_data.circuit.metadata["backend_type_name"] = self.backend().name + circuit_data.circuit.metadata["backend_type_id"] = self.backend().id + circuit_data.circuit.metadata["batch_job_id"] = self.batch_job_id + + qpy.dump([circuit_data.circuit for circuit_data in self.circuits_run_data], file)
+ + +
+[docs] + @classmethod + def deserialize(cls, provider: BaseProvider, file_path: Union[str, Path]) -> "QIJob": + """Recover a prior job from a file written by QIJob.serialize(). + + Args: + provider: Used to get the backend on which the original job ran. + file_path: The path to the file where the job information is stored. + """ + with open(file_path, "rb") as file: + circuits = qpy.load(file) + + # Qiskit doesn't seem to allow serialization of an empty list of circuits + assert len(circuits) > 0 + + try: + backend_name = cast(str, circuits[0].metadata["backend_type_name"]) + backend_id = cast(int, circuits[0].metadata["backend_type_id"]) + batch_job_id = cast(int, circuits[0].metadata["batch_job_id"]) + except KeyError: + raise ValueError(f"Invalid file format: {file_path}") + + circuits = cast(list[QuantumCircuit], circuits) + + job = cls(circuits, provider.get_backend(backend_name, backend_id)) + job.batch_job_id = batch_job_id + + for circuit_data in job.circuits_run_data: + circuit_data.job_id = circuit_data.circuit.metadata.get("job_id") + + return job
+ + + def _process_results(self) -> Result: + """Process the raw job results obtained from QuantumInspire.""" + + results = [] + batch_job_success = [False] * len(self.circuits_run_data) + + for idx, circuit_data in enumerate(self.circuits_run_data): + qi_result = circuit_data.results + circuit_name = circuit_data.circuit.name + + if qi_result is None: + experiment_result = self._create_empty_experiment_result(circuit_name=circuit_name) + results.append(experiment_result) + continue + + experiment_result = self._create_experiment_result( + circuit_name=circuit_name, + result=qi_result, + ) + results.append(experiment_result) + batch_job_success[idx] = qi_result.shots_done > 0 + + result = Result( + backend_name=self.backend().name, + backend_version="1.0.0", + qobj_id="", + job_id=str(self.batch_job_id), + success=all(batch_job_success), + results=results, + ) + return result + + @staticmethod + def _create_experiment_result( + circuit_name: str, + result: RawJobResult, + ) -> ExperimentResult: + """Create an ExperimentResult instance based on RawJobResult parameters.""" + counts = {hex(int(key, 2)): value for key, value in result.results.items()} + memory = [hex(int(measurement, 2)) for measurement in result.raw_data] if result.raw_data else None + + experiment_data = ExperimentResultData( + counts={} if counts is None else counts, + memory=memory, + ) + return ExperimentResult( + shots=result.shots_done, + success=result.shots_done > 0, + data=experiment_data, + header=QobjExperimentHeader(name=circuit_name), + ) + + @staticmethod + def _create_empty_experiment_result(circuit_name: str) -> ExperimentResult: + """Create an empty ExperimentResult instance.""" + return ExperimentResult( + shots=0, + success=False, + data=ExperimentResultData(counts={}), + header=QobjExperimentHeader(name=circuit_name), + )
+ +
+
+
+
+ + +
+
+ + Made with Sphinx and @pradyunsg's + + Furo + +
+
+ +
+
+ +
+
+ +
+
+ + + + + \ No newline at end of file diff --git a/pr-preview/pr-92/_modules/qiskit_quantuminspire/qi_provider.html b/pr-preview/pr-92/_modules/qiskit_quantuminspire/qi_provider.html new file mode 100644 index 0000000..7437a9d --- /dev/null +++ b/pr-preview/pr-92/_modules/qiskit_quantuminspire/qi_provider.html @@ -0,0 +1,349 @@ + + + + + + + + qiskit_quantuminspire.qi_provider - Qiskit-QuantumInspire 0.1.0 documentation + + + + + + + + + + + + + + + + + + Contents + + + + + + Menu + + + + + + + + + Expand + + + + + + Light mode + + + + + + + + + + + + + + Dark mode + + + + + + + Auto light/dark, in light mode + + + + + + + + + + + + + + + Auto light/dark, in dark mode + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +Skip to content + + + +
+
+
+ +
+ +
+
+ +
+ +
+
+ +
+
+
+ + + + + Back to top + +
+
+ +
+ +
+
+

Source code for qiskit_quantuminspire.qi_provider

+from typing import Any, List, Optional, Sequence
+
+from compute_api_client import ApiClient, BackendType, BackendTypesApi, PageBackendType
+
+from qiskit_quantuminspire.api.client import config
+from qiskit_quantuminspire.api.pagination import PageReader
+from qiskit_quantuminspire.base_provider import BaseProvider
+from qiskit_quantuminspire.qi_backend import QIBackend
+from qiskit_quantuminspire.utils import run_async
+
+
+
+[docs] +class QIProvider(BaseProvider): + """List QIBackends integrated with QiskitBackend interface.""" + + def __init__(self) -> None: + self._qiskit_backends = self._construct_backends() + + async def _fetch_qi_backend_types(self) -> List[BackendType]: + """Fetch backend types from CJM using api client. + + (Implemented without paging only for demonstration purposes, should get a proper implementation) + """ + async with ApiClient(config()) as client: + page_reader = PageReader[PageBackendType, BackendType]() + backend_types_api = BackendTypesApi(client) + backend_types: List[BackendType] = await page_reader.get_all( + backend_types_api.read_backend_types_backend_types_get + ) + return backend_types + + def _construct_backends(self) -> List[QIBackend]: + """Construct QIBackend using fetched backendtypes and metadata.""" + qi_backend_types = run_async(self._fetch_qi_backend_types()) + qi_backends = [QIBackend(provider=self, backend_type=backend_type) for backend_type in qi_backend_types] + return qi_backends + +
+[docs] + def backends(self) -> Sequence[QIBackend]: + return self._qiskit_backends
+ + +
+[docs] + def get_backend(self, name: Optional[str] = None, id: Optional[int] = None) -> QIBackend: + filter_arguments: dict[str, Any] = {} + + if name is not None: + filter_arguments["name"] = name + + if id is not None: + filter_arguments["id"] = id + + for backend in self._qiskit_backends: + if all(getattr(backend, key) == value for key, value in filter_arguments.items()): + return backend + + raise ValueError(f"Backend {name} not found")
+
+ +
+
+
+
+ + +
+
+ + Made with Sphinx and @pradyunsg's + + Furo + +
+
+ +
+
+ +
+
+ +
+
+ + + + + \ No newline at end of file diff --git a/pr-preview/pr-92/_modules/qiskit_quantuminspire/utils.html b/pr-preview/pr-92/_modules/qiskit_quantuminspire/utils.html new file mode 100644 index 0000000..6cf705f --- /dev/null +++ b/pr-preview/pr-92/_modules/qiskit_quantuminspire/utils.html @@ -0,0 +1,318 @@ + + + + + + + + qiskit_quantuminspire.utils - Qiskit-QuantumInspire 0.1.0 documentation + + + + + + + + + + + + + + + + + + Contents + + + + + + Menu + + + + + + + + + Expand + + + + + + Light mode + + + + + + + + + + + + + + Dark mode + + + + + + + Auto light/dark, in light mode + + + + + + + + + + + + + + + Auto light/dark, in dark mode + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +Skip to content + + + +
+
+
+ +
+ +
+
+ +
+ +
+
+ +
+
+
+ + + + + Back to top + +
+
+ +
+ +
+
+

Source code for qiskit_quantuminspire.utils

+import asyncio
+import concurrent
+from typing import Any, Coroutine
+
+from qiskit.transpiler import CouplingMap
+
+
+
+[docs] +def is_coupling_map_complete(coupling_map: CouplingMap) -> bool: + """A complete digraph is a digraph in which there is a directed edge from every vertex to every other vertex.""" + distance_matrix = coupling_map.distance_matrix + + assert distance_matrix is not None + + is_semicomplete = all(distance in [1, 0] for distance in distance_matrix.flatten()) + + return is_semicomplete and coupling_map.is_symmetric
+ + + +
+[docs] +def run_async(async_function: Coroutine[Any, Any, Any]) -> Any: + try: + _ = asyncio.get_running_loop() + with concurrent.futures.ThreadPoolExecutor() as executor: + return executor.submit(asyncio.run, async_function).result() + except RuntimeError: + return asyncio.run(async_function)
+ +
+
+
+
+ + +
+
+ + Made with Sphinx and @pradyunsg's + + Furo + +
+
+ +
+
+ +
+
+ +
+
+ + + + + \ No newline at end of file diff --git a/pr-preview/pr-92/_sources/api/modules.rst.txt b/pr-preview/pr-92/_sources/api/modules.rst.txt new file mode 100644 index 0000000..8da2492 --- /dev/null +++ b/pr-preview/pr-92/_sources/api/modules.rst.txt @@ -0,0 +1,7 @@ +qiskit_quantuminspire +===================== + +.. toctree:: + :maxdepth: 4 + + qiskit_quantuminspire diff --git a/pr-preview/pr-92/_sources/api/qiskit_quantuminspire.api.rst.txt b/pr-preview/pr-92/_sources/api/qiskit_quantuminspire.api.rst.txt new file mode 100644 index 0000000..5724818 --- /dev/null +++ b/pr-preview/pr-92/_sources/api/qiskit_quantuminspire.api.rst.txt @@ -0,0 +1,45 @@ +qiskit\_quantuminspire.api package +================================== + +Submodules +---------- + +qiskit\_quantuminspire.api.authentication module +------------------------------------------------ + +.. automodule:: qiskit_quantuminspire.api.authentication + :members: + :undoc-members: + :show-inheritance: + +qiskit\_quantuminspire.api.client module +---------------------------------------- + +.. automodule:: qiskit_quantuminspire.api.client + :members: + :undoc-members: + :show-inheritance: + +qiskit\_quantuminspire.api.pagination module +-------------------------------------------- + +.. automodule:: qiskit_quantuminspire.api.pagination + :members: + :undoc-members: + :show-inheritance: + +qiskit\_quantuminspire.api.settings module +------------------------------------------ + +.. automodule:: qiskit_quantuminspire.api.settings + :members: + :undoc-members: + :show-inheritance: + +Module contents +--------------- + +.. automodule:: qiskit_quantuminspire.api + :members: + :undoc-members: + :show-inheritance: diff --git a/pr-preview/pr-92/_sources/api/qiskit_quantuminspire.rst.txt b/pr-preview/pr-92/_sources/api/qiskit_quantuminspire.rst.txt new file mode 100644 index 0000000..1de9b3d --- /dev/null +++ b/pr-preview/pr-92/_sources/api/qiskit_quantuminspire.rst.txt @@ -0,0 +1,69 @@ +qiskit\_quantuminspire package +============================== + +Subpackages +----------- + +.. toctree:: + :maxdepth: 4 + + qiskit_quantuminspire.api + +Submodules +---------- + +qiskit\_quantuminspire.base\_provider module +-------------------------------------------- + +.. automodule:: qiskit_quantuminspire.base_provider + :members: + :undoc-members: + :show-inheritance: + +qiskit\_quantuminspire.cqasm module +----------------------------------- + +.. automodule:: qiskit_quantuminspire.cqasm + :members: + :undoc-members: + :show-inheritance: + +qiskit\_quantuminspire.qi\_backend module +----------------------------------------- + +.. automodule:: qiskit_quantuminspire.qi_backend + :members: + :undoc-members: + :show-inheritance: + +qiskit\_quantuminspire.qi\_jobs module +-------------------------------------- + +.. automodule:: qiskit_quantuminspire.qi_jobs + :members: + :undoc-members: + :show-inheritance: + +qiskit\_quantuminspire.qi\_provider module +------------------------------------------ + +.. automodule:: qiskit_quantuminspire.qi_provider + :members: + :undoc-members: + :show-inheritance: + +qiskit\_quantuminspire.utils module +----------------------------------- + +.. automodule:: qiskit_quantuminspire.utils + :members: + :undoc-members: + :show-inheritance: + +Module contents +--------------- + +.. automodule:: qiskit_quantuminspire + :members: + :undoc-members: + :show-inheritance: diff --git a/pr-preview/pr-92/_sources/contributing.md.txt b/pr-preview/pr-92/_sources/contributing.md.txt new file mode 100644 index 0000000..1b63274 --- /dev/null +++ b/pr-preview/pr-92/_sources/contributing.md.txt @@ -0,0 +1,28 @@ +# Contributing + +This project uses Poetry for package management and tox for managing testing/linting/documentation tools. + +## Setting up a development environment + +Ensure both Poetry and tox installed (using [pipx](https://github.com/pypa/pipx) is recommended): + +```bash +pipx install poetry +pipx install tox +``` + +Install dependencies in a virtual environment (run in root of repository): + +```bash +poetry install +``` + +## Useful tox commands + +```bash +tox -e test # Run pytest +tox -e lint # Run linters +tox -e type # Run mypy +tox # Run all of above +tox -e docs # Generate documentation +``` diff --git a/pr-preview/pr-92/_sources/getting_started/index.rst.txt b/pr-preview/pr-92/_sources/getting_started/index.rst.txt new file mode 100644 index 0000000..2337cfe --- /dev/null +++ b/pr-preview/pr-92/_sources/getting_started/index.rst.txt @@ -0,0 +1,12 @@ +====================== +Getting Started +====================== + +How to get started + +.. toctree:: + :maxdepth: 2 + + Installation and login + Submitting a circuit + diff --git a/pr-preview/pr-92/_sources/getting_started/installation.md.txt b/pr-preview/pr-92/_sources/getting_started/installation.md.txt new file mode 100644 index 0000000..90bbe5d --- /dev/null +++ b/pr-preview/pr-92/_sources/getting_started/installation.md.txt @@ -0,0 +1,13 @@ +# Installation and login + +You can install the Qiskit-QI plugin using pip: + +```bash +pip install qiskit-quantuminspire +``` + +For access to the Quantum Inspire 2 API you can use the QI2 CLI. Once installed (see [repository](https://github.com/QuTech-Delft/quantuminspire2) for installation instructions), simply run the shell command below to log in to the production environment. + +```bash +qi login "https://api.qi2.quantum-inspire.com" +``` diff --git a/pr-preview/pr-92/_sources/getting_started/submitting.md.txt b/pr-preview/pr-92/_sources/getting_started/submitting.md.txt new file mode 100644 index 0000000..f7d8ed7 --- /dev/null +++ b/pr-preview/pr-92/_sources/getting_started/submitting.md.txt @@ -0,0 +1,74 @@ +# How to: Submit a circuit + +## Getting a backend + +To instantiate the provider, make sure you are logged into QI2, then create a provider: + +```python +from qiskit_quantuminspire.qi_provider import QIProvider + +provider = QIProvider() +``` + +Once the provider has been instantiated, it may be used to access supported backends: + +```python +# Show all current supported backends: +print(provider.backends()) + +# Get Quantum Inspire's simulator backend: +simulator_backend = provider.get_backend("QX emulator") +``` + +## Submitting a Circuit + +Once a backend has been specified, it may be used to submit circuits. +For example, running a Bell State: + +```python +from qiskit import QuantumCircuit + +# Create a basic Bell State circuit: +qc = QuantumCircuit(2, 2) +qc.h(0) +qc.cx(0, 1) +qc.measure([0, 1], [0, 1]) + +# Show a representation of the quantum circuit: +print(qc) + +# Run the circuit on Quantum Inspire's platform: +job = simulator_backend.run(qc) + +# Print the results. +print(job.result().get_counts()) +``` + +On backends that support the `raw data` feature, you can set the `memory` option to get the measurement result of each individual shot: + +```python +job = simulator_backend.run(qc, memory=True) +``` + +## Transpilation + +Depending on the chosen backends, certain gates may not be supported. Qiskit is aware of the capabilities of each backend, and can transpile +circuits to use only supported gates: + +```python +from qiskit import transpile + +# Show supported gates +print(simulator_backend.target) + +# Create circuit with a gate the backend doesn't support: +qc = QuantumCircuit(2, 2) +qc.sx(0) +qc.cx(0, 1) +qc.measure([0, 1], [0, 1]) + + +# Transpile the circuit for the target backend: +qc_compiled = transpile(qc, simulator_backend) +print(qc_compiled) +``` diff --git a/pr-preview/pr-92/_sources/index.rst.txt b/pr-preview/pr-92/_sources/index.rst.txt new file mode 100644 index 0000000..86906e2 --- /dev/null +++ b/pr-preview/pr-92/_sources/index.rst.txt @@ -0,0 +1,33 @@ +====================== +Qiskit-QuantumInspire +====================== + +Welcome to the documentation of **Qiskit-QuantumInspire**, a Qiskit plugin for the Quantum Inspire platform. + +.. toctree:: + :hidden: + + Documentation Home + Getting Started + Example Notebooks + Contributing and Development + License + API Reference + GitHub + + +.. _toctree: https://www.sphinx-doc.org/en/master/usage/restructuredtext/directives.html +.. _reStructuredText: https://www.sphinx-doc.org/en/master/usage/restructuredtext/basics.html +.. _references: https://www.sphinx-doc.org/en/stable/markup/inline.html +.. _Python domain syntax: https://www.sphinx-doc.org/en/master/usage/restructuredtext/domains.html#the-python-domain +.. _Sphinx: https://www.sphinx-doc.org/ +.. _Python: https://docs.python.org/ +.. _Numpy: https://numpy.org/doc/stable +.. _SciPy: https://docs.scipy.org/doc/scipy/reference/ +.. _matplotlib: https://matplotlib.org/contents.html# +.. _Pandas: https://pandas.pydata.org/pandas-docs/stable +.. _Scikit-Learn: https://scikit-learn.org/stable +.. _autodoc: https://www.sphinx-doc.org/en/master/ext/autodoc.html +.. _Google style: https://google.github.io/styleguide/pyguide.html#38-comments-and-docstrings +.. _NumPy style: https://numpydoc.readthedocs.io/en/latest/format.html +.. _classical style: https://www.sphinx-doc.org/en/master/domains.html#info-field-lists diff --git a/pr-preview/pr-92/_sources/license.md.txt b/pr-preview/pr-92/_sources/license.md.txt new file mode 100644 index 0000000..c2384ea --- /dev/null +++ b/pr-preview/pr-92/_sources/license.md.txt @@ -0,0 +1,178 @@ +# License + + Apache License + Version 2.0, January 2004 + https://www.apache.org/licenses/ + + TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION + + 1. Definitions. + + "License" shall mean the terms and conditions for use, reproduction, + and distribution as defined by Sections 1 through 9 of this document. + + "Licensor" shall mean the copyright owner or entity authorized by + the copyright owner that is granting the License. + + "Legal Entity" shall mean the union of the acting entity and all + other entities that control, are controlled by, or are under common + control with that entity. For the purposes of this definition, + "control" means (i) the power, direct or indirect, to cause the + direction or management of such entity, whether by contract or + otherwise, or (ii) ownership of fifty percent (50%) or more of the + outstanding shares, or (iii) beneficial ownership of such entity. + + "You" (or "Your") shall mean an individual or Legal Entity + exercising permissions granted by this License. + + "Source" form shall mean the preferred form for making modifications, + including but not limited to software source code, documentation + source, and configuration files. + + "Object" form shall mean any form resulting from mechanical + transformation or translation of a Source form, including but + not limited to compiled object code, generated documentation, + and conversions to other media types. + + "Work" shall mean the work of authorship, whether in Source or + Object form, made available under the License, as indicated by a + copyright notice that is included in or attached to the work + (an example is provided in the Appendix below). + + "Derivative Works" shall mean any work, whether in Source or Object + form, that is based on (or derived from) the Work and for which the + editorial revisions, annotations, elaborations, or other modifications + represent, as a whole, an original work of authorship. For the purposes + of this License, Derivative Works shall not include works that remain + separable from, or merely link (or bind by name) to the interfaces of, + the Work and Derivative Works thereof. + + "Contribution" shall mean any work of authorship, including + the original version of the Work and any modifications or additions + to that Work or Derivative Works thereof, that is intentionally + submitted to Licensor for inclusion in the Work by the copyright owner + or by an individual or Legal Entity authorized to submit on behalf of + the copyright owner. For the purposes of this definition, "submitted" + means any form of electronic, verbal, or written communication sent + to the Licensor or its representatives, including but not limited to + communication on electronic mailing lists, source code control systems, + and issue tracking systems that are managed by, or on behalf of, the + Licensor for the purpose of discussing and improving the Work, but + excluding communication that is conspicuously marked or otherwise + designated in writing by the copyright owner as "Not a Contribution." + + "Contributor" shall mean Licensor and any individual or Legal Entity + on behalf of whom a Contribution has been received by Licensor and + subsequently incorporated within the Work. + + 2. Grant of Copyright License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + copyright license to reproduce, prepare Derivative Works of, + publicly display, publicly perform, sublicense, and distribute the + Work and such Derivative Works in Source or Object form. + + 3. Grant of Patent License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + (except as stated in this section) patent license to make, have made, + use, offer to sell, sell, import, and otherwise transfer the Work, + where such license applies only to those patent claims licensable + by such Contributor that are necessarily infringed by their + Contribution(s) alone or by combination of their Contribution(s) + with the Work to which such Contribution(s) was submitted. If You + institute patent litigation against any entity (including a + cross-claim or counterclaim in a lawsuit) alleging that the Work + or a Contribution incorporated within the Work constitutes direct + or contributory patent infringement, then any patent licenses + granted to You under this License for that Work shall terminate + as of the date such litigation is filed. + + 4. Redistribution. You may reproduce and distribute copies of the + Work or Derivative Works thereof in any medium, with or without + modifications, and in Source or Object form, provided that You + meet the following conditions: + + (a) You must give any other recipients of the Work or + Derivative Works a copy of this License; and + + (b) You must cause any modified files to carry prominent notices + stating that You changed the files; and + + (c) You must retain, in the Source form of any Derivative Works + that You distribute, all copyright, patent, trademark, and + attribution notices from the Source form of the Work, + excluding those notices that do not pertain to any part of + the Derivative Works; and + + (d) If the Work includes a "NOTICE" text file as part of its + distribution, then any Derivative Works that You distribute must + include a readable copy of the attribution notices contained + within such NOTICE file, excluding those notices that do not + pertain to any part of the Derivative Works, in at least one + of the following places: within a NOTICE text file distributed + as part of the Derivative Works; within the Source form or + documentation, if provided along with the Derivative Works; or, + within a display generated by the Derivative Works, if and + wherever such third-party notices normally appear. The contents + of the NOTICE file are for informational purposes only and + do not modify the License. You may add Your own attribution + notices within Derivative Works that You distribute, alongside + or as an addendum to the NOTICE text from the Work, provided + that such additional attribution notices cannot be construed + as modifying the License. + + You may add Your own copyright statement to Your modifications and + may provide additional or different license terms and conditions + for use, reproduction, or distribution of Your modifications, or + for any such Derivative Works as a whole, provided Your use, + reproduction, and distribution of the Work otherwise complies with + the conditions stated in this License. + + 5. Submission of Contributions. Unless You explicitly state otherwise, + any Contribution intentionally submitted for inclusion in the Work + by You to the Licensor shall be under the terms and conditions of + this License, without any additional terms or conditions. + Notwithstanding the above, nothing herein shall supersede or modify + the terms of any separate license agreement you may have executed + with Licensor regarding such Contributions. + + 6. Trademarks. This License does not grant permission to use the trade + names, trademarks, service marks, or product names of the Licensor, + except as required for reasonable and customary use in describing the + origin of the Work and reproducing the content of the NOTICE file. + + 7. Disclaimer of Warranty. Unless required by applicable law or + agreed to in writing, Licensor provides the Work (and each + Contributor provides its Contributions) on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or + implied, including, without limitation, any warranties or conditions + of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A + PARTICULAR PURPOSE. You are solely responsible for determining the + appropriateness of using or redistributing the Work and assume any + risks associated with Your exercise of permissions under this License. + + 8. Limitation of Liability. In no event and under no legal theory, + whether in tort (including negligence), contract, or otherwise, + unless required by applicable law (such as deliberate and grossly + negligent acts) or agreed to in writing, shall any Contributor be + liable to You for damages, including any direct, indirect, special, + incidental, or consequential damages of any character arising as a + result of this License or out of the use or inability to use the + Work (including but not limited to damages for loss of goodwill, + work stoppage, computer failure or malfunction, or any and all + other commercial damages or losses), even if such Contributor + has been advised of the possibility of such damages. + + 9. Accepting Warranty or Additional Liability. While redistributing + the Work or Derivative Works thereof, You may choose to offer, + and charge a fee for, acceptance of support, warranty, indemnity, + or other liability obligations and/or rights consistent with this + License. However, in accepting such obligations, You may act only + on Your own behalf and on Your sole responsibility, not on behalf + of any other Contributor, and only if You agree to indemnify, + defend, and hold each Contributor harmless for any liability + incurred by, or claims asserted against, such Contributor by reason + of your accepting any such warranty or additional liability. + + END OF TERMS AND CONDITIONS diff --git a/pr-preview/pr-92/_sources/notebooks/QI2 Performance Test.ipynb.txt b/pr-preview/pr-92/_sources/notebooks/QI2 Performance Test.ipynb.txt new file mode 100644 index 0000000..06d0ee7 --- /dev/null +++ b/pr-preview/pr-92/_sources/notebooks/QI2 Performance Test.ipynb.txt @@ -0,0 +1,185 @@ +{ + "cells": [ + { + "cell_type": "markdown", + "id": "bb3b3564-fad4-4beb-8274-051385b8ad99", + "metadata": {}, + "source": [ + "# Quantum Inspire performance test\n", + "\n", + "We compare performance of the simulator with the circuit from \"Overview and Comparison of Gate Level Quantum Software Platforms\", https://arxiv.org/abs/1807.02500" + ] + }, + { + "cell_type": "code", + "execution_count": 10, + "id": "405026b3-84de-403f-a65b-17a4f32e59c7", + "metadata": {}, + "outputs": [], + "source": [ + "import numpy as np\n", + "from qiskit import ClassicalRegister, QuantumCircuit, QuantumRegister\n", + "from qiskit.visualization import plot_histogram\n", + "\n", + "from qiskit_quantuminspire.qi_provider import QIProvider" + ] + }, + { + "cell_type": "markdown", + "id": "fdeea15e-13be-4451-8745-e0608b0673ef", + "metadata": {}, + "source": [ + "We define the circuit based on the number of qubits and the depth (e.g. the number of iterations of the unit building block)." + ] + }, + { + "cell_type": "code", + "execution_count": 2, + "id": "d2484486-175c-4108-904b-6cb5d2486301", + "metadata": {}, + "outputs": [ + { + "data": { + "image/png": "iVBORw0KGgoAAAANSUhEUgAAA0IAAAFvCAYAAABn83u1AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8hTgPZAAAACXBIWXMAAA9hAAAPYQGoP6dpAABosUlEQVR4nO3deVxU9f4/8NcsrAqyyyayiaCikguaWy4k7plbN7tpll/t5tVbpjetrmaZmpaW3qxfmZp1yVxKc9cwt1Rwyx0QAWVTEQXZmZnz+4OYRAadGWfmwJzX8/HwoXPmLO/jfAbmNZ/P+RyZIAgCiIiIiIiIJEQudgFERERERESWxiBERERERESSwyBERERERESSwyBERERERESSwyBERERERESSwyBERERERESSwyBERERERESSwyBERERERESSwyBERERERESSwyBERERERESSwyBERERERESSwyBERERERESSwyBERERERESSwyBERERERESSwyBERERERESSwyBERERERESSwyBERERERESSwyBERERERESSwyBERERERESSwyBERERERESSwyBERERERESSwyBERERERESSwyBERERERESSwyBERERERESSwyBERERERESSwyBERERERESSwyBERERERESSwyBERERERESSoxS7ACIxJCYmGrR+Xl4eNm/ejGeffRYeHh56bdOpUydjSiMLYRsgIiKSNvYIEekhLy8PX3/9NfLy8sQuhUTCNkBERGRdGISIiIiIiEhyGISIiIiIiEhyGISIiIiIiEhyGISI9ODk5ITY2Fg4OTmJXQqJhG2AiIjIusgEQRDELoLI0gydMcwYnDGsfmMbICIikjb2CBHpoby8HNevX0d5ebnYpZBI2AaIiIisC4MQkR7S0tIwYsQIpKWliV0KiYRtgIiIyLrwhqpWRBAEoKF9W21nB5lMJnYVVkMQBKhKG1YbUDqwDRARkekIggC1Wi12GQZRKBT8XSgCBiFrUl4O1ehxYldhEOWPawF7e7HLsBqq0nJ8H/KC2GUYZGzqd7BxZBsgIiLTUKvV2LRpk9hlGGTEiBFQKvmx3NI4NI6IiIiIiCSHQYiIiIiIiCSHfXBEeggPD0dCQoLYZZCI2AaIiIisC3uEiIiIiIhIchiEiPSQkZGBCRMmICMjQ+xSSCRSbQMqlQap1wtxLjkf51Py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+ap/B8R2QsbOhFrrR059Fk6B3jj54fcWrVMMUmkDREREUsEgRERabq0DteHHvW0wbv8Zinyfal9jOBwAtJ48FM0HRmPf2PlQl1ZYvFYiIiKix8EgREQAAEdvN0AQUJKbDwBwi2iOO5evwSOqBQpSsqAqKdOu22rSYAQN74Y9Y+ahorBErJKJiIiIjCa5a4SISDe3NkHa3iAAqCgsRvi4/ijPv4dru/4aFufo44bOc8ejMD0XsRvnAgDUFSpsHzTL0iUTERERGY1BiEgPdnZ2aNmyJezs7MQuxWwy951E5r6T2sfbBrwFABj221Lsvm9q7JKcfKzxGWnx+sQmhTZAREQkJQxCRHoICgrCunXrxC5DFFueel3sEuoFKbcBIiIia8RrhIiIiIiISHIYhIj0kJSUhG7duiEpKUnsUkgkbANERETWhUGISA+CIKCyshKCIIhdComEbYCIiMi68Boha2JnB+WPa8WuwjC88NyklA52GJv6ndhlGETpwDZARERkKgqFAiNGjDDZ/hZ/uR73iovh1KgRZkwaU+uxKSgUCpPsx1AMQlZEJpMB9vZil0EikslksHFkGyAiIpIqmUwGpdJ0H/EFABqh6m+lUlnrcUPGoXFERERERCQ5DTvGEVlIYGAg4uLi4OfnJ3YpJBK2ASIiIuvCIESkB3t7e4SEhIhdBomIbYCIiMi6cGgckR5ycnLwwQcfICcnR+xSSCRsA0RERNaFQYhIDwUFBdi6dSsKCgrELoVEwjZARERkXRiEiIiIiIhIchiEiIiIiIhIchiEiIiIiIhIcjhrHElSp06dDFrf398fc+bMQb9+/eDj42OmqsiS2AaIiIikjUGISA8+Pj6YO3eu2GWQiNgGiIiIrAuHxhERERERkeQwCBERERERkeQwCBERERERkeQwCBERERERkeQwCBERERERkeQwCBERERERkeQwCBERERERkeQwCBERERERkeQwCBERERERkeQwCBERERERkeQwCBERERERkeQwCBERERERkeQwCFmR+Ph4KBQKhIaGil0KERGRTgcPHsSwYcPQvHlzyGQyfPDBB2KXRBa2ePFidO3aFa6urnBxcUH37t2xa9cuscuyqB07dqB9+/aws7NDYGAgPvnkE7FLsph169ahQ4cOcHV1hYODAyIiIvDJJ59AEASL18IgZCVyc3Mxbtw4PP3002KX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", + "text/plain": [ + "
" + ] + }, + "execution_count": 2, + "metadata": {}, + "output_type": "execute_result" + } + ], + "source": [ + "def pcircuit(nqubits, depth=10):\n", + " \"\"\"Circuit to test performance of quantum computer\"\"\"\n", + " q = QuantumRegister(nqubits)\n", + " ans = ClassicalRegister(nqubits)\n", + " qc = QuantumCircuit(q, ans)\n", + "\n", + " for level in range(depth):\n", + " for qidx in range(nqubits):\n", + " qc.h(q[qidx])\n", + " qc.barrier()\n", + " for qidx in range(nqubits):\n", + " qc.rx(np.pi / 2, q[qidx])\n", + " qc.barrier()\n", + "\n", + " for qidx in range(nqubits):\n", + " if qidx != 0:\n", + " qc.cx(q[qidx], q[0])\n", + " for qidx in range(nqubits):\n", + " qc.measure(q[qidx], ans[qidx])\n", + " return q, qc\n", + "\n", + "\n", + "q, qc = pcircuit(4, 1)\n", + "qc.draw(output=\"mpl\")" + ] + }, + { + "cell_type": "markdown", + "id": "ce37a3ec-3a7d-4328-a039-6eb3eda9750a", + "metadata": {}, + "source": [ + "### Run the cirquit on the Quantum Inspire Platform\n", + "First we make a connection to the Quantum Inspire platform and choose a backend." + ] + }, + { + "cell_type": "code", + "execution_count": 3, + "id": "2372a97f-174f-463d-91b5-8a85b32de97a", + "metadata": {}, + "outputs": [], + "source": [ + "provider = QIProvider()\n", + "backend = provider.get_backend(name=\"QX emulator\")" + ] + }, + { + "cell_type": "markdown", + "id": "174e22b9-cdd8-419a-aac4-a4840bab1b41", + "metadata": {}, + "source": [ + "We run the job for a certain amount of shots in the chosen backend and wait for the results." + ] + }, + { + "cell_type": "code", + "execution_count": 27, + "id": "36e01187-eccd-4dde-b385-65337e4aefb6", + "metadata": {}, + "outputs": [], + "source": [ + "job = backend.run(qc, shots=1024)\n", + "results = job.result(wait_for_results=True)" + ] + }, + { + "cell_type": "markdown", + "id": "bde69940-3e85-4a96-9fc5-c3caf0dfcefd", + "metadata": {}, + "source": [ + "We visualize the histogram with matplotlib." + ] + }, + { + "cell_type": "code", + "execution_count": 28, + "id": "0eae2daa-4f3d-450f-a2cd-8767d31603e0", + "metadata": {}, + "outputs": [ + { + "data": { + "image/png": "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ssSm+yUiIiJ1suicG0v3OsnKylLsxFciIiKiwrCo8vDx8cG5c+cKffy5c+fwzDPPWNwpIiIiImtZVNy0bdsWe/bswY0bN5547I0bN7Bnzx60a9fO2r4RERERWcyi4mb48OHIyspC3759kZCQkO9x9+7dQ79+/ZCdnY333nvP5k4SERERFZZFJxQ3a9YMo0ePxqJFi1C/fn28++676NixI5599lkAwO3bt7F7924sW7YMd+/exdixY0025CMiIiIqahZvMzl//nyUK1cO8+bNw4wZMzBjxgyT20UEWq0WEyZMMLnoJREREVFxsLi40Wg0mDlzJoYOHYqIiAgcPnzYeNFKLy8vhISE4I033kCtWrUU7ywRERHRk1h9gZBatWpxZYaIiIhKHG5CQ0RERKrC4oaIiIhUhcUNERERqQqLGyIiIlIVFjdERESkKixuiIiISFVY3BAREZGqsLghIiIiVWFxQ0RERKrC4oaIiIhUhcUNERERqQqLGyIiIlIVFjdERESkKixuiIiISFVY3BAREZGqsLghIiIiVWFxQ0RERKrC4oaIiIhUhcUNERERqQqLGyIiIlIVFjdERESkKixuiIiISFVY3BAREZGqsLghIiIiVWFxQ0RERKrC4oaIiIhUhcUNERERqQqLGyIiIlIVFjdERESkKixuiIiISFVY3BAREZGqsLghIiIiVWFxQ0RERKrC4oaIiIhUhcUNERERqQqLGyIiIlIVFjdERESkKixuiIiISFVY3BAREZGqsLghIiIiVWFxQ0RERKrC4oaIiIhUhcUNERERqQqLGyIiIlIVFjdERESkKixuiIiISFVY3BAREZGqsLghIiIiVWFxQ0RERKrC4oaIiIhUhcUNERERqQqLGyIiIlIVFjdERESkKixuiIiISFVY3BAREZGqsLghIiIiVWFxQ0RERKrC4oaIiIhUhcUNERERqQqLGyIiIlIVFjdERESkKixuiIiISFVY3BAREZGqsLghIiIiVWFxQ0RERKpS4oqbWbNmoWXLlnBxcUG1atXQu3dvXLp0yeSY9PR0DB8+HO7u7qhYsSL69OmD+Ph4O/WYiIiISpISV9zs378fw4cPx5EjR/Dbb78hKysLnTt3RmpqqvGYMWPGYNOmTVi3bh3279+P2NhYvPTSS3bsNREREZUUjvbuwOO2b99u8v8VK1agWrVqOHnyJNq1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RCQzM1OWLl0qLi4u8vvvvyuSJyIybtw4adu2rcyfP18GDx4sbdu2leDgYOnfv798+eWXcunSJTly5IhoNBpJSUlRJPNpGeeSJUskMDDQWMRlZGRIZmam8fYtW7aIu7u7bNq0SZE8EZF//vOf8sILL8iqVatk8uTJ0qVLF6lXr560bNlSPvnkEzl58qQcO3ZM0XGKiLz00ksydOhQkzadTifHjx+XAQMGSK1ateSXX35RLE9EZNCgQVKhQgVp27at9OnTR+bPny9nz541Oebw4cMybNgwxX5B9O3bV95+++087Xfv3pWPPvpIPDw8ZOHChYpk5TZo0CApV66cNG7cWJo3by5jxoyRw4cPmxxz6NAhefnll/MUetayx1jtMc5XXnlFhg0blqc9MzNTFi5cKO7u7jJq1ChFsgwGDRokTk5OUr16dalSpYr07dtXduzYYXLMwYMHJSwsLE+RVxz4tlQx+f3339G3b1/897//RefOnfPcnpmZia5du+If//gHPvjgA0UyBw4ciKpVq2LhwoXIyMjA9u3bsWXLFpw5cwZ6vR41a9bEuXPn4OXlhV27dimSef78eXTq1Alffvkl+vfvb2yXXMuhPXr0QFBQED799FNFMt98801otVp8++23yM7OxpEjR3DgwAGcOnUKsbGxKFeuHKKjo9GwYUNs27ZNkcynZZx//fUXWrdujY8//tjkeZn7HJF+/frB398fc+fOVSRz9OjRePDgAb799ls4ODjgwoULOH36NI4dO4ZTp04hMTERN2/eRLt27bBlyxZFMgGgffv2eOGFFzBp0iQApmNMTk7GsGHDcP36dWzbtg3u7u6KZAYGBiI0NBQeHh44efIk/vrrLzg4OKBWrVro2LEjXnzxRXz22WfYv38//vzzT0Uye/bsierVq+PLL78EkDP3ODg4GM+b+Oijj7Bjxw5s3boVvr6+imQCOW9vdu7cGQ0bNsSJEydw4sQJ/P333/D09ETXrl3Rr18/LFiwAPv378e5c+cUybTHWO0xzkGDBiErKwvff/89ypQpg/T0dGi1WuP5Nl988QWWLl2KDRs2oG7duopktmvXDi+++CJCQ0Nx/PhxbNmyBSdOnED58uXx0ksvYdiwYfj6669x4MAB/PHHH4pkWqTYy6mnVFpamgwaNEjq168v8+bNk6ioKHn48KHx9uTkZHnmmWfk559/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", + "text/plain": [ + "
" + ] + }, + "execution_count": 28, + "metadata": {}, + "output_type": "execute_result" + } + ], + "source": [ + "counts = results.data()[\"counts\"]\n", + "result_map = {}\n", + "for key in counts:\n", + " bin_str = format(int(key, 16), \"04b\")\n", + " result_map[bin_str] = counts[key]\n", + "\n", + "plot_histogram(result_map)" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "id": "9c58d8d6-4dd5-49de-bfa3-6eaad80600ed", + "metadata": {}, + "outputs": [], + "source": [] + } + ], + "metadata": { + "kernelspec": { + "display_name": "Python 3 (ipykernel)", + "language": "python", + "name": "python3" + }, + "language_info": { + "codemirror_mode": { + "name": "ipython", + "version": 3 + }, + "file_extension": ".py", + "mimetype": "text/x-python", + "name": "python", + "nbconvert_exporter": "python", + "pygments_lexer": "ipython3", + "version": "3.12.3" + } + }, + "nbformat": 4, + "nbformat_minor": 5 +} diff --git a/pr-preview/pr-92/_sources/notebooks/Super Dense Coding.ipynb.txt b/pr-preview/pr-92/_sources/notebooks/Super Dense Coding.ipynb.txt new file mode 100644 index 0000000..bf092bb --- /dev/null +++ b/pr-preview/pr-92/_sources/notebooks/Super Dense Coding.ipynb.txt @@ -0,0 +1,267 @@ +{ + "cells": [ + { + "cell_type": "markdown", + "metadata": { + "collapsed": false, + "jupyter": { + "outputs_hidden": false + } + }, + "source": [ + "# Superdense Coding\n", + "This is a port of [this notebook](https://github.com/QuTech-Delft/quantum-inspire-examples/blob/dev/docs/notebooks_action_needed/superdense_coding/superdense_coding.ipynb).\n", + "\n", + "In this notebook, we use the Quantum Inspire to implement the superdense coding algorithm. With this quantum communication protocol, a sender (Bob) can transmit two classical bits of information to a receiver (Alice) using only one qubit. In addition, this method of communication is highly secure against eavesdropping since reading out the state during the communication will collapse the entangled state, indicating the presence of a third party listening.\n" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": { + "ExecuteTime": { + "end_time": "2024-11-20T12:37:04.536147800Z", + "start_time": "2024-11-20T12:37:04.456110900Z" + }, + "collapsed": false, + "jupyter": { + "outputs_hidden": false + } + }, + "outputs": [], + "source": [ + "import matplotlib.pyplot as plt\n", + "from qiskit import QuantumCircuit\n", + "\n", + "from qiskit_quantuminspire.qi_provider import QIProvider" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "We divide the superdense code into four main sections: initilization, encoding, decoding, measurement. Initially, Alice creates the entangled state and sends one qubit to Bob for the encoding step. After the encoding, Bob returns the qubit to Alice, who decodes the message and measures the two qubits.\n", + "\n", + "![Superdense Coding](super_dense_coding.png)" + ] + }, + { + "cell_type": "markdown", + "metadata": { + "collapsed": false, + "jupyter": { + "outputs_hidden": false + } + }, + "source": [ + "### Generate the circuit\n", + "\n", + "The two qubits are initially prepared in the ground state 00. Before sending the qubit to Bob, Alice needs to prepare an entangled state. So, Alice applies a H-gate followed by a CNOT-gate to obtain the desired entangled state (1/sqrt(2))(00 + 11). Now the qubit is ready to be sent to Bob, who encodes the two classical bits of information.\n", + "\n", + "Bob can choose between four gates to apply to the qubit. Each gate will encode a different message for Alice. The four different possibilities are listed in the table below.\n", + "\n", + "| Gates\t | Classical Message |\n", + "|:------:| :------: |\n", + "| I\t | 00 |\n", + "| X\t | 01 |\n", + "| Z\t | 10 |\n", + "| ZX | 11 |\n", + "\n", + "A different Bell state will be encoded for each gate that Bob applies to the qubit. After decoding, each Bell state will result in a different 2-bit message. Remember that the Identity gate doesn't alter the state, and the X and Z gates make the qubit do a pi-rotation over their respective axes.\n", + "\n", + "The different possible states after encoding will then be:\n", + "\n", + "![encoding states](encoding_states.png)\n", + "\n", + "After the encoding step, Bobs sends the qubit back to Alice. To decode the message, Alice applies a CNOT-gate followed by a H-gate, as shown in the first figure. The decoding of the '11' message is: H CNOT (1/sqrt(2))(-10 + 01) = 11" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": { + "ExecuteTime": { + "start_time": "2024-11-20T11:02:48.197216900Z" + }, + "collapsed": false, + "jupyter": { + "outputs_hidden": false + } + }, + "outputs": [], + "source": [ + "def superdense_encoding_circuit(bit_a: int = 0, bit_b: int = 0) -> QuantumCircuit:\n", + " circuit = QuantumCircuit(2, 2)\n", + " qubit_a = 0\n", + " qubit_b = 1\n", + " circuit.reset(qubit_a)\n", + " circuit.reset(qubit_b)\n", + " circuit.measure(qubit_a, qubit_a)\n", + " circuit.measure(qubit_b, qubit_b)\n", + " circuit.ry(1.57079632679, qubit_a)\n", + " circuit.ry(-1.57079632679, qubit_b)\n", + " circuit.cz(qubit_b, qubit_a)\n", + "\n", + " ## apply variable gate\n", + " encode_gate = bit_a + 2**bit_b\n", + " if encode_gate == 0: # identity I\n", + " circuit.id(qubit_a)\n", + " elif encode_gate == 1: # X\n", + " circuit.x(qubit_a)\n", + " elif encode_gate == 2: # Z\n", + " circuit.z(qubit_a)\n", + " elif encode_gate == 3: # Y\n", + " circuit.y(qubit_a)\n", + "\n", + " circuit.cz(qubit_b, qubit_a)\n", + " circuit.ry(-1.57079632679, qubit_a)\n", + " circuit.ry(1.57079632679, qubit_b)\n", + "\n", + " # maximum-likelihood 3 readout (ML3 RO)\n", + " circuit.measure(qubit_b, qubit_a) # in qiskit this measures in z basis\n", + " circuit.measure(qubit_b, qubit_a) # in qiskit this measures in z basis\n", + " circuit.measure(qubit_b, qubit_a) # in qiskit this measures in z basis\n", + "\n", + " return circuit" + ] + }, + { + "cell_type": "markdown", + "metadata": { + "collapsed": false, + "jupyter": { + "outputs_hidden": false + } + }, + "source": [ + "### Run the Circuit in Quantum Inspire Platform\n", + "We generate a circuit for each of the possibilities (00, 01, 10, 11) and then run the circuit in the Quantum Inspire. We connect and choose one of the available backends." + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "provider = QIProvider()\n", + "backend = provider.get_backend(name=\"QX emulator\")" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "We run a job for a certain amount of shots for each combination of classical bits we wish to send. We wait for each result and collect all." + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "result_map = {}\n", + "for bit_a in range(2):\n", + " for bit_b in range(2):\n", + " circuit = superdense_encoding_circuit(bit_a, bit_b)\n", + "\n", + " # if using qxelarator\n", + " # cqasm_string = dumps(circuit)\n", + " # results = execute_string(cqasm_string, iterations=100).results\n", + " # result_map[f'{bit_a}{bit_b}'] = results\n", + "\n", + " # if using thq QI2 Platform\n", + " job = backend.run(circuit, shots=1024)\n", + " results = job.result(wait_for_results=True)\n", + " counts = results.data()[\"counts\"]\n", + " result_counts = {}\n", + " for key in counts:\n", + " bin_str = format(int(key, 16), \"04b\")\n", + " result_counts[bin_str] = counts[key]\n", + "\n", + " result_map[f\"{bit_a}{bit_b}\"] = result_counts" + ] + }, + { + "cell_type": "markdown", + "metadata": { + "collapsed": false, + "jupyter": { + "outputs_hidden": false + } + }, + "source": [ + "### Plot results\n", + "We plot the results of each encoding using matplotlib" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": { + "ExecuteTime": { + "end_time": "2024-11-20T12:50:57.519324200Z", + "start_time": "2024-11-20T12:50:57.462245200Z" + }, + "collapsed": false, + "jupyter": { + "outputs_hidden": false + } + }, + "outputs": [], + "source": [ + "fig, axs = plt.subplots(2, 2, figsize=(8, 6))\n", + "for index, key in enumerate(result_map):\n", + " results = result_map[key]\n", + " entries = list(results.keys())\n", + " occurrences = list(results.values())\n", + " i0 = int(index / 2)\n", + " i1 = index % 2\n", + " axs[i0][i1].bar(entries, occurrences, color=\"skyblue\")\n", + " axs[i0][i1].set_title(f\"Supercoding {key}\")\n", + " axs[i0][i1].set_xlabel(\"Entries\")\n", + " axs[i0][i1].set_ylabel(\"Occurrences\")\n", + "\n", + "# Adjust layout to prevent overlap\n", + "plt.tight_layout()\n", + "\n", + "# Display the plot\n", + "plt.show()" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": { + "collapsed": false, + "jupyter": { + "outputs_hidden": false + } + }, + "outputs": [], + "source": [] + } + ], + "metadata": { + "kernelspec": { + "display_name": "Python 3 (ipykernel)", + "language": "python", + "name": "python3" + }, + "language_info": { + "codemirror_mode": { + "name": "ipython", + "version": 3 + }, + "file_extension": ".py", + "mimetype": "text/x-python", + "name": "python", + "nbconvert_exporter": "python", + "pygments_lexer": "ipython3", + "version": "3.12.3" + } + }, + "nbformat": 4, + "nbformat_minor": 4 +} diff --git a/pr-preview/pr-92/_sources/notebooks/basic_circuit_execution.ipynb.txt b/pr-preview/pr-92/_sources/notebooks/basic_circuit_execution.ipynb.txt new file mode 100644 index 0000000..e802853 --- /dev/null +++ b/pr-preview/pr-92/_sources/notebooks/basic_circuit_execution.ipynb.txt @@ -0,0 +1,155 @@ +{ + "cells": [ + { + "cell_type": "markdown", + "id": "48c6731f-5188-41c1-afc4-123c6ed796ae", + "metadata": {}, + "source": [ + "# Basic circuit execution\n", + "This notebooks illustrates how you can run your qiskit code on the Quantum Inspire 2 platform.\n", + "## This notebook makes the following assumptions:\n", + "- quantuminspire2 sdk installed\n", + "- account exists in the QI2 platform\n", + "- qiskit plugin installed (pip install qiskit-quantuminspire) in the same environment as this notebook" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "id": "93fe4f56-4ced-41fc-b778-14d6c95e2434", + "metadata": {}, + "outputs": [], + "source": [ + "# Be sure to have logged in to the QI2 platform via the SDK. If you have installed it in the same environment as\n", + "# this notebook, you may run this cell.\n", + "\n", + "!qi login \"https://staging.qi2.quantum-inspire.com\"" + ] + }, + { + "cell_type": "markdown", + "id": "0d8ba9f9-9b38-4a86-9252-0b9b9fcdc83f", + "metadata": {}, + "source": [ + "## The necessary imports" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "id": "3d4b3950-fe75-47cf-afb5-2286be7c01b4", + "metadata": {}, + "outputs": [], + "source": [ + "from qiskit import QuantumCircuit\n", + "\n", + "from qiskit_quantuminspire.qi_provider import QIProvider" + ] + }, + { + "cell_type": "markdown", + "id": "0b464f03-9573-4c3c-852c-3ea4477b59ec", + "metadata": {}, + "source": [ + "## What QI Backends are available?" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "id": "df119aa6-6b48-43a5-aa68-ecf4f7c0dc38", + "metadata": {}, + "outputs": [], + "source": [ + "provider = QIProvider()\n", + "\n", + "# Show all current supported backends:\n", + "print(provider.backends())" + ] + }, + { + "cell_type": "markdown", + "id": "a9f9b123-9b11-4d62-a4ab-8af8f08f7153", + "metadata": {}, + "source": [ + "## Create your Qiskit Circuit\n", + "Let's create a bell state circuit." + ] + }, + { + "cell_type": "code", + "execution_count": null, + "id": "e6bbe6af-9908-46cb-8638-8f29966fbf61", + "metadata": {}, + "outputs": [], + "source": [ + "circuit = QuantumCircuit(3, 10)\n", + "circuit.h(0)\n", + "circuit.cx(0, 1)\n", + "circuit.measure(0, 0)\n", + "circuit.measure(1, 1)" + ] + }, + { + "cell_type": "markdown", + "id": "a638262c-c785-4a4f-9ba2-32cc534225f3", + "metadata": {}, + "source": [ + "## Create the Job in the Quantum Inspire Platform\n", + "On the appropriate backend, you run your circuit. Be aware that if your circuit contains gates that are not supported by the target, compilation errors may arise." + ] + }, + { + "cell_type": "code", + "execution_count": null, + "id": "1f446ddc-7fe6-4731-9840-da1775e10e0f", + "metadata": {}, + "outputs": [], + "source": [ + "backend = provider.get_backend(name=\"QX emulator\")\n", + "job = backend.run(circuit, shots=1024)" + ] + }, + { + "cell_type": "markdown", + "id": "9645611e-bd42-4814-9266-243676877e8d", + "metadata": {}, + "source": [ + "## Obtain the result \n", + "After a while the result should be available. Depending on the current load, the time for completion may vary." + ] + }, + { + "cell_type": "code", + "execution_count": null, + "id": "4302f110-e5c1-47ea-8e48-994db317a74c", + "metadata": {}, + "outputs": [], + "source": [ + "result = job.result()\n", + "print(result)" + ] + } + ], + "metadata": { + "kernelspec": { + "display_name": "qiskit-quantuminspire-C0W6c0G_-py3.12", + "language": "python", + "name": "python3" + }, + "language_info": { + "codemirror_mode": { + "name": "ipython", + "version": 3 + }, + "file_extension": ".py", + "mimetype": "text/x-python", + "name": "python", + "nbconvert_exporter": "python", + "pygments_lexer": "ipython3", + "version": "3.12.5" + } + }, + "nbformat": 4, + "nbformat_minor": 5 +} diff --git a/pr-preview/pr-92/_sources/notebooks/index.rst.txt b/pr-preview/pr-92/_sources/notebooks/index.rst.txt new file mode 100644 index 0000000..1424548 --- /dev/null +++ b/pr-preview/pr-92/_sources/notebooks/index.rst.txt @@ -0,0 +1,9 @@ +================= +Example notebooks +================= + +.. toctree:: + :maxdepth: 1 + :glob: + + * diff --git a/pr-preview/pr-92/_static/basic.css b/pr-preview/pr-92/_static/basic.css new file mode 100644 index 0000000..7ebbd6d --- /dev/null +++ b/pr-preview/pr-92/_static/basic.css @@ -0,0 +1,914 @@ +/* + * 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; + } +} \ No newline at end of file diff --git a/pr-preview/pr-92/_static/debug.css b/pr-preview/pr-92/_static/debug.css new file mode 100644 index 0000000..74d4aec --- /dev/null +++ b/pr-preview/pr-92/_static/debug.css @@ -0,0 +1,69 @@ +/* + This CSS file should be overridden by the theme authors. It's + meant for debugging and developing the skeleton that this theme provides. +*/ +body { + font-family: -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif, + "Apple Color Emoji", "Segoe UI Emoji"; + background: lavender; +} +.sb-announcement { + background: rgb(131, 131, 131); +} +.sb-announcement__inner { + background: black; + color: white; +} +.sb-header { + background: lightskyblue; +} +.sb-header__inner { + background: royalblue; + color: white; +} +.sb-header-secondary { + background: lightcyan; +} +.sb-header-secondary__inner { + background: cornflowerblue; + color: white; +} +.sb-sidebar-primary { + background: lightgreen; +} +.sb-main { + background: blanchedalmond; +} +.sb-main__inner { + background: antiquewhite; +} +.sb-header-article { + background: lightsteelblue; +} +.sb-article-container { + background: snow; +} +.sb-article-main { + background: white; +} +.sb-footer-article { + background: lightpink; +} +.sb-sidebar-secondary { + background: lightgoldenrodyellow; +} +.sb-footer-content { + background: plum; +} +.sb-footer-content__inner { + background: palevioletred; +} +.sb-footer { + background: pink; +} +.sb-footer__inner { + background: salmon; +} +.sb-article { + background: white; +} diff --git a/pr-preview/pr-92/_static/doctools.js b/pr-preview/pr-92/_static/doctools.js new file mode 100644 index 0000000..0398ebb --- /dev/null +++ b/pr-preview/pr-92/_static/doctools.js @@ -0,0 +1,149 @@ +/* + * 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); diff --git a/pr-preview/pr-92/_static/documentation_options.js b/pr-preview/pr-92/_static/documentation_options.js new file mode 100644 index 0000000..13d90ff --- /dev/null +++ b/pr-preview/pr-92/_static/documentation_options.js @@ -0,0 +1,13 @@ +const DOCUMENTATION_OPTIONS = { + VERSION: '0.1.0', + 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, +}; \ No newline at end of file diff --git a/pr-preview/pr-92/_static/file.png b/pr-preview/pr-92/_static/file.png new file mode 100644 index 0000000..a858a41 Binary files /dev/null and b/pr-preview/pr-92/_static/file.png differ diff --git a/pr-preview/pr-92/_static/images/logo.png b/pr-preview/pr-92/_static/images/logo.png new file mode 100644 index 0000000..769ddee Binary files /dev/null and b/pr-preview/pr-92/_static/images/logo.png differ diff --git a/pr-preview/pr-92/_static/language_data.js b/pr-preview/pr-92/_static/language_data.js new file mode 100644 index 0000000..c7fe6c6 --- /dev/null +++ b/pr-preview/pr-92/_static/language_data.js @@ -0,0 +1,192 @@ +/* + * 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; + } +} + diff --git a/pr-preview/pr-92/_static/minus.png b/pr-preview/pr-92/_static/minus.png new file mode 100644 index 0000000..d96755f Binary files /dev/null and b/pr-preview/pr-92/_static/minus.png differ diff --git a/pr-preview/pr-92/_static/mystnb.4510f1fc1dee50b3e5859aac5469c37c29e427902b24a333a5f9fcb2f0b3ac41.css b/pr-preview/pr-92/_static/mystnb.4510f1fc1dee50b3e5859aac5469c37c29e427902b24a333a5f9fcb2f0b3ac41.css new file mode 100644 index 0000000..3356631 --- /dev/null +++ b/pr-preview/pr-92/_static/mystnb.4510f1fc1dee50b3e5859aac5469c37c29e427902b24a333a5f9fcb2f0b3ac41.css @@ -0,0 +1,2342 @@ +/* Variables */ +:root { + --mystnb-source-bg-color: #f7f7f7; + --mystnb-stdout-bg-color: #fcfcfc; + --mystnb-stderr-bg-color: #fdd; + --mystnb-traceback-bg-color: #fcfcfc; + --mystnb-source-border-color: #ccc; + --mystnb-source-margin-color: green; + --mystnb-stdout-border-color: #f7f7f7; + --mystnb-stderr-border-color: #f7f7f7; + --mystnb-traceback-border-color: #ffd6d6; + --mystnb-hide-prompt-opacity: 70%; + --mystnb-source-border-radius: .4em; + --mystnb-source-border-width: 1px; +} + +/* Whole cell */ +div.container.cell { + padding-left: 0; + margin-bottom: 1em; +} + +/* Removing all background formatting so we can control at the div level */ +.cell_input div.highlight, +.cell_output pre, +.cell_input pre, +.cell_output .output { + border: none; + box-shadow: none; +} + +.cell_output .output pre, +.cell_input pre { + margin: 0px; +} + +/* Input cells */ +div.cell div.cell_input, +div.cell details.above-input>summary { + padding-left: 0em; + padding-right: 0em; + border: var(--mystnb-source-border-width) var(--mystnb-source-border-color) solid; + background-color: var(--mystnb-source-bg-color); + border-left-color: var(--mystnb-source-margin-color); + border-left-width: medium; + border-radius: var(--mystnb-source-border-radius); +} + +div.cell_input>div, +div.cell_output div.output>div.highlight { + margin: 0em !important; + border: none !important; +} + +/* All cell outputs */ +.cell_output { + padding-left: 1em; + padding-right: 0em; + margin-top: 1em; +} + +/* Text outputs from cells */ +.cell_output .output.text_plain, +.cell_output .output.traceback, +.cell_output .output.stream, +.cell_output .output.stderr { + margin-top: 1em; + margin-bottom: 0em; + box-shadow: none; +} + +.cell_output .output.text_plain, +.cell_output .output.stream { + background: var(--mystnb-stdout-bg-color); + border: 1px solid var(--mystnb-stdout-border-color); +} + +.cell_output .output.stderr { + background: var(--mystnb-stderr-bg-color); + border: 1px solid var(--mystnb-stderr-border-color); +} + +.cell_output .output.traceback { + background: var(--mystnb-traceback-bg-color); + border: 1px solid var(--mystnb-traceback-border-color); +} + +/* Collapsible cell content */ +div.cell details.above-input div.cell_input { + border-top-left-radius: 0; + border-top-right-radius: 0; + border-top: var(--mystnb-source-border-width) var(--mystnb-source-border-color) dashed; +} + +div.cell div.cell_input.above-output-prompt { + border-bottom-left-radius: 0; + border-bottom-right-radius: 0; +} + +div.cell details.above-input>summary { + border-bottom-left-radius: 0; + border-bottom-right-radius: 0; + border-bottom: var(--mystnb-source-border-width) var(--mystnb-source-border-color) dashed; + padding-left: 1em; + margin-bottom: 0; +} + +div.cell details.above-output>summary { + background-color: var(--mystnb-source-bg-color); + padding-left: 1em; + padding-right: 0em; + border: var(--mystnb-source-border-width) var(--mystnb-source-border-color) solid; + border-radius: var(--mystnb-source-border-radius); + border-left-color: var(--mystnb-source-margin-color); + border-left-width: medium; +} + +div.cell details.below-input>summary { + background-color: var(--mystnb-source-bg-color); + padding-left: 1em; + padding-right: 0em; + border: var(--mystnb-source-border-width) var(--mystnb-source-border-color) solid; + border-top: none; + border-bottom-left-radius: var(--mystnb-source-border-radius); + border-bottom-right-radius: var(--mystnb-source-border-radius); + border-left-color: var(--mystnb-source-margin-color); + border-left-width: medium; +} + +div.cell details.hide>summary>span { + opacity: var(--mystnb-hide-prompt-opacity); +} + +div.cell details.hide[open]>summary>span.collapsed { + display: none; +} + +div.cell details.hide:not([open])>summary>span.expanded { + display: none; +} + +@keyframes collapsed-fade-in { + 0% { + opacity: 0; + } + + 100% { + opacity: 1; + } +} +div.cell details.hide[open]>summary~* { + -moz-animation: collapsed-fade-in 0.3s ease-in-out; + -webkit-animation: collapsed-fade-in 0.3s ease-in-out; + animation: collapsed-fade-in 0.3s ease-in-out; +} + +/* Math align to the left */ +.cell_output .MathJax_Display { + text-align: left !important; +} + +/* Pandas tables. Pulled from the Jupyter / nbsphinx CSS */ +div.cell_output table { + border: none; + border-collapse: collapse; + border-spacing: 0; + color: black; + font-size: 1em; + table-layout: fixed; +} + +div.cell_output thead { + border-bottom: 1px solid black; + vertical-align: bottom; +} + +div.cell_output tr, +div.cell_output th, +div.cell_output td { + text-align: right; + vertical-align: middle; + padding: 0.5em 0.5em; + line-height: normal; + white-space: normal; + max-width: none; + border: none; +} + +div.cell_output th { + font-weight: bold; +} + +div.cell_output tbody tr:nth-child(odd) { + background: #f5f5f5; +} + +div.cell_output tbody tr:hover { + background: rgba(66, 165, 245, 0.2); +} + +/** source code line numbers **/ +span.linenos { + opacity: 0.5; +} + +/* Inline text from `paste` operation */ + +span.pasted-text { + font-weight: bold; +} + +span.pasted-inline img { + max-height: 2em; +} + +tbody span.pasted-inline img { + max-height: none; +} + +/* Font colors for translated ANSI escape sequences +Color values are copied from Jupyter Notebook +https://github.com/jupyter/notebook/blob/52581f8eda9b319eb0390ac77fe5903c38f81e3e/notebook/static/notebook/less/ansicolors.less#L14-L21 +Background colors from +https://nbsphinx.readthedocs.io/en/latest/code-cells.html#ANSI-Colors +*/ +div.highlight .-Color-Bold { + font-weight: bold; +} + +div.highlight .-Color[class*=-Black] { + color: #3E424D +} + +div.highlight .-Color[class*=-Red] { + color: #E75C58 +} + +div.highlight .-Color[class*=-Green] { + color: #00A250 +} + +div.highlight .-Color[class*=-Yellow] { + color: #DDB62B +} + +div.highlight .-Color[class*=-Blue] { + color: #208FFB +} + +div.highlight .-Color[class*=-Magenta] { + color: #D160C4 +} + +div.highlight .-Color[class*=-Cyan] { + color: #60C6C8 +} + +div.highlight .-Color[class*=-White] { + color: #C5C1B4 +} + +div.highlight .-Color[class*=-BGBlack] { + background-color: #3E424D +} + +div.highlight .-Color[class*=-BGRed] { + background-color: #E75C58 +} + +div.highlight .-Color[class*=-BGGreen] { + background-color: #00A250 +} + +div.highlight .-Color[class*=-BGYellow] { + background-color: #DDB62B +} + +div.highlight .-Color[class*=-BGBlue] { + background-color: #208FFB +} + +div.highlight .-Color[class*=-BGMagenta] { + background-color: #D160C4 +} + +div.highlight .-Color[class*=-BGCyan] { + background-color: #60C6C8 +} + +div.highlight .-Color[class*=-BGWhite] { + background-color: #C5C1B4 +} + +/* Font colors for 8-bit ANSI */ + +div.highlight .-Color[class*=-C0] { + color: #000000 +} + +div.highlight .-Color[class*=-BGC0] { + background-color: #000000 +} + +div.highlight .-Color[class*=-C1] { + color: #800000 +} + +div.highlight .-Color[class*=-BGC1] { + background-color: #800000 +} + +div.highlight .-Color[class*=-C2] { + color: #008000 +} + +div.highlight .-Color[class*=-BGC2] { + background-color: #008000 +} + +div.highlight .-Color[class*=-C3] { + color: #808000 +} + +div.highlight .-Color[class*=-BGC3] { + background-color: #808000 +} + +div.highlight .-Color[class*=-C4] { + color: #000080 +} + +div.highlight .-Color[class*=-BGC4] { + background-color: #000080 +} + +div.highlight .-Color[class*=-C5] { + color: #800080 +} + +div.highlight .-Color[class*=-BGC5] { + background-color: #800080 +} + +div.highlight .-Color[class*=-C6] { + color: #008080 +} + +div.highlight .-Color[class*=-BGC6] { + background-color: #008080 +} + +div.highlight .-Color[class*=-C7] { + color: #C0C0C0 +} + +div.highlight .-Color[class*=-BGC7] { + background-color: #C0C0C0 +} + +div.highlight .-Color[class*=-C8] { + color: #808080 +} + +div.highlight .-Color[class*=-BGC8] { + background-color: #808080 +} + +div.highlight .-Color[class*=-C9] { + color: #FF0000 +} + +div.highlight .-Color[class*=-BGC9] { + background-color: #FF0000 +} + +div.highlight .-Color[class*=-C10] { + color: #00FF00 +} + +div.highlight .-Color[class*=-BGC10] { + background-color: #00FF00 +} + +div.highlight .-Color[class*=-C11] { + color: #FFFF00 +} + +div.highlight .-Color[class*=-BGC11] { + background-color: #FFFF00 +} + +div.highlight .-Color[class*=-C12] { + color: #0000FF +} + +div.highlight .-Color[class*=-BGC12] { + background-color: #0000FF +} + +div.highlight .-Color[class*=-C13] { + color: #FF00FF +} + +div.highlight .-Color[class*=-BGC13] { + background-color: #FF00FF +} + +div.highlight .-Color[class*=-C14] { + color: #00FFFF +} + +div.highlight .-Color[class*=-BGC14] { + background-color: #00FFFF +} + +div.highlight .-Color[class*=-C15] { + color: #FFFFFF +} + +div.highlight .-Color[class*=-BGC15] { + background-color: #FFFFFF +} + +div.highlight .-Color[class*=-C16] { + color: #000000 +} + +div.highlight .-Color[class*=-BGC16] { + background-color: #000000 +} + +div.highlight .-Color[class*=-C17] { + color: #00005F +} + +div.highlight .-Color[class*=-BGC17] { + background-color: #00005F +} + +div.highlight .-Color[class*=-C18] { + color: #000087 +} + +div.highlight .-Color[class*=-BGC18] { + background-color: #000087 +} + +div.highlight .-Color[class*=-C19] { + color: #0000AF +} + +div.highlight .-Color[class*=-BGC19] { + background-color: #0000AF +} + +div.highlight .-Color[class*=-C20] { + color: #0000D7 +} + +div.highlight .-Color[class*=-BGC20] { + background-color: #0000D7 +} + +div.highlight .-Color[class*=-C21] { + color: #0000FF +} + +div.highlight .-Color[class*=-BGC21] { + background-color: #0000FF +} + +div.highlight .-Color[class*=-C22] { + color: #005F00 +} + +div.highlight .-Color[class*=-BGC22] { + background-color: #005F00 +} + +div.highlight .-Color[class*=-C23] { + color: #005F5F +} + +div.highlight .-Color[class*=-BGC23] { + background-color: #005F5F +} + +div.highlight .-Color[class*=-C24] { + color: #005F87 +} + +div.highlight .-Color[class*=-BGC24] { + background-color: #005F87 +} + +div.highlight .-Color[class*=-C25] { + color: #005FAF +} + +div.highlight .-Color[class*=-BGC25] { + background-color: #005FAF +} + +div.highlight .-Color[class*=-C26] { + color: #005FD7 +} + +div.highlight .-Color[class*=-BGC26] { + background-color: #005FD7 +} + +div.highlight .-Color[class*=-C27] { + color: #005FFF +} + +div.highlight .-Color[class*=-BGC27] { + background-color: #005FFF +} + +div.highlight .-Color[class*=-C28] { + color: #008700 +} + +div.highlight .-Color[class*=-BGC28] { + background-color: #008700 +} + +div.highlight .-Color[class*=-C29] { + color: #00875F +} + +div.highlight .-Color[class*=-BGC29] { + background-color: #00875F +} + +div.highlight .-Color[class*=-C30] { + color: #008787 +} + +div.highlight .-Color[class*=-BGC30] { + background-color: #008787 +} + +div.highlight .-Color[class*=-C31] { + color: #0087AF +} + +div.highlight .-Color[class*=-BGC31] { + background-color: #0087AF +} + +div.highlight .-Color[class*=-C32] { + color: #0087D7 +} + +div.highlight .-Color[class*=-BGC32] { + background-color: #0087D7 +} + +div.highlight .-Color[class*=-C33] { + color: #0087FF +} + +div.highlight .-Color[class*=-BGC33] { + background-color: #0087FF +} + +div.highlight .-Color[class*=-C34] { + color: #00AF00 +} + +div.highlight .-Color[class*=-BGC34] { + background-color: #00AF00 +} + +div.highlight .-Color[class*=-C35] { + color: #00AF5F +} + +div.highlight .-Color[class*=-BGC35] { + background-color: #00AF5F +} + +div.highlight .-Color[class*=-C36] { + color: #00AF87 +} + +div.highlight .-Color[class*=-BGC36] { + background-color: #00AF87 +} + +div.highlight .-Color[class*=-C37] { + color: #00AFAF +} + +div.highlight .-Color[class*=-BGC37] { + background-color: #00AFAF +} + +div.highlight .-Color[class*=-C38] { + color: #00AFD7 +} + +div.highlight .-Color[class*=-BGC38] { + background-color: #00AFD7 +} + +div.highlight .-Color[class*=-C39] { + color: #00AFFF +} + +div.highlight .-Color[class*=-BGC39] { + background-color: #00AFFF +} + +div.highlight .-Color[class*=-C40] { + color: #00D700 +} + +div.highlight .-Color[class*=-BGC40] { + background-color: #00D700 +} + +div.highlight .-Color[class*=-C41] { + color: #00D75F +} + +div.highlight .-Color[class*=-BGC41] { + background-color: #00D75F +} + +div.highlight .-Color[class*=-C42] { + color: #00D787 +} + +div.highlight .-Color[class*=-BGC42] { + background-color: #00D787 +} + +div.highlight .-Color[class*=-C43] { + color: #00D7AF +} + +div.highlight .-Color[class*=-BGC43] { + background-color: #00D7AF +} + +div.highlight .-Color[class*=-C44] { + color: #00D7D7 +} + +div.highlight .-Color[class*=-BGC44] { + background-color: #00D7D7 +} + +div.highlight .-Color[class*=-C45] { + color: #00D7FF +} + +div.highlight .-Color[class*=-BGC45] { + background-color: #00D7FF +} + +div.highlight .-Color[class*=-C46] { + color: #00FF00 +} + +div.highlight .-Color[class*=-BGC46] { + background-color: #00FF00 +} + +div.highlight .-Color[class*=-C47] { + color: #00FF5F +} + +div.highlight .-Color[class*=-BGC47] { + background-color: #00FF5F +} + +div.highlight .-Color[class*=-C48] { + color: #00FF87 +} + +div.highlight .-Color[class*=-BGC48] { + background-color: #00FF87 +} + +div.highlight .-Color[class*=-C49] { + color: #00FFAF +} + +div.highlight .-Color[class*=-BGC49] { + background-color: #00FFAF +} + +div.highlight .-Color[class*=-C50] { + color: #00FFD7 +} + +div.highlight .-Color[class*=-BGC50] { + background-color: #00FFD7 +} + +div.highlight .-Color[class*=-C51] { + color: #00FFFF +} + +div.highlight .-Color[class*=-BGC51] { + background-color: #00FFFF +} + +div.highlight .-Color[class*=-C52] { + color: #5F0000 +} + +div.highlight .-Color[class*=-BGC52] { + background-color: #5F0000 +} + +div.highlight .-Color[class*=-C53] { + color: #5F005F +} + +div.highlight .-Color[class*=-BGC53] { + background-color: #5F005F +} + +div.highlight .-Color[class*=-C54] { + color: #5F0087 +} + +div.highlight .-Color[class*=-BGC54] { + background-color: #5F0087 +} + +div.highlight .-Color[class*=-C55] { + color: #5F00AF +} + +div.highlight .-Color[class*=-BGC55] { + background-color: #5F00AF +} + +div.highlight .-Color[class*=-C56] { + color: #5F00D7 +} + +div.highlight .-Color[class*=-BGC56] { + background-color: #5F00D7 +} + +div.highlight .-Color[class*=-C57] { + color: #5F00FF +} + +div.highlight .-Color[class*=-BGC57] { + background-color: #5F00FF +} + +div.highlight .-Color[class*=-C58] { + color: #5F5F00 +} + +div.highlight .-Color[class*=-BGC58] { + background-color: #5F5F00 +} + +div.highlight .-Color[class*=-C59] { + color: #5F5F5F +} + +div.highlight .-Color[class*=-BGC59] { + background-color: #5F5F5F +} + +div.highlight .-Color[class*=-C60] { + color: #5F5F87 +} + +div.highlight .-Color[class*=-BGC60] { + background-color: #5F5F87 +} + +div.highlight .-Color[class*=-C61] { + color: #5F5FAF +} + +div.highlight .-Color[class*=-BGC61] { + background-color: #5F5FAF +} + +div.highlight .-Color[class*=-C62] { + color: #5F5FD7 +} + +div.highlight .-Color[class*=-BGC62] { + background-color: #5F5FD7 +} + +div.highlight .-Color[class*=-C63] { + color: #5F5FFF +} + +div.highlight .-Color[class*=-BGC63] { + background-color: #5F5FFF +} + +div.highlight .-Color[class*=-C64] { + color: #5F8700 +} + +div.highlight .-Color[class*=-BGC64] { + background-color: #5F8700 +} + +div.highlight .-Color[class*=-C65] { + color: #5F875F +} + +div.highlight .-Color[class*=-BGC65] { + background-color: #5F875F +} + +div.highlight .-Color[class*=-C66] { + color: #5F8787 +} + +div.highlight .-Color[class*=-BGC66] { + background-color: #5F8787 +} + +div.highlight .-Color[class*=-C67] { + color: #5F87AF +} + +div.highlight .-Color[class*=-BGC67] { + background-color: #5F87AF +} + +div.highlight .-Color[class*=-C68] { + color: #5F87D7 +} + +div.highlight .-Color[class*=-BGC68] { + background-color: #5F87D7 +} + +div.highlight .-Color[class*=-C69] { + color: #5F87FF +} + +div.highlight .-Color[class*=-BGC69] { + background-color: #5F87FF +} + +div.highlight .-Color[class*=-C70] { + color: #5FAF00 +} + +div.highlight .-Color[class*=-BGC70] { + background-color: #5FAF00 +} + +div.highlight .-Color[class*=-C71] { + color: #5FAF5F +} + +div.highlight .-Color[class*=-BGC71] { + background-color: #5FAF5F +} + +div.highlight .-Color[class*=-C72] { + color: #5FAF87 +} + +div.highlight .-Color[class*=-BGC72] { + background-color: #5FAF87 +} + +div.highlight .-Color[class*=-C73] { + color: #5FAFAF +} + +div.highlight .-Color[class*=-BGC73] { + background-color: #5FAFAF +} + +div.highlight .-Color[class*=-C74] { + color: #5FAFD7 +} + +div.highlight .-Color[class*=-BGC74] { + background-color: #5FAFD7 +} + +div.highlight .-Color[class*=-C75] { + color: #5FAFFF +} + +div.highlight .-Color[class*=-BGC75] { + background-color: #5FAFFF +} + +div.highlight .-Color[class*=-C76] { + color: #5FD700 +} + +div.highlight .-Color[class*=-BGC76] { + background-color: #5FD700 +} + +div.highlight .-Color[class*=-C77] { + color: #5FD75F +} + +div.highlight .-Color[class*=-BGC77] { + background-color: #5FD75F +} + +div.highlight .-Color[class*=-C78] { + color: #5FD787 +} + +div.highlight .-Color[class*=-BGC78] { + background-color: #5FD787 +} + +div.highlight .-Color[class*=-C79] { + color: #5FD7AF +} + +div.highlight .-Color[class*=-BGC79] { + background-color: #5FD7AF +} + +div.highlight .-Color[class*=-C80] { + color: #5FD7D7 +} + +div.highlight .-Color[class*=-BGC80] { + background-color: #5FD7D7 +} + +div.highlight .-Color[class*=-C81] { + color: #5FD7FF +} + +div.highlight .-Color[class*=-BGC81] { + background-color: #5FD7FF +} + +div.highlight .-Color[class*=-C82] { + color: #5FFF00 +} + +div.highlight .-Color[class*=-BGC82] { + background-color: #5FFF00 +} + +div.highlight .-Color[class*=-C83] { + color: #5FFF5F +} + +div.highlight .-Color[class*=-BGC83] { + background-color: #5FFF5F +} + +div.highlight .-Color[class*=-C84] { + color: #5FFF87 +} + +div.highlight .-Color[class*=-BGC84] { + background-color: #5FFF87 +} + +div.highlight .-Color[class*=-C85] { + color: #5FFFAF +} + +div.highlight .-Color[class*=-BGC85] { + background-color: #5FFFAF +} + +div.highlight .-Color[class*=-C86] { + color: #5FFFD7 +} + +div.highlight .-Color[class*=-BGC86] { + background-color: #5FFFD7 +} + +div.highlight .-Color[class*=-C87] { + color: #5FFFFF +} + +div.highlight .-Color[class*=-BGC87] { + background-color: #5FFFFF +} + +div.highlight .-Color[class*=-C88] { + color: #870000 +} + +div.highlight .-Color[class*=-BGC88] { + background-color: #870000 +} + +div.highlight .-Color[class*=-C89] { + color: #87005F +} + +div.highlight .-Color[class*=-BGC89] { + background-color: #87005F +} + +div.highlight .-Color[class*=-C90] { + color: #870087 +} + +div.highlight .-Color[class*=-BGC90] { + background-color: #870087 +} + +div.highlight .-Color[class*=-C91] { + color: #8700AF +} + +div.highlight .-Color[class*=-BGC91] { + background-color: #8700AF +} + +div.highlight .-Color[class*=-C92] { + color: #8700D7 +} + +div.highlight .-Color[class*=-BGC92] { + background-color: #8700D7 +} + +div.highlight .-Color[class*=-C93] { + color: #8700FF +} + +div.highlight .-Color[class*=-BGC93] { + background-color: #8700FF +} + +div.highlight .-Color[class*=-C94] { + color: #875F00 +} + +div.highlight .-Color[class*=-BGC94] { + background-color: #875F00 +} + +div.highlight .-Color[class*=-C95] { + color: #875F5F +} + +div.highlight .-Color[class*=-BGC95] { + background-color: #875F5F +} + +div.highlight .-Color[class*=-C96] { + color: #875F87 +} + +div.highlight .-Color[class*=-BGC96] { + background-color: #875F87 +} + +div.highlight .-Color[class*=-C97] { + color: #875FAF +} + +div.highlight .-Color[class*=-BGC97] { + background-color: #875FAF +} + +div.highlight .-Color[class*=-C98] { + color: #875FD7 +} + +div.highlight .-Color[class*=-BGC98] { + background-color: #875FD7 +} + +div.highlight .-Color[class*=-C99] { + color: #875FFF +} + +div.highlight .-Color[class*=-BGC99] { + background-color: #875FFF +} + +div.highlight .-Color[class*=-C100] { + color: #878700 +} + +div.highlight .-Color[class*=-BGC100] { + background-color: #878700 +} + +div.highlight .-Color[class*=-C101] { + color: #87875F +} + +div.highlight .-Color[class*=-BGC101] { + background-color: #87875F +} + +div.highlight .-Color[class*=-C102] { + color: #878787 +} + +div.highlight .-Color[class*=-BGC102] { + background-color: #878787 +} + +div.highlight .-Color[class*=-C103] { + color: #8787AF +} + +div.highlight .-Color[class*=-BGC103] { + background-color: #8787AF +} + +div.highlight .-Color[class*=-C104] { + color: #8787D7 +} + +div.highlight .-Color[class*=-BGC104] { + background-color: #8787D7 +} + +div.highlight .-Color[class*=-C105] { + color: #8787FF +} + +div.highlight .-Color[class*=-BGC105] { + background-color: #8787FF +} + +div.highlight .-Color[class*=-C106] { + color: #87AF00 +} + +div.highlight .-Color[class*=-BGC106] { + background-color: #87AF00 +} + +div.highlight .-Color[class*=-C107] { + color: #87AF5F +} + +div.highlight .-Color[class*=-BGC107] { + background-color: #87AF5F +} + +div.highlight .-Color[class*=-C108] { + color: #87AF87 +} + +div.highlight .-Color[class*=-BGC108] { + background-color: #87AF87 +} + +div.highlight .-Color[class*=-C109] { + color: #87AFAF +} + +div.highlight .-Color[class*=-BGC109] { + background-color: #87AFAF +} + +div.highlight .-Color[class*=-C110] { + color: #87AFD7 +} + +div.highlight .-Color[class*=-BGC110] { + background-color: #87AFD7 +} + +div.highlight .-Color[class*=-C111] { + color: #87AFFF +} + +div.highlight .-Color[class*=-BGC111] { + background-color: #87AFFF +} + +div.highlight .-Color[class*=-C112] { + color: #87D700 +} + +div.highlight .-Color[class*=-BGC112] { + background-color: #87D700 +} + +div.highlight .-Color[class*=-C113] { + color: #87D75F +} + +div.highlight .-Color[class*=-BGC113] { + background-color: #87D75F +} + +div.highlight .-Color[class*=-C114] { + color: #87D787 +} + +div.highlight .-Color[class*=-BGC114] { + background-color: #87D787 +} + +div.highlight .-Color[class*=-C115] { + color: #87D7AF +} + +div.highlight .-Color[class*=-BGC115] { + background-color: #87D7AF +} + +div.highlight .-Color[class*=-C116] { + color: #87D7D7 +} + +div.highlight .-Color[class*=-BGC116] { + background-color: #87D7D7 +} + +div.highlight .-Color[class*=-C117] { + color: #87D7FF +} + +div.highlight .-Color[class*=-BGC117] { + background-color: #87D7FF +} + +div.highlight .-Color[class*=-C118] { + color: #87FF00 +} + +div.highlight .-Color[class*=-BGC118] { + background-color: #87FF00 +} + +div.highlight .-Color[class*=-C119] { + color: #87FF5F +} + +div.highlight .-Color[class*=-BGC119] { + background-color: #87FF5F +} + +div.highlight .-Color[class*=-C120] { + color: #87FF87 +} + +div.highlight .-Color[class*=-BGC120] { + background-color: #87FF87 +} + +div.highlight .-Color[class*=-C121] { + color: #87FFAF +} + +div.highlight .-Color[class*=-BGC121] { + background-color: #87FFAF +} + +div.highlight .-Color[class*=-C122] { + color: #87FFD7 +} + +div.highlight .-Color[class*=-BGC122] { + background-color: #87FFD7 +} + +div.highlight .-Color[class*=-C123] { + color: #87FFFF +} + +div.highlight .-Color[class*=-BGC123] { + background-color: #87FFFF +} + +div.highlight .-Color[class*=-C124] { + color: #AF0000 +} + +div.highlight .-Color[class*=-BGC124] { + background-color: #AF0000 +} + +div.highlight .-Color[class*=-C125] { + color: #AF005F +} + +div.highlight .-Color[class*=-BGC125] { + background-color: #AF005F +} + +div.highlight .-Color[class*=-C126] { + color: #AF0087 +} + +div.highlight .-Color[class*=-BGC126] { + background-color: #AF0087 +} + +div.highlight .-Color[class*=-C127] { + color: #AF00AF +} + +div.highlight .-Color[class*=-BGC127] { + background-color: #AF00AF +} + +div.highlight .-Color[class*=-C128] { + color: #AF00D7 +} + +div.highlight .-Color[class*=-BGC128] { + background-color: #AF00D7 +} + +div.highlight .-Color[class*=-C129] { + color: #AF00FF +} + +div.highlight .-Color[class*=-BGC129] { + background-color: #AF00FF +} + +div.highlight .-Color[class*=-C130] { + color: #AF5F00 +} + +div.highlight .-Color[class*=-BGC130] { + background-color: #AF5F00 +} + +div.highlight .-Color[class*=-C131] { + color: #AF5F5F +} + +div.highlight .-Color[class*=-BGC131] { + background-color: #AF5F5F +} + +div.highlight .-Color[class*=-C132] { + color: #AF5F87 +} + +div.highlight .-Color[class*=-BGC132] { + background-color: #AF5F87 +} + +div.highlight .-Color[class*=-C133] { + color: #AF5FAF +} + +div.highlight .-Color[class*=-BGC133] { + background-color: #AF5FAF +} + +div.highlight .-Color[class*=-C134] { + color: #AF5FD7 +} + +div.highlight .-Color[class*=-BGC134] { + background-color: #AF5FD7 +} + +div.highlight .-Color[class*=-C135] { + color: #AF5FFF +} + +div.highlight .-Color[class*=-BGC135] { + background-color: #AF5FFF +} + +div.highlight .-Color[class*=-C136] { + color: #AF8700 +} + +div.highlight .-Color[class*=-BGC136] { + background-color: #AF8700 +} + +div.highlight .-Color[class*=-C137] { + color: #AF875F +} + +div.highlight .-Color[class*=-BGC137] { + background-color: #AF875F +} + +div.highlight .-Color[class*=-C138] { + color: #AF8787 +} + +div.highlight .-Color[class*=-BGC138] { + background-color: #AF8787 +} + +div.highlight .-Color[class*=-C139] { + color: #AF87AF +} + +div.highlight .-Color[class*=-BGC139] { + background-color: #AF87AF +} + +div.highlight .-Color[class*=-C140] { + color: #AF87D7 +} + +div.highlight .-Color[class*=-BGC140] { + background-color: #AF87D7 +} + +div.highlight .-Color[class*=-C141] { + color: #AF87FF +} + +div.highlight .-Color[class*=-BGC141] { + background-color: #AF87FF +} + +div.highlight .-Color[class*=-C142] { + color: #AFAF00 +} + +div.highlight .-Color[class*=-BGC142] { + background-color: #AFAF00 +} + +div.highlight .-Color[class*=-C143] { + color: #AFAF5F +} + +div.highlight .-Color[class*=-BGC143] { + background-color: #AFAF5F +} + +div.highlight .-Color[class*=-C144] { + color: #AFAF87 +} + +div.highlight .-Color[class*=-BGC144] { + background-color: #AFAF87 +} + +div.highlight .-Color[class*=-C145] { + color: #AFAFAF +} + +div.highlight .-Color[class*=-BGC145] { + background-color: #AFAFAF +} + +div.highlight .-Color[class*=-C146] { + color: #AFAFD7 +} + +div.highlight .-Color[class*=-BGC146] { + background-color: #AFAFD7 +} + +div.highlight .-Color[class*=-C147] { + color: #AFAFFF +} + +div.highlight .-Color[class*=-BGC147] { + background-color: #AFAFFF +} + +div.highlight .-Color[class*=-C148] { + color: #AFD700 +} + +div.highlight .-Color[class*=-BGC148] { + background-color: #AFD700 +} + +div.highlight .-Color[class*=-C149] { + color: #AFD75F +} + +div.highlight .-Color[class*=-BGC149] { + background-color: #AFD75F +} + +div.highlight .-Color[class*=-C150] { + color: #AFD787 +} + +div.highlight .-Color[class*=-BGC150] { + background-color: #AFD787 +} + +div.highlight .-Color[class*=-C151] { + color: #AFD7AF +} + +div.highlight .-Color[class*=-BGC151] { + background-color: #AFD7AF +} + +div.highlight .-Color[class*=-C152] { + color: #AFD7D7 +} + +div.highlight .-Color[class*=-BGC152] { + background-color: #AFD7D7 +} + +div.highlight .-Color[class*=-C153] { + color: #AFD7FF +} + +div.highlight .-Color[class*=-BGC153] { + background-color: #AFD7FF +} + +div.highlight .-Color[class*=-C154] { + color: #AFFF00 +} + +div.highlight .-Color[class*=-BGC154] { + background-color: #AFFF00 +} + +div.highlight .-Color[class*=-C155] { + color: #AFFF5F +} + +div.highlight .-Color[class*=-BGC155] { + background-color: #AFFF5F +} + +div.highlight .-Color[class*=-C156] { + color: #AFFF87 +} + +div.highlight .-Color[class*=-BGC156] { + background-color: #AFFF87 +} + +div.highlight .-Color[class*=-C157] { + color: #AFFFAF +} + +div.highlight .-Color[class*=-BGC157] { + background-color: #AFFFAF +} + +div.highlight .-Color[class*=-C158] { + color: #AFFFD7 +} + +div.highlight .-Color[class*=-BGC158] { + background-color: #AFFFD7 +} + +div.highlight .-Color[class*=-C159] { + color: #AFFFFF +} + +div.highlight .-Color[class*=-BGC159] { + background-color: #AFFFFF +} + +div.highlight .-Color[class*=-C160] { + color: #D70000 +} + +div.highlight .-Color[class*=-BGC160] { + background-color: #D70000 +} + +div.highlight .-Color[class*=-C161] { + color: #D7005F +} + +div.highlight .-Color[class*=-BGC161] { + background-color: #D7005F +} + +div.highlight .-Color[class*=-C162] { + color: #D70087 +} + +div.highlight .-Color[class*=-BGC162] { + background-color: #D70087 +} + +div.highlight .-Color[class*=-C163] { + color: #D700AF +} + +div.highlight .-Color[class*=-BGC163] { + background-color: #D700AF +} + +div.highlight .-Color[class*=-C164] { + color: #D700D7 +} + +div.highlight .-Color[class*=-BGC164] { + background-color: #D700D7 +} + +div.highlight .-Color[class*=-C165] { + color: #D700FF +} + +div.highlight .-Color[class*=-BGC165] { + background-color: #D700FF +} + +div.highlight .-Color[class*=-C166] { + color: #D75F00 +} + +div.highlight .-Color[class*=-BGC166] { + background-color: #D75F00 +} + +div.highlight .-Color[class*=-C167] { + color: #D75F5F +} + +div.highlight .-Color[class*=-BGC167] { + background-color: #D75F5F +} + +div.highlight .-Color[class*=-C168] { + color: #D75F87 +} + +div.highlight .-Color[class*=-BGC168] { + background-color: #D75F87 +} + +div.highlight .-Color[class*=-C169] { + color: #D75FAF +} + +div.highlight .-Color[class*=-BGC169] { + background-color: #D75FAF +} + +div.highlight .-Color[class*=-C170] { + color: #D75FD7 +} + +div.highlight .-Color[class*=-BGC170] { + background-color: #D75FD7 +} + +div.highlight .-Color[class*=-C171] { + color: #D75FFF +} + +div.highlight .-Color[class*=-BGC171] { + background-color: #D75FFF +} + +div.highlight .-Color[class*=-C172] { + color: #D78700 +} + +div.highlight .-Color[class*=-BGC172] { + background-color: #D78700 +} + +div.highlight .-Color[class*=-C173] { + color: #D7875F +} + +div.highlight .-Color[class*=-BGC173] { + background-color: #D7875F +} + +div.highlight .-Color[class*=-C174] { + color: #D78787 +} + +div.highlight .-Color[class*=-BGC174] { + background-color: #D78787 +} + +div.highlight .-Color[class*=-C175] { + color: #D787AF +} + +div.highlight .-Color[class*=-BGC175] { + background-color: #D787AF +} + +div.highlight .-Color[class*=-C176] { + color: #D787D7 +} + +div.highlight .-Color[class*=-BGC176] { + background-color: #D787D7 +} + +div.highlight .-Color[class*=-C177] { + color: #D787FF +} + +div.highlight .-Color[class*=-BGC177] { + background-color: #D787FF +} + +div.highlight .-Color[class*=-C178] { + color: #D7AF00 +} + +div.highlight .-Color[class*=-BGC178] { + background-color: #D7AF00 +} + +div.highlight .-Color[class*=-C179] { + color: #D7AF5F +} + +div.highlight .-Color[class*=-BGC179] { + background-color: #D7AF5F +} + +div.highlight .-Color[class*=-C180] { + color: #D7AF87 +} + +div.highlight .-Color[class*=-BGC180] { + background-color: #D7AF87 +} + +div.highlight .-Color[class*=-C181] { + color: #D7AFAF +} + +div.highlight .-Color[class*=-BGC181] { + background-color: #D7AFAF +} + +div.highlight .-Color[class*=-C182] { + color: #D7AFD7 +} + +div.highlight .-Color[class*=-BGC182] { + background-color: #D7AFD7 +} + +div.highlight .-Color[class*=-C183] { + color: #D7AFFF +} + +div.highlight .-Color[class*=-BGC183] { + background-color: #D7AFFF +} + +div.highlight .-Color[class*=-C184] { + color: #D7D700 +} + +div.highlight .-Color[class*=-BGC184] { + background-color: #D7D700 +} + +div.highlight .-Color[class*=-C185] { + color: #D7D75F +} + +div.highlight .-Color[class*=-BGC185] { + background-color: #D7D75F +} + +div.highlight .-Color[class*=-C186] { + color: #D7D787 +} + +div.highlight .-Color[class*=-BGC186] { + background-color: #D7D787 +} + +div.highlight .-Color[class*=-C187] { + color: #D7D7AF +} + +div.highlight .-Color[class*=-BGC187] { + background-color: #D7D7AF +} + +div.highlight .-Color[class*=-C188] { + color: #D7D7D7 +} + +div.highlight .-Color[class*=-BGC188] { + background-color: #D7D7D7 +} + +div.highlight .-Color[class*=-C189] { + color: #D7D7FF +} + +div.highlight .-Color[class*=-BGC189] { + background-color: #D7D7FF +} + +div.highlight .-Color[class*=-C190] { + color: #D7FF00 +} + +div.highlight .-Color[class*=-BGC190] { + background-color: #D7FF00 +} + +div.highlight .-Color[class*=-C191] { + color: #D7FF5F +} + +div.highlight .-Color[class*=-BGC191] { + background-color: #D7FF5F +} + +div.highlight .-Color[class*=-C192] { + color: #D7FF87 +} + +div.highlight .-Color[class*=-BGC192] { + background-color: #D7FF87 +} + +div.highlight .-Color[class*=-C193] { + color: #D7FFAF +} + +div.highlight .-Color[class*=-BGC193] { + background-color: #D7FFAF +} + +div.highlight .-Color[class*=-C194] { + color: #D7FFD7 +} + +div.highlight .-Color[class*=-BGC194] { + background-color: #D7FFD7 +} + +div.highlight .-Color[class*=-C195] { + color: #D7FFFF +} + +div.highlight .-Color[class*=-BGC195] { + background-color: #D7FFFF +} + +div.highlight .-Color[class*=-C196] { + color: #FF0000 +} + +div.highlight .-Color[class*=-BGC196] { + background-color: #FF0000 +} + +div.highlight .-Color[class*=-C197] { + color: #FF005F +} + +div.highlight .-Color[class*=-BGC197] { + background-color: #FF005F +} + +div.highlight .-Color[class*=-C198] { + color: #FF0087 +} + +div.highlight .-Color[class*=-BGC198] { + background-color: #FF0087 +} + +div.highlight .-Color[class*=-C199] { + color: #FF00AF +} + +div.highlight .-Color[class*=-BGC199] { + background-color: #FF00AF +} + +div.highlight .-Color[class*=-C200] { + color: #FF00D7 +} + +div.highlight .-Color[class*=-BGC200] { + background-color: #FF00D7 +} + +div.highlight .-Color[class*=-C201] { + color: #FF00FF +} + +div.highlight .-Color[class*=-BGC201] { + background-color: #FF00FF +} + +div.highlight .-Color[class*=-C202] { + color: #FF5F00 +} + +div.highlight .-Color[class*=-BGC202] { + background-color: #FF5F00 +} + +div.highlight .-Color[class*=-C203] { + color: #FF5F5F +} + +div.highlight .-Color[class*=-BGC203] { + background-color: #FF5F5F +} + +div.highlight .-Color[class*=-C204] { + color: #FF5F87 +} + +div.highlight .-Color[class*=-BGC204] { + background-color: #FF5F87 +} + +div.highlight .-Color[class*=-C205] { + color: #FF5FAF +} + +div.highlight .-Color[class*=-BGC205] { + background-color: #FF5FAF +} + +div.highlight .-Color[class*=-C206] { + color: #FF5FD7 +} + +div.highlight .-Color[class*=-BGC206] { + background-color: #FF5FD7 +} + +div.highlight .-Color[class*=-C207] { + color: #FF5FFF +} + +div.highlight .-Color[class*=-BGC207] { + background-color: #FF5FFF +} + +div.highlight .-Color[class*=-C208] { + color: #FF8700 +} + +div.highlight .-Color[class*=-BGC208] { + background-color: #FF8700 +} + +div.highlight .-Color[class*=-C209] { + color: #FF875F +} + +div.highlight .-Color[class*=-BGC209] { + background-color: #FF875F +} + +div.highlight .-Color[class*=-C210] { + color: #FF8787 +} + +div.highlight .-Color[class*=-BGC210] { + background-color: #FF8787 +} + +div.highlight .-Color[class*=-C211] { + color: #FF87AF +} + +div.highlight .-Color[class*=-BGC211] { + background-color: #FF87AF +} + +div.highlight .-Color[class*=-C212] { + color: #FF87D7 +} + +div.highlight .-Color[class*=-BGC212] { + background-color: #FF87D7 +} + +div.highlight .-Color[class*=-C213] { + color: #FF87FF +} + +div.highlight .-Color[class*=-BGC213] { + background-color: #FF87FF +} + +div.highlight .-Color[class*=-C214] { + color: #FFAF00 +} + +div.highlight .-Color[class*=-BGC214] { + background-color: #FFAF00 +} + +div.highlight .-Color[class*=-C215] { + color: #FFAF5F +} + +div.highlight .-Color[class*=-BGC215] { + background-color: #FFAF5F +} + +div.highlight .-Color[class*=-C216] { + color: #FFAF87 +} + +div.highlight .-Color[class*=-BGC216] { + background-color: #FFAF87 +} + +div.highlight .-Color[class*=-C217] { + color: #FFAFAF +} + +div.highlight .-Color[class*=-BGC217] { + background-color: #FFAFAF +} + +div.highlight .-Color[class*=-C218] { + color: #FFAFD7 +} + +div.highlight .-Color[class*=-BGC218] { + background-color: #FFAFD7 +} + +div.highlight .-Color[class*=-C219] { + color: #FFAFFF +} + +div.highlight .-Color[class*=-BGC219] { + background-color: #FFAFFF +} + +div.highlight .-Color[class*=-C220] { + color: #FFD700 +} + +div.highlight .-Color[class*=-BGC220] { + background-color: #FFD700 +} + +div.highlight .-Color[class*=-C221] { + color: #FFD75F +} + +div.highlight .-Color[class*=-BGC221] { + background-color: #FFD75F +} + +div.highlight .-Color[class*=-C222] { + color: #FFD787 +} + +div.highlight .-Color[class*=-BGC222] { + background-color: #FFD787 +} + +div.highlight .-Color[class*=-C223] { + color: #FFD7AF +} + +div.highlight .-Color[class*=-BGC223] { + background-color: #FFD7AF +} + +div.highlight .-Color[class*=-C224] { + color: #FFD7D7 +} + +div.highlight .-Color[class*=-BGC224] { + background-color: #FFD7D7 +} + +div.highlight .-Color[class*=-C225] { + color: #FFD7FF +} + +div.highlight .-Color[class*=-BGC225] { + background-color: #FFD7FF +} + +div.highlight .-Color[class*=-C226] { + color: #FFFF00 +} + +div.highlight .-Color[class*=-BGC226] { + background-color: #FFFF00 +} + +div.highlight .-Color[class*=-C227] { + color: #FFFF5F +} + +div.highlight .-Color[class*=-BGC227] { + background-color: #FFFF5F +} + +div.highlight .-Color[class*=-C228] { + color: #FFFF87 +} + +div.highlight .-Color[class*=-BGC228] { + background-color: #FFFF87 +} + +div.highlight .-Color[class*=-C229] { + color: #FFFFAF +} + +div.highlight .-Color[class*=-BGC229] { + background-color: #FFFFAF +} + +div.highlight .-Color[class*=-C230] { + color: #FFFFD7 +} + +div.highlight .-Color[class*=-BGC230] { + background-color: #FFFFD7 +} + +div.highlight .-Color[class*=-C231] { + color: #FFFFFF +} + +div.highlight .-Color[class*=-BGC231] { + background-color: #FFFFFF +} + +div.highlight .-Color[class*=-C232] { + color: #080808 +} + +div.highlight .-Color[class*=-BGC232] { + background-color: #080808 +} + +div.highlight .-Color[class*=-C233] { + color: #121212 +} + +div.highlight .-Color[class*=-BGC233] { + background-color: #121212 +} + +div.highlight .-Color[class*=-C234] { + color: #1C1C1C +} + +div.highlight .-Color[class*=-BGC234] { + background-color: #1C1C1C +} + +div.highlight .-Color[class*=-C235] { + color: #262626 +} + +div.highlight .-Color[class*=-BGC235] { + background-color: #262626 +} + +div.highlight .-Color[class*=-C236] { + color: #303030 +} + +div.highlight .-Color[class*=-BGC236] { + background-color: #303030 +} + +div.highlight .-Color[class*=-C237] { + color: #3A3A3A +} + +div.highlight .-Color[class*=-BGC237] { + background-color: #3A3A3A +} + +div.highlight .-Color[class*=-C238] { + color: #444444 +} + +div.highlight .-Color[class*=-BGC238] { + background-color: #444444 +} + +div.highlight .-Color[class*=-C239] { + color: #4E4E4E +} + +div.highlight .-Color[class*=-BGC239] { + background-color: #4E4E4E +} + +div.highlight .-Color[class*=-C240] { + color: #585858 +} + +div.highlight .-Color[class*=-BGC240] { + background-color: #585858 +} + +div.highlight .-Color[class*=-C241] { + color: #626262 +} + +div.highlight .-Color[class*=-BGC241] { + background-color: #626262 +} + +div.highlight .-Color[class*=-C242] { + color: #6C6C6C +} + +div.highlight .-Color[class*=-BGC242] { + background-color: #6C6C6C +} + +div.highlight .-Color[class*=-C243] { + color: #767676 +} + +div.highlight .-Color[class*=-BGC243] { + background-color: #767676 +} + +div.highlight .-Color[class*=-C244] { + color: #808080 +} + +div.highlight .-Color[class*=-BGC244] { + background-color: #808080 +} + +div.highlight .-Color[class*=-C245] { + color: #8A8A8A +} + +div.highlight .-Color[class*=-BGC245] { + background-color: #8A8A8A +} + +div.highlight .-Color[class*=-C246] { + color: #949494 +} + +div.highlight .-Color[class*=-BGC246] { + background-color: #949494 +} + +div.highlight .-Color[class*=-C247] { + color: #9E9E9E +} + +div.highlight .-Color[class*=-BGC247] { + background-color: #9E9E9E +} + +div.highlight .-Color[class*=-C248] { + color: #A8A8A8 +} + +div.highlight .-Color[class*=-BGC248] { + background-color: #A8A8A8 +} + +div.highlight .-Color[class*=-C249] { + color: #B2B2B2 +} + +div.highlight .-Color[class*=-BGC249] { + background-color: #B2B2B2 +} + +div.highlight .-Color[class*=-C250] { + color: #BCBCBC +} + +div.highlight .-Color[class*=-BGC250] { + background-color: #BCBCBC +} + +div.highlight .-Color[class*=-C251] { + color: #C6C6C6 +} + +div.highlight .-Color[class*=-BGC251] { + background-color: #C6C6C6 +} + +div.highlight .-Color[class*=-C252] { + color: #D0D0D0 +} + +div.highlight .-Color[class*=-BGC252] { + background-color: #D0D0D0 +} + +div.highlight .-Color[class*=-C253] { + color: #DADADA +} + +div.highlight .-Color[class*=-BGC253] { + background-color: #DADADA +} + +div.highlight .-Color[class*=-C254] { + color: #E4E4E4 +} + +div.highlight .-Color[class*=-BGC254] { + background-color: #E4E4E4 +} + +div.highlight .-Color[class*=-C255] { + color: #EEEEEE +} + +div.highlight .-Color[class*=-BGC255] { + background-color: #EEEEEE +} diff --git a/pr-preview/pr-92/_static/plus.png b/pr-preview/pr-92/_static/plus.png new file mode 100644 index 0000000..7107cec Binary files /dev/null and b/pr-preview/pr-92/_static/plus.png differ diff --git a/pr-preview/pr-92/_static/pygments.css b/pr-preview/pr-92/_static/pygments.css new file mode 100644 index 0000000..d0ae3b8 --- /dev/null +++ b/pr-preview/pr-92/_static/pygments.css @@ -0,0 +1,249 @@ +.highlight pre { line-height: 125%; } +.highlight td.linenos .normal { color: inherit; background-color: transparent; padding-left: 5px; padding-right: 5px; } +.highlight span.linenos { color: inherit; background-color: transparent; padding-left: 5px; padding-right: 5px; } +.highlight td.linenos .special { color: #000000; background-color: #ffffc0; padding-left: 5px; padding-right: 5px; } +.highlight span.linenos.special { color: #000000; background-color: #ffffc0; padding-left: 5px; padding-right: 5px; } +.highlight .hll { background-color: #ffffcc } +.highlight { background: #eeffcc; } +.highlight .c { color: #408090; font-style: italic } /* Comment */ +.highlight .err { border: 1px solid #FF0000 } /* Error */ +.highlight .k { color: #007020; font-weight: bold } /* Keyword */ +.highlight .o { color: #666666 } /* Operator */ +.highlight .ch { color: #408090; font-style: italic } /* Comment.Hashbang */ +.highlight .cm { color: #408090; font-style: italic } /* Comment.Multiline */ +.highlight .cp { color: #007020 } /* Comment.Preproc */ +.highlight .cpf { color: #408090; font-style: italic } /* Comment.PreprocFile */ +.highlight .c1 { color: #408090; font-style: italic } /* Comment.Single */ +.highlight .cs { color: #408090; background-color: #fff0f0 } /* 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: #FF0000 } /* Generic.Error */ +.highlight .gh { color: #000080; font-weight: bold } /* Generic.Heading */ +.highlight .gi { color: #00A000 } /* Generic.Inserted */ +.highlight .go { color: #333333 } /* Generic.Output */ +.highlight .gp { color: #c65d09; font-weight: bold } /* Generic.Prompt */ +.highlight .gs { font-weight: bold } /* Generic.Strong */ +.highlight .gu { color: #800080; font-weight: bold } /* Generic.Subheading */ +.highlight .gt { color: #0044DD } /* Generic.Traceback */ +.highlight .kc { color: #007020; font-weight: bold } /* Keyword.Constant */ +.highlight .kd { color: #007020; font-weight: bold } /* Keyword.Declaration */ +.highlight .kn { color: #007020; font-weight: bold } /* Keyword.Namespace */ +.highlight .kp { color: #007020 } /* Keyword.Pseudo */ +.highlight .kr { color: #007020; font-weight: bold } /* Keyword.Reserved */ +.highlight .kt { color: #902000 } /* Keyword.Type */ +.highlight .m { color: #208050 } /* Literal.Number */ +.highlight .s { color: #4070a0 } /* Literal.String */ +.highlight .na { color: #4070a0 } /* Name.Attribute */ +.highlight .nb { color: #007020 } /* Name.Builtin */ +.highlight .nc { color: #0e84b5; font-weight: bold } /* Name.Class */ +.highlight .no { color: #60add5 } /* Name.Constant */ +.highlight .nd { color: #555555; font-weight: bold } /* Name.Decorator */ +.highlight .ni { color: #d55537; font-weight: bold } /* Name.Entity */ +.highlight .ne { color: #007020 } /* Name.Exception */ +.highlight .nf { color: #06287e } /* Name.Function */ +.highlight .nl { color: #002070; font-weight: bold } /* Name.Label */ +.highlight .nn { color: #0e84b5; font-weight: bold } /* Name.Namespace */ +.highlight .nt { color: #062873; font-weight: bold } /* Name.Tag */ +.highlight .nv { color: #bb60d5 } /* Name.Variable */ +.highlight .ow { color: #007020; font-weight: bold } /* Operator.Word */ +.highlight .w { color: #bbbbbb } /* Text.Whitespace */ +.highlight .mb { color: #208050 } /* Literal.Number.Bin */ +.highlight .mf { color: #208050 } /* Literal.Number.Float */ +.highlight .mh { color: #208050 } /* Literal.Number.Hex */ +.highlight .mi { color: #208050 } /* Literal.Number.Integer */ +.highlight .mo { color: #208050 } /* Literal.Number.Oct */ +.highlight .sa { color: #4070a0 } /* Literal.String.Affix */ +.highlight .sb { color: #4070a0 } /* Literal.String.Backtick */ +.highlight .sc { color: #4070a0 } /* Literal.String.Char */ +.highlight .dl { color: #4070a0 } /* Literal.String.Delimiter */ +.highlight .sd { color: #4070a0; font-style: italic } /* Literal.String.Doc */ +.highlight .s2 { color: #4070a0 } /* Literal.String.Double */ +.highlight .se { color: #4070a0; font-weight: bold } /* Literal.String.Escape */ +.highlight .sh { color: #4070a0 } /* Literal.String.Heredoc */ +.highlight .si { color: #70a0d0; font-style: italic } /* Literal.String.Interpol */ +.highlight .sx { color: #c65d09 } /* Literal.String.Other */ +.highlight .sr { color: #235388 } /* Literal.String.Regex */ +.highlight .s1 { color: #4070a0 } /* Literal.String.Single */ +.highlight .ss { color: #517918 } /* Literal.String.Symbol */ +.highlight .bp { color: #007020 } /* Name.Builtin.Pseudo */ +.highlight .fm { color: #06287e } /* Name.Function.Magic */ +.highlight .vc { color: #bb60d5 } /* Name.Variable.Class */ +.highlight .vg { color: #bb60d5 } /* Name.Variable.Global */ +.highlight .vi { color: #bb60d5 } /* Name.Variable.Instance */ +.highlight .vm { color: #bb60d5 } /* Name.Variable.Magic */ +.highlight .il { color: #208050 } /* Literal.Number.Integer.Long */ +@media not print { +body[data-theme="dark"] .highlight pre { line-height: 125%; } +body[data-theme="dark"] .highlight td.linenos .normal { color: #aaaaaa; background-color: transparent; padding-left: 5px; padding-right: 5px; } +body[data-theme="dark"] .highlight span.linenos { color: #aaaaaa; background-color: transparent; padding-left: 5px; padding-right: 5px; } +body[data-theme="dark"] .highlight td.linenos .special { color: #000000; background-color: #ffffc0; padding-left: 5px; padding-right: 5px; } +body[data-theme="dark"] .highlight span.linenos.special { color: #000000; background-color: #ffffc0; padding-left: 5px; padding-right: 5px; } +body[data-theme="dark"] .highlight .hll { background-color: #404040 } +body[data-theme="dark"] .highlight { background: #202020; color: #d0d0d0 } +body[data-theme="dark"] .highlight .c { color: #ababab; font-style: italic } /* Comment */ +body[data-theme="dark"] .highlight .err { color: #a61717; background-color: #e3d2d2 } /* Error */ +body[data-theme="dark"] .highlight .esc { color: #d0d0d0 } /* Escape */ +body[data-theme="dark"] .highlight .g { color: #d0d0d0 } /* Generic */ +body[data-theme="dark"] .highlight .k { color: #6ebf26; font-weight: bold } /* Keyword */ +body[data-theme="dark"] .highlight .l { color: #d0d0d0 } /* Literal */ +body[data-theme="dark"] .highlight .n { color: #d0d0d0 } /* Name */ +body[data-theme="dark"] .highlight .o { color: #d0d0d0 } /* Operator */ +body[data-theme="dark"] .highlight .x { color: #d0d0d0 } /* Other */ +body[data-theme="dark"] .highlight .p { color: #d0d0d0 } /* Punctuation */ +body[data-theme="dark"] .highlight .ch { color: #ababab; font-style: italic } /* Comment.Hashbang */ +body[data-theme="dark"] .highlight .cm { color: #ababab; font-style: italic } /* Comment.Multiline */ +body[data-theme="dark"] .highlight .cp { color: #ff3a3a; font-weight: bold } /* Comment.Preproc */ +body[data-theme="dark"] .highlight .cpf { color: #ababab; font-style: italic } /* Comment.PreprocFile */ +body[data-theme="dark"] .highlight .c1 { color: #ababab; font-style: italic } /* Comment.Single */ +body[data-theme="dark"] .highlight .cs { color: #e50808; font-weight: bold; background-color: #520000 } /* Comment.Special */ +body[data-theme="dark"] .highlight .gd { color: #ff3a3a } /* Generic.Deleted */ +body[data-theme="dark"] .highlight .ge { color: #d0d0d0; font-style: italic } /* Generic.Emph */ +body[data-theme="dark"] .highlight .ges { color: #d0d0d0; font-weight: bold; font-style: italic } /* Generic.EmphStrong */ +body[data-theme="dark"] .highlight .gr { color: #ff3a3a } /* Generic.Error */ +body[data-theme="dark"] .highlight .gh { color: #ffffff; font-weight: bold } /* Generic.Heading */ +body[data-theme="dark"] .highlight .gi { color: #589819 } /* Generic.Inserted */ +body[data-theme="dark"] .highlight .go { color: #cccccc } /* Generic.Output */ +body[data-theme="dark"] .highlight .gp { color: #aaaaaa } /* Generic.Prompt */ +body[data-theme="dark"] .highlight .gs { color: #d0d0d0; font-weight: bold } /* Generic.Strong */ +body[data-theme="dark"] .highlight .gu { color: #ffffff; text-decoration: underline } /* Generic.Subheading */ +body[data-theme="dark"] .highlight .gt { color: #ff3a3a } /* Generic.Traceback */ +body[data-theme="dark"] .highlight .kc { color: #6ebf26; font-weight: bold } /* Keyword.Constant */ +body[data-theme="dark"] .highlight .kd { color: #6ebf26; font-weight: bold } /* Keyword.Declaration */ +body[data-theme="dark"] .highlight .kn { color: #6ebf26; font-weight: bold } /* Keyword.Namespace */ +body[data-theme="dark"] .highlight .kp { color: #6ebf26 } /* Keyword.Pseudo */ +body[data-theme="dark"] .highlight .kr { color: #6ebf26; font-weight: bold } /* Keyword.Reserved */ +body[data-theme="dark"] .highlight .kt { color: #6ebf26; font-weight: bold } /* Keyword.Type */ +body[data-theme="dark"] .highlight .ld { color: #d0d0d0 } /* Literal.Date */ +body[data-theme="dark"] .highlight .m { color: #51b2fd } /* Literal.Number */ +body[data-theme="dark"] .highlight .s { color: #ed9d13 } /* Literal.String */ +body[data-theme="dark"] .highlight .na { color: #bbbbbb } /* Name.Attribute */ +body[data-theme="dark"] .highlight .nb { color: #2fbccd } /* Name.Builtin */ +body[data-theme="dark"] .highlight .nc { color: #71adff; text-decoration: underline } /* Name.Class */ +body[data-theme="dark"] .highlight .no { color: #40ffff } /* Name.Constant */ +body[data-theme="dark"] .highlight .nd { color: #ffa500 } /* Name.Decorator */ +body[data-theme="dark"] .highlight .ni { color: #d0d0d0 } /* Name.Entity */ +body[data-theme="dark"] .highlight .ne { color: #bbbbbb } /* Name.Exception */ +body[data-theme="dark"] .highlight .nf { color: #71adff } /* Name.Function */ +body[data-theme="dark"] .highlight .nl { color: #d0d0d0 } /* Name.Label */ +body[data-theme="dark"] .highlight .nn { color: #71adff; text-decoration: underline } /* Name.Namespace */ +body[data-theme="dark"] .highlight .nx { color: #d0d0d0 } /* Name.Other */ +body[data-theme="dark"] .highlight .py { color: #d0d0d0 } /* Name.Property */ +body[data-theme="dark"] .highlight .nt { color: #6ebf26; font-weight: bold } /* Name.Tag */ +body[data-theme="dark"] .highlight .nv { color: #40ffff } /* Name.Variable */ +body[data-theme="dark"] .highlight .ow { color: #6ebf26; font-weight: bold } /* Operator.Word */ +body[data-theme="dark"] .highlight .pm { color: #d0d0d0 } /* Punctuation.Marker */ +body[data-theme="dark"] .highlight .w { color: #666666 } /* Text.Whitespace */ +body[data-theme="dark"] .highlight .mb { color: #51b2fd } /* Literal.Number.Bin */ +body[data-theme="dark"] .highlight .mf { color: #51b2fd } /* Literal.Number.Float */ +body[data-theme="dark"] .highlight .mh { color: #51b2fd } /* Literal.Number.Hex */ +body[data-theme="dark"] .highlight .mi { color: #51b2fd } /* Literal.Number.Integer */ +body[data-theme="dark"] .highlight .mo { color: #51b2fd } /* Literal.Number.Oct */ +body[data-theme="dark"] .highlight .sa { color: #ed9d13 } /* Literal.String.Affix */ +body[data-theme="dark"] .highlight .sb { color: #ed9d13 } /* Literal.String.Backtick */ +body[data-theme="dark"] .highlight .sc { color: #ed9d13 } /* Literal.String.Char */ +body[data-theme="dark"] .highlight .dl { color: #ed9d13 } /* Literal.String.Delimiter */ +body[data-theme="dark"] .highlight .sd { color: #ed9d13 } /* Literal.String.Doc */ +body[data-theme="dark"] .highlight .s2 { color: #ed9d13 } /* Literal.String.Double */ +body[data-theme="dark"] .highlight .se { color: #ed9d13 } /* Literal.String.Escape */ +body[data-theme="dark"] .highlight .sh { color: #ed9d13 } /* Literal.String.Heredoc */ +body[data-theme="dark"] .highlight .si { color: #ed9d13 } /* Literal.String.Interpol */ +body[data-theme="dark"] .highlight .sx { color: #ffa500 } /* Literal.String.Other */ +body[data-theme="dark"] .highlight .sr { color: #ed9d13 } /* Literal.String.Regex */ +body[data-theme="dark"] .highlight .s1 { color: #ed9d13 } /* Literal.String.Single */ +body[data-theme="dark"] .highlight .ss { color: #ed9d13 } /* Literal.String.Symbol */ +body[data-theme="dark"] .highlight .bp { color: #2fbccd } /* Name.Builtin.Pseudo */ +body[data-theme="dark"] .highlight .fm { color: #71adff } /* Name.Function.Magic */ +body[data-theme="dark"] .highlight .vc { color: #40ffff } /* Name.Variable.Class */ +body[data-theme="dark"] .highlight .vg { color: #40ffff } /* Name.Variable.Global */ +body[data-theme="dark"] .highlight .vi { color: #40ffff } /* Name.Variable.Instance */ +body[data-theme="dark"] .highlight .vm { color: #40ffff } /* Name.Variable.Magic */ +body[data-theme="dark"] .highlight .il { color: #51b2fd } /* Literal.Number.Integer.Long */ +@media (prefers-color-scheme: dark) { +body:not([data-theme="light"]) .highlight pre { line-height: 125%; } +body:not([data-theme="light"]) .highlight td.linenos .normal { color: #aaaaaa; background-color: transparent; padding-left: 5px; padding-right: 5px; } +body:not([data-theme="light"]) .highlight span.linenos { color: #aaaaaa; background-color: transparent; padding-left: 5px; padding-right: 5px; } +body:not([data-theme="light"]) .highlight td.linenos .special { color: #000000; background-color: #ffffc0; padding-left: 5px; padding-right: 5px; } +body:not([data-theme="light"]) .highlight span.linenos.special { color: #000000; background-color: #ffffc0; padding-left: 5px; padding-right: 5px; } +body:not([data-theme="light"]) .highlight .hll { background-color: #404040 } +body:not([data-theme="light"]) .highlight { background: #202020; color: #d0d0d0 } +body:not([data-theme="light"]) .highlight .c { color: #ababab; font-style: italic } /* Comment */ +body:not([data-theme="light"]) .highlight .err { color: #a61717; background-color: #e3d2d2 } /* Error */ +body:not([data-theme="light"]) .highlight .esc { color: #d0d0d0 } /* Escape */ +body:not([data-theme="light"]) .highlight .g { color: #d0d0d0 } /* Generic */ +body:not([data-theme="light"]) .highlight .k { color: #6ebf26; font-weight: bold } /* Keyword */ +body:not([data-theme="light"]) .highlight .l { color: #d0d0d0 } /* Literal */ +body:not([data-theme="light"]) .highlight .n { color: #d0d0d0 } /* Name */ +body:not([data-theme="light"]) .highlight .o { color: #d0d0d0 } /* Operator */ +body:not([data-theme="light"]) .highlight .x { color: #d0d0d0 } /* Other */ +body:not([data-theme="light"]) .highlight .p { color: #d0d0d0 } /* Punctuation */ +body:not([data-theme="light"]) .highlight .ch { color: #ababab; font-style: italic } /* Comment.Hashbang */ +body:not([data-theme="light"]) .highlight .cm { color: #ababab; font-style: italic } /* Comment.Multiline */ +body:not([data-theme="light"]) .highlight .cp { color: #ff3a3a; font-weight: bold } /* Comment.Preproc */ +body:not([data-theme="light"]) .highlight .cpf { color: #ababab; font-style: italic } /* Comment.PreprocFile */ +body:not([data-theme="light"]) .highlight .c1 { color: #ababab; font-style: italic } /* Comment.Single */ +body:not([data-theme="light"]) .highlight .cs { color: #e50808; font-weight: bold; background-color: #520000 } /* Comment.Special */ +body:not([data-theme="light"]) .highlight .gd { color: #ff3a3a } /* Generic.Deleted */ +body:not([data-theme="light"]) .highlight .ge { color: #d0d0d0; font-style: italic } /* Generic.Emph */ +body:not([data-theme="light"]) .highlight .ges { color: #d0d0d0; font-weight: bold; font-style: italic } /* Generic.EmphStrong */ +body:not([data-theme="light"]) .highlight .gr { color: #ff3a3a } /* Generic.Error */ +body:not([data-theme="light"]) .highlight .gh { color: #ffffff; font-weight: bold } /* Generic.Heading */ +body:not([data-theme="light"]) .highlight .gi { color: #589819 } /* Generic.Inserted */ +body:not([data-theme="light"]) .highlight .go { color: #cccccc } /* Generic.Output */ +body:not([data-theme="light"]) .highlight .gp { color: #aaaaaa } /* Generic.Prompt */ +body:not([data-theme="light"]) .highlight .gs { color: #d0d0d0; font-weight: bold } /* Generic.Strong */ +body:not([data-theme="light"]) .highlight .gu { color: #ffffff; text-decoration: underline } /* Generic.Subheading */ +body:not([data-theme="light"]) .highlight .gt { color: #ff3a3a } /* Generic.Traceback */ +body:not([data-theme="light"]) .highlight .kc { color: #6ebf26; font-weight: bold } /* Keyword.Constant */ +body:not([data-theme="light"]) .highlight .kd { color: #6ebf26; font-weight: bold } /* Keyword.Declaration */ +body:not([data-theme="light"]) .highlight .kn { color: #6ebf26; font-weight: bold } /* Keyword.Namespace */ +body:not([data-theme="light"]) .highlight .kp { color: #6ebf26 } /* Keyword.Pseudo */ +body:not([data-theme="light"]) .highlight .kr { color: #6ebf26; font-weight: bold } /* Keyword.Reserved */ +body:not([data-theme="light"]) .highlight .kt { color: #6ebf26; font-weight: bold } /* Keyword.Type */ +body:not([data-theme="light"]) .highlight .ld { color: #d0d0d0 } /* Literal.Date */ +body:not([data-theme="light"]) .highlight .m { color: #51b2fd } /* Literal.Number */ +body:not([data-theme="light"]) .highlight .s { color: #ed9d13 } /* Literal.String */ +body:not([data-theme="light"]) .highlight .na { color: #bbbbbb } /* Name.Attribute */ +body:not([data-theme="light"]) .highlight .nb { color: #2fbccd } /* Name.Builtin */ +body:not([data-theme="light"]) .highlight .nc { color: #71adff; text-decoration: underline } /* Name.Class */ +body:not([data-theme="light"]) .highlight .no { color: #40ffff } /* Name.Constant */ +body:not([data-theme="light"]) .highlight .nd { color: #ffa500 } /* Name.Decorator */ +body:not([data-theme="light"]) .highlight .ni { color: #d0d0d0 } /* Name.Entity */ +body:not([data-theme="light"]) .highlight .ne { color: #bbbbbb } /* Name.Exception */ +body:not([data-theme="light"]) .highlight .nf { color: #71adff } /* Name.Function */ +body:not([data-theme="light"]) .highlight .nl { color: #d0d0d0 } /* Name.Label */ +body:not([data-theme="light"]) .highlight .nn { color: #71adff; text-decoration: underline } /* Name.Namespace */ +body:not([data-theme="light"]) .highlight .nx { color: #d0d0d0 } /* Name.Other */ +body:not([data-theme="light"]) .highlight .py { color: #d0d0d0 } /* Name.Property */ +body:not([data-theme="light"]) .highlight .nt { color: #6ebf26; font-weight: bold } /* Name.Tag */ +body:not([data-theme="light"]) .highlight .nv { color: #40ffff } /* Name.Variable */ +body:not([data-theme="light"]) .highlight .ow { color: #6ebf26; font-weight: bold } /* Operator.Word */ +body:not([data-theme="light"]) .highlight .pm { color: #d0d0d0 } /* Punctuation.Marker */ +body:not([data-theme="light"]) .highlight .w { color: #666666 } /* Text.Whitespace */ +body:not([data-theme="light"]) .highlight .mb { color: #51b2fd } /* Literal.Number.Bin */ +body:not([data-theme="light"]) .highlight .mf { color: #51b2fd } /* Literal.Number.Float */ +body:not([data-theme="light"]) .highlight .mh { color: #51b2fd } /* Literal.Number.Hex */ +body:not([data-theme="light"]) .highlight .mi { color: #51b2fd } /* Literal.Number.Integer */ +body:not([data-theme="light"]) .highlight .mo { color: #51b2fd } /* Literal.Number.Oct */ +body:not([data-theme="light"]) .highlight .sa { color: #ed9d13 } /* Literal.String.Affix */ +body:not([data-theme="light"]) .highlight .sb { color: #ed9d13 } /* Literal.String.Backtick */ +body:not([data-theme="light"]) .highlight .sc { color: #ed9d13 } /* Literal.String.Char */ +body:not([data-theme="light"]) .highlight .dl { color: #ed9d13 } /* Literal.String.Delimiter */ +body:not([data-theme="light"]) .highlight .sd { color: #ed9d13 } /* Literal.String.Doc */ +body:not([data-theme="light"]) .highlight .s2 { color: #ed9d13 } /* Literal.String.Double */ +body:not([data-theme="light"]) .highlight .se { color: #ed9d13 } /* Literal.String.Escape */ +body:not([data-theme="light"]) .highlight .sh { color: #ed9d13 } /* Literal.String.Heredoc */ +body:not([data-theme="light"]) .highlight .si { color: #ed9d13 } /* Literal.String.Interpol */ +body:not([data-theme="light"]) .highlight .sx { color: #ffa500 } /* Literal.String.Other */ +body:not([data-theme="light"]) .highlight .sr { color: #ed9d13 } /* Literal.String.Regex */ +body:not([data-theme="light"]) .highlight .s1 { color: #ed9d13 } /* Literal.String.Single */ +body:not([data-theme="light"]) .highlight .ss { color: #ed9d13 } /* Literal.String.Symbol */ +body:not([data-theme="light"]) .highlight .bp { color: #2fbccd } /* Name.Builtin.Pseudo */ +body:not([data-theme="light"]) .highlight .fm { color: #71adff } /* Name.Function.Magic */ +body:not([data-theme="light"]) .highlight .vc { color: #40ffff } /* Name.Variable.Class */ +body:not([data-theme="light"]) .highlight .vg { color: #40ffff } /* Name.Variable.Global */ +body:not([data-theme="light"]) .highlight .vi { color: #40ffff } /* Name.Variable.Instance */ +body:not([data-theme="light"]) .highlight .vm { color: #40ffff } /* Name.Variable.Magic */ +body:not([data-theme="light"]) .highlight .il { color: #51b2fd } /* Literal.Number.Integer.Long */ +} +} \ No newline at end of file diff --git a/pr-preview/pr-92/_static/scripts/furo-extensions.js b/pr-preview/pr-92/_static/scripts/furo-extensions.js new file mode 100644 index 0000000..e69de29 diff --git a/pr-preview/pr-92/_static/scripts/furo.js b/pr-preview/pr-92/_static/scripts/furo.js new file mode 100644 index 0000000..0abb2af --- /dev/null +++ b/pr-preview/pr-92/_static/scripts/furo.js @@ -0,0 +1,3 @@ +/*! For license information please see furo.js.LICENSE.txt */ +(()=>{var t={856:function(t,e,n){var o,r;r=void 0!==n.g?n.g:"undefined"!=typeof window?window:this,o=function(){return function(t){"use strict";var e={navClass:"active",contentClass:"active",nested:!1,nestedClass:"active",offset:0,reflow:!1,events:!0},n=function(t,e,n){if(n.settings.events){var o=new CustomEvent(t,{bubbles:!0,cancelable:!0,detail:n});e.dispatchEvent(o)}},o=function(t){var e=0;if(t.offsetParent)for(;t;)e+=t.offsetTop,t=t.offsetParent;return e>=0?e:0},r=function(t){t&&t.sort((function(t,e){return o(t.content)=Math.max(document.body.scrollHeight,document.documentElement.scrollHeight,document.body.offsetHeight,document.documentElement.offsetHeight,document.body.clientHeight,document.documentElement.clientHeight)},l=function(t,e){var n=t[t.length-1];if(function(t,e){return!(!s()||!c(t.content,e,!0))}(n,e))return n;for(var o=t.length-1;o>=0;o--)if(c(t[o].content,e))return t[o]},a=function(t,e){if(e.nested&&t.parentNode){var n=t.parentNode.closest("li");n&&(n.classList.remove(e.nestedClass),a(n,e))}},i=function(t,e){if(t){var o=t.nav.closest("li");o&&(o.classList.remove(e.navClass),t.content.classList.remove(e.contentClass),a(o,e),n("gumshoeDeactivate",o,{link:t.nav,content:t.content,settings:e}))}},u=function(t,e){if(e.nested){var n=t.parentNode.closest("li");n&&(n.classList.add(e.nestedClass),u(n,e))}};return function(o,c){var s,a,d,f,m,v={setup:function(){s=document.querySelectorAll(o),a=[],Array.prototype.forEach.call(s,(function(t){var e=document.getElementById(decodeURIComponent(t.hash.substr(1)));e&&a.push({nav:t,content:e})})),r(a)},detect:function(){var t=l(a,m);t?d&&t.content===d.content||(i(d,m),function(t,e){if(t){var o=t.nav.closest("li");o&&(o.classList.add(e.navClass),t.content.classList.add(e.contentClass),u(o,e),n("gumshoeActivate",o,{link:t.nav,content:t.content,settings:e}))}}(t,m),d=t):d&&(i(d,m),d=null)}},h=function(e){f&&t.cancelAnimationFrame(f),f=t.requestAnimationFrame(v.detect)},g=function(e){f&&t.cancelAnimationFrame(f),f=t.requestAnimationFrame((function(){r(a),v.detect()}))};return v.destroy=function(){d&&i(d,m),t.removeEventListener("scroll",h,!1),m.reflow&&t.removeEventListener("resize",g,!1),a=null,s=null,d=null,f=null,m=null},m=function(){var t={};return Array.prototype.forEach.call(arguments,(function(e){for(var n in e){if(!e.hasOwnProperty(n))return;t[n]=e[n]}})),t}(e,c||{}),v.setup(),v.detect(),t.addEventListener("scroll",h,!1),m.reflow&&t.addEventListener("resize",g,!1),v}}(r)}.apply(e,[]),void 0===o||(t.exports=o)}},e={};function n(o){var r=e[o];if(void 0!==r)return r.exports;var c=e[o]={exports:{}};return t[o].call(c.exports,c,c.exports,n),c.exports}n.n=t=>{var e=t&&t.__esModule?()=>t.default:()=>t;return n.d(e,{a:e}),e},n.d=(t,e)=>{for(var o in e)n.o(e,o)&&!n.o(t,o)&&Object.defineProperty(t,o,{enumerable:!0,get:e[o]})},n.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(t){if("object"==typeof window)return window}}(),n.o=(t,e)=>Object.prototype.hasOwnProperty.call(t,e),(()=>{"use strict";var t=n(856),e=n.n(t),o=null,r=null,c=document.documentElement.scrollTop;const s=64;function l(){const t=localStorage.getItem("theme")||"auto";var e;"light"!==(e=window.matchMedia("(prefers-color-scheme: dark)").matches?"auto"===t?"light":"light"==t?"dark":"auto":"auto"===t?"dark":"dark"==t?"light":"auto")&&"dark"!==e&&"auto"!==e&&(console.error(`Got invalid theme mode: ${e}. Resetting to auto.`),e="auto"),document.body.dataset.theme=e,localStorage.setItem("theme",e),console.log(`Changed to ${e} mode.`)}function a(){!function(){const t=document.getElementsByClassName("theme-toggle");Array.from(t).forEach((t=>{t.addEventListener("click",l)}))}(),function(){let t=0,e=!1;window.addEventListener("scroll",(function(n){t=window.scrollY,e||(window.requestAnimationFrame((function(){var n;(function(t){const e=Math.floor(r.getBoundingClientRect().top);console.log(`headerTop: ${e}`),0==e&&t!=e?r.classList.add("scrolled"):r.classList.remove("scrolled")})(n=t),function(t){tc&&document.documentElement.classList.remove("show-back-to-top"),c=t}(n),function(t){null!==o&&(0==t?o.scrollTo(0,0):Math.ceil(t)>=Math.floor(document.documentElement.scrollHeight-window.innerHeight)?o.scrollTo(0,o.scrollHeight):document.querySelector(".scroll-current"))}(n),e=!1})),e=!0)})),window.scroll()}(),null!==o&&new(e())(".toc-tree a",{reflow:!0,recursive:!0,navClass:"scroll-current",offset:()=>{let t=parseFloat(getComputedStyle(document.documentElement).fontSize);return r.getBoundingClientRect().height+2.5*t+1}})}document.addEventListener("DOMContentLoaded",(function(){document.body.parentNode.classList.remove("no-js"),r=document.querySelector("header"),o=document.querySelector(".toc-scroll"),a()}))})()})(); +//# sourceMappingURL=furo.js.map \ No newline at end of file diff --git a/pr-preview/pr-92/_static/scripts/furo.js.LICENSE.txt b/pr-preview/pr-92/_static/scripts/furo.js.LICENSE.txt new file mode 100644 index 0000000..1632189 --- /dev/null +++ b/pr-preview/pr-92/_static/scripts/furo.js.LICENSE.txt @@ -0,0 +1,7 @@ +/*! + * gumshoejs v5.1.2 (patched by @pradyunsg) + * A simple, framework-agnostic scrollspy script. + * (c) 2019 Chris Ferdinandi + * MIT License + * http://github.com/cferdinandi/gumshoe + */ diff --git a/pr-preview/pr-92/_static/scripts/furo.js.map b/pr-preview/pr-92/_static/scripts/furo.js.map new file mode 100644 index 0000000..80ea12b --- /dev/null +++ b/pr-preview/pr-92/_static/scripts/furo.js.map @@ -0,0 +1 @@ +{"version":3,"file":"scripts/furo.js","mappings":"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","sources":["webpack:///./src/furo/assets/scripts/gumshoe-patched.js","webpack:///webpack/bootstrap","webpack:///webpack/runtime/compat get default export","webpack:///webpack/runtime/define property getters","webpack:///webpack/runtime/global","webpack:///webpack/runtime/hasOwnProperty shorthand","webpack:///./src/furo/assets/scripts/furo.js"],"sourcesContent":["/*!\n * gumshoejs v5.1.2 (patched by @pradyunsg)\n * A simple, framework-agnostic scrollspy script.\n * (c) 2019 Chris Ferdinandi\n * MIT License\n * http://github.com/cferdinandi/gumshoe\n */\n\n(function (root, factory) {\n if (typeof define === \"function\" && define.amd) {\n define([], function () {\n return factory(root);\n });\n } else if (typeof exports === \"object\") {\n module.exports = factory(root);\n } else {\n root.Gumshoe = factory(root);\n }\n})(\n typeof global !== \"undefined\"\n ? global\n : typeof window !== \"undefined\"\n ? window\n : this,\n function (window) {\n \"use strict\";\n\n //\n // Defaults\n //\n\n var defaults = {\n // Active classes\n navClass: \"active\",\n contentClass: \"active\",\n\n // Nested navigation\n nested: false,\n nestedClass: \"active\",\n\n // Offset & reflow\n offset: 0,\n reflow: false,\n\n // Event support\n events: true,\n };\n\n //\n // Methods\n //\n\n /**\n * Merge two or more objects together.\n * @param {Object} objects The objects to merge together\n * @returns {Object} Merged values of defaults and options\n */\n var extend = function () {\n var merged = {};\n Array.prototype.forEach.call(arguments, function (obj) {\n for (var key in obj) {\n if (!obj.hasOwnProperty(key)) return;\n merged[key] = obj[key];\n }\n });\n return merged;\n };\n\n /**\n * Emit a custom event\n * @param {String} type The event type\n * @param {Node} elem The element to attach the event to\n * @param {Object} detail Any details to pass along with the event\n */\n var emitEvent = function (type, elem, detail) {\n // Make sure events are enabled\n if (!detail.settings.events) return;\n\n // Create a new event\n var event = new CustomEvent(type, {\n bubbles: true,\n cancelable: true,\n detail: detail,\n });\n\n // Dispatch the event\n elem.dispatchEvent(event);\n };\n\n /**\n * Get an element's distance from the top of the Document.\n * @param {Node} elem The element\n * @return {Number} Distance from the top in pixels\n */\n var getOffsetTop = function (elem) {\n var location = 0;\n if (elem.offsetParent) {\n while (elem) {\n location += elem.offsetTop;\n elem = elem.offsetParent;\n }\n }\n return location >= 0 ? location : 0;\n };\n\n /**\n * Sort content from first to last in the DOM\n * @param {Array} contents The content areas\n */\n var sortContents = function (contents) {\n if (contents) {\n contents.sort(function (item1, item2) {\n var offset1 = getOffsetTop(item1.content);\n var offset2 = getOffsetTop(item2.content);\n if (offset1 < offset2) return -1;\n return 1;\n });\n }\n };\n\n /**\n * Get the offset to use for calculating position\n * @param {Object} settings The settings for this instantiation\n * @return {Float} The number of pixels to offset the calculations\n */\n var getOffset = function (settings) {\n // if the offset is a function run it\n if (typeof settings.offset === \"function\") {\n return parseFloat(settings.offset());\n }\n\n // Otherwise, return it as-is\n return parseFloat(settings.offset);\n };\n\n /**\n * Get the document element's height\n * @private\n * @returns {Number}\n */\n var getDocumentHeight = function () {\n return Math.max(\n document.body.scrollHeight,\n document.documentElement.scrollHeight,\n document.body.offsetHeight,\n document.documentElement.offsetHeight,\n document.body.clientHeight,\n document.documentElement.clientHeight,\n );\n };\n\n /**\n * Determine if an element is in view\n * @param {Node} elem The element\n * @param {Object} settings The settings for this instantiation\n * @param {Boolean} bottom If true, check if element is above bottom of viewport instead\n * @return {Boolean} Returns true if element is in the viewport\n */\n var isInView = function (elem, settings, bottom) {\n var bounds = elem.getBoundingClientRect();\n var offset = getOffset(settings);\n if (bottom) {\n return (\n parseInt(bounds.bottom, 10) <\n (window.innerHeight || document.documentElement.clientHeight)\n );\n }\n return parseInt(bounds.top, 10) <= offset;\n };\n\n /**\n * Check if at the bottom of the viewport\n * @return {Boolean} If true, page is at the bottom of the viewport\n */\n var isAtBottom = function () {\n if (\n Math.ceil(window.innerHeight + window.pageYOffset) >=\n getDocumentHeight()\n )\n return true;\n return false;\n };\n\n /**\n * Check if the last item should be used (even if not at the top of the page)\n * @param {Object} item The last item\n * @param {Object} settings The settings for this instantiation\n * @return {Boolean} If true, use the last item\n */\n var useLastItem = function (item, settings) {\n if (isAtBottom() && isInView(item.content, settings, true)) return true;\n return false;\n };\n\n /**\n * Get the active content\n * @param {Array} contents The content areas\n * @param {Object} settings The settings for this instantiation\n * @return {Object} The content area and matching navigation link\n */\n var getActive = function (contents, settings) {\n var last = contents[contents.length - 1];\n if (useLastItem(last, settings)) return last;\n for (var i = contents.length - 1; i >= 0; i--) {\n if (isInView(contents[i].content, settings)) return contents[i];\n }\n };\n\n /**\n * Deactivate parent navs in a nested navigation\n * @param {Node} nav The starting navigation element\n * @param {Object} settings The settings for this instantiation\n */\n var deactivateNested = function (nav, settings) {\n // If nesting isn't activated, bail\n if (!settings.nested || !nav.parentNode) return;\n\n // Get the parent navigation\n var li = nav.parentNode.closest(\"li\");\n if (!li) return;\n\n // Remove the active class\n li.classList.remove(settings.nestedClass);\n\n // Apply recursively to any parent navigation elements\n deactivateNested(li, settings);\n };\n\n /**\n * Deactivate a nav and content area\n * @param {Object} items The nav item and content to deactivate\n * @param {Object} settings The settings for this instantiation\n */\n var deactivate = function (items, settings) {\n // Make sure there are items to deactivate\n if (!items) return;\n\n // Get the parent list item\n var li = items.nav.closest(\"li\");\n if (!li) return;\n\n // Remove the active class from the nav and content\n li.classList.remove(settings.navClass);\n items.content.classList.remove(settings.contentClass);\n\n // Deactivate any parent navs in a nested navigation\n deactivateNested(li, settings);\n\n // Emit a custom event\n emitEvent(\"gumshoeDeactivate\", li, {\n link: items.nav,\n content: items.content,\n settings: settings,\n });\n };\n\n /**\n * Activate parent navs in a nested navigation\n * @param {Node} nav The starting navigation element\n * @param {Object} settings The settings for this instantiation\n */\n var activateNested = function (nav, settings) {\n // If nesting isn't activated, bail\n if (!settings.nested) return;\n\n // Get the parent navigation\n var li = nav.parentNode.closest(\"li\");\n if (!li) return;\n\n // Add the active class\n li.classList.add(settings.nestedClass);\n\n // Apply recursively to any parent navigation elements\n activateNested(li, settings);\n };\n\n /**\n * Activate a nav and content area\n * @param {Object} items The nav item and content to activate\n * @param {Object} settings The settings for this instantiation\n */\n var activate = function (items, settings) {\n // Make sure there are items to activate\n if (!items) return;\n\n // Get the parent list item\n var li = items.nav.closest(\"li\");\n if (!li) return;\n\n // Add the active class to the nav and content\n li.classList.add(settings.navClass);\n items.content.classList.add(settings.contentClass);\n\n // Activate any parent navs in a nested navigation\n activateNested(li, settings);\n\n // Emit a custom event\n emitEvent(\"gumshoeActivate\", li, {\n link: items.nav,\n content: items.content,\n settings: settings,\n });\n };\n\n /**\n * Create the Constructor object\n * @param {String} selector The selector to use for navigation items\n * @param {Object} options User options and settings\n */\n var Constructor = function (selector, options) {\n //\n // Variables\n //\n\n var publicAPIs = {};\n var navItems, contents, current, timeout, settings;\n\n //\n // Methods\n //\n\n /**\n * Set variables from DOM elements\n */\n publicAPIs.setup = function () {\n // Get all nav items\n navItems = document.querySelectorAll(selector);\n\n // Create contents array\n contents = [];\n\n // Loop through each item, get it's matching content, and push to the array\n Array.prototype.forEach.call(navItems, function (item) {\n // Get the content for the nav item\n var content = document.getElementById(\n decodeURIComponent(item.hash.substr(1)),\n );\n if (!content) return;\n\n // Push to the contents array\n contents.push({\n nav: item,\n content: content,\n });\n });\n\n // Sort contents by the order they appear in the DOM\n sortContents(contents);\n };\n\n /**\n * Detect which content is currently active\n */\n publicAPIs.detect = function () {\n // Get the active content\n var active = getActive(contents, settings);\n\n // if there's no active content, deactivate and bail\n if (!active) {\n if (current) {\n deactivate(current, settings);\n current = null;\n }\n return;\n }\n\n // If the active content is the one currently active, do nothing\n if (current && active.content === current.content) return;\n\n // Deactivate the current content and activate the new content\n deactivate(current, settings);\n activate(active, settings);\n\n // Update the currently active content\n current = active;\n };\n\n /**\n * Detect the active content on scroll\n * Debounced for performance\n */\n var scrollHandler = function (event) {\n // If there's a timer, cancel it\n if (timeout) {\n window.cancelAnimationFrame(timeout);\n }\n\n // Setup debounce callback\n timeout = window.requestAnimationFrame(publicAPIs.detect);\n };\n\n /**\n * Update content sorting on resize\n * Debounced for performance\n */\n var resizeHandler = function (event) {\n // If there's a timer, cancel it\n if (timeout) {\n window.cancelAnimationFrame(timeout);\n }\n\n // Setup debounce callback\n timeout = window.requestAnimationFrame(function () {\n sortContents(contents);\n publicAPIs.detect();\n });\n };\n\n /**\n * Destroy the current instantiation\n */\n publicAPIs.destroy = function () {\n // Undo DOM changes\n if (current) {\n deactivate(current, settings);\n }\n\n // Remove event listeners\n window.removeEventListener(\"scroll\", scrollHandler, false);\n if (settings.reflow) {\n window.removeEventListener(\"resize\", resizeHandler, false);\n }\n\n // Reset variables\n contents = null;\n navItems = null;\n current = null;\n timeout = null;\n settings = null;\n };\n\n /**\n * Initialize the current instantiation\n */\n var init = function () {\n // Merge user options into defaults\n settings = extend(defaults, options || {});\n\n // Setup variables based on the current DOM\n publicAPIs.setup();\n\n // Find the currently active content\n publicAPIs.detect();\n\n // Setup event listeners\n window.addEventListener(\"scroll\", scrollHandler, false);\n if (settings.reflow) {\n window.addEventListener(\"resize\", resizeHandler, false);\n }\n };\n\n //\n // Initialize and return the public APIs\n //\n\n init();\n return publicAPIs;\n };\n\n //\n // Return the Constructor\n //\n\n return Constructor;\n },\n);\n","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// getDefaultExport function for compatibility with non-harmony modules\n__webpack_require__.n = (module) => {\n\tvar getter = module && module.__esModule ?\n\t\t() => (module['default']) :\n\t\t() => (module);\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.g = (function() {\n\tif (typeof globalThis === 'object') return globalThis;\n\ttry {\n\t\treturn this || new Function('return this')();\n\t} catch (e) {\n\t\tif (typeof window === 'object') return window;\n\t}\n})();","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","import Gumshoe from \"./gumshoe-patched.js\";\n\n////////////////////////////////////////////////////////////////////////////////\n// Scroll Handling\n////////////////////////////////////////////////////////////////////////////////\nvar tocScroll = null;\nvar header = null;\nvar lastScrollTop = document.documentElement.scrollTop;\nconst GO_TO_TOP_OFFSET = 64;\n\nfunction scrollHandlerForHeader(positionY) {\n const headerTop = Math.floor(header.getBoundingClientRect().top);\n\n console.log(`headerTop: ${headerTop}`);\n if (headerTop == 0 && positionY != headerTop) {\n header.classList.add(\"scrolled\");\n } else {\n header.classList.remove(\"scrolled\");\n }\n}\n\nfunction scrollHandlerForBackToTop(positionY) {\n if (positionY < GO_TO_TOP_OFFSET) {\n document.documentElement.classList.remove(\"show-back-to-top\");\n } else {\n if (positionY < lastScrollTop) {\n document.documentElement.classList.add(\"show-back-to-top\");\n } else if (positionY > lastScrollTop) {\n document.documentElement.classList.remove(\"show-back-to-top\");\n }\n }\n lastScrollTop = positionY;\n}\n\nfunction scrollHandlerForTOC(positionY) {\n if (tocScroll === null) {\n return;\n }\n\n // top of page.\n if (positionY == 0) {\n tocScroll.scrollTo(0, 0);\n } else if (\n // bottom of page.\n Math.ceil(positionY) >=\n Math.floor(document.documentElement.scrollHeight - window.innerHeight)\n ) {\n tocScroll.scrollTo(0, tocScroll.scrollHeight);\n } else {\n // somewhere in the middle.\n const current = document.querySelector(\".scroll-current\");\n if (current == null) {\n return;\n }\n\n // https://github.com/pypa/pip/issues/9159 This breaks scroll behaviours.\n // // scroll the currently \"active\" heading in toc, into view.\n // const rect = current.getBoundingClientRect();\n // if (0 > rect.top) {\n // current.scrollIntoView(true); // the argument is \"alignTop\"\n // } else if (rect.bottom > window.innerHeight) {\n // current.scrollIntoView(false);\n // }\n }\n}\n\nfunction scrollHandler(positionY) {\n scrollHandlerForHeader(positionY);\n scrollHandlerForBackToTop(positionY);\n scrollHandlerForTOC(positionY);\n}\n\n////////////////////////////////////////////////////////////////////////////////\n// Theme Toggle\n////////////////////////////////////////////////////////////////////////////////\nfunction setTheme(mode) {\n if (mode !== \"light\" && mode !== \"dark\" && mode !== \"auto\") {\n console.error(`Got invalid theme mode: ${mode}. Resetting to auto.`);\n mode = \"auto\";\n }\n\n document.body.dataset.theme = mode;\n localStorage.setItem(\"theme\", mode);\n console.log(`Changed to ${mode} mode.`);\n}\n\nfunction cycleThemeOnce() {\n const currentTheme = localStorage.getItem(\"theme\") || \"auto\";\n const prefersDark = window.matchMedia(\"(prefers-color-scheme: dark)\").matches;\n\n if (prefersDark) {\n // Auto (dark) -> Light -> Dark\n if (currentTheme === \"auto\") {\n setTheme(\"light\");\n } else if (currentTheme == \"light\") {\n setTheme(\"dark\");\n } else {\n setTheme(\"auto\");\n }\n } else {\n // Auto (light) -> Dark -> Light\n if (currentTheme === \"auto\") {\n setTheme(\"dark\");\n } else if (currentTheme == \"dark\") {\n setTheme(\"light\");\n } else {\n setTheme(\"auto\");\n }\n }\n}\n\n////////////////////////////////////////////////////////////////////////////////\n// Setup\n////////////////////////////////////////////////////////////////////////////////\nfunction setupScrollHandler() {\n // Taken from https://developer.mozilla.org/en-US/docs/Web/API/Document/scroll_event\n let last_known_scroll_position = 0;\n let ticking = false;\n\n window.addEventListener(\"scroll\", function (e) {\n last_known_scroll_position = window.scrollY;\n\n if (!ticking) {\n window.requestAnimationFrame(function () {\n scrollHandler(last_known_scroll_position);\n ticking = false;\n });\n\n ticking = true;\n }\n });\n window.scroll();\n}\n\nfunction setupScrollSpy() {\n if (tocScroll === null) {\n return;\n }\n\n // Scrollspy -- highlight table on contents, based on scroll\n new Gumshoe(\".toc-tree a\", {\n reflow: true,\n recursive: true,\n navClass: \"scroll-current\",\n offset: () => {\n let rem = parseFloat(getComputedStyle(document.documentElement).fontSize);\n return header.getBoundingClientRect().height + 2.5 * rem + 1;\n },\n });\n}\n\nfunction setupTheme() {\n // Attach event handlers for toggling themes\n const buttons = document.getElementsByClassName(\"theme-toggle\");\n Array.from(buttons).forEach((btn) => {\n btn.addEventListener(\"click\", cycleThemeOnce);\n });\n}\n\nfunction setup() {\n setupTheme();\n setupScrollHandler();\n setupScrollSpy();\n}\n\n////////////////////////////////////////////////////////////////////////////////\n// Main entrypoint\n////////////////////////////////////////////////////////////////////////////////\nfunction main() {\n document.body.parentNode.classList.remove(\"no-js\");\n\n header = document.querySelector(\"header\");\n tocScroll = document.querySelector(\".toc-scroll\");\n\n setup();\n}\n\ndocument.addEventListener(\"DOMContentLoaded\", main);\n"],"names":["root","g","window","this","defaults","navClass","contentClass","nested","nestedClass","offset","reflow","events","emitEvent","type","elem","detail","settings","event","CustomEvent","bubbles","cancelable","dispatchEvent","getOffsetTop","location","offsetParent","offsetTop","sortContents","contents","sort","item1","item2","content","isInView","bottom","bounds","getBoundingClientRect","parseFloat","getOffset","parseInt","innerHeight","document","documentElement","clientHeight","top","isAtBottom","Math","ceil","pageYOffset","max","body","scrollHeight","offsetHeight","getActive","last","length","item","useLastItem","i","deactivateNested","nav","parentNode","li","closest","classList","remove","deactivate","items","link","activateNested","add","selector","options","navItems","current","timeout","publicAPIs","querySelectorAll","Array","prototype","forEach","call","getElementById","decodeURIComponent","hash","substr","push","active","activate","scrollHandler","cancelAnimationFrame","requestAnimationFrame","detect","resizeHandler","destroy","removeEventListener","merged","arguments","obj","key","hasOwnProperty","extend","setup","addEventListener","factory","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","undefined","exports","module","__webpack_modules__","n","getter","__esModule","d","a","definition","o","Object","defineProperty","enumerable","get","globalThis","Function","e","prop","tocScroll","header","lastScrollTop","scrollTop","GO_TO_TOP_OFFSET","cycleThemeOnce","currentTheme","localStorage","getItem","mode","matchMedia","matches","console","error","dataset","theme","setItem","log","buttons","getElementsByClassName","from","btn","setupTheme","last_known_scroll_position","ticking","scrollY","positionY","headerTop","floor","scrollHandlerForHeader","scrollHandlerForBackToTop","scrollTo","querySelector","scrollHandlerForTOC","scroll","setupScrollHandler","recursive","rem","getComputedStyle","fontSize","height"],"sourceRoot":""} \ No newline at end of file diff --git a/pr-preview/pr-92/_static/scripts/qiskit-sphinx-theme.js b/pr-preview/pr-92/_static/scripts/qiskit-sphinx-theme.js new file mode 100644 index 0000000..e69de29 diff --git a/pr-preview/pr-92/_static/searchtools.js b/pr-preview/pr-92/_static/searchtools.js new file mode 100644 index 0000000..2c774d1 --- /dev/null +++ b/pr-preview/pr-92/_static/searchtools.js @@ -0,0 +1,632 @@ +/* + * 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); diff --git a/pr-preview/pr-92/_static/skeleton.css b/pr-preview/pr-92/_static/skeleton.css new file mode 100644 index 0000000..467c878 --- /dev/null +++ b/pr-preview/pr-92/_static/skeleton.css @@ -0,0 +1,296 @@ +/* Some sane resets. */ +html { + height: 100%; +} + +body { + margin: 0; + min-height: 100%; +} + +/* All the flexbox magic! */ +body, +.sb-announcement, +.sb-content, +.sb-main, +.sb-container, +.sb-container__inner, +.sb-article-container, +.sb-footer-content, +.sb-header, +.sb-header-secondary, +.sb-footer { + display: flex; +} + +/* These order things vertically */ +body, +.sb-main, +.sb-article-container { + flex-direction: column; +} + +/* Put elements in the center */ +.sb-header, +.sb-header-secondary, +.sb-container, +.sb-content, +.sb-footer, +.sb-footer-content { + justify-content: center; +} +/* Put elements at the ends */ +.sb-article-container { + justify-content: space-between; +} + +/* These elements grow. */ +.sb-main, +.sb-content, +.sb-container, +article { + flex-grow: 1; +} + +/* Because padding making this wider is not fun */ +article { + box-sizing: border-box; +} + +/* The announcements element should never be wider than the page. */ +.sb-announcement { + max-width: 100%; +} + +.sb-sidebar-primary, +.sb-sidebar-secondary { + flex-shrink: 0; + width: 17rem; +} + +.sb-announcement__inner { + justify-content: center; + + box-sizing: border-box; + height: 3rem; + + overflow-x: auto; + white-space: nowrap; +} + +/* Sidebars, with checkbox-based toggle */ +.sb-sidebar-primary, +.sb-sidebar-secondary { + position: fixed; + height: 100%; + top: 0; +} + +.sb-sidebar-primary { + left: -17rem; + transition: left 250ms ease-in-out; +} +.sb-sidebar-secondary { + right: -17rem; + transition: right 250ms ease-in-out; +} + +.sb-sidebar-toggle { + display: none; +} +.sb-sidebar-overlay { + position: fixed; + top: 0; + width: 0; + height: 0; + + transition: width 0ms ease 250ms, height 0ms ease 250ms, opacity 250ms ease; + + opacity: 0; + background-color: rgba(0, 0, 0, 0.54); +} + +#sb-sidebar-toggle--primary:checked + ~ .sb-sidebar-overlay[for="sb-sidebar-toggle--primary"], +#sb-sidebar-toggle--secondary:checked + ~ .sb-sidebar-overlay[for="sb-sidebar-toggle--secondary"] { + width: 100%; + height: 100%; + opacity: 1; + transition: width 0ms ease, height 0ms ease, opacity 250ms ease; +} + +#sb-sidebar-toggle--primary:checked ~ .sb-container .sb-sidebar-primary { + left: 0; +} +#sb-sidebar-toggle--secondary:checked ~ .sb-container .sb-sidebar-secondary { + right: 0; +} + +/* Full-width mode */ +.drop-secondary-sidebar-for-full-width-content + .hide-when-secondary-sidebar-shown { + display: none !important; +} +.drop-secondary-sidebar-for-full-width-content .sb-sidebar-secondary { + display: none !important; +} + +/* Mobile views */ +.sb-page-width { + width: 100%; +} + +.sb-article-container, +.sb-footer-content__inner, +.drop-secondary-sidebar-for-full-width-content .sb-article, +.drop-secondary-sidebar-for-full-width-content .match-content-width { + width: 100vw; +} + +.sb-article, +.match-content-width { + padding: 0 1rem; + box-sizing: border-box; +} + +@media (min-width: 32rem) { + .sb-article, + .match-content-width { + padding: 0 2rem; + } +} + +/* Tablet views */ +@media (min-width: 42rem) { + .sb-article-container { + width: auto; + } + .sb-footer-content__inner, + .drop-secondary-sidebar-for-full-width-content .sb-article, + .drop-secondary-sidebar-for-full-width-content .match-content-width { + width: 42rem; + } + .sb-article, + .match-content-width { + width: 42rem; + } +} +@media (min-width: 46rem) { + .sb-footer-content__inner, + .drop-secondary-sidebar-for-full-width-content .sb-article, + .drop-secondary-sidebar-for-full-width-content .match-content-width { + width: 46rem; + } + .sb-article, + .match-content-width { + width: 46rem; + } +} +@media (min-width: 50rem) { + .sb-footer-content__inner, + .drop-secondary-sidebar-for-full-width-content .sb-article, + .drop-secondary-sidebar-for-full-width-content .match-content-width { + width: 50rem; + } + .sb-article, + .match-content-width { + width: 50rem; + } +} + +/* Tablet views */ +@media (min-width: 59rem) { + .sb-sidebar-secondary { + position: static; + } + .hide-when-secondary-sidebar-shown { + display: none !important; + } + .sb-footer-content__inner, + .drop-secondary-sidebar-for-full-width-content .sb-article, + .drop-secondary-sidebar-for-full-width-content .match-content-width { + width: 59rem; + } + .sb-article, + .match-content-width { + width: 42rem; + } +} +@media (min-width: 63rem) { + .sb-footer-content__inner, + .drop-secondary-sidebar-for-full-width-content .sb-article, + .drop-secondary-sidebar-for-full-width-content .match-content-width { + width: 63rem; + } + .sb-article, + .match-content-width { + width: 46rem; + } +} +@media (min-width: 67rem) { + .sb-footer-content__inner, + .drop-secondary-sidebar-for-full-width-content .sb-article, + .drop-secondary-sidebar-for-full-width-content .match-content-width { + width: 67rem; + } + .sb-article, + .match-content-width { + width: 50rem; + } +} + +/* Desktop views */ +@media (min-width: 76rem) { + .sb-sidebar-primary { + position: static; + } + .hide-when-primary-sidebar-shown { + display: none !important; + } + .sb-footer-content__inner, + .drop-secondary-sidebar-for-full-width-content .sb-article, + .drop-secondary-sidebar-for-full-width-content .match-content-width { + width: 59rem; + } + .sb-article, + .match-content-width { + width: 42rem; + } +} + +/* Full desktop views */ +@media (min-width: 80rem) { + .sb-article, + .match-content-width { + width: 46rem; + } + .sb-footer-content__inner, + .drop-secondary-sidebar-for-full-width-content .sb-article, + .drop-secondary-sidebar-for-full-width-content .match-content-width { + width: 63rem; + } +} + +@media (min-width: 84rem) { + .sb-article, + .match-content-width { + width: 50rem; + } + .sb-footer-content__inner, + .drop-secondary-sidebar-for-full-width-content .sb-article, + .drop-secondary-sidebar-for-full-width-content .match-content-width { + width: 67rem; + } +} + +@media (min-width: 88rem) { + .sb-footer-content__inner, + .drop-secondary-sidebar-for-full-width-content .sb-article, + .drop-secondary-sidebar-for-full-width-content .match-content-width { + width: 67rem; + } + .sb-page-width { + width: 88rem; + } +} diff --git a/pr-preview/pr-92/_static/sphinx_highlight.js b/pr-preview/pr-92/_static/sphinx_highlight.js new file mode 100644 index 0000000..8a96c69 --- /dev/null +++ b/pr-preview/pr-92/_static/sphinx_highlight.js @@ -0,0 +1,154 @@ +/* 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( + '" + ) + ); + }, + + /** + * 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(); +}); diff --git a/pr-preview/pr-92/_static/styles/furo-extensions.css b/pr-preview/pr-92/_static/styles/furo-extensions.css new file mode 100644 index 0000000..8229587 --- /dev/null +++ b/pr-preview/pr-92/_static/styles/furo-extensions.css @@ -0,0 +1,2 @@ +#furo-sidebar-ad-placement{padding:var(--sidebar-item-spacing-vertical) var(--sidebar-item-spacing-horizontal)}#furo-sidebar-ad-placement .ethical-sidebar{background:var(--color-background-secondary);border:none;box-shadow:none}#furo-sidebar-ad-placement .ethical-sidebar:hover{background:var(--color-background-hover)}#furo-sidebar-ad-placement .ethical-sidebar a{color:var(--color-foreground-primary)}#furo-sidebar-ad-placement .ethical-callout a{color:var(--color-foreground-secondary)!important}#furo-readthedocs-versions{background:transparent;display:block;position:static;width:100%}#furo-readthedocs-versions .rst-versions{background:#1a1c1e}#furo-readthedocs-versions .rst-current-version{background:var(--color-sidebar-item-background);cursor:unset}#furo-readthedocs-versions .rst-current-version:hover{background:var(--color-sidebar-item-background)}#furo-readthedocs-versions .rst-current-version .fa-book{color:var(--color-foreground-primary)}#furo-readthedocs-versions>.rst-other-versions{padding:0}#furo-readthedocs-versions>.rst-other-versions small{opacity:1}#furo-readthedocs-versions .injected .rst-versions{position:unset}#furo-readthedocs-versions:focus-within,#furo-readthedocs-versions:hover{box-shadow:0 0 0 1px var(--color-sidebar-background-border)}#furo-readthedocs-versions:focus-within .rst-current-version,#furo-readthedocs-versions:hover .rst-current-version{background:#1a1c1e;font-size:inherit;height:auto;line-height:inherit;padding:12px;text-align:right}#furo-readthedocs-versions:focus-within .rst-current-version .fa-book,#furo-readthedocs-versions:hover .rst-current-version .fa-book{color:#fff;float:left}#furo-readthedocs-versions:focus-within .fa-caret-down,#furo-readthedocs-versions:hover .fa-caret-down{display:none}#furo-readthedocs-versions:focus-within .injected,#furo-readthedocs-versions:focus-within .rst-current-version,#furo-readthedocs-versions:focus-within .rst-other-versions,#furo-readthedocs-versions:hover .injected,#furo-readthedocs-versions:hover .rst-current-version,#furo-readthedocs-versions:hover .rst-other-versions{display:block}#furo-readthedocs-versions:focus-within>.rst-current-version,#furo-readthedocs-versions:hover>.rst-current-version{display:none}.highlight:hover button.copybtn{color:var(--color-code-foreground)}.highlight button.copybtn{align-items:center;background-color:var(--color-code-background);border:none;color:var(--color-background-item);cursor:pointer;height:1.25em;right:.5rem;top:.625rem;transition:color .3s,opacity .3s;width:1.25em}.highlight button.copybtn:hover{background-color:var(--color-code-background);color:var(--color-brand-content)}.highlight button.copybtn:after{background-color:transparent;color:var(--color-code-foreground);display:none}.highlight button.copybtn.success{color:#22863a;transition:color 0ms}.highlight button.copybtn.success:after{display:block}.highlight button.copybtn svg{padding:0}body{--sd-color-primary:var(--color-brand-primary);--sd-color-primary-highlight:var(--color-brand-content);--sd-color-primary-text:var(--color-background-primary);--sd-color-shadow:rgba(0,0,0,.05);--sd-color-card-border:var(--color-card-border);--sd-color-card-border-hover:var(--color-brand-content);--sd-color-card-background:var(--color-card-background);--sd-color-card-text:var(--color-foreground-primary);--sd-color-card-header:var(--color-card-marginals-background);--sd-color-card-footer:var(--color-card-marginals-background);--sd-color-tabs-label-active:var(--color-brand-content);--sd-color-tabs-label-hover:var(--color-foreground-muted);--sd-color-tabs-label-inactive:var(--color-foreground-muted);--sd-color-tabs-underline-active:var(--color-brand-content);--sd-color-tabs-underline-hover:var(--color-foreground-border);--sd-color-tabs-underline-inactive:var(--color-background-border);--sd-color-tabs-overline:var(--color-background-border);--sd-color-tabs-underline:var(--color-background-border)}.sd-tab-content{box-shadow:0 -2px var(--sd-color-tabs-overline),0 1px var(--sd-color-tabs-underline)}.sd-card{box-shadow:0 .1rem .25rem var(--sd-color-shadow),0 0 .0625rem rgba(0,0,0,.1)}.sd-shadow-sm{box-shadow:0 .1rem .25rem var(--sd-color-shadow),0 0 .0625rem rgba(0,0,0,.1)!important}.sd-shadow-md{box-shadow:0 .3rem .75rem var(--sd-color-shadow),0 0 .0625rem rgba(0,0,0,.1)!important}.sd-shadow-lg{box-shadow:0 .6rem 1.5rem var(--sd-color-shadow),0 0 .0625rem rgba(0,0,0,.1)!important}.sd-card-hover:hover{transform:none}.sd-cards-carousel{gap:.25rem;padding:.25rem}body{--tabs--label-text:var(--color-foreground-muted);--tabs--label-text--hover:var(--color-foreground-muted);--tabs--label-text--active:var(--color-brand-content);--tabs--label-text--active--hover:var(--color-brand-content);--tabs--label-background:transparent;--tabs--label-background--hover:transparent;--tabs--label-background--active:transparent;--tabs--label-background--active--hover:transparent;--tabs--padding-x:0.25em;--tabs--margin-x:1em;--tabs--border:var(--color-background-border);--tabs--label-border:transparent;--tabs--label-border--hover:var(--color-foreground-muted);--tabs--label-border--active:var(--color-brand-content);--tabs--label-border--active--hover:var(--color-brand-content)}[role=main] .container{max-width:none;padding-left:0;padding-right:0}.shadow.docutils{border:none;box-shadow:0 .2rem .5rem rgba(0,0,0,.05),0 0 .0625rem rgba(0,0,0,.1)!important}.sphinx-bs .card{background-color:var(--color-background-secondary);color:var(--color-foreground)} +/*# sourceMappingURL=furo-extensions.css.map*/ \ No newline at end of file diff --git a/pr-preview/pr-92/_static/styles/furo-extensions.css.map b/pr-preview/pr-92/_static/styles/furo-extensions.css.map new file mode 100644 index 0000000..c26eac7 --- /dev/null +++ b/pr-preview/pr-92/_static/styles/furo-extensions.css.map @@ -0,0 +1 @@ +{"version":3,"file":"styles/furo-extensions.css","mappings":"AAGA,2BACE,oFACA,4CAKE,6CAHA,YACA,eAEA,CACA,kDACE,yCAEF,8CACE,sCAEJ,8CACE,kDAEJ,2BAGE,uBACA,cAHA,gBACA,UAEA,CAGA,yCACE,mBAEF,gDAEE,gDADA,YACA,CACA,sDACE,gDACF,yDACE,sCAEJ,+CACE,UACA,qDACE,UAGF,mDACE,eAEJ,yEAEE,4DAEA,mHASE,mBAPA,kBAEA,YADA,oBAGA,aADA,gBAIA,CAEA,qIAEE,WADA,UACA,CAEJ,uGACE,aAEF,iUAGE,cAEF,mHACE,aC1EJ,gCACE,mCAEF,0BAEE,mBAUA,8CACA,YAFA,mCAKA,eAZA,cAIA,YADA,YAYA,iCAdA,YAcA,CAEA,gCAEE,8CADA,gCACA,CAEF,gCAGE,6BADA,mCADA,YAEA,CAEF,kCAEE,cADA,oBACA,CACA,wCACE,cAEJ,8BACE,UCzCN,KAEE,6CAA8C,CAC9C,uDAAwD,CACxD,uDAAwD,CAGxD,iCAAsC,CAGtC,+CAAgD,CAChD,uDAAwD,CACxD,uDAAwD,CACxD,oDAAqD,CACrD,6DAA8D,CAC9D,6DAA8D,CAG9D,uDAAwD,CACxD,yDAA0D,CAC1D,4DAA6D,CAC7D,2DAA4D,CAC5D,8DAA+D,CAC/D,iEAAkE,CAClE,uDAAwD,CACxD,wDAAyD,CAG3D,gBACE,qFAGF,SACE,6EAEF,cACE,uFAEF,cACE,uFAEF,cACE,uFAGF,qBACE,eAEF,mBACE,WACA,eChDF,KACE,gDAAiD,CACjD,uDAAwD,CACxD,qDAAsD,CACtD,4DAA6D,CAC7D,oCAAqC,CACrC,2CAA4C,CAC5C,4CAA6C,CAC7C,mDAAoD,CACpD,wBAAyB,CACzB,oBAAqB,CACrB,6CAA8C,CAC9C,gCAAiC,CACjC,yDAA0D,CAC1D,uDAAwD,CACxD,8DAA+D,CCbjE,uBACE,eACA,eACA,gBAGF,iBACE,YACA,+EAGF,iBACE,mDACA","sources":["webpack:///./src/furo/assets/styles/extensions/_readthedocs.sass","webpack:///./src/furo/assets/styles/extensions/_copybutton.sass","webpack:///./src/furo/assets/styles/extensions/_sphinx-design.sass","webpack:///./src/furo/assets/styles/extensions/_sphinx-inline-tabs.sass","webpack:///./src/furo/assets/styles/extensions/_sphinx-panels.sass"],"sourcesContent":["// This file contains the styles used for tweaking how ReadTheDoc's embedded\n// contents would show up inside the theme.\n\n#furo-sidebar-ad-placement\n padding: var(--sidebar-item-spacing-vertical) var(--sidebar-item-spacing-horizontal)\n .ethical-sidebar\n // Remove the border and box-shadow.\n border: none\n box-shadow: none\n // Manage the background colors.\n background: var(--color-background-secondary)\n &:hover\n background: var(--color-background-hover)\n // Ensure the text is legible.\n a\n color: var(--color-foreground-primary)\n\n .ethical-callout a\n color: var(--color-foreground-secondary) !important\n\n#furo-readthedocs-versions\n position: static\n width: 100%\n background: transparent\n display: block\n\n // Make the background color fit with the theme's aesthetic.\n .rst-versions\n background: rgb(26, 28, 30)\n\n .rst-current-version\n cursor: unset\n background: var(--color-sidebar-item-background)\n &:hover\n background: var(--color-sidebar-item-background)\n .fa-book\n color: var(--color-foreground-primary)\n\n > .rst-other-versions\n padding: 0\n small\n opacity: 1\n\n .injected\n .rst-versions\n position: unset\n\n &:hover,\n &:focus-within\n box-shadow: 0 0 0 1px var(--color-sidebar-background-border)\n\n .rst-current-version\n // Undo the tweaks done in RTD's CSS\n font-size: inherit\n line-height: inherit\n height: auto\n text-align: right\n padding: 12px\n\n // Match the rest of the body\n background: #1a1c1e\n\n .fa-book\n float: left\n color: white\n\n .fa-caret-down\n display: none\n\n .rst-current-version,\n .rst-other-versions,\n .injected\n display: block\n\n > .rst-current-version\n display: none\n",".highlight\n &:hover button.copybtn\n color: var(--color-code-foreground)\n\n button.copybtn\n // Align things correctly\n align-items: center\n\n height: 1.25em\n width: 1.25em\n\n top: 0.625rem // $code-spacing-vertical\n right: 0.5rem\n\n // Make it look better\n color: var(--color-background-item)\n background-color: var(--color-code-background)\n border: none\n\n // Change to cursor to make it obvious that you can click on it\n cursor: pointer\n\n // Transition smoothly, for aesthetics\n transition: color 300ms, opacity 300ms\n\n &:hover\n color: var(--color-brand-content)\n background-color: var(--color-code-background)\n\n &::after\n display: none\n color: var(--color-code-foreground)\n background-color: transparent\n\n &.success\n transition: color 0ms\n color: #22863a\n &::after\n display: block\n\n svg\n padding: 0\n","body\n // Colors\n --sd-color-primary: var(--color-brand-primary)\n --sd-color-primary-highlight: var(--color-brand-content)\n --sd-color-primary-text: var(--color-background-primary)\n\n // Shadows\n --sd-color-shadow: rgba(0, 0, 0, 0.05)\n\n // Cards\n --sd-color-card-border: var(--color-card-border)\n --sd-color-card-border-hover: var(--color-brand-content)\n --sd-color-card-background: var(--color-card-background)\n --sd-color-card-text: var(--color-foreground-primary)\n --sd-color-card-header: var(--color-card-marginals-background)\n --sd-color-card-footer: var(--color-card-marginals-background)\n\n // Tabs\n --sd-color-tabs-label-active: var(--color-brand-content)\n --sd-color-tabs-label-hover: var(--color-foreground-muted)\n --sd-color-tabs-label-inactive: var(--color-foreground-muted)\n --sd-color-tabs-underline-active: var(--color-brand-content)\n --sd-color-tabs-underline-hover: var(--color-foreground-border)\n --sd-color-tabs-underline-inactive: var(--color-background-border)\n --sd-color-tabs-overline: var(--color-background-border)\n --sd-color-tabs-underline: var(--color-background-border)\n\n// Tabs\n.sd-tab-content\n box-shadow: 0 -2px var(--sd-color-tabs-overline), 0 1px var(--sd-color-tabs-underline)\n\n// Shadows\n.sd-card // Have a shadow by default\n box-shadow: 0 0.1rem 0.25rem var(--sd-color-shadow), 0 0 0.0625rem rgba(0, 0, 0, 0.1)\n\n.sd-shadow-sm\n box-shadow: 0 0.1rem 0.25rem var(--sd-color-shadow), 0 0 0.0625rem rgba(0, 0, 0, 0.1) !important\n\n.sd-shadow-md\n box-shadow: 0 0.3rem 0.75rem var(--sd-color-shadow), 0 0 0.0625rem rgba(0, 0, 0, 0.1) !important\n\n.sd-shadow-lg\n box-shadow: 0 0.6rem 1.5rem var(--sd-color-shadow), 0 0 0.0625rem rgba(0, 0, 0, 0.1) !important\n\n// Cards\n.sd-card-hover:hover // Don't change scale on hover\n transform: none\n\n.sd-cards-carousel // Have a bit of gap in the carousel by default\n gap: 0.25rem\n padding: 0.25rem\n","// This file contains styles to tweak sphinx-inline-tabs to work well with Furo.\n\nbody\n --tabs--label-text: var(--color-foreground-muted)\n --tabs--label-text--hover: var(--color-foreground-muted)\n --tabs--label-text--active: var(--color-brand-content)\n --tabs--label-text--active--hover: var(--color-brand-content)\n --tabs--label-background: transparent\n --tabs--label-background--hover: transparent\n --tabs--label-background--active: transparent\n --tabs--label-background--active--hover: transparent\n --tabs--padding-x: 0.25em\n --tabs--margin-x: 1em\n --tabs--border: var(--color-background-border)\n --tabs--label-border: transparent\n --tabs--label-border--hover: var(--color-foreground-muted)\n --tabs--label-border--active: var(--color-brand-content)\n --tabs--label-border--active--hover: var(--color-brand-content)\n","// This file contains styles to tweak sphinx-panels to work well with Furo.\n\n// sphinx-panels includes Bootstrap 4, which uses .container which can conflict\n// with docutils' `.. container::` directive.\n[role=\"main\"] .container\n max-width: initial\n padding-left: initial\n padding-right: initial\n\n// Make the panels look nicer!\n.shadow.docutils\n border: none\n box-shadow: 0 0.2rem 0.5rem rgba(0, 0, 0, 0.05), 0 0 0.0625rem rgba(0, 0, 0, 0.1) !important\n\n// Make panel colors respond to dark mode\n.sphinx-bs .card\n background-color: var(--color-background-secondary)\n color: var(--color-foreground)\n"],"names":[],"sourceRoot":""} \ No newline at end of file diff --git a/pr-preview/pr-92/_static/styles/furo.css b/pr-preview/pr-92/_static/styles/furo.css new file mode 100644 index 0000000..05a56b1 --- /dev/null +++ b/pr-preview/pr-92/_static/styles/furo.css @@ -0,0 +1,2 @@ +/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */html{line-height:1.15;-webkit-text-size-adjust:100%}body{margin:0}main{display:block}h1{font-size:2em;margin:.67em 0}hr{box-sizing:content-box;height:0;overflow:visible}pre{font-family:monospace,monospace;font-size:1em}a{background-color:transparent}abbr[title]{border-bottom:none;text-decoration:underline;text-decoration:underline dotted}b,strong{font-weight:bolder}code,kbd,samp{font-family:monospace,monospace;font-size:1em}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}img{border-style:none}button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;line-height:1.15;margin:0}button,input{overflow:visible}button,select{text-transform:none}[type=button],[type=reset],[type=submit],button{-webkit-appearance:button}[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner,button::-moz-focus-inner{border-style:none;padding:0}[type=button]:-moz-focusring,[type=reset]:-moz-focusring,[type=submit]:-moz-focusring,button:-moz-focusring{outline:1px dotted ButtonText}fieldset{padding:.35em .75em .625em}legend{box-sizing:border-box;color:inherit;display:table;max-width:100%;padding:0;white-space:normal}progress{vertical-align:baseline}textarea{overflow:auto}[type=checkbox],[type=radio]{box-sizing:border-box;padding:0}[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}[type=search]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}details{display:block}summary{display:list-item}[hidden],template{display:none}@media print{.content-icon-container,.headerlink,.mobile-header,.related-pages{display:none!important}.highlight{border:.1pt solid var(--color-foreground-border)}a,blockquote,dl,ol,p,pre,table,ul{page-break-inside:avoid}caption,figure,h1,h2,h3,h4,h5,h6,img{page-break-after:avoid;page-break-inside:avoid}dl,ol,ul{page-break-before:avoid}}.visually-hidden{height:1px!important;margin:-1px!important;overflow:hidden!important;padding:0!important;position:absolute!important;width:1px!important;clip:rect(0,0,0,0)!important;background:var(--color-background-primary);border:0!important;color:var(--color-foreground-primary);white-space:nowrap!important}:-moz-focusring{outline:auto}body{--font-stack:-apple-system,BlinkMacSystemFont,Segoe UI,Helvetica,Arial,sans-serif,Apple Color Emoji,Segoe UI Emoji;--font-stack--monospace:"SFMono-Regular",Menlo,Consolas,Monaco,Liberation Mono,Lucida Console,monospace;--font-stack--headings:var(--font-stack);--font-size--normal:100%;--font-size--small:87.5%;--font-size--small--2:81.25%;--font-size--small--3:75%;--font-size--small--4:62.5%;--sidebar-caption-font-size:var(--font-size--small--2);--sidebar-item-font-size:var(--font-size--small);--sidebar-search-input-font-size:var(--font-size--small);--toc-font-size:var(--font-size--small--3);--toc-font-size--mobile:var(--font-size--normal);--toc-title-font-size:var(--font-size--small--4);--admonition-font-size:0.8125rem;--admonition-title-font-size:0.8125rem;--code-font-size:var(--font-size--small--2);--api-font-size:var(--font-size--small);--header-height:calc(var(--sidebar-item-line-height) + var(--sidebar-item-spacing-vertical)*4);--header-padding:0.5rem;--sidebar-tree-space-above:1.5rem;--sidebar-caption-space-above:1rem;--sidebar-item-line-height:1rem;--sidebar-item-spacing-vertical:0.5rem;--sidebar-item-spacing-horizontal:1rem;--sidebar-item-height:calc(var(--sidebar-item-line-height) + var(--sidebar-item-spacing-vertical)*2);--sidebar-expander-width:var(--sidebar-item-height);--sidebar-search-space-above:0.5rem;--sidebar-search-input-spacing-vertical:0.5rem;--sidebar-search-input-spacing-horizontal:0.5rem;--sidebar-search-input-height:1rem;--sidebar-search-icon-size:var(--sidebar-search-input-height);--toc-title-padding:0.25rem 0;--toc-spacing-vertical:1.5rem;--toc-spacing-horizontal:1.5rem;--toc-item-spacing-vertical:0.4rem;--toc-item-spacing-horizontal:1rem;--icon-search:url('data:image/svg+xml;charset=utf-8,');--icon-pencil:url('data:image/svg+xml;charset=utf-8,');--icon-abstract:url('data:image/svg+xml;charset=utf-8,');--icon-info:url('data:image/svg+xml;charset=utf-8,');--icon-flame:url('data:image/svg+xml;charset=utf-8,');--icon-question:url('data:image/svg+xml;charset=utf-8,');--icon-warning:url('data:image/svg+xml;charset=utf-8,');--icon-failure:url('data:image/svg+xml;charset=utf-8,');--icon-spark:url('data:image/svg+xml;charset=utf-8,');--color-admonition-title--caution:#ff9100;--color-admonition-title-background--caution:rgba(255,145,0,.2);--color-admonition-title--warning:#ff9100;--color-admonition-title-background--warning:rgba(255,145,0,.2);--color-admonition-title--danger:#ff5252;--color-admonition-title-background--danger:rgba(255,82,82,.2);--color-admonition-title--attention:#ff5252;--color-admonition-title-background--attention:rgba(255,82,82,.2);--color-admonition-title--error:#ff5252;--color-admonition-title-background--error:rgba(255,82,82,.2);--color-admonition-title--hint:#00c852;--color-admonition-title-background--hint:rgba(0,200,82,.2);--color-admonition-title--tip:#00c852;--color-admonition-title-background--tip:rgba(0,200,82,.2);--color-admonition-title--important:#00bfa5;--color-admonition-title-background--important:rgba(0,191,165,.2);--color-admonition-title--note:#00b0ff;--color-admonition-title-background--note:rgba(0,176,255,.2);--color-admonition-title--seealso:#448aff;--color-admonition-title-background--seealso:rgba(68,138,255,.2);--color-admonition-title--admonition-todo:grey;--color-admonition-title-background--admonition-todo:hsla(0,0%,50%,.2);--color-admonition-title:#651fff;--color-admonition-title-background:rgba(101,31,255,.2);--icon-admonition-default:var(--icon-abstract);--color-topic-title:#14b8a6;--color-topic-title-background:rgba(20,184,166,.2);--icon-topic-default:var(--icon-pencil);--color-problematic:#b30000;--color-foreground-primary:#000;--color-foreground-secondary:#5a5c63;--color-foreground-muted:#6b6f76;--color-foreground-border:#878787;--color-background-primary:#fff;--color-background-secondary:#f8f9fb;--color-background-hover:#efeff4;--color-background-hover--transparent:#efeff400;--color-background-border:#eeebee;--color-background-item:#ccc;--color-announcement-background:#000000dd;--color-announcement-text:#eeebee;--color-brand-primary:#0a4bff;--color-brand-content:#2757dd;--color-brand-visited:#872ee0;--color-api-background:var(--color-background-hover--transparent);--color-api-background-hover:var(--color-background-hover);--color-api-overall:var(--color-foreground-secondary);--color-api-name:var(--color-problematic);--color-api-pre-name:var(--color-problematic);--color-api-paren:var(--color-foreground-secondary);--color-api-keyword:var(--color-foreground-primary);--color-api-added:#21632c;--color-api-added-border:#38a84d;--color-api-changed:#046172;--color-api-changed-border:#06a1bc;--color-api-deprecated:#605706;--color-api-deprecated-border:#f0d90f;--color-api-removed:#b30000;--color-api-removed-border:#ff5c5c;--color-highlight-on-target:#ffc;--color-inline-code-background:var(--color-background-secondary);--color-highlighted-background:#def;--color-highlighted-text:var(--color-foreground-primary);--color-guilabel-background:#ddeeff80;--color-guilabel-border:#bedaf580;--color-guilabel-text:var(--color-foreground-primary);--color-admonition-background:transparent;--color-table-header-background:var(--color-background-secondary);--color-table-border:var(--color-background-border);--color-card-border:var(--color-background-secondary);--color-card-background:transparent;--color-card-marginals-background:var(--color-background-secondary);--color-header-background:var(--color-background-primary);--color-header-border:var(--color-background-border);--color-header-text:var(--color-foreground-primary);--color-sidebar-background:var(--color-background-secondary);--color-sidebar-background-border:var(--color-background-border);--color-sidebar-brand-text:var(--color-foreground-primary);--color-sidebar-caption-text:var(--color-foreground-muted);--color-sidebar-link-text:var(--color-foreground-secondary);--color-sidebar-link-text--top-level:var(--color-brand-primary);--color-sidebar-item-background:var(--color-sidebar-background);--color-sidebar-item-background--current:var( --color-sidebar-item-background );--color-sidebar-item-background--hover:linear-gradient(90deg,var(--color-background-hover--transparent) 0%,var(--color-background-hover) var(--sidebar-item-spacing-horizontal),var(--color-background-hover) 100%);--color-sidebar-item-expander-background:transparent;--color-sidebar-item-expander-background--hover:var( --color-background-hover );--color-sidebar-search-text:var(--color-foreground-primary);--color-sidebar-search-background:var(--color-background-secondary);--color-sidebar-search-background--focus:var(--color-background-primary);--color-sidebar-search-border:var(--color-background-border);--color-sidebar-search-icon:var(--color-foreground-muted);--color-toc-background:var(--color-background-primary);--color-toc-title-text:var(--color-foreground-muted);--color-toc-item-text:var(--color-foreground-secondary);--color-toc-item-text--hover:var(--color-foreground-primary);--color-toc-item-text--active:var(--color-brand-primary);--color-content-foreground:var(--color-foreground-primary);--color-content-background:transparent;--color-link:var(--color-brand-content);--color-link-underline:var(--color-background-border);--color-link--hover:var(--color-brand-content);--color-link-underline--hover:var(--color-foreground-border);--color-link--visited:var(--color-brand-visited);--color-link-underline--visited:var(--color-background-border);--color-link--visited--hover:var(--color-brand-visited);--color-link-underline--visited--hover:var(--color-foreground-border)}.only-light{display:block!important}html body .only-dark{display:none!important}@media not print{body[data-theme=dark]{--color-problematic:#ee5151;--color-foreground-primary:#cfd0d0;--color-foreground-secondary:#9ca0a5;--color-foreground-muted:#81868d;--color-foreground-border:#666;--color-background-primary:#131416;--color-background-secondary:#1a1c1e;--color-background-hover:#1e2124;--color-background-hover--transparent:#1e212400;--color-background-border:#303335;--color-background-item:#444;--color-announcement-background:#000000dd;--color-announcement-text:#eeebee;--color-brand-primary:#3d94ff;--color-brand-content:#5ca5ff;--color-brand-visited:#b27aeb;--color-highlighted-background:#083563;--color-guilabel-background:#08356380;--color-guilabel-border:#13395f80;--color-api-keyword:var(--color-foreground-secondary);--color-highlight-on-target:#330;--color-api-added:#3db854;--color-api-added-border:#267334;--color-api-changed:#09b0ce;--color-api-changed-border:#056d80;--color-api-deprecated:#b1a10b;--color-api-deprecated-border:#6e6407;--color-api-removed:#ff7575;--color-api-removed-border:#b03b3b;--color-admonition-background:#18181a;--color-card-border:var(--color-background-secondary);--color-card-background:#18181a;--color-card-marginals-background:var(--color-background-hover)}html body[data-theme=dark] .only-light{display:none!important}body[data-theme=dark] .only-dark{display:block!important}@media(prefers-color-scheme:dark){body:not([data-theme=light]){--color-problematic:#ee5151;--color-foreground-primary:#cfd0d0;--color-foreground-secondary:#9ca0a5;--color-foreground-muted:#81868d;--color-foreground-border:#666;--color-background-primary:#131416;--color-background-secondary:#1a1c1e;--color-background-hover:#1e2124;--color-background-hover--transparent:#1e212400;--color-background-border:#303335;--color-background-item:#444;--color-announcement-background:#000000dd;--color-announcement-text:#eeebee;--color-brand-primary:#3d94ff;--color-brand-content:#5ca5ff;--color-brand-visited:#b27aeb;--color-highlighted-background:#083563;--color-guilabel-background:#08356380;--color-guilabel-border:#13395f80;--color-api-keyword:var(--color-foreground-secondary);--color-highlight-on-target:#330;--color-api-added:#3db854;--color-api-added-border:#267334;--color-api-changed:#09b0ce;--color-api-changed-border:#056d80;--color-api-deprecated:#b1a10b;--color-api-deprecated-border:#6e6407;--color-api-removed:#ff7575;--color-api-removed-border:#b03b3b;--color-admonition-background:#18181a;--color-card-border:var(--color-background-secondary);--color-card-background:#18181a;--color-card-marginals-background:var(--color-background-hover)}html body:not([data-theme=light]) .only-light{display:none!important}body:not([data-theme=light]) .only-dark{display:block!important}}}body[data-theme=auto] .theme-toggle svg.theme-icon-when-auto-light{display:block}@media(prefers-color-scheme:dark){body[data-theme=auto] .theme-toggle svg.theme-icon-when-auto-dark{display:block}body[data-theme=auto] .theme-toggle svg.theme-icon-when-auto-light{display:none}}body[data-theme=dark] .theme-toggle svg.theme-icon-when-dark,body[data-theme=light] .theme-toggle svg.theme-icon-when-light{display:block}body{font-family:var(--font-stack)}code,kbd,pre,samp{font-family:var(--font-stack--monospace)}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}article{line-height:1.5}h1,h2,h3,h4,h5,h6{border-radius:.5rem;font-family:var(--font-stack--headings);font-weight:700;line-height:1.25;margin:.5rem -.5rem;padding-left:.5rem;padding-right:.5rem}h1+p,h2+p,h3+p,h4+p,h5+p,h6+p{margin-top:0}h1{font-size:2.5em;margin-bottom:1rem}h1,h2{margin-top:1.75rem}h2{font-size:2em}h3{font-size:1.5em}h4{font-size:1.25em}h5{font-size:1.125em}h6{font-size:1em}small{font-size:80%;opacity:75%}p{margin-bottom:.75rem;margin-top:.5rem}hr.docutils{background-color:var(--color-background-border);border:0;height:1px;margin:2rem 0;padding:0}.centered{text-align:center}a{color:var(--color-link);text-decoration:underline;text-decoration-color:var(--color-link-underline)}a:visited{color:var(--color-link--visited);text-decoration-color:var(--color-link-underline--visited)}a:visited:hover{color:var(--color-link--visited--hover);text-decoration-color:var(--color-link-underline--visited--hover)}a:hover{color:var(--color-link--hover);text-decoration-color:var(--color-link-underline--hover)}a.muted-link{color:inherit}a.muted-link:hover{color:var(--color-link--hover);text-decoration-color:var(--color-link-underline--hover)}a.muted-link:hover:visited{color:var(--color-link--visited--hover);text-decoration-color:var(--color-link-underline--visited--hover)}html{overflow-x:hidden;overflow-y:scroll;scroll-behavior:smooth}.sidebar-scroll,.toc-scroll,article[role=main] *{scrollbar-color:var(--color-foreground-border) transparent;scrollbar-width:thin}.sidebar-scroll::-webkit-scrollbar,.toc-scroll::-webkit-scrollbar,article[role=main] ::-webkit-scrollbar{height:.25rem;width:.25rem}.sidebar-scroll::-webkit-scrollbar-thumb,.toc-scroll::-webkit-scrollbar-thumb,article[role=main] ::-webkit-scrollbar-thumb{background-color:var(--color-foreground-border);border-radius:.125rem}body,html{height:100%}.skip-to-content,body,html{background:var(--color-background-primary);color:var(--color-foreground-primary)}.skip-to-content{border-radius:1rem;left:.25rem;padding:1rem;position:fixed;top:.25rem;transform:translateY(-200%);transition:transform .3s ease-in-out;z-index:40}.skip-to-content:focus-within{transform:translateY(0)}article{background:var(--color-content-background);color:var(--color-content-foreground);overflow-wrap:break-word}.page{display:flex;min-height:100%}.mobile-header{background-color:var(--color-header-background);border-bottom:1px solid var(--color-header-border);color:var(--color-header-text);display:none;height:var(--header-height);width:100%;z-index:10}.mobile-header.scrolled{border-bottom:none;box-shadow:0 0 .2rem rgba(0,0,0,.1),0 .2rem .4rem rgba(0,0,0,.2)}.mobile-header .header-center a{color:var(--color-header-text);text-decoration:none}.main{display:flex;flex:1}.sidebar-drawer{background:var(--color-sidebar-background);border-right:1px solid var(--color-sidebar-background-border);box-sizing:border-box;display:flex;justify-content:flex-end;min-width:15em;width:calc(50% - 26em)}.sidebar-container,.toc-drawer{box-sizing:border-box;width:15em}.toc-drawer{background:var(--color-toc-background);padding-right:1rem}.sidebar-sticky,.toc-sticky{display:flex;flex-direction:column;height:min(100%,100vh);height:100vh;position:sticky;top:0}.sidebar-scroll,.toc-scroll{flex-grow:1;flex-shrink:1;overflow:auto;scroll-behavior:smooth}.content{display:flex;flex-direction:column;justify-content:space-between;padding:0 3em;width:46em}.icon{display:inline-block;height:1rem;width:1rem}.icon svg{height:100%;width:100%}.announcement{align-items:center;background-color:var(--color-announcement-background);color:var(--color-announcement-text);display:flex;height:var(--header-height);overflow-x:auto}.announcement+.page{min-height:calc(100% - var(--header-height))}.announcement-content{box-sizing:border-box;min-width:100%;padding:.5rem;text-align:center;white-space:nowrap}.announcement-content a{color:var(--color-announcement-text);text-decoration-color:var(--color-announcement-text)}.announcement-content a:hover{color:var(--color-announcement-text);text-decoration-color:var(--color-link--hover)}.no-js .theme-toggle-container{display:none}.theme-toggle-container{display:flex}.theme-toggle{background:transparent;border:none;cursor:pointer;display:flex;padding:0}.theme-toggle svg{color:var(--color-foreground-primary);display:none;height:1.25rem;width:1.25rem}.theme-toggle-header{align-items:center;display:flex;justify-content:center}.nav-overlay-icon,.toc-overlay-icon{cursor:pointer;display:none}.nav-overlay-icon .icon,.toc-overlay-icon .icon{color:var(--color-foreground-secondary);height:1.5rem;width:1.5rem}.nav-overlay-icon,.toc-header-icon{align-items:center;justify-content:center}.toc-content-icon{height:1.5rem;width:1.5rem}.content-icon-container{display:flex;float:right;gap:.5rem;margin-bottom:1rem;margin-left:1rem;margin-top:1.5rem}.content-icon-container .edit-this-page svg,.content-icon-container .view-this-page svg{color:inherit;height:1.25rem;width:1.25rem}.sidebar-toggle{display:none;position:absolute}.sidebar-toggle[name=__toc]{left:20px}.sidebar-toggle:checked{left:40px}.overlay{background-color:rgba(0,0,0,.54);height:0;opacity:0;position:fixed;top:0;transition:width 0ms,height 0ms,opacity .25s ease-out;width:0}.sidebar-overlay{z-index:20}.toc-overlay{z-index:40}.sidebar-drawer{transition:left .25s ease-in-out;z-index:30}.toc-drawer{transition:right .25s ease-in-out;z-index:50}#__navigation:checked~.sidebar-overlay{height:100%;opacity:1;width:100%}#__navigation:checked~.page .sidebar-drawer{left:0;top:0}#__toc:checked~.toc-overlay{height:100%;opacity:1;width:100%}#__toc:checked~.page .toc-drawer{right:0;top:0}.back-to-top{background:var(--color-background-primary);border-radius:1rem;box-shadow:0 .2rem .5rem rgba(0,0,0,.05),0 0 1px 0 hsla(220,9%,46%,.502);display:none;font-size:.8125rem;left:0;margin-left:50%;padding:.5rem .75rem .5rem .5rem;position:fixed;text-decoration:none;top:1rem;transform:translateX(-50%);z-index:10}.back-to-top svg{height:1rem;width:1rem;fill:currentColor;display:inline-block}.back-to-top span{margin-left:.25rem}.show-back-to-top .back-to-top{align-items:center;display:flex}@media(min-width:97em){html{font-size:110%}}@media(max-width:82em){.toc-content-icon{display:flex}.toc-drawer{border-left:1px solid var(--color-background-muted);height:100vh;position:fixed;right:-15em;top:0}.toc-tree{border-left:none;font-size:var(--toc-font-size--mobile)}.sidebar-drawer{width:calc(50% - 18.5em)}}@media(max-width:67em){.content{margin-left:auto;margin-right:auto;padding:0 1em}}@media(max-width:63em){.nav-overlay-icon{display:flex}.sidebar-drawer{height:100vh;left:-15em;position:fixed;top:0;width:15em}.theme-toggle-header,.toc-header-icon{display:flex}.theme-toggle-content,.toc-content-icon{display:none}.mobile-header{align-items:center;display:flex;justify-content:space-between;position:sticky;top:0}.mobile-header .header-left,.mobile-header .header-right{display:flex;height:var(--header-height);padding:0 var(--header-padding)}.mobile-header .header-left label,.mobile-header .header-right label{height:100%;-webkit-user-select:none;-moz-user-select:none;user-select:none;width:100%}.nav-overlay-icon .icon,.theme-toggle svg{height:1.5rem;width:1.5rem}:target{scroll-margin-top:calc(var(--header-height) + 2.5rem)}.back-to-top{top:calc(var(--header-height) + .5rem)}.page{flex-direction:column;justify-content:center}}@media(max-width:48em){.content{overflow-x:auto;width:100%}}@media(max-width:46em){article[role=main] aside.sidebar{float:none;margin:1rem 0;width:100%}}.admonition,.topic{background:var(--color-admonition-background);border-radius:.2rem;box-shadow:0 .2rem .5rem rgba(0,0,0,.05),0 0 .0625rem rgba(0,0,0,.1);font-size:var(--admonition-font-size);margin:1rem auto;overflow:hidden;padding:0 .5rem .5rem;page-break-inside:avoid}.admonition>:nth-child(2),.topic>:nth-child(2){margin-top:0}.admonition>:last-child,.topic>:last-child{margin-bottom:0}.admonition p.admonition-title,p.topic-title{font-size:var(--admonition-title-font-size);font-weight:500;line-height:1.3;margin:0 -.5rem .5rem;padding:.4rem .5rem .4rem 2rem;position:relative}.admonition p.admonition-title:before,p.topic-title:before{content:"";height:1rem;left:.5rem;position:absolute;width:1rem}p.admonition-title{background-color:var(--color-admonition-title-background)}p.admonition-title:before{background-color:var(--color-admonition-title);-webkit-mask-image:var(--icon-admonition-default);mask-image:var(--icon-admonition-default);-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat}p.topic-title{background-color:var(--color-topic-title-background)}p.topic-title:before{background-color:var(--color-topic-title);-webkit-mask-image:var(--icon-topic-default);mask-image:var(--icon-topic-default);-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat}.admonition{border-left:.2rem solid var(--color-admonition-title)}.admonition.caution{border-left-color:var(--color-admonition-title--caution)}.admonition.caution>.admonition-title{background-color:var(--color-admonition-title-background--caution)}.admonition.caution>.admonition-title:before{background-color:var(--color-admonition-title--caution);-webkit-mask-image:var(--icon-spark);mask-image:var(--icon-spark)}.admonition.warning{border-left-color:var(--color-admonition-title--warning)}.admonition.warning>.admonition-title{background-color:var(--color-admonition-title-background--warning)}.admonition.warning>.admonition-title:before{background-color:var(--color-admonition-title--warning);-webkit-mask-image:var(--icon-warning);mask-image:var(--icon-warning)}.admonition.danger{border-left-color:var(--color-admonition-title--danger)}.admonition.danger>.admonition-title{background-color:var(--color-admonition-title-background--danger)}.admonition.danger>.admonition-title:before{background-color:var(--color-admonition-title--danger);-webkit-mask-image:var(--icon-spark);mask-image:var(--icon-spark)}.admonition.attention{border-left-color:var(--color-admonition-title--attention)}.admonition.attention>.admonition-title{background-color:var(--color-admonition-title-background--attention)}.admonition.attention>.admonition-title:before{background-color:var(--color-admonition-title--attention);-webkit-mask-image:var(--icon-warning);mask-image:var(--icon-warning)}.admonition.error{border-left-color:var(--color-admonition-title--error)}.admonition.error>.admonition-title{background-color:var(--color-admonition-title-background--error)}.admonition.error>.admonition-title:before{background-color:var(--color-admonition-title--error);-webkit-mask-image:var(--icon-failure);mask-image:var(--icon-failure)}.admonition.hint{border-left-color:var(--color-admonition-title--hint)}.admonition.hint>.admonition-title{background-color:var(--color-admonition-title-background--hint)}.admonition.hint>.admonition-title:before{background-color:var(--color-admonition-title--hint);-webkit-mask-image:var(--icon-question);mask-image:var(--icon-question)}.admonition.tip{border-left-color:var(--color-admonition-title--tip)}.admonition.tip>.admonition-title{background-color:var(--color-admonition-title-background--tip)}.admonition.tip>.admonition-title:before{background-color:var(--color-admonition-title--tip);-webkit-mask-image:var(--icon-info);mask-image:var(--icon-info)}.admonition.important{border-left-color:var(--color-admonition-title--important)}.admonition.important>.admonition-title{background-color:var(--color-admonition-title-background--important)}.admonition.important>.admonition-title:before{background-color:var(--color-admonition-title--important);-webkit-mask-image:var(--icon-flame);mask-image:var(--icon-flame)}.admonition.note{border-left-color:var(--color-admonition-title--note)}.admonition.note>.admonition-title{background-color:var(--color-admonition-title-background--note)}.admonition.note>.admonition-title:before{background-color:var(--color-admonition-title--note);-webkit-mask-image:var(--icon-pencil);mask-image:var(--icon-pencil)}.admonition.seealso{border-left-color:var(--color-admonition-title--seealso)}.admonition.seealso>.admonition-title{background-color:var(--color-admonition-title-background--seealso)}.admonition.seealso>.admonition-title:before{background-color:var(--color-admonition-title--seealso);-webkit-mask-image:var(--icon-info);mask-image:var(--icon-info)}.admonition.admonition-todo{border-left-color:var(--color-admonition-title--admonition-todo)}.admonition.admonition-todo>.admonition-title{background-color:var(--color-admonition-title-background--admonition-todo)}.admonition.admonition-todo>.admonition-title:before{background-color:var(--color-admonition-title--admonition-todo);-webkit-mask-image:var(--icon-pencil);mask-image:var(--icon-pencil)}.admonition-todo>.admonition-title{text-transform:uppercase}dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.glossary):not(.simple) dd{margin-left:2rem}dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.glossary):not(.simple) dd>:first-child{margin-top:.125rem}dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.glossary):not(.simple) .field-list,dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.glossary):not(.simple) dd>:last-child{margin-bottom:.75rem}dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.glossary):not(.simple) .field-list>dt{font-size:var(--font-size--small);text-transform:uppercase}dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.glossary):not(.simple) .field-list dd:empty{margin-bottom:.5rem}dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.glossary):not(.simple) .field-list dd>ul{margin-left:-1.2rem}dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.glossary):not(.simple) .field-list dd>ul>li>p:nth-child(2){margin-top:0}dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.glossary):not(.simple) .field-list dd>ul>li>p+p:last-child:empty{margin-bottom:0;margin-top:0}dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.glossary):not(.simple)>dt{color:var(--color-api-overall)}.sig:not(.sig-inline){background:var(--color-api-background);border-radius:.25rem;font-family:var(--font-stack--monospace);font-size:var(--api-font-size);font-weight:700;margin-left:-.25rem;margin-right:-.25rem;padding:.25rem .5rem .25rem 3em;text-indent:-2.5em;transition:background .1s ease-out}.sig:not(.sig-inline):hover{background:var(--color-api-background-hover)}.sig:not(.sig-inline) a.reference .viewcode-link{font-weight:400;width:4.25rem}em.property{font-style:normal}em.property:first-child{color:var(--color-api-keyword)}.sig-name{color:var(--color-api-name)}.sig-prename{color:var(--color-api-pre-name);font-weight:400}.sig-paren{color:var(--color-api-paren)}.sig-param{font-style:normal}div.deprecated,div.versionadded,div.versionchanged,div.versionremoved{border-left:.1875rem solid;border-radius:.125rem;padding-left:.75rem}div.deprecated p,div.versionadded p,div.versionchanged p,div.versionremoved p{margin-bottom:.125rem;margin-top:.125rem}div.versionadded{border-color:var(--color-api-added-border)}div.versionadded .versionmodified{color:var(--color-api-added)}div.versionchanged{border-color:var(--color-api-changed-border)}div.versionchanged .versionmodified{color:var(--color-api-changed)}div.deprecated{border-color:var(--color-api-deprecated-border)}div.deprecated .versionmodified{color:var(--color-api-deprecated)}div.versionremoved{border-color:var(--color-api-removed-border)}div.versionremoved .versionmodified{color:var(--color-api-removed)}.viewcode-back,.viewcode-link{float:right;text-align:right}.line-block{margin-bottom:.75rem;margin-top:.5rem}.line-block .line-block{margin-bottom:0;margin-top:0;padding-left:1rem}.code-block-caption,article p.caption,table>caption{font-size:var(--font-size--small);text-align:center}.toctree-wrapper.compound .caption,.toctree-wrapper.compound :not(.caption)>.caption-text{font-size:var(--font-size--small);margin-bottom:0;text-align:initial;text-transform:uppercase}.toctree-wrapper.compound>ul{margin-bottom:0;margin-top:0}.sig-inline,code.literal{background:var(--color-inline-code-background);border-radius:.2em;font-size:var(--font-size--small--2);padding:.1em .2em}pre.literal-block .sig-inline,pre.literal-block code.literal{font-size:inherit;padding:0}p .sig-inline,p code.literal{border:1px solid var(--color-background-border)}.sig-inline{font-family:var(--font-stack--monospace)}div[class*=" highlight-"],div[class^=highlight-]{display:flex;margin:1em 0}div[class*=" highlight-"] .table-wrapper,div[class^=highlight-] .table-wrapper,pre{margin:0;padding:0}pre{overflow:auto}article[role=main] .highlight pre{line-height:1.5}.highlight pre,pre.literal-block{font-size:var(--code-font-size);padding:.625rem .875rem}pre.literal-block{background-color:var(--color-code-background);border-radius:.2rem;color:var(--color-code-foreground);margin-bottom:1rem;margin-top:1rem}.highlight{border-radius:.2rem;width:100%}.highlight .gp,.highlight span.linenos{pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.highlight .hll{display:block;margin-left:-.875rem;margin-right:-.875rem;padding-left:.875rem;padding-right:.875rem}.code-block-caption{background-color:var(--color-code-background);border-bottom:1px solid;border-radius:.25rem;border-bottom-left-radius:0;border-bottom-right-radius:0;border-color:var(--color-background-border);color:var(--color-code-foreground);display:flex;font-weight:300;padding:.625rem .875rem}.code-block-caption+div[class]{margin-top:0}.code-block-caption+div[class] pre{border-top-left-radius:0;border-top-right-radius:0}.highlighttable{display:block;width:100%}.highlighttable tbody{display:block}.highlighttable tr{display:flex}.highlighttable td.linenos{background-color:var(--color-code-background);border-bottom-left-radius:.2rem;border-top-left-radius:.2rem;color:var(--color-code-foreground);padding:.625rem 0 .625rem .875rem}.highlighttable .linenodiv{box-shadow:-.0625rem 0 var(--color-foreground-border) inset;font-size:var(--code-font-size);padding-right:.875rem}.highlighttable td.code{display:block;flex:1;overflow:hidden;padding:0}.highlighttable td.code .highlight{border-bottom-left-radius:0;border-top-left-radius:0}.highlight span.linenos{box-shadow:-.0625rem 0 var(--color-foreground-border) inset;display:inline-block;margin-right:.875rem;padding-left:0;padding-right:.875rem}.footnote-reference{font-size:var(--font-size--small--4);vertical-align:super}dl.footnote.brackets{color:var(--color-foreground-secondary);display:grid;font-size:var(--font-size--small);grid-template-columns:max-content auto}dl.footnote.brackets dt{margin:0}dl.footnote.brackets dt>.fn-backref{margin-left:.25rem}dl.footnote.brackets dt:after{content:":"}dl.footnote.brackets dt .brackets:before{content:"["}dl.footnote.brackets dt .brackets:after{content:"]"}dl.footnote.brackets dd{margin:0;padding:0 1rem}aside.footnote{color:var(--color-foreground-secondary);font-size:var(--font-size--small)}aside.footnote>span,div.citation>span{float:left;font-weight:500;padding-right:.25rem}aside.footnote>:not(span),div.citation>p{margin-left:2rem}img{box-sizing:border-box;height:auto;max-width:100%}article .figure,article figure{border-radius:.2rem;margin:0}article .figure :last-child,article figure :last-child{margin-bottom:0}article .align-left{clear:left;float:left;margin:0 1rem 1rem}article .align-right{clear:right;float:right;margin:0 1rem 1rem}article .align-center,article .align-default{display:block;margin-left:auto;margin-right:auto;text-align:center}article table.align-default{display:table;text-align:initial}.domainindex-jumpbox,.genindex-jumpbox{border-bottom:1px solid var(--color-background-border);border-top:1px solid var(--color-background-border);padding:.25rem}.domainindex-section h2,.genindex-section h2{margin-bottom:.5rem;margin-top:.75rem}.domainindex-section ul,.genindex-section ul{margin-bottom:0;margin-top:0}ol,ul{margin-bottom:1rem;margin-top:1rem;padding-left:1.2rem}ol li>p:first-child,ul li>p:first-child{margin-bottom:.25rem;margin-top:.25rem}ol li>p:last-child,ul li>p:last-child{margin-top:.25rem}ol li>ol,ol li>ul,ul li>ol,ul li>ul{margin-bottom:.5rem;margin-top:.5rem}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}.simple li>ol,.simple li>ul,.toctree-wrapper li>ol,.toctree-wrapper li>ul{margin-bottom:0;margin-top:0}.field-list dt,.option-list dt,dl.footnote dt,dl.glossary dt,dl.simple dt,dl:not([class]) dt{font-weight:500;margin-top:.25rem}.field-list dt+dt,.option-list dt+dt,dl.footnote dt+dt,dl.glossary dt+dt,dl.simple dt+dt,dl:not([class]) dt+dt{margin-top:0}.field-list dt .classifier:before,.option-list dt .classifier:before,dl.footnote dt .classifier:before,dl.glossary dt .classifier:before,dl.simple dt .classifier:before,dl:not([class]) dt .classifier:before{content:":";margin-left:.2rem;margin-right:.2rem}.field-list dd ul,.field-list dd>p:first-child,.option-list dd ul,.option-list dd>p:first-child,dl.footnote dd ul,dl.footnote dd>p:first-child,dl.glossary dd ul,dl.glossary dd>p:first-child,dl.simple dd ul,dl.simple dd>p:first-child,dl:not([class]) dd ul,dl:not([class]) dd>p:first-child{margin-top:.125rem}.field-list dd ul,.option-list dd ul,dl.footnote dd ul,dl.glossary dd ul,dl.simple dd ul,dl:not([class]) dd ul{margin-bottom:.125rem}.math-wrapper{overflow-x:auto;width:100%}div.math{position:relative;text-align:center}div.math .headerlink,div.math:focus .headerlink{display:none}div.math:hover .headerlink{display:inline-block}div.math span.eqno{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);z-index:1}abbr[title]{cursor:help}.problematic{color:var(--color-problematic)}kbd:not(.compound){background-color:var(--color-background-secondary);border:1px solid var(--color-foreground-border);border-radius:.2rem;box-shadow:0 .0625rem 0 rgba(0,0,0,.2),inset 0 0 0 .125rem var(--color-background-primary);color:var(--color-foreground-primary);display:inline-block;font-size:var(--font-size--small--3);margin:0 .2rem;padding:0 .2rem;vertical-align:text-bottom}blockquote{background:var(--color-background-secondary);border-left:4px solid var(--color-background-border);margin-left:0;margin-right:0;padding:.5rem 1rem}blockquote .attribution{font-weight:600;text-align:right}blockquote.highlights,blockquote.pull-quote{font-size:1.25em}blockquote.epigraph,blockquote.pull-quote{border-left-width:0;border-radius:.5rem}blockquote.highlights{background:transparent;border-left-width:0}p .reference img{vertical-align:middle}p.rubric{font-size:1.125em;font-weight:700;line-height:1.25}dd p.rubric{font-size:var(--font-size--small);font-weight:inherit;line-height:inherit;text-transform:uppercase}article .sidebar{background-color:var(--color-background-secondary);border:1px solid var(--color-background-border);border-radius:.2rem;clear:right;float:right;margin-left:1rem;margin-right:0;width:30%}article .sidebar>*{padding-left:1rem;padding-right:1rem}article .sidebar>ol,article .sidebar>ul{padding-left:2.2rem}article .sidebar .sidebar-title{border-bottom:1px solid var(--color-background-border);font-weight:500;margin:0;padding:.5rem 1rem}[role=main] .table-wrapper.container{margin-bottom:.5rem;margin-top:1rem;overflow-x:auto;padding:.2rem .2rem .75rem;width:100%}table.docutils{border-collapse:collapse;border-radius:.2rem;border-spacing:0;box-shadow:0 .2rem .5rem rgba(0,0,0,.05),0 0 .0625rem rgba(0,0,0,.1)}table.docutils th{background:var(--color-table-header-background)}table.docutils td,table.docutils th{border-bottom:1px solid var(--color-table-border);border-left:1px solid var(--color-table-border);border-right:1px solid var(--color-table-border);padding:0 .25rem}table.docutils td p,table.docutils th p{margin:.25rem}table.docutils td:first-child,table.docutils th:first-child{border-left:none}table.docutils td:last-child,table.docutils th:last-child{border-right:none}table.docutils td.text-left,table.docutils th.text-left{text-align:left}table.docutils td.text-right,table.docutils th.text-right{text-align:right}table.docutils td.text-center,table.docutils th.text-center{text-align:center}:target{scroll-margin-top:2.5rem}@media(max-width:67em){:target{scroll-margin-top:calc(2.5rem + var(--header-height))}section>span:target{scroll-margin-top:calc(2.8rem + var(--header-height))}}.headerlink{font-weight:100;-webkit-user-select:none;-moz-user-select:none;user-select:none}.code-block-caption>.headerlink,dl dt>.headerlink,figcaption p>.headerlink,h1>.headerlink,h2>.headerlink,h3>.headerlink,h4>.headerlink,h5>.headerlink,h6>.headerlink,p.caption>.headerlink,table>caption>.headerlink{margin-left:.5rem;visibility:hidden}.code-block-caption:hover>.headerlink,dl dt:hover>.headerlink,figcaption p:hover>.headerlink,h1:hover>.headerlink,h2:hover>.headerlink,h3:hover>.headerlink,h4:hover>.headerlink,h5:hover>.headerlink,h6:hover>.headerlink,p.caption:hover>.headerlink,table>caption:hover>.headerlink{visibility:visible}.code-block-caption>.toc-backref,dl dt>.toc-backref,figcaption p>.toc-backref,h1>.toc-backref,h2>.toc-backref,h3>.toc-backref,h4>.toc-backref,h5>.toc-backref,h6>.toc-backref,p.caption>.toc-backref,table>caption>.toc-backref{color:inherit;text-decoration-line:none}figure:hover>figcaption>p>.headerlink,table:hover>caption>.headerlink{visibility:visible}:target>h1:first-of-type,:target>h2:first-of-type,:target>h3:first-of-type,:target>h4:first-of-type,:target>h5:first-of-type,:target>h6:first-of-type,span:target~h1:first-of-type,span:target~h2:first-of-type,span:target~h3:first-of-type,span:target~h4:first-of-type,span:target~h5:first-of-type,span:target~h6:first-of-type{background-color:var(--color-highlight-on-target)}:target>h1:first-of-type code.literal,:target>h2:first-of-type code.literal,:target>h3:first-of-type code.literal,:target>h4:first-of-type code.literal,:target>h5:first-of-type code.literal,:target>h6:first-of-type code.literal,span:target~h1:first-of-type code.literal,span:target~h2:first-of-type code.literal,span:target~h3:first-of-type code.literal,span:target~h4:first-of-type code.literal,span:target~h5:first-of-type code.literal,span:target~h6:first-of-type code.literal{background-color:transparent}.literal-block-wrapper:target .code-block-caption,.this-will-duplicate-information-and-it-is-still-useful-here li :target,figure:target,table:target>caption{background-color:var(--color-highlight-on-target)}dt:target{background-color:var(--color-highlight-on-target)!important}.footnote-reference:target,.footnote>dt:target+dd{background-color:var(--color-highlight-on-target)}.guilabel{background-color:var(--color-guilabel-background);border:1px solid var(--color-guilabel-border);border-radius:.5em;color:var(--color-guilabel-text);font-size:.9em;padding:0 .3em}footer{display:flex;flex-direction:column;font-size:var(--font-size--small);margin-top:2rem}.bottom-of-page{align-items:center;border-top:1px solid var(--color-background-border);color:var(--color-foreground-secondary);display:flex;justify-content:space-between;line-height:1.5;margin-top:1rem;padding-bottom:1rem;padding-top:1rem}@media(max-width:46em){.bottom-of-page{flex-direction:column-reverse;gap:.25rem;text-align:center}}.bottom-of-page .left-details{font-size:var(--font-size--small)}.bottom-of-page .right-details{display:flex;flex-direction:column;gap:.25rem;text-align:right}.bottom-of-page .icons{display:flex;font-size:1rem;gap:.25rem;justify-content:flex-end}.bottom-of-page .icons a{text-decoration:none}.bottom-of-page .icons img,.bottom-of-page .icons svg{font-size:1.125rem;height:1em;width:1em}.related-pages a{align-items:center;display:flex;text-decoration:none}.related-pages a:hover .page-info .title{color:var(--color-link);text-decoration:underline;text-decoration-color:var(--color-link-underline)}.related-pages a svg.furo-related-icon,.related-pages a svg.furo-related-icon>use{color:var(--color-foreground-border);flex-shrink:0;height:.75rem;margin:0 .5rem;width:.75rem}.related-pages a.next-page{clear:right;float:right;max-width:50%;text-align:right}.related-pages a.prev-page{clear:left;float:left;max-width:50%}.related-pages a.prev-page svg{transform:rotate(180deg)}.page-info{display:flex;flex-direction:column;overflow-wrap:anywhere}.next-page .page-info{align-items:flex-end}.page-info .context{align-items:center;color:var(--color-foreground-muted);display:flex;font-size:var(--font-size--small);padding-bottom:.1rem;text-decoration:none}ul.search{list-style:none;padding-left:0}ul.search li{border-bottom:1px solid var(--color-background-border);padding:1rem 0}[role=main] .highlighted{background-color:var(--color-highlighted-background);color:var(--color-highlighted-text)}.sidebar-brand{display:flex;flex-direction:column;flex-shrink:0;padding:var(--sidebar-item-spacing-vertical) var(--sidebar-item-spacing-horizontal);text-decoration:none}.sidebar-brand-text{color:var(--color-sidebar-brand-text);font-size:1.5rem;overflow-wrap:break-word}.sidebar-brand-text,.sidebar-logo-container{margin:var(--sidebar-item-spacing-vertical) 0}.sidebar-logo{display:block;margin:0 auto;max-width:100%}.sidebar-search-container{align-items:center;background:var(--color-sidebar-search-background);display:flex;margin-top:var(--sidebar-search-space-above);position:relative}.sidebar-search-container:focus-within,.sidebar-search-container:hover{background:var(--color-sidebar-search-background--focus)}.sidebar-search-container:before{background-color:var(--color-sidebar-search-icon);content:"";height:var(--sidebar-search-icon-size);left:var(--sidebar-item-spacing-horizontal);-webkit-mask-image:var(--icon-search);mask-image:var(--icon-search);position:absolute;width:var(--sidebar-search-icon-size)}.sidebar-search{background:transparent;border:none;border-bottom:1px solid var(--color-sidebar-search-border);border-top:1px solid var(--color-sidebar-search-border);box-sizing:border-box;color:var(--color-sidebar-search-foreground);padding:var(--sidebar-search-input-spacing-vertical) var(--sidebar-search-input-spacing-horizontal) var(--sidebar-search-input-spacing-vertical) calc(var(--sidebar-item-spacing-horizontal) + var(--sidebar-search-input-spacing-horizontal) + var(--sidebar-search-icon-size));width:100%;z-index:10}.sidebar-search:focus{outline:none}.sidebar-search::-moz-placeholder{font-size:var(--sidebar-search-input-font-size)}.sidebar-search::placeholder{font-size:var(--sidebar-search-input-font-size)}#searchbox .highlight-link{margin:0;padding:var(--sidebar-item-spacing-vertical) var(--sidebar-item-spacing-horizontal) 0;text-align:center}#searchbox .highlight-link a{color:var(--color-sidebar-search-icon);font-size:var(--font-size--small--2)}.sidebar-tree{font-size:var(--sidebar-item-font-size);margin-bottom:var(--sidebar-item-spacing-vertical);margin-top:var(--sidebar-tree-space-above)}.sidebar-tree ul{display:flex;flex-direction:column;list-style:none;margin-bottom:0;margin-top:0;padding:0}.sidebar-tree li{margin:0;position:relative}.sidebar-tree li>ul{margin-left:var(--sidebar-item-spacing-horizontal)}.sidebar-tree .icon,.sidebar-tree .reference{color:var(--color-sidebar-link-text)}.sidebar-tree .reference{box-sizing:border-box;display:inline-block;height:100%;line-height:var(--sidebar-item-line-height);overflow-wrap:anywhere;padding:var(--sidebar-item-spacing-vertical) var(--sidebar-item-spacing-horizontal);text-decoration:none;width:100%}.sidebar-tree .reference:hover{background:var(--color-sidebar-item-background--hover);color:var(--color-sidebar-link-text)}.sidebar-tree .reference.external:after{color:var(--color-sidebar-link-text);content:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='none' stroke='%23607D8B' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' viewBox='0 0 24 24'%3E%3Cpath stroke='none' d='M0 0h24v24H0z'/%3E%3Cpath d='M11 7H6a2 2 0 0 0-2 2v9a2 2 0 0 0 2 2h9a2 2 0 0 0 2-2v-5M10 14 20 4M15 4h5v5'/%3E%3C/svg%3E");margin:0 .25rem;vertical-align:middle}.sidebar-tree .current-page>.reference{font-weight:700}.sidebar-tree label{align-items:center;cursor:pointer;display:flex;height:var(--sidebar-item-height);justify-content:center;position:absolute;right:0;top:0;-webkit-user-select:none;-moz-user-select:none;user-select:none;width:var(--sidebar-expander-width)}.sidebar-tree .caption,.sidebar-tree :not(.caption)>.caption-text{color:var(--color-sidebar-caption-text);font-size:var(--sidebar-caption-font-size);font-weight:700;margin:var(--sidebar-caption-space-above) 0 0 0;padding:var(--sidebar-item-spacing-vertical) var(--sidebar-item-spacing-horizontal);text-transform:uppercase}.sidebar-tree li.has-children>.reference{padding-right:var(--sidebar-expander-width)}.sidebar-tree .toctree-l1>.reference,.sidebar-tree .toctree-l1>label .icon{color:var(--color-sidebar-link-text--top-level)}.sidebar-tree label{background:var(--color-sidebar-item-expander-background)}.sidebar-tree label:hover{background:var(--color-sidebar-item-expander-background--hover)}.sidebar-tree .current>.reference{background:var(--color-sidebar-item-background--current)}.sidebar-tree .current>.reference:hover{background:var(--color-sidebar-item-background--hover)}.toctree-checkbox{display:none;position:absolute}.toctree-checkbox~ul{display:none}.toctree-checkbox~label .icon svg{transform:rotate(90deg)}.toctree-checkbox:checked~ul{display:block}.toctree-checkbox:checked~label .icon svg{transform:rotate(-90deg)}.toc-title-container{padding:var(--toc-title-padding);padding-top:var(--toc-spacing-vertical)}.toc-title{color:var(--color-toc-title-text);font-size:var(--toc-title-font-size);padding-left:var(--toc-spacing-horizontal);text-transform:uppercase}.no-toc{display:none}.toc-tree-container{padding-bottom:var(--toc-spacing-vertical)}.toc-tree{border-left:1px solid var(--color-background-border);font-size:var(--toc-font-size);line-height:1.3;padding-left:calc(var(--toc-spacing-horizontal) - var(--toc-item-spacing-horizontal))}.toc-tree>ul>li:first-child{padding-top:0}.toc-tree>ul>li:first-child>ul{padding-left:0}.toc-tree>ul>li:first-child>a{display:none}.toc-tree ul{list-style-type:none;margin-bottom:0;margin-top:0;padding-left:var(--toc-item-spacing-horizontal)}.toc-tree li{padding-top:var(--toc-item-spacing-vertical)}.toc-tree li.scroll-current>.reference{color:var(--color-toc-item-text--active);font-weight:700}.toc-tree a.reference{color:var(--color-toc-item-text);overflow-wrap:anywhere;text-decoration:none}.toc-scroll{max-height:100vh;overflow-y:scroll}.contents:not(.this-will-duplicate-information-and-it-is-still-useful-here){background:rgba(255,0,0,.25);color:var(--color-problematic)}.contents:not(.this-will-duplicate-information-and-it-is-still-useful-here):before{content:"ERROR: Adding a table of contents in Furo-based documentation is unnecessary, and does not work well with existing styling. Add a 'this-will-duplicate-information-and-it-is-still-useful-here' class, if you want an escape hatch."}.text-align\:left>p{text-align:left}.text-align\:center>p{text-align:center}.text-align\:right>p{text-align:right} +/*# sourceMappingURL=furo.css.map*/ \ No newline at end of file diff --git a/pr-preview/pr-92/_static/styles/furo.css.map b/pr-preview/pr-92/_static/styles/furo.css.map new file mode 100644 index 0000000..3ecc371 --- /dev/null +++ b/pr-preview/pr-92/_static/styles/furo.css.map @@ -0,0 +1 @@ +{"version":3,"file":"styles/furo.css","mappings":"AAAA,2EAA2E,CAU3E,KACE,gBAAiB,CACjB,6BACF,CASA,KACE,QACF,CAMA,KACE,aACF,CAOA,GACE,aAAc,CACd,cACF,CAUA,GACE,sBAAuB,CACvB,QAAS,CACT,gBACF,CAOA,IACE,+BAAiC,CACjC,aACF,CASA,EACE,4BACF,CAOA,YACE,kBAAmB,CACnB,yBAA0B,CAC1B,gCACF,CAMA,SAEE,kBACF,CAOA,cAGE,+BAAiC,CACjC,aACF,CAeA,QAEE,aAAc,CACd,aAAc,CACd,iBAAkB,CAClB,uBACF,CAEA,IACE,aACF,CAEA,IACE,SACF,CASA,IACE,iBACF,CAUA,sCAKE,mBAAoB,CACpB,cAAe,CACf,gBAAiB,CACjB,QACF,CAOA,aAEE,gBACF,CAOA,cAEE,mBACF,CAMA,gDAIE,yBACF,CAMA,wHAIE,iBAAkB,CAClB,SACF,CAMA,4GAIE,6BACF,CAMA,SACE,0BACF,CASA,OACE,qBAAsB,CACtB,aAAc,CACd,aAAc,CACd,cAAe,CACf,SAAU,CACV,kBACF,CAMA,SACE,uBACF,CAMA,SACE,aACF,CAOA,6BAEE,qBAAsB,CACtB,SACF,CAMA,kFAEE,WACF,CAOA,cACE,4BAA6B,CAC7B,mBACF,CAMA,yCACE,uBACF,CAOA,6BACE,yBAA0B,CAC1B,YACF,CASA,QACE,aACF,CAMA,QACE,iBACF,CAiBA,kBACE,YACF,CCvVA,aAcE,kEACE,uBAOF,WACE,iDAMF,kCACE,wBAEF,qCAEE,uBADA,uBACA,CAEF,SACE,wBAtBA,CCpBJ,iBAGE,qBAEA,sBACA,0BAFA,oBAHA,4BACA,oBAKA,6BAIA,2CAFA,mBACA,sCAFA,4BAGA,CAEF,gBACE,aCTF,KCGE,mHAEA,wGAEA,wCAAyC,CAEzC,wBAAyB,CACzB,wBAAyB,CACzB,4BAA6B,CAC7B,yBAA0B,CAC1B,2BAA4B,CAG5B,sDAAuD,CACvD,gDAAiD,CACjD,wDAAyD,CAGzD,0CAA2C,CAC3C,gDAAiD,CACjD,gDAAiD,CAKjD,gCAAiC,CACjC,sCAAuC,CAGvC,2CAA4C,CAG5C,uCAAwC,CCjCxC,+FAGA,uBAAwB,CAGxB,iCAAkC,CAClC,kCAAmC,CAEnC,+BAAgC,CAChC,sCAAuC,CACvC,sCAAuC,CACvC,qGAIA,mDAAoD,CAEpD,mCAAoC,CACpC,8CAA+C,CAC/C,gDAAiD,CACjD,kCAAmC,CACnC,6DAA8D,CAG9D,6BAA8B,CAC9B,6BAA8B,CAC9B,+BAAgC,CAChC,kCAAmC,CACnC,kCAAmC,CCPjC,+jBCYA,iqCAZF,iaCVA,8KAOA,4SAWA,4SAUA,0CACA,gEAGA,0CAGA,gEAGA,yCACA,+DAIA,4CACA,kEAGA,wCAUA,8DACA,uCAGA,4DACA,sCACA,2DAGA,4CACA,kEACA,uCAGA,6DACA,2GAGA,sHAEA,yFAEA,+CACA,+EAGA,4MAOA,gCACA,sHAIA,kCACA,uEACA,gEACA,4DACA,kEAGA,2DACA,sDACA,0CACA,8CACA,wGAGA,0BACA,iCAGA,+DACA,+BACA,sCACA,+DAEA,kGACA,oCACA,yDACA,sCL7HF,kCAEA,sDAIA,0CK2HE,kEAIA,oDACA,sDAGA,oCACA,oEAEA,0DACA,qDAIA,oDACA,6DAIA,iEAIA,2DAIA,2DAGA,4DACA,gEAIA,gEAEA,gFAEA,oNASA,qDLxKE,gFAGE,4DAIF,oEKkHF,yEAEA,6DAGA,0DAEA,uDACA,qDACA,wDAIA,6DAIA,yDACA,2DAIA,uCAGA,wCACA,sDAGA,+CAGA,6DAEA,iDACA,+DAEA,wDAEA,sEAMA,0DACA,sBACA,mEL9JI,wEAEA,iCACE,+BAMN,wEAGA,iCACE,kFAEA,uEAIF,gEACE,8BAGF,qEMvDA,sCAKA,wFAKA,iCAIA,0BAWA,iCACA,4BACA,mCAGA,+BAEA,sCACA,4BAEA,mCAEA,sCAKA,sDAIA,gCAEA,gEAQF,wCAME,sBACA,kCAKA,uBAEA,gEAIA,2BAIA,mCAEA,qCACA,iCAGE,+BACA,wEAEE,iCACA,kFAGF,6BACA,0CACF,kCAEE,8BACE,8BACA,qEAEE,sCACA,wFCnFN,iCAGF,2DAEE,4BACA,oCAGA,mIAGA,4HACE,gEAMJ,+CAGE,sBACA,yCAEF,uBAEE,sEAKA,gDACA,kEAGA,iFAGE,YAGF,EACA,4HAQF,mBACE,6BACA,mBACA,wCACA,wCACA,2CAIA,eAGA,mBAKE,mBAGA,CAJA,uCACA,iBAFF,gBACE,CAKE,mBACA,mBAGJ,oBAIF,+BAGE,kDACA,OADA,kBAGA,CAFA,gBAEA,mBACA,oBAEA,sCACA,OAGF,cAHE,WAGF,GAEE,oBACA,CAHF,gBAGE,CC9Gc,YDiHd,+CAIF,SAEE,CAPF,UACE,wBAMA,4BAEA,GAGA,uBACA,CAJA,yBAGA,CACA,iDAKA,2CAGA,2DAQA,iBACA,uCAGA,kEAKE,SAKJ,8BACE,yDACA,2BAEA,oBACA,8BAEA,yDAEE,4BAEJ,uCACE,CACA,iEAGA,CAEA,wCACE,uBACA,kDAEA,0DAEE,CAJF,oBAIE,0GAWN,aACE,CAHA,YAGA,4HASA,+CAGF,sBACE,WACA,WAQA,4BAFF,0CAEE,CARA,qCAsBA,CAdA,iBAEA,kBACE,aADF,4BACE,WAMF,2BAGF,qCAEE,CAXE,UAWF,+BAGA,uBAEA,SAEA,0CAIE,CANF,qCAEA,CAIE,2DACE,gBAIN,+CAIA,CAEA,kDAKE,CAPF,8BAEA,CAOE,YACA,CAjBI,2BAGN,CAHM,WAcJ,UAGA,CAEA,2GAIF,iCAGE,8BAIA,qBACA,oBACF,uBAOI,0CAIA,CATF,6DAKE,CALF,sBASE,qCAKF,CACE,cACA,CAFF,sBAEE,CACA,+BAEA,qBAEE,WAKN,aACE,sCAGA,mBAEA,6BAMA,kCACA,CAJA,sBACA,aAEA,CAJA,eACA,MAIA,2FAEA,UAGA,YACA,sBACE,8BAEA,CALF,aACA,WAIE,OACA,oBAEF,uBACE,WAEF,YAFE,UAEF,eAgBA,kBACE,CAhBA,qDAQF,qCAGF,CAGI,YACF,CAJF,2BAGI,CAEA,eACA,qBAGA,mEAEA,qBACA,8BAIA,kBADF,kBACE,yBAEJ,oCAGI,qDAIJ,+BAGI,oCAEA,+CAQF,4CACE,yBACF,2BAOE,sBACA,CAHA,WACA,CAFF,cACE,CAJA,YAGF,CAEE,SAEA,mBAGA,kDAEE,CAJF,cAEA,cAEE,sBAEA,mBADA,YACA,uBACA,mDACE,CADF,YACE,iDAEA,uCAEN,+DAOE,mBADF,sBACE,mBAGF,aACE,sCAIA,aADF,WACE,CAKF,SACE,CAHJ,kBAEE,CAJE,gBAEJ,CAHI,iBAMA,yFAKA,aACA,eACA,cElbJ,iBAEE,aADA,iBACA,6BAEA,kCAEA,SACA,UAIA,gCACA,CALA,SAEA,SAEA,CAJA,0EAEA,CAFA,OAKA,CAGA,mDACE,iBAGF,gCACE,CADF,UACE,aAEJ,iCAEE,CAFF,UAEE,wCAEA,WACA,WADA,UACA,CACA,4CAGA,MACA,CADA,KACA,wCACA,UAGA,CAJA,UAIA,6DAUA,0CACE,CAFF,mBAEE,wEACA,CAVA,YACA,CAMF,mBAJE,OAOA,gBAJJ,gCACE,CANE,cACA,CAHA,oBACA,CAGA,QAGJ,CAII,0BACA,CADA,UACA,wCAEJ,kBACE,0DACA,gCACE,kBACA,CADA,YACA,oEACA,2CAMF,mDAII,CALN,YACE,CANE,cAKJ,CACE,iBAII,kEACA,yCACE,kDACA,yDACE,+CACA,uBANN,CAMM,+BANN,uCACE,qDACA,4BAEE,mBADA,0CACA,CADA,qBACA,0DACE,wCACA,sGALJ,oCACA,sBACE,kBAFF,UAEE,2CACA,wFACE,cACA,kEANN,uBACE,iDACA,CADA,UACA,0DACE,wDAEE,iEACA,qEANN,sCACE,CAGE,iBAHF,gBAGE,qBACE,CAJJ,uBACA,gDACE,wDACA,6DAHF,2CACA,CADA,gBACA,eACE,CAGE,sBANN,8BACE,CAII,iBAFF,4DACA,WACE,YADF,uCACE,6EACA,2BANN,8CACE,kDACA,0CACE,8BACA,yFACE,sBACA,sFALJ,mEACA,sBACE,kEACA,6EACE,uCACA,kEALJ,qGAEE,kEACA,6EACE,uCACA,kEALJ,8CACA,uDACE,sEACA,2EACE,sCACA,iEALJ,mGACA,qCACE,oDACA,0DACE,6GACA,gDAGR,yDCrEA,sEACE,CACA,6GACE,gEACF,iGAIF,wFACE,qDAGA,mGAEE,2CAEF,4FACE,gCACF,wGACE,8DAEE,6FAIA,iJAKN,6GACE,gDAKF,yDACA,qCAGA,6BACA,kBACA,qDAKA,oCAEA,+DAGA,2CAGE,oDAIA,oEAEE,qBAGJ,wDAEE,uCAEF,kE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","sources":["webpack:///./node_modules/normalize.css/normalize.css","webpack:///./src/furo/assets/styles/base/_print.sass","webpack:///./src/furo/assets/styles/base/_screen-readers.sass","webpack:///./src/furo/assets/styles/base/_theme.sass","webpack:///./src/furo/assets/styles/variables/_fonts.scss","webpack:///./src/furo/assets/styles/variables/_spacing.scss","webpack:///./src/furo/assets/styles/variables/_icons.scss","webpack:///./src/furo/assets/styles/variables/_admonitions.scss","webpack:///./src/furo/assets/styles/variables/_colors.scss","webpack:///./src/furo/assets/styles/base/_typography.sass","webpack:///./src/furo/assets/styles/_scaffold.sass","webpack:///./src/furo/assets/styles/variables/_layout.scss","webpack:///./src/furo/assets/styles/content/_admonitions.sass","webpack:///./src/furo/assets/styles/content/_api.sass","webpack:///./src/furo/assets/styles/content/_blocks.sass","webpack:///./src/furo/assets/styles/content/_captions.sass","webpack:///./src/furo/assets/styles/content/_code.sass","webpack:///./src/furo/assets/styles/content/_footnotes.sass","webpack:///./src/furo/assets/styles/content/_images.sass","webpack:///./src/furo/assets/styles/content/_indexes.sass","webpack:///./src/furo/assets/styles/content/_lists.sass","webpack:///./src/furo/assets/styles/content/_math.sass","webpack:///./src/furo/assets/styles/content/_misc.sass","webpack:///./src/furo/assets/styles/content/_rubrics.sass","webpack:///./src/furo/assets/styles/content/_sidebar.sass","webpack:///./src/furo/assets/styles/content/_tables.sass","webpack:///./src/furo/assets/styles/content/_target.sass","webpack:///./src/furo/assets/styles/content/_gui-labels.sass","webpack:///./src/furo/assets/styles/components/_footer.sass","webpack:///./src/furo/assets/styles/components/_sidebar.sass","webpack:///./src/furo/assets/styles/components/_table_of_contents.sass","webpack:///./src/furo/assets/styles/_shame.sass"],"sourcesContent":["/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */\n\n/* Document\n ========================================================================== */\n\n/**\n * 1. Correct the line height in all browsers.\n * 2. Prevent adjustments of font size after orientation changes in iOS.\n */\n\nhtml {\n line-height: 1.15; /* 1 */\n -webkit-text-size-adjust: 100%; /* 2 */\n}\n\n/* Sections\n ========================================================================== */\n\n/**\n * Remove the margin in all browsers.\n */\n\nbody {\n margin: 0;\n}\n\n/**\n * Render the `main` element consistently in IE.\n */\n\nmain {\n display: block;\n}\n\n/**\n * Correct the font size and margin on `h1` elements within `section` and\n * `article` contexts in Chrome, Firefox, and Safari.\n */\n\nh1 {\n font-size: 2em;\n margin: 0.67em 0;\n}\n\n/* Grouping content\n ========================================================================== */\n\n/**\n * 1. Add the correct box sizing in Firefox.\n * 2. Show the overflow in Edge and IE.\n */\n\nhr {\n box-sizing: content-box; /* 1 */\n height: 0; /* 1 */\n overflow: visible; /* 2 */\n}\n\n/**\n * 1. Correct the inheritance and scaling of font size in all browsers.\n * 2. Correct the odd `em` font sizing in all browsers.\n */\n\npre {\n font-family: monospace, monospace; /* 1 */\n font-size: 1em; /* 2 */\n}\n\n/* Text-level semantics\n ========================================================================== */\n\n/**\n * Remove the gray background on active links in IE 10.\n */\n\na {\n background-color: transparent;\n}\n\n/**\n * 1. Remove the bottom border in Chrome 57-\n * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.\n */\n\nabbr[title] {\n border-bottom: none; /* 1 */\n text-decoration: underline; /* 2 */\n text-decoration: underline dotted; /* 2 */\n}\n\n/**\n * Add the correct font weight in Chrome, Edge, and Safari.\n */\n\nb,\nstrong {\n font-weight: bolder;\n}\n\n/**\n * 1. Correct the inheritance and scaling of font size in all browsers.\n * 2. Correct the odd `em` font sizing in all browsers.\n */\n\ncode,\nkbd,\nsamp {\n font-family: monospace, monospace; /* 1 */\n font-size: 1em; /* 2 */\n}\n\n/**\n * Add the correct font size in all browsers.\n */\n\nsmall {\n font-size: 80%;\n}\n\n/**\n * Prevent `sub` and `sup` elements from affecting the line height in\n * all browsers.\n */\n\nsub,\nsup {\n font-size: 75%;\n line-height: 0;\n position: relative;\n vertical-align: baseline;\n}\n\nsub {\n bottom: -0.25em;\n}\n\nsup {\n top: -0.5em;\n}\n\n/* Embedded content\n ========================================================================== */\n\n/**\n * Remove the border on images inside links in IE 10.\n */\n\nimg {\n border-style: none;\n}\n\n/* Forms\n ========================================================================== */\n\n/**\n * 1. Change the font styles in all browsers.\n * 2. Remove the margin in Firefox and Safari.\n */\n\nbutton,\ninput,\noptgroup,\nselect,\ntextarea {\n font-family: inherit; /* 1 */\n font-size: 100%; /* 1 */\n line-height: 1.15; /* 1 */\n margin: 0; /* 2 */\n}\n\n/**\n * Show the overflow in IE.\n * 1. Show the overflow in Edge.\n */\n\nbutton,\ninput { /* 1 */\n overflow: visible;\n}\n\n/**\n * Remove the inheritance of text transform in Edge, Firefox, and IE.\n * 1. Remove the inheritance of text transform in Firefox.\n */\n\nbutton,\nselect { /* 1 */\n text-transform: none;\n}\n\n/**\n * Correct the inability to style clickable types in iOS and Safari.\n */\n\nbutton,\n[type=\"button\"],\n[type=\"reset\"],\n[type=\"submit\"] {\n -webkit-appearance: button;\n}\n\n/**\n * Remove the inner border and padding in Firefox.\n */\n\nbutton::-moz-focus-inner,\n[type=\"button\"]::-moz-focus-inner,\n[type=\"reset\"]::-moz-focus-inner,\n[type=\"submit\"]::-moz-focus-inner {\n border-style: none;\n padding: 0;\n}\n\n/**\n * Restore the focus styles unset by the previous rule.\n */\n\nbutton:-moz-focusring,\n[type=\"button\"]:-moz-focusring,\n[type=\"reset\"]:-moz-focusring,\n[type=\"submit\"]:-moz-focusring {\n outline: 1px dotted ButtonText;\n}\n\n/**\n * Correct the padding in Firefox.\n */\n\nfieldset {\n padding: 0.35em 0.75em 0.625em;\n}\n\n/**\n * 1. Correct the text wrapping in Edge and IE.\n * 2. Correct the color inheritance from `fieldset` elements in IE.\n * 3. Remove the padding so developers are not caught out when they zero out\n * `fieldset` elements in all browsers.\n */\n\nlegend {\n box-sizing: border-box; /* 1 */\n color: inherit; /* 2 */\n display: table; /* 1 */\n max-width: 100%; /* 1 */\n padding: 0; /* 3 */\n white-space: normal; /* 1 */\n}\n\n/**\n * Add the correct vertical alignment in Chrome, Firefox, and Opera.\n */\n\nprogress {\n vertical-align: baseline;\n}\n\n/**\n * Remove the default vertical scrollbar in IE 10+.\n */\n\ntextarea {\n overflow: auto;\n}\n\n/**\n * 1. Add the correct box sizing in IE 10.\n * 2. Remove the padding in IE 10.\n */\n\n[type=\"checkbox\"],\n[type=\"radio\"] {\n box-sizing: border-box; /* 1 */\n padding: 0; /* 2 */\n}\n\n/**\n * Correct the cursor style of increment and decrement buttons in Chrome.\n */\n\n[type=\"number\"]::-webkit-inner-spin-button,\n[type=\"number\"]::-webkit-outer-spin-button {\n height: auto;\n}\n\n/**\n * 1. Correct the odd appearance in Chrome and Safari.\n * 2. Correct the outline style in Safari.\n */\n\n[type=\"search\"] {\n -webkit-appearance: textfield; /* 1 */\n outline-offset: -2px; /* 2 */\n}\n\n/**\n * Remove the inner padding in Chrome and Safari on macOS.\n */\n\n[type=\"search\"]::-webkit-search-decoration {\n -webkit-appearance: none;\n}\n\n/**\n * 1. Correct the inability to style clickable types in iOS and Safari.\n * 2. Change font properties to `inherit` in Safari.\n */\n\n::-webkit-file-upload-button {\n -webkit-appearance: button; /* 1 */\n font: inherit; /* 2 */\n}\n\n/* Interactive\n ========================================================================== */\n\n/*\n * Add the correct display in Edge, IE 10+, and Firefox.\n */\n\ndetails {\n display: block;\n}\n\n/*\n * Add the correct display in all browsers.\n */\n\nsummary {\n display: list-item;\n}\n\n/* Misc\n ========================================================================== */\n\n/**\n * Add the correct display in IE 10+.\n */\n\ntemplate {\n display: none;\n}\n\n/**\n * Add the correct display in IE 10.\n */\n\n[hidden] {\n display: none;\n}\n","// This file contains styles for managing print media.\n\n////////////////////////////////////////////////////////////////////////////////\n// Hide elements not relevant to print media.\n////////////////////////////////////////////////////////////////////////////////\n@media print\n // Hide icon container.\n .content-icon-container\n display: none !important\n\n // Hide showing header links if hovering over when printing.\n .headerlink\n display: none !important\n\n // Hide mobile header.\n .mobile-header\n display: none !important\n\n // Hide navigation links.\n .related-pages\n display: none !important\n\n////////////////////////////////////////////////////////////////////////////////\n// Tweaks related to decolorization.\n////////////////////////////////////////////////////////////////////////////////\n@media print\n // Apply a border around code which no longer have a color background.\n .highlight\n border: 0.1pt solid var(--color-foreground-border)\n\n////////////////////////////////////////////////////////////////////////////////\n// Avoid page break in some relevant cases.\n////////////////////////////////////////////////////////////////////////////////\n@media print\n ul, ol, dl, a, table, pre, blockquote, p\n page-break-inside: avoid\n\n h1, h2, h3, h4, h5, h6, img, figure, caption\n page-break-inside: avoid\n page-break-after: avoid\n\n ul, ol, dl\n page-break-before: avoid\n",".visually-hidden\n position: absolute !important\n width: 1px !important\n height: 1px !important\n padding: 0 !important\n margin: -1px !important\n overflow: hidden !important\n clip: rect(0,0,0,0) !important\n white-space: nowrap !important\n border: 0 !important\n color: var(--color-foreground-primary)\n background: var(--color-background-primary)\n\n:-moz-focusring\n outline: auto\n","// This file serves as the \"skeleton\" of the theming logic.\n//\n// This contains the bulk of the logic for handling dark mode, color scheme\n// toggling and the handling of color-scheme-specific hiding of elements.\n\nbody\n @include fonts\n @include spacing\n @include icons\n @include admonitions\n @include default-admonition(#651fff, \"abstract\")\n @include default-topic(#14B8A6, \"pencil\")\n\n @include colors\n\n.only-light\n display: block !important\nhtml body .only-dark\n display: none !important\n\n// Ignore dark-mode hints if print media.\n@media not print\n // Enable dark-mode, if requested.\n body[data-theme=\"dark\"]\n @include colors-dark\n\n html & .only-light\n display: none !important\n .only-dark\n display: block !important\n\n // Enable dark mode, unless explicitly told to avoid.\n @media (prefers-color-scheme: dark)\n body:not([data-theme=\"light\"])\n @include colors-dark\n\n html & .only-light\n display: none !important\n .only-dark\n display: block !important\n\n//\n// Theme toggle presentation\n//\nbody[data-theme=\"auto\"]\n .theme-toggle svg.theme-icon-when-auto-light\n display: block\n\n @media (prefers-color-scheme: dark)\n .theme-toggle svg.theme-icon-when-auto-dark\n display: block\n .theme-toggle svg.theme-icon-when-auto-light\n display: none\n\nbody[data-theme=\"dark\"]\n .theme-toggle svg.theme-icon-when-dark\n display: block\n\nbody[data-theme=\"light\"]\n .theme-toggle svg.theme-icon-when-light\n display: block\n","// Fonts used by this theme.\n//\n// There are basically two things here -- using the system font stack and\n// defining sizes for various elements in %ages. We could have also used `em`\n// but %age is easier to reason about for me.\n\n@mixin fonts {\n // These are adapted from https://systemfontstack.com/\n --font-stack: -apple-system, BlinkMacSystemFont, Segoe UI, Helvetica, Arial,\n sans-serif, Apple Color Emoji, Segoe UI Emoji;\n --font-stack--monospace: \"SFMono-Regular\", Menlo, Consolas, Monaco,\n Liberation Mono, Lucida Console, monospace;\n --font-stack--headings: var(--font-stack);\n\n --font-size--normal: 100%;\n --font-size--small: 87.5%;\n --font-size--small--2: 81.25%;\n --font-size--small--3: 75%;\n --font-size--small--4: 62.5%;\n\n // Sidebar\n --sidebar-caption-font-size: var(--font-size--small--2);\n --sidebar-item-font-size: var(--font-size--small);\n --sidebar-search-input-font-size: var(--font-size--small);\n\n // Table of Contents\n --toc-font-size: var(--font-size--small--3);\n --toc-font-size--mobile: var(--font-size--normal);\n --toc-title-font-size: var(--font-size--small--4);\n\n // Admonitions\n //\n // These aren't defined in terms of %ages, since nesting these is permitted.\n --admonition-font-size: 0.8125rem;\n --admonition-title-font-size: 0.8125rem;\n\n // Code\n --code-font-size: var(--font-size--small--2);\n\n // API\n --api-font-size: var(--font-size--small);\n}\n","// Spacing for various elements on the page\n//\n// If the user wants to tweak things in a certain way, they are permitted to.\n// They also have to deal with the consequences though!\n\n@mixin spacing {\n // Header!\n --header-height: calc(\n var(--sidebar-item-line-height) + 4 * #{var(--sidebar-item-spacing-vertical)}\n );\n --header-padding: 0.5rem;\n\n // Sidebar\n --sidebar-tree-space-above: 1.5rem;\n --sidebar-caption-space-above: 1rem;\n\n --sidebar-item-line-height: 1rem;\n --sidebar-item-spacing-vertical: 0.5rem;\n --sidebar-item-spacing-horizontal: 1rem;\n --sidebar-item-height: calc(\n var(--sidebar-item-line-height) + 2 *#{var(--sidebar-item-spacing-vertical)}\n );\n\n --sidebar-expander-width: var(--sidebar-item-height); // be square\n\n --sidebar-search-space-above: 0.5rem;\n --sidebar-search-input-spacing-vertical: 0.5rem;\n --sidebar-search-input-spacing-horizontal: 0.5rem;\n --sidebar-search-input-height: 1rem;\n --sidebar-search-icon-size: var(--sidebar-search-input-height);\n\n // Table of Contents\n --toc-title-padding: 0.25rem 0;\n --toc-spacing-vertical: 1.5rem;\n --toc-spacing-horizontal: 1.5rem;\n --toc-item-spacing-vertical: 0.4rem;\n --toc-item-spacing-horizontal: 1rem;\n}\n","// Expose theme icons as CSS variables.\n\n$icons: (\n // Adapted from tabler-icons\n // url: https://tablericons.com/\n \"search\":\n url('data:image/svg+xml;charset=utf-8,'),\n // Factored out from mkdocs-material on 24-Aug-2020.\n // url: https://squidfunk.github.io/mkdocs-material/reference/admonitions/\n \"pencil\":\n url('data:image/svg+xml;charset=utf-8,'),\n \"abstract\":\n url('data:image/svg+xml;charset=utf-8,'),\n \"info\":\n url('data:image/svg+xml;charset=utf-8,'),\n \"flame\":\n url('data:image/svg+xml;charset=utf-8,'),\n \"question\":\n url('data:image/svg+xml;charset=utf-8,'),\n \"warning\":\n url('data:image/svg+xml;charset=utf-8,'),\n \"failure\":\n url('data:image/svg+xml;charset=utf-8,'),\n \"spark\":\n url('data:image/svg+xml;charset=utf-8,')\n);\n\n@mixin icons {\n @each $name, $glyph in $icons {\n --icon-#{$name}: #{$glyph};\n }\n}\n","// Admonitions\n\n// Structure of these is:\n// admonition-class: color \"icon-name\";\n//\n// The colors are translated into CSS variables below. The icons are\n// used directly in the main declarations to set the `mask-image` in\n// the title.\n\n// prettier-ignore\n$admonitions: (\n // Each of these has an reST directives for it.\n \"caution\": #ff9100 \"spark\",\n \"warning\": #ff9100 \"warning\",\n \"danger\": #ff5252 \"spark\",\n \"attention\": #ff5252 \"warning\",\n \"error\": #ff5252 \"failure\",\n \"hint\": #00c852 \"question\",\n \"tip\": #00c852 \"info\",\n \"important\": #00bfa5 \"flame\",\n \"note\": #00b0ff \"pencil\",\n \"seealso\": #448aff \"info\",\n \"admonition-todo\": #808080 \"pencil\"\n);\n\n@mixin default-admonition($color, $icon-name) {\n --color-admonition-title: #{$color};\n --color-admonition-title-background: #{rgba($color, 0.2)};\n\n --icon-admonition-default: var(--icon-#{$icon-name});\n}\n\n@mixin default-topic($color, $icon-name) {\n --color-topic-title: #{$color};\n --color-topic-title-background: #{rgba($color, 0.2)};\n\n --icon-topic-default: var(--icon-#{$icon-name});\n}\n\n@mixin admonitions {\n @each $name, $values in $admonitions {\n --color-admonition-title--#{$name}: #{nth($values, 1)};\n --color-admonition-title-background--#{$name}: #{rgba(\n nth($values, 1),\n 0.2\n )};\n }\n}\n","// Colors used throughout this theme.\n//\n// The aim is to give the user more control. Thus, instead of hard-coding colors\n// in various parts of the stylesheet, the approach taken is to define all\n// colors as CSS variables and reusing them in all the places.\n//\n// `colors-dark` depends on `colors` being included at a lower specificity.\n\n@mixin colors {\n --color-problematic: #b30000;\n\n // Base Colors\n --color-foreground-primary: black; // for main text and headings\n --color-foreground-secondary: #5a5c63; // for secondary text\n --color-foreground-muted: #6b6f76; // for muted text\n --color-foreground-border: #878787; // for content borders\n\n --color-background-primary: white; // for content\n --color-background-secondary: #f8f9fb; // for navigation + ToC\n --color-background-hover: #efeff4ff; // for navigation-item hover\n --color-background-hover--transparent: #efeff400;\n --color-background-border: #eeebee; // for UI borders\n --color-background-item: #ccc; // for \"background\" items (eg: copybutton)\n\n // Announcements\n --color-announcement-background: #000000dd;\n --color-announcement-text: #eeebee;\n\n // Brand colors\n --color-brand-primary: #0a4bff;\n --color-brand-content: #2757dd;\n --color-brand-visited: #872ee0;\n\n // API documentation\n --color-api-background: var(--color-background-hover--transparent);\n --color-api-background-hover: var(--color-background-hover);\n --color-api-overall: var(--color-foreground-secondary);\n --color-api-name: var(--color-problematic);\n --color-api-pre-name: var(--color-problematic);\n --color-api-paren: var(--color-foreground-secondary);\n --color-api-keyword: var(--color-foreground-primary);\n\n --color-api-added: #21632c;\n --color-api-added-border: #38a84d;\n --color-api-changed: #046172;\n --color-api-changed-border: #06a1bc;\n --color-api-deprecated: #605706;\n --color-api-deprecated-border: #f0d90f;\n --color-api-removed: #b30000;\n --color-api-removed-border: #ff5c5c;\n\n --color-highlight-on-target: #ffffcc;\n\n // Inline code background\n --color-inline-code-background: var(--color-background-secondary);\n\n // Highlighted text (search)\n --color-highlighted-background: #ddeeff;\n --color-highlighted-text: var(--color-foreground-primary);\n\n // GUI Labels\n --color-guilabel-background: #ddeeff80;\n --color-guilabel-border: #bedaf580;\n --color-guilabel-text: var(--color-foreground-primary);\n\n // Admonitions!\n --color-admonition-background: transparent;\n\n //////////////////////////////////////////////////////////////////////////////\n // Everything below this should be one of:\n // - var(...)\n // - *-gradient(...)\n // - special literal values (eg: transparent, none)\n //////////////////////////////////////////////////////////////////////////////\n\n // Tables\n --color-table-header-background: var(--color-background-secondary);\n --color-table-border: var(--color-background-border);\n\n // Cards\n --color-card-border: var(--color-background-secondary);\n --color-card-background: transparent;\n --color-card-marginals-background: var(--color-background-secondary);\n\n // Header\n --color-header-background: var(--color-background-primary);\n --color-header-border: var(--color-background-border);\n --color-header-text: var(--color-foreground-primary);\n\n // Sidebar (left)\n --color-sidebar-background: var(--color-background-secondary);\n --color-sidebar-background-border: var(--color-background-border);\n\n --color-sidebar-brand-text: var(--color-foreground-primary);\n --color-sidebar-caption-text: var(--color-foreground-muted);\n --color-sidebar-link-text: var(--color-foreground-secondary);\n --color-sidebar-link-text--top-level: var(--color-brand-primary);\n\n --color-sidebar-item-background: var(--color-sidebar-background);\n --color-sidebar-item-background--current: var(\n --color-sidebar-item-background\n );\n --color-sidebar-item-background--hover: linear-gradient(\n 90deg,\n var(--color-background-hover--transparent) 0%,\n var(--color-background-hover) var(--sidebar-item-spacing-horizontal),\n var(--color-background-hover) 100%\n );\n\n --color-sidebar-item-expander-background: transparent;\n --color-sidebar-item-expander-background--hover: var(\n --color-background-hover\n );\n\n --color-sidebar-search-text: var(--color-foreground-primary);\n --color-sidebar-search-background: var(--color-background-secondary);\n --color-sidebar-search-background--focus: var(--color-background-primary);\n --color-sidebar-search-border: var(--color-background-border);\n --color-sidebar-search-icon: var(--color-foreground-muted);\n\n // Table of Contents (right)\n --color-toc-background: var(--color-background-primary);\n --color-toc-title-text: var(--color-foreground-muted);\n --color-toc-item-text: var(--color-foreground-secondary);\n --color-toc-item-text--hover: var(--color-foreground-primary);\n --color-toc-item-text--active: var(--color-brand-primary);\n\n // Actual page contents\n --color-content-foreground: var(--color-foreground-primary);\n --color-content-background: transparent;\n\n // Links\n --color-link: var(--color-brand-content);\n --color-link-underline: var(--color-background-border);\n --color-link--hover: var(--color-brand-content);\n --color-link-underline--hover: var(--color-foreground-border);\n\n --color-link--visited: var(--color-brand-visited);\n --color-link-underline--visited: var(--color-background-border);\n --color-link--visited--hover: var(--color-brand-visited);\n --color-link-underline--visited--hover: var(--color-foreground-border);\n}\n\n@mixin colors-dark {\n --color-problematic: #ee5151;\n\n // Base Colors\n --color-foreground-primary: #cfd0d0; // for main text and headings\n --color-foreground-secondary: #9ca0a5; // for secondary text\n --color-foreground-muted: #81868d; // for muted text\n --color-foreground-border: #666666; // for content borders\n\n --color-background-primary: #131416; // for content\n --color-background-secondary: #1a1c1e; // for navigation + ToC\n --color-background-hover: #1e2124ff; // for navigation-item hover\n --color-background-hover--transparent: #1e212400;\n --color-background-border: #303335; // for UI borders\n --color-background-item: #444; // for \"background\" items (eg: copybutton)\n\n // Announcements\n --color-announcement-background: #000000dd;\n --color-announcement-text: #eeebee;\n\n // Brand colors\n --color-brand-primary: #3d94ff;\n --color-brand-content: #5ca5ff;\n --color-brand-visited: #b27aeb;\n\n // Highlighted text (search)\n --color-highlighted-background: #083563;\n\n // GUI Labels\n --color-guilabel-background: #08356380;\n --color-guilabel-border: #13395f80;\n\n // API documentation\n --color-api-keyword: var(--color-foreground-secondary);\n --color-highlight-on-target: #333300;\n\n --color-api-added: #3db854;\n --color-api-added-border: #267334;\n --color-api-changed: #09b0ce;\n --color-api-changed-border: #056d80;\n --color-api-deprecated: #b1a10b;\n --color-api-deprecated-border: #6e6407;\n --color-api-removed: #ff7575;\n --color-api-removed-border: #b03b3b;\n\n // Admonitions\n --color-admonition-background: #18181a;\n\n // Cards\n --color-card-border: var(--color-background-secondary);\n --color-card-background: #18181a;\n --color-card-marginals-background: var(--color-background-hover);\n}\n","// This file contains the styling for making the content throughout the page,\n// including fonts, paragraphs, headings and spacing among these elements.\n\nbody\n font-family: var(--font-stack)\npre,\ncode,\nkbd,\nsamp\n font-family: var(--font-stack--monospace)\n\n// Make fonts look slightly nicer.\nbody\n -webkit-font-smoothing: antialiased\n -moz-osx-font-smoothing: grayscale\n\n// Line height from Bootstrap 4.1\narticle\n line-height: 1.5\n\n//\n// Headings\n//\nh1,\nh2,\nh3,\nh4,\nh5,\nh6\n line-height: 1.25\n font-family: var(--font-stack--headings)\n font-weight: bold\n\n border-radius: 0.5rem\n margin-top: 0.5rem\n margin-bottom: 0.5rem\n margin-left: -0.5rem\n margin-right: -0.5rem\n padding-left: 0.5rem\n padding-right: 0.5rem\n\n + p\n margin-top: 0\n\nh1\n font-size: 2.5em\n margin-top: 1.75rem\n margin-bottom: 1rem\nh2\n font-size: 2em\n margin-top: 1.75rem\nh3\n font-size: 1.5em\nh4\n font-size: 1.25em\nh5\n font-size: 1.125em\nh6\n font-size: 1em\n\nsmall\n opacity: 75%\n font-size: 80%\n\n// Paragraph\np\n margin-top: 0.5rem\n margin-bottom: 0.75rem\n\n// Horizontal rules\nhr.docutils\n height: 1px\n padding: 0\n margin: 2rem 0\n background-color: var(--color-background-border)\n border: 0\n\n.centered\n text-align: center\n\n// Links\na\n text-decoration: underline\n\n color: var(--color-link)\n text-decoration-color: var(--color-link-underline)\n\n &:visited\n color: var(--color-link--visited)\n text-decoration-color: var(--color-link-underline--visited)\n &:hover\n color: var(--color-link--visited--hover)\n text-decoration-color: var(--color-link-underline--visited--hover)\n\n &:hover\n color: var(--color-link--hover)\n text-decoration-color: var(--color-link-underline--hover)\n &.muted-link\n color: inherit\n &:hover\n color: var(--color-link--hover)\n text-decoration-color: var(--color-link-underline--hover)\n &:visited\n color: var(--color-link--visited--hover)\n text-decoration-color: var(--color-link-underline--visited--hover)\n","// This file contains the styles for the overall layouting of the documentation\n// skeleton, including the responsive changes as well as sidebar toggles.\n//\n// This is implemented as a mobile-last design, which isn't ideal, but it is\n// reasonably good-enough and I got pretty tired by the time I'd finished this\n// to move the rules around to fix this. Shouldn't take more than 3-4 hours,\n// if you know what you're doing tho.\n\n// HACK: Not all browsers account for the scrollbar width in media queries.\n// This results in horizontal scrollbars in the breakpoint where we go\n// from displaying everything to hiding the ToC. We accomodate for this by\n// adding a bit of padding to the TOC drawer, disabling the horizontal\n// scrollbar and allowing the scrollbars to cover the padding.\n// https://www.456bereastreet.com/archive/201301/media_query_width_and_vertical_scrollbars/\n\n// HACK: Always having the scrollbar visible, prevents certain browsers from\n// causing the content to stutter horizontally between taller-than-viewport and\n// not-taller-than-viewport pages.\n\nhtml\n overflow-x: hidden\n overflow-y: scroll\n scroll-behavior: smooth\n\n.sidebar-scroll, .toc-scroll, article[role=main] *\n // Override Firefox scrollbar style\n scrollbar-width: thin\n scrollbar-color: var(--color-foreground-border) transparent\n\n // Override Chrome scrollbar styles\n &::-webkit-scrollbar\n width: 0.25rem\n height: 0.25rem\n &::-webkit-scrollbar-thumb\n background-color: var(--color-foreground-border)\n border-radius: 0.125rem\n\n//\n// Overalls\n//\nhtml,\nbody\n height: 100%\n color: var(--color-foreground-primary)\n background: var(--color-background-primary)\n\n.skip-to-content\n position: fixed\n padding: 1rem\n border-radius: 1rem\n left: 0.25rem\n top: 0.25rem\n z-index: 40\n background: var(--color-background-primary)\n color: var(--color-foreground-primary)\n\n transform: translateY(-200%)\n transition: transform 300ms ease-in-out\n\n &:focus-within\n transform: translateY(0%)\n\narticle\n color: var(--color-content-foreground)\n background: var(--color-content-background)\n overflow-wrap: break-word\n\n.page\n display: flex\n // fill the viewport for pages with little content.\n min-height: 100%\n\n.mobile-header\n width: 100%\n height: var(--header-height)\n background-color: var(--color-header-background)\n color: var(--color-header-text)\n border-bottom: 1px solid var(--color-header-border)\n\n // Looks like sub-script/super-script have this, and we need this to\n // be \"on top\" of those.\n z-index: 10\n\n // We don't show the header on large screens.\n display: none\n\n // Add shadow when scrolled\n &.scrolled\n border-bottom: none\n box-shadow: 0 0 0.2rem rgba(0, 0, 0, 0.1), 0 0.2rem 0.4rem rgba(0, 0, 0, 0.2)\n\n .header-center\n a\n color: var(--color-header-text)\n text-decoration: none\n\n.main\n display: flex\n flex: 1\n\n// Sidebar (left) also covers the entire left portion of screen.\n.sidebar-drawer\n box-sizing: border-box\n\n border-right: 1px solid var(--color-sidebar-background-border)\n background: var(--color-sidebar-background)\n\n display: flex\n justify-content: flex-end\n // These next two lines took me two days to figure out.\n width: calc((100% - #{$full-width}) / 2 + #{$sidebar-width})\n min-width: $sidebar-width\n\n// Scroll-along sidebars\n.sidebar-container,\n.toc-drawer\n box-sizing: border-box\n width: $sidebar-width\n\n.toc-drawer\n background: var(--color-toc-background)\n // See HACK described on top of this document\n padding-right: 1rem\n\n.sidebar-sticky,\n.toc-sticky\n position: sticky\n top: 0\n height: min(100%, 100vh)\n height: 100vh\n\n display: flex\n flex-direction: column\n\n.sidebar-scroll,\n.toc-scroll\n flex-grow: 1\n flex-shrink: 1\n\n overflow: auto\n scroll-behavior: smooth\n\n// Central items.\n.content\n padding: 0 $content-padding\n width: $content-width\n\n display: flex\n flex-direction: column\n justify-content: space-between\n\n.icon\n display: inline-block\n height: 1rem\n width: 1rem\n svg\n width: 100%\n height: 100%\n\n//\n// Accommodate announcement banner\n//\n.announcement\n background-color: var(--color-announcement-background)\n color: var(--color-announcement-text)\n\n height: var(--header-height)\n display: flex\n align-items: center\n overflow-x: auto\n & + .page\n min-height: calc(100% - var(--header-height))\n\n.announcement-content\n box-sizing: border-box\n padding: 0.5rem\n min-width: 100%\n white-space: nowrap\n text-align: center\n\n a\n color: var(--color-announcement-text)\n text-decoration-color: var(--color-announcement-text)\n\n &:hover\n color: var(--color-announcement-text)\n text-decoration-color: var(--color-link--hover)\n\n////////////////////////////////////////////////////////////////////////////////\n// Toggles for theme\n////////////////////////////////////////////////////////////////////////////////\n.no-js .theme-toggle-container // don't show theme toggle if there's no JS\n display: none\n\n.theme-toggle-container\n display: flex\n\n.theme-toggle\n display: flex\n cursor: pointer\n border: none\n padding: 0\n background: transparent\n\n.theme-toggle svg\n height: 1.25rem\n width: 1.25rem\n color: var(--color-foreground-primary)\n display: none\n\n.theme-toggle-header\n display: flex\n align-items: center\n justify-content: center\n\n////////////////////////////////////////////////////////////////////////////////\n// Toggles for elements\n////////////////////////////////////////////////////////////////////////////////\n.toc-overlay-icon, .nav-overlay-icon\n display: none\n cursor: pointer\n\n .icon\n color: var(--color-foreground-secondary)\n height: 1.5rem\n width: 1.5rem\n\n.toc-header-icon, .nav-overlay-icon\n // for when we set display: flex\n justify-content: center\n align-items: center\n\n.toc-content-icon\n height: 1.5rem\n width: 1.5rem\n\n.content-icon-container\n float: right\n display: flex\n margin-top: 1.5rem\n margin-left: 1rem\n margin-bottom: 1rem\n gap: 0.5rem\n\n .edit-this-page, .view-this-page\n svg\n color: inherit\n height: 1.25rem\n width: 1.25rem\n\n.sidebar-toggle\n position: absolute\n display: none\n// \n.sidebar-toggle[name=\"__toc\"]\n left: 20px\n.sidebar-toggle:checked\n left: 40px\n// \n\n.overlay\n position: fixed\n top: 0\n width: 0\n height: 0\n\n transition: width 0ms, height 0ms, opacity 250ms ease-out\n\n opacity: 0\n background-color: rgba(0, 0, 0, 0.54)\n.sidebar-overlay\n z-index: 20\n.toc-overlay\n z-index: 40\n\n// Keep things on top and smooth.\n.sidebar-drawer\n z-index: 30\n transition: left 250ms ease-in-out\n.toc-drawer\n z-index: 50\n transition: right 250ms ease-in-out\n\n// Show the Sidebar\n#__navigation:checked\n & ~ .sidebar-overlay\n width: 100%\n height: 100%\n opacity: 1\n & ~ .page\n .sidebar-drawer\n top: 0\n left: 0\n // Show the toc sidebar\n#__toc:checked\n & ~ .toc-overlay\n width: 100%\n height: 100%\n opacity: 1\n & ~ .page\n .toc-drawer\n top: 0\n right: 0\n\n////////////////////////////////////////////////////////////////////////////////\n// Back to top\n////////////////////////////////////////////////////////////////////////////////\n.back-to-top\n text-decoration: none\n\n display: none\n position: fixed\n left: 0\n top: 1rem\n padding: 0.5rem\n padding-right: 0.75rem\n border-radius: 1rem\n font-size: 0.8125rem\n\n background: var(--color-background-primary)\n box-shadow: 0 0.2rem 0.5rem rgba(0, 0, 0, 0.05), #6b728080 0px 0px 1px 0px\n\n z-index: 10\n\n margin-left: 50%\n transform: translateX(-50%)\n svg\n height: 1rem\n width: 1rem\n fill: currentColor\n display: inline-block\n\n span\n margin-left: 0.25rem\n\n .show-back-to-top &\n display: flex\n align-items: center\n\n////////////////////////////////////////////////////////////////////////////////\n// Responsive layouting\n////////////////////////////////////////////////////////////////////////////////\n// Make things a bit bigger on bigger screens.\n@media (min-width: $full-width + $sidebar-width)\n html\n font-size: 110%\n\n@media (max-width: $full-width)\n // Collapse \"toc\" into the icon.\n .toc-content-icon\n display: flex\n .toc-drawer\n position: fixed\n height: 100vh\n top: 0\n right: -$sidebar-width\n border-left: 1px solid var(--color-background-muted)\n .toc-tree\n border-left: none\n font-size: var(--toc-font-size--mobile)\n\n // Accomodate for a changed content width.\n .sidebar-drawer\n width: calc((100% - #{$full-width - $sidebar-width}) / 2 + #{$sidebar-width})\n\n@media (max-width: $content-padded-width + $sidebar-width)\n // Center the page\n .content\n margin-left: auto\n margin-right: auto\n padding: 0 $content-padding--small\n\n@media (max-width: $content-padded-width--small + $sidebar-width)\n // Collapse \"navigation\".\n .nav-overlay-icon\n display: flex\n .sidebar-drawer\n position: fixed\n height: 100vh\n width: $sidebar-width\n\n top: 0\n left: -$sidebar-width\n\n // Swap which icon is visible.\n .toc-header-icon, .theme-toggle-header\n display: flex\n .toc-content-icon, .theme-toggle-content\n display: none\n\n // Show the header.\n .mobile-header\n position: sticky\n top: 0\n display: flex\n justify-content: space-between\n align-items: center\n\n .header-left,\n .header-right\n display: flex\n height: var(--header-height)\n padding: 0 var(--header-padding)\n label\n height: 100%\n width: 100%\n user-select: none\n\n .nav-overlay-icon .icon,\n .theme-toggle svg\n height: 1.5rem\n width: 1.5rem\n\n // Add a scroll margin for the content\n :target\n scroll-margin-top: calc(var(--header-height) + 2.5rem)\n\n // Show back-to-top below the header\n .back-to-top\n top: calc(var(--header-height) + 0.5rem)\n\n // Accommodate for the header.\n .page\n flex-direction: column\n justify-content: center\n\n@media (max-width: $content-width + 2* $content-padding--small)\n // Content should respect window limits.\n .content\n width: 100%\n overflow-x: auto\n\n@media (max-width: $content-width)\n article[role=main] aside.sidebar\n float: none\n width: 100%\n margin: 1rem 0\n","// Overall Layout Variables\n//\n// Because CSS variables can't be used in media queries. The fact that this\n// makes the layout non-user-configurable is a good thing.\n$content-padding: 3em;\n$content-padding--small: 1em;\n$content-width: 46em;\n$sidebar-width: 15em;\n$content-padded-width: $content-width + 2 * $content-padding;\n$content-padded-width--small: $content-width + 2 * $content-padding--small;\n$full-width: $content-padded-width + 2 * $sidebar-width;\n","//\n// The design here is strongly inspired by mkdocs-material.\n.admonition, .topic\n margin: 1rem auto\n padding: 0 0.5rem 0.5rem 0.5rem\n\n background: var(--color-admonition-background)\n\n border-radius: 0.2rem\n box-shadow: 0 0.2rem 0.5rem rgba(0, 0, 0, 0.05), 0 0 0.0625rem rgba(0, 0, 0, 0.1)\n\n font-size: var(--admonition-font-size)\n\n overflow: hidden\n page-break-inside: avoid\n\n // First element should have no margin, since the title has it.\n > :nth-child(2)\n margin-top: 0\n\n // Last item should have no margin, since we'll control that w/ padding\n > :last-child\n margin-bottom: 0\n\n.admonition p.admonition-title,\np.topic-title\n position: relative\n margin: 0 -0.5rem 0.5rem\n padding-left: 2rem\n padding-right: .5rem\n padding-top: .4rem\n padding-bottom: .4rem\n\n font-weight: 500\n font-size: var(--admonition-title-font-size)\n line-height: 1.3\n\n // Our fancy icon\n &::before\n content: \"\"\n position: absolute\n left: 0.5rem\n width: 1rem\n height: 1rem\n\n// Default styles\np.admonition-title\n background-color: var(--color-admonition-title-background)\n &::before\n background-color: var(--color-admonition-title)\n mask-image: var(--icon-admonition-default)\n mask-repeat: no-repeat\n\np.topic-title\n background-color: var(--color-topic-title-background)\n &::before\n background-color: var(--color-topic-title)\n mask-image: var(--icon-topic-default)\n mask-repeat: no-repeat\n\n//\n// Variants\n//\n.admonition\n border-left: 0.2rem solid var(--color-admonition-title)\n\n @each $type, $value in $admonitions\n &.#{$type}\n border-left-color: var(--color-admonition-title--#{$type})\n > .admonition-title\n background-color: var(--color-admonition-title-background--#{$type})\n &::before\n background-color: var(--color-admonition-title--#{$type})\n mask-image: var(--icon-#{nth($value, 2)})\n\n.admonition-todo > .admonition-title\n text-transform: uppercase\n","// This file stylizes the API documentation (stuff generated by autodoc). It's\n// deeply nested due to how autodoc structures the HTML without enough classes\n// to select the relevant items.\n\n// API docs!\ndl[class]:not(.option-list):not(.field-list):not(.footnote):not(.glossary):not(.simple)\n // Tweak the spacing of all the things!\n dd\n margin-left: 2rem\n > :first-child\n margin-top: 0.125rem\n > :last-child\n margin-bottom: 0.75rem\n\n // This is used for the arguments\n .field-list\n margin-bottom: 0.75rem\n\n // \"Headings\" (like \"Parameters\" and \"Return\")\n > dt\n text-transform: uppercase\n font-size: var(--font-size--small)\n\n dd:empty\n margin-bottom: 0.5rem\n dd > ul\n margin-left: -1.2rem\n > li\n > p:nth-child(2)\n margin-top: 0\n // When the last-empty-paragraph follows a paragraph, it doesn't need\n // to augument the existing spacing.\n > p + p:last-child:empty\n margin-top: 0\n margin-bottom: 0\n\n // Colorize the elements\n > dt\n color: var(--color-api-overall)\n\n.sig:not(.sig-inline)\n font-weight: bold\n\n font-size: var(--api-font-size)\n font-family: var(--font-stack--monospace)\n\n margin-left: -0.25rem\n margin-right: -0.25rem\n padding-top: 0.25rem\n padding-bottom: 0.25rem\n padding-right: 0.5rem\n\n // These are intentionally em, to properly match the font size.\n padding-left: 3em\n text-indent: -2.5em\n\n border-radius: 0.25rem\n\n background: var(--color-api-background)\n transition: background 100ms ease-out\n\n &:hover\n background: var(--color-api-background-hover)\n\n // adjust the size of the [source] link on the right.\n a.reference\n .viewcode-link\n font-weight: normal\n width: 4.25rem\n\nem.property\n font-style: normal\n &:first-child\n color: var(--color-api-keyword)\n.sig-name\n color: var(--color-api-name)\n.sig-prename\n font-weight: normal\n color: var(--color-api-pre-name)\n.sig-paren\n color: var(--color-api-paren)\n.sig-param\n font-style: normal\n\ndiv.versionadded,\ndiv.versionchanged,\ndiv.deprecated,\ndiv.versionremoved\n border-left: 0.1875rem solid\n border-radius: 0.125rem\n\n padding-left: 0.75rem\n\n p\n margin-top: 0.125rem\n margin-bottom: 0.125rem\n\ndiv.versionadded\n border-color: var(--color-api-added-border)\n .versionmodified\n color: var(--color-api-added)\n\ndiv.versionchanged\n border-color: var(--color-api-changed-border)\n .versionmodified\n color: var(--color-api-changed)\n\ndiv.deprecated\n border-color: var(--color-api-deprecated-border)\n .versionmodified\n color: var(--color-api-deprecated)\n\ndiv.versionremoved\n border-color: var(--color-api-removed-border)\n .versionmodified\n color: var(--color-api-removed)\n\n// Align the [docs] and [source] to the right.\n.viewcode-link, .viewcode-back\n float: right\n text-align: right\n",".line-block\n margin-top: 0.5rem\n margin-bottom: 0.75rem\n .line-block\n margin-top: 0rem\n margin-bottom: 0rem\n padding-left: 1rem\n","// Captions\narticle p.caption,\ntable > caption,\n.code-block-caption\n font-size: var(--font-size--small)\n text-align: center\n\n// Caption above a TOCTree\n.toctree-wrapper.compound\n .caption, :not(.caption) > .caption-text\n font-size: var(--font-size--small)\n text-transform: uppercase\n\n text-align: initial\n margin-bottom: 0\n\n > ul\n margin-top: 0\n margin-bottom: 0\n","// Inline code\ncode.literal, .sig-inline\n background: var(--color-inline-code-background)\n border-radius: 0.2em\n // Make the font smaller, and use padding to recover.\n font-size: var(--font-size--small--2)\n padding: 0.1em 0.2em\n\n pre.literal-block &\n font-size: inherit\n padding: 0\n\n p &\n border: 1px solid var(--color-background-border)\n\n.sig-inline\n font-family: var(--font-stack--monospace)\n\n// Code and Literal Blocks\n$code-spacing-vertical: 0.625rem\n$code-spacing-horizontal: 0.875rem\n\n// Wraps every literal block + line numbers.\ndiv[class*=\" highlight-\"],\ndiv[class^=\"highlight-\"]\n margin: 1em 0\n display: flex\n\n .table-wrapper\n margin: 0\n padding: 0\n\npre\n margin: 0\n padding: 0\n overflow: auto\n\n // Needed to have more specificity than pygments' \"pre\" selector. :(\n article[role=\"main\"] .highlight &\n line-height: 1.5\n\n &.literal-block,\n .highlight &\n font-size: var(--code-font-size)\n padding: $code-spacing-vertical $code-spacing-horizontal\n\n // Make it look like all the other blocks.\n &.literal-block\n margin-top: 1rem\n margin-bottom: 1rem\n\n border-radius: 0.2rem\n background-color: var(--color-code-background)\n color: var(--color-code-foreground)\n\n// All code is always contained in this.\n.highlight\n width: 100%\n border-radius: 0.2rem\n\n // Make line numbers and prompts un-selectable.\n .gp, span.linenos\n user-select: none\n pointer-events: none\n\n // Expand the line-highlighting.\n .hll\n display: block\n margin-left: -$code-spacing-horizontal\n margin-right: -$code-spacing-horizontal\n padding-left: $code-spacing-horizontal\n padding-right: $code-spacing-horizontal\n\n/* Make code block captions be nicely integrated */\n.code-block-caption\n display: flex\n padding: $code-spacing-vertical $code-spacing-horizontal\n\n border-radius: 0.25rem\n border-bottom-left-radius: 0\n border-bottom-right-radius: 0\n font-weight: 300\n border-bottom: 1px solid\n\n background-color: var(--color-code-background)\n color: var(--color-code-foreground)\n border-color: var(--color-background-border)\n\n + div[class]\n margin-top: 0\n pre\n border-top-left-radius: 0\n border-top-right-radius: 0\n\n// When `html_codeblock_linenos_style` is table.\n.highlighttable\n width: 100%\n display: block\n tbody\n display: block\n\n tr\n display: flex\n\n // Line numbers\n td.linenos\n background-color: var(--color-code-background)\n color: var(--color-code-foreground)\n padding: $code-spacing-vertical $code-spacing-horizontal\n padding-right: 0\n border-top-left-radius: 0.2rem\n border-bottom-left-radius: 0.2rem\n\n .linenodiv\n padding-right: $code-spacing-horizontal\n font-size: var(--code-font-size)\n box-shadow: -0.0625rem 0 var(--color-foreground-border) inset\n\n // Actual code\n td.code\n padding: 0\n display: block\n flex: 1\n overflow: hidden\n\n .highlight\n border-top-left-radius: 0\n border-bottom-left-radius: 0\n\n// When `html_codeblock_linenos_style` is inline.\n.highlight\n span.linenos\n display: inline-block\n padding-left: 0\n padding-right: $code-spacing-horizontal\n margin-right: $code-spacing-horizontal\n box-shadow: -0.0625rem 0 var(--color-foreground-border) inset\n","// Inline Footnote Reference\n.footnote-reference\n font-size: var(--font-size--small--4)\n vertical-align: super\n\n// Definition list, listing the content of each note.\n// docutils <= 0.17\ndl.footnote.brackets\n font-size: var(--font-size--small)\n color: var(--color-foreground-secondary)\n\n display: grid\n grid-template-columns: max-content auto\n dt\n margin: 0\n > .fn-backref\n margin-left: 0.25rem\n\n &:after\n content: \":\"\n\n .brackets\n &:before\n content: \"[\"\n &:after\n content: \"]\"\n\n dd\n margin: 0\n padding: 0 1rem\n\n// docutils >= 0.18\naside.footnote\n font-size: var(--font-size--small)\n color: var(--color-foreground-secondary)\n\naside.footnote > span,\ndiv.citation > span\n float: left\n font-weight: 500\n padding-right: 0.25rem\n\naside.footnote > *:not(span),\ndiv.citation > p\n margin-left: 2rem\n","//\n// Figures\n//\nimg\n box-sizing: border-box\n max-width: 100%\n height: auto\n\narticle\n figure, .figure\n border-radius: 0.2rem\n\n margin: 0\n :last-child\n margin-bottom: 0\n\n .align-left\n float: left\n clear: left\n margin: 0 1rem 1rem\n\n .align-right\n float: right\n clear: right\n margin: 0 1rem 1rem\n\n .align-default,\n .align-center\n display: block\n text-align: center\n margin-left: auto\n margin-right: auto\n\n // WELL, table needs to be stylised like a table.\n table.align-default\n display: table\n text-align: initial\n",".genindex-jumpbox, .domainindex-jumpbox\n border-top: 1px solid var(--color-background-border)\n border-bottom: 1px solid var(--color-background-border)\n padding: 0.25rem\n\n.genindex-section, .domainindex-section\n h2\n margin-top: 0.75rem\n margin-bottom: 0.5rem\n ul\n margin-top: 0\n margin-bottom: 0\n","ul,\nol\n padding-left: 1.2rem\n\n // Space lists out like paragraphs\n margin-top: 1rem\n margin-bottom: 1rem\n // reduce margins within li.\n li\n > p:first-child\n margin-top: 0.25rem\n margin-bottom: 0.25rem\n\n > p:last-child\n margin-top: 0.25rem\n\n > ul,\n > ol\n margin-top: 0.5rem\n margin-bottom: 0.5rem\n\nol\n &.arabic\n list-style: decimal\n &.loweralpha\n list-style: lower-alpha\n &.upperalpha\n list-style: upper-alpha\n &.lowerroman\n list-style: lower-roman\n &.upperroman\n list-style: upper-roman\n\n// Don't space lists out when they're \"simple\" or in a `.. toctree::`\n.simple,\n.toctree-wrapper\n li\n > ul,\n > ol\n margin-top: 0\n margin-bottom: 0\n\n// Definition Lists\n.field-list,\n.option-list,\ndl:not([class]),\ndl.simple,\ndl.footnote,\ndl.glossary\n dt\n font-weight: 500\n margin-top: 0.25rem\n + dt\n margin-top: 0\n\n .classifier::before\n content: \":\"\n margin-left: 0.2rem\n margin-right: 0.2rem\n\n dd\n > p:first-child,\n ul\n margin-top: 0.125rem\n\n ul\n margin-bottom: 0.125rem\n",".math-wrapper\n width: 100%\n overflow-x: auto\n\ndiv.math\n position: relative\n text-align: center\n\n .headerlink,\n &:focus .headerlink\n display: none\n\n &:hover .headerlink\n display: inline-block\n\n span.eqno\n position: absolute\n right: 0.5rem\n top: 50%\n transform: translate(0, -50%)\n z-index: 1\n","// Abbreviations\nabbr[title]\n cursor: help\n\n// \"Problematic\" content, as identified by Sphinx\n.problematic\n color: var(--color-problematic)\n\n// Keyboard / Mouse \"instructions\"\nkbd:not(.compound)\n margin: 0 0.2rem\n padding: 0 0.2rem\n border-radius: 0.2rem\n border: 1px solid var(--color-foreground-border)\n color: var(--color-foreground-primary)\n vertical-align: text-bottom\n\n font-size: var(--font-size--small--3)\n display: inline-block\n\n box-shadow: 0 0.0625rem 0 rgba(0, 0, 0, 0.2), inset 0 0 0 0.125rem var(--color-background-primary)\n\n background-color: var(--color-background-secondary)\n\n// Blockquote\nblockquote\n border-left: 4px solid var(--color-background-border)\n background: var(--color-background-secondary)\n\n margin-left: 0\n margin-right: 0\n padding: 0.5rem 1rem\n\n .attribution\n font-weight: 600\n text-align: right\n\n &.pull-quote,\n &.highlights\n font-size: 1.25em\n\n &.epigraph,\n &.pull-quote\n border-left-width: 0\n border-radius: 0.5rem\n\n &.highlights\n border-left-width: 0\n background: transparent\n\n// Center align embedded-in-text images\np .reference img\n vertical-align: middle\n","p.rubric\n line-height: 1.25\n font-weight: bold\n font-size: 1.125em\n\n // For Numpy-style documentation that's got rubrics within it.\n // https://github.com/pradyunsg/furo/discussions/505\n dd &\n line-height: inherit\n font-weight: inherit\n\n font-size: var(--font-size--small)\n text-transform: uppercase\n","article .sidebar\n float: right\n clear: right\n width: 30%\n\n margin-left: 1rem\n margin-right: 0\n\n border-radius: 0.2rem\n background-color: var(--color-background-secondary)\n border: var(--color-background-border) 1px solid\n\n > *\n padding-left: 1rem\n padding-right: 1rem\n\n > ul, > ol // lists need additional padding, because bullets.\n padding-left: 2.2rem\n\n .sidebar-title\n margin: 0\n padding: 0.5rem 1rem\n border-bottom: var(--color-background-border) 1px solid\n\n font-weight: 500\n\n// TODO: subtitle\n// TODO: dedicated variables?\n","[role=main] .table-wrapper.container\n width: 100%\n overflow-x: auto\n margin-top: 1rem\n margin-bottom: 0.5rem\n padding: 0.2rem 0.2rem 0.75rem\n\ntable.docutils\n border-radius: 0.2rem\n border-spacing: 0\n border-collapse: collapse\n\n box-shadow: 0 0.2rem 0.5rem rgba(0, 0, 0, 0.05), 0 0 0.0625rem rgba(0, 0, 0, 0.1)\n\n th\n background: var(--color-table-header-background)\n\n td,\n th\n // Space things out properly\n padding: 0 0.25rem\n\n // Get the borders looking just-right.\n border-left: 1px solid var(--color-table-border)\n border-right: 1px solid var(--color-table-border)\n border-bottom: 1px solid var(--color-table-border)\n\n p\n margin: 0.25rem\n\n &:first-child\n border-left: none\n &:last-child\n border-right: none\n\n // MyST-parser tables set these classes for control of column alignment\n &.text-left\n text-align: left\n &.text-right\n text-align: right\n &.text-center\n text-align: center\n",":target\n scroll-margin-top: 2.5rem\n\n@media (max-width: $full-width - $sidebar-width)\n :target\n scroll-margin-top: calc(2.5rem + var(--header-height))\n\n // When a heading is selected\n section > span:target\n scroll-margin-top: calc(2.8rem + var(--header-height))\n\n// Permalinks\n.headerlink\n font-weight: 100\n user-select: none\n\nh1,\nh2,\nh3,\nh4,\nh5,\nh6,\ndl dt,\np.caption,\nfigcaption p,\ntable > caption,\n.code-block-caption\n > .headerlink\n margin-left: 0.5rem\n visibility: hidden\n &:hover > .headerlink\n visibility: visible\n\n // Don't change to link-like, if someone adds the contents directive.\n > .toc-backref\n color: inherit\n text-decoration-line: none\n\n// Figure and table captions are special.\nfigure:hover > figcaption > p > .headerlink,\ntable:hover > caption > .headerlink\n visibility: visible\n\n:target >, // Regular section[id] style anchors\nspan:target ~ // Non-regular span[id] style \"extra\" anchors\n h1,\n h2,\n h3,\n h4,\n h5,\n h6\n &:nth-of-type(1)\n background-color: var(--color-highlight-on-target)\n // .headerlink\n // visibility: visible\n code.literal\n background-color: transparent\n\ntable:target > caption,\nfigure:target\n background-color: var(--color-highlight-on-target)\n\n// Inline page contents\n.this-will-duplicate-information-and-it-is-still-useful-here li :target\n background-color: var(--color-highlight-on-target)\n\n// Code block permalinks\n.literal-block-wrapper:target .code-block-caption\n background-color: var(--color-highlight-on-target)\n\n// When a definition list item is selected\n//\n// There isn't really an alternative to !important here, due to the\n// high-specificity of API documentation's selector.\ndt:target\n background-color: var(--color-highlight-on-target) !important\n\n// When a footnote reference is selected\n.footnote > dt:target + dd,\n.footnote-reference:target\n background-color: var(--color-highlight-on-target)\n",".guilabel\n background-color: var(--color-guilabel-background)\n border: 1px solid var(--color-guilabel-border)\n color: var(--color-guilabel-text)\n\n padding: 0 0.3em\n border-radius: 0.5em\n font-size: 0.9em\n","// This file contains the styles used for stylizing the footer that's shown\n// below the content.\n\nfooter\n font-size: var(--font-size--small)\n display: flex\n flex-direction: column\n\n margin-top: 2rem\n\n// Bottom of page information\n.bottom-of-page\n display: flex\n align-items: center\n justify-content: space-between\n\n margin-top: 1rem\n padding-top: 1rem\n padding-bottom: 1rem\n\n color: var(--color-foreground-secondary)\n border-top: 1px solid var(--color-background-border)\n\n line-height: 1.5\n\n @media (max-width: $content-width)\n text-align: center\n flex-direction: column-reverse\n gap: 0.25rem\n\n .left-details\n font-size: var(--font-size--small)\n\n .right-details\n display: flex\n flex-direction: column\n gap: 0.25rem\n text-align: right\n\n .icons\n display: flex\n justify-content: flex-end\n gap: 0.25rem\n font-size: 1rem\n\n a\n text-decoration: none\n\n svg,\n img\n font-size: 1.125rem\n height: 1em\n width: 1em\n\n// Next/Prev page information\n.related-pages\n a\n display: flex\n align-items: center\n\n text-decoration: none\n &:hover .page-info .title\n text-decoration: underline\n color: var(--color-link)\n text-decoration-color: var(--color-link-underline)\n\n svg.furo-related-icon,\n svg.furo-related-icon > use\n flex-shrink: 0\n\n color: var(--color-foreground-border)\n\n width: 0.75rem\n height: 0.75rem\n margin: 0 0.5rem\n\n &.next-page\n max-width: 50%\n\n float: right\n clear: right\n text-align: right\n\n &.prev-page\n max-width: 50%\n\n float: left\n clear: left\n\n svg\n transform: rotate(180deg)\n\n.page-info\n display: flex\n flex-direction: column\n overflow-wrap: anywhere\n\n .next-page &\n align-items: flex-end\n\n .context\n display: flex\n align-items: center\n\n padding-bottom: 0.1rem\n\n color: var(--color-foreground-muted)\n font-size: var(--font-size--small)\n text-decoration: none\n","// This file contains the styles for the contents of the left sidebar, which\n// contains the navigation tree, logo, search etc.\n\n////////////////////////////////////////////////////////////////////////////////\n// Brand on top of the scrollable tree.\n////////////////////////////////////////////////////////////////////////////////\n.sidebar-brand\n display: flex\n flex-direction: column\n flex-shrink: 0\n\n padding: var(--sidebar-item-spacing-vertical) var(--sidebar-item-spacing-horizontal)\n text-decoration: none\n\n.sidebar-brand-text\n color: var(--color-sidebar-brand-text)\n overflow-wrap: break-word\n margin: var(--sidebar-item-spacing-vertical) 0\n font-size: 1.5rem\n\n.sidebar-logo-container\n margin: var(--sidebar-item-spacing-vertical) 0\n\n.sidebar-logo\n margin: 0 auto\n display: block\n max-width: 100%\n\n////////////////////////////////////////////////////////////////////////////////\n// Search\n////////////////////////////////////////////////////////////////////////////////\n.sidebar-search-container\n display: flex\n align-items: center\n margin-top: var(--sidebar-search-space-above)\n\n position: relative\n\n background: var(--color-sidebar-search-background)\n &:hover,\n &:focus-within\n background: var(--color-sidebar-search-background--focus)\n\n &::before\n content: \"\"\n position: absolute\n left: var(--sidebar-item-spacing-horizontal)\n width: var(--sidebar-search-icon-size)\n height: var(--sidebar-search-icon-size)\n\n background-color: var(--color-sidebar-search-icon)\n mask-image: var(--icon-search)\n\n.sidebar-search\n box-sizing: border-box\n\n border: none\n border-top: 1px solid var(--color-sidebar-search-border)\n border-bottom: 1px solid var(--color-sidebar-search-border)\n\n padding-top: var(--sidebar-search-input-spacing-vertical)\n padding-bottom: var(--sidebar-search-input-spacing-vertical)\n padding-right: var(--sidebar-search-input-spacing-horizontal)\n padding-left: calc(var(--sidebar-item-spacing-horizontal) + var(--sidebar-search-input-spacing-horizontal) + var(--sidebar-search-icon-size))\n\n width: 100%\n\n color: var(--color-sidebar-search-foreground)\n background: transparent\n z-index: 10\n\n &:focus\n outline: none\n\n &::placeholder\n font-size: var(--sidebar-search-input-font-size)\n\n//\n// Hide Search Matches link\n//\n#searchbox .highlight-link\n padding: var(--sidebar-item-spacing-vertical) var(--sidebar-item-spacing-horizontal) 0\n margin: 0\n text-align: center\n\n a\n color: var(--color-sidebar-search-icon)\n font-size: var(--font-size--small--2)\n\n////////////////////////////////////////////////////////////////////////////////\n// Structure/Skeleton of the navigation tree (left)\n////////////////////////////////////////////////////////////////////////////////\n.sidebar-tree\n font-size: var(--sidebar-item-font-size)\n margin-top: var(--sidebar-tree-space-above)\n margin-bottom: var(--sidebar-item-spacing-vertical)\n\n ul\n padding: 0\n margin-top: 0\n margin-bottom: 0\n\n display: flex\n flex-direction: column\n\n list-style: none\n\n li\n position: relative\n margin: 0\n\n > ul\n margin-left: var(--sidebar-item-spacing-horizontal)\n\n .icon\n color: var(--color-sidebar-link-text)\n\n .reference\n box-sizing: border-box\n color: var(--color-sidebar-link-text)\n\n // Fill the parent.\n display: inline-block\n line-height: var(--sidebar-item-line-height)\n text-decoration: none\n\n // Don't allow long words to cause wrapping.\n overflow-wrap: anywhere\n\n height: 100%\n width: 100%\n\n padding: var(--sidebar-item-spacing-vertical) var(--sidebar-item-spacing-horizontal)\n\n &:hover\n color: var(--color-sidebar-link-text)\n background: var(--color-sidebar-item-background--hover)\n\n // Add a nice little \"external-link\" arrow here.\n &.external::after\n content: url('data:image/svg+xml,')\n margin: 0 0.25rem\n vertical-align: middle\n color: var(--color-sidebar-link-text)\n\n // Make the current page reference bold.\n .current-page > .reference\n font-weight: bold\n\n label\n position: absolute\n top: 0\n right: 0\n height: var(--sidebar-item-height)\n width: var(--sidebar-expander-width)\n\n cursor: pointer\n user-select: none\n\n display: flex\n justify-content: center\n align-items: center\n\n .caption, :not(.caption) > .caption-text\n font-size: var(--sidebar-caption-font-size)\n color: var(--color-sidebar-caption-text)\n\n font-weight: bold\n text-transform: uppercase\n\n margin: var(--sidebar-caption-space-above) 0 0 0\n padding: var(--sidebar-item-spacing-vertical) var(--sidebar-item-spacing-horizontal)\n\n // If it has children, add a bit more padding to wrap the content to avoid\n // overlapping with the