rustdoc: remove artificial indentation of doctest code

This makes the examples look nicer when printed (when is this
done?), but breaks tests using multi-line string literals.

Fixes: #25944
This commit is contained in:
Georg Brandl 2016-05-09 15:30:24 +02:00
parent 50909f2d50
commit 5606b42981
3 changed files with 23 additions and 2 deletions

View File

@ -32,7 +32,7 @@ include the newline and the leading spaces:
let s = "foo
bar";
assert_eq!("foo\n bar", s);
assert_eq!("foo\n bar", s);
```
The second, with a `\`, trims the spaces and the newline:

View File

@ -340,7 +340,7 @@ pub fn maketest(s: &str, cratename: Option<&str>, dont_insert_main: bool,
prog.push_str(&everything_else);
} else {
prog.push_str("fn main() {\n ");
prog.push_str(&everything_else.replace("\n", "\n "));
prog.push_str(&everything_else);
prog = prog.trim().into();
prog.push_str("\n}");
}

View File

@ -0,0 +1,21 @@
// Copyright 2016 The Rust Project Developers. See the COPYRIGHT
// file at the top-level directory of this distribution and at
// http://rust-lang.org/COPYRIGHT.
//
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
// option. This file may not be copied, modified, or distributed
// except according to those terms.
// compile-flags:--test
/// ```
/// let a = r#"
/// foo
/// bar"#;
/// let b = "\nfoo\nbar";
/// assert_eq!(a, b);
/// ```
pub fn main() {
}