Skip to content

Commit

Permalink
patch: fix active enable of file copy paste
Browse files Browse the repository at this point in the history
Signed-off-by: ClSlaid <[email protected]>
  • Loading branch information
ClSlaid committed Oct 30, 2023
1 parent 803509d commit 43aa62e
Show file tree
Hide file tree
Showing 4 changed files with 25 additions and 30 deletions.
13 changes: 13 additions & 0 deletions libs/clipboard/src/context_send.rs
Original file line number Diff line number Diff line change
Expand Up @@ -47,6 +47,19 @@ impl ContextSend {
}
}

/// make sure the clipboard context is enabled.
pub fn make_sure_enabled() -> ResultType<()> {
let mut lock = CONTEXT_SEND.addr.lock().unwrap();
if lock.is_some() {
return Ok(());
}

let ctx = crate::create_cliprdr_context(true, false, CLIPBOARD_RESPONSE_WAIT_TIMEOUT_SECS)?;
*lock = Some(ctx);
log::info!("clipboard context for file transfer recreated.");
Ok(())
}

pub fn proc<F: FnOnce(&mut Box<dyn CliprdrServiceContext>) -> ResultType<()>>(
f: F,
) -> ResultType<()> {
Expand Down
3 changes: 1 addition & 2 deletions libs/clipboard/src/platform/unix/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -63,7 +63,6 @@ fn add_remote_format(local_name: &str, remote_id: i32) {

trait SysClipboard: Send + Sync {
fn start(&self);
fn stop(&self);

fn set_file_list(&self, paths: &[PathBuf]) -> Result<(), CliprdrError>;
fn get_file_list(&self) -> Vec<PathBuf>;
Expand Down Expand Up @@ -524,7 +523,7 @@ impl CliprdrServiceContext for ClipboardContext {
if let Some(fuse_handle) = self.fuse_handle.lock().take() {
fuse_handle.join();
}
self.clipboard.stop();
// we don't stop the clipboard, keep listening in case of restart
Ok(())
}

Expand Down
33 changes: 5 additions & 28 deletions libs/clipboard/src/platform/unix/x11.rs
Original file line number Diff line number Diff line change
@@ -1,8 +1,4 @@
use std::{
collections::BTreeSet,
path::PathBuf,
sync::atomic::{AtomicBool, Ordering},
};
use std::{collections::BTreeSet, path::PathBuf};

use hbb_common::log;
use once_cell::sync::OnceCell;
Expand All @@ -21,7 +17,6 @@ fn get_clip() -> Result<&'static Clipboard, CliprdrError> {
}

pub struct X11Clipboard {
stop: AtomicBool,
ignore_path: PathBuf,
text_uri_list: Atom,
gnome_copied_files: Atom,
Expand All @@ -47,7 +42,6 @@ impl X11Clipboard {
.map_err(|_| CliprdrError::CliprdrInit)?;
Ok(Self {
ignore_path: ignore_path.to_owned(),
stop: AtomicBool::new(false),
text_uri_list,
gnome_copied_files,
nautilus_clipboard,
Expand Down Expand Up @@ -85,22 +79,12 @@ impl X11Clipboard {
}

fn wait_file_list(&self) -> Result<Option<Vec<PathBuf>>, CliprdrError> {
if self.stop.load(Ordering::Relaxed) {
return Ok(None);
}
let v = self.load(self.text_uri_list)?;
let p = parse_plain_uri_list(v)?;
Ok(Some(p))
}
}

impl X11Clipboard {
#[inline]
fn is_stopped(&self) -> bool {
self.stop.load(Ordering::Relaxed)
}
}

impl SysClipboard for X11Clipboard {
fn set_file_list(&self, paths: &[PathBuf]) -> Result<(), CliprdrError> {
*self.former_file_list.lock() = paths.to_vec();
Expand All @@ -118,13 +102,11 @@ impl SysClipboard for X11Clipboard {
.map_err(|_| CliprdrError::ClipboardInternalError)
}

fn stop(&self) {
self.stop.store(true, Ordering::Relaxed);
}

fn start(&self) {
self.stop.store(false, Ordering::Relaxed);

{
// clear cached file list
*self.former_file_list.lock() = vec![];
}
loop {
let sth = match self.wait_file_list() {
Ok(sth) => sth,
Expand All @@ -135,11 +117,6 @@ impl SysClipboard for X11Clipboard {
}
};

if self.is_stopped() {
std::thread::sleep(std::time::Duration::from_millis(100));
continue;
}

let Some(paths) = sth else {
// just sleep
std::thread::sleep(std::time::Duration::from_millis(100));
Expand Down
6 changes: 6 additions & 0 deletions src/client/io_loop.rs
Original file line number Diff line number Diff line change
Expand Up @@ -317,6 +317,9 @@ impl<T: InvokeUiSession> Remote<T> {
if stop {
ContextSend::set_is_stopped();
} else {
if let Err(e) = ContextSend::make_sure_enabled() {
log::error!("failed to restart clipboard context: {}", e);
};
log::debug!("Send system clipboard message to remote");
let msg = crate::clipboard_file::clip_2_msg(clip);
allow_err!(peer.send(&msg).await);
Expand Down Expand Up @@ -1742,6 +1745,9 @@ impl<T: InvokeUiSession> Remote<T> {
"Process clipboard message from server peer, stop: {}, is_stopping_allowed: {}, file_transfer_enabled: {}",
stop, is_stopping_allowed, file_transfer_enabled);
if !stop {
if let Err(e) = ContextSend::make_sure_enabled() {
log::error!("failed to restart clipboard context: {}", e);
};
let _ = ContextSend::proc(|context| -> ResultType<()> {
context
.server_clip_file(self.client_conn_id, clip)
Expand Down

0 comments on commit 43aa62e

Please sign in to comment.