Cleanup
@ -1,4 +0,0 @@
|
|||||||
# Sphinx build info version 1
|
|
||||||
# This file hashes the configuration used when building these files. When it is not found, a full rebuild will be done.
|
|
||||||
config: 4dd2b36a085fb43c0c972dbea1600037
|
|
||||||
tags: 645f666f9bcd5a90fca523b33c5a78b7
|
|
||||||
@ -1,287 +0,0 @@
|
|||||||
|
|
||||||
ErrorDocument 404 /manual/en/4.5/404.html
|
|
||||||
|
|
||||||
RedirectMatch "^/manual/en/4.5/addons/import_export/io_(.*)" "/manual/en/4.5/addons/import_export/$1"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/curve/curve_parameter.html" "/manual/en/4.5/modeling/geometry_nodes/curve/spline_parameter.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/utilities/compare_floats.html" "/manual/en/4.5/modeling/geometry_nodes/utilities/compare.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/about/contribute/" "/manual/en/4.5/contribute/$1"
|
|
||||||
RedirectMatch "^/manual/en/4.5/about/index.html" "/manual/en/4.5/contribute/index.html"
|
|
||||||
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/input/boolean.html" "/manual/en/4.5/modeling/geometry_nodes/input/constant/boolean.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/input/color.html" "/manual/en/4.5/modeling/geometry_nodes/input/constant/color.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/input/image_input.html" "/manual/en/4.5/modeling/geometry_nodes/input/constant/image.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/input/integer.html" "/manual/en/4.5/modeling/geometry_nodes/input/constant/integer.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/input/material.html" "/manual/en/4.5/modeling/geometry_nodes/input/constant/material.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/input/string.html" "/manual/en/4.5/modeling/geometry_nodes/input/constant/string.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/input/value.html" "/manual/en/4.5/modeling/geometry_nodes/input/constant/value.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/input/vector.html" "/manual/en/4.5/modeling/geometry_nodes/input/constant/vector.html"
|
|
||||||
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/input/collection_info.html" "/manual/en/4.5/modeling/geometry_nodes/input/scene/collection_info.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/input/image_info.html" "/manual/en/4.5/modeling/geometry_nodes/input/scene/image_info.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/input/is_viewport.html" "/manual/en/4.5/modeling/geometry_nodes/input/scene/is_viewport.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/input/object_info.html" "/manual/en/4.5/modeling/geometry_nodes/input/scene/object_info.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/input/self_object.html" "/manual/en/4.5/modeling/geometry_nodes/input/scene/self_object.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/input/scene_time.html" "/manual/en/4.5/modeling/geometry_nodes/input/scene/scene_time.html"
|
|
||||||
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/input/id.html" "/manual/en/4.5/modeling/geometry_nodes/geometry/read/id.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/input/input_index.html" "/manual/en/4.5/modeling/geometry_nodes/geometry/read/input_index.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/input/named_attribute.html" "/manual/en/4.5/modeling/geometry_nodes/geometry/read/named_attribute.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/input/normal.html" "/manual/en/4.5/modeling/geometry_nodes/geometry/read/normal.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/input/position.html" "/manual/en/4.5/modeling/geometry_nodes/geometry/read/position.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/input/radius.html" "/manual/en/4.5/modeling/geometry_nodes/geometry/read/radius.html"
|
|
||||||
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/geometry/set_id.html" "/manual/en/4.5/modeling/geometry_nodes/geometry/write/set_id.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/geometry/set_position.html" "/manual/en/4.5/modeling/geometry_nodes/geometry/write/set_position.html"
|
|
||||||
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/geometry/bounding_box.html" "/manual/en/4.5/modeling/geometry_nodes/geometry/operations/bounding_box.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/geometry/convex_hull.html" "/manual/en/4.5/modeling/geometry_nodes/geometry/operations/convex_hull.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/geometry/delete_geometry.html" "/manual/en/4.5/modeling/geometry_nodes/geometry/operations/delete_geometry.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/geometry/duplicate_elements.html" "/manual/en/4.5/modeling/geometry_nodes/geometry/operations/duplicate_elements.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/geometry/merge_by_distance.html" "/manual/en/4.5/modeling/geometry_nodes/geometry/operations/merge_by_distance.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/geometry/transform_geometry.html" "/manual/en/4.5/modeling/geometry_nodes/geometry/operations/transform_geometry.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/geometry/separate_components.html" "/manual/en/4.5/modeling/geometry_nodes/geometry/operations/separate_components.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/geometry/separate_geometry.html" "/manual/en/4.5/modeling/geometry_nodes/geometry/operations/separate_geometry.html"
|
|
||||||
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/geometry/geometry_proximity.html" "/manual/en/4.5/modeling/geometry_nodes/geometry/sample/geometry_proximity.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/geometry/raycast.html" "/manual/en/4.5/modeling/geometry_nodes/geometry/sample/raycast.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/geometry/sample_index.html" "/manual/en/4.5/modeling/geometry_nodes/geometry/sample/sample_index.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/geometry/sample_nearest.html" "/manual/en/4.5/modeling/geometry_nodes/geometry/sample/sample_nearest.html"
|
|
||||||
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/curve/curve_handle_position.html" "/manual/en/4.5/modeling/geometry_nodes/curve/read/curve_handle_position.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/curve/curve_length.html" "/manual/en/4.5/modeling/geometry_nodes/curve/read/curve_length.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/curve/curve_tangent.html" "/manual/en/4.5/modeling/geometry_nodes/curve/read/curve_tangent.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/curve/curve_tilt.html" "/manual/en/4.5/modeling/geometry_nodes/curve/read/curve_tilt.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/curve/endpoint_selection.html" "/manual/en/4.5/modeling/geometry_nodes/curve/read/endpoint_selection.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/curve/handle_type_selection.html" "/manual/en/4.5/modeling/geometry_nodes/curve/read/handle_type_selection.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/curve/is_spline_cyclic.html" "/manual/en/4.5/modeling/geometry_nodes/curve/read/is_spline_cyclic.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/curve/spline_length.html" "/manual/en/4.5/modeling/geometry_nodes/curve/read/spline_length.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/curve/spline_parameter.html" "/manual/en/4.5/modeling/geometry_nodes/curve/read/spline_parameter.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/curve/spline_resolution.html" "/manual/en/4.5/modeling/geometry_nodes/curve/read/spline_resolution.html"
|
|
||||||
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/curve/sample_curve.html" "/manual/en/4.5/modeling/geometry_nodes/curve/sample/sample_curve.html"
|
|
||||||
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/curve/set_curve_normal.html" "/manual/en/4.5/modeling/geometry_nodes/curve/write/set_curve_normal.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/curve/set_curve_radius.html" "/manual/en/4.5/modeling/geometry_nodes/curve/write/set_curve_radius.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/curve/set_curve_tilt.html" "/manual/en/4.5/modeling/geometry_nodes/curve/write/set_curve_tilt.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/curve/set_handle_positions.html" "/manual/en/4.5/modeling/geometry_nodes/curve/write/set_handle_positions.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/curve/set_handle_type.html" "/manual/en/4.5/modeling/geometry_nodes/curve/write/set_handle_type.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/curve/set_spline_cyclic.html" "/manual/en/4.5/modeling/geometry_nodes/curve/write/set_spline_cyclic.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/curve/set_spline_resolution.html" "/manual/en/4.5/modeling/geometry_nodes/curve/write/set_spline_resolution.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/curve/set_spline_type.html" "/manual/en/4.5/modeling/geometry_nodes/curve/write/set_spline_type.html"
|
|
||||||
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/curve/curve_to_mesh.html" "/manual/en/4.5/modeling/geometry_nodes/curve/operations/curve_to_mesh.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/curve/curve_to_points.html" "/manual/en/4.5/modeling/geometry_nodes/curve/operations/curve_to_points.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/curve/deform_curves_on_surface.html" "/manual/en/4.5/modeling/geometry_nodes/curve/operations/deform_curves_on_surface.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/curve/fill_curve.html" "/manual/en/4.5/modeling/geometry_nodes/curve/operations/fill_curve.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/curve/fillet_curve.html" "/manual/en/4.5/modeling/geometry_nodes/curve/operations/fillet_curve.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/curve/resample_curve.html" "/manual/en/4.5/modeling/geometry_nodes/curve/operations/resample_curve.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/curve/reverse_curve.html" "/manual/en/4.5/modeling/geometry_nodes/curve/operations/reverse_curve.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/curve/subdivide_curve.html" "/manual/en/4.5/modeling/geometry_nodes/curve/operations/subdivide_curve.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/curve/trim_curve.html" "/manual/en/4.5/modeling/geometry_nodes/curve/operations/trim_curve.html"
|
|
||||||
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/curve_primitives/" "/manual/en/4.5/modeling/geometry_nodes/curve/primitives/$1"
|
|
||||||
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/curve_topology/" "/manual/en/4.5/modeling/geometry_nodes/curve/topology/$1"
|
|
||||||
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/mesh/edge_angle.html" "/manual/en/4.5/modeling/geometry_nodes/mesh/read/edge_angle.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/mesh/edge_neighbors.html" "/manual/en/4.5/modeling/geometry_nodes/mesh/read/edge_neighbors.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/mesh/edge_vertices.html" "/manual/en/4.5/modeling/geometry_nodes/mesh/read/edge_vertices.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/mesh/face_area.html" "/manual/en/4.5/modeling/geometry_nodes/mesh/read/face_area.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/mesh/face_neighbors.html" "/manual/en/4.5/modeling/geometry_nodes/mesh/read/face_neighbors.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/mesh/face_set_boundaries.html" "/manual/en/4.5/modeling/geometry_nodes/mesh/read/face_group_boundaries.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/mesh/face_is_planar.html" "/manual/en/4.5/modeling/geometry_nodes/mesh/read/face_is_planar.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/mesh/is_shade_smooth.html" "/manual/en/4.5/modeling/geometry_nodes/mesh/read/is_shade_smooth.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/mesh/mesh_island.html" "/manual/en/4.5/modeling/geometry_nodes/mesh/read/mesh_island.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/mesh/shortest_edge_paths.html" "/manual/en/4.5/modeling/geometry_nodes/mesh/read/shortest_edge_paths.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/mesh/vertex_neighbors.html" "/manual/en/4.5/modeling/geometry_nodes/mesh/read/vertex_neighbors.html"
|
|
||||||
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/mesh/sample_nearest_surface.html" "/manual/en/4.5/modeling/geometry_nodes/mesh/sample/sample_nearest_surface.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/mesh/sample_uv_surface.html" "/manual/en/4.5/modeling/geometry_nodes/mesh/sample/sample_uv_surface.html"
|
|
||||||
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/mesh/set_shade_smooth.html" "/manual/en/4.5/modeling/geometry_nodes/mesh/write/set_shade_smooth.html"
|
|
||||||
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/mesh/dual_mesh.html" "/manual/en/4.5/modeling/geometry_nodes/mesh/operations/dual_mesh.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/mesh/edge_paths_to_curves.html" "/manual/en/4.5/modeling/geometry_nodes/mesh/operations/edge_paths_to_curves.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/mesh/edge_paths_to_selection.html" "/manual/en/4.5/modeling/geometry_nodes/mesh/operations/edge_paths_to_selection.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/mesh/extrude_mesh.html" "/manual/en/4.5/modeling/geometry_nodes/mesh/operations/extrude_mesh.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/mesh/flip_faces.html" "/manual/en/4.5/modeling/geometry_nodes/mesh/operations/flip_faces.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/mesh/mesh_boolean.html" "/manual/en/4.5/modeling/geometry_nodes/mesh/operations/mesh_boolean.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/mesh/mesh_to_curve.html" "/manual/en/4.5/modeling/geometry_nodes/mesh/operations/mesh_to_curve.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/mesh/mesh_to_points.html" "/manual/en/4.5/modeling/geometry_nodes/mesh/operations/mesh_to_points.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/mesh/mesh_to_volume.html" "/manual/en/4.5/modeling/geometry_nodes/mesh/operations/mesh_to_volume.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/mesh/scale_elements.html" "/manual/en/4.5/modeling/geometry_nodes/mesh/operations/scale_elements.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/mesh/split_edges.html" "/manual/en/4.5/modeling/geometry_nodes/mesh/operations/split_edges.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/mesh/subdivide_mesh.html" "/manual/en/4.5/modeling/geometry_nodes/mesh/operations/subdivide_mesh.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/mesh/subdivision_surface.html" "/manual/en/4.5/modeling/geometry_nodes/operations/mesh/subdivision_surface.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/mesh/triangulate.html" "/manual/en/4.5/modeling/geometry_nodes/mesh/operations/triangulate.html"
|
|
||||||
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/mesh_primitives/" "/manual/en/4.5/modeling/geometry_nodes/mesh/primitives/$1"
|
|
||||||
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/mesh_topology/" "/manual/en/4.5/modeling/geometry_nodes/mesh/topology/$1"
|
|
||||||
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/uv/" "/manual/en/4.5/modeling/geometry_nodes/mesh/uv/$1"
|
|
||||||
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/color/" "/manual/en/4.5/modeling/geometry_nodes/utilities/color/$1"
|
|
||||||
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/text/" "/manual/en/4.5/modeling/geometry_nodes/utilities/text/$1"
|
|
||||||
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/vector/" "/manual/en/4.5/modeling/geometry_nodes/utilities/vector/$1"
|
|
||||||
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/utilities/accumulate_field.html" "/manual/en/4.5/modeling/geometry_nodes/utilities/field/accumulate_field.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/utilities/field_at_index.html" "/manual/en/4.5/modeling/geometry_nodes/utilities/field/evaluate_at_index.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/utilities/interpolate_domain.html" "/manual/en/4.5/modeling/geometry_nodes/utilities/field/evaluate_on_domain.html"
|
|
||||||
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/utilities/boolean_math.html" "/manual/en/4.5/modeling/geometry_nodes/utilities/math/boolean_math.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/utilities/clamp.html" "/manual/en/4.5/modeling/geometry_nodes/utilities/math/clamp.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/utilities/compare.html" "/manual/en/4.5/modeling/geometry_nodes/utilities/math/compare.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/utilities/float_curve.html" "/manual/en/4.5/modeling/geometry_nodes/utilities/math/float_curve.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/utilities/float_to_integer.html" "/manual/en/4.5/modeling/geometry_nodes/utilities/math/float_to_integer.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/utilities/map_range.html" "/manual/en/4.5/modeling/geometry_nodes/utilities/math/map_range.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/utilities/math.html" "/manual/en/4.5/modeling/geometry_nodes/utilities/math/math.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/utilities/mix.html" "/manual/en/4.5/modeling/geometry_nodes/utilities/math/mix.html"
|
|
||||||
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/utilities/align_euler_to_vector.html" "/manual/en/4.5/modeling/geometry_nodes/utilities/rotation/align_euler_to_vector.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/utilities/rotate_euler.html" "/manual/en/4.5/modeling/geometry_nodes/utilities/rotation/rotate_euler.html"
|
|
||||||
|
|
||||||
RedirectMatch "^/manual/en/4.5/editors/graph_editor/channels.html" "/manual/en/4.5/editors/graph_editor/channels/index.html"
|
|
||||||
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/color/invert.html" "/manual/en/4.5/compositing/types/color/invert_color.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/editors/texture_node/types/color/invert.html" "/manual/en/4.5/editors/texture_node/types/color/invert_color.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/render/shader_nodes/color/invert.html" "/manual/en/4.5/render/shader_nodes/color/invert_color.html"
|
|
||||||
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/color/bright_contrast.html" "/manual/en/4.5/compositing/types/color/adjust/bright_contrast.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/color/color_balance.html" "/manual/en/4.5/compositing/types/color/adjust/color_balance.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/color/color_correction.html" "/manual/en/4.5/compositing/types/color/adjust/color_correction.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/color/exposure.html" "/manual/en/4.5/compositing/types/color/adjust/exposure.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/color/gamma.html" "/manual/en/4.5/compositing/types/color/adjust/gamma.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/color/hue_correct.html" "/manual/en/4.5/compositing/types/color/adjust/hue_correct.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/color/hue_saturation.html" "/manual/en/4.5/compositing/types/color/adjust/hue_saturation.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/color/rgb_curves.html" "/manual/en/4.5/compositing/types/color/adjust/rgb_curves.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/color/tone_map.html" "/manual/en/4.5/compositing/types/color/adjust/tone_map.html"
|
|
||||||
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/color/alpha_over.html" "/manual/en/4.5/compositing/types/color/mix/alpha_over.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/converter/combine_color.html" "/manual/en/4.5/compositing/types/color/mix/compine_color.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/converter/seperate_color.html" "/manual/en/4.5/compositing/types/color/mix/seperate_color.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/color/mix.html" "/manual/en/4.5/compositing/types/color/mix/mix_color.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/color/z_combine.html" "/manual/en/4.5/compositing/types/color/mix/z_combine.html"
|
|
||||||
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/converter/alpha_convert.html" "/manual/en/4.5/compositing/types/color/alpha_convert.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/converter/color_ramp.html" "/manual/en/4.5/compositing/types/color/color_ramp.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/converter/color_space.html" "/manual/en/4.5/compositing/types/color/convert_colorspace.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/converter/rgb_to_bw.html" "/manual/en/4.5/compositing/types/color/rgb_to_bw.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/converter/set_alpha.html" "/manual/en/4.5/compositing/types/color/set_alpha.html"
|
|
||||||
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/filter/bilateral_blur.html" "/manual/en/4.5/compositing/types/filter/blur/bilateral_blur.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/filter/blur_node.html" "/manual/en/4.5/compositing/types/filter/blur/blur.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/filter/bokeh_blur.html" "/manual/en/4.5/compositing/types/filter/blur/bokeh_blur.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/filter/defocus.html" "/manual/en/4.5/compositing/types/filter/blur/defocus.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/filter/directional_blur.html" "/manual/en/4.5/compositing/types/filter/blur/directional_blur.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/filter/vector_blur.html" "/manual/en/4.5/compositing/types/filter/blur/vector_blur.html"
|
|
||||||
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/color/posterize.html" "/manual/en/4.5/compositing/types/filter/posterize.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/filter/filter_node.html" "/manual/en/4.5/compositing/types/filter/filter.html"
|
|
||||||
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/input/rgb.html" "/manual/en/4.5/compositing/types/input/constant/rgb.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/input/value.html" "/manual/en/4.5/compositing/types/input/constant/value.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/input/render_layers.html" "/manual/en/4.5/compositing/types/input/scene/render_layers.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/input/scene_time.html" "/manual/en/4.5/compositing/types/input/scene/scene_time.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/input/time_curve.html" "/manual/en/4.5/compositing/types/input/scene/time_curve.html"
|
|
||||||
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/matte/channel_key.html" "/manual/en/4.5/compositing/types/keying/channel_key.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/matte/chroma_key.html" "/manual/en/4.5/compositing/types/keying/chroma_key.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/matte/color_key.html" "/manual/en/4.5/compositing/types/keying/color_key.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/matte/color_spill.html" "/manual/en/4.5/compositing/types/keying/color_spill.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/matte/difference_key.html" "/manual/en/4.5/compositing/types/keying/difference_key.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/matte/distance_key.html" "/manual/en/4.5/compositing/types/keying/distance_key.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/matte/keying_screen.html" "/manual/en/4.5/compositing/types/keying/keying_screen.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/matte/keying.html" "/manual/en/4.5/compositing/types/keying/keying.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/matte/luminance_key.html" "/manual/en/4.5/compositing/types/keying/luminance_key.html"
|
|
||||||
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/matte/box_mask.html" "/manual/en/4.5/compositing/types/mask/box_mask.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/matte/cryptomatte_legacy.html" "/manual/en/4.5/compositing/types/mask/cryptomatte_legacy.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/matte/cryptomatte.html" "/manual/en/4.5/compositing/types/mask/cryptomatte.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/matte/double_edge_mask.html" "/manual/en/4.5/compositing/types/mask/double_edge_mask.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/matte/ellipse_mask.html" "/manual/en/4.5/compositing/types/mask/ellipse_mask.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/converter/id_mask.html" "/manual/en/4.5/compositing/types/mask/id_mask.html"
|
|
||||||
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/output/file.html" "/manual/en/4.5/compositing/types/output/file_output.html"
|
|
||||||
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/destort/plane_track_deform.html" "/manual/en/4.5/compositing/types/tracking/plane_track_deform.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/destort/stabilize_2d.html" "/manual/en/4.5/compositing/types/tracking/stabilize_2d.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/input/track_position.html" "/manual/en/4.5/compositing/types/tracking/track_position.html"
|
|
||||||
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/destort/corner_pin.html" "/manual/en/4.5/compositing/types/transform/corner_pin.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/destort/crop.html" "/manual/en/4.5/compositing/types/transform/crop.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/destort/displace.html" "/manual/en/4.5/compositing/types/transform/displace.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/destort/flip.html" "/manual/en/4.5/compositing/types/transform/flip.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/destort/lens_distortion.html" "/manual/en/4.5/compositing/types/transform/lens_distortion.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/destort/map_uv.html" "/manual/en/4.5/compositing/types/transform/map_uv.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/destort/movie_distortion.html" "/manual/en/4.5/compositing/types/transform/movie_distortion.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/destort/rotate.html" "/manual/en/4.5/compositing/types/transform/rotate.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/destort/scale.html" "/manual/en/4.5/compositing/types/transform/scale.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/destort/transform.html" "/manual/en/4.5/compositing/types/transform/transform.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/destort/translate.html" "/manual/en/4.5/compositing/types/transform/translate.html"
|
|
||||||
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/output/levels.html" "/manual/en/4.5/compositing/types/utilities/levels.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/vector/map_range.html" "/manual/en/4.5/compositing/types/utilities/map_range.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/vector/map_value.html" "/manual/en/4.5/compositing/types/utilities/map_value.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/converter/math.html" "/manual/en/4.5/compositing/types/utilities/math.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/vector/normalize.html" "/manual/en/4.5/compositing/types/utilities/normalize.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/converter/switch_view.html" "/manual/en/4.5/compositing/types/utilities/switch_stereo_view.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/layout/switch.html" "/manual/en/4.5/compositing/types/utilities/switch.html"
|
|
||||||
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/converter/combine_xyz.html" "/manual/en/4.5/compositing/types/vector/combine_xyz.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/types/converter/seperate_xyz.html" "/manual/en/4.5/compositing/types/vector/seperate_xyz.html"
|
|
||||||
|
|
||||||
RedirectMatch "^/manual/en/4.5/compositing/realtime_compositor.html" "/manual/en/4.5/compositing/compositor_system.html"
|
|
||||||
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/mesh/read/is_shade_smooth.html" "/manual/en/4.5/modeling/geometry_nodes/mesh/read/is_face_smooth.html"
|
|
||||||
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/volume/volume_to_mesh.html" "/manual/en/4.5/modeling/geometry_nodes/mesh/operations/volume_to_mesh.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/volume/volume_cube.html" "/manual/en/4.5/modeling/geometry_nodes/mesh/primatives/volume_cube.html"
|
|
||||||
|
|
||||||
RedirectMatch "^/manual/en/4.5/editors/nla/editing.html" "/manual/en/4.5/editors/nla/editing/index.html"
|
|
||||||
|
|
||||||
RedirectMatch "^/manual/en/4.5/render/shader_nodes/shader/anisotropic.html" "/manual/en/4.5/render/shader_nodes/shader/glossy.html"
|
|
||||||
|
|
||||||
RedirectMatch "^/manual/en/4.5/files/import_export.html" "/manual/en/4.5/files/import_export/index.html"
|
|
||||||
|
|
||||||
RedirectMatch "^/manual/en/4.5/render/eevee/light_probes/introduction.html" "/manual/en/4.5/render/eevee/light_probes/index.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/movie_clip/introduction.html" "/manual/en/4.5/movie_clip/index.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/getting_started/about/introduction.html" "/manual/en/4.5/getting_started/about/index.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/animation/armatures/bones/properties/introduction.html" "/manual/en/4.5/animation/armatures/bones/properties/index.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/advanced/command_line/introduction.html" "/manual/en/4.5/advanced/command_line/index.html"
|
|
||||||
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/utilities/rotation/align_euler_to_vector.html" "/manual/en/4.5/modeling/geometry_nodes/utilities/rotation/align_rotation_to_vector.html"
|
|
||||||
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/modifiers/modify/normal_edit.html" "/manual/en/4.5/modeling/modifiers/normals/normal_edit.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/modifiers/modify/weighted_normal.html" "/manual/en/4.5/modeling/modifiers/normals/weighted_normal.html"
|
|
||||||
|
|
||||||
RedirectMatch "^/manual/en/4.5/sculpt_paint/brush/brush.html" "/manual/en/4.5/sculpt_paint/brush/introduction.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/sculpt_paint/sculpting/tools/rotate.html" "/manual/en/4.5/sculpt_paint/sculpting/brushes/twist.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/sculpt_paint/sculpting/tools/simplify.html" "/manual/en/4.5/sculpt_paint/sculpting/brushes/density.html"
|
|
||||||
# Mesh sculpting tools converted to asset
|
|
||||||
RedirectMatch "^/manual/en/4.5/sculpt_paint/sculpting/tools/(blob|boundary|clay|clay_strips|clay_thumb|cloth|crease|draw|draw_facesets|draw_sharp|elastic_deform|fill|flatten|grab|inflate|layer|mask|multiplane_scrape|multires_displacement_eraser|multires_displacement_smear|nudge|paint|pinch|pose|scrape|slide_relax|smear|smooth|snake_hook|thumb).html" "/manual/en/4.5/sculpt_paint/sculpting/brushes/$1.html"
|
|
||||||
# Curve sculpting tools converted to asset
|
|
||||||
RedirectMatch "^/manual/en/4.5/sculpt_paint/curves_sculpting/tools/(index|add_curves|comb_curves|delete_curves|density_curves|grow_shrink_curves|pinch_curves|puff_curves|selection_paint|slide_curves|smooth_curves|snake_hook_curves).html" "/manual/en/4.5/sculpt_paint/curves_sculpting/brushes/$1.html"
|
|
||||||
# Grease pencil draw tools
|
|
||||||
RedirectMatch "^/manual/en/4.5/grease_pencil/modes/draw/tools/draw.html" "/manual/en/4.5/grease_pencil/modes/draw/tools/brush.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/grease_pencil/modes/draw/tools/tint.html" "/manual/en/4.5/grease_pencil/modes/draw/brushes/tint.rst.html"
|
|
||||||
# Texture paint tools converted to asset
|
|
||||||
RedirectMatch "^/manual/en/4.5/sculpt_paint/texture_paint/tools.html" "/manual/en/4.5/sculpt_paint/texture_paint/brushes.html"
|
|
||||||
|
|
||||||
RedirectMatch "^/manual/en/4.5/grease_pencil/modifiers/index.html" "/manual/en/4.5/grease_pencil/edit/index.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/grease_pencil/modifiers/texture_mapping.html" "/manual/en/4.5/grease_pencil/edit/texture_mapping.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/grease_pencil/modifiers/time_offset.html" "/manual/en/4.5/grease_pencil/edit/time_offset.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/grease_pencil/modifiers/weight_angle.html" "/manual/en/4.5/grease_pencil/edit/weight_angle.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/grease_pencil/modifiers/weight_proximity.html" "/manual/en/4.5/grease_pencil/edit/weight_proximity.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/grease_pencil/materials/introduction.html" "/manual/en/4.5/grease_pencil/materials/index.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/grease_pencil/selecting.html" "/manual/en/4.5/grease_pencil/modes/edit/selecting.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/grease_pencil/object.html" "/manual/en/4.5/grease_pencil/properties/object.html"
|
|
||||||
|
|
||||||
RedirectMatch "^/manual/en/4.5/grease_pencil/modes/draw/tools/cutter.html" "/manual/en/4.5/grease_pencil/modes/draw/tools/trim.html"
|
|
||||||
|
|
||||||
RedirectMatch "^/manual/en/4.5/contribute/translations/contribute/" "/manual/en/4.5/contribute/translate_manual//$1"
|
|
||||||
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/curve/operations/grease_pencil_to_curves.html" "/manual/en/4.5/modeling/geometry_nodes/grease_pencil/operations/grease_pencil_to_curves.html"
|
|
||||||
RedirectMatch "^/manual/en/4.5/modeling/geometry_nodes/curve/operations/merge_layers.html" "/manual/en/4.5/modeling/geometry_nodes/grease_pencil/operations/merge_layers.html"
|
|
||||||
@ -1,925 +0,0 @@
|
|||||||
/*
|
|
||||||
* basic.css
|
|
||||||
* ~~~~~~~~~
|
|
||||||
*
|
|
||||||
* Sphinx stylesheet -- basic theme.
|
|
||||||
*
|
|
||||||
* :copyright: Copyright 2007-2024 by the Sphinx team, see AUTHORS.
|
|
||||||
* :license: BSD, see LICENSE for details.
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* -- 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: 10px 0 0 20px;
|
|
||||||
padding: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
ul.search li {
|
|
||||||
padding: 5px 0 5px 20px;
|
|
||||||
background-image: url(file.png);
|
|
||||||
background-repeat: no-repeat;
|
|
||||||
background-position: 0 7px;
|
|
||||||
}
|
|
||||||
|
|
||||||
ul.search li a {
|
|
||||||
font-weight: bold;
|
|
||||||
}
|
|
||||||
|
|
||||||
ul.search li p.context {
|
|
||||||
color: #888;
|
|
||||||
margin: 2px 0 0 30px;
|
|
||||||
text-align: left;
|
|
||||||
}
|
|
||||||
|
|
||||||
ul.keywordmatches li.goodmatch a {
|
|
||||||
font-weight: bold;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* -- index page ------------------------------------------------------------ */
|
|
||||||
|
|
||||||
table.contentstable {
|
|
||||||
width: 90%;
|
|
||||||
margin-left: auto;
|
|
||||||
margin-right: auto;
|
|
||||||
}
|
|
||||||
|
|
||||||
table.contentstable p.biglink {
|
|
||||||
line-height: 150%;
|
|
||||||
}
|
|
||||||
|
|
||||||
a.biglink {
|
|
||||||
font-size: 1.3em;
|
|
||||||
}
|
|
||||||
|
|
||||||
span.linkdescr {
|
|
||||||
font-style: italic;
|
|
||||||
padding-top: 5px;
|
|
||||||
font-size: 90%;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* -- general index --------------------------------------------------------- */
|
|
||||||
|
|
||||||
table.indextable {
|
|
||||||
width: 100%;
|
|
||||||
}
|
|
||||||
|
|
||||||
table.indextable td {
|
|
||||||
text-align: left;
|
|
||||||
vertical-align: top;
|
|
||||||
}
|
|
||||||
|
|
||||||
table.indextable ul {
|
|
||||||
margin-top: 0;
|
|
||||||
margin-bottom: 0;
|
|
||||||
list-style-type: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
table.indextable > tbody > tr > td > ul {
|
|
||||||
padding-left: 0em;
|
|
||||||
}
|
|
||||||
|
|
||||||
table.indextable tr.pcap {
|
|
||||||
height: 10px;
|
|
||||||
}
|
|
||||||
|
|
||||||
table.indextable tr.cap {
|
|
||||||
margin-top: 10px;
|
|
||||||
background-color: #f2f2f2;
|
|
||||||
}
|
|
||||||
|
|
||||||
img.toggler {
|
|
||||||
margin-right: 3px;
|
|
||||||
margin-top: 3px;
|
|
||||||
cursor: pointer;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.modindex-jumpbox {
|
|
||||||
border-top: 1px solid #ddd;
|
|
||||||
border-bottom: 1px solid #ddd;
|
|
||||||
margin: 1em 0 1em 0;
|
|
||||||
padding: 0.4em;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.genindex-jumpbox {
|
|
||||||
border-top: 1px solid #ddd;
|
|
||||||
border-bottom: 1px solid #ddd;
|
|
||||||
margin: 1em 0 1em 0;
|
|
||||||
padding: 0.4em;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* -- domain module index --------------------------------------------------- */
|
|
||||||
|
|
||||||
table.modindextable td {
|
|
||||||
padding: 2px;
|
|
||||||
border-collapse: collapse;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* -- general body styles --------------------------------------------------- */
|
|
||||||
|
|
||||||
div.body {
|
|
||||||
min-width: 360px;
|
|
||||||
max-width: 800px;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.body p, div.body dd, div.body li, div.body blockquote {
|
|
||||||
-moz-hyphens: auto;
|
|
||||||
-ms-hyphens: auto;
|
|
||||||
-webkit-hyphens: auto;
|
|
||||||
hyphens: auto;
|
|
||||||
}
|
|
||||||
|
|
||||||
a.headerlink {
|
|
||||||
visibility: hidden;
|
|
||||||
}
|
|
||||||
|
|
||||||
a:visited {
|
|
||||||
color: #551A8B;
|
|
||||||
}
|
|
||||||
|
|
||||||
h1:hover > a.headerlink,
|
|
||||||
h2:hover > a.headerlink,
|
|
||||||
h3:hover > a.headerlink,
|
|
||||||
h4:hover > a.headerlink,
|
|
||||||
h5:hover > a.headerlink,
|
|
||||||
h6:hover > a.headerlink,
|
|
||||||
dt:hover > a.headerlink,
|
|
||||||
caption:hover > a.headerlink,
|
|
||||||
p.caption:hover > a.headerlink,
|
|
||||||
div.code-block-caption:hover > a.headerlink {
|
|
||||||
visibility: visible;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.body p.caption {
|
|
||||||
text-align: inherit;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.body td {
|
|
||||||
text-align: left;
|
|
||||||
}
|
|
||||||
|
|
||||||
.first {
|
|
||||||
margin-top: 0 !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
p.rubric {
|
|
||||||
margin-top: 30px;
|
|
||||||
font-weight: bold;
|
|
||||||
}
|
|
||||||
|
|
||||||
img.align-left, figure.align-left, .figure.align-left, object.align-left {
|
|
||||||
clear: left;
|
|
||||||
float: left;
|
|
||||||
margin-right: 1em;
|
|
||||||
}
|
|
||||||
|
|
||||||
img.align-right, figure.align-right, .figure.align-right, object.align-right {
|
|
||||||
clear: right;
|
|
||||||
float: right;
|
|
||||||
margin-left: 1em;
|
|
||||||
}
|
|
||||||
|
|
||||||
img.align-center, figure.align-center, .figure.align-center, object.align-center {
|
|
||||||
display: block;
|
|
||||||
margin-left: auto;
|
|
||||||
margin-right: auto;
|
|
||||||
}
|
|
||||||
|
|
||||||
img.align-default, figure.align-default, .figure.align-default {
|
|
||||||
display: block;
|
|
||||||
margin-left: auto;
|
|
||||||
margin-right: auto;
|
|
||||||
}
|
|
||||||
|
|
||||||
.align-left {
|
|
||||||
text-align: left;
|
|
||||||
}
|
|
||||||
|
|
||||||
.align-center {
|
|
||||||
text-align: center;
|
|
||||||
}
|
|
||||||
|
|
||||||
.align-default {
|
|
||||||
text-align: center;
|
|
||||||
}
|
|
||||||
|
|
||||||
.align-right {
|
|
||||||
text-align: right;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* -- sidebars -------------------------------------------------------------- */
|
|
||||||
|
|
||||||
div.sidebar,
|
|
||||||
aside.sidebar {
|
|
||||||
margin: 0 0 0.5em 1em;
|
|
||||||
border: 1px solid #ddb;
|
|
||||||
padding: 7px;
|
|
||||||
background-color: #ffe;
|
|
||||||
width: 40%;
|
|
||||||
float: right;
|
|
||||||
clear: right;
|
|
||||||
overflow-x: auto;
|
|
||||||
}
|
|
||||||
|
|
||||||
p.sidebar-title {
|
|
||||||
font-weight: bold;
|
|
||||||
}
|
|
||||||
|
|
||||||
nav.contents,
|
|
||||||
aside.topic,
|
|
||||||
div.admonition, div.topic, blockquote {
|
|
||||||
clear: left;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* -- topics ---------------------------------------------------------------- */
|
|
||||||
|
|
||||||
nav.contents,
|
|
||||||
aside.topic,
|
|
||||||
div.topic {
|
|
||||||
border: 1px solid #ccc;
|
|
||||||
padding: 7px;
|
|
||||||
margin: 10px 0 10px 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
p.topic-title {
|
|
||||||
font-size: 1.1em;
|
|
||||||
font-weight: bold;
|
|
||||||
margin-top: 10px;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* -- admonitions ----------------------------------------------------------- */
|
|
||||||
|
|
||||||
div.admonition {
|
|
||||||
margin-top: 10px;
|
|
||||||
margin-bottom: 10px;
|
|
||||||
padding: 7px;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.admonition dt {
|
|
||||||
font-weight: bold;
|
|
||||||
}
|
|
||||||
|
|
||||||
p.admonition-title {
|
|
||||||
margin: 0px 10px 5px 0px;
|
|
||||||
font-weight: bold;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.body p.centered {
|
|
||||||
text-align: center;
|
|
||||||
margin-top: 25px;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* -- content of sidebars/topics/admonitions -------------------------------- */
|
|
||||||
|
|
||||||
div.sidebar > :last-child,
|
|
||||||
aside.sidebar > :last-child,
|
|
||||||
nav.contents > :last-child,
|
|
||||||
aside.topic > :last-child,
|
|
||||||
div.topic > :last-child,
|
|
||||||
div.admonition > :last-child {
|
|
||||||
margin-bottom: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.sidebar::after,
|
|
||||||
aside.sidebar::after,
|
|
||||||
nav.contents::after,
|
|
||||||
aside.topic::after,
|
|
||||||
div.topic::after,
|
|
||||||
div.admonition::after,
|
|
||||||
blockquote::after {
|
|
||||||
display: block;
|
|
||||||
content: '';
|
|
||||||
clear: both;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* -- tables ---------------------------------------------------------------- */
|
|
||||||
|
|
||||||
table.docutils {
|
|
||||||
margin-top: 10px;
|
|
||||||
margin-bottom: 10px;
|
|
||||||
border: 0;
|
|
||||||
border-collapse: collapse;
|
|
||||||
}
|
|
||||||
|
|
||||||
table.align-center {
|
|
||||||
margin-left: auto;
|
|
||||||
margin-right: auto;
|
|
||||||
}
|
|
||||||
|
|
||||||
table.align-default {
|
|
||||||
margin-left: auto;
|
|
||||||
margin-right: auto;
|
|
||||||
}
|
|
||||||
|
|
||||||
table caption span.caption-number {
|
|
||||||
font-style: italic;
|
|
||||||
}
|
|
||||||
|
|
||||||
table caption span.caption-text {
|
|
||||||
}
|
|
||||||
|
|
||||||
table.docutils td, table.docutils th {
|
|
||||||
padding: 1px 8px 1px 5px;
|
|
||||||
border-top: 0;
|
|
||||||
border-left: 0;
|
|
||||||
border-right: 0;
|
|
||||||
border-bottom: 1px solid #aaa;
|
|
||||||
}
|
|
||||||
|
|
||||||
th {
|
|
||||||
text-align: left;
|
|
||||||
padding-right: 5px;
|
|
||||||
}
|
|
||||||
|
|
||||||
table.citation {
|
|
||||||
border-left: solid 1px gray;
|
|
||||||
margin-left: 1px;
|
|
||||||
}
|
|
||||||
|
|
||||||
table.citation td {
|
|
||||||
border-bottom: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
th > :first-child,
|
|
||||||
td > :first-child {
|
|
||||||
margin-top: 0px;
|
|
||||||
}
|
|
||||||
|
|
||||||
th > :last-child,
|
|
||||||
td > :last-child {
|
|
||||||
margin-bottom: 0px;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* -- figures --------------------------------------------------------------- */
|
|
||||||
|
|
||||||
div.figure, figure {
|
|
||||||
margin: 0.5em;
|
|
||||||
padding: 0.5em;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.figure p.caption, figcaption {
|
|
||||||
padding: 0.3em;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.figure p.caption span.caption-number,
|
|
||||||
figcaption span.caption-number {
|
|
||||||
font-style: italic;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.figure p.caption span.caption-text,
|
|
||||||
figcaption span.caption-text {
|
|
||||||
}
|
|
||||||
|
|
||||||
/* -- field list styles ----------------------------------------------------- */
|
|
||||||
|
|
||||||
table.field-list td, table.field-list th {
|
|
||||||
border: 0 !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.field-list ul {
|
|
||||||
margin: 0;
|
|
||||||
padding-left: 1em;
|
|
||||||
}
|
|
||||||
|
|
||||||
.field-list p {
|
|
||||||
margin: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
.field-name {
|
|
||||||
-moz-hyphens: manual;
|
|
||||||
-ms-hyphens: manual;
|
|
||||||
-webkit-hyphens: manual;
|
|
||||||
hyphens: manual;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* -- hlist styles ---------------------------------------------------------- */
|
|
||||||
|
|
||||||
table.hlist {
|
|
||||||
margin: 1em 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
table.hlist td {
|
|
||||||
vertical-align: top;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* -- object description styles --------------------------------------------- */
|
|
||||||
|
|
||||||
.sig {
|
|
||||||
font-family: 'Consolas', 'Menlo', 'DejaVu Sans Mono', 'Bitstream Vera Sans Mono', monospace;
|
|
||||||
}
|
|
||||||
|
|
||||||
.sig-name, code.descname {
|
|
||||||
background-color: transparent;
|
|
||||||
font-weight: bold;
|
|
||||||
}
|
|
||||||
|
|
||||||
.sig-name {
|
|
||||||
font-size: 1.1em;
|
|
||||||
}
|
|
||||||
|
|
||||||
code.descname {
|
|
||||||
font-size: 1.2em;
|
|
||||||
}
|
|
||||||
|
|
||||||
.sig-prename, code.descclassname {
|
|
||||||
background-color: transparent;
|
|
||||||
}
|
|
||||||
|
|
||||||
.optional {
|
|
||||||
font-size: 1.3em;
|
|
||||||
}
|
|
||||||
|
|
||||||
.sig-paren {
|
|
||||||
font-size: larger;
|
|
||||||
}
|
|
||||||
|
|
||||||
.sig-param.n {
|
|
||||||
font-style: italic;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* C++ specific styling */
|
|
||||||
|
|
||||||
.sig-inline.c-texpr,
|
|
||||||
.sig-inline.cpp-texpr {
|
|
||||||
font-family: unset;
|
|
||||||
}
|
|
||||||
|
|
||||||
.sig.c .k, .sig.c .kt,
|
|
||||||
.sig.cpp .k, .sig.cpp .kt {
|
|
||||||
color: #0033B3;
|
|
||||||
}
|
|
||||||
|
|
||||||
.sig.c .m,
|
|
||||||
.sig.cpp .m {
|
|
||||||
color: #1750EB;
|
|
||||||
}
|
|
||||||
|
|
||||||
.sig.c .s, .sig.c .sc,
|
|
||||||
.sig.cpp .s, .sig.cpp .sc {
|
|
||||||
color: #067D17;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* -- other body styles ----------------------------------------------------- */
|
|
||||||
|
|
||||||
ol.arabic {
|
|
||||||
list-style: decimal;
|
|
||||||
}
|
|
||||||
|
|
||||||
ol.loweralpha {
|
|
||||||
list-style: lower-alpha;
|
|
||||||
}
|
|
||||||
|
|
||||||
ol.upperalpha {
|
|
||||||
list-style: upper-alpha;
|
|
||||||
}
|
|
||||||
|
|
||||||
ol.lowerroman {
|
|
||||||
list-style: lower-roman;
|
|
||||||
}
|
|
||||||
|
|
||||||
ol.upperroman {
|
|
||||||
list-style: upper-roman;
|
|
||||||
}
|
|
||||||
|
|
||||||
:not(li) > ol > li:first-child > :first-child,
|
|
||||||
:not(li) > ul > li:first-child > :first-child {
|
|
||||||
margin-top: 0px;
|
|
||||||
}
|
|
||||||
|
|
||||||
:not(li) > ol > li:last-child > :last-child,
|
|
||||||
:not(li) > ul > li:last-child > :last-child {
|
|
||||||
margin-bottom: 0px;
|
|
||||||
}
|
|
||||||
|
|
||||||
ol.simple ol p,
|
|
||||||
ol.simple ul p,
|
|
||||||
ul.simple ol p,
|
|
||||||
ul.simple ul p {
|
|
||||||
margin-top: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
ol.simple > li:not(:first-child) > p,
|
|
||||||
ul.simple > li:not(:first-child) > p {
|
|
||||||
margin-top: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
ol.simple p,
|
|
||||||
ul.simple p {
|
|
||||||
margin-bottom: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
aside.footnote > span,
|
|
||||||
div.citation > span {
|
|
||||||
float: left;
|
|
||||||
}
|
|
||||||
aside.footnote > span:last-of-type,
|
|
||||||
div.citation > span:last-of-type {
|
|
||||||
padding-right: 0.5em;
|
|
||||||
}
|
|
||||||
aside.footnote > p {
|
|
||||||
margin-left: 2em;
|
|
||||||
}
|
|
||||||
div.citation > p {
|
|
||||||
margin-left: 4em;
|
|
||||||
}
|
|
||||||
aside.footnote > p:last-of-type,
|
|
||||||
div.citation > p:last-of-type {
|
|
||||||
margin-bottom: 0em;
|
|
||||||
}
|
|
||||||
aside.footnote > p:last-of-type:after,
|
|
||||||
div.citation > p:last-of-type:after {
|
|
||||||
content: "";
|
|
||||||
clear: both;
|
|
||||||
}
|
|
||||||
|
|
||||||
dl.field-list {
|
|
||||||
display: grid;
|
|
||||||
grid-template-columns: fit-content(30%) auto;
|
|
||||||
}
|
|
||||||
|
|
||||||
dl.field-list > dt {
|
|
||||||
font-weight: bold;
|
|
||||||
word-break: break-word;
|
|
||||||
padding-left: 0.5em;
|
|
||||||
padding-right: 5px;
|
|
||||||
}
|
|
||||||
|
|
||||||
dl.field-list > dd {
|
|
||||||
padding-left: 0.5em;
|
|
||||||
margin-top: 0em;
|
|
||||||
margin-left: 0em;
|
|
||||||
margin-bottom: 0em;
|
|
||||||
}
|
|
||||||
|
|
||||||
dl {
|
|
||||||
margin-bottom: 15px;
|
|
||||||
}
|
|
||||||
|
|
||||||
dd > :first-child {
|
|
||||||
margin-top: 0px;
|
|
||||||
}
|
|
||||||
|
|
||||||
dd ul, dd table {
|
|
||||||
margin-bottom: 10px;
|
|
||||||
}
|
|
||||||
|
|
||||||
dd {
|
|
||||||
margin-top: 3px;
|
|
||||||
margin-bottom: 10px;
|
|
||||||
margin-left: 30px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.sig dd {
|
|
||||||
margin-top: 0px;
|
|
||||||
margin-bottom: 0px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.sig dl {
|
|
||||||
margin-top: 0px;
|
|
||||||
margin-bottom: 0px;
|
|
||||||
}
|
|
||||||
|
|
||||||
dl > dd:last-child,
|
|
||||||
dl > dd:last-child > :last-child {
|
|
||||||
margin-bottom: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
dt:target, span.highlighted {
|
|
||||||
background-color: #fbe54e;
|
|
||||||
}
|
|
||||||
|
|
||||||
rect.highlighted {
|
|
||||||
fill: #fbe54e;
|
|
||||||
}
|
|
||||||
|
|
||||||
dl.glossary dt {
|
|
||||||
font-weight: bold;
|
|
||||||
font-size: 1.1em;
|
|
||||||
}
|
|
||||||
|
|
||||||
.versionmodified {
|
|
||||||
font-style: italic;
|
|
||||||
}
|
|
||||||
|
|
||||||
.system-message {
|
|
||||||
background-color: #fda;
|
|
||||||
padding: 5px;
|
|
||||||
border: 3px solid red;
|
|
||||||
}
|
|
||||||
|
|
||||||
.footnote:target {
|
|
||||||
background-color: #ffa;
|
|
||||||
}
|
|
||||||
|
|
||||||
.line-block {
|
|
||||||
display: block;
|
|
||||||
margin-top: 1em;
|
|
||||||
margin-bottom: 1em;
|
|
||||||
}
|
|
||||||
|
|
||||||
.line-block .line-block {
|
|
||||||
margin-top: 0;
|
|
||||||
margin-bottom: 0;
|
|
||||||
margin-left: 1.5em;
|
|
||||||
}
|
|
||||||
|
|
||||||
.guilabel, .menuselection {
|
|
||||||
font-family: sans-serif;
|
|
||||||
}
|
|
||||||
|
|
||||||
.accelerator {
|
|
||||||
text-decoration: underline;
|
|
||||||
}
|
|
||||||
|
|
||||||
.classifier {
|
|
||||||
font-style: oblique;
|
|
||||||
}
|
|
||||||
|
|
||||||
.classifier:before {
|
|
||||||
font-style: normal;
|
|
||||||
margin: 0 0.5em;
|
|
||||||
content: ":";
|
|
||||||
display: inline-block;
|
|
||||||
}
|
|
||||||
|
|
||||||
abbr, acronym {
|
|
||||||
border-bottom: dotted 1px;
|
|
||||||
cursor: help;
|
|
||||||
}
|
|
||||||
|
|
||||||
.translated {
|
|
||||||
background-color: rgba(207, 255, 207, 0.2)
|
|
||||||
}
|
|
||||||
|
|
||||||
.untranslated {
|
|
||||||
background-color: rgba(255, 207, 207, 0.2)
|
|
||||||
}
|
|
||||||
|
|
||||||
/* -- code displays --------------------------------------------------------- */
|
|
||||||
|
|
||||||
pre {
|
|
||||||
overflow: auto;
|
|
||||||
overflow-y: hidden; /* fixes display issues on Chrome browsers */
|
|
||||||
}
|
|
||||||
|
|
||||||
pre, div[class*="highlight-"] {
|
|
||||||
clear: both;
|
|
||||||
}
|
|
||||||
|
|
||||||
span.pre {
|
|
||||||
-moz-hyphens: none;
|
|
||||||
-ms-hyphens: none;
|
|
||||||
-webkit-hyphens: none;
|
|
||||||
hyphens: none;
|
|
||||||
white-space: nowrap;
|
|
||||||
}
|
|
||||||
|
|
||||||
div[class*="highlight-"] {
|
|
||||||
margin: 1em 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
td.linenos pre {
|
|
||||||
border: 0;
|
|
||||||
background-color: transparent;
|
|
||||||
color: #aaa;
|
|
||||||
}
|
|
||||||
|
|
||||||
table.highlighttable {
|
|
||||||
display: block;
|
|
||||||
}
|
|
||||||
|
|
||||||
table.highlighttable tbody {
|
|
||||||
display: block;
|
|
||||||
}
|
|
||||||
|
|
||||||
table.highlighttable tr {
|
|
||||||
display: flex;
|
|
||||||
}
|
|
||||||
|
|
||||||
table.highlighttable td {
|
|
||||||
margin: 0;
|
|
||||||
padding: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
table.highlighttable td.linenos {
|
|
||||||
padding-right: 0.5em;
|
|
||||||
}
|
|
||||||
|
|
||||||
table.highlighttable td.code {
|
|
||||||
flex: 1;
|
|
||||||
overflow: hidden;
|
|
||||||
}
|
|
||||||
|
|
||||||
.highlight .hll {
|
|
||||||
display: block;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.highlight pre,
|
|
||||||
table.highlighttable pre {
|
|
||||||
margin: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.code-block-caption + div {
|
|
||||||
margin-top: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.code-block-caption {
|
|
||||||
margin-top: 1em;
|
|
||||||
padding: 2px 5px;
|
|
||||||
font-size: small;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.code-block-caption code {
|
|
||||||
background-color: transparent;
|
|
||||||
}
|
|
||||||
|
|
||||||
table.highlighttable td.linenos,
|
|
||||||
span.linenos,
|
|
||||||
div.highlight span.gp { /* gp: Generic.Prompt */
|
|
||||||
user-select: none;
|
|
||||||
-webkit-user-select: text; /* Safari fallback only */
|
|
||||||
-webkit-user-select: none; /* Chrome/Safari */
|
|
||||||
-moz-user-select: none; /* Firefox */
|
|
||||||
-ms-user-select: none; /* IE10+ */
|
|
||||||
}
|
|
||||||
|
|
||||||
div.code-block-caption span.caption-number {
|
|
||||||
padding: 0.1em 0.3em;
|
|
||||||
font-style: italic;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.code-block-caption span.caption-text {
|
|
||||||
}
|
|
||||||
|
|
||||||
div.literal-block-wrapper {
|
|
||||||
margin: 1em 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
code.xref, a code {
|
|
||||||
background-color: transparent;
|
|
||||||
font-weight: bold;
|
|
||||||
}
|
|
||||||
|
|
||||||
h1 code, h2 code, h3 code, h4 code, h5 code, h6 code {
|
|
||||||
background-color: transparent;
|
|
||||||
}
|
|
||||||
|
|
||||||
.viewcode-link {
|
|
||||||
float: right;
|
|
||||||
}
|
|
||||||
|
|
||||||
.viewcode-back {
|
|
||||||
float: right;
|
|
||||||
font-family: sans-serif;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.viewcode-block:target {
|
|
||||||
margin: -1px -10px;
|
|
||||||
padding: 0 10px;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* -- math display ---------------------------------------------------------- */
|
|
||||||
|
|
||||||
img.math {
|
|
||||||
vertical-align: middle;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.body div.math p {
|
|
||||||
text-align: center;
|
|
||||||
}
|
|
||||||
|
|
||||||
span.eqno {
|
|
||||||
float: right;
|
|
||||||
}
|
|
||||||
|
|
||||||
span.eqno a.headerlink {
|
|
||||||
position: absolute;
|
|
||||||
z-index: 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.math:hover a.headerlink {
|
|
||||||
visibility: visible;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* -- printout stylesheet --------------------------------------------------- */
|
|
||||||
|
|
||||||
@media print {
|
|
||||||
div.document,
|
|
||||||
div.documentwrapper,
|
|
||||||
div.bodywrapper {
|
|
||||||
margin: 0 !important;
|
|
||||||
width: 100%;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.sphinxsidebar,
|
|
||||||
div.related,
|
|
||||||
div.footer,
|
|
||||||
#top-link {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@ -1,116 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
|
||||||
<svg
|
|
||||||
xmlns:dc="http://purl.org/dc/elements/1.1/"
|
|
||||||
xmlns:cc="http://creativecommons.org/ns#"
|
|
||||||
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
|
|
||||||
xmlns:svg="http://www.w3.org/2000/svg"
|
|
||||||
xmlns="http://www.w3.org/2000/svg"
|
|
||||||
id="svg8"
|
|
||||||
version="1.1"
|
|
||||||
viewBox="0 0 55.032989 15.935012"
|
|
||||||
height="60.226818"
|
|
||||||
width="207.9987">
|
|
||||||
<defs
|
|
||||||
id="defs2">
|
|
||||||
<clipPath
|
|
||||||
clipPathUnits="userSpaceOnUse"
|
|
||||||
id="clipPath3020">
|
|
||||||
<path
|
|
||||||
style="stroke-width:1.06666672"
|
|
||||||
d="M 0,0 H 211.2 V 61.866667 H 0 Z"
|
|
||||||
id="path3022" />
|
|
||||||
</clipPath>
|
|
||||||
<clipPath
|
|
||||||
clipPathUnits="userSpaceOnUse"
|
|
||||||
id="clipPath3020-8">
|
|
||||||
<path
|
|
||||||
style="stroke-width:1.06666672"
|
|
||||||
d="M 0,0 H 211.2 V 61.866667 H 0 Z"
|
|
||||||
id="path3022-1" />
|
|
||||||
</clipPath>
|
|
||||||
</defs>
|
|
||||||
<metadata
|
|
||||||
id="metadata5">
|
|
||||||
<rdf:RDF>
|
|
||||||
<cc:Work
|
|
||||||
rdf:about="">
|
|
||||||
<dc:format>image/svg+xml</dc:format>
|
|
||||||
<dc:type
|
|
||||||
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
|
|
||||||
<dc:creator>
|
|
||||||
<cc:Agent>
|
|
||||||
<dc:title>Blender Logo</dc:title>
|
|
||||||
</cc:Agent>
|
|
||||||
</dc:creator>
|
|
||||||
<dc:source>https://www.blender.org/about/logo/</dc:source>
|
|
||||||
<cc:license
|
|
||||||
rdf:resource="(c) Blender Foundation" />
|
|
||||||
</cc:Work>
|
|
||||||
</rdf:RDF>
|
|
||||||
</metadata>
|
|
||||||
<g
|
|
||||||
transform="translate(42.023693,-77.734934)"
|
|
||||||
id="layer1">
|
|
||||||
<g
|
|
||||||
transform="matrix(0.26259939,0,0,-0.26259939,-42.237694,93.888967)"
|
|
||||||
id="g3012"
|
|
||||||
style="stroke-width:7.2904439">
|
|
||||||
<g
|
|
||||||
id="g3014"
|
|
||||||
style="stroke-width:7.2904439" />
|
|
||||||
<g
|
|
||||||
id="g3016"
|
|
||||||
style="stroke-width:7.2904439">
|
|
||||||
<g
|
|
||||||
clip-path="url(#clipPath3020-8)"
|
|
||||||
id="g3018"
|
|
||||||
style="stroke-width:7.2904439">
|
|
||||||
<path
|
|
||||||
id="path3024"
|
|
||||||
style="fill:#ffffff;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:7.77647352"
|
|
||||||
d="m 192.54827,44.510933 c 0,0 -125.158403,0 -128.688003,0 -0.07893,0.06187 -0.1504,0.1344 -0.2272,0.193067 -0.01813,0.0192 -18.9312,14.548267 -19.5008,14.986667 -0.032,0.0256 -0.06507,0.04907 -0.06507,0.04907 -3.029333,2.321067 -7.531733,2.369067 -10.721067,0.133334 -1.9968,-1.396267 -3.194666,-3.508267 -3.285333,-5.792 -0.0021,-0.09173 -0.0064,-0.1824 -0.0064,-0.2752 0,-1.185067 0.314667,-2.3296 0.8832,-3.357867 -5.857067,-0.0053 -11.746133,-0.0128 -11.746133,-0.0128 -4.3936,-0.0021 -8.3648,-2.965333 -9.2725337,-6.8928 C 9.7898667,42.9792 9.7248,42.411733 9.7248,41.8496 c 0,-1.643733 0.546133,-3.236267 1.5808,-4.542933 1.162667,-1.463467 2.842667,-2.448 4.7584,-2.832 C 10.530133,30.2272 5.0016,25.984 4.9973333,25.979733 4.9578667,25.949867 4.9248,25.924267 4.8970667,25.905067 c -2.2176,-1.703467 -3.68,-4.1728 -4.0106667,-6.770134 -0.0490667,-0.381866 -0.0714667,-0.7584 -0.0714667,-1.133866 0,-1.870934 0.5962667,-3.650134 1.7301334,-5.102934 1.3781333,-1.764266 3.4144,-2.884266 5.7322666,-3.147733 2.6549337,-0.3072 5.4495997,0.542933 7.6607997,2.330667 0.01493,0.01173 2.753067,2.256 5.639467,4.6176 1.060267,-2.555734 2.545067,-4.926934 4.465067,-7.0453337 2.4704,-2.7306666 5.473066,-4.8864 8.919466,-6.4128 C 38.5856,1.6352 42.466133,0.82453333 46.501333,0.83413333 50.5376,0.8416 54.417067,1.6629333 58.0352,3.2768 c 3.453867,1.5466667 6.449067,3.7109333 8.910933,6.4352 0.360534,0.4032 0.693334,0.8288 1.0272,1.2544 4.885334,0 124.574937,0 124.574937,0 9.84,0 17.8368,7.5232 17.8368,16.7712 0,9.248 -7.9968,16.773333 -17.8368,16.773333" />
|
|
||||||
<path
|
|
||||||
id="path3026"
|
|
||||||
style="fill:#0d528a;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:7.77647352"
|
|
||||||
d="m 38.538667,28.497067 c 0.113066,2.016 1.101866,3.793066 2.590933,5.0528 1.4624,1.237333 3.428267,1.9936 5.575467,1.9936 2.144,0 4.110933,-0.756267 5.572266,-1.9936 1.490134,-1.259734 2.4768,-3.0368 2.590934,-5.050667 0.113066,-2.0736 -0.718934,-3.997867 -2.181334,-5.425067 C 51.1968,21.6224 49.0784,20.7104 46.705067,20.7104 c -2.3744,0 -4.497067,0.912 -5.9872,2.363733 -1.461334,1.4272 -2.292267,3.351467 -2.1792,5.422934" />
|
|
||||||
<path
|
|
||||||
id="path3028"
|
|
||||||
style="fill:#f5792a;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:7.77647352"
|
|
||||||
d="m 25.536,24.421333 c 0.01387,-0.7904 0.2656,-2.3232 0.6432,-3.521066 C 26.9728,18.3648 28.318933,16.0192 30.193067,13.950933 32.1152,11.8272 34.482133,10.119467 37.216,8.9088 c 2.872533,-1.2736 5.986133,-1.9210667 9.220267,-1.9157333 3.229866,0.00427 6.3424,0.6656 9.216,1.9477333 2.733866,1.2224 5.098666,2.9376 7.018666,5.063467 1.870934,2.074666 3.216,4.424533 4.010667,6.96 0.401067,1.282133 0.6528,2.581333 0.754133,3.886933 0.100267,1.285333 0.0576,2.571733 -0.1248,3.858133 -0.356266,2.507734 -1.223466,4.858667 -2.557866,7.002667 -1.2224,1.970133 -2.7968,3.696 -4.6688,5.147733 l 0.0053,0.0021 -18.8928,14.506666 c -0.016,0.0128 -0.02987,0.02667 -0.048,0.03733 -1.240533,0.952533 -3.3248,0.948266 -4.686933,-0.0053 -1.3792,-0.9632 -1.536,-2.557866 -0.3104,-3.5648 l -0.0043,-0.0043 7.8784,-6.407467 -24.016,-0.02667 c -0.01173,0 -0.0224,0 -0.032,0 -1.985067,-0.0011 -3.893333,-1.303466 -4.269867,-2.9504 -0.389333,-1.6768 0.958934,-3.067733 3.022934,-3.074133 l -0.0021,-0.0075 L 30.900267,39.3888 9.1786667,22.715733 c -0.026667,-0.02133 -0.0576,-0.0416 -0.0832,-0.06293 -2.0490667,-1.568 -2.7104,-4.178133 -1.4197334,-5.828267 1.3088,-1.68 4.0949337,-1.6832 6.1653337,-0.0096 L 25.696,26.516267 c 0,0 -0.173867,-1.3088 -0.16,-2.094934 z M 56,20.034133 c -2.443733,-2.488533 -5.8624,-3.899733 -9.563733,-3.9072 -3.7056,-0.0064 -7.124267,1.393067 -9.568,3.877334 -1.1936,1.210666 -2.0704,2.602666 -2.6112,4.087466 -0.529067,1.457067 -0.736,3.0048 -0.599467,4.5664 0.130133,1.527467 0.583467,2.9824 1.309867,4.3008 0.712533,1.293867 1.6928,2.465067 2.9056,3.454934 2.373333,1.934933 5.396266,2.981333 8.558933,2.9856 3.1648,0.0053 6.1856,-1.0336 8.561067,-2.961067 1.2096,-0.9856 2.190933,-2.151467 2.903466,-3.445333 0.728534,-1.316267 1.179734,-2.765867 1.314134,-4.2976 C 59.344,27.136 59.138133,25.5904 58.609067,24.1312 58.0672,22.6432 57.1936,21.2512 56,20.034133" />
|
|
||||||
<path
|
|
||||||
id="path3030"
|
|
||||||
style="fill:#0d528a;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:7.77647352"
|
|
||||||
d="m 167.96587,28.529067 c 0.1824,2.0352 1.75466,3.325866 4.15786,3.325866 2.4064,0 3.97974,-1.290666 4.16214,-3.325866 z M 176.0384,23.504 c -0.61547,-1.508267 -2.06507,-2.401067 -4.03627,-2.401067 -2.46613,0 -4.12693,1.540267 -4.1952,3.9744 h 14.18347 c 0,0.251734 0,0.462934 0,0.715734 0,6.094933 -3.57653,9.518933 -9.98827,9.518933 -6.22506,0 -9.98826,-3.457067 -9.98826,-8.878933 0,-5.454934 3.82293,-8.9056 9.98826,-8.9056 3.70134,0 6.5696,1.2672 8.33814,3.4976 L 176.0384,23.504" />
|
|
||||||
<path
|
|
||||||
id="path3032"
|
|
||||||
style="fill:#0d528a;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:7.77647352"
|
|
||||||
d="m 105.0336,28.519467 c 0.18667,2.036266 1.76,3.326933 4.16533,3.326933 2.40214,0 3.97547,-1.290667 4.15894,-3.326933 z m 8.07787,-5.025067 c -0.61547,-1.512533 -2.06614,-2.404267 -4.03947,-2.404267 -2.464,0 -4.12907,1.544534 -4.19413,3.9776 h 14.18026 c 0,0.2496 0,0.4608 0,0.712534 0,6.098133 -3.57546,9.524266 -9.98613,9.524266 -6.22933,0 -9.986133,-3.458133 -9.986133,-8.88 0,-5.456 3.821863,-8.906666 9.986133,-8.906666 3.6992,0 6.5696,1.262933 8.34133,3.495466 l -4.30186,2.481067" />
|
|
||||||
<path
|
|
||||||
id="path3034"
|
|
||||||
style="fill:#0d528a;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:7.77647352"
|
|
||||||
d="m 92.701867,38.997333 h 5.114666 v -20.9248 h -5.114666 z" />
|
|
||||||
<path
|
|
||||||
id="path3036"
|
|
||||||
style="fill:#0d528a;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:7.77647352"
|
|
||||||
d="m 120.33067,33.438933 h 5.14453 v -1.245866 c 1.8208,1.9424 4.00747,2.9248 6.47253,2.9248 2.84054,0 4.992,-0.9824 6.1024,-2.653867 0.92587,-1.381333 0.98774,-3.0496 0.98774,-5.239467 v -9.152 h -5.15094 v 8.040534 c 0,3.336533 -0.67093,4.877866 -3.6,4.877866 -2.96106,0 -4.81173,-1.764266 -4.81173,-4.724266 v -8.194134 h -5.14453 v 15.3664" />
|
|
||||||
<path
|
|
||||||
id="path3038"
|
|
||||||
style="fill:#0d528a;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:7.77647352"
|
|
||||||
d="m 155.60107,26.173867 c 0,-2.864 -1.9136,-4.741334 -4.8736,-4.741334 -2.96427,0 -4.87787,1.813334 -4.87787,4.709334 0,2.9376 1.88907,4.750933 4.87787,4.750933 2.96,0 4.8736,-1.8464 4.8736,-4.718933 z m 0,6.568533 c -1.30027,1.393067 -3.1808,2.157867 -5.79734,2.157867 -5.64266,0 -9.49546,-3.479467 -9.49546,-8.6944 0,-5.112534 3.82613,-8.688 9.40266,-8.688 2.5568,0 4.4352,0.645333 5.89014,2.096 v -1.541334 h 5.14666 v 22.2528 l -5.14666,-1.328 V 32.7424" />
|
|
||||||
<path
|
|
||||||
id="path3040"
|
|
||||||
style="fill:#0d528a;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:7.77647352"
|
|
||||||
d="m 81.010133,30.8928 c 2.990934,0 4.871467,-1.813333 4.871467,-4.750933 0,-2.896 -1.9104,-4.709334 -4.871467,-4.709334 -2.958933,0 -4.869333,1.877334 -4.869333,4.741334 0,2.872533 1.9104,4.718933 4.869333,4.718933 z m -4.869333,8.104533 -5.1488,1.328 v -22.2528 h 5.1488 v 1.541334 c 1.448533,-1.450667 3.329067,-2.096 5.886933,-2.096 5.579734,0 9.4016,3.575466 9.4016,8.688 0,5.214933 -3.853866,8.6944 -9.493333,8.6944 -2.621867,0 -4.5024,-0.7648 -5.7952,-2.157867 v 6.254933" />
|
|
||||||
<path
|
|
||||||
id="path3042"
|
|
||||||
style="fill:#0d528a;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:7.77647352"
|
|
||||||
d="m 183.2608,18.072533 v 15.3664 h 5.14667 v -0.9504 c 1.54026,1.857067 3.1712,2.7808 5.0272,2.7808 0.368,0 0.82986,-0.05973 1.44533,-0.1216 V 30.768 c -0.496,0.064 -1.04747,0.064 -1.6352,0.064 -2.992,0 -4.83733,-1.972267 -4.83733,-5.329067 v -7.4304 h -5.14667" />
|
|
||||||
<path
|
|
||||||
id="path3044"
|
|
||||||
style="fill:#0d528a;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:7.77647352"
|
|
||||||
d="m 201.55307,35.252267 h -0.39467 l 0.0139,1.409066 0.0203,0.466134 -0.1056,-0.384 -0.46826,-1.4912 h -0.36054 l -0.45866,1.4912 -0.1152,0.376533 0.0277,-0.458667 0.0139,-1.409066 h -0.38614 v 2.282666 h 0.54187 l 0.57067,-1.8016 0.5568,1.8016 h 0.544 z m -3.12747,0 h -0.39787 V 37.1968 h -0.7328 v 0.338133 h 1.85067 V 37.1968 h -0.72 v -1.944533" />
|
|
||||||
</g>
|
|
||||||
</g>
|
|
||||||
</g>
|
|
||||||
</g>
|
|
||||||
</svg>
|
|
||||||
|
Before Width: | Height: | Size: 10 KiB |
|
Before Width: | Height: | Size: 6.9 MiB |
@ -1,23 +0,0 @@
|
|||||||
/*
|
|
||||||
* This stylesheet is applied after the theme's default one,
|
|
||||||
* and thus any overrides or additions can be added here.
|
|
||||||
*
|
|
||||||
* More info:
|
|
||||||
* https://www.sphinx-doc.org/en/master/extdev/appapi.html#sphinx.application.Sphinx.add_css_file
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* Allow text to flow around right aligned images */
|
|
||||||
.align-right {
|
|
||||||
float: right;
|
|
||||||
margin: 0 0 24px 24px;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Prevent images from flowing into other headings */
|
|
||||||
h1,
|
|
||||||
h2,
|
|
||||||
h3,
|
|
||||||
h4,
|
|
||||||
h5,
|
|
||||||
h6 {
|
|
||||||
clear: both;
|
|
||||||
}
|
|
||||||
@ -1,383 +0,0 @@
|
|||||||
/*
|
|
||||||
* This stylesheet is applied after the theme's default one,
|
|
||||||
* and thus any overrides or additions can be added here.
|
|
||||||
*
|
|
||||||
* More info:
|
|
||||||
* https://www.sphinx-doc.org/en/master/extdev/appapi.html#sphinx.application.Sphinx.add_css_file
|
|
||||||
*/
|
|
||||||
|
|
||||||
body {
|
|
||||||
--sidebar-caption-font-size: var(--font-size--normal);
|
|
||||||
--toc-title-font-size: var(--font-size--normal);
|
|
||||||
--toc-font-size: var(--sidebar-item-font-size);
|
|
||||||
--admonition-font-size: var(--font-size--normal);
|
|
||||||
--admonition-title-font-size: var(--font-size--normal);
|
|
||||||
--color-api-name: #e87d0d;
|
|
||||||
--color-brand-visited: var(--color-brand-content) !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
h1,
|
|
||||||
h2,
|
|
||||||
h3 {
|
|
||||||
margin-top: 1.75rem;
|
|
||||||
margin-bottom: 1rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
h1 {
|
|
||||||
font-size: 2em;
|
|
||||||
}
|
|
||||||
|
|
||||||
h2 {
|
|
||||||
font-size: 1.5em;
|
|
||||||
}
|
|
||||||
|
|
||||||
h3 {
|
|
||||||
font-size: 1.25em;
|
|
||||||
}
|
|
||||||
|
|
||||||
h4,
|
|
||||||
h5,
|
|
||||||
h6,
|
|
||||||
.rubric {
|
|
||||||
margin-top: 1.25rem;
|
|
||||||
margin-bottom: 0.75rem;
|
|
||||||
font-size: 1.125em;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Fix alignment of icons. */
|
|
||||||
[class^="bl-icons-"], [class*=" bl-icons-"] {
|
|
||||||
vertical-align: text-bottom;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Increase the size of icons inside rubrics. */
|
|
||||||
.rubric > [class^="bl-icons-"] {
|
|
||||||
font-size: xx-large;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Reduce the margins on top/bottom of horizontal lines. */
|
|
||||||
hr.docutils {
|
|
||||||
margin: 1rem 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* Slightly decrease text to make the text fit on one line */
|
|
||||||
.sidebar-brand-text {
|
|
||||||
font-size: 1.4rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
.toctree-checkbox~label .icon svg {
|
|
||||||
transition: transform 0.25s ease-out;
|
|
||||||
}
|
|
||||||
|
|
||||||
@media (prefers-reduced-motion: reduce) {
|
|
||||||
.toctree-checkbox~label .icon svg {
|
|
||||||
transition-duration: 0s !important;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Add more visual weight to definition terms */
|
|
||||||
dl dt {
|
|
||||||
font-weight: bold !important
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Fixes to field list, see #104636 */
|
|
||||||
dl.field-list {
|
|
||||||
display: grid;
|
|
||||||
grid-template-columns: auto minmax(80%, 95%);
|
|
||||||
row-gap: 0.125em;
|
|
||||||
}
|
|
||||||
|
|
||||||
.field-list > dt {
|
|
||||||
margin-top: 0 !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.field-list > dd > p {
|
|
||||||
margin-top: 0 !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
dl.field-list > dd > p:last-child {
|
|
||||||
margin-bottom: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Revert back to normal definitions for field lists on mobile
|
|
||||||
inside a definition (gives more room for definition text). */
|
|
||||||
@media (max-width: calc(67em / 2)) {
|
|
||||||
dd > dl.field-list {
|
|
||||||
grid-template-columns: unset;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* TABLE & FIGURE */
|
|
||||||
|
|
||||||
/* Cell's vertical align. */
|
|
||||||
/* use "valign" class for middle align */
|
|
||||||
table.docutils:not(.valign) td {
|
|
||||||
vertical-align: top;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Decrease whitespace above figure and add it below */
|
|
||||||
figure {
|
|
||||||
padding-bottom: 0.5rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
figcaption {
|
|
||||||
margin-bottom: 0.5rem !important;
|
|
||||||
|
|
||||||
p {
|
|
||||||
margin-top: 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Allow horizontal lists to collapse on narrow screens */
|
|
||||||
.hlist tr {
|
|
||||||
display: flex;
|
|
||||||
flex-flow: row wrap;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* End TABLE & FIGURE. */
|
|
||||||
|
|
||||||
/* Force admonition to span the full width if close to a figure */
|
|
||||||
.admonition {
|
|
||||||
clear: both;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Use secondary font color for caption text */
|
|
||||||
figcaption,
|
|
||||||
caption {
|
|
||||||
color: var(--color-foreground-secondary);
|
|
||||||
font-size: var(--font-size--small)
|
|
||||||
}
|
|
||||||
|
|
||||||
/* A bit hacky, revert the themes styling of kbd */
|
|
||||||
kbd:not(.compound) {
|
|
||||||
all: revert;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Only style parent kbd elements instead of the individual children */
|
|
||||||
:not(dl.option-list)> :not(kbd):not(kbd)>kbd,
|
|
||||||
.menuselection {
|
|
||||||
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-secondary);
|
|
||||||
color: var(--color-foreground-primary);
|
|
||||||
display: inline-block;
|
|
||||||
margin: 0;
|
|
||||||
padding: 0 .2rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Don't underline any text within code blocks (hurts readability). */
|
|
||||||
.highlight .nc,
|
|
||||||
.highlight .nn,
|
|
||||||
.highlight .gu {
|
|
||||||
text-decoration-line: none !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.caption .menuselection {
|
|
||||||
background-color: transparent;
|
|
||||||
border: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
a {
|
|
||||||
text-decoration: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Break long code references onto a second line */
|
|
||||||
a > code.docutils {
|
|
||||||
overflow-wrap: anywhere;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Quotes for Fig. "link". */
|
|
||||||
a[href^="#fig-"]::before {
|
|
||||||
content: "\201c";
|
|
||||||
}
|
|
||||||
|
|
||||||
a[href^="#fig-"]::after {
|
|
||||||
content: "\201d";
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Mark external links. */
|
|
||||||
a.external:not(figure > a.external) {
|
|
||||||
filter: brightness(150%);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* List blender.org as internal. */
|
|
||||||
.external[href^="https://www.blender.org"],
|
|
||||||
.external[href^="https://docs.blender.org"],
|
|
||||||
.external[href^="https://projects.blender.org"],
|
|
||||||
.external[href^="https://builder.blender.org"],
|
|
||||||
.external[href^="https://code.blender.org"],
|
|
||||||
.external[href^="https://translate.blender.org"],
|
|
||||||
.external[href^="https://fund.blender.org"],
|
|
||||||
.external[href^="blender_manual_html.zip"],
|
|
||||||
.external[href^="blender_manual_epub.zip"],
|
|
||||||
.external[href^="https://archive.blender.org"] {
|
|
||||||
filter: revert;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* ".. container::" lead, block text float around image. */
|
|
||||||
.lead {
|
|
||||||
clear: both;
|
|
||||||
width: 100%;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Start reference admonition. */
|
|
||||||
.admonition.refbox {
|
|
||||||
border-color: rgb(50, 50, 50);
|
|
||||||
}
|
|
||||||
|
|
||||||
.admonition.refbox>.admonition-title {
|
|
||||||
background-color: rgba(50, 50, 50, 0.2);
|
|
||||||
border-color: rgb(50, 50, 50);
|
|
||||||
}
|
|
||||||
|
|
||||||
.admonition.refbox>.admonition-title::before {
|
|
||||||
background-color: var(--color-content-foreground);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* 'refbox' field. */
|
|
||||||
.refbox .field-list .field-name,
|
|
||||||
.refbox .field-list .field-body {
|
|
||||||
padding: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
.refbox dl dt {
|
|
||||||
font-weight: normal
|
|
||||||
}
|
|
||||||
|
|
||||||
/* End reference admonition. */
|
|
||||||
|
|
||||||
/* Applied on main index:sections. */
|
|
||||||
|
|
||||||
.global-index-toc {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Start section cards. */
|
|
||||||
.toc-cards {
|
|
||||||
display: grid;
|
|
||||||
grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
|
|
||||||
grid-gap: 20px;
|
|
||||||
list-style-type: none;
|
|
||||||
margin-bottom: 24px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.card {
|
|
||||||
border-radius: .3em;
|
|
||||||
user-select: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
.card div.figure,
|
|
||||||
.card figure {
|
|
||||||
margin-bottom: 0;
|
|
||||||
display: block;
|
|
||||||
}
|
|
||||||
|
|
||||||
.card img {
|
|
||||||
border-top-left-radius: .3em;
|
|
||||||
border-top-right-radius: .3em;
|
|
||||||
}
|
|
||||||
|
|
||||||
.card dl {
|
|
||||||
margin-bottom: 10px
|
|
||||||
}
|
|
||||||
|
|
||||||
.card dl dt>a {
|
|
||||||
display: block;
|
|
||||||
width: 100%;
|
|
||||||
margin-bottom: 10px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.card dl dt a em,
|
|
||||||
.card dl dt a span {
|
|
||||||
font-weight: bold;
|
|
||||||
font-style: normal;
|
|
||||||
font-size: 1.3em;
|
|
||||||
}
|
|
||||||
|
|
||||||
.card dl dt {
|
|
||||||
padding: 0 15px 0 !important
|
|
||||||
}
|
|
||||||
|
|
||||||
.card dl dd {
|
|
||||||
padding: 0 15px 5px 15px;
|
|
||||||
font-style: normal;
|
|
||||||
margin: 0;
|
|
||||||
color: var(--color-foreground-secondary);
|
|
||||||
font-size: 90%;
|
|
||||||
}
|
|
||||||
|
|
||||||
.card {
|
|
||||||
box-shadow: 0 .2rem .5rem rgba(0, 0, 0, .05), 0 0 .0625rem rgba(0, 0, 0, .1);
|
|
||||||
}
|
|
||||||
|
|
||||||
#getting-started .card {
|
|
||||||
box-shadow: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* End section cards. */
|
|
||||||
|
|
||||||
/* Start custom toctree. */
|
|
||||||
/* Indent all lines following the first. */
|
|
||||||
.toctree-wrapper * a {
|
|
||||||
display: block;
|
|
||||||
padding-top: 0.25em;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Make the top level links act like H2 tags. */
|
|
||||||
.toctree-wrapper .toctree-l1 > a {
|
|
||||||
font-size: 1.5em;
|
|
||||||
font-weight: bold;
|
|
||||||
}
|
|
||||||
|
|
||||||
.toctree-wrapper ul {
|
|
||||||
list-style: none;
|
|
||||||
padding-left: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Underline provided by nested ul (not li). */
|
|
||||||
.toctree-wrapper * ul {
|
|
||||||
margin-bottom: 1rem !important;
|
|
||||||
border-top: solid var(--color-background-border) 1px;
|
|
||||||
padding-left: 2em;
|
|
||||||
padding-top: 0.25em;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* End custom toctree. */
|
|
||||||
|
|
||||||
/* Start footer contribute link */
|
|
||||||
.footer-contribute {
|
|
||||||
display: block;
|
|
||||||
font-size: var(--font-size--small);
|
|
||||||
}
|
|
||||||
|
|
||||||
.bottom-of-page {
|
|
||||||
padding-bottom: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
.footer-contribute ul {
|
|
||||||
display: flex;
|
|
||||||
gap: 1.5rem;
|
|
||||||
margin: 0;
|
|
||||||
padding: 0;
|
|
||||||
padding-bottom: 1rem
|
|
||||||
}
|
|
||||||
|
|
||||||
.footer-contribute li {
|
|
||||||
list-style-type: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
@media (max-width: 46em) {
|
|
||||||
.footer-contribute > ul {
|
|
||||||
align-items: center;
|
|
||||||
justify-content: center;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@media print {
|
|
||||||
.footer-contribute {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* End footer contribute link */
|
|
||||||
@ -1,119 +0,0 @@
|
|||||||
#versionwrap {
|
|
||||||
margin: 0;
|
|
||||||
display: flex;
|
|
||||||
padding-top: 2px;
|
|
||||||
padding-left: 0;
|
|
||||||
font-size: var(--sidebar-item-font-size);
|
|
||||||
justify-content: center;
|
|
||||||
flex-wrap: wrap;
|
|
||||||
}
|
|
||||||
|
|
||||||
#versionwrap>ul {
|
|
||||||
list-style: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
#versionwrap>li {
|
|
||||||
display: flex;
|
|
||||||
width: 50%;
|
|
||||||
}
|
|
||||||
|
|
||||||
.version-btn {
|
|
||||||
display: inline-block;
|
|
||||||
background-color: var(--color-sidebar-background);
|
|
||||||
width: 100%;
|
|
||||||
text-align: center;
|
|
||||||
padding: 3px 10px;
|
|
||||||
margin: 0 5px 4px;
|
|
||||||
vertical-align: middle;
|
|
||||||
color: var(--color-link);
|
|
||||||
border: solid 1px var(--color-sidebar-background-border);
|
|
||||||
border-radius: 3px;
|
|
||||||
cursor: pointer;
|
|
||||||
z-index: 400;
|
|
||||||
}
|
|
||||||
|
|
||||||
.version-btn-open::after {
|
|
||||||
color: gray;
|
|
||||||
}
|
|
||||||
|
|
||||||
.version-btn:hover,
|
|
||||||
.version-btn:focus {
|
|
||||||
border-color: #525252;
|
|
||||||
}
|
|
||||||
|
|
||||||
.version-btn-open {
|
|
||||||
color: gray;
|
|
||||||
border: solid 1px var(--color-sidebar-background-border);
|
|
||||||
}
|
|
||||||
|
|
||||||
.version-btn.wait {
|
|
||||||
cursor: wait;
|
|
||||||
}
|
|
||||||
|
|
||||||
.version-btn.disabled {
|
|
||||||
cursor: not-allowed;
|
|
||||||
color: dimgray;
|
|
||||||
}
|
|
||||||
|
|
||||||
.version-dialog {
|
|
||||||
display: none;
|
|
||||||
position: absolute;
|
|
||||||
bottom: 24px;
|
|
||||||
width: 50%;
|
|
||||||
margin: 0 5px;
|
|
||||||
border-radius: 3px;
|
|
||||||
box-shadow: 0 0 6px #000C;
|
|
||||||
z-index: 999;
|
|
||||||
max-height: calc(100vh - 30px);
|
|
||||||
overflow-x: clip;
|
|
||||||
overflow-y: auto;
|
|
||||||
cursor: default;
|
|
||||||
}
|
|
||||||
|
|
||||||
.version-title {
|
|
||||||
padding: 5px;
|
|
||||||
color: var(--color-content-foreground);
|
|
||||||
text-align: center;
|
|
||||||
font-size: 102%;
|
|
||||||
font-weight: 700;
|
|
||||||
background-color: var(--color-brand-primary);
|
|
||||||
border-bottom: solid 1.5px var(--color-sidebar-background-border);
|
|
||||||
}
|
|
||||||
|
|
||||||
.version-list {
|
|
||||||
padding-left: 0;
|
|
||||||
margin-top: 0;
|
|
||||||
margin-bottom: 4px;
|
|
||||||
text-align: center;
|
|
||||||
border: solid 1px var(--color-sidebar-background-border);
|
|
||||||
border-radius: 0 0 3px 3px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.version-list a,
|
|
||||||
.version-list span,
|
|
||||||
.version-list li {
|
|
||||||
position: relative;
|
|
||||||
display: block;
|
|
||||||
font-size: 98%;
|
|
||||||
line-height: 1.15;
|
|
||||||
width: 100%;
|
|
||||||
margin: 0;
|
|
||||||
padding: 4px 0;
|
|
||||||
color: var(--color-sidebar-link-text);
|
|
||||||
}
|
|
||||||
|
|
||||||
.version-list li {
|
|
||||||
background-color: var(--color-sidebar-background);
|
|
||||||
color: var(--color-sidebar-link-text);
|
|
||||||
padding: 1px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.version-list li:hover,
|
|
||||||
.version-list li a:focus {
|
|
||||||
background-color: var(--color-background-hover);
|
|
||||||
}
|
|
||||||
|
|
||||||
.version-list li.selected {
|
|
||||||
background: var(--color-sidebar-item-background--current);
|
|
||||||
font-weight: 700;
|
|
||||||
}
|
|
||||||
@ -1,69 +0,0 @@
|
|||||||
/*
|
|
||||||
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;
|
|
||||||
}
|
|
||||||
@ -1,156 +0,0 @@
|
|||||||
/*
|
|
||||||
* doctools.js
|
|
||||||
* ~~~~~~~~~~~
|
|
||||||
*
|
|
||||||
* Base JavaScript utilities for all Sphinx HTML documentation.
|
|
||||||
*
|
|
||||||
* :copyright: Copyright 2007-2024 by the Sphinx team, see AUTHORS.
|
|
||||||
* :license: BSD, see LICENSE for details.
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
"use strict";
|
|
||||||
|
|
||||||
const BLACKLISTED_KEY_CONTROL_ELEMENTS = new Set([
|
|
||||||
"TEXTAREA",
|
|
||||||
"INPUT",
|
|
||||||
"SELECT",
|
|
||||||
"BUTTON",
|
|
||||||
]);
|
|
||||||
|
|
||||||
const _ready = (callback) => {
|
|
||||||
if (document.readyState !== "loading") {
|
|
||||||
callback();
|
|
||||||
} else {
|
|
||||||
document.addEventListener("DOMContentLoaded", callback);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Small JavaScript module for the documentation.
|
|
||||||
*/
|
|
||||||
const Documentation = {
|
|
||||||
init: () => {
|
|
||||||
Documentation.initDomainIndexTable();
|
|
||||||
Documentation.initOnKeyListeners();
|
|
||||||
},
|
|
||||||
|
|
||||||
/**
|
|
||||||
* i18n support
|
|
||||||
*/
|
|
||||||
TRANSLATIONS: {},
|
|
||||||
PLURAL_EXPR: (n) => (n === 1 ? 0 : 1),
|
|
||||||
LOCALE: "unknown",
|
|
||||||
|
|
||||||
// gettext and ngettext don't access this so that the functions
|
|
||||||
// can safely bound to a different name (_ = Documentation.gettext)
|
|
||||||
gettext: (string) => {
|
|
||||||
const translated = Documentation.TRANSLATIONS[string];
|
|
||||||
switch (typeof translated) {
|
|
||||||
case "undefined":
|
|
||||||
return string; // no translation
|
|
||||||
case "string":
|
|
||||||
return translated; // translation exists
|
|
||||||
default:
|
|
||||||
return translated[0]; // (singular, plural) translation tuple exists
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
ngettext: (singular, plural, n) => {
|
|
||||||
const translated = Documentation.TRANSLATIONS[singular];
|
|
||||||
if (typeof translated !== "undefined")
|
|
||||||
return translated[Documentation.PLURAL_EXPR(n)];
|
|
||||||
return n === 1 ? singular : plural;
|
|
||||||
},
|
|
||||||
|
|
||||||
addTranslations: (catalog) => {
|
|
||||||
Object.assign(Documentation.TRANSLATIONS, catalog.messages);
|
|
||||||
Documentation.PLURAL_EXPR = new Function(
|
|
||||||
"n",
|
|
||||||
`return (${catalog.plural_expr})`
|
|
||||||
);
|
|
||||||
Documentation.LOCALE = catalog.locale;
|
|
||||||
},
|
|
||||||
|
|
||||||
/**
|
|
||||||
* helper function to focus on search bar
|
|
||||||
*/
|
|
||||||
focusSearchBar: () => {
|
|
||||||
document.querySelectorAll("input[name=q]")[0]?.focus();
|
|
||||||
},
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Initialise the domain index toggle buttons
|
|
||||||
*/
|
|
||||||
initDomainIndexTable: () => {
|
|
||||||
const toggler = (el) => {
|
|
||||||
const idNumber = el.id.substr(7);
|
|
||||||
const toggledRows = document.querySelectorAll(`tr.cg-${idNumber}`);
|
|
||||||
if (el.src.substr(-9) === "minus.png") {
|
|
||||||
el.src = `${el.src.substr(0, el.src.length - 9)}plus.png`;
|
|
||||||
toggledRows.forEach((el) => (el.style.display = "none"));
|
|
||||||
} else {
|
|
||||||
el.src = `${el.src.substr(0, el.src.length - 8)}minus.png`;
|
|
||||||
toggledRows.forEach((el) => (el.style.display = ""));
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
const togglerElements = document.querySelectorAll("img.toggler");
|
|
||||||
togglerElements.forEach((el) =>
|
|
||||||
el.addEventListener("click", (event) => toggler(event.currentTarget))
|
|
||||||
);
|
|
||||||
togglerElements.forEach((el) => (el.style.display = ""));
|
|
||||||
if (DOCUMENTATION_OPTIONS.COLLAPSE_INDEX) togglerElements.forEach(toggler);
|
|
||||||
},
|
|
||||||
|
|
||||||
initOnKeyListeners: () => {
|
|
||||||
// only install a listener if it is really needed
|
|
||||||
if (
|
|
||||||
!DOCUMENTATION_OPTIONS.NAVIGATION_WITH_KEYS &&
|
|
||||||
!DOCUMENTATION_OPTIONS.ENABLE_SEARCH_SHORTCUTS
|
|
||||||
)
|
|
||||||
return;
|
|
||||||
|
|
||||||
document.addEventListener("keydown", (event) => {
|
|
||||||
// bail for input elements
|
|
||||||
if (BLACKLISTED_KEY_CONTROL_ELEMENTS.has(document.activeElement.tagName)) return;
|
|
||||||
// bail with special keys
|
|
||||||
if (event.altKey || event.ctrlKey || event.metaKey) return;
|
|
||||||
|
|
||||||
if (!event.shiftKey) {
|
|
||||||
switch (event.key) {
|
|
||||||
case "ArrowLeft":
|
|
||||||
if (!DOCUMENTATION_OPTIONS.NAVIGATION_WITH_KEYS) break;
|
|
||||||
|
|
||||||
const prevLink = document.querySelector('link[rel="prev"]');
|
|
||||||
if (prevLink && prevLink.href) {
|
|
||||||
window.location.href = prevLink.href;
|
|
||||||
event.preventDefault();
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case "ArrowRight":
|
|
||||||
if (!DOCUMENTATION_OPTIONS.NAVIGATION_WITH_KEYS) break;
|
|
||||||
|
|
||||||
const nextLink = document.querySelector('link[rel="next"]');
|
|
||||||
if (nextLink && nextLink.href) {
|
|
||||||
window.location.href = nextLink.href;
|
|
||||||
event.preventDefault();
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// some keyboard layouts may need Shift to get /
|
|
||||||
switch (event.key) {
|
|
||||||
case "/":
|
|
||||||
if (!DOCUMENTATION_OPTIONS.ENABLE_SEARCH_SHORTCUTS) break;
|
|
||||||
Documentation.focusSearchBar();
|
|
||||||
event.preventDefault();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
// quick alias for translations
|
|
||||||
const _ = Documentation.gettext;
|
|
||||||
|
|
||||||
_ready(Documentation.init);
|
|
||||||
@ -1,13 +0,0 @@
|
|||||||
const DOCUMENTATION_OPTIONS = {
|
|
||||||
VERSION: '4.5',
|
|
||||||
LANGUAGE: 'en',
|
|
||||||
COLLAPSE_INDEX: false,
|
|
||||||
BUILDER: 'html',
|
|
||||||
FILE_SUFFIX: '.html',
|
|
||||||
LINK_SUFFIX: '.html',
|
|
||||||
HAS_SOURCE: false,
|
|
||||||
SOURCELINK_SUFFIX: '.txt',
|
|
||||||
NAVIGATION_WITH_KEYS: false,
|
|
||||||
SHOW_SEARCH_SUMMARY: true,
|
|
||||||
ENABLE_SEARCH_SHORTCUTS: true,
|
|
||||||
};
|
|
||||||
|
Before Width: | Height: | Size: 10 KiB |
|
Before Width: | Height: | Size: 286 B |
@ -1,764 +0,0 @@
|
|||||||
@font-face {
|
|
||||||
font-family: "bl-icons";
|
|
||||||
src: url('bl-icons.eot?t=1744579905951'); /* IE9*/
|
|
||||||
src: url('bl-icons.eot?t=1744579905951#iefix') format('embedded-opentype') /* IE6-IE8 */,
|
|
||||||
url('bl-icons.woff2?t=1744579905951') format('woff2'),
|
|
||||||
url('bl-icons.woff?t=1744579905951') format('woff'),
|
|
||||||
url('bl-icons.ttf?t=1744579905951') format('truetype'),
|
|
||||||
url('bl-icons.svg?t=1744579905951') format('svg');
|
|
||||||
}
|
|
||||||
|
|
||||||
[class^="bl-icons-"], [class*=" bl-icons-"] {
|
|
||||||
font-family: 'bl-icons' !important;
|
|
||||||
font-style:normal;
|
|
||||||
-webkit-font-smoothing: antialiased;
|
|
||||||
-moz-osx-font-smoothing: grayscale;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
.bl-icons-action::before { content: "\ea01"; }
|
|
||||||
.bl-icons-action_slot::before { content: "\ea02"; }
|
|
||||||
.bl-icons-action_tweak::before { content: "\ea03"; }
|
|
||||||
.bl-icons-add::before { content: "\ea04"; }
|
|
||||||
.bl-icons-aliased::before { content: "\ea05"; }
|
|
||||||
.bl-icons-align_bottom::before { content: "\ea06"; }
|
|
||||||
.bl-icons-align_center::before { content: "\ea07"; }
|
|
||||||
.bl-icons-align_flush::before { content: "\ea08"; }
|
|
||||||
.bl-icons-align_justify::before { content: "\ea09"; }
|
|
||||||
.bl-icons-align_left::before { content: "\ea0a"; }
|
|
||||||
.bl-icons-align_middle::before { content: "\ea0b"; }
|
|
||||||
.bl-icons-align_right::before { content: "\ea0c"; }
|
|
||||||
.bl-icons-align_top::before { content: "\ea0d"; }
|
|
||||||
.bl-icons-anchor_bottom::before { content: "\ea0e"; }
|
|
||||||
.bl-icons-anchor_center::before { content: "\ea0f"; }
|
|
||||||
.bl-icons-anchor_left::before { content: "\ea10"; }
|
|
||||||
.bl-icons-anchor_right::before { content: "\ea11"; }
|
|
||||||
.bl-icons-anchor_top::before { content: "\ea12"; }
|
|
||||||
.bl-icons-anim::before { content: "\ea13"; }
|
|
||||||
.bl-icons-anim_data::before { content: "\ea14"; }
|
|
||||||
.bl-icons-antialiased::before { content: "\ea15"; }
|
|
||||||
.bl-icons-append_blend::before { content: "\ea16"; }
|
|
||||||
.bl-icons-area_dock::before { content: "\ea17"; }
|
|
||||||
.bl-icons-area_join::before { content: "\ea18"; }
|
|
||||||
.bl-icons-area_join_down::before { content: "\ea19"; }
|
|
||||||
.bl-icons-area_join_left::before { content: "\ea1a"; }
|
|
||||||
.bl-icons-area_join_up::before { content: "\ea1b"; }
|
|
||||||
.bl-icons-area_swap::before { content: "\ea1c"; }
|
|
||||||
.bl-icons-armature_data::before { content: "\ea1d"; }
|
|
||||||
.bl-icons-arrow_leftright::before { content: "\ea1e"; }
|
|
||||||
.bl-icons-asset_manager::before { content: "\ea1f"; }
|
|
||||||
.bl-icons-auto::before { content: "\ea20"; }
|
|
||||||
.bl-icons-automerge_off::before { content: "\ea21"; }
|
|
||||||
.bl-icons-automerge_on::before { content: "\ea22"; }
|
|
||||||
.bl-icons-axis_front::before { content: "\ea23"; }
|
|
||||||
.bl-icons-axis_side::before { content: "\ea24"; }
|
|
||||||
.bl-icons-axis_top::before { content: "\ea25"; }
|
|
||||||
.bl-icons-back::before { content: "\ea26"; }
|
|
||||||
.bl-icons-blank1::before { content: "\ea27"; }
|
|
||||||
.bl-icons-blender::before { content: "\ea28"; }
|
|
||||||
.bl-icons-blender_logo_large::before { content: "\ea29"; }
|
|
||||||
.bl-icons-boids::before { content: "\ea2a"; }
|
|
||||||
.bl-icons-bold::before { content: "\ea2b"; }
|
|
||||||
.bl-icons-bone_data::before { content: "\ea2c"; }
|
|
||||||
.bl-icons-bookmarks::before { content: "\ea2d"; }
|
|
||||||
.bl-icons-bordermove::before { content: "\ea2e"; }
|
|
||||||
.bl-icons-brush_data::before { content: "\ea2f"; }
|
|
||||||
.bl-icons-brushes_all::before { content: "\ea30"; }
|
|
||||||
.bl-icons-camera_data::before { content: "\ea31"; }
|
|
||||||
.bl-icons-camera_stereo::before { content: "\ea32"; }
|
|
||||||
.bl-icons-cancel::before { content: "\ea33"; }
|
|
||||||
.bl-icons-cancel_large::before { content: "\ea34"; }
|
|
||||||
.bl-icons-center_only::before { content: "\ea35"; }
|
|
||||||
.bl-icons-char_notdef::before { content: "\ea36"; }
|
|
||||||
.bl-icons-char_replacement::before { content: "\ea37"; }
|
|
||||||
.bl-icons-checkbox_dehlt::before { content: "\ea38"; }
|
|
||||||
.bl-icons-checkbox_hlt::before { content: "\ea39"; }
|
|
||||||
.bl-icons-checkmark::before { content: "\ea3a"; }
|
|
||||||
.bl-icons-clipuv_dehlt::before { content: "\ea3b"; }
|
|
||||||
.bl-icons-clipuv_hlt::before { content: "\ea3c"; }
|
|
||||||
.bl-icons-collapsemenu::before { content: "\ea3d"; }
|
|
||||||
.bl-icons-collection_new::before { content: "\ea3e"; }
|
|
||||||
.bl-icons-color::before { content: "\ea3f"; }
|
|
||||||
.bl-icons-color_blue::before { content: "\ea40"; }
|
|
||||||
.bl-icons-color_green::before { content: "\ea41"; }
|
|
||||||
.bl-icons-color_red::before { content: "\ea42"; }
|
|
||||||
.bl-icons-community::before { content: "\ea43"; }
|
|
||||||
.bl-icons-con_action::before { content: "\ea44"; }
|
|
||||||
.bl-icons-con_armature::before { content: "\ea45"; }
|
|
||||||
.bl-icons-con_camerasolver::before { content: "\ea46"; }
|
|
||||||
.bl-icons-con_childof::before { content: "\ea47"; }
|
|
||||||
.bl-icons-con_clampto::before { content: "\ea48"; }
|
|
||||||
.bl-icons-con_distlimit::before { content: "\ea49"; }
|
|
||||||
.bl-icons-con_floor::before { content: "\ea4a"; }
|
|
||||||
.bl-icons-con_followpath::before { content: "\ea4b"; }
|
|
||||||
.bl-icons-con_followtrack::before { content: "\ea4c"; }
|
|
||||||
.bl-icons-con_kinematic::before { content: "\ea4d"; }
|
|
||||||
.bl-icons-con_locktrack::before { content: "\ea4e"; }
|
|
||||||
.bl-icons-con_loclike::before { content: "\ea4f"; }
|
|
||||||
.bl-icons-con_loclimit::before { content: "\ea50"; }
|
|
||||||
.bl-icons-con_objectsolver::before { content: "\ea51"; }
|
|
||||||
.bl-icons-con_pivot::before { content: "\ea52"; }
|
|
||||||
.bl-icons-con_rotlike::before { content: "\ea53"; }
|
|
||||||
.bl-icons-con_rotlimit::before { content: "\ea54"; }
|
|
||||||
.bl-icons-con_samevol::before { content: "\ea55"; }
|
|
||||||
.bl-icons-con_shrinkwrap::before { content: "\ea56"; }
|
|
||||||
.bl-icons-con_sizelike::before { content: "\ea57"; }
|
|
||||||
.bl-icons-con_sizelimit::before { content: "\ea58"; }
|
|
||||||
.bl-icons-con_splineik::before { content: "\ea59"; }
|
|
||||||
.bl-icons-con_stretchto::before { content: "\ea5a"; }
|
|
||||||
.bl-icons-con_trackto::before { content: "\ea5b"; }
|
|
||||||
.bl-icons-con_transform::before { content: "\ea5c"; }
|
|
||||||
.bl-icons-con_transform_cache::before { content: "\ea5d"; }
|
|
||||||
.bl-icons-con_translike::before { content: "\ea5e"; }
|
|
||||||
.bl-icons-cone::before { content: "\ea5f"; }
|
|
||||||
.bl-icons-console::before { content: "\ea60"; }
|
|
||||||
.bl-icons-constraint::before { content: "\ea61"; }
|
|
||||||
.bl-icons-constraint_bone::before { content: "\ea62"; }
|
|
||||||
.bl-icons-copy_id::before { content: "\ea63"; }
|
|
||||||
.bl-icons-copydown::before { content: "\ea64"; }
|
|
||||||
.bl-icons-cube::before { content: "\ea65"; }
|
|
||||||
.bl-icons-current_file::before { content: "\ea66"; }
|
|
||||||
.bl-icons-cursor::before { content: "\ea67"; }
|
|
||||||
.bl-icons-curve_bezcircle::before { content: "\ea68"; }
|
|
||||||
.bl-icons-curve_bezcurve::before { content: "\ea69"; }
|
|
||||||
.bl-icons-curve_data::before { content: "\ea6a"; }
|
|
||||||
.bl-icons-curve_ncircle::before { content: "\ea6b"; }
|
|
||||||
.bl-icons-curve_ncurve::before { content: "\ea6c"; }
|
|
||||||
.bl-icons-curve_path::before { content: "\ea6d"; }
|
|
||||||
.bl-icons-curves::before { content: "\ea6e"; }
|
|
||||||
.bl-icons-curves_data::before { content: "\ea6f"; }
|
|
||||||
.bl-icons-decorate::before { content: "\ea70"; }
|
|
||||||
.bl-icons-decorate_animate::before { content: "\ea71"; }
|
|
||||||
.bl-icons-decorate_driver::before { content: "\ea72"; }
|
|
||||||
.bl-icons-decorate_keyframe::before { content: "\ea73"; }
|
|
||||||
.bl-icons-decorate_library_override::before { content: "\ea74"; }
|
|
||||||
.bl-icons-decorate_linked::before { content: "\ea75"; }
|
|
||||||
.bl-icons-decorate_locked::before { content: "\ea76"; }
|
|
||||||
.bl-icons-decorate_override::before { content: "\ea77"; }
|
|
||||||
.bl-icons-decorate_unlocked::before { content: "\ea78"; }
|
|
||||||
.bl-icons-desktop::before { content: "\ea79"; }
|
|
||||||
.bl-icons-disc::before { content: "\ea7a"; }
|
|
||||||
.bl-icons-disc_large::before { content: "\ea7b"; }
|
|
||||||
.bl-icons-disclosure_tri_down::before { content: "\ea7c"; }
|
|
||||||
.bl-icons-disclosure_tri_right::before { content: "\ea7d"; }
|
|
||||||
.bl-icons-disk_drive::before { content: "\ea7e"; }
|
|
||||||
.bl-icons-disk_drive_large::before { content: "\ea7f"; }
|
|
||||||
.bl-icons-documents::before { content: "\ea80"; }
|
|
||||||
.bl-icons-dot::before { content: "\ea81"; }
|
|
||||||
.bl-icons-downarrow_hlt::before { content: "\ea82"; }
|
|
||||||
.bl-icons-driver::before { content: "\ea83"; }
|
|
||||||
.bl-icons-driver_distance::before { content: "\ea84"; }
|
|
||||||
.bl-icons-driver_rotational_difference::before { content: "\ea85"; }
|
|
||||||
.bl-icons-driver_transform::before { content: "\ea86"; }
|
|
||||||
.bl-icons-duplicate::before { content: "\ea87"; }
|
|
||||||
.bl-icons-edgesel::before { content: "\ea88"; }
|
|
||||||
.bl-icons-editmode_hlt::before { content: "\ea89"; }
|
|
||||||
.bl-icons-empty_arrows::before { content: "\ea8a"; }
|
|
||||||
.bl-icons-empty_axis::before { content: "\ea8b"; }
|
|
||||||
.bl-icons-empty_data::before { content: "\ea8c"; }
|
|
||||||
.bl-icons-empty_single_arrow::before { content: "\ea8d"; }
|
|
||||||
.bl-icons-error::before { content: "\ea8e"; }
|
|
||||||
.bl-icons-experimental::before { content: "\ea8f"; }
|
|
||||||
.bl-icons-export::before { content: "\ea90"; }
|
|
||||||
.bl-icons-external_drive::before { content: "\ea91"; }
|
|
||||||
.bl-icons-external_drive_large::before { content: "\ea92"; }
|
|
||||||
.bl-icons-eyedropper::before { content: "\ea93"; }
|
|
||||||
.bl-icons-face_corner::before { content: "\ea94"; }
|
|
||||||
.bl-icons-face_maps::before { content: "\ea95"; }
|
|
||||||
.bl-icons-facesel::before { content: "\ea96"; }
|
|
||||||
.bl-icons-fake_user_off::before { content: "\ea97"; }
|
|
||||||
.bl-icons-fake_user_on::before { content: "\ea98"; }
|
|
||||||
.bl-icons-fcurve::before { content: "\ea99"; }
|
|
||||||
.bl-icons-fcurve_snapshot::before { content: "\ea9a"; }
|
|
||||||
.bl-icons-ff::before { content: "\ea9b"; }
|
|
||||||
.bl-icons-file::before { content: "\ea9c"; }
|
|
||||||
.bl-icons-file_3d::before { content: "\ea9d"; }
|
|
||||||
.bl-icons-file_alias::before { content: "\ea9e"; }
|
|
||||||
.bl-icons-file_archive::before { content: "\ea9f"; }
|
|
||||||
.bl-icons-file_backup::before { content: "\eaa0"; }
|
|
||||||
.bl-icons-file_blank::before { content: "\eaa1"; }
|
|
||||||
.bl-icons-file_blend::before { content: "\eaa2"; }
|
|
||||||
.bl-icons-file_cache::before { content: "\eaa3"; }
|
|
||||||
.bl-icons-file_folder::before { content: "\eaa4"; }
|
|
||||||
.bl-icons-file_folder_large::before { content: "\eaa5"; }
|
|
||||||
.bl-icons-file_font::before { content: "\eaa6"; }
|
|
||||||
.bl-icons-file_hidden::before { content: "\eaa7"; }
|
|
||||||
.bl-icons-file_image::before { content: "\eaa8"; }
|
|
||||||
.bl-icons-file_large::before { content: "\eaa9"; }
|
|
||||||
.bl-icons-file_movie::before { content: "\eaaa"; }
|
|
||||||
.bl-icons-file_new::before { content: "\eaab"; }
|
|
||||||
.bl-icons-file_parent::before { content: "\eaac"; }
|
|
||||||
.bl-icons-file_parent_large::before { content: "\eaad"; }
|
|
||||||
.bl-icons-file_refresh::before { content: "\eaae"; }
|
|
||||||
.bl-icons-file_script::before { content: "\eaaf"; }
|
|
||||||
.bl-icons-file_sound::before { content: "\eab0"; }
|
|
||||||
.bl-icons-file_text::before { content: "\eab1"; }
|
|
||||||
.bl-icons-file_tick::before { content: "\eab2"; }
|
|
||||||
.bl-icons-file_volume::before { content: "\eab3"; }
|
|
||||||
.bl-icons-filebrowser::before { content: "\eab4"; }
|
|
||||||
.bl-icons-filter::before { content: "\eab5"; }
|
|
||||||
.bl-icons-fixed_size::before { content: "\eab6"; }
|
|
||||||
.bl-icons-folder_redirect::before { content: "\eab7"; }
|
|
||||||
.bl-icons-font_data::before { content: "\eab8"; }
|
|
||||||
.bl-icons-fontpreview::before { content: "\eab9"; }
|
|
||||||
.bl-icons-force_boid::before { content: "\eaba"; }
|
|
||||||
.bl-icons-force_charge::before { content: "\eabb"; }
|
|
||||||
.bl-icons-force_curve::before { content: "\eabc"; }
|
|
||||||
.bl-icons-force_drag::before { content: "\eabd"; }
|
|
||||||
.bl-icons-force_fluidflow::before { content: "\eabe"; }
|
|
||||||
.bl-icons-force_force::before { content: "\eabf"; }
|
|
||||||
.bl-icons-force_harmonic::before { content: "\eac0"; }
|
|
||||||
.bl-icons-force_lennardjones::before { content: "\eac1"; }
|
|
||||||
.bl-icons-force_magnetic::before { content: "\eac2"; }
|
|
||||||
.bl-icons-force_texture::before { content: "\eac3"; }
|
|
||||||
.bl-icons-force_turbulence::before { content: "\eac4"; }
|
|
||||||
.bl-icons-force_vortex::before { content: "\eac5"; }
|
|
||||||
.bl-icons-force_wind::before { content: "\eac6"; }
|
|
||||||
.bl-icons-forward::before { content: "\eac7"; }
|
|
||||||
.bl-icons-frame_next::before { content: "\eac8"; }
|
|
||||||
.bl-icons-frame_prev::before { content: "\eac9"; }
|
|
||||||
.bl-icons-freeze::before { content: "\eaca"; }
|
|
||||||
.bl-icons-fullscreen_enter::before { content: "\eacb"; }
|
|
||||||
.bl-icons-fullscreen_exit::before { content: "\eacc"; }
|
|
||||||
.bl-icons-fund::before { content: "\eacd"; }
|
|
||||||
.bl-icons-geometry_nodes::before { content: "\eace"; }
|
|
||||||
.bl-icons-geometry_set::before { content: "\eacf"; }
|
|
||||||
.bl-icons-ghost_disabled::before { content: "\ead0"; }
|
|
||||||
.bl-icons-ghost_enabled::before { content: "\ead1"; }
|
|
||||||
.bl-icons-gizmo::before { content: "\ead2"; }
|
|
||||||
.bl-icons-gp_caps_flat::before { content: "\ead3"; }
|
|
||||||
.bl-icons-gp_caps_round::before { content: "\ead4"; }
|
|
||||||
.bl-icons-gp_multiframe_editing::before { content: "\ead5"; }
|
|
||||||
.bl-icons-gp_only_selected::before { content: "\ead6"; }
|
|
||||||
.bl-icons-gp_select_between_strokes::before { content: "\ead7"; }
|
|
||||||
.bl-icons-gp_select_points::before { content: "\ead8"; }
|
|
||||||
.bl-icons-gp_select_strokes::before { content: "\ead9"; }
|
|
||||||
.bl-icons-graph::before { content: "\eada"; }
|
|
||||||
.bl-icons-greasepencil::before { content: "\eadb"; }
|
|
||||||
.bl-icons-greasepencil_layer_group::before { content: "\eadc"; }
|
|
||||||
.bl-icons-grid::before { content: "\eadd"; }
|
|
||||||
.bl-icons-grip::before { content: "\eade"; }
|
|
||||||
.bl-icons-grip_v::before { content: "\eadf"; }
|
|
||||||
.bl-icons-group::before { content: "\eae0"; }
|
|
||||||
.bl-icons-group_bone::before { content: "\eae1"; }
|
|
||||||
.bl-icons-group_uvs::before { content: "\eae2"; }
|
|
||||||
.bl-icons-group_vcol::before { content: "\eae3"; }
|
|
||||||
.bl-icons-group_vertex::before { content: "\eae4"; }
|
|
||||||
.bl-icons-hand::before { content: "\eae5"; }
|
|
||||||
.bl-icons-handle_aligned::before { content: "\eae6"; }
|
|
||||||
.bl-icons-handle_auto::before { content: "\eae7"; }
|
|
||||||
.bl-icons-handle_autoclamped::before { content: "\eae8"; }
|
|
||||||
.bl-icons-handle_free::before { content: "\eae9"; }
|
|
||||||
.bl-icons-handle_vector::before { content: "\eaea"; }
|
|
||||||
.bl-icons-heart::before { content: "\eaeb"; }
|
|
||||||
.bl-icons-help::before { content: "\eaec"; }
|
|
||||||
.bl-icons-hide_off::before { content: "\eaed"; }
|
|
||||||
.bl-icons-hide_on::before { content: "\eaee"; }
|
|
||||||
.bl-icons-holdout_off::before { content: "\eaef"; }
|
|
||||||
.bl-icons-holdout_on::before { content: "\eaf0"; }
|
|
||||||
.bl-icons-home::before { content: "\eaf1"; }
|
|
||||||
.bl-icons-hook::before { content: "\eaf2"; }
|
|
||||||
.bl-icons-image::before { content: "\eaf3"; }
|
|
||||||
.bl-icons-image_alpha::before { content: "\eaf4"; }
|
|
||||||
.bl-icons-image_background::before { content: "\eaf5"; }
|
|
||||||
.bl-icons-image_data::before { content: "\eaf6"; }
|
|
||||||
.bl-icons-image_plane::before { content: "\eaf7"; }
|
|
||||||
.bl-icons-image_reference::before { content: "\eaf8"; }
|
|
||||||
.bl-icons-image_rgb::before { content: "\eaf9"; }
|
|
||||||
.bl-icons-image_rgb_alpha::before { content: "\eafa"; }
|
|
||||||
.bl-icons-image_zdepth::before { content: "\eafb"; }
|
|
||||||
.bl-icons-imgdisplay::before { content: "\eafc"; }
|
|
||||||
.bl-icons-import::before { content: "\eafd"; }
|
|
||||||
.bl-icons-indirect_only_off::before { content: "\eafe"; }
|
|
||||||
.bl-icons-indirect_only_on::before { content: "\eaff"; }
|
|
||||||
.bl-icons-info::before { content: "\eb00"; }
|
|
||||||
.bl-icons-info_large::before { content: "\eb01"; }
|
|
||||||
.bl-icons-internet::before { content: "\eb02"; }
|
|
||||||
.bl-icons-internet_offline::before { content: "\eb03"; }
|
|
||||||
.bl-icons-inversesquarecurve::before { content: "\eb04"; }
|
|
||||||
.bl-icons-ipo_back::before { content: "\eb05"; }
|
|
||||||
.bl-icons-ipo_bezier::before { content: "\eb06"; }
|
|
||||||
.bl-icons-ipo_bounce::before { content: "\eb07"; }
|
|
||||||
.bl-icons-ipo_circ::before { content: "\eb08"; }
|
|
||||||
.bl-icons-ipo_constant::before { content: "\eb09"; }
|
|
||||||
.bl-icons-ipo_cubic::before { content: "\eb0a"; }
|
|
||||||
.bl-icons-ipo_ease_in::before { content: "\eb0b"; }
|
|
||||||
.bl-icons-ipo_ease_in_out::before { content: "\eb0c"; }
|
|
||||||
.bl-icons-ipo_ease_out::before { content: "\eb0d"; }
|
|
||||||
.bl-icons-ipo_elastic::before { content: "\eb0e"; }
|
|
||||||
.bl-icons-ipo_expo::before { content: "\eb0f"; }
|
|
||||||
.bl-icons-ipo_linear::before { content: "\eb10"; }
|
|
||||||
.bl-icons-ipo_quad::before { content: "\eb11"; }
|
|
||||||
.bl-icons-ipo_quart::before { content: "\eb12"; }
|
|
||||||
.bl-icons-ipo_quint::before { content: "\eb13"; }
|
|
||||||
.bl-icons-ipo_sine::before { content: "\eb14"; }
|
|
||||||
.bl-icons-italic::before { content: "\eb15"; }
|
|
||||||
.bl-icons-key_backspace::before { content: "\eb16"; }
|
|
||||||
.bl-icons-key_backspace_filled::before { content: "\eb17"; }
|
|
||||||
.bl-icons-key_command::before { content: "\eb18"; }
|
|
||||||
.bl-icons-key_command_filled::before { content: "\eb19"; }
|
|
||||||
.bl-icons-key_control::before { content: "\eb1a"; }
|
|
||||||
.bl-icons-key_control_filled::before { content: "\eb1b"; }
|
|
||||||
.bl-icons-key_dehlt::before { content: "\eb1c"; }
|
|
||||||
.bl-icons-key_empty1::before { content: "\eb1d"; }
|
|
||||||
.bl-icons-key_empty1_filled::before { content: "\eb1e"; }
|
|
||||||
.bl-icons-key_empty2::before { content: "\eb1f"; }
|
|
||||||
.bl-icons-key_empty2_filled::before { content: "\eb20"; }
|
|
||||||
.bl-icons-key_empty3::before { content: "\eb21"; }
|
|
||||||
.bl-icons-key_empty3_filled::before { content: "\eb22"; }
|
|
||||||
.bl-icons-key_hlt::before { content: "\eb23"; }
|
|
||||||
.bl-icons-key_menu::before { content: "\eb24"; }
|
|
||||||
.bl-icons-key_menu_filled::before { content: "\eb25"; }
|
|
||||||
.bl-icons-key_option_filled::before { content: "\eb26"; }
|
|
||||||
.bl-icons-key_return::before { content: "\eb27"; }
|
|
||||||
.bl-icons-key_return_filled::before { content: "\eb28"; }
|
|
||||||
.bl-icons-key_ring::before { content: "\eb29"; }
|
|
||||||
.bl-icons-key_ring_filled::before { content: "\eb2a"; }
|
|
||||||
.bl-icons-key_shift::before { content: "\eb2b"; }
|
|
||||||
.bl-icons-key_shift_filled::before { content: "\eb2c"; }
|
|
||||||
.bl-icons-key_tab::before { content: "\eb2d"; }
|
|
||||||
.bl-icons-key_tab_filled::before { content: "\eb2e"; }
|
|
||||||
.bl-icons-key_windows_filled::before { content: "\eb2f"; }
|
|
||||||
.bl-icons-keyframe::before { content: "\eb30"; }
|
|
||||||
.bl-icons-keyframe_hlt::before { content: "\eb31"; }
|
|
||||||
.bl-icons-keyingset::before { content: "\eb32"; }
|
|
||||||
.bl-icons-lattice_data::before { content: "\eb33"; }
|
|
||||||
.bl-icons-layer_active::before { content: "\eb34"; }
|
|
||||||
.bl-icons-layer_used::before { content: "\eb35"; }
|
|
||||||
.bl-icons-library_data_broken::before { content: "\eb36"; }
|
|
||||||
.bl-icons-library_data_direct::before { content: "\eb37"; }
|
|
||||||
.bl-icons-library_data_override::before { content: "\eb38"; }
|
|
||||||
.bl-icons-light::before { content: "\eb39"; }
|
|
||||||
.bl-icons-light_area::before { content: "\eb3a"; }
|
|
||||||
.bl-icons-light_data::before { content: "\eb3b"; }
|
|
||||||
.bl-icons-light_hemi::before { content: "\eb3c"; }
|
|
||||||
.bl-icons-light_point::before { content: "\eb3d"; }
|
|
||||||
.bl-icons-light_spot::before { content: "\eb3e"; }
|
|
||||||
.bl-icons-light_sun::before { content: "\eb3f"; }
|
|
||||||
.bl-icons-lightprobe_plane::before { content: "\eb40"; }
|
|
||||||
.bl-icons-lightprobe_sphere::before { content: "\eb41"; }
|
|
||||||
.bl-icons-lightprobe_volume::before { content: "\eb42"; }
|
|
||||||
.bl-icons-lincurve::before { content: "\eb43"; }
|
|
||||||
.bl-icons-line_data::before { content: "\eb44"; }
|
|
||||||
.bl-icons-linenumbers_off::before { content: "\eb45"; }
|
|
||||||
.bl-icons-linenumbers_on::before { content: "\eb46"; }
|
|
||||||
.bl-icons-link_blend::before { content: "\eb47"; }
|
|
||||||
.bl-icons-linked::before { content: "\eb48"; }
|
|
||||||
.bl-icons-locked::before { content: "\eb49"; }
|
|
||||||
.bl-icons-lockview_off::before { content: "\eb4a"; }
|
|
||||||
.bl-icons-lockview_on::before { content: "\eb4b"; }
|
|
||||||
.bl-icons-longdisplay::before { content: "\eb4c"; }
|
|
||||||
.bl-icons-loop_back::before { content: "\eb4d"; }
|
|
||||||
.bl-icons-loop_forwards::before { content: "\eb4e"; }
|
|
||||||
.bl-icons-marker::before { content: "\eb4f"; }
|
|
||||||
.bl-icons-marker_hlt::before { content: "\eb50"; }
|
|
||||||
.bl-icons-mat_sphere_sky::before { content: "\eb51"; }
|
|
||||||
.bl-icons-matcloth::before { content: "\eb52"; }
|
|
||||||
.bl-icons-matcube::before { content: "\eb53"; }
|
|
||||||
.bl-icons-material::before { content: "\eb54"; }
|
|
||||||
.bl-icons-material_data::before { content: "\eb55"; }
|
|
||||||
.bl-icons-matfluid::before { content: "\eb56"; }
|
|
||||||
.bl-icons-matplane::before { content: "\eb57"; }
|
|
||||||
.bl-icons-matshaderball::before { content: "\eb58"; }
|
|
||||||
.bl-icons-matsphere::before { content: "\eb59"; }
|
|
||||||
.bl-icons-memory::before { content: "\eb5a"; }
|
|
||||||
.bl-icons-menu_panel::before { content: "\eb5b"; }
|
|
||||||
.bl-icons-mesh_capsule::before { content: "\eb5c"; }
|
|
||||||
.bl-icons-mesh_circle::before { content: "\eb5d"; }
|
|
||||||
.bl-icons-mesh_cone::before { content: "\eb5e"; }
|
|
||||||
.bl-icons-mesh_cube::before { content: "\eb5f"; }
|
|
||||||
.bl-icons-mesh_cylinder::before { content: "\eb60"; }
|
|
||||||
.bl-icons-mesh_data::before { content: "\eb61"; }
|
|
||||||
.bl-icons-mesh_grid::before { content: "\eb62"; }
|
|
||||||
.bl-icons-mesh_icosphere::before { content: "\eb63"; }
|
|
||||||
.bl-icons-mesh_monkey::before { content: "\eb64"; }
|
|
||||||
.bl-icons-mesh_plane::before { content: "\eb65"; }
|
|
||||||
.bl-icons-mesh_torus::before { content: "\eb66"; }
|
|
||||||
.bl-icons-mesh_uvsphere::before { content: "\eb67"; }
|
|
||||||
.bl-icons-meta_ball::before { content: "\eb68"; }
|
|
||||||
.bl-icons-meta_capsule::before { content: "\eb69"; }
|
|
||||||
.bl-icons-meta_cube::before { content: "\eb6a"; }
|
|
||||||
.bl-icons-meta_data::before { content: "\eb6b"; }
|
|
||||||
.bl-icons-meta_ellipsoid::before { content: "\eb6c"; }
|
|
||||||
.bl-icons-meta_plane::before { content: "\eb6d"; }
|
|
||||||
.bl-icons-mod_armature::before { content: "\eb6e"; }
|
|
||||||
.bl-icons-mod_array::before { content: "\eb6f"; }
|
|
||||||
.bl-icons-mod_bevel::before { content: "\eb70"; }
|
|
||||||
.bl-icons-mod_boolean::before { content: "\eb71"; }
|
|
||||||
.bl-icons-mod_build::before { content: "\eb72"; }
|
|
||||||
.bl-icons-mod_cast::before { content: "\eb73"; }
|
|
||||||
.bl-icons-mod_cloth::before { content: "\eb74"; }
|
|
||||||
.bl-icons-mod_curve::before { content: "\eb75"; }
|
|
||||||
.bl-icons-mod_dash::before { content: "\eb76"; }
|
|
||||||
.bl-icons-mod_data_transfer::before { content: "\eb77"; }
|
|
||||||
.bl-icons-mod_decim::before { content: "\eb78"; }
|
|
||||||
.bl-icons-mod_displace::before { content: "\eb79"; }
|
|
||||||
.bl-icons-mod_dynamicpaint::before { content: "\eb7a"; }
|
|
||||||
.bl-icons-mod_edgesplit::before { content: "\eb7b"; }
|
|
||||||
.bl-icons-mod_envelope::before { content: "\eb7c"; }
|
|
||||||
.bl-icons-mod_explode::before { content: "\eb7d"; }
|
|
||||||
.bl-icons-mod_fluid::before { content: "\eb7e"; }
|
|
||||||
.bl-icons-mod_fluidsim::before { content: "\eb7f"; }
|
|
||||||
.bl-icons-mod_hue_saturation::before { content: "\eb80"; }
|
|
||||||
.bl-icons-mod_instance::before { content: "\eb81"; }
|
|
||||||
.bl-icons-mod_lattice::before { content: "\eb82"; }
|
|
||||||
.bl-icons-mod_length::before { content: "\eb83"; }
|
|
||||||
.bl-icons-mod_lineart::before { content: "\eb84"; }
|
|
||||||
.bl-icons-mod_mask::before { content: "\eb85"; }
|
|
||||||
.bl-icons-mod_meshdeform::before { content: "\eb86"; }
|
|
||||||
.bl-icons-mod_mirror::before { content: "\eb87"; }
|
|
||||||
.bl-icons-mod_multires::before { content: "\eb88"; }
|
|
||||||
.bl-icons-mod_noise::before { content: "\eb89"; }
|
|
||||||
.bl-icons-mod_normaledit::before { content: "\eb8a"; }
|
|
||||||
.bl-icons-mod_ocean::before { content: "\eb8b"; }
|
|
||||||
.bl-icons-mod_offset::before { content: "\eb8c"; }
|
|
||||||
.bl-icons-mod_opacity::before { content: "\eb8d"; }
|
|
||||||
.bl-icons-mod_outline::before { content: "\eb8e"; }
|
|
||||||
.bl-icons-mod_particle_instance::before { content: "\eb8f"; }
|
|
||||||
.bl-icons-mod_particles::before { content: "\eb90"; }
|
|
||||||
.bl-icons-mod_physics::before { content: "\eb91"; }
|
|
||||||
.bl-icons-mod_remesh::before { content: "\eb92"; }
|
|
||||||
.bl-icons-mod_screw::before { content: "\eb93"; }
|
|
||||||
.bl-icons-mod_shrinkwrap::before { content: "\eb94"; }
|
|
||||||
.bl-icons-mod_simpledeform::before { content: "\eb95"; }
|
|
||||||
.bl-icons-mod_simplify::before { content: "\eb96"; }
|
|
||||||
.bl-icons-mod_skin::before { content: "\eb97"; }
|
|
||||||
.bl-icons-mod_smooth::before { content: "\eb98"; }
|
|
||||||
.bl-icons-mod_soft::before { content: "\eb99"; }
|
|
||||||
.bl-icons-mod_solidify::before { content: "\eb9a"; }
|
|
||||||
.bl-icons-mod_subsurf::before { content: "\eb9b"; }
|
|
||||||
.bl-icons-mod_thickness::before { content: "\eb9c"; }
|
|
||||||
.bl-icons-mod_time::before { content: "\eb9d"; }
|
|
||||||
.bl-icons-mod_tint::before { content: "\eb9e"; }
|
|
||||||
.bl-icons-mod_triangulate::before { content: "\eb9f"; }
|
|
||||||
.bl-icons-mod_uvproject::before { content: "\eba0"; }
|
|
||||||
.bl-icons-mod_vertex_weight::before { content: "\eba1"; }
|
|
||||||
.bl-icons-mod_warp::before { content: "\eba2"; }
|
|
||||||
.bl-icons-mod_wave::before { content: "\eba3"; }
|
|
||||||
.bl-icons-mod_wireframe::before { content: "\eba4"; }
|
|
||||||
.bl-icons-modifier::before { content: "\eba5"; }
|
|
||||||
.bl-icons-modifier_data::before { content: "\eba6"; }
|
|
||||||
.bl-icons-modifier_off::before { content: "\eba7"; }
|
|
||||||
.bl-icons-modifier_on::before { content: "\eba8"; }
|
|
||||||
.bl-icons-monkey::before { content: "\eba9"; }
|
|
||||||
.bl-icons-mouse_lmb::before { content: "\ebaa"; }
|
|
||||||
.bl-icons-mouse_lmb_2x::before { content: "\ebab"; }
|
|
||||||
.bl-icons-mouse_lmb_drag::before { content: "\ebac"; }
|
|
||||||
.bl-icons-mouse_mmb::before { content: "\ebad"; }
|
|
||||||
.bl-icons-mouse_mmb_drag::before { content: "\ebae"; }
|
|
||||||
.bl-icons-mouse_mmb_scroll::before { content: "\ebaf"; }
|
|
||||||
.bl-icons-mouse_move::before { content: "\ebb0"; }
|
|
||||||
.bl-icons-mouse_rmb::before { content: "\ebb1"; }
|
|
||||||
.bl-icons-mouse_rmb_drag::before { content: "\ebb2"; }
|
|
||||||
.bl-icons-mute_ipo_off::before { content: "\ebb3"; }
|
|
||||||
.bl-icons-mute_ipo_on::before { content: "\ebb4"; }
|
|
||||||
.bl-icons-network_drive::before { content: "\ebb5"; }
|
|
||||||
.bl-icons-network_drive_large::before { content: "\ebb6"; }
|
|
||||||
.bl-icons-newfolder::before { content: "\ebb7"; }
|
|
||||||
.bl-icons-next_keyframe::before { content: "\ebb8"; }
|
|
||||||
.bl-icons-nla::before { content: "\ebb9"; }
|
|
||||||
.bl-icons-nla_pushdown::before { content: "\ebba"; }
|
|
||||||
.bl-icons-nocurve::before { content: "\ebbb"; }
|
|
||||||
.bl-icons-node::before { content: "\ebbc"; }
|
|
||||||
.bl-icons-node_compositing::before { content: "\ebbd"; }
|
|
||||||
.bl-icons-node_corner::before { content: "\ebbe"; }
|
|
||||||
.bl-icons-node_insert_off::before { content: "\ebbf"; }
|
|
||||||
.bl-icons-node_insert_on::before { content: "\ebc0"; }
|
|
||||||
.bl-icons-node_material::before { content: "\ebc1"; }
|
|
||||||
.bl-icons-node_sel::before { content: "\ebc2"; }
|
|
||||||
.bl-icons-node_side::before { content: "\ebc3"; }
|
|
||||||
.bl-icons-node_texture::before { content: "\ebc4"; }
|
|
||||||
.bl-icons-node_top::before { content: "\ebc5"; }
|
|
||||||
.bl-icons-nodetree::before { content: "\ebc6"; }
|
|
||||||
.bl-icons-none::before { content: "\ebc7"; }
|
|
||||||
.bl-icons-normalize_fcurves::before { content: "\ebc8"; }
|
|
||||||
.bl-icons-normals_face::before { content: "\ebc9"; }
|
|
||||||
.bl-icons-normals_vertex::before { content: "\ebca"; }
|
|
||||||
.bl-icons-normals_vertex_face::before { content: "\ebcb"; }
|
|
||||||
.bl-icons-not_found::before { content: "\ebcc"; }
|
|
||||||
.bl-icons-object_data::before { content: "\ebcd"; }
|
|
||||||
.bl-icons-object_datamode::before { content: "\ebce"; }
|
|
||||||
.bl-icons-object_hidden::before { content: "\ebcf"; }
|
|
||||||
.bl-icons-object_origin::before { content: "\ebd0"; }
|
|
||||||
.bl-icons-onionskin_off::before { content: "\ebd1"; }
|
|
||||||
.bl-icons-onionskin_on::before { content: "\ebd2"; }
|
|
||||||
.bl-icons-options::before { content: "\ebd3"; }
|
|
||||||
.bl-icons-orientation_cursor::before { content: "\ebd4"; }
|
|
||||||
.bl-icons-orientation_gimbal::before { content: "\ebd5"; }
|
|
||||||
.bl-icons-orientation_global::before { content: "\ebd6"; }
|
|
||||||
.bl-icons-orientation_local::before { content: "\ebd7"; }
|
|
||||||
.bl-icons-orientation_normal::before { content: "\ebd8"; }
|
|
||||||
.bl-icons-orientation_parent::before { content: "\ebd9"; }
|
|
||||||
.bl-icons-orientation_view::before { content: "\ebda"; }
|
|
||||||
.bl-icons-orphan_data::before { content: "\ebdb"; }
|
|
||||||
.bl-icons-outliner::before { content: "\ebdc"; }
|
|
||||||
.bl-icons-outliner_collection::before { content: "\ebdd"; }
|
|
||||||
.bl-icons-outliner_data_armature::before { content: "\ebde"; }
|
|
||||||
.bl-icons-outliner_data_camera::before { content: "\ebdf"; }
|
|
||||||
.bl-icons-outliner_data_curve::before { content: "\ebe0"; }
|
|
||||||
.bl-icons-outliner_data_curves::before { content: "\ebe1"; }
|
|
||||||
.bl-icons-outliner_data_empty::before { content: "\ebe2"; }
|
|
||||||
.bl-icons-outliner_data_font::before { content: "\ebe3"; }
|
|
||||||
.bl-icons-outliner_data_gp_layer::before { content: "\ebe4"; }
|
|
||||||
.bl-icons-outliner_data_greasepencil::before { content: "\ebe5"; }
|
|
||||||
.bl-icons-outliner_data_lattice::before { content: "\ebe6"; }
|
|
||||||
.bl-icons-outliner_data_light::before { content: "\ebe7"; }
|
|
||||||
.bl-icons-outliner_data_lightprobe::before { content: "\ebe8"; }
|
|
||||||
.bl-icons-outliner_data_mesh::before { content: "\ebe9"; }
|
|
||||||
.bl-icons-outliner_data_meta::before { content: "\ebea"; }
|
|
||||||
.bl-icons-outliner_data_pointcloud::before { content: "\ebeb"; }
|
|
||||||
.bl-icons-outliner_data_speaker::before { content: "\ebec"; }
|
|
||||||
.bl-icons-outliner_data_surface::before { content: "\ebed"; }
|
|
||||||
.bl-icons-outliner_data_volume::before { content: "\ebee"; }
|
|
||||||
.bl-icons-outliner_ob_armature::before { content: "\ebef"; }
|
|
||||||
.bl-icons-outliner_ob_camera::before { content: "\ebf0"; }
|
|
||||||
.bl-icons-outliner_ob_curve::before { content: "\ebf1"; }
|
|
||||||
.bl-icons-outliner_ob_curves::before { content: "\ebf2"; }
|
|
||||||
.bl-icons-outliner_ob_empty::before { content: "\ebf3"; }
|
|
||||||
.bl-icons-outliner_ob_font::before { content: "\ebf4"; }
|
|
||||||
.bl-icons-outliner_ob_force_field::before { content: "\ebf5"; }
|
|
||||||
.bl-icons-outliner_ob_greasepencil::before { content: "\ebf6"; }
|
|
||||||
.bl-icons-outliner_ob_group_instance::before { content: "\ebf7"; }
|
|
||||||
.bl-icons-outliner_ob_image::before { content: "\ebf8"; }
|
|
||||||
.bl-icons-outliner_ob_lattice::before { content: "\ebf9"; }
|
|
||||||
.bl-icons-outliner_ob_light::before { content: "\ebfa"; }
|
|
||||||
.bl-icons-outliner_ob_lightprobe::before { content: "\ebfb"; }
|
|
||||||
.bl-icons-outliner_ob_mesh::before { content: "\ebfc"; }
|
|
||||||
.bl-icons-outliner_ob_meta::before { content: "\ebfd"; }
|
|
||||||
.bl-icons-outliner_ob_pointcloud::before { content: "\ebfe"; }
|
|
||||||
.bl-icons-outliner_ob_speaker::before { content: "\ebff"; }
|
|
||||||
.bl-icons-outliner_ob_surface::before { content: "\ec00"; }
|
|
||||||
.bl-icons-outliner_ob_volume::before { content: "\ec01"; }
|
|
||||||
.bl-icons-output::before { content: "\ec02"; }
|
|
||||||
.bl-icons-overlay::before { content: "\ec03"; }
|
|
||||||
.bl-icons-package::before { content: "\ec04"; }
|
|
||||||
.bl-icons-panel_close::before { content: "\ec05"; }
|
|
||||||
.bl-icons-particle_data::before { content: "\ec06"; }
|
|
||||||
.bl-icons-particle_path::before { content: "\ec07"; }
|
|
||||||
.bl-icons-particle_point::before { content: "\ec08"; }
|
|
||||||
.bl-icons-particle_tip::before { content: "\ec09"; }
|
|
||||||
.bl-icons-particlemode::before { content: "\ec0a"; }
|
|
||||||
.bl-icons-particles::before { content: "\ec0b"; }
|
|
||||||
.bl-icons-pastedown::before { content: "\ec0c"; }
|
|
||||||
.bl-icons-pasteflipdown::before { content: "\ec0d"; }
|
|
||||||
.bl-icons-pasteflipup::before { content: "\ec0e"; }
|
|
||||||
.bl-icons-pause::before { content: "\ec0f"; }
|
|
||||||
.bl-icons-physics::before { content: "\ec10"; }
|
|
||||||
.bl-icons-pinned::before { content: "\ec11"; }
|
|
||||||
.bl-icons-pivot_active::before { content: "\ec12"; }
|
|
||||||
.bl-icons-pivot_boundbox::before { content: "\ec13"; }
|
|
||||||
.bl-icons-pivot_cursor::before { content: "\ec14"; }
|
|
||||||
.bl-icons-pivot_individual::before { content: "\ec15"; }
|
|
||||||
.bl-icons-pivot_median::before { content: "\ec16"; }
|
|
||||||
.bl-icons-play::before { content: "\ec17"; }
|
|
||||||
.bl-icons-play_reverse::before { content: "\ec18"; }
|
|
||||||
.bl-icons-play_sound::before { content: "\ec19"; }
|
|
||||||
.bl-icons-plugin::before { content: "\ec1a"; }
|
|
||||||
.bl-icons-plus::before { content: "\ec1b"; }
|
|
||||||
.bl-icons-pmarker::before { content: "\ec1c"; }
|
|
||||||
.bl-icons-pmarker_act::before { content: "\ec1d"; }
|
|
||||||
.bl-icons-pmarker_sel::before { content: "\ec1e"; }
|
|
||||||
.bl-icons-pointcloud_data::before { content: "\ec1f"; }
|
|
||||||
.bl-icons-pointcloud_point::before { content: "\ec20"; }
|
|
||||||
.bl-icons-pose_hlt::before { content: "\ec21"; }
|
|
||||||
.bl-icons-preferences::before { content: "\ec22"; }
|
|
||||||
.bl-icons-preset::before { content: "\ec23"; }
|
|
||||||
.bl-icons-preset_new::before { content: "\ec24"; }
|
|
||||||
.bl-icons-prev_keyframe::before { content: "\ec25"; }
|
|
||||||
.bl-icons-preview_loading::before { content: "\ec26"; }
|
|
||||||
.bl-icons-preview_range::before { content: "\ec27"; }
|
|
||||||
.bl-icons-prop_con::before { content: "\ec28"; }
|
|
||||||
.bl-icons-prop_off::before { content: "\ec29"; }
|
|
||||||
.bl-icons-prop_on::before { content: "\ec2a"; }
|
|
||||||
.bl-icons-prop_projected::before { content: "\ec2b"; }
|
|
||||||
.bl-icons-properties::before { content: "\ec2c"; }
|
|
||||||
.bl-icons-question::before { content: "\ec2d"; }
|
|
||||||
.bl-icons-question_large::before { content: "\ec2e"; }
|
|
||||||
.bl-icons-quit::before { content: "\ec2f"; }
|
|
||||||
.bl-icons-radiobut_off::before { content: "\ec30"; }
|
|
||||||
.bl-icons-radiobut_on::before { content: "\ec31"; }
|
|
||||||
.bl-icons-rec::before { content: "\ec32"; }
|
|
||||||
.bl-icons-record_off::before { content: "\ec33"; }
|
|
||||||
.bl-icons-record_on::before { content: "\ec34"; }
|
|
||||||
.bl-icons-recover_last::before { content: "\ec35"; }
|
|
||||||
.bl-icons-remove::before { content: "\ec36"; }
|
|
||||||
.bl-icons-render_animation::before { content: "\ec37"; }
|
|
||||||
.bl-icons-render_result::before { content: "\ec38"; }
|
|
||||||
.bl-icons-render_still::before { content: "\ec39"; }
|
|
||||||
.bl-icons-renderlayers::before { content: "\ec3a"; }
|
|
||||||
.bl-icons-restrict_color_off::before { content: "\ec3b"; }
|
|
||||||
.bl-icons-restrict_color_on::before { content: "\ec3c"; }
|
|
||||||
.bl-icons-restrict_instanced_off::before { content: "\ec3d"; }
|
|
||||||
.bl-icons-restrict_instanced_on::before { content: "\ec3e"; }
|
|
||||||
.bl-icons-restrict_render_off::before { content: "\ec3f"; }
|
|
||||||
.bl-icons-restrict_render_on::before { content: "\ec40"; }
|
|
||||||
.bl-icons-restrict_select_off::before { content: "\ec41"; }
|
|
||||||
.bl-icons-restrict_select_on::before { content: "\ec42"; }
|
|
||||||
.bl-icons-restrict_view_off::before { content: "\ec43"; }
|
|
||||||
.bl-icons-restrict_view_on::before { content: "\ec44"; }
|
|
||||||
.bl-icons-rew::before { content: "\ec45"; }
|
|
||||||
.bl-icons-rightarrow::before { content: "\ec46"; }
|
|
||||||
.bl-icons-rightarrow_thin::before { content: "\ec47"; }
|
|
||||||
.bl-icons-rigid_body::before { content: "\ec48"; }
|
|
||||||
.bl-icons-rigid_body_constraint::before { content: "\ec49"; }
|
|
||||||
.bl-icons-rna::before { content: "\ec4a"; }
|
|
||||||
.bl-icons-rna_add::before { content: "\ec4b"; }
|
|
||||||
.bl-icons-rndcurve::before { content: "\ec4c"; }
|
|
||||||
.bl-icons-rootcurve::before { content: "\ec4d"; }
|
|
||||||
.bl-icons-scene::before { content: "\ec4e"; }
|
|
||||||
.bl-icons-scene_data::before { content: "\ec4f"; }
|
|
||||||
.bl-icons-screen_back::before { content: "\ec50"; }
|
|
||||||
.bl-icons-script::before { content: "\ec51"; }
|
|
||||||
.bl-icons-scriptplugins::before { content: "\ec52"; }
|
|
||||||
.bl-icons-sculptmode_hlt::before { content: "\ec53"; }
|
|
||||||
.bl-icons-select_difference::before { content: "\ec54"; }
|
|
||||||
.bl-icons-select_extend::before { content: "\ec55"; }
|
|
||||||
.bl-icons-select_intersect::before { content: "\ec56"; }
|
|
||||||
.bl-icons-select_set::before { content: "\ec57"; }
|
|
||||||
.bl-icons-select_subtract::before { content: "\ec58"; }
|
|
||||||
.bl-icons-seq_chroma_scope::before { content: "\ec59"; }
|
|
||||||
.bl-icons-seq_histogram::before { content: "\ec5a"; }
|
|
||||||
.bl-icons-seq_luma_waveform::before { content: "\ec5b"; }
|
|
||||||
.bl-icons-seq_preview::before { content: "\ec5c"; }
|
|
||||||
.bl-icons-seq_sequencer::before { content: "\ec5d"; }
|
|
||||||
.bl-icons-seq_splitview::before { content: "\ec5e"; }
|
|
||||||
.bl-icons-seq_strip_duplicate::before { content: "\ec5f"; }
|
|
||||||
.bl-icons-seq_strip_meta::before { content: "\ec60"; }
|
|
||||||
.bl-icons-sequence::before { content: "\ec61"; }
|
|
||||||
.bl-icons-settings::before { content: "\ec62"; }
|
|
||||||
.bl-icons-shaderfx::before { content: "\ec63"; }
|
|
||||||
.bl-icons-shading_bbox::before { content: "\ec64"; }
|
|
||||||
.bl-icons-shading_rendered::before { content: "\ec65"; }
|
|
||||||
.bl-icons-shading_solid::before { content: "\ec66"; }
|
|
||||||
.bl-icons-shading_texture::before { content: "\ec67"; }
|
|
||||||
.bl-icons-shading_wire::before { content: "\ec68"; }
|
|
||||||
.bl-icons-shapekey_data::before { content: "\ec69"; }
|
|
||||||
.bl-icons-sharpcurve::before { content: "\ec6a"; }
|
|
||||||
.bl-icons-shortdisplay::before { content: "\ec6b"; }
|
|
||||||
.bl-icons-small_caps::before { content: "\ec6c"; }
|
|
||||||
.bl-icons-smoothcurve::before { content: "\ec6d"; }
|
|
||||||
.bl-icons-snap_edge::before { content: "\ec6e"; }
|
|
||||||
.bl-icons-snap_face::before { content: "\ec6f"; }
|
|
||||||
.bl-icons-snap_face_center::before { content: "\ec70"; }
|
|
||||||
.bl-icons-snap_face_nearest::before { content: "\ec71"; }
|
|
||||||
.bl-icons-snap_grid::before { content: "\ec72"; }
|
|
||||||
.bl-icons-snap_increment::before { content: "\ec73"; }
|
|
||||||
.bl-icons-snap_midpoint::before { content: "\ec74"; }
|
|
||||||
.bl-icons-snap_normal::before { content: "\ec75"; }
|
|
||||||
.bl-icons-snap_off::before { content: "\ec76"; }
|
|
||||||
.bl-icons-snap_on::before { content: "\ec77"; }
|
|
||||||
.bl-icons-snap_peel_object::before { content: "\ec78"; }
|
|
||||||
.bl-icons-snap_perpendicular::before { content: "\ec79"; }
|
|
||||||
.bl-icons-snap_vertex::before { content: "\ec7a"; }
|
|
||||||
.bl-icons-snap_volume::before { content: "\ec7b"; }
|
|
||||||
.bl-icons-solo_off::before { content: "\ec7c"; }
|
|
||||||
.bl-icons-solo_on::before { content: "\ec7d"; }
|
|
||||||
.bl-icons-sort_asc::before { content: "\ec7e"; }
|
|
||||||
.bl-icons-sort_desc::before { content: "\ec7f"; }
|
|
||||||
.bl-icons-sortalpha::before { content: "\ec80"; }
|
|
||||||
.bl-icons-sortbyext::before { content: "\ec81"; }
|
|
||||||
.bl-icons-sortsize::before { content: "\ec82"; }
|
|
||||||
.bl-icons-sorttime::before { content: "\ec83"; }
|
|
||||||
.bl-icons-sound::before { content: "\ec84"; }
|
|
||||||
.bl-icons-speaker::before { content: "\ec85"; }
|
|
||||||
.bl-icons-sphere::before { content: "\ec86"; }
|
|
||||||
.bl-icons-spherecurve::before { content: "\ec87"; }
|
|
||||||
.bl-icons-split_horizontal::before { content: "\ec88"; }
|
|
||||||
.bl-icons-split_vertical::before { content: "\ec89"; }
|
|
||||||
.bl-icons-spreadsheet::before { content: "\ec8a"; }
|
|
||||||
.bl-icons-statusbar::before { content: "\ec8b"; }
|
|
||||||
.bl-icons-sticky_uvs_disable::before { content: "\ec8c"; }
|
|
||||||
.bl-icons-sticky_uvs_loc::before { content: "\ec8d"; }
|
|
||||||
.bl-icons-sticky_uvs_vert::before { content: "\ec8e"; }
|
|
||||||
.bl-icons-strands::before { content: "\ec8f"; }
|
|
||||||
.bl-icons-stroke::before { content: "\ec90"; }
|
|
||||||
.bl-icons-stylus_pressure::before { content: "\ec91"; }
|
|
||||||
.bl-icons-surface_data::before { content: "\ec92"; }
|
|
||||||
.bl-icons-surface_ncircle::before { content: "\ec93"; }
|
|
||||||
.bl-icons-surface_ncurve::before { content: "\ec94"; }
|
|
||||||
.bl-icons-surface_ncylinder::before { content: "\ec95"; }
|
|
||||||
.bl-icons-surface_nsphere::before { content: "\ec96"; }
|
|
||||||
.bl-icons-surface_nsurface::before { content: "\ec97"; }
|
|
||||||
.bl-icons-surface_ntorus::before { content: "\ec98"; }
|
|
||||||
.bl-icons-syntax_off::before { content: "\ec99"; }
|
|
||||||
.bl-icons-syntax_on::before { content: "\ec9a"; }
|
|
||||||
.bl-icons-system::before { content: "\ec9b"; }
|
|
||||||
.bl-icons-tag::before { content: "\ec9c"; }
|
|
||||||
.bl-icons-temp::before { content: "\ec9d"; }
|
|
||||||
.bl-icons-text::before { content: "\ec9e"; }
|
|
||||||
.bl-icons-texture::before { content: "\ec9f"; }
|
|
||||||
.bl-icons-texture_data::before { content: "\eca0"; }
|
|
||||||
.bl-icons-three_dots::before { content: "\eca1"; }
|
|
||||||
.bl-icons-time::before { content: "\eca2"; }
|
|
||||||
.bl-icons-tool_settings::before { content: "\eca3"; }
|
|
||||||
.bl-icons-topbar::before { content: "\eca4"; }
|
|
||||||
.bl-icons-tpaint_hlt::before { content: "\eca5"; }
|
|
||||||
.bl-icons-tracker::before { content: "\eca6"; }
|
|
||||||
.bl-icons-tracker_data::before { content: "\eca7"; }
|
|
||||||
.bl-icons-tracking::before { content: "\eca8"; }
|
|
||||||
.bl-icons-tracking_backwards::before { content: "\eca9"; }
|
|
||||||
.bl-icons-tracking_backwards_single::before { content: "\ecaa"; }
|
|
||||||
.bl-icons-tracking_clear_backwards::before { content: "\ecab"; }
|
|
||||||
.bl-icons-tracking_clear_forwards::before { content: "\ecac"; }
|
|
||||||
.bl-icons-tracking_forwards::before { content: "\ecad"; }
|
|
||||||
.bl-icons-tracking_forwards_single::before { content: "\ecae"; }
|
|
||||||
.bl-icons-tracking_refine_backwards::before { content: "\ecaf"; }
|
|
||||||
.bl-icons-tracking_refine_forwards::before { content: "\ecb0"; }
|
|
||||||
.bl-icons-transform_origins::before { content: "\ecb1"; }
|
|
||||||
.bl-icons-trash::before { content: "\ecb2"; }
|
|
||||||
.bl-icons-tria_down::before { content: "\ecb3"; }
|
|
||||||
.bl-icons-tria_down_bar::before { content: "\ecb4"; }
|
|
||||||
.bl-icons-tria_left::before { content: "\ecb5"; }
|
|
||||||
.bl-icons-tria_left_bar::before { content: "\ecb6"; }
|
|
||||||
.bl-icons-tria_right::before { content: "\ecb7"; }
|
|
||||||
.bl-icons-tria_right_bar::before { content: "\ecb8"; }
|
|
||||||
.bl-icons-tria_up::before { content: "\ecb9"; }
|
|
||||||
.bl-icons-tria_up_bar::before { content: "\ecba"; }
|
|
||||||
.bl-icons-uglypackage::before { content: "\ecbb"; }
|
|
||||||
.bl-icons-underline::before { content: "\ecbc"; }
|
|
||||||
.bl-icons-unlinked::before { content: "\ecbd"; }
|
|
||||||
.bl-icons-unlocked::before { content: "\ecbe"; }
|
|
||||||
.bl-icons-unpinned::before { content: "\ecbf"; }
|
|
||||||
.bl-icons-url::before { content: "\ecc0"; }
|
|
||||||
.bl-icons-user::before { content: "\ecc1"; }
|
|
||||||
.bl-icons-uv::before { content: "\ecc2"; }
|
|
||||||
.bl-icons-uv_data::before { content: "\ecc3"; }
|
|
||||||
.bl-icons-uv_edgesel::before { content: "\ecc4"; }
|
|
||||||
.bl-icons-uv_facesel::before { content: "\ecc5"; }
|
|
||||||
.bl-icons-uv_islandsel::before { content: "\ecc6"; }
|
|
||||||
.bl-icons-uv_sync_select::before { content: "\ecc7"; }
|
|
||||||
.bl-icons-uv_vertexsel::before { content: "\ecc8"; }
|
|
||||||
.bl-icons-vertexsel::before { content: "\ecc9"; }
|
|
||||||
.bl-icons-view3d::before { content: "\ecca"; }
|
|
||||||
.bl-icons-view_camera::before { content: "\eccb"; }
|
|
||||||
.bl-icons-view_camera_unselected::before { content: "\eccc"; }
|
|
||||||
.bl-icons-view_locked::before { content: "\eccd"; }
|
|
||||||
.bl-icons-view_ortho::before { content: "\ecce"; }
|
|
||||||
.bl-icons-view_pan::before { content: "\eccf"; }
|
|
||||||
.bl-icons-view_perspective::before { content: "\ecd0"; }
|
|
||||||
.bl-icons-view_unlocked::before { content: "\ecd1"; }
|
|
||||||
.bl-icons-view_zoom::before { content: "\ecd2"; }
|
|
||||||
.bl-icons-viewzoom::before { content: "\ecd3"; }
|
|
||||||
.bl-icons-vis_sel_00::before { content: "\ecd4"; }
|
|
||||||
.bl-icons-vis_sel_01::before { content: "\ecd5"; }
|
|
||||||
.bl-icons-vis_sel_10::before { content: "\ecd6"; }
|
|
||||||
.bl-icons-vis_sel_11::before { content: "\ecd7"; }
|
|
||||||
.bl-icons-volume_data::before { content: "\ecd8"; }
|
|
||||||
.bl-icons-vpaint_hlt::before { content: "\ecd9"; }
|
|
||||||
.bl-icons-warning_large::before { content: "\ecda"; }
|
|
||||||
.bl-icons-window::before { content: "\ecdb"; }
|
|
||||||
.bl-icons-wordwrap_off::before { content: "\ecdc"; }
|
|
||||||
.bl-icons-wordwrap_on::before { content: "\ecdd"; }
|
|
||||||
.bl-icons-workspace::before { content: "\ecde"; }
|
|
||||||
.bl-icons-world::before { content: "\ecdf"; }
|
|
||||||
.bl-icons-world_data::before { content: "\ece0"; }
|
|
||||||
.bl-icons-wpaint_hlt::before { content: "\ece1"; }
|
|
||||||
.bl-icons-x::before { content: "\ece2"; }
|
|
||||||
.bl-icons-xray::before { content: "\ece3"; }
|
|
||||||
.bl-icons-zoom_all::before { content: "\ece4"; }
|
|
||||||
.bl-icons-zoom_in::before { content: "\ece5"; }
|
|
||||||
.bl-icons-zoom_out::before { content: "\ece6"; }
|
|
||||||
.bl-icons-zoom_previous::before { content: "\ece7"; }
|
|
||||||
.bl-icons-zoom_selected::before { content: "\ece8"; }
|
|
||||||
|
|
||||||
|
|
||||||
|
Before Width: | Height: | Size: 1.2 MiB |
|
Before Width: | Height: | Size: 596 KiB |
@ -1,295 +0,0 @@
|
|||||||
(function() {//switch: v1.5
|
|
||||||
"use strict";
|
|
||||||
|
|
||||||
var versionsFileUrl = "https://docs.blender.org/PROD/versions.json"
|
|
||||||
|
|
||||||
var all_versions;
|
|
||||||
var all_langs = {
|
|
||||||
"en": "English",
|
|
||||||
"ar": "اَلْعَرَبِيَّةُ",
|
|
||||||
"ca": "Català",
|
|
||||||
"de": "Deutsch",
|
|
||||||
"es": "Español",
|
|
||||||
"fi": "Suomi",
|
|
||||||
"fr": "Français",
|
|
||||||
"id": "Bahasa Indonesia",
|
|
||||||
"it": "Italiano",
|
|
||||||
"ja": "日本語",
|
|
||||||
"ka": "ქართული",
|
|
||||||
"ko": "한국어",
|
|
||||||
"nb": "Norsk Bokmål",
|
|
||||||
"nl": "Nederlands",
|
|
||||||
"pt": "Português",
|
|
||||||
"ru": "Ρусский",
|
|
||||||
"sk": "Slovenčina",
|
|
||||||
"sl": "Slovenščina",
|
|
||||||
"sr": "српски",
|
|
||||||
"th": "ภาษาไทย",
|
|
||||||
"uk": "Українська",
|
|
||||||
"vi": "Tiếng Việt",
|
|
||||||
"zh-hans": "中文(简体)",
|
|
||||||
"zh-hant": "中文(繁體)",
|
|
||||||
};
|
|
||||||
|
|
||||||
class Popover {
|
|
||||||
constructor(id) {
|
|
||||||
this.isOpen=false;
|
|
||||||
this.type = (id === "version-popover");
|
|
||||||
this.btn = document.querySelector('#' + id);
|
|
||||||
this.dialog = this.btn.nextElementSibling;
|
|
||||||
this.list = this.dialog.querySelector("ul");
|
|
||||||
this.sel = null;
|
|
||||||
const that = this;
|
|
||||||
this.btnClickHandler = function(e) {that.init();e.preventDefault();e.stopPropagation();};
|
|
||||||
this.btnKeyHandler = function(e) {if(that.btnKeyFilter(e)){that.init();e.preventDefault();e.stopPropagation();} };
|
|
||||||
this.btn.addEventListener("click", this.btnClickHandler);
|
|
||||||
this.btn.addEventListener("keydown", this.btnKeyHandler);
|
|
||||||
}
|
|
||||||
|
|
||||||
init() {
|
|
||||||
this.btn.removeEventListener("click", this.btnClickHandler);
|
|
||||||
this.btn.removeEventListener("keydown", this.btnKeyHandler);
|
|
||||||
|
|
||||||
new Promise((resolve, reject) => {
|
|
||||||
if(all_versions === undefined) {
|
|
||||||
this.btn.classList.add("wait");
|
|
||||||
fetch(versionsFileUrl)
|
|
||||||
.then((response) => response.json())
|
|
||||||
.then((data) => {
|
|
||||||
all_versions = data;
|
|
||||||
resolve();
|
|
||||||
})
|
|
||||||
.catch(() => {
|
|
||||||
console.error("Version Switch Error: versions.json could not be loaded.");
|
|
||||||
this.btn.classList.remove("disabled");
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
resolve();
|
|
||||||
}
|
|
||||||
})
|
|
||||||
.then(() => {
|
|
||||||
let release = DOCUMENTATION_OPTIONS.VERSION;
|
|
||||||
const m = release.match(/\d\.\d+/g);
|
|
||||||
if (m) {release = m[0];}
|
|
||||||
let lang = DOCUMENTATION_OPTIONS.LANGUAGE;
|
|
||||||
if(!lang || lang === "None" || lang === "") {lang = "en";}
|
|
||||||
|
|
||||||
this.warnOld(release, all_versions);
|
|
||||||
|
|
||||||
const version = this.getNamed(release);
|
|
||||||
this.buildList(version, lang);
|
|
||||||
|
|
||||||
this.list.firstElementChild.remove();
|
|
||||||
const that = this;
|
|
||||||
this.list.addEventListener("keydown", function(e) {that.keyMove(e);});
|
|
||||||
|
|
||||||
this.btn.classList.remove("wait");
|
|
||||||
this.btnOpenHandler();
|
|
||||||
this.btn.addEventListener("mousedown", function(e){that.btnOpenHandler(); e.preventDefault()});
|
|
||||||
this.btn.addEventListener("keydown", function(e){ if(that.btnKeyFilter(e)){that.btnOpenHandler();} });
|
|
||||||
});
|
|
||||||
}
|
|
||||||
warnOld(release, all_versions) {
|
|
||||||
// Note this is effectively disabled now, two issues must fixed:
|
|
||||||
// * versions.js does not contain a current entry, because that leads to
|
|
||||||
// duplicate version numbers in the menu. These need to be deduplicated.
|
|
||||||
// * It only shows the warning after opening the menu to switch version
|
|
||||||
// or language, when versions.js is loaded. This is too late to be useful.
|
|
||||||
let current = all_versions.current
|
|
||||||
if (!current) {
|
|
||||||
//console.log("Version Switch Error: no 'current' in version.json.");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
const m = current.match(/\d\.\d+/g);
|
|
||||||
if (m) {current = parseFloat(m[0]);}
|
|
||||||
if (release < current) {
|
|
||||||
const currentURL = window.location.pathname.replace(release, current);
|
|
||||||
const warning = document.querySelector("template#version-warning").firstElementChild.cloneNode(true);
|
|
||||||
const link = warning.querySelector('a');
|
|
||||||
link.setAttribute('href', currentURL);
|
|
||||||
link.textContent = current;
|
|
||||||
|
|
||||||
let body = document.querySelector("div.body");
|
|
||||||
if (!body.length) {body = document.querySelector("div.document");}
|
|
||||||
body.prepend(warning);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
buildList(v, l) {
|
|
||||||
const url = new URL(window.location.href);
|
|
||||||
let pathSplit = ["", "manual", l, v];
|
|
||||||
if (url.pathname.startsWith("/manual/")) {
|
|
||||||
pathSplit.push(url.pathname.split('/').slice(4).join('/'));
|
|
||||||
} else {
|
|
||||||
pathSplit.push(url.pathname.substring(1));
|
|
||||||
}
|
|
||||||
let dyn, cur;
|
|
||||||
if(this.type) {
|
|
||||||
dyn = all_versions;
|
|
||||||
cur = v;
|
|
||||||
} else {
|
|
||||||
dyn = all_langs;
|
|
||||||
cur = l;
|
|
||||||
}
|
|
||||||
const that = this;
|
|
||||||
const template = document.querySelector("template#version-entry").content;
|
|
||||||
for (let [ix, title] of Object.entries(dyn)) {
|
|
||||||
let clone;
|
|
||||||
if (ix === cur) {
|
|
||||||
clone = template.querySelector("li.selected").cloneNode(true);
|
|
||||||
clone.querySelector("span").innerHTML = title;
|
|
||||||
} else {
|
|
||||||
pathSplit[2 + that.type] = ix;
|
|
||||||
let href = new URL(url);
|
|
||||||
href.pathname = pathSplit.join('/');
|
|
||||||
clone = template.firstElementChild.cloneNode(true);
|
|
||||||
const link = clone.querySelector("a");
|
|
||||||
link.href = href;
|
|
||||||
if (that.type) {
|
|
||||||
link.innerHTML = title;
|
|
||||||
} else {
|
|
||||||
const hint = document.createElement("bdi");
|
|
||||||
hint.innerHTML = title;
|
|
||||||
link.appendChild(hint);
|
|
||||||
}
|
|
||||||
link.setAttribute("lang", !that.type ? ix : "en");
|
|
||||||
}
|
|
||||||
that.list.append(clone);
|
|
||||||
};
|
|
||||||
return this.list;
|
|
||||||
}
|
|
||||||
getNamed(v) {
|
|
||||||
for (let [ix, title] of Object.entries(all_versions)) {
|
|
||||||
if (ix === "dev" || ix === "latest") {
|
|
||||||
const m = title.match(/\d\.\d[\w\d\.]*/)[0];
|
|
||||||
if (parseFloat(m) == v) {
|
|
||||||
v = ix;
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
return v;
|
|
||||||
}
|
|
||||||
dialogToggle(speed) {
|
|
||||||
speed = window.matchMedia("(prefers-reduced-motion: reduce)").matches ? 0 : speed;
|
|
||||||
const wasClose = !this.isOpen;
|
|
||||||
const that = this;
|
|
||||||
if(!this.isOpen) {
|
|
||||||
this.btn.classList.add("version-btn-open");
|
|
||||||
this.btn.setAttribute("aria-pressed", true);
|
|
||||||
this.dialog.setAttribute("aria-hidden", false);
|
|
||||||
this.dialog.style.display = "block";
|
|
||||||
this.dialog.animate({opacity: [0, 1], easing: ['ease-in', 'ease-out']}, speed).finished
|
|
||||||
.then(() => {
|
|
||||||
this.focusoutHandlerPrime = function(e) {that.focusoutHandler(); e.stopImmediatePropagation();};
|
|
||||||
this.mouseoutHandlerPrime = function(e){that.mouseoutHandler(); e.stopImmediatePropagation();};
|
|
||||||
this.btn.parentNode.addEventListener("focusout", this.focusoutHandlerPrime);
|
|
||||||
this.btn.parentNode.addEventListener("mouseleave", this.mouseoutHandlerPrime);
|
|
||||||
});
|
|
||||||
this.isOpen = true;
|
|
||||||
} else {
|
|
||||||
this.btn.classList.remove("version-btn-open");
|
|
||||||
this.btn.setAttribute("aria-pressed", false);
|
|
||||||
this.dialog.setAttribute("aria-hidden", true);
|
|
||||||
this.btn.parentNode.removeEventListener("focusout", this.focusoutHandlerPrime);
|
|
||||||
this.btn.parentNode.removeEventListener("mouseleave", this.mouseoutHandlerPrime);
|
|
||||||
this.dialog.animate({opacity: [1, 0], easing: ['ease-in', 'ease-out']}, speed).finished
|
|
||||||
.then(() => {
|
|
||||||
this.dialog.style.display = "none";
|
|
||||||
if (this.sel) {this.sel.setAttribute("tabindex", -1);}
|
|
||||||
this.btn.setAttribute("tabindex", 0);
|
|
||||||
if(document.activeElement !== null && document.activeElement !== document && document.activeElement !== document.body) {
|
|
||||||
this.btn.focus();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
this.isOpen = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
if(wasClose) {
|
|
||||||
if (this.sel) {this.sel.setAttribute("tabindex", -1);}
|
|
||||||
if(document.activeElement !== null && document.activeElement !== document && document.activeElement !== document.body) {
|
|
||||||
const nw = this.listEnter();
|
|
||||||
nw.setAttribute("tabindex", 0);
|
|
||||||
nw.focus();
|
|
||||||
this.sel = nw;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
btnOpenHandler() {
|
|
||||||
this.dialogToggle(300);
|
|
||||||
}
|
|
||||||
focusoutHandler() {
|
|
||||||
const list = this.list;
|
|
||||||
const that = this;
|
|
||||||
setTimeout(function() {
|
|
||||||
if (!list.querySelector(":focus")) {
|
|
||||||
that.dialogToggle(200);
|
|
||||||
}
|
|
||||||
}, 200);
|
|
||||||
}
|
|
||||||
mouseoutHandler() {
|
|
||||||
this.dialogToggle(200);
|
|
||||||
}
|
|
||||||
btnKeyFilter(e) {
|
|
||||||
if (e.ctrlKey || e.shiftKey) {return false;}
|
|
||||||
if(e.key === " " || e.key === "Enter" || (e.key === "ArrowDown" && e.altKey) || e.key === "ArrowDown" || e.key === "ArrowUp") {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
keyMove(e) {
|
|
||||||
if (e.ctrlKey || e.shiftKey) {return true;}
|
|
||||||
let nw = e.target;
|
|
||||||
switch(e.key) {
|
|
||||||
case "ArrowUp": nw = this.listPrev(nw); break;
|
|
||||||
case "ArrowDown": nw = this.listNext(nw); break;
|
|
||||||
case "Home": nw = this.listFirst(); break;
|
|
||||||
case "End": nw = this.listLast(); break;
|
|
||||||
case "Escape": nw = this.listExit(); break;
|
|
||||||
case "ArrowLeft": nw = this.listExit(); break;
|
|
||||||
case "ArrowRight": nw = this.listExit(); break;
|
|
||||||
default: return false;
|
|
||||||
}
|
|
||||||
nw.setAttribute("tabindex", 0);
|
|
||||||
nw.focus();
|
|
||||||
if (this.sel) {this.sel.setAttribute("tabindex", -1);}
|
|
||||||
this.sel = nw;
|
|
||||||
e.preventDefault();
|
|
||||||
e.stopPropagation();
|
|
||||||
}
|
|
||||||
listPrev(nw) {
|
|
||||||
if (nw.parentNode.previousElementSibling.length !== 0) {
|
|
||||||
return nw.parentNode.previousElementSibling.firstElementChild;
|
|
||||||
} else {
|
|
||||||
return this.listLast();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
listNext(nw) {
|
|
||||||
if (nw.parentNode.nextElementSibling.length !== 0) {
|
|
||||||
return nw.parentNode.nextElementSibling.firstElementChild;
|
|
||||||
} else {
|
|
||||||
return this.listFirst();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
listFirst() {
|
|
||||||
return this.list.firstElementChild.firstElementChild;
|
|
||||||
}
|
|
||||||
listLast() {
|
|
||||||
return this.list.lastElementChild.firstElementChild;
|
|
||||||
}
|
|
||||||
listExit() {
|
|
||||||
this.mouseoutHandler();
|
|
||||||
return this.btn;
|
|
||||||
}
|
|
||||||
listEnter() {
|
|
||||||
return this.list.firstElementChild.firstElementChild;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
document.addEventListener('DOMContentLoaded', () => {
|
|
||||||
let lang = DOCUMENTATION_OPTIONS.LANGUAGE;
|
|
||||||
if(!lang || lang === "None") {lang = "en";}
|
|
||||||
if(all_langs.hasOwnProperty(lang)) {document.querySelector("#lang-popover").innerHTML = all_langs[lang];}
|
|
||||||
new Popover("version-popover");
|
|
||||||
new Popover("lang-popover");
|
|
||||||
});
|
|
||||||
})();
|
|
||||||
@ -1,199 +0,0 @@
|
|||||||
/*
|
|
||||||
* language_data.js
|
|
||||||
* ~~~~~~~~~~~~~~~~
|
|
||||||
*
|
|
||||||
* This script contains the language-specific data used by searchtools.js,
|
|
||||||
* namely the list of stopwords, stemmer, scorer and splitter.
|
|
||||||
*
|
|
||||||
* :copyright: Copyright 2007-2024 by the Sphinx team, see AUTHORS.
|
|
||||||
* :license: BSD, see LICENSE for details.
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
|
|
||||||
var stopwords = ["a", "and", "are", "as", "at", "be", "but", "by", "for", "if", "in", "into", "is", "it", "near", "no", "not", "of", "on", "or", "such", "that", "the", "their", "then", "there", "these", "they", "this", "to", "was", "will", "with"];
|
|
||||||
|
|
||||||
|
|
||||||
/* Non-minified version is copied as a separate JS file, if available */
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Porter Stemmer
|
|
||||||
*/
|
|
||||||
var Stemmer = function() {
|
|
||||||
|
|
||||||
var step2list = {
|
|
||||||
ational: 'ate',
|
|
||||||
tional: 'tion',
|
|
||||||
enci: 'ence',
|
|
||||||
anci: 'ance',
|
|
||||||
izer: 'ize',
|
|
||||||
bli: 'ble',
|
|
||||||
alli: 'al',
|
|
||||||
entli: 'ent',
|
|
||||||
eli: 'e',
|
|
||||||
ousli: 'ous',
|
|
||||||
ization: 'ize',
|
|
||||||
ation: 'ate',
|
|
||||||
ator: 'ate',
|
|
||||||
alism: 'al',
|
|
||||||
iveness: 'ive',
|
|
||||||
fulness: 'ful',
|
|
||||||
ousness: 'ous',
|
|
||||||
aliti: 'al',
|
|
||||||
iviti: 'ive',
|
|
||||||
biliti: 'ble',
|
|
||||||
logi: 'log'
|
|
||||||
};
|
|
||||||
|
|
||||||
var step3list = {
|
|
||||||
icate: 'ic',
|
|
||||||
ative: '',
|
|
||||||
alize: 'al',
|
|
||||||
iciti: 'ic',
|
|
||||||
ical: 'ic',
|
|
||||||
ful: '',
|
|
||||||
ness: ''
|
|
||||||
};
|
|
||||||
|
|
||||||
var c = "[^aeiou]"; // consonant
|
|
||||||
var v = "[aeiouy]"; // vowel
|
|
||||||
var C = c + "[^aeiouy]*"; // consonant sequence
|
|
||||||
var V = v + "[aeiou]*"; // vowel sequence
|
|
||||||
|
|
||||||
var mgr0 = "^(" + C + ")?" + V + C; // [C]VC... is m>0
|
|
||||||
var meq1 = "^(" + C + ")?" + V + C + "(" + V + ")?$"; // [C]VC[V] is m=1
|
|
||||||
var mgr1 = "^(" + C + ")?" + V + C + V + C; // [C]VCVC... is m>1
|
|
||||||
var s_v = "^(" + C + ")?" + v; // vowel in stem
|
|
||||||
|
|
||||||
this.stemWord = function (w) {
|
|
||||||
var stem;
|
|
||||||
var suffix;
|
|
||||||
var firstch;
|
|
||||||
var origword = w;
|
|
||||||
|
|
||||||
if (w.length < 3)
|
|
||||||
return w;
|
|
||||||
|
|
||||||
var re;
|
|
||||||
var re2;
|
|
||||||
var re3;
|
|
||||||
var re4;
|
|
||||||
|
|
||||||
firstch = w.substr(0,1);
|
|
||||||
if (firstch == "y")
|
|
||||||
w = firstch.toUpperCase() + w.substr(1);
|
|
||||||
|
|
||||||
// Step 1a
|
|
||||||
re = /^(.+?)(ss|i)es$/;
|
|
||||||
re2 = /^(.+?)([^s])s$/;
|
|
||||||
|
|
||||||
if (re.test(w))
|
|
||||||
w = w.replace(re,"$1$2");
|
|
||||||
else if (re2.test(w))
|
|
||||||
w = w.replace(re2,"$1$2");
|
|
||||||
|
|
||||||
// Step 1b
|
|
||||||
re = /^(.+?)eed$/;
|
|
||||||
re2 = /^(.+?)(ed|ing)$/;
|
|
||||||
if (re.test(w)) {
|
|
||||||
var fp = re.exec(w);
|
|
||||||
re = new RegExp(mgr0);
|
|
||||||
if (re.test(fp[1])) {
|
|
||||||
re = /.$/;
|
|
||||||
w = w.replace(re,"");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else if (re2.test(w)) {
|
|
||||||
var fp = re2.exec(w);
|
|
||||||
stem = fp[1];
|
|
||||||
re2 = new RegExp(s_v);
|
|
||||||
if (re2.test(stem)) {
|
|
||||||
w = stem;
|
|
||||||
re2 = /(at|bl|iz)$/;
|
|
||||||
re3 = new RegExp("([^aeiouylsz])\\1$");
|
|
||||||
re4 = new RegExp("^" + C + v + "[^aeiouwxy]$");
|
|
||||||
if (re2.test(w))
|
|
||||||
w = w + "e";
|
|
||||||
else if (re3.test(w)) {
|
|
||||||
re = /.$/;
|
|
||||||
w = w.replace(re,"");
|
|
||||||
}
|
|
||||||
else if (re4.test(w))
|
|
||||||
w = w + "e";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Step 1c
|
|
||||||
re = /^(.+?)y$/;
|
|
||||||
if (re.test(w)) {
|
|
||||||
var fp = re.exec(w);
|
|
||||||
stem = fp[1];
|
|
||||||
re = new RegExp(s_v);
|
|
||||||
if (re.test(stem))
|
|
||||||
w = stem + "i";
|
|
||||||
}
|
|
||||||
|
|
||||||
// Step 2
|
|
||||||
re = /^(.+?)(ational|tional|enci|anci|izer|bli|alli|entli|eli|ousli|ization|ation|ator|alism|iveness|fulness|ousness|aliti|iviti|biliti|logi)$/;
|
|
||||||
if (re.test(w)) {
|
|
||||||
var fp = re.exec(w);
|
|
||||||
stem = fp[1];
|
|
||||||
suffix = fp[2];
|
|
||||||
re = new RegExp(mgr0);
|
|
||||||
if (re.test(stem))
|
|
||||||
w = stem + step2list[suffix];
|
|
||||||
}
|
|
||||||
|
|
||||||
// Step 3
|
|
||||||
re = /^(.+?)(icate|ative|alize|iciti|ical|ful|ness)$/;
|
|
||||||
if (re.test(w)) {
|
|
||||||
var fp = re.exec(w);
|
|
||||||
stem = fp[1];
|
|
||||||
suffix = fp[2];
|
|
||||||
re = new RegExp(mgr0);
|
|
||||||
if (re.test(stem))
|
|
||||||
w = stem + step3list[suffix];
|
|
||||||
}
|
|
||||||
|
|
||||||
// Step 4
|
|
||||||
re = /^(.+?)(al|ance|ence|er|ic|able|ible|ant|ement|ment|ent|ou|ism|ate|iti|ous|ive|ize)$/;
|
|
||||||
re2 = /^(.+?)(s|t)(ion)$/;
|
|
||||||
if (re.test(w)) {
|
|
||||||
var fp = re.exec(w);
|
|
||||||
stem = fp[1];
|
|
||||||
re = new RegExp(mgr1);
|
|
||||||
if (re.test(stem))
|
|
||||||
w = stem;
|
|
||||||
}
|
|
||||||
else if (re2.test(w)) {
|
|
||||||
var fp = re2.exec(w);
|
|
||||||
stem = fp[1] + fp[2];
|
|
||||||
re2 = new RegExp(mgr1);
|
|
||||||
if (re2.test(stem))
|
|
||||||
w = stem;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Step 5
|
|
||||||
re = /^(.+?)e$/;
|
|
||||||
if (re.test(w)) {
|
|
||||||
var fp = re.exec(w);
|
|
||||||
stem = fp[1];
|
|
||||||
re = new RegExp(mgr1);
|
|
||||||
re2 = new RegExp(meq1);
|
|
||||||
re3 = new RegExp("^" + C + v + "[^aeiouwxy]$");
|
|
||||||
if (re.test(stem) || (re2.test(stem) && !(re3.test(stem))))
|
|
||||||
w = stem;
|
|
||||||
}
|
|
||||||
re = /ll$/;
|
|
||||||
re2 = new RegExp(mgr1);
|
|
||||||
if (re.test(w) && re2.test(w)) {
|
|
||||||
re = /.$/;
|
|
||||||
w = w.replace(re,"");
|
|
||||||
}
|
|
||||||
|
|
||||||
// and turn initial Y back to y
|
|
||||||
if (firstch == "y")
|
|
||||||
w = firstch.toLowerCase() + w.substr(1);
|
|
||||||
return w;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
Before Width: | Height: | Size: 90 B |
@ -1,11 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
<OpenSearchDescription xmlns="http://a9.com/-/spec/opensearch/1.1/">
|
|
||||||
<ShortName>Blender 4.5 Manual</ShortName>
|
|
||||||
<Description>Search Blender 4.5 Manual</Description>
|
|
||||||
<InputEncoding>utf-8</InputEncoding>
|
|
||||||
<Url type="text/html" method="get"
|
|
||||||
template="https://docs.blender.org/manual/en/latest/search.html?q={searchTerms}"/>
|
|
||||||
<LongName>Blender 4.5 Manual</LongName>
|
|
||||||
<Image height="16" width="16" type="image/x-icon">https://docs.blender.org/manual/en/latest/_static/favicon.png</Image>
|
|
||||||
|
|
||||||
</OpenSearchDescription>
|
|
||||||
|
Before Width: | Height: | Size: 90 B |
@ -1,258 +0,0 @@
|
|||||||
.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: #f8f8f8; }
|
|
||||||
.highlight .c { color: #8f5902; font-style: italic } /* Comment */
|
|
||||||
.highlight .err { color: #a40000; border: 1px solid #ef2929 } /* Error */
|
|
||||||
.highlight .g { color: #000000 } /* Generic */
|
|
||||||
.highlight .k { color: #204a87; font-weight: bold } /* Keyword */
|
|
||||||
.highlight .l { color: #000000 } /* Literal */
|
|
||||||
.highlight .n { color: #000000 } /* Name */
|
|
||||||
.highlight .o { color: #ce5c00; font-weight: bold } /* Operator */
|
|
||||||
.highlight .x { color: #000000 } /* Other */
|
|
||||||
.highlight .p { color: #000000; font-weight: bold } /* Punctuation */
|
|
||||||
.highlight .ch { color: #8f5902; font-style: italic } /* Comment.Hashbang */
|
|
||||||
.highlight .cm { color: #8f5902; font-style: italic } /* Comment.Multiline */
|
|
||||||
.highlight .cp { color: #8f5902; font-style: italic } /* Comment.Preproc */
|
|
||||||
.highlight .cpf { color: #8f5902; font-style: italic } /* Comment.PreprocFile */
|
|
||||||
.highlight .c1 { color: #8f5902; font-style: italic } /* Comment.Single */
|
|
||||||
.highlight .cs { color: #8f5902; font-style: italic } /* Comment.Special */
|
|
||||||
.highlight .gd { color: #a40000 } /* Generic.Deleted */
|
|
||||||
.highlight .ge { color: #000000; font-style: italic } /* Generic.Emph */
|
|
||||||
.highlight .ges { color: #000000; font-weight: bold; font-style: italic } /* Generic.EmphStrong */
|
|
||||||
.highlight .gr { color: #ef2929 } /* Generic.Error */
|
|
||||||
.highlight .gh { color: #000080; font-weight: bold } /* Generic.Heading */
|
|
||||||
.highlight .gi { color: #00A000 } /* Generic.Inserted */
|
|
||||||
.highlight .go { color: #000000; font-style: italic } /* Generic.Output */
|
|
||||||
.highlight .gp { color: #8f5902 } /* Generic.Prompt */
|
|
||||||
.highlight .gs { color: #000000; font-weight: bold } /* Generic.Strong */
|
|
||||||
.highlight .gu { color: #800080; font-weight: bold } /* Generic.Subheading */
|
|
||||||
.highlight .gt { color: #a40000; font-weight: bold } /* Generic.Traceback */
|
|
||||||
.highlight .kc { color: #204a87; font-weight: bold } /* Keyword.Constant */
|
|
||||||
.highlight .kd { color: #204a87; font-weight: bold } /* Keyword.Declaration */
|
|
||||||
.highlight .kn { color: #204a87; font-weight: bold } /* Keyword.Namespace */
|
|
||||||
.highlight .kp { color: #204a87; font-weight: bold } /* Keyword.Pseudo */
|
|
||||||
.highlight .kr { color: #204a87; font-weight: bold } /* Keyword.Reserved */
|
|
||||||
.highlight .kt { color: #204a87; font-weight: bold } /* Keyword.Type */
|
|
||||||
.highlight .ld { color: #000000 } /* Literal.Date */
|
|
||||||
.highlight .m { color: #0000cf; font-weight: bold } /* Literal.Number */
|
|
||||||
.highlight .s { color: #4e9a06 } /* Literal.String */
|
|
||||||
.highlight .na { color: #c4a000 } /* Name.Attribute */
|
|
||||||
.highlight .nb { color: #204a87 } /* Name.Builtin */
|
|
||||||
.highlight .nc { color: #000000 } /* Name.Class */
|
|
||||||
.highlight .no { color: #000000 } /* Name.Constant */
|
|
||||||
.highlight .nd { color: #5c35cc; font-weight: bold } /* Name.Decorator */
|
|
||||||
.highlight .ni { color: #ce5c00 } /* Name.Entity */
|
|
||||||
.highlight .ne { color: #cc0000; font-weight: bold } /* Name.Exception */
|
|
||||||
.highlight .nf { color: #000000 } /* Name.Function */
|
|
||||||
.highlight .nl { color: #f57900 } /* Name.Label */
|
|
||||||
.highlight .nn { color: #000000 } /* Name.Namespace */
|
|
||||||
.highlight .nx { color: #000000 } /* Name.Other */
|
|
||||||
.highlight .py { color: #000000 } /* Name.Property */
|
|
||||||
.highlight .nt { color: #204a87; font-weight: bold } /* Name.Tag */
|
|
||||||
.highlight .nv { color: #000000 } /* Name.Variable */
|
|
||||||
.highlight .ow { color: #204a87; font-weight: bold } /* Operator.Word */
|
|
||||||
.highlight .pm { color: #000000; font-weight: bold } /* Punctuation.Marker */
|
|
||||||
.highlight .w { color: #f8f8f8 } /* Text.Whitespace */
|
|
||||||
.highlight .mb { color: #0000cf; font-weight: bold } /* Literal.Number.Bin */
|
|
||||||
.highlight .mf { color: #0000cf; font-weight: bold } /* Literal.Number.Float */
|
|
||||||
.highlight .mh { color: #0000cf; font-weight: bold } /* Literal.Number.Hex */
|
|
||||||
.highlight .mi { color: #0000cf; font-weight: bold } /* Literal.Number.Integer */
|
|
||||||
.highlight .mo { color: #0000cf; font-weight: bold } /* Literal.Number.Oct */
|
|
||||||
.highlight .sa { color: #4e9a06 } /* Literal.String.Affix */
|
|
||||||
.highlight .sb { color: #4e9a06 } /* Literal.String.Backtick */
|
|
||||||
.highlight .sc { color: #4e9a06 } /* Literal.String.Char */
|
|
||||||
.highlight .dl { color: #4e9a06 } /* Literal.String.Delimiter */
|
|
||||||
.highlight .sd { color: #8f5902; font-style: italic } /* Literal.String.Doc */
|
|
||||||
.highlight .s2 { color: #4e9a06 } /* Literal.String.Double */
|
|
||||||
.highlight .se { color: #4e9a06 } /* Literal.String.Escape */
|
|
||||||
.highlight .sh { color: #4e9a06 } /* Literal.String.Heredoc */
|
|
||||||
.highlight .si { color: #4e9a06 } /* Literal.String.Interpol */
|
|
||||||
.highlight .sx { color: #4e9a06 } /* Literal.String.Other */
|
|
||||||
.highlight .sr { color: #4e9a06 } /* Literal.String.Regex */
|
|
||||||
.highlight .s1 { color: #4e9a06 } /* Literal.String.Single */
|
|
||||||
.highlight .ss { color: #4e9a06 } /* Literal.String.Symbol */
|
|
||||||
.highlight .bp { color: #3465a4 } /* Name.Builtin.Pseudo */
|
|
||||||
.highlight .fm { color: #000000 } /* Name.Function.Magic */
|
|
||||||
.highlight .vc { color: #000000 } /* Name.Variable.Class */
|
|
||||||
.highlight .vg { color: #000000 } /* Name.Variable.Global */
|
|
||||||
.highlight .vi { color: #000000 } /* Name.Variable.Instance */
|
|
||||||
.highlight .vm { color: #000000 } /* Name.Variable.Magic */
|
|
||||||
.highlight .il { color: #0000cf; font-weight: bold } /* 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 */
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@ -1,7 +0,0 @@
|
|||||||
/*!
|
|
||||||
* gumshoejs v5.1.2 (patched by @pradyunsg)
|
|
||||||
* A simple, framework-agnostic scrollspy script.
|
|
||||||
* (c) 2019 Chris Ferdinandi
|
|
||||||
* MIT License
|
|
||||||
* http://github.com/cferdinandi/gumshoe
|
|
||||||
*/
|
|
||||||
@ -1,620 +0,0 @@
|
|||||||
/*
|
|
||||||
* searchtools.js
|
|
||||||
* ~~~~~~~~~~~~~~~~
|
|
||||||
*
|
|
||||||
* Sphinx JavaScript utilities for the full-text search.
|
|
||||||
*
|
|
||||||
* :copyright: Copyright 2007-2024 by the Sphinx team, see AUTHORS.
|
|
||||||
* :license: BSD, see LICENSE for details.
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
"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] = 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,
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
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] = item;
|
|
||||||
|
|
||||||
let listItem = document.createElement("li");
|
|
||||||
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 = _(
|
|
||||||
"Search finished, found ${resultCount} page(s) matching the search query."
|
|
||||||
).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].
|
|
||||||
// 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.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].
|
|
||||||
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],
|
|
||||||
]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// 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],
|
|
||||||
];
|
|
||||||
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]],
|
|
||||||
]);
|
|
||||||
};
|
|
||||||
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],
|
|
||||||
]);
|
|
||||||
}
|
|
||||||
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);
|
|
||||||
296
BlenderDocumentation/_static/skeleton.css
vendored
@ -1,296 +0,0 @@
|
|||||||
/* 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;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@ -1,154 +0,0 @@
|
|||||||
/* Highlighting utilities for Sphinx HTML documentation. */
|
|
||||||
"use strict";
|
|
||||||
|
|
||||||
const SPHINX_HIGHLIGHT_ENABLED = true
|
|
||||||
|
|
||||||
/**
|
|
||||||
* highlight a given string on a node by wrapping it in
|
|
||||||
* span elements with the given class name.
|
|
||||||
*/
|
|
||||||
const _highlight = (node, addItems, text, className) => {
|
|
||||||
if (node.nodeType === Node.TEXT_NODE) {
|
|
||||||
const val = node.nodeValue;
|
|
||||||
const parent = node.parentNode;
|
|
||||||
const pos = val.toLowerCase().indexOf(text);
|
|
||||||
if (
|
|
||||||
pos >= 0 &&
|
|
||||||
!parent.classList.contains(className) &&
|
|
||||||
!parent.classList.contains("nohighlight")
|
|
||||||
) {
|
|
||||||
let span;
|
|
||||||
|
|
||||||
const closestNode = parent.closest("body, svg, foreignObject");
|
|
||||||
const isInSVG = closestNode && closestNode.matches("svg");
|
|
||||||
if (isInSVG) {
|
|
||||||
span = document.createElementNS("http://www.w3.org/2000/svg", "tspan");
|
|
||||||
} else {
|
|
||||||
span = document.createElement("span");
|
|
||||||
span.classList.add(className);
|
|
||||||
}
|
|
||||||
|
|
||||||
span.appendChild(document.createTextNode(val.substr(pos, text.length)));
|
|
||||||
const rest = document.createTextNode(val.substr(pos + text.length));
|
|
||||||
parent.insertBefore(
|
|
||||||
span,
|
|
||||||
parent.insertBefore(
|
|
||||||
rest,
|
|
||||||
node.nextSibling
|
|
||||||
)
|
|
||||||
);
|
|
||||||
node.nodeValue = val.substr(0, pos);
|
|
||||||
/* There may be more occurrences of search term in this node. So call this
|
|
||||||
* function recursively on the remaining fragment.
|
|
||||||
*/
|
|
||||||
_highlight(rest, addItems, text, className);
|
|
||||||
|
|
||||||
if (isInSVG) {
|
|
||||||
const rect = document.createElementNS(
|
|
||||||
"http://www.w3.org/2000/svg",
|
|
||||||
"rect"
|
|
||||||
);
|
|
||||||
const bbox = parent.getBBox();
|
|
||||||
rect.x.baseVal.value = bbox.x;
|
|
||||||
rect.y.baseVal.value = bbox.y;
|
|
||||||
rect.width.baseVal.value = bbox.width;
|
|
||||||
rect.height.baseVal.value = bbox.height;
|
|
||||||
rect.setAttribute("class", className);
|
|
||||||
addItems.push({ parent: parent, target: rect });
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else if (node.matches && !node.matches("button, select, textarea")) {
|
|
||||||
node.childNodes.forEach((el) => _highlight(el, addItems, text, className));
|
|
||||||
}
|
|
||||||
};
|
|
||||||
const _highlightText = (thisNode, text, className) => {
|
|
||||||
let addItems = [];
|
|
||||||
_highlight(thisNode, addItems, text, className);
|
|
||||||
addItems.forEach((obj) =>
|
|
||||||
obj.parent.insertAdjacentElement("beforebegin", obj.target)
|
|
||||||
);
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Small JavaScript module for the documentation.
|
|
||||||
*/
|
|
||||||
const SphinxHighlight = {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* highlight the search words provided in localstorage in the text
|
|
||||||
*/
|
|
||||||
highlightSearchWords: () => {
|
|
||||||
if (!SPHINX_HIGHLIGHT_ENABLED) return; // bail if no highlight
|
|
||||||
|
|
||||||
// get and clear terms from localstorage
|
|
||||||
const url = new URL(window.location);
|
|
||||||
const highlight =
|
|
||||||
localStorage.getItem("sphinx_highlight_terms")
|
|
||||||
|| url.searchParams.get("highlight")
|
|
||||||
|| "";
|
|
||||||
localStorage.removeItem("sphinx_highlight_terms")
|
|
||||||
url.searchParams.delete("highlight");
|
|
||||||
window.history.replaceState({}, "", url);
|
|
||||||
|
|
||||||
// get individual terms from highlight string
|
|
||||||
const terms = highlight.toLowerCase().split(/\s+/).filter(x => x);
|
|
||||||
if (terms.length === 0) return; // nothing to do
|
|
||||||
|
|
||||||
// There should never be more than one element matching "div.body"
|
|
||||||
const divBody = document.querySelectorAll("div.body");
|
|
||||||
const body = divBody.length ? divBody[0] : document.querySelector("body");
|
|
||||||
window.setTimeout(() => {
|
|
||||||
terms.forEach((term) => _highlightText(body, term, "highlighted"));
|
|
||||||
}, 10);
|
|
||||||
|
|
||||||
const searchBox = document.getElementById("searchbox");
|
|
||||||
if (searchBox === null) return;
|
|
||||||
searchBox.appendChild(
|
|
||||||
document
|
|
||||||
.createRange()
|
|
||||||
.createContextualFragment(
|
|
||||||
'<p class="highlight-link">' +
|
|
||||||
'<a href="javascript:SphinxHighlight.hideSearchWords()">' +
|
|
||||||
_("Hide Search Matches") +
|
|
||||||
"</a></p>"
|
|
||||||
)
|
|
||||||
);
|
|
||||||
},
|
|
||||||
|
|
||||||
/**
|
|
||||||
* helper function to hide the search marks again
|
|
||||||
*/
|
|
||||||
hideSearchWords: () => {
|
|
||||||
document
|
|
||||||
.querySelectorAll("#searchbox .highlight-link")
|
|
||||||
.forEach((el) => el.remove());
|
|
||||||
document
|
|
||||||
.querySelectorAll("span.highlighted")
|
|
||||||
.forEach((el) => el.classList.remove("highlighted"));
|
|
||||||
localStorage.removeItem("sphinx_highlight_terms")
|
|
||||||
},
|
|
||||||
|
|
||||||
initEscapeListener: () => {
|
|
||||||
// only install a listener if it is really needed
|
|
||||||
if (!DOCUMENTATION_OPTIONS.ENABLE_SEARCH_SHORTCUTS) return;
|
|
||||||
|
|
||||||
document.addEventListener("keydown", (event) => {
|
|
||||||
// bail for input elements
|
|
||||||
if (BLACKLISTED_KEY_CONTROL_ELEMENTS.has(document.activeElement.tagName)) return;
|
|
||||||
// bail with special keys
|
|
||||||
if (event.shiftKey || event.altKey || event.ctrlKey || event.metaKey) return;
|
|
||||||
if (DOCUMENTATION_OPTIONS.ENABLE_SEARCH_SHORTCUTS && (event.key === "Escape")) {
|
|
||||||
SphinxHighlight.hideSearchWords();
|
|
||||||
event.preventDefault();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
_ready(() => {
|
|
||||||
/* Do not call highlightSearchWords() when we are on the search page.
|
|
||||||
* It will highlight words from the *previous* search query.
|
|
||||||
*/
|
|
||||||
if (typeof Search === "undefined") SphinxHighlight.highlightSearchWords();
|
|
||||||
SphinxHighlight.initEscapeListener();
|
|
||||||
});
|
|
||||||