espanso/src/engine.rs

50 lines
1.8 KiB
Rust
Raw Normal View History

use crate::matcher::{Match, MatchReceiver};
use crate::keyboard::KeyboardSender;
2019-09-07 11:35:45 +00:00
use crate::config::ConfigSet;
use crate::config::BackendType;
use crate::clipboard::ClipboardManager;
use std::sync::Arc;
pub struct Engine<S, C> where S: KeyboardSender, C: ClipboardManager {
2019-09-05 18:54:19 +00:00
sender: S,
clipboard_manager: Arc<C>,
2019-09-07 11:35:45 +00:00
config_set: ConfigSet,
}
impl <S, C> Engine<S, C> where S: KeyboardSender, C: ClipboardManager{
2019-09-07 11:35:45 +00:00
pub fn new(sender: S, clipboard_manager: Arc<C>, config_set: ConfigSet) -> Engine<S, C> where S: KeyboardSender, C: ClipboardManager {
Engine{sender, clipboard_manager, config_set }
}
}
impl <S, C> MatchReceiver for Engine<S, C> where S: KeyboardSender, C: ClipboardManager{
2019-08-31 15:00:23 +00:00
fn on_match(&self, m: &Match) {
self.sender.delete_string(m.trigger.len() as i32);
2019-09-07 11:35:45 +00:00
match self.config_set.backend() {
BackendType::Inject => {
// Send the expected string. On linux, newlines are managed automatically
// while on windows and macos, we need to emulate a Enter key press.
if cfg!(target_os = "linux") {
self.sender.send_string(m.replace.as_str());
}else{
// To handle newlines, substitute each "\n" char with an Enter key press.
let splits = m.replace.lines();
2019-09-06 20:19:28 +00:00
for (i, split) in splits.enumerate() {
if i > 0 {
self.sender.send_enter();
}
self.sender.send_string(split);
}
}
},
BackendType::Clipboard => {
self.clipboard_manager.set_clipboard(m.replace.as_str());
self.sender.trigger_paste();
},
}
}
}