refactor: remove META_PLUGIN_PROGRAMS and use get_meta_plugin() instead
Co-authored-by: aider (openai/andrew.openrouter.qwen.qwen3-coder) <aider@aider.chat>
This commit is contained in:
@@ -1,12 +1,6 @@
|
||||
use anyhow::Result;
|
||||
use std::io;
|
||||
|
||||
use lazy_static::lazy_static;
|
||||
|
||||
extern crate enum_map;
|
||||
use enum_map::enum_map;
|
||||
use enum_map::{Enum, EnumMap};
|
||||
|
||||
pub mod program;
|
||||
pub mod digest;
|
||||
pub mod system;
|
||||
@@ -15,7 +9,7 @@ use crate::meta_plugin::program::MetaPluginProgram;
|
||||
use crate::meta_plugin::digest::{DigestSha256MetaPlugin, ReadTimeMetaPlugin, ReadRateMetaPlugin};
|
||||
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)]
|
||||
#[derive(Debug, Eq, PartialEq, Clone, strum::EnumIter, strum::Display, strum::EnumString)]
|
||||
#[strum(ascii_case_insensitive)]
|
||||
pub enum MetaPluginType {
|
||||
FileMagic,
|
||||
@@ -54,51 +48,6 @@ pub trait MetaPlugin {
|
||||
|
||||
use std::io::Write;
|
||||
|
||||
lazy_static! {
|
||||
pub static ref META_PLUGIN_PROGRAMS: EnumMap<MetaPluginType, Option<MetaPluginProgram>> = enum_map! {
|
||||
MetaPluginType::FileMagic => {
|
||||
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!["-b", "--mime-type", "-"], "file_mime".to_string(), true);
|
||||
if program.supported { Some(program) } else { None }
|
||||
}
|
||||
MetaPluginType::FileEncoding => {
|
||||
let program = MetaPluginProgram::new("file", vec!["-b", "--mime-encoding", "-"], "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 }
|
||||
}
|
||||
MetaPluginType::DigestMd5 => {
|
||||
let program = MetaPluginProgram::new("md5sum", vec![], "digest_md5".to_string(), true);
|
||||
if program.supported { Some(program) } else { None }
|
||||
}
|
||||
MetaPluginType::ReadTime => None,
|
||||
MetaPluginType::ReadRate => None,
|
||||
MetaPluginType::Hostname => None,
|
||||
MetaPluginType::FullHostname => None,
|
||||
};
|
||||
}
|
||||
|
||||
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)),
|
||||
|
||||
Reference in New Issue
Block a user