diff options
| author | A Farzat <a@farzat.xyz> | 2026-03-03 18:35:38 +0300 |
|---|---|---|
| committer | A Farzat <a@farzat.xyz> | 2026-03-03 18:35:38 +0300 |
| commit | ffd97108068a0dde153dbb64aa4493fa5945a5d3 (patch) | |
| tree | 0f286c607d819bc13278bc5e191b7ae230294c6b /src/main.rs | |
| parent | 6782269bb52a349e9568a28ed6c1f43438b7bb24 (diff) | |
| download | oreilly-epub-ffd97108068a0dde153dbb64aa4493fa5945a5d3.tar.gz oreilly-epub-ffd97108068a0dde153dbb64aa4493fa5945a5d3.zip | |
Generate the EPUB file
Diffstat (limited to 'src/main.rs')
| -rw-r--r-- | src/main.rs | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/src/main.rs b/src/main.rs index 8c5c712..002f669 100644 --- a/src/main.rs +++ b/src/main.rs @@ -5,7 +5,7 @@ mod models; use std::collections::HashMap; use std::path::Path; -use crate::epub::{download_all_files,}; +use crate::epub::{create_epub_archive, download_all_files}; use crate::http_client::build_authenticated_client; use crate::models::{Chapter, EpubResponse, FileEntry, Paginated, SpineItem, TocNode}; use anyhow::{Context, Result, ensure}; @@ -115,6 +115,9 @@ async fn main() -> Result<()> { let dest_root = format!("Books/{}/epub_root", args.bookid); let dest_root = Path::new(&dest_root); download_all_files(&client, &file_entries, dest_root).await?; + let epub_path = format!("Books/{0}/{0}.epub", args.bookid); + let epub_path = Path::new(&epub_path); + create_epub_archive(dest_root, &epub_path, &file_entries)?; // Sanity check: Every entry in spine exists in chapters. let chapters: HashMap<String, Chapter> = |
