feat: dnd integration
This commit is contained in:
parent
c3e9e794b9
commit
228288dfdf
11 changed files with 589 additions and 14 deletions
88
dnd/src/platform/linux.rs
Normal file
88
dnd/src/platform/linux.rs
Normal file
|
|
@ -0,0 +1,88 @@
|
|||
use std::{borrow::Cow, ffi::c_void, sync::Arc};
|
||||
|
||||
use crate::{DataWrapper, DndAction, DndSurface};
|
||||
use smithay_clipboard::mime::{AllowedMimeTypes, AsMimeTypes, MimeType};
|
||||
|
||||
impl<
|
||||
T: mime::AllowedMimeTypes
|
||||
+ std::convert::TryFrom<(std::vec::Vec<u8>, String)>,
|
||||
> AllowedMimeTypes for DataWrapper<T>
|
||||
{
|
||||
fn allowed() -> Cow<'static, [MimeType]> {
|
||||
T::allowed()
|
||||
.into_iter()
|
||||
.map(|s| MimeType::from(Cow::Owned(s.to_string())))
|
||||
.collect()
|
||||
}
|
||||
}
|
||||
|
||||
impl<T: TryFrom<(Vec<u8>, String)>> TryFrom<(Vec<u8>, MimeType)>
|
||||
for DataWrapper<T>
|
||||
{
|
||||
type Error = T::Error;
|
||||
|
||||
fn try_from(
|
||||
(data, mime): (Vec<u8>, MimeType),
|
||||
) -> Result<Self, Self::Error> {
|
||||
T::try_from((data, mime.to_string())).map(|d| DataWrapper(d))
|
||||
}
|
||||
}
|
||||
|
||||
impl<T: mime::AsMimeTypes> AsMimeTypes for DataWrapper<T> {
|
||||
fn available(&self) -> Cow<'static, [MimeType]> {
|
||||
self.0
|
||||
.available()
|
||||
.into_iter()
|
||||
.map(|m| MimeType::from(Cow::Owned(m.to_string())))
|
||||
.collect()
|
||||
}
|
||||
|
||||
fn as_bytes(&self, mime_type: &MimeType) -> Option<Cow<'static, [u8]>> {
|
||||
self.0.as_bytes(mime_type.as_ref())
|
||||
}
|
||||
}
|
||||
|
||||
impl smithay_clipboard::dnd::RawSurface for DndSurface {
|
||||
unsafe fn get_ptr(&mut self) -> *mut c_void {
|
||||
// XXX won't panic because this is only called once before it could be cloned
|
||||
Arc::get_mut(&mut self.0).unwrap().get_ptr()
|
||||
}
|
||||
}
|
||||
|
||||
impl From<sctk::reexports::client::protocol::wl_data_device_manager::DndAction>
|
||||
for DndAction
|
||||
{
|
||||
fn from(
|
||||
action: sctk::reexports::client::protocol::wl_data_device_manager::DndAction,
|
||||
) -> Self {
|
||||
let mut a = DndAction::empty();
|
||||
if action.contains(sctk::reexports::client::protocol::wl_data_device_manager::DndAction::Copy) {
|
||||
a |= DndAction::Copy;
|
||||
}
|
||||
if action.contains(sctk::reexports::client::protocol::wl_data_device_manager::DndAction::Move) {
|
||||
a |= DndAction::Move;
|
||||
}
|
||||
if action.contains(sctk::reexports::client::protocol::wl_data_device_manager::DndAction::Ask) {
|
||||
a |= DndAction::Ask;
|
||||
}
|
||||
a
|
||||
}
|
||||
}
|
||||
|
||||
impl From<DndAction>
|
||||
for sctk::reexports::client::protocol::wl_data_device_manager::DndAction
|
||||
{
|
||||
fn from(action: DndAction) -> Self {
|
||||
let mut a = sctk::reexports::client::protocol::wl_data_device_manager::DndAction::empty();
|
||||
if action.contains(DndAction::Copy) {
|
||||
a |= sctk::reexports::client::protocol::wl_data_device_manager::DndAction::Copy;
|
||||
}
|
||||
if action.contains(DndAction::Move) {
|
||||
a |= sctk::reexports::client::protocol::wl_data_device_manager::DndAction::Move;
|
||||
}
|
||||
if action.contains(DndAction::Ask) {
|
||||
a |= sctk::reexports::client::protocol::wl_data_device_manager::DndAction::Ask;
|
||||
}
|
||||
a
|
||||
}
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue