diff --git a/doc/favicon.inc b/doc/favicon.inc
new file mode 100644
index 0000000000000..8dd05620e48f6
--- /dev/null
+++ b/doc/favicon.inc
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/doc/manual.inc b/doc/manual.inc
index 783679d0ea5fd..a60ef803b5f8a 100644
--- a/doc/manual.inc
+++ b/doc/manual.inc
@@ -4,4 +4,9 @@
display: block;
padding-left: 2em;
}
-
\ No newline at end of file
+ #influences blockquote p:last-child {
+ display: block;
+ line-height: 1.428571429;
+ color: #999999;
+ }
+
diff --git a/doc/rust.css b/doc/rust.css
index 26135edd8bead..8b95a5860300c 100644
--- a/doc/rust.css
+++ b/doc/rust.css
@@ -2,7 +2,7 @@
* Copyright 2013 The Rust Project Developers. See the COPYRIGHT
* file at the top-level directory of this distribution and at
* http://rust-lang.org/COPYRIGHT.
- * With elements taken from Bootstrap v3.0.0 (Apache v2.0 licensed).
+ * With elements taken from Bootstrap v3.0.2 (MIT licensed).
*
* Licensed under the Apache License, Version 2.0 or the MIT license
@@ -93,6 +93,7 @@ p {
a {
text-decoration: none;
color: #428BCA;
+ background: transparent;
}
a:hover, a:focus {
color: #2A6496;
@@ -114,7 +115,7 @@ h5 a:link, h5 a:visited {color: black;}
/* Code
========================================================================== */
pre, code {
- font-family: Monaco, Menlo, Consolas, "Courier New", monospace;
+ font-family: Menlo, Monaco, Consolas, "Courier New", monospace;
border-radius: 4px;
}
pre {
@@ -141,7 +142,7 @@ pre code {
color: inherit;
white-space: pre-wrap;
background-color: transparent;
- border: 0;
+ border-radius: 0;
}
/* Code highlighting */
@@ -158,7 +159,7 @@ pre code {
.cm-s-default span.cm-string {color: #a11;}
.cm-s-default span.cm-string-2 {color: #f50;}
.cm-s-default span.cm-meta {color: #555;}
-.cm-s-default span.cm-error {color: #f00;}
+/*.cm-s-default span.cm-error {color: #f00;}*/
.cm-s-default span.cm-qualifier {color: #555;}
.cm-s-default span.cm-builtin {color: #30a;}
.cm-s-default span.cm-bracket {color: #cc7;}
@@ -187,7 +188,7 @@ pre code {
}
#versioninfo a.hash {
color: gray;
- font-size: 60%;
+ font-size: 70%;
}
blockquote {
@@ -303,4 +304,4 @@ hr {
table td, table th {
background-color: #fff !important;
}
-}
\ No newline at end of file
+}
diff --git a/doc/tutorial-macros.md b/doc/tutorial-macros.md
index f1f4ade0542d5..4117faa1a6b81 100644
--- a/doc/tutorial-macros.md
+++ b/doc/tutorial-macros.md
@@ -210,10 +210,10 @@ solves the problem.
# Macro argument pattern matching
-Now consider code like the following:
-
## Motivation
+Now consider code like the following:
+
~~~~
# enum t1 { good_1(t2, uint), bad_1 };
# pub struct t2 { body: t3 }
diff --git a/doc/tutorial-rustpkg.md b/doc/tutorial-rustpkg.md
index fb15e0c0cf298..daacd4ab76bf4 100644
--- a/doc/tutorial-rustpkg.md
+++ b/doc/tutorial-rustpkg.md
@@ -27,7 +27,6 @@ $ rustc main.rs
main.rs:1:0: 1:17 error: can't find crate for `hello`
main.rs:1 extern mod hello;
^~~~~~~~~~~~~~~~~
-
~~~~
This makes sense, as we haven't gotten it from anywhere yet! Luckily for us,
@@ -216,7 +215,7 @@ a function that can be sensibly tested:
#[license = "MIT"];
pub fn is_even(i: uint) -> bool {
- i % 2 == 0
+ i % 2 == 0
}
~~~
@@ -230,9 +229,9 @@ use hello::is_even;
#[test]
fn test_is_even() {
- assert!(is_even(0));
- assert!(!is_even(1));
- assert!(is_even(2));
+ assert!(is_even(0));
+ assert!(!is_even(1));
+ assert!(is_even(2));
}
~~~
diff --git a/doc/tutorial-tasks.md b/doc/tutorial-tasks.md
index 4983a5af3e5ab..93c2b124fa545 100644
--- a/doc/tutorial-tasks.md
+++ b/doc/tutorial-tasks.md
@@ -104,8 +104,8 @@ an environment that it carries across tasks.
let child_task_number = generate_task_number();
do spawn {
- // Capture it in the remote task
- println!("I am child number {}", child_task_number);
+ // Capture it in the remote task
+ println!("I am child number {}", child_task_number);
}
~~~
diff --git a/doc/tutorial.md b/doc/tutorial.md
index 5f805b39f238b..5e238c5911def 100644
--- a/doc/tutorial.md
+++ b/doc/tutorial.md
@@ -804,7 +804,7 @@ confusing numbers that correspond to different units.
We've already seen several function definitions. Like all other static
declarations, such as `type`, functions can be declared both at the
top level and inside other functions (or in modules, which we'll come
-back to [later](#modules-and-crates)). The `fn` keyword introduces a
+back to [later](#crates-and-the-module-system)). The `fn` keyword introduces a
function. A function has an argument list, which is a parenthesized
list of `expr: type` pairs separated by commas. An arrow `->`
separates the argument list and the function's return type.
@@ -2711,10 +2711,10 @@ extend with the `-L` switch).
However, Rust also ships with rustpkg, a package manager that is able to automatically download and build
libraries if you use it for building your crate. How it works is explained [here][rustpkg],
but for this tutorial it's only important to know that you can optionally annotate an
-`extern mod` statement with an package id that rustpkg can use to identify it:
+`extern mod` statement with a package id that rustpkg can use to identify it:
~~~ {.ignore}
-extern mod rust = "github.com/mozilla/rust"; // pretend Rust is an simple library
+extern mod rust = "github.com/mozilla/rust"; // pretend Rust is a simple library
~~~
[rustpkg]: rustpkg.html
@@ -2730,7 +2730,7 @@ the link name and the version. It also hashes the filename and the symbols in a
based on the link metadata, allowing you to use two different versions of the same library in a crate
without conflict.
-Therefor, if you plan to compile your crate as a library, you should annotate it with that information:
+Therefore, if you plan to compile your crate as a library, you should annotate it with that information:
~~~~
// lib.rs
@@ -2746,8 +2746,8 @@ Therefor, if you plan to compile your crate as a library, you should annotate it
You can also in turn require in a `extern mod` statement that certain link metadata items match some criteria.
For that, Rust currently parses a comma-separated list of name/value pairs that appear after
it, and ensures that they match the attributes provided in the `link` attribute of a crate file.
-This enables you to, eg, pick a a crate based on it's version number, or to link an library under an
-different name. For example, this two mod statements would both accept and select the crate define above:
+This enables you to, e.g., pick a crate based on its version number, or link a library under a
+different name. For example, these two `mod` statements would both accept and select the crate define above:
~~~~ {.xfail-test}
extern mod farm(vers = "2.5");
@@ -2836,14 +2836,14 @@ This allows you to use common types and functions like `Option` or `println`
without needing to import them. And if you need something from `std` that's not in the prelude,
you just have to import it with an `use` statement.
-For example, it re-exports `println` which is defined in `std::io::println`:
+For example, it re-exports `println` which is defined in `std::io::stdio::println`:
~~~
use puts = std::io::stdio::println;
fn main() {
println("println is imported per default.");
- puts("Doesn't hinder you from importing it under an different name yourself.");
+ puts("Doesn't hinder you from importing it under a different name yourself.");
::std::io::stdio::println("Or from not using the automatic import.");
}
~~~
diff --git a/mk/docs.mk b/mk/docs.mk
index 621d283ee5da3..a7ffe928940f5 100644
--- a/mk/docs.mk
+++ b/mk/docs.mk
@@ -15,6 +15,10 @@
DOCS :=
DOCS_L10N :=
+BASE_DOC_OPTS := --from=markdown --standalone --toc --number-sections --include-before-body=doc/version_info.html
+HTML_OPTS = $(BASE_DOC_OPTS) --to=html5 --section-divs --css=rust.css --include-in-header=doc/favicon.inc
+TEX_OPTS = $(BASE_DOC_OPTS) --to=latex
+EPUB_OPTS = $(BASE_DOC_OPTS) --to=epub
######################################################################
# Docs, from pandoc, rustdoc (which runs pandoc), and node
@@ -28,6 +32,10 @@ doc/manual.inc: manual.inc
@$(call E, cp: $@)
$(Q)cp -a $< $@ 2> /dev/null
+doc/favicon.inc: favicon.inc
+ @$(call E, cp: $@)
+ $(Q)cp -a $< $@ 2> /dev/null
+
ifeq ($(CFG_PANDOC),)
$(info cfg: no pandoc found, omitting docs)
NO_DOCS = 1
@@ -41,86 +49,49 @@ endif
ifneq ($(NO_DOCS),1)
DOCS += doc/rust.html
-doc/rust.html: rust.md doc/version_info.html doc/rust.css doc/manual.inc
+doc/rust.html: rust.md doc/version_info.html doc/rust.css doc/manual.inc \
+ doc/favicon.inc
@$(call E, pandoc: $@)
$(Q)$(CFG_NODE) $(S)doc/prep.js --highlight $< | \
- "$(CFG_PANDOC)" \
- --standalone --toc \
- --section-divs \
- --number-sections \
- --from=markdown --to=html5 \
- --css=rust.css --include-in-header=doc/manual.inc \
- --include-before-body=doc/version_info.html \
- --output=$@
+ $(CFG_PANDOC) $(HTML_OPTS) --include-in-header=doc/manual.inc --output=$@
DOCS += doc/rust.tex
doc/rust.tex: rust.md doc/version.md
@$(call E, pandoc: $@)
$(Q)$(CFG_NODE) $(S)doc/prep.js $< | \
- "$(CFG_PANDOC)" \
- --standalone --toc \
- --number-sections \
- --include-before-body=doc/version.md \
- --from=markdown --to=latex \
- --output=$@
+ $(CFG_PANDOC) $(TEX_OPTS) --output=$@
DOCS += doc/rust.epub
-doc/rust.epub: rust.md doc/version_info.html doc/rust.css doc/manual.inc
+doc/rust.epub: rust.md doc/version_info.html doc/rust.css
@$(call E, pandoc: $@)
$(Q)$(CFG_NODE) $(S)doc/prep.js --highlight $< | \
- "$(CFG_PANDOC)" \
- --standalone --toc \
- --section-divs \
- --number-sections \
- --from=markdown --to=epub \
- --css=rust.css --include-in-header=doc/manual.inc \
- --include-before-body=doc/version_info.html \
- --output=$@
-
-
-DOCS += doc/tutorial.tex
-doc/tutorial.tex: tutorial.md doc/version.md
- @$(call E, pandoc: $@)
- $(Q)$(CFG_NODE) $(S)doc/prep.js $< | \
- "$(CFG_PANDOC)" \
- --standalone --toc \
- --number-sections \
- --include-before-body=doc/version.md \
- --from=markdown --to=latex \
- --output=$@
+ $(CFG_PANDOC) $(EPUB_OPTS) --output=$@
DOCS += doc/rustpkg.html
-doc/rustpkg.html: rustpkg.md doc/version_info.html doc/rust.css doc/manual.inc
+doc/rustpkg.html: rustpkg.md doc/version_info.html doc/rust.css \
+ doc/favicon.inc
@$(call E, pandoc: $@)
$(Q)$(CFG_NODE) $(S)doc/prep.js --highlight $< | \
- "$(CFG_PANDOC)" \
- --standalone --toc \
- --section-divs \
- --number-sections \
- --from=markdown --to=html5 \
- --css=rust.css --include-in-header=doc/manual.inc \
- --include-before-body=doc/version_info.html \
- --output=$@
+ $(CFG_PANDOC) $(HTML_OPTS) --output=$@
DOCS += doc/tutorial.html
-doc/tutorial.html: tutorial.md doc/version_info.html doc/rust.css
+doc/tutorial.html: tutorial.md doc/version_info.html doc/rust.css \
+ doc/favicon.inc
@$(call E, pandoc: $@)
$(Q)$(CFG_NODE) $(S)doc/prep.js --highlight $< | \
- $(CFG_PANDOC) --standalone --toc \
- --section-divs --number-sections \
- --from=markdown --to=html5 --css=rust.css \
- --include-before-body=doc/version_info.html \
- --output=$@
+ $(CFG_PANDOC) $(HTML_OPTS) --output=$@
+
+DOCS += doc/tutorial.tex
+doc/tutorial.tex: tutorial.md doc/version.md
+ @$(call E, pandoc: $@)
+ $(Q)$(CFG_NODE) $(S)doc/prep.js $< | \
+ $(CFG_PANDOC) $(TEX_OPTS) --output=$@
DOCS += doc/tutorial.epub
doc/tutorial.epub: tutorial.md doc/version_info.html doc/rust.css
@$(call E, pandoc: $@)
$(Q)$(CFG_NODE) $(S)doc/prep.js --highlight $< | \
- $(CFG_PANDOC) --standalone --toc \
- --section-divs --number-sections \
- --from=markdown --to=epub --css=rust.css \
- --include-before-body=doc/version_info.html \
- --output=$@
+ $(CFG_PANDOC) $(EPUB_OPTS) --output=$@
DOCS_L10N += doc/l10n/ja/tutorial.html
@@ -134,75 +105,53 @@ doc/l10n/ja/tutorial.html: doc/l10n/ja/tutorial.md doc/version_info.html doc/rus
--output=$@
DOCS += doc/tutorial-macros.html
-doc/tutorial-macros.html: tutorial-macros.md doc/version_info.html \
- doc/rust.css
+doc/tutorial-macros.html: tutorial-macros.md doc/version_info.html doc/rust.css \
+ doc/favicon.inc
@$(call E, pandoc: $@)
$(Q)$(CFG_NODE) $(S)doc/prep.js --highlight $< | \
- $(CFG_PANDOC) --standalone --toc \
- --section-divs --number-sections \
- --from=markdown --to=html5 --css=rust.css \
- --include-before-body=doc/version_info.html \
- --output=$@
+ $(CFG_PANDOC) $(HTML_OPTS) --output=$@
DOCS += doc/tutorial-container.html
-doc/tutorial-container.html: tutorial-container.md doc/version_info.html doc/rust.css
+doc/tutorial-container.html: tutorial-container.md doc/version_info.html doc/rust.css \
+ doc/favicon.inc
@$(call E, pandoc: $@)
$(Q)$(CFG_NODE) $(S)doc/prep.js --highlight $< | \
- $(CFG_PANDOC) --standalone --toc \
- --section-divs --number-sections \
- --from=markdown --to=html5 --css=rust.css \
- --include-before-body=doc/version_info.html \
- --output=$@
+ $(CFG_PANDOC) $(HTML_OPTS) --output=$@
DOCS += doc/tutorial-ffi.html
-doc/tutorial-ffi.html: tutorial-ffi.md doc/version_info.html doc/rust.css
+doc/tutorial-ffi.html: tutorial-ffi.md doc/version_info.html doc/rust.css \
+ doc/favicon.inc
@$(call E, pandoc: $@)
$(Q)$(CFG_NODE) $(S)doc/prep.js --highlight $< | \
- $(CFG_PANDOC) --standalone --toc \
- --section-divs --number-sections \
- --from=markdown --to=html5 --css=rust.css \
- --include-before-body=doc/version_info.html \
- --output=$@
+ $(CFG_PANDOC) $(HTML_OPTS) --output=$@
DOCS += doc/tutorial-borrowed-ptr.html
-doc/tutorial-borrowed-ptr.html: tutorial-borrowed-ptr.md doc/version_info.html doc/rust.css
+doc/tutorial-borrowed-ptr.html: tutorial-borrowed-ptr.md doc/version_info.html doc/rust.css \
+ doc/favicon.inc
@$(call E, pandoc: $@)
$(Q)$(CFG_NODE) $(S)doc/prep.js --highlight $< | \
- $(CFG_PANDOC) --standalone --toc \
- --section-divs --number-sections \
- --from=markdown --to=html5 --css=rust.css \
- --include-before-body=doc/version_info.html \
- --output=$@
+ $(CFG_PANDOC) $(HTML_OPTS) --output=$@
DOCS += doc/tutorial-tasks.html
-doc/tutorial-tasks.html: tutorial-tasks.md doc/version_info.html doc/rust.css
+doc/tutorial-tasks.html: tutorial-tasks.md doc/version_info.html doc/rust.css \
+ doc/favicon.inc
@$(call E, pandoc: $@)
$(Q)$(CFG_NODE) $(S)doc/prep.js --highlight $< | \
- $(CFG_PANDOC) --standalone --toc \
- --section-divs --number-sections \
- --from=markdown --to=html5 --css=rust.css \
- --include-before-body=doc/version_info.html \
- --output=$@
+ $(CFG_PANDOC) $(HTML_OPTS) --output=$@
DOCS += doc/tutorial-conditions.html
-doc/tutorial-conditions.html: tutorial-conditions.md doc/version_info.html doc/rust.css
+doc/tutorial-conditions.html: tutorial-conditions.md doc/version_info.html doc/rust.css \
+ doc/favicon.inc
@$(call E, pandoc: $@)
$(Q)$(CFG_NODE) $(S)doc/prep.js --highlight $< | \
- $(CFG_PANDOC) --standalone --toc \
- --section-divs --number-sections \
- --from=markdown --to=html5 --css=rust.css \
- --include-before-body=doc/version_info.html \
- --output=$@
+ $(CFG_PANDOC) $(HTML_OPTS) --output=$@
DOCS += doc/tutorial-rustpkg.html
-doc/tutorial-rustpkg.html: tutorial-rustpkg.md doc/version_info.html doc/rust.css
+doc/tutorial-rustpkg.html: tutorial-rustpkg.md doc/version_info.html doc/rust.css \
+ doc/favicon.inc
@$(call E, pandoc: $@)
$(Q)$(CFG_NODE) $(S)doc/prep.js --highlight $< | \
- $(CFG_PANDOC) --standalone --toc \
- --section-divs --number-sections \
- --from=markdown --to=html5 --css=rust.css \
- --include-before-body=doc/version_info.html \
- --output=$@
+ $(CFG_PANDOC) $(HTML_OPTS) --output=$@
ifeq ($(CFG_PDFLATEX),)
$(info cfg: no pdflatex found, omitting doc/rust.pdf)
diff --git a/src/librustdoc/html/static/main.css b/src/librustdoc/html/static/main.css
index b1ef4dc829acc..80bdb0a9e4f9a 100644
--- a/src/librustdoc/html/static/main.css
+++ b/src/librustdoc/html/static/main.css
@@ -43,7 +43,13 @@ h2 code, h3 code, h4 code {
}
code, pre, h1.fqn {
- font: 15px Monaco, Menlo, "Inconsolata", Consolas, "Courier New", monospace;
+ font-family: Menlo, Monaco, Consolas, "Inconsolata", "Courier New", monospace;
+}
+code, pre {
+ color: #333;
+}
+pre {
+ font-size: 15px;
}
h1.fqn {
font-size: 26px;
@@ -215,6 +221,7 @@ nav, .content {
a {
text-decoration: none;
color: #000;
+ background: transparent;
}
.content a, .block a.current { font-weight: bold; }