Fix missing clipboard content
This commit is contained in:
parent
516904551c
commit
972ec8d79d
@ -1,12 +1,11 @@
|
|||||||
use std::sync::mpsc::Sender;
|
|
||||||
|
|
||||||
use clipboard_master::{CallbackResult, ClipboardHandler, Master};
|
|
||||||
|
|
||||||
use super::*;
|
use super::*;
|
||||||
pub use crate::common::{
|
pub use crate::common::{
|
||||||
check_clipboard, ClipboardContext, CLIPBOARD_INTERVAL as INTERVAL, CLIPBOARD_NAME as NAME,
|
check_clipboard, ClipboardContext, CLIPBOARD_INTERVAL as INTERVAL, CLIPBOARD_NAME as NAME,
|
||||||
CONTENT,
|
CONTENT,
|
||||||
};
|
};
|
||||||
|
use clipboard_master::{CallbackResult, ClipboardHandler, Master};
|
||||||
|
use hbb_common::ResultType;
|
||||||
|
use std::{sync, sync::mpsc::Sender, thread};
|
||||||
|
|
||||||
struct State {
|
struct State {
|
||||||
ctx: Option<ClipboardContext>,
|
ctx: Option<ClipboardContext>,
|
||||||
@ -31,41 +30,56 @@ impl super::service::Reset for State {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
struct ClipHandle {
|
|
||||||
tx: Sender<bool>,
|
|
||||||
}
|
|
||||||
|
|
||||||
impl ClipboardHandler for ClipHandle {
|
|
||||||
fn on_clipboard_change(&mut self) -> CallbackResult {
|
|
||||||
let _ = self.tx.send(true);
|
|
||||||
CallbackResult::Next
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn new() -> GenericService {
|
pub fn new() -> GenericService {
|
||||||
let sp = GenericService::new(NAME, true);
|
let sp = GenericService::new(NAME, true);
|
||||||
sp.listen::<State, _, _>(notify, run);
|
sp.run::<_>(listen::run);
|
||||||
sp
|
sp
|
||||||
}
|
}
|
||||||
|
|
||||||
fn notify(tx: Sender<bool>) -> ResultType<()> {
|
mod listen {
|
||||||
Master::new(ClipHandle { tx }).run()?;
|
use super::*;
|
||||||
Ok(())
|
|
||||||
}
|
|
||||||
|
|
||||||
fn run(sp: GenericService, state: &mut State) -> ResultType<()> {
|
struct ClipHandle {
|
||||||
if let Some(ctx) = state.ctx.as_mut() {
|
tx: Sender<()>,
|
||||||
if let Some(msg) = check_clipboard(ctx, None) {
|
}
|
||||||
sp.send(msg);
|
|
||||||
}
|
impl ClipboardHandler for ClipHandle {
|
||||||
sp.snapshot(|sps| {
|
fn on_clipboard_change(&mut self) -> CallbackResult {
|
||||||
let txt = crate::CONTENT.lock().unwrap().clone();
|
let _ = self.tx.send(());
|
||||||
if !txt.is_empty() {
|
CallbackResult::Next
|
||||||
let msg_out = crate::create_clipboard_msg(txt);
|
}
|
||||||
sps.send_shared(Arc::new(msg_out));
|
}
|
||||||
}
|
|
||||||
Ok(())
|
fn notify(tx: Sender<()>) -> ResultType<()> {
|
||||||
})?;
|
Master::new(ClipHandle { tx }).run()?;
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn run(sp: GenericService) -> ResultType<()> {
|
||||||
|
let mut state = State::default();
|
||||||
|
let (tx, rx) = sync::mpsc::channel::<()>();
|
||||||
|
thread::spawn(|| {
|
||||||
|
let _ = notify(tx);
|
||||||
|
});
|
||||||
|
|
||||||
|
while sp.ok() {
|
||||||
|
sp.snapshot(|sps| {
|
||||||
|
let txt = crate::CONTENT.lock().unwrap().clone();
|
||||||
|
if !txt.is_empty() {
|
||||||
|
let msg_out = crate::create_clipboard_msg(txt);
|
||||||
|
sps.send_shared(Arc::new(msg_out));
|
||||||
|
}
|
||||||
|
Ok(())
|
||||||
|
})?;
|
||||||
|
|
||||||
|
if let Ok(()) = rx.recv() {
|
||||||
|
if let Some(ctx) = state.ctx.as_mut() {
|
||||||
|
if let Some(msg) = check_clipboard(ctx, None) {
|
||||||
|
sp.send(msg);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Ok(())
|
||||||
}
|
}
|
||||||
Ok(())
|
|
||||||
}
|
}
|
||||||
|
@ -1,6 +1,5 @@
|
|||||||
use super::*;
|
use super::*;
|
||||||
use std::{
|
use std::{
|
||||||
sync::{self, mpsc::Sender},
|
|
||||||
thread::{self, JoinHandle},
|
thread::{self, JoinHandle},
|
||||||
time,
|
time,
|
||||||
};
|
};
|
||||||
@ -154,39 +153,6 @@ impl<T: Subscriber + From<ConnInner>> ServiceTmpl<T> {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn listen<S, N, F>(&self, notify: N, callback: F)
|
|
||||||
where
|
|
||||||
N: 'static + FnMut(Sender<bool>) -> ResultType<()> + Send,
|
|
||||||
F: 'static + FnMut(Self, &mut S) -> ResultType<()> + Send,
|
|
||||||
S: 'static + Default + Reset,
|
|
||||||
{
|
|
||||||
let mut notify = notify;
|
|
||||||
let mut callback = callback;
|
|
||||||
let sp = self.clone();
|
|
||||||
let (tx, rx) = sync::mpsc::channel();
|
|
||||||
thread::spawn(move || {
|
|
||||||
let _ = notify(tx);
|
|
||||||
});
|
|
||||||
|
|
||||||
let thread = thread::spawn(move || {
|
|
||||||
let mut state = S::default();
|
|
||||||
while let Ok(changed) = rx.recv() {
|
|
||||||
if changed && sp.active() {
|
|
||||||
if sp.has_subscribes() {
|
|
||||||
if let Err(err) = callback(sp.clone(), &mut state) {
|
|
||||||
log::error!("Error of {} service: {}", sp.name(), err);
|
|
||||||
#[cfg(windows)]
|
|
||||||
crate::platform::windows::try_change_desktop();
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
state.reset();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
self.0.write().unwrap().handle = Some(thread);
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn repeat<S, F>(&self, interval_ms: u64, callback: F)
|
pub fn repeat<S, F>(&self, interval_ms: u64, callback: F)
|
||||||
where
|
where
|
||||||
F: 'static + FnMut(Self, &mut S) -> ResultType<()> + Send,
|
F: 'static + FnMut(Self, &mut S) -> ResultType<()> + Send,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user