pub mod cpu;
pub mod cpu_flags;
pub mod machines;
pub mod migration;
#[derive(Debug, Clone)]
pub struct QemuClient<T> {
client: T,
path: String,
}
impl<T> QemuClient<T>
where
T: crate::client::Client,
{
pub fn new(client: T, parent_path: &str) -> Self {
Self {
client,
path: format!("{}{}", parent_path, "/qemu"),
}
}
}
impl<T> QemuClient<T>
where
T: crate::client::Client,
{
#[doc = "QEMU capabilities index."]
#[doc = ""]
pub async fn get(&self) -> Result<Vec<GetOutputItems>, T::Error> {
let path = self.path.to_string();
let optional_vec: Option<Vec<GetOutputItems>> = self.client.get(&path, &()).await?;
Ok(optional_vec.unwrap_or_default())
}
}
#[derive(Clone, Debug, :: serde :: Serialize, :: serde :: Deserialize, Default)]
pub struct GetOutputItems {
#[serde(
flatten,
default,
skip_serializing_if = "::std::collections::HashMap::is_empty"
)]
pub additional_properties: ::std::collections::HashMap<String, ::serde_json::Value>,
}
impl<T> QemuClient<T>
where
T: crate::client::Client,
{
pub fn cpu(&self) -> cpu::CpuClient<T> {
cpu::CpuClient::<T>::new(self.client.clone(), &self.path)
}
}
impl<T> QemuClient<T>
where
T: crate::client::Client,
{
pub fn cpu_flags(&self) -> cpu_flags::CpuFlagsClient<T> {
cpu_flags::CpuFlagsClient::<T>::new(self.client.clone(), &self.path)
}
}
impl<T> QemuClient<T>
where
T: crate::client::Client,
{
pub fn machines(&self) -> machines::MachinesClient<T> {
machines::MachinesClient::<T>::new(self.client.clone(), &self.path)
}
}
impl<T> QemuClient<T>
where
T: crate::client::Client,
{
pub fn migration(&self) -> migration::MigrationClient<T> {
migration::MigrationClient::<T>::new(self.client.clone(), &self.path)
}
}