mirror of
https://github.com/13hannes11/toolbx-tuner.git
synced 2024-09-03 23:21:00 +02:00
change toolbox status to be enum
This commit is contained in:
@@ -1,11 +1,55 @@
|
|||||||
use std::{iter::zip, process::Command, sync::Arc, fmt::Result, string::ParseError};
|
use std::{fmt::Display, iter::zip, process::Command, str::FromStr, string::ParseError, sync::Arc};
|
||||||
|
|
||||||
|
#[derive(Debug)]
|
||||||
|
pub enum ToolbxError {
|
||||||
|
ParseStatusError(String),
|
||||||
|
}
|
||||||
|
|
||||||
|
impl std::error::Error for ToolbxError {}
|
||||||
|
|
||||||
|
impl Display for ToolbxError {
|
||||||
|
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
|
||||||
|
match self {
|
||||||
|
ToolbxError::ParseStatusError(parse_int_error) => write!(f, "{}", parse_int_error),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Debug, PartialEq)]
|
||||||
|
pub enum ToolbxStatus {
|
||||||
|
Running,
|
||||||
|
Configured,
|
||||||
|
Exited,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Default for ToolbxStatus {
|
||||||
|
fn default() -> Self {
|
||||||
|
ToolbxStatus::Configured
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl FromStr for ToolbxStatus {
|
||||||
|
type Err = ToolbxError;
|
||||||
|
|
||||||
|
fn from_str(s: &str) -> Result<ToolbxStatus, ToolbxError> {
|
||||||
|
match s {
|
||||||
|
"running" => Ok(ToolbxStatus::Running),
|
||||||
|
"configured" => Ok(ToolbxStatus::Configured),
|
||||||
|
"exited" => Ok(ToolbxStatus::Exited),
|
||||||
|
s => Err(ToolbxError::ParseStatusError(format!(
|
||||||
|
"'{}' is not a valid toolbx status.",
|
||||||
|
s
|
||||||
|
))),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
#[derive(Debug, PartialEq, Default)]
|
#[derive(Debug, PartialEq, Default)]
|
||||||
pub struct ToolbxContainer {
|
pub struct ToolbxContainer {
|
||||||
pub id: String,
|
pub id: String,
|
||||||
pub name: String,
|
pub name: String,
|
||||||
pub created: String,
|
pub created: String,
|
||||||
pub status: String,
|
pub status: ToolbxStatus,
|
||||||
pub image: String,
|
pub image: String,
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -96,18 +140,18 @@ fn test_tokenize_line_list_containers() {
|
|||||||
assert_eq!(target, result);
|
assert_eq!(target, result);
|
||||||
}
|
}
|
||||||
|
|
||||||
fn parse_line_list_containers(line: &str) -> ToolbxContainer {
|
fn parse_line_list_containers(line: &str) -> Result<ToolbxContainer, ToolbxError> {
|
||||||
let tokens = tokenize_line_list_containers(line);
|
let tokens = tokenize_line_list_containers(line);
|
||||||
if tokens.len() != 5 {
|
if tokens.len() != 5 {
|
||||||
panic! {"Expected 5 tokens found {} in {:?}", tokens.len(), tokens};
|
panic! {"Expected 5 tokens found {} in {:?}", tokens.len(), tokens};
|
||||||
}
|
}
|
||||||
ToolbxContainer {
|
Ok(ToolbxContainer {
|
||||||
id: tokens[0].clone(),
|
id: tokens[0].clone(),
|
||||||
name: tokens[1].clone(),
|
name: tokens[1].clone(),
|
||||||
created: tokens[2].clone(),
|
created: tokens[2].clone(),
|
||||||
status: tokens[3].clone(),
|
status: ToolbxStatus::from_str(&tokens[3])?,
|
||||||
image: tokens[4].clone(),
|
image: tokens[4].clone(),
|
||||||
}
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
@@ -119,17 +163,17 @@ fn test_parse_line_list_containers() {
|
|||||||
id: "ae05203091ab".to_string(),
|
id: "ae05203091ab".to_string(),
|
||||||
name: "rust".to_string(),
|
name: "rust".to_string(),
|
||||||
created: "4 months ago".to_string(),
|
created: "4 months ago".to_string(),
|
||||||
status: "running".to_string(),
|
status: ToolbxStatus::Running,
|
||||||
image: "registry.fedoraproject.org/fedora-toolbox:35".to_string(),
|
image: "registry.fedoraproject.org/fedora-toolbox:35".to_string(),
|
||||||
};
|
};
|
||||||
let result = parse_line_list_containers(toolbox_cmd_container_header);
|
let result = parse_line_list_containers(toolbox_cmd_container_header);
|
||||||
assert_eq!(target, result);
|
assert_eq!(target, result.unwrap());
|
||||||
}
|
}
|
||||||
|
|
||||||
fn parse_cmd_list_containers(output: &str) -> Vec<ToolbxContainer> {
|
fn parse_cmd_list_containers(output: &str) -> Vec<ToolbxContainer> {
|
||||||
let lines = output.trim().split("\n").skip(1);
|
let lines = output.trim().split("\n").skip(1);
|
||||||
println!("{:?}", lines);
|
println!("{:?}", lines);
|
||||||
lines.map(parse_line_list_containers).collect()
|
lines.map(parse_line_list_containers).flatten().collect()
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
@@ -147,21 +191,21 @@ fn test_parse_cmd_list_containers() {
|
|||||||
id: "cee1002b5f0b".to_string(),
|
id: "cee1002b5f0b".to_string(),
|
||||||
name: "fedora-toolbox-35".to_string(),
|
name: "fedora-toolbox-35".to_string(),
|
||||||
created: "2 months ago".to_string(),
|
created: "2 months ago".to_string(),
|
||||||
status: "exited".to_string(),
|
status: ToolbxStatus::Exited,
|
||||||
image: "registry.fedoraproject.org/fedora-toolbox:35".to_string(),
|
image: "registry.fedoraproject.org/fedora-toolbox:35".to_string(),
|
||||||
},
|
},
|
||||||
ToolbxContainer {
|
ToolbxContainer {
|
||||||
id: "9b611313bf65".to_string(),
|
id: "9b611313bf65".to_string(),
|
||||||
name: "latex".to_string(),
|
name: "latex".to_string(),
|
||||||
created: "4 months ago".to_string(),
|
created: "4 months ago".to_string(),
|
||||||
status: "configured".to_string(),
|
status: ToolbxStatus::Configured,
|
||||||
image: "registry.fedoraproject.org/fedora-toolbox:35".to_string(),
|
image: "registry.fedoraproject.org/fedora-toolbox:35".to_string(),
|
||||||
},
|
},
|
||||||
ToolbxContainer {
|
ToolbxContainer {
|
||||||
id: "ae05203091ab".to_string(),
|
id: "ae05203091ab".to_string(),
|
||||||
name: "rust".to_string(),
|
name: "rust".to_string(),
|
||||||
created: "4 months ago".to_string(),
|
created: "4 months ago".to_string(),
|
||||||
status: "running".to_string(),
|
status: ToolbxStatus::Running,
|
||||||
image: "registry.fedoraproject.org/fedora-toolbox:35".to_string(),
|
image: "registry.fedoraproject.org/fedora-toolbox:35".to_string(),
|
||||||
},
|
},
|
||||||
];
|
];
|
||||||
|
|||||||
@@ -8,14 +8,15 @@ use relm4::{
|
|||||||
gtk, send, view, Sender,
|
gtk, send, view, Sender,
|
||||||
};
|
};
|
||||||
|
|
||||||
use crate::{ui::{
|
use crate::{
|
||||||
ui_strings::{
|
toolbx::{ToolbxContainer, ToolbxStatus},
|
||||||
|
ui::ui_strings::{
|
||||||
APP_ICON, APP_TOOLTIP, SETTINGS_ICON, SETTINGS_TOOLTIP, SHUTDOWN_ICON, SHUTDOWN_TOOLTIP,
|
APP_ICON, APP_TOOLTIP, SETTINGS_ICON, SETTINGS_TOOLTIP, SHUTDOWN_ICON, SHUTDOWN_TOOLTIP,
|
||||||
START_ICON, START_TOOLTIP, TERMINAL_ICON, TERMINAL_TOOLTIP, UPDATE_ICON, UPDATE_TOOLTIP,
|
START_ICON, START_TOOLTIP, TERMINAL_ICON, TERMINAL_TOOLTIP, UPDATE_ICON, UPDATE_TOOLTIP,
|
||||||
},
|
},
|
||||||
}, toolbx::ToolbxContainer};
|
};
|
||||||
|
|
||||||
use super::{messages::AppMsg};
|
use super::messages::AppMsg;
|
||||||
|
|
||||||
#[derive(Debug)]
|
#[derive(Debug)]
|
||||||
pub struct FactoryWidgets {
|
pub struct FactoryWidgets {
|
||||||
@@ -96,8 +97,8 @@ impl FactoryPrototype for ToolbxContainer {
|
|||||||
let mut status_button_tooltip = START_TOOLTIP;
|
let mut status_button_tooltip = START_TOOLTIP;
|
||||||
let mut status_button_icon = START_ICON;
|
let mut status_button_icon = START_ICON;
|
||||||
|
|
||||||
match self.status.as_str() {
|
match self.status {
|
||||||
"running" => {
|
ToolbxStatus::Running => {
|
||||||
status_button_tooltip = SHUTDOWN_TOOLTIP;
|
status_button_tooltip = SHUTDOWN_TOOLTIP;
|
||||||
status_button_icon = SHUTDOWN_ICON;
|
status_button_icon = SHUTDOWN_ICON;
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user