cubic 0.14.0

Cubic is a lightweight command line manager for virtual machines. It has a simple, daemon-less and rootless design. All Cubic virtual machines run isolated in the user context. Cubic is built on top of QEMU, KVM and cloud-init. Show all supported images: $ cubic images Create a new virtual machine instance: $ cubic create mymachine --image ubuntu:noble List all virtual machine instances: $ cubic instances Start an instance: $ cubic start <instance name> Stop an instance: $ cubic stop <instance name> Open a shell in the instance: $ cubic ssh <machine name> Copy a file from the host to the instance: $ cubic scp <path/to/host/file> <machine>:<path/to/guest/file> Copy a file from the instance to the hots: $ cubic scp <machine>:<path/to/guest/file> <path/to/host/file>
use crate::commands;
use crate::error::Error;
use crate::instance::InstanceDao;
use crate::util::Terminal;
use clap::Parser;
use std::path::Path;
use std::thread;
use std::time::Duration;

/// Open the console of an virtual machine instance
#[derive(Parser)]
pub struct InstanceConsoleCommand {
    /// Name of the virtual machine instance
    instance: String,
}

impl InstanceConsoleCommand {
    pub fn run(
        &self,
        instance_dao: &InstanceDao,
        verbosity: commands::Verbosity,
    ) -> Result<(), Error> {
        commands::InstanceStartCommand {
            qemu_args: None,
            wait: false,
            instances: vec![self.instance.to_string()],
        }
        .run(instance_dao, verbosity)?;

        println!("Press CTRL+W to exit the console.");
        let console_path = instance_dao.env.get_console_file(&self.instance);
        while !Path::new(&console_path).exists() {
            thread::sleep(Duration::new(1, 0));
        }

        if let Ok(mut term) = Terminal::open(&console_path) {
            term.wait();
        } else {
            println!("Cannot open shell");
        }

        Ok(())
    }
}