diff options
| author | Guillaume Gomez <guillaume1.gomez@gmail.com> | 2017-09-09 15:33:57 +0200 |
|---|---|---|
| committer | Guillaume Gomez <guillaume1.gomez@gmail.com> | 2017-09-11 22:31:37 +0200 |
| commit | 79f888da6810e9e38918f524b0882b8eaf40e5a1 (patch) | |
| tree | a5a9ea6c0f25f10e1d3344e6b49d47c8fe4a0839 | |
| parent | 9c12e5d4e8c1211783e2c9e6f6cc1fd0091b8724 (diff) | |
| download | rust-79f888da6810e9e38918f524b0882b8eaf40e5a1.tar.gz rust-79f888da6810e9e38918f524b0882b8eaf40e5a1.zip | |
Add arrow and improve display
| -rw-r--r-- | src/librustdoc/html/highlight.rs | 11 | ||||
| -rw-r--r-- | src/librustdoc/html/markdown.rs | 30 | ||||
| -rw-r--r-- | src/librustdoc/html/render.rs | 3 | ||||
| -rw-r--r-- | src/librustdoc/html/static/main.js | 18 | ||||
| -rw-r--r-- | src/librustdoc/html/static/rustdoc.css | 42 | ||||
| -rw-r--r-- | src/librustdoc/html/static/styles/main.css | 30 |
6 files changed, 98 insertions, 36 deletions
diff --git a/src/librustdoc/html/highlight.rs b/src/librustdoc/html/highlight.rs index cc1da35a997..081f950e40d 100644 --- a/src/librustdoc/html/highlight.rs +++ b/src/librustdoc/html/highlight.rs @@ -22,7 +22,6 @@ use html::escape::Escape; -use std::collections::HashMap; use std::fmt::Display; use std::io; use std::io::prelude::*; @@ -36,7 +35,7 @@ use syntax_pos::Span; /// Highlights `src`, returning the HTML output. pub fn render_with_highlighting(src: &str, class: Option<&str>, id: Option<&str>, extension: Option<&str>, - extras: Option<HashMap<String, String>>) -> String { + tooltip: Option<(&str, &str)>) -> String { debug!("highlighting: ================\n{}\n==============", src); let sess = parse::ParseSess::new(FilePathMapping::empty()); let fm = sess.codemap().new_filemap("<stdin>".to_string(), src.to_string()); @@ -396,18 +395,12 @@ impl Class { fn write_header(class: Option<&str>, id: Option<&str>, - out: &mut Write, - extras: Option<HashMap<String, String>>) + out: &mut Write) -> io::Result<()> { write!(out, "<pre ")?; if let Some(id) = id { write!(out, "id='{}' ", id)?; } - if let Some(extras) = extras { - for (key, value) in &extras { - write!(out, "{}=\"{}\" ", key, value)?; - } - } write!(out, "class=\"rust {}\">\n", class.unwrap_or("")) } diff --git a/src/librustdoc/html/markdown.rs b/src/librustdoc/html/markdown.rs index d9fb35c4c26..3b03acf9908 100644 --- a/src/librustdoc/html/markdown.rs +++ b/src/librustdoc/html/markdown.rs @@ -225,16 +225,10 @@ impl<'a, I: Iterator<Item = Event<'a>>> Iterator for CodeBlocks<'a, I> { url, test_escaped, channel )) }); - let title = if ignore { - let mut tmp = HashMap::new(); - tmp.insert("title".to_owned(), - "Be careful when using this code, it's not being tested!".to_owned()); - Some(tmp) + let tooltip = if ignore { + Some(("Be careful when using this code, it's not being tested!", "ignore")) } else if compile_fail { - let mut tmp = HashMap::new(); - tmp.insert("title".to_owned(), - "This code doesn't compile so be extra careful!".to_owned()); - Some(tmp) + Some(("This code doesn't compile so be extra careful!", "compile_fail")) } else { None }; @@ -246,7 +240,7 @@ impl<'a, I: Iterator<Item = Event<'a>>> Iterator for CodeBlocks<'a, I> { else { "" })), None, playground_button.as_ref().map(String::as_str), - title)); + tooltip)); Some(Event::Html(s.into())) }) } @@ -642,18 +636,10 @@ pub fn render(w: &mut fmt::Formatter, url, test_escaped, channel )) }); - let title = if ignore { - let mut tmp = HashMap::new(); - tmp.insert("title".to_owned(), - "Be careful when using this code, it's not being \ - tested!".to_owned()); - Some(tmp) + let tooltip = if ignore { + Some(("Be careful when using this code, it's not being tested!", "ignore")) } else if compile_fail { - let mut tmp = HashMap::new(); - tmp.insert("title".to_owned(), - "This code doesn't compile so be extra \ - careful!".to_owned()); - Some(tmp) + Some(("This code doesn't compile so be extra careful!", "compile_fail")) } else { None }; @@ -665,7 +651,7 @@ pub fn render(w: &mut fmt::Formatter, else { "" })), None, playground_button.as_ref().map(String::as_str), - title)); + tooltip)); hoedown_buffer_put(ob, s.as_ptr(), s.len()); }) } diff --git a/src/librustdoc/html/render.rs b/src/librustdoc/html/render.rs index f911ddb4d4f..993462a8d44 100644 --- a/src/librustdoc/html/render.rs +++ b/src/librustdoc/html/render.rs @@ -3679,7 +3679,8 @@ impl<'a> fmt::Display for Source<'a> { write!(fmt, "<span id=\"{0}\">{0:1$}</span>\n", i, cols)?; } write!(fmt, "</pre>")?; - write!(fmt, "{}", highlight::render_with_highlighting(s, None, None, None, None))?; + write!(fmt, "{}", + highlight::render_with_highlighting(s, None, None, None, None))?; Ok(()) } } diff --git a/src/librustdoc/html/static/main.js b/src/librustdoc/html/static/main.js index 8ec9cd8660a..da4430d8a15 100644 --- a/src/librustdoc/html/static/main.js +++ b/src/librustdoc/html/static/main.js @@ -1296,6 +1296,24 @@ collapseDocs(i_e.previousSibling.childNodes[0]); }); }); + + onEach(document.getElementsByClassName('rust-example-rendered'), function(e) { + if (hasClass(e, 'compile_fail')) { + e.addEventListener("mouseover", function(event) { + e.previousElementSibling.childNodes[0].style.color = '#f00'; + }); + e.addEventListener("mouseout", function(event) { + e.previousElementSibling.childNodes[0].style.color = ''; + }); + } else if (hasClass(e, 'ignore')) { + e.addEventListener("mouseover", function(event) { + e.previousElementSibling.childNodes[0].style.color = '#ff9200'; + }); + e.addEventListener("mouseout", function(event) { + e.previousElementSibling.childNodes[0].style.color = ''; + }); + } + }); }()); // Sets the focus on the search bar at the top of the page diff --git a/src/librustdoc/html/static/rustdoc.css b/src/librustdoc/html/static/rustdoc.css index ca55d0e5d2a..c15051376bf 100644 --- a/src/librustdoc/html/static/rustdoc.css +++ b/src/librustdoc/html/static/rustdoc.css @@ -612,7 +612,6 @@ pre.rust .question-mark { font-weight: bold; } -pre.rust { position: relative; } a.test-arrow { display: inline-block; position: absolute; @@ -813,3 +812,44 @@ span.since { display: none; } } + +.information { + position: absolute; + left: -1px; + margin-top: 7px; +} + +.tooltip { + position: relative; + display: inline-block; + cursor: pointer; +} + +.tooltip .tooltiptext { + width: 120px; + display: none; + background-color: black; + color: #fff; + text-align: center; + padding: 5px 3px; + border-radius: 6px; + margin-left: 5px; + top: -5px; + left: 105%; + z-index: 1; +} + +.tooltip:hover .tooltiptext { + display: inline; +} + +.tooltip .tooltiptext::after { + content: " "; + position: absolute; + top: 50%; + left: 11px; + margin-top: -5px; + border-width: 5px; + border-style: solid; + border-color: transparent black transparent transparent; +} diff --git a/src/librustdoc/html/static/styles/main.css b/src/librustdoc/html/static/styles/main.css index 18b40b3d60c..42d0ec704f4 100644 --- a/src/librustdoc/html/static/styles/main.css +++ b/src/librustdoc/html/static/styles/main.css @@ -205,9 +205,33 @@ a.test-arrow:hover{ } pre.compile_fail { - box-shadow: -6px 0 5px -3px #f00; + border-left: 2px solid rgba(255,0,0,.4); +} + +pre.compile_fail:hover, .information:hover + pre.compile_fail { + border-left: 2px solid #f00; } pre.ignore { - box-shadow: -6px 0 5px -3px #ff9200; -} \ No newline at end of file + border-left: 2px solid rgba(255,142,0,.4); +} + +pre.ignore:hover, .information:hover + pre.ignore { + border-left: 2px solid #ff9200; +} + +.tooltip.compile_fail { + color: rgba(255,0,0,.3); +} + +.information > .compile_fail:hover { + color: #f00; +} + +.tooltip.ignore { + color: rgba(255,142,0,.3); +} + +.information > .ignore:hover { + color: rgba(255,142,0,1); +} |
