summaryrefslogtreecommitdiffstats
path: root/winit
diff options
context:
space:
mode:
Diffstat (limited to 'winit')
-rw-r--r--winit/src/application.rs20
-rw-r--r--winit/src/clipboard.rs64
-rw-r--r--winit/src/multi_window.rs20
3 files changed, 30 insertions, 74 deletions
diff --git a/winit/src/application.rs b/winit/src/application.rs
index 2d3ac52c..0fc67adc 100644
--- a/winit/src/application.rs
+++ b/winit/src/application.rs
@@ -704,27 +704,15 @@ pub fn run_command<A, C, E>(
runtime.run(stream);
}
command::Action::Clipboard(action) => match action {
- clipboard::Action::Read(tag) => {
- let message = tag(clipboard.read());
+ clipboard::Action::Read(tag, kind) => {
+ let message = tag(clipboard.read(kind));
proxy
.send_event(message)
.expect("Send message to event loop");
}
- clipboard::Action::Write(contents) => {
- clipboard.write(contents);
- }
- },
- command::Action::ClipboardPrimary(action) => match action {
- clipboard::Action::Read(tag) => {
- let message = tag(clipboard.read_primary());
-
- proxy
- .send_event(message)
- .expect("Send message to event loop");
- }
- clipboard::Action::Write(contents) => {
- clipboard.write_primary(contents);
+ clipboard::Action::Write(contents, kind) => {
+ clipboard.write(kind, contents);
}
},
command::Action::Window(action) => match action {
diff --git a/winit/src/clipboard.rs b/winit/src/clipboard.rs
index a1496fa3..5237ca01 100644
--- a/winit/src/clipboard.rs
+++ b/winit/src/clipboard.rs
@@ -1,5 +1,7 @@
//! Access the clipboard.
+use crate::core::clipboard::Kind;
+
/// A buffer for short-term storage and transfer within and between
/// applications.
#[allow(missing_debug_implementations)]
@@ -33,46 +35,32 @@ impl Clipboard {
}
/// Reads the current content of the [`Clipboard`] as text.
- pub fn read(&self) -> Option<String> {
+ pub fn read(&self, kind: Kind) -> Option<String> {
match &self.state {
- State::Connected(clipboard) => clipboard.read().ok(),
+ State::Connected(clipboard) => match kind {
+ Kind::Standard => clipboard.read().ok(),
+ Kind::Primary => clipboard.read_primary().and_then(Result::ok),
+ },
State::Unavailable => None,
}
}
/// Writes the given text contents to the [`Clipboard`].
- pub fn write(&mut self, contents: String) {
+ pub fn write(&mut self, kind: Kind, contents: String) {
match &mut self.state {
- State::Connected(clipboard) => match clipboard.write(contents) {
- Ok(()) => {}
- Err(error) => {
- log::warn!("error writing to clipboard: {error}");
- }
- },
- State::Unavailable => {}
- }
- }
-
- /// Reads the current content of primary as text.
- pub fn read_primary(&self) -> Option<String> {
- match &self.state {
State::Connected(clipboard) => {
- clipboard.read_primary().and_then(|r| r.ok())
- }
- State::Unavailable => None,
- }
- }
+ let result = match kind {
+ Kind::Standard => clipboard.write(contents),
+ Kind::Primary => {
+ clipboard.write_primary(contents).unwrap_or(Ok(()))
+ }
+ };
- /// Writes the given text contents to primary.
- pub fn write_primary(&mut self, contents: String) {
- match &mut self.state {
- State::Connected(clipboard) => {
- match clipboard.write_primary(contents) {
- Some(Ok(())) => {}
- Some(Err(error)) => {
- log::warn!("error writing to primary: {error}");
+ match result {
+ Ok(()) => {}
+ Err(error) => {
+ log::warn!("error writing to clipboard: {error}");
}
- None => {}
}
}
State::Unavailable => {}
@@ -81,19 +69,11 @@ impl Clipboard {
}
impl crate::core::Clipboard for Clipboard {
- fn read(&self) -> Option<String> {
- self.read()
- }
-
- fn write(&mut self, contents: String) {
- self.write(contents);
- }
-
- fn read_primary(&self) -> Option<String> {
- self.read_primary()
+ fn read(&self, kind: Kind) -> Option<String> {
+ self.read(kind)
}
- fn write_primary(&mut self, contents: String) {
- self.write_primary(contents);
+ fn write(&mut self, kind: Kind, contents: String) {
+ self.write(kind, contents);
}
}
diff --git a/winit/src/multi_window.rs b/winit/src/multi_window.rs
index 33f521c4..ed00abdf 100644
--- a/winit/src/multi_window.rs
+++ b/winit/src/multi_window.rs
@@ -876,27 +876,15 @@ fn run_command<A, C, E>(
runtime.run(Box::pin(stream));
}
command::Action::Clipboard(action) => match action {
- clipboard::Action::Read(tag) => {
- let message = tag(clipboard.read());
+ clipboard::Action::Read(tag, kind) => {
+ let message = tag(clipboard.read(kind));
proxy
.send_event(message)
.expect("Send message to event loop");
}
- clipboard::Action::Write(contents) => {
- clipboard.write(contents);
- }
- },
- command::Action::ClipboardPrimary(action) => match action {
- clipboard::Action::Read(tag) => {
- let message = tag(clipboard.read_primary());
-
- proxy
- .send_event(message)
- .expect("Send message to event loop");
- }
- clipboard::Action::Write(contents) => {
- clipboard.write_primary(contents);
+ clipboard::Action::Write(contents, kind) => {
+ clipboard.write(kind, contents);
}
},
command::Action::Window(action) => match action {