diff --git a/src/librustdoc/html/render/write_shared.rs b/src/librustdoc/html/render/write_shared.rs index f529b2f2bfcd..4411b7771eda 100644 --- a/src/librustdoc/html/render/write_shared.rs +++ b/src/librustdoc/html/render/write_shared.rs @@ -126,16 +126,13 @@ impl Context<'_> { emit: &[EmitType], ) -> Result<(), Error> { let tmp; - let contents = - contents.replace("data-url(minus-17x17.png)", static_files::MINUS_PNG_DATAURL); - let contents = contents.replace("data-url(plus-17x17.png)", static_files::PLUS_PNG_DATAURL); let contents = if minify { tmp = if resource.extension() == Some(&OsStr::new("css")) { - minifier::css::minify(&contents).map_err(|e| { + minifier::css::minify(contents).map_err(|e| { Error::new(format!("failed to minify CSS file: {}", e), resource.path(self)) })? } else { - minifier::js::minify(&contents) + minifier::js::minify(contents) }; tmp.as_bytes() } else { @@ -178,9 +175,45 @@ pub(super) fn write_shared( cx.write_shared(SharedResource::InvocationSpecific { basename: p }, content, &options.emit) }; + fn add_background_image_to_css( + cx: &Context<'_>, + css: &mut String, + rule: &str, + file: &'static str, + ) { + css.push_str(&format!( + "{} {{ background-image: url({}); }}", + rule, + SharedResource::ToolchainSpecific { basename: file } + .path(cx) + .file_name() + .unwrap() + .to_str() + .unwrap() + )) + } + + // Add all the static files. These may already exist, but we just + // overwrite them anyway to make sure that they're fresh and up-to-date. + let mut rustdoc_css = static_files::RUSTDOC_CSS.to_owned(); + add_background_image_to_css( + cx, + &mut rustdoc_css, + "details.undocumented[open] > summary::before, \ + details.rustdoc-toggle[open] > summary::before, \ + details.rustdoc-toggle[open] > summary.hideme::before", + "toggle-minus.svg", + ); + add_background_image_to_css( + cx, + &mut rustdoc_css, + "details.undocumented > summary::before, details.rustdoc-toggle > summary::before", + "toggle-plus.svg", + ); + write_minify("rustdoc.css", &rustdoc_css)?; + // Add all the static files. These may already exist, but we just // overwrite them anyway to make sure that they're fresh and up-to-date. - write_minify("rustdoc.css", static_files::RUSTDOC_CSS)?; write_minify("settings.css", static_files::SETTINGS_CSS)?; write_minify("noscript.css", static_files::NOSCRIPT_CSS)?; @@ -220,6 +253,8 @@ pub(super) fn write_shared( write_toolchain("wheel.svg", static_files::WHEEL_SVG)?; write_toolchain("clipboard.svg", static_files::CLIPBOARD_SVG)?; write_toolchain("down-arrow.svg", static_files::DOWN_ARROW_SVG)?; + write_toolchain("toggle-minus.svg", static_files::TOGGLE_MINUS_PNG)?; + write_toolchain("toggle-plus.svg", static_files::TOGGLE_PLUS_PNG)?; let mut themes: Vec<&String> = themes.iter().collect(); themes.sort(); diff --git a/src/librustdoc/html/static/css/rustdoc.css b/src/librustdoc/html/static/css/rustdoc.css index 0754eeb9900d..4e33eab56500 100644 --- a/src/librustdoc/html/static/css/rustdoc.css +++ b/src/librustdoc/html/static/css/rustdoc.css @@ -1512,7 +1512,8 @@ details.rustdoc-toggle > summary::before { cursor: pointer; width: 17px; height: max(17px, 1.1em); - background: data-url(plus-17x17.png) no-repeat top left; + background-repeat: no-repeat; + background-position: top left; display: inline-block; vertical-align: middle; opacity: .5; @@ -1533,10 +1534,6 @@ details.rustdoc-toggle > summary.hideme::after { content: ""; } -details.rustdoc-toggle > summary:focus::before { - outline: dotted 1px; -} - details.rustdoc-toggle > summary:focus::before, details.rustdoc-toggle > summary:hover::before { opacity: 1; @@ -1591,7 +1588,8 @@ details.rustdoc-toggle[open] > summary::before, details.rustdoc-toggle[open] > summary.hideme::before { width: 17px; height: max(17px, 1.1em); - background: data-url(minus-17x17.png) no-repeat top left; + background-repeat: no-repeat; + background-position: top left; display: inline-block; content: ""; } @@ -1604,7 +1602,8 @@ details.rustdoc-toggle[open] > summary.hideme::after { details.undocumented > summary::before { padding-left: 17px; height: max(17px, 1.1em); - background: data-url(plus-17x17.png) no-repeat top left; + background-repeat: no-repeat; + background-position: top left; content: "Show hidden undocumented items"; cursor: pointer; font-size: 16px; @@ -1612,10 +1611,6 @@ details.undocumented > summary::before { opacity: .5; } -details.undocumented > summary:focus::before { - outline: dotted 1px; -} - details.undocumented > summary:focus::before, details.undocumented > summary:hover::before { opacity: 1; @@ -1624,7 +1619,8 @@ details.undocumented > summary:hover::before { details.undocumented[open] > summary::before { padding-left: 17px; height: max(17px, 1.1em); - background: data-url(minus-17x17.png) no-repeat top left; + background-repeat: no-repeat + background-position: top left; content: "Hide undocumented items"; } diff --git a/src/librustdoc/html/static/images/minus-17x17.png b/src/librustdoc/html/static/images/minus-17x17.png deleted file mode 100644 index 3cdbbf5033ec..000000000000 Binary files a/src/librustdoc/html/static/images/minus-17x17.png and /dev/null differ diff --git a/src/librustdoc/html/static/images/minus-17x17.png.url b/src/librustdoc/html/static/images/minus-17x17.png.url deleted file mode 100644 index a05bac5d875c..000000000000 --- a/src/librustdoc/html/static/images/minus-17x17.png.url +++ /dev/null @@ -1 +0,0 @@ -url() diff --git a/src/librustdoc/html/static/images/plus-17x17.png b/src/librustdoc/html/static/images/plus-17x17.png deleted file mode 100644 index fa996a147a52..000000000000 Binary files a/src/librustdoc/html/static/images/plus-17x17.png and /dev/null differ diff --git a/src/librustdoc/html/static/images/plus-17x17.png.url b/src/librustdoc/html/static/images/plus-17x17.png.url deleted file mode 100644 index dd0078d1ace7..000000000000 --- a/src/librustdoc/html/static/images/plus-17x17.png.url +++ /dev/null @@ -1 +0,0 @@ -url() diff --git a/src/librustdoc/html/static/images/toggle-minus.svg b/src/librustdoc/html/static/images/toggle-minus.svg new file mode 100644 index 000000000000..73154788a0e8 --- /dev/null +++ b/src/librustdoc/html/static/images/toggle-minus.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/src/librustdoc/html/static/images/toggle-plus.svg b/src/librustdoc/html/static/images/toggle-plus.svg new file mode 100644 index 000000000000..08b17033e164 --- /dev/null +++ b/src/librustdoc/html/static/images/toggle-plus.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/src/librustdoc/html/static_files.rs b/src/librustdoc/html/static_files.rs index db34d60638e8..6f3d08ea6556 100644 --- a/src/librustdoc/html/static_files.rs +++ b/src/librustdoc/html/static_files.rs @@ -47,6 +47,12 @@ crate static CLIPBOARD_SVG: &[u8] = include_bytes!("static/images/clipboard.svg" /// The file contents of `down-arrow.svg`, the icon used for the crate choice combobox. crate static DOWN_ARROW_SVG: &[u8] = include_bytes!("static/images/down-arrow.svg"); +/// The file contents of `toggle-minus.svg`, the icon used for opened toggles. +crate static TOGGLE_MINUS_PNG: &[u8] = include_bytes!("static/images/toggle-minus.svg"); + +/// The file contents of `toggle-plus.svg`, the icon used for closed toggles. +crate static TOGGLE_PLUS_PNG: &[u8] = include_bytes!("static/images/toggle-plus.svg"); + /// The contents of `COPYRIGHT.txt`, the license listing for files distributed with documentation /// output. crate static COPYRIGHT: &[u8] = include_bytes!("static/COPYRIGHT.txt"); @@ -64,10 +70,6 @@ crate static RUST_FAVICON_SVG: &[u8] = include_bytes!("static/images/favicon.svg crate static RUST_FAVICON_PNG_16: &[u8] = include_bytes!("static/images/favicon-16x16.png"); crate static RUST_FAVICON_PNG_32: &[u8] = include_bytes!("static/images/favicon-32x32.png"); -/// The pixel art buttons -crate static MINUS_PNG_DATAURL: &str = include_str!("static/images/minus-17x17.png.url"); -crate static PLUS_PNG_DATAURL: &str = include_str!("static/images/plus-17x17.png.url"); - crate static PAGE: &str = include_str!("templates/page.html"); /// The built-in themes given to every documentation site.