diff --git a/ciel/src/container.rs b/ciel/src/container.rs index d046704..b107ad3 100644 --- a/ciel/src/container.rs +++ b/ciel/src/container.rs @@ -49,7 +49,7 @@ pub struct Container { instance: Instance, config: Arc, #[allow(unused)] - lock: Arc, + lock: Option>, ns_name: String, rootfs_path: PathBuf, @@ -89,15 +89,21 @@ impl Drop for FileLock { } impl Container { - /// Opens the build container, locking it exclusively. - pub fn open(instance: Instance) -> Result { - let lock = File::options() - .read(true) - .write(true) - .create(true) - .open(instance.directory().join(".lock"))?; - fs3::FileExt::lock_exclusive(&lock)?; - let lock = FileLock(lock); + /// Opens the build container. + /// + /// If `lock` is true, it will be locked exclusively. + pub fn open(instance: Instance, lock: bool) -> Result { + let lock = if lock { + let lock = File::options() + .read(true) + .write(true) + .create(true) + .open(instance.directory().join(".lock"))?; + fs3::FileExt::lock_exclusive(&lock)?; + Some(Arc::new(FileLock(lock))) + } else { + None + }; let ns_name = make_container_ns_name(instance.name())?; let rootfs_path = instance.workspace().directory().join(instance.name()); @@ -134,7 +140,7 @@ impl Container { Ok(Self { instance, config: Arc::new(config), - lock: Arc::new(lock), + lock, ns_name, rootfs_path, config_path, @@ -598,7 +604,9 @@ impl Deref for OwnedContainer { impl Drop for OwnedContainer { fn drop(&mut self) { let instance = self.0.instance().to_owned(); - self.0.lock.force_unlock(); + if let Some(lock) = &self.0.lock { + lock.force_unlock(); + } instance.destroy().unwrap(); } } diff --git a/ciel/src/instance.rs b/ciel/src/instance.rs index 9a18695..5ecebd2 100644 --- a/ciel/src/instance.rs +++ b/ciel/src/instance.rs @@ -89,7 +89,12 @@ impl Instance { /// /// This is equivalent to calling [Container::open]. pub fn open(&self) -> Result { - Container::open(self.to_owned()) + Container::open(self.to_owned(), true) + } + + /// Opens the build container for further operations without locking. + pub fn open_unlocked(&self) -> Result { + Container::open(self.to_owned(), false) } /// Destories the container, removing all related files. diff --git a/cli/src/actions/workspace.rs b/cli/src/actions/workspace.rs index 22face8..714bc80 100644 --- a/cli/src/actions/workspace.rs +++ b/cli/src/actions/workspace.rs @@ -27,7 +27,7 @@ pub fn list_instances() -> Result<()> { writeln!(&mut formatter, "NAME\tMOUNTED\tSTARTED\tBOOTED")?; for inst in ws.instances()? { - let container = inst.open()?; + let container = inst.open_unlocked()?; let state = container.state()?; let (mounted, started, running) = match state { ContainerState::Down => (false, false, false),