mirror of
https://github.com/msfjarvis/clipboard-substitutor
synced 2025-08-14 17:47:02 +05:30
refactor: support multiple matchers in a single substitutor
This commit is contained in:
parent
0f67855571
commit
7be11d9a90
2 changed files with 20 additions and 8 deletions
|
@ -13,12 +13,21 @@ pub struct Replacements<'config> {
|
|||
pub struct Substitutor<'config> {
|
||||
#[serde(default)]
|
||||
pub name: &'config str,
|
||||
#[serde(borrow)]
|
||||
pub matcher: Matcher<'config>,
|
||||
#[serde(borrow, alias = "matcher")]
|
||||
pub matcher_type: MatcherType<'config>,
|
||||
#[serde(borrow)]
|
||||
pub action: Action<'config>,
|
||||
}
|
||||
|
||||
#[derive(Debug, Deserialize)]
|
||||
#[serde(untagged)]
|
||||
pub enum MatcherType<'config> {
|
||||
#[serde(borrow)]
|
||||
Single(Matcher<'config>),
|
||||
#[serde(borrow)]
|
||||
Multiple(Vec<Matcher<'config>>),
|
||||
}
|
||||
|
||||
#[derive(Debug, Deserialize)]
|
||||
pub enum Matcher<'config> {
|
||||
#[serde(rename = "starts_with")]
|
||||
|
|
15
src/main.rs
15
src/main.rs
|
@ -11,7 +11,7 @@ use clipboard::{ClipboardContext, ClipboardProvider};
|
|||
use dirs::config_dir;
|
||||
use log::{debug, error};
|
||||
|
||||
use crate::config::{Act, Match, Replacements};
|
||||
use crate::config::{Act, Match, MatcherType, Replacements};
|
||||
|
||||
const VERSION_ARGS: [&str; 3] = ["version", "-v", "--version"];
|
||||
|
||||
|
@ -57,11 +57,14 @@ fn loop_clipboard<'a>(config: Replacements<'a>) {
|
|||
ClipboardProvider::new().expect("Failed to get clipboard");
|
||||
let mut clipboard_contents = get_clipboard_contents(&mut clipboard);
|
||||
while let Ok(contents) = clipboard_contents.as_deref() {
|
||||
if let Some(subst) = config
|
||||
.substitutors
|
||||
.iter()
|
||||
.find(|subst| subst.matcher.check_match(contents))
|
||||
{
|
||||
if let Some(subst) = config.substitutors.iter().find(|subst| {
|
||||
return match &subst.matcher_type {
|
||||
MatcherType::Single(matcher) => matcher.check_match(contents),
|
||||
MatcherType::Multiple(matchers) => {
|
||||
matchers.iter().all(|matcher| matcher.check_match(contents))
|
||||
}
|
||||
};
|
||||
}) {
|
||||
if subst.name.is_empty().not() {
|
||||
debug!("{}: matched on {}...", &subst.name, truncate(&contents, 40));
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue