refactor: move hostname plugins to system module and remove basic.rs

Co-authored-by: aider (openai/andrew.openrouter.qwen.qwen3-coder) <aider@aider.chat>
This commit is contained in:
Andrew Phillips
2025-07-29 12:46:05 -03:00
parent 46d305f13d
commit 67c8f48a7c
2 changed files with 139 additions and 3 deletions

View File

@@ -9,17 +9,28 @@ use enum_map::{Enum, EnumMap};
pub mod program;
pub mod digest;
pub mod basic;
pub mod system;
use crate::meta_plugin::program::MetaPluginProgram;
use crate::meta_plugin::digest::{DigestSha256MetaPlugin, ReadTimeMetaPlugin, ReadRateMetaPlugin};
use crate::meta_plugin::basic::{HostnameMetaPlugin, FullHostnameMetaPlugin};
use crate::meta_plugin::system::{CwdMetaPlugin, UidMetaPlugin, UserMetaPlugin, GidMetaPlugin, GroupMetaPlugin, ShellMetaPlugin, ShellPidMetaPlugin, KeepPidMetaPlugin};
use crate::meta_plugin::system::{CwdMetaPlugin, UidMetaPlugin, UserMetaPlugin, GidMetaPlugin, GroupMetaPlugin, ShellMetaPlugin, ShellPidMetaPlugin, KeepPidMetaPlugin, HostnameMetaPlugin, FullHostnameMetaPlugin};
#[derive(Debug, Eq, PartialEq, Clone, strum::EnumIter, strum::Display, strum::EnumString, Enum)]
#[strum(ascii_case_insensitive)]
pub enum MetaPluginType {
FileMagic,
FileMime,
FileEncoding,
LineCount,
WordCount,
Cwd,
Uid,
User,
Gid,
Group,
Shell,
ShellPid,
KeepPid,
DigestSha256,
DigestMd5,
ReadTime,
@@ -49,6 +60,30 @@ lazy_static! {
let program = MetaPluginProgram::new("file", vec!["-bE", "-"], "file_magic".to_string(), true);
if program.supported { Some(program) } else { None }
}
MetaPluginType::FileMime => {
let program = MetaPluginProgram::new("file", vec!["--mime", "-"], "file_mime".to_string(), true);
if program.supported { Some(program) } else { None }
}
MetaPluginType::FileEncoding => {
let program = MetaPluginProgram::new("file", vec!["-bI", "-"], "file_encoding".to_string(), true);
if program.supported { Some(program) } else { None }
}
MetaPluginType::LineCount => {
let program = MetaPluginProgram::new("wc", vec!["-l"], "line_count".to_string(), true);
if program.supported { Some(program) } else { None }
}
MetaPluginType::WordCount => {
let program = MetaPluginProgram::new("wc", vec!["-w"], "word_count".to_string(), true);
if program.supported { Some(program) } else { None }
}
MetaPluginType::Cwd => None,
MetaPluginType::Uid => None,
MetaPluginType::User => None,
MetaPluginType::Gid => None,
MetaPluginType::Group => None,
MetaPluginType::Shell => None,
MetaPluginType::ShellPid => None,
MetaPluginType::KeepPid => None,
MetaPluginType::DigestSha256 => {
let program = MetaPluginProgram::new("sha256sum", vec![], "digest_sha256".to_string(), true);
if program.supported { Some(program) } else { None }
@@ -67,6 +102,18 @@ lazy_static! {
pub fn get_meta_plugin(meta_plugin_type: MetaPluginType) -> Box<dyn MetaPlugin> {
match meta_plugin_type {
MetaPluginType::FileMagic => Box::new(MetaPluginProgram::new("file", vec!["-bE", "-"], "file_magic".to_string(), true)),
MetaPluginType::FileMime => Box::new(MetaPluginProgram::new("file", vec!["--mime", "-"], "file_mime".to_string(), true)),
MetaPluginType::FileEncoding => Box::new(MetaPluginProgram::new("file", vec!["-bI", "-"], "file_encoding".to_string(), true)),
MetaPluginType::LineCount => Box::new(MetaPluginProgram::new("wc", vec!["-l"], "line_count".to_string(), true)),
MetaPluginType::WordCount => Box::new(MetaPluginProgram::new("wc", vec!["-w"], "word_count".to_string(), true)),
MetaPluginType::Cwd => Box::new(CwdMetaPlugin::new()),
MetaPluginType::Uid => Box::new(UidMetaPlugin::new()),
MetaPluginType::User => Box::new(UserMetaPlugin::new()),
MetaPluginType::Gid => Box::new(GidMetaPlugin::new()),
MetaPluginType::Group => Box::new(GroupMetaPlugin::new()),
MetaPluginType::Shell => Box::new(ShellMetaPlugin::new()),
MetaPluginType::ShellPid => Box::new(ShellPidMetaPlugin::new()),
MetaPluginType::KeepPid => Box::new(KeepPidMetaPlugin::new()),
MetaPluginType::DigestSha256 => Box::new(DigestSha256MetaPlugin::new()),
MetaPluginType::DigestMd5 => Box::new(MetaPluginProgram::new("md5sum", vec![], "digest_md5".to_string(), true)),
MetaPluginType::ReadTime => Box::new(ReadTimeMetaPlugin::new()),