build_fs_tree/lib.rs
1//! # [`FileSystemTree`]
2//!
3//! [`FileSystemTree::build`](Build::build) is faster than
4//! [`MergeableFileSystemTree::build`](MergeableFileSystemTree) but it does not write over an existing
5//! directory and it does not create parent directories when they don't exist.
6//!
7//! **Example:**
8//!
9//! ```no_run
10//! use build_fs_tree::{FileSystemTree, Build, dir, file};
11//! let tree: FileSystemTree<&str, &str> = dir! {
12//! "index.html" => file!(r#"
13//! <!DOCTYPE html>
14//! <link rel="stylesheet" href="styles/style.css" />
15//! <script src="scripts/main.js"></script>
16//! "#)
17//! "scripts" => dir! {
18//! "main.js" => file!(r#"document.write('Hello World')"#)
19//! }
20//! "styles" => dir! {
21//! "style.css" => file!(r#":root { color: red; }"#)
22//! }
23//! };
24//! tree.build("public").unwrap();
25//! ```
26//!
27//! # [`MergeableFileSystemTree`]
28//!
29//! Unlike [`FileSystemTree::build`](FileSystemTree), [`MergeableFileSystemTree::build`](Build::build)
30//! can write over an existing directory and create parent directories that were not exist before at the
31//! cost of performance.
32//!
33//! You can convert a `FileSystemTree` into a `MergeableFileSystemTree` via [`From::from`]/[`Into::into`]
34//! and vice versa.
35//!
36//! **Example:**
37//!
38//! ```no_run
39//! use build_fs_tree::{MergeableFileSystemTree, Build, dir, file};
40//! let tree = MergeableFileSystemTree::<&str, &str>::from(dir! {
41//! "public" => dir! {
42//! "index.html" => file!(r#"
43//! <!DOCTYPE html>
44//! <link rel="stylesheet" href="styles/style.css" />
45//! <script src="scripts/main.js"></script>
46//! "#)
47//! "scripts/main.js" => file!(r#"document.write('Hello World')"#)
48//! "scripts/style.css" => file!(r#":root { color: red; }"#)
49//! }
50//! });
51//! tree.build(".").unwrap();
52//! ```
53//!
54//! # Serialization and Deserialization
55//!
56//! Both [`FileSystemTree`] and [`MergeableFileSystemTree`] implement [`serde::Deserialize`]
57//! and [`serde::Serialize`].
58
59#![deny(warnings)]
60
61mod build;
62mod macros;
63mod node;
64mod tree;
65
66pub use build::*;
67pub use node::*;
68pub use tree::*;
69
70#[cfg(feature = "cli")]
71pub mod program;
72
73pub use serde;
74pub use serde_yaml;