mirror of
https://github.com/rust-lang/mdBook
synced 2025-01-21 00:44:04 +00:00
Fleshed out the api docs
This commit is contained in:
parent
132f4fd358
commit
5cd5e4764c
2 changed files with 34 additions and 7 deletions
|
@ -5,6 +5,7 @@ extern crate clap;
|
||||||
|
|
||||||
use clap::{App, Arg, ArgMatches, SubCommand};
|
use clap::{App, Arg, ArgMatches, SubCommand};
|
||||||
use mdbook::preprocess::CmdPreprocessor;
|
use mdbook::preprocess::CmdPreprocessor;
|
||||||
|
use mdbook::book::Book;
|
||||||
use std::process;
|
use std::process;
|
||||||
use std::io;
|
use std::io;
|
||||||
|
|
||||||
|
@ -14,18 +15,21 @@ fn main() {
|
||||||
if let Some(sub_args) = matches.subcommand_matches("supports") {
|
if let Some(sub_args) = matches.subcommand_matches("supports") {
|
||||||
handle_supports(sub_args);
|
handle_supports(sub_args);
|
||||||
} else {
|
} else {
|
||||||
handle_preprocessing(&matches);
|
handle_preprocessing();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn handle_preprocessing(args: &ArgMatches) {
|
fn handle_preprocessing() {
|
||||||
let (ctx, book) = CmdPreprocessor::parse_input(io::stdin())
|
let (ctx, book) = CmdPreprocessor::parse_input(io::stdin())
|
||||||
.expect("Couldn't parse the input");
|
.expect("Couldn't parse the input");
|
||||||
|
|
||||||
eprintln!("{:?}", ctx.config);
|
// You can inspect the calling mdbook's version to check for compatibility
|
||||||
|
if ctx.mdbook_version != mdbook::MDBOOK_VERSION {
|
||||||
|
panic!("The version check failed!");
|
||||||
|
}
|
||||||
|
|
||||||
// You can tell the preprocessor to blow up by setting a particular
|
// In testing we want to tell the preprocessor to blow up by setting a
|
||||||
// config value
|
// particular config value
|
||||||
if let Some(table) = ctx.config.get_preprocessor("nop-preprocessor") {
|
if let Some(table) = ctx.config.get_preprocessor("nop-preprocessor") {
|
||||||
let should_blow_up = table.get("blow-up").is_some();
|
let should_blow_up = table.get("blow-up").is_some();
|
||||||
|
|
||||||
|
@ -34,13 +38,21 @@ fn handle_preprocessing(args: &ArgMatches) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
serde_json::to_writer(io::stdout(), &book).unwrap();
|
let processed_book = do_processing(book);
|
||||||
|
|
||||||
|
serde_json::to_writer(io::stdout(), &processed_book).unwrap();
|
||||||
|
}
|
||||||
|
|
||||||
|
fn do_processing(book: Book) -> Book {
|
||||||
|
// We *are* a nop preprocessor after all...
|
||||||
|
book
|
||||||
}
|
}
|
||||||
|
|
||||||
fn handle_supports(sub_args: &ArgMatches) {
|
fn handle_supports(sub_args: &ArgMatches) {
|
||||||
let renderer = sub_args.value_of("renderer").expect("Required argument");
|
let renderer = sub_args.value_of("renderer").expect("Required argument");
|
||||||
let supported = renderer_is_supported(&renderer);
|
let supported = renderer_is_supported(&renderer);
|
||||||
|
|
||||||
|
// Signal whether the renderer is supported by exiting with 1 or 0.
|
||||||
if supported {
|
if supported {
|
||||||
process::exit(0);
|
process::exit(0);
|
||||||
} else {
|
} else {
|
||||||
|
|
|
@ -8,12 +8,27 @@ use std::process::{Child, Command, Stdio};
|
||||||
|
|
||||||
/// A custom preprocessor which will shell out to a 3rd-party program.
|
/// A custom preprocessor which will shell out to a 3rd-party program.
|
||||||
///
|
///
|
||||||
/// # Preprocessing
|
/// # Preprocessing Protocol
|
||||||
///
|
///
|
||||||
/// When the `supports_renderer()` method is executed, `CmdPreprocessor` will
|
/// When the `supports_renderer()` method is executed, `CmdPreprocessor` will
|
||||||
/// execute the shell command `$cmd supports $renderer`. If the renderer is
|
/// execute the shell command `$cmd supports $renderer`. If the renderer is
|
||||||
/// supported, custom preprocessors should exit with a exit code of `0`,
|
/// supported, custom preprocessors should exit with a exit code of `0`,
|
||||||
/// any other exit code be considered as unsupported.
|
/// any other exit code be considered as unsupported.
|
||||||
|
///
|
||||||
|
/// The `run()` method is implemented by passing a `(PreprocessorContext, Book)`
|
||||||
|
/// tuple to the spawned command (`$cmd`) as JSON via `stdin`. Preprocessors
|
||||||
|
/// should then "return" a processed book by printing it to `stdout` as JSON.
|
||||||
|
/// For convenience, the `CmdPreprocessor::parse_input()` function can be used
|
||||||
|
/// to parse the input provided by `mdbook`.
|
||||||
|
///
|
||||||
|
/// Exiting with a non-zero exit code while preprocessing is considered an
|
||||||
|
/// error. `stderr` is passed directly through to the user, so it can be used
|
||||||
|
/// for logging or emitting warnings if desired.
|
||||||
|
///
|
||||||
|
/// # Examples
|
||||||
|
///
|
||||||
|
/// An example preprocessor is available in this project's `examples/`
|
||||||
|
/// directory.
|
||||||
#[derive(Debug, Clone, PartialEq)]
|
#[derive(Debug, Clone, PartialEq)]
|
||||||
pub struct CmdPreprocessor {
|
pub struct CmdPreprocessor {
|
||||||
name: String,
|
name: String,
|
||||||
|
|
Loading…
Reference in a new issue