Crates.io | macro_files |
lib.rs | macro_files |
version | 0.1.0 |
source | src |
created_at | 2022-08-07 04:41:38.067889 |
updated_at | 2022-08-07 04:41:38.067889 |
description | Macro consuming JSON like data structures to create directories and files at runtime. |
homepage | https://github.com/MathieuTricoire/macro_files |
repository | https://github.com/MathieuTricoire/macro_files |
max_upload_size | |
id | 640101 |
size | 41,543 |
Macro consuming JSON like data structures to create directories and files at runtime.
[dependencies]
macro_files = "0.1"
Version requirement: rustc 1.56+
Create directories and files
fn project_readme(project_name: &str) -> String {
format!("# {}", project_name)
}
let project_name = "Project name".to_string();
let adr_directory = "adr";
let temp_dir = macro_files::tempfile::tempdir().unwrap();
macro_files::create!({
temp_dir.path(): {
"README.md": project_readme(&project_name),
".adr-dir": adr_directory,
adr_directory: {
"templates": {
"template.md": "# ADR Template",
}
},
"LICENSE": "MIT"
},
}).unwrap();
let file_contents = std::fs::read(temp_dir.path().join("LICENSE")).unwrap();
assert_eq!(
String::from_utf8_lossy(&file_contents),
"MIT"
);
// Macro expands as:
// {
// #[allow(unused_variables)]
// let path = ::std::path::PathBuf::default();
// {
// let path = &path.join(temp_dir.path());
// $crate::create_dir(&path).and_then(|_| {
// $crate::write_file(path.join("README.md"), (project_readme(&project_name)))
// .and_then(|_| {
// $crate::write_file(path.join(".adr-dir"), adr_directory).and_then(|_| {
// {
// let path = &path.join(adr_directory);
// $crate::create_dir(&path).and_then(|_| {
// let path = &path.join("templates");
// $crate::create_dir(&path).and_then(|_| {
// $crate::write_file(
// path.join("template.md"),
// "# ADR Template",
// )
// .and_then(|_| Ok::<(), ::std::io::Error>(()))
// })
// })
// }
// .and_then(|_| $crate::write_file(path.join("LICENSE"), "MIT"))
// })
// })
// })
// }
// .and_then(|_| Ok::<(), ::std::io::Error>(()))
// }
Create directories and files within a temporary directory.
This requires the default feature tempfile
that uses the tempfile
crate.
The macro will return a tempfile::TempDir
struct, the temporary directory will lives as long as
the returned tempfile::TempDir
struct is not dropped (see documentation).
let temp_dir = macro_files::create_temp!({
"README.md": "# Project name",
"LICENSE": "MIT",
}).unwrap();
let file_contents = std::fs::read(temp_dir.path().join("README.md")).unwrap();
assert_eq!(
String::from_utf8_lossy(&file_contents),
"# Project name"
);
Licensed under either of
at your option.
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.