Started to implement init
This commit is contained in:
parent
b94304405a
commit
a27bc498eb
|
@ -1,2 +1,4 @@
|
||||||
target
|
target
|
||||||
Cargo.lock
|
Cargo.lock
|
||||||
|
|
||||||
|
book-test
|
||||||
|
|
|
@ -1,3 +1,3 @@
|
||||||
#[test]
|
pub mod mdbook;
|
||||||
fn it_works() {
|
|
||||||
}
|
pub use mdbook::MDBook;
|
||||||
|
|
|
@ -2,6 +2,7 @@ extern crate mdbook;
|
||||||
extern crate getopts;
|
extern crate getopts;
|
||||||
use std::env;
|
use std::env;
|
||||||
|
|
||||||
|
use mdbook::MDBook;
|
||||||
|
|
||||||
const NAME: &'static str = "mdbook";
|
const NAME: &'static str = "mdbook";
|
||||||
const VERSION: &'static str = "0.0.1";
|
const VERSION: &'static str = "0.0.1";
|
||||||
|
@ -108,7 +109,14 @@ fn init(args: Vec<String>) {
|
||||||
|
|
||||||
if matches.opt_present("help") {
|
if matches.opt_present("help") {
|
||||||
println!("{}", usage);
|
println!("{}", usage);
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
let dir = std::env::current_dir().unwrap();
|
||||||
|
let book = MDBook::new();
|
||||||
|
|
||||||
|
book.init(&dir);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
fn build(args: Vec<String>) {
|
fn build(args: Vec<String>) {
|
||||||
|
|
|
@ -0,0 +1,79 @@
|
||||||
|
use std::path::PathBuf;
|
||||||
|
use std::fs::{self, File, metadata};
|
||||||
|
|
||||||
|
pub struct MDBook {
|
||||||
|
dest: PathBuf,
|
||||||
|
src: PathBuf,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl MDBook {
|
||||||
|
pub fn new() -> Self {
|
||||||
|
MDBook {
|
||||||
|
dest: PathBuf::from("book"),
|
||||||
|
src: PathBuf::from("src"),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn init(&self, dir: &PathBuf) -> Result<(),&str> {
|
||||||
|
|
||||||
|
// Hacky way to check if the directory exists... Until PathExt moves to stable
|
||||||
|
match metadata(dir) {
|
||||||
|
Err(_) => return Err("Destination path does not exist"),
|
||||||
|
_ => {}
|
||||||
|
}
|
||||||
|
|
||||||
|
let dest = if self.dest.is_relative() {
|
||||||
|
dir.join(&self.dest)
|
||||||
|
} else {
|
||||||
|
self.dest.clone()
|
||||||
|
};
|
||||||
|
|
||||||
|
let src = if self.src.is_relative() {
|
||||||
|
dir.join(&self.src)
|
||||||
|
} else {
|
||||||
|
self.src.clone()
|
||||||
|
};
|
||||||
|
|
||||||
|
// Hacky way to check if the directory exists... Until PathExt moves to stable
|
||||||
|
match metadata(&dest) {
|
||||||
|
Err(_) => {
|
||||||
|
// There is a very high chance that the error is due to the fact that
|
||||||
|
// the directory / file does not exist
|
||||||
|
fs::create_dir(&dest).unwrap();
|
||||||
|
},
|
||||||
|
Ok(_) => { /* If there is no error, the directory / file does exist */ }
|
||||||
|
}
|
||||||
|
|
||||||
|
// Hacky way to check if the directory exists... Until PathExt moves to stable
|
||||||
|
match metadata(&src) {
|
||||||
|
Err(_) => {
|
||||||
|
// There is a very high chance that the error is due to the fact that
|
||||||
|
// the directory / file does not exist
|
||||||
|
fs::create_dir(&src).unwrap();
|
||||||
|
},
|
||||||
|
Ok(_) => { /* If there is no error, the directory / file does exist */ }
|
||||||
|
}
|
||||||
|
|
||||||
|
// Hacky way to check if the directory exists... Until PathExt moves to stable
|
||||||
|
match metadata(dir.join("src/SUMMARY.md")) {
|
||||||
|
Err(_) => {
|
||||||
|
// There is a very high chance that the error is due to the fact that
|
||||||
|
// the directory / file does not exist
|
||||||
|
File::create("src/SUMMARY.md").unwrap();
|
||||||
|
},
|
||||||
|
Ok(_) => { /* If there is no error, the directory / file does exist */ }
|
||||||
|
}
|
||||||
|
|
||||||
|
return Ok(());
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn set_dest(mut self, dest: PathBuf) -> Self {
|
||||||
|
self.dest = dest;
|
||||||
|
self
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn set_src(mut self, src: PathBuf) -> Self {
|
||||||
|
self.src = src;
|
||||||
|
self
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue