1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
use crate::package::{Package, PackageOutput};
use crate::target::Target;
use serde_derive::Deserialize;
use std::collections::BTreeMap;
use std::path::Path;
use thiserror::Error;
#[derive(Deserialize, Debug)]
pub struct Config {
#[serde(default, rename = "package")]
pub packages: BTreeMap<String, Package>,
}
impl Config {
pub fn packages_to_build(&self, target: &Target) -> BTreeMap<&String, &Package> {
self.packages
.iter()
.filter(|(_, pkg)| target.includes_package(pkg))
.map(|(name, pkg)| (name, pkg))
.collect()
}
pub fn packages_to_deploy(&self, target: &Target) -> BTreeMap<&String, &Package> {
let all_packages = self.packages_to_build(target);
all_packages
.into_iter()
.filter(|(_, pkg)| match pkg.output {
PackageOutput::Zone { intermediate_only } => !intermediate_only,
PackageOutput::Tarball => true,
})
.collect()
}
}
#[derive(Error, Debug)]
pub enum ParseError {
#[error("Cannot parse toml: {0}")]
Toml(#[from] toml::de::Error),
#[error("IO error: {0}")]
Io(#[from] std::io::Error),
}
pub fn parse_manifest(manifest: &str) -> Result<Config, ParseError> {
let cfg = toml::from_str::<Config>(manifest)?;
Ok(cfg)
}
pub fn parse<P: AsRef<Path>>(path: P) -> Result<Config, ParseError> {
let contents = std::fs::read_to_string(path.as_ref())?;
parse_manifest(&contents)
}