Skip to content

Commit

Permalink
Rollup merge of rust-lang#54921 - GuillaumeGomez:line-numbers, r=Quie…
Browse files Browse the repository at this point in the history
…tMisdreavus

Add line numbers option to rustdoc

Fixes rust-lang#22878.

r? @QuietMisdreavus
  • Loading branch information
pietroalbini authored Oct 25, 2018
2 parents b5596fa + e961d39 commit eed093c
Show file tree
Hide file tree
Showing 6 changed files with 68 additions and 14 deletions.
13 changes: 8 additions & 5 deletions src/librustdoc/html/highlight.rs
Original file line number Diff line number Diff line change
Expand Up @@ -28,9 +28,12 @@ use syntax::parse;
use syntax_pos::{Span, FileName};

/// Highlights `src`, returning the HTML output.
pub fn render_with_highlighting(src: &str, class: Option<&str>,
extension: Option<&str>,
tooltip: Option<(&str, &str)>) -> String {
pub fn render_with_highlighting(
src: &str,
class: Option<&str>,
extension: Option<&str>,
tooltip: Option<(&str, &str)>,
) -> String {
debug!("highlighting: ================\n{}\n==============", src);
let sess = parse::ParseSess::new(FilePathMapping::empty());
let fm = sess.source_map().new_source_file(FileName::Custom("stdin".to_string()),
Expand Down Expand Up @@ -384,9 +387,9 @@ impl Class {
}

fn write_header(class: Option<&str>, out: &mut dyn Write) -> io::Result<()> {
write!(out, "<pre class=\"rust {}\">\n", class.unwrap_or(""))
write!(out, "<div class=\"example-wrap\"><pre class=\"rust {}\">\n", class.unwrap_or(""))
}

fn write_footer(out: &mut dyn Write) -> io::Result<()> {
write!(out, "</pre>\n")
write!(out, "</pre></div>\n")
}
1 change: 1 addition & 0 deletions src/librustdoc/html/render.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1709,6 +1709,7 @@ impl<'a> Settings<'a> {
("method-docs", "Auto-hide item methods' documentation", false),
("go-to-only-result", "Directly go to item in search if there is only one result",
false),
("line-numbers", "Show line numbers on code examples", false),
],
root_path,
suffix,
Expand Down
42 changes: 33 additions & 9 deletions src/librustdoc/html/static/main.js
Original file line number Diff line number Diff line change
Expand Up @@ -2093,6 +2093,7 @@
return wrapper;
}

var hideItemDeclarations = getCurrentValue('rustdoc-item-declarations') === "false";
onEach(document.getElementsByClassName('docblock'), function(e) {
if (hasClass(e, 'autohide')) {
var wrap = e.previousElementSibling;
Expand All @@ -2116,16 +2117,14 @@
}
}
if (e.parentNode.id === "main") {
var otherMessage;
var otherMessage = '';
var fontSize;
var extraClass;
var show = true;

if (hasClass(e, "type-decl")) {
fontSize = "20px";
otherMessage = '&nbsp;Show&nbsp;declaration';
show = getCurrentValue('rustdoc-item-declarations') === "false";
if (!show) {
if (hideItemDeclarations === false) {
extraClass = 'collapsed';
}
} else if (hasClass(e, "non-exhaustive")) {
Expand All @@ -2142,8 +2141,12 @@
extraClass = "marg-left";
}

e.parentNode.insertBefore(createToggle(otherMessage, fontSize, extraClass, show), e);
if (otherMessage && show) {
e.parentNode.insertBefore(createToggle(otherMessage,
fontSize,
extraClass,
hideItemDeclarations),
e);
if (otherMessage.length > 0 && hideItemDeclarations === true) {
collapseDocs(e.previousSibling.childNodes[0], "toggle");
}
}
Expand Down Expand Up @@ -2186,13 +2189,33 @@
});
}

// To avoid checking on "rustdoc-item-attributes" value on every loop...
var itemAttributesFunc = function() {};
if (getCurrentValue("rustdoc-item-attributes") !== "false") {
itemAttributesFunc = function(x) {
collapseDocs(x.previousSibling.childNodes[0], "toggle");
};
}
onEach(document.getElementById('main').getElementsByClassName('attributes'), function(i_e) {
i_e.parentNode.insertBefore(createToggleWrapper(toggle.cloneNode(true)), i_e);
if (getCurrentValue("rustdoc-item-attributes") !== "false") {
collapseDocs(i_e.previousSibling.childNodes[0], "toggle");
}
itemAttributesFunc(i_e);
});

// To avoid checking on "rustdoc-line-numbers" value on every loop...
var lineNumbersFunc = function() {};
if (getCurrentValue("rustdoc-line-numbers") === "true") {
lineNumbersFunc = function(x) {
var count = x.textContent.split('\n').length;
var elems = [];
for (var i = 0; i < count; ++i) {
elems.push(i + 1);
}
var node = document.createElement('pre');
addClass(node, 'line-number');
node.innerHTML = elems.join('\n');
x.parentNode.insertBefore(node, x);
};
}
onEach(document.getElementsByClassName('rust-example-rendered'), function(e) {
if (hasClass(e, 'compile_fail')) {
e.addEventListener("mouseover", function(event) {
Expand All @@ -2209,6 +2232,7 @@
e.previousElementSibling.childNodes[0].style.color = '';
});
}
lineNumbersFunc(e);
});

function showModal(content) {
Expand Down
18 changes: 18 additions & 0 deletions src/librustdoc/html/static/rustdoc.css
Original file line number Diff line number Diff line change
Expand Up @@ -282,6 +282,24 @@ nav.sub {
padding-left: 0;
}

.example-wrap {
display: inline-flex;
width: 100%;
}

.example-wrap > pre.line-number {
overflow: initial;
border: 1px solid;
border-top-left-radius: 5px;
border-bottom-left-radius: 5px;
padding: 13px 8px;
text-align: right;
}

.example-wrap > pre.rust {
width: 100%;
}

#search {
margin-left: 230px;
position: relative;
Expand Down
4 changes: 4 additions & 0 deletions src/librustdoc/html/static/themes/dark.css
Original file line number Diff line number Diff line change
Expand Up @@ -233,6 +233,10 @@ pre.rust .question-mark {
color: #ff9011;
}

.example-wrap > pre.line-number {
border-color: #4a4949;
}

a.test-arrow {
background-color: rgba(78, 139, 202, 0.2);
}
Expand Down
4 changes: 4 additions & 0 deletions src/librustdoc/html/static/themes/light.css
Original file line number Diff line number Diff line change
Expand Up @@ -227,6 +227,10 @@ pre.rust .question-mark {
color: #ff9011;
}

.example-wrap > pre.line-number {
border-color: #c7c7c7;
}

a.test-arrow {
background-color: rgba(78, 139, 202, 0.2);
}
Expand Down

0 comments on commit eed093c

Please sign in to comment.