mirror of
https://github.com/cyborg42/epub2mdbook.git
synced 2026-02-10 16:24:50 -05:00
adjust api
This commit is contained in:
parent
b183e611e8
commit
7deafd0f81
4 changed files with 13 additions and 16 deletions
2
Cargo.lock
generated
2
Cargo.lock
generated
|
|
@ -192,7 +192,7 @@ dependencies = [
|
|||
|
||||
[[package]]
|
||||
name = "epub2mdbook"
|
||||
version = "0.11.0"
|
||||
version = "0.12.0"
|
||||
dependencies = [
|
||||
"clap",
|
||||
"epub",
|
||||
|
|
|
|||
|
|
@ -1,6 +1,6 @@
|
|||
[package]
|
||||
name = "epub2mdbook"
|
||||
version = "0.11.0"
|
||||
version = "0.12.0"
|
||||
edition = "2024"
|
||||
description = "A tool to convert EPUB files to MDBook format"
|
||||
authors = ["Maverick Liu <maverick.liu42@gmail.com>"]
|
||||
|
|
|
|||
19
src/lib.rs
19
src/lib.rs
|
|
@ -15,15 +15,15 @@ use std::{fs, io};
|
|||
/// # Arguments
|
||||
///
|
||||
/// * `epub_path` - The path to the EPUB file
|
||||
/// * `output_dir` - The path to the output directory, working directory by default
|
||||
/// * `output_dir` - The path to the output directory
|
||||
/// * `with_file_name` - Whether to use the file name as the output directory
|
||||
///
|
||||
pub fn convert_epub_to_mdbook(
|
||||
epub_path: impl AsRef<Path>,
|
||||
output_dir: Option<impl AsRef<Path>>,
|
||||
output_dir: impl AsRef<Path>,
|
||||
with_file_name: bool,
|
||||
) -> Result<(), Error> {
|
||||
let epub_path = epub_path.as_ref();
|
||||
let output_dir = output_dir.as_ref();
|
||||
if !epub_path.is_file() {
|
||||
return Err(Error::NotAFile(epub_path.display().to_string()));
|
||||
}
|
||||
|
|
@ -33,13 +33,11 @@ pub fn convert_epub_to_mdbook(
|
|||
.expect("unreachable")
|
||||
.to_string_lossy()
|
||||
.to_string();
|
||||
let mut output_dir = match output_dir {
|
||||
Some(output_dir) => output_dir.as_ref().to_owned(),
|
||||
None => PathBuf::from("."),
|
||||
let output_dir = if with_file_name {
|
||||
output_dir.join(&book_name)
|
||||
} else {
|
||||
output_dir.to_owned()
|
||||
};
|
||||
if with_file_name {
|
||||
output_dir.push(&book_name);
|
||||
}
|
||||
fs::create_dir_all(output_dir.join("src"))?;
|
||||
|
||||
let mut epub_doc = EpubDoc::new(epub_path)?;
|
||||
|
|
@ -118,8 +116,7 @@ fn extract_chapters_and_resources<R: Read + Seek>(
|
|||
.iter()
|
||||
.filter_map(|(k, v)| Some((k.file_name()?, v.file_name()?)))
|
||||
.collect::<HashMap<_, _>>();
|
||||
let output_dir = output_dir.as_ref();
|
||||
let src_dir = output_dir.join("src");
|
||||
let src_dir = output_dir.as_ref().join("src");
|
||||
for (_, (path, _)) in epub_doc.resources.clone().into_iter() {
|
||||
let mut content = match epub_doc.get_resource_by_path(&path) {
|
||||
Some(content) => content,
|
||||
|
|
|
|||
|
|
@ -9,8 +9,8 @@ struct Args {
|
|||
#[clap(short, long)]
|
||||
input_epub: PathBuf,
|
||||
/// The path to the output directory, working directory by default
|
||||
#[clap(short, long)]
|
||||
output_dir: Option<PathBuf>,
|
||||
#[clap(short, long, default_value = ".")]
|
||||
output_dir: PathBuf,
|
||||
}
|
||||
|
||||
fn main() -> Result<(), Error> {
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue