summaryrefslogtreecommitdiff
path: root/crates/vcs/src/data/sheet.rs
diff options
context:
space:
mode:
Diffstat (limited to 'crates/vcs/src/data/sheet.rs')
-rw-r--r--crates/vcs/src/data/sheet.rs22
1 files changed, 16 insertions, 6 deletions
diff --git a/crates/vcs/src/data/sheet.rs b/crates/vcs/src/data/sheet.rs
index 3acc8ff..edf307a 100644
--- a/crates/vcs/src/data/sheet.rs
+++ b/crates/vcs/src/data/sheet.rs
@@ -14,8 +14,15 @@ use crate::{
pub type SheetName = String;
pub type SheetPathBuf = PathBuf;
pub type InputName = String;
-pub type InputPackage = (InputName, Vec<(InputRaltivePathBuf, VirtualFileId)>);
-pub type InputRaltivePathBuf = PathBuf;
+pub type InputRelativePathBuf = PathBuf;
+
+#[derive(Debug, Clone, Serialize, Deserialize)]
+pub struct InputPackage {
+ /// Name of the input package
+ pub name: InputName,
+ /// Files in this input package with their relative paths and virtual file IDs
+ pub files: Vec<(InputRelativePathBuf, VirtualFileId)>,
+}
const SHEET_NAME: &str = "{sheet-name}";
@@ -62,9 +69,12 @@ impl<'a> Sheet<'a> {
pub fn add_input(
&mut self,
input_name: InputName,
- files: Vec<(InputRaltivePathBuf, VirtualFileId)>,
+ files: Vec<(InputRelativePathBuf, VirtualFileId)>,
) {
- self.data.inputs.push((input_name, files));
+ self.data.inputs.push(InputPackage {
+ name: input_name,
+ files,
+ });
}
/// Remove an input package from the sheet
@@ -72,7 +82,7 @@ impl<'a> Sheet<'a> {
self.data
.inputs
.iter()
- .position(|(name, _)| name == input_name)
+ .position(|input| input.name == *input_name)
.map(|pos| self.data.inputs.remove(pos))
}
@@ -92,7 +102,7 @@ impl<'a> Sheet<'a> {
/// Because I don't want a second instance of the sheet to be kept in memory.
/// If needed, please deserialize and reload it.
pub async fn persist(self) -> Result<(), std::io::Error> {
- SheetData::write_to(&self.data, &self.sheet_path()).await
+ SheetData::write_to(&self.data, self.sheet_path()).await
}
/// Get the path to the sheet file