>)
+ out: &mut Write)
-> io::Result<()> {
write!(out, "\n", class.unwrap_or(""))
}
diff --git a/src/librustdoc/html/markdown.rs b/src/librustdoc/html/markdown.rs
index d9fb35c4c269..3b03acf99081 100644
--- a/src/librustdoc/html/markdown.rs
+++ b/src/librustdoc/html/markdown.rs
@@ -225,16 +225,10 @@ impl<'a, I: Iterator- >> 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
- >> 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 f911ddb4d4f5..993462a8d444 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, "{0:1$}\n", i, cols)?;
}
write!(fmt, "
")?;
- 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 8ec9cd8660a8..da4430d8a153 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 ca55d0e5d2a8..c15051376bf2 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 18b40b3d60c1..42d0ec704f45 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);
+}