Add backend configuration option. Fix #10
This commit is contained in:
parent
30c127786d
commit
9c680445f0
|
@ -32,9 +32,23 @@ pub struct Configs {
|
||||||
#[serde(default = "default_backspace_limit")]
|
#[serde(default = "default_backspace_limit")]
|
||||||
pub backspace_limit: i32,
|
pub backspace_limit: i32,
|
||||||
|
|
||||||
|
#[serde(default)]
|
||||||
|
pub backend: BackendType,
|
||||||
|
|
||||||
pub matches: Vec<Match>
|
pub matches: Vec<Match>
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[derive(Debug, Clone, PartialEq, Serialize, Deserialize)]
|
||||||
|
pub enum BackendType {
|
||||||
|
Inject,
|
||||||
|
Clipboard
|
||||||
|
}
|
||||||
|
impl Default for BackendType {
|
||||||
|
fn default() -> Self {
|
||||||
|
BackendType::Inject
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
impl Configs {
|
impl Configs {
|
||||||
pub fn load(path: &Path) -> Configs {
|
pub fn load(path: &Path) -> Configs {
|
||||||
let file_res = File::open(path);
|
let file_res = File::open(path);
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
use crate::matcher::{Match, MatchReceiver};
|
use crate::matcher::{Match, MatchReceiver};
|
||||||
use crate::keyboard::KeyboardSender;
|
use crate::keyboard::KeyboardSender;
|
||||||
use crate::config::Configs;
|
use crate::config::Configs;
|
||||||
|
use crate::config::BackendType;
|
||||||
use crate::clipboard::ClipboardManager;
|
use crate::clipboard::ClipboardManager;
|
||||||
use std::sync::Arc;
|
use std::sync::Arc;
|
||||||
|
|
||||||
|
@ -20,24 +21,30 @@ impl <S, C> MatchReceiver for Engine<S, C> where S: KeyboardSender, C: Clipboard
|
||||||
fn on_match(&self, m: &Match) {
|
fn on_match(&self, m: &Match) {
|
||||||
self.sender.delete_string(m.trigger.len() as i32);
|
self.sender.delete_string(m.trigger.len() as i32);
|
||||||
|
|
||||||
// Send the expected string. On linux, newlines are managed automatically
|
match self.configs.backend {
|
||||||
// while on windows and macos, we need to emulate a Enter key press.
|
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") {
|
if cfg!(target_os = "linux") {
|
||||||
self.clipboard_manager.set_clipboard(m.replace.as_str());
|
self.sender.send_string(m.replace.as_str());
|
||||||
self.sender.trigger_paste();
|
}else{
|
||||||
//self.sender.send_string(m.replace.as_str());
|
// To handle newlines, substitute each "\n" char with an Enter key press.
|
||||||
}else{
|
let splits = m.replace.lines();
|
||||||
// To handle newlines, substitute each "\n" char with an Enter key press.
|
|
||||||
let splits = m.replace.lines();
|
|
||||||
|
|
||||||
for (i, split) in splits.enumerate() {
|
for (i, split) in splits.enumerate() {
|
||||||
if i > 0 {
|
if i > 0 {
|
||||||
self.sender.send_enter();
|
self.sender.send_enter();
|
||||||
|
}
|
||||||
|
|
||||||
|
self.sender.send_string(split);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
},
|
||||||
self.sender.send_string(split);
|
BackendType::Clipboard => {
|
||||||
}
|
self.clipboard_manager.set_clipboard(m.replace.as_str());
|
||||||
|
self.sender.trigger_paste();
|
||||||
|
},
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
Loading…
Reference in New Issue
Block a user