16a6ebd1f6
This pulls all of our long-form documentation into a single document, nicknamed "the book" and formally titled "The Rust Programming Language." A few things motivated this change: * People knew of The Guide, but not the individual Guides. This merges them together, helping discoverability. * You can get all of Rust's longform documentation in one place, which is nice. * We now have rustbook in-tree, which can generate this kind of documentation. While its style is basic, the general idea is much better: a table of contents on the left-hand side. * Rather than a almost 10,000-line guide.md, there are now smaller files per section.
76 lines
2.5 KiB
Rust
76 lines
2.5 KiB
Rust
// Copyright 2014 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.
|
|
|
|
//! Implementation of the `test` subcommand. Just a stub for now.
|
|
|
|
use subcommand::Subcommand;
|
|
use error::CliResult;
|
|
use error::CommandResult;
|
|
use error::Error;
|
|
use term::Term;
|
|
use book;
|
|
use std::io::{Command, File};
|
|
use std::os;
|
|
|
|
struct Test;
|
|
|
|
pub fn parse_cmd(name: &str) -> Option<Box<Subcommand>> {
|
|
if name == "test" {
|
|
Some(box Test as Box<Subcommand>)
|
|
} else {
|
|
None
|
|
}
|
|
}
|
|
|
|
impl Subcommand for Test {
|
|
fn parse_args(&mut self, _: &[String]) -> CliResult<()> {
|
|
Ok(())
|
|
}
|
|
fn usage(&self) {}
|
|
fn execute(&mut self, term: &mut Term) -> CommandResult<()> {
|
|
let cwd = os::getcwd().unwrap();
|
|
let src = cwd.clone();
|
|
|
|
let summary = File::open(&src.join("SUMMARY.md"));
|
|
match book::parse_summary(summary, &src) {
|
|
Ok(book) => {
|
|
for (_, item) in book.iter() {
|
|
let output_result = Command::new("rustdoc")
|
|
.arg(&item.path)
|
|
.arg("--test")
|
|
.output();
|
|
match output_result {
|
|
Ok(output) => {
|
|
if !output.status.success() {
|
|
term.err(&format!("{}\n{}",
|
|
String::from_utf8_lossy(&output.output[]),
|
|
String::from_utf8_lossy(&output.error[]))[]);
|
|
return Err(box "Some tests failed." as Box<Error>);
|
|
}
|
|
|
|
}
|
|
Err(e) => {
|
|
let message = format!("Could not execute `rustdoc`: {}", e);
|
|
return Err(box message as Box<Error>);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
Err(errors) => {
|
|
for err in errors.into_iter() {
|
|
term.err(&err[]);
|
|
}
|
|
return Err(box "There was an error." as Box<Error>);
|
|
}
|
|
}
|
|
Ok(()) // lol
|
|
}
|
|
}
|