From be2391a69ab82d4f2728486805f13368a72b2140 Mon Sep 17 00:00:00 2001 From: Ignacio Casal Quinteiro Date: Mon, 9 Dec 2024 10:45:21 +0100 Subject: [PATCH] gdk4-macos: manually implement native_window method For now we need to depend on the cocoa crate in order to implement this method since it is the only decent crate implementing the cocoa api. --- Cargo.lock | 116 +++++++++++++++++++++++++++ gdk4-macos/Cargo.toml | 1 + gdk4-macos/Gir.toml | 10 ++- gdk4-macos/src/auto/macos_surface.rs | 8 -- gdk4-macos/src/lib.rs | 2 + gdk4-macos/src/macos_surface.rs | 26 ++++++ 6 files changed, 153 insertions(+), 10 deletions(-) create mode 100644 gdk4-macos/src/macos_surface.rs diff --git a/Cargo.lock b/Cargo.lock index 602da4388af6..1dae94b7bc2f 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -101,6 +101,12 @@ dependencies = [ "typenum", ] +[[package]] +name = "block" +version = "0.1.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "0d8c1fef690941d3e7788d328517591fecc684c084084702d6ff1641e993699a" + [[package]] name = "bumpalo" version = "3.16.0" @@ -211,6 +217,36 @@ dependencies = [ "windows-targets", ] +[[package]] +name = "cocoa" +version = "0.26.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f79398230a6e2c08f5c9760610eb6924b52aa9e7950a619602baba59dcbbdbb2" +dependencies = [ + "bitflags 2.6.0", + "block", + "cocoa-foundation", + "core-foundation", + "core-graphics", + "foreign-types", + "libc", + "objc", +] + +[[package]] +name = "cocoa-foundation" +version = "0.2.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e14045fb83be07b5acf1c0884b2180461635b433455fa35d1cd6f17f1450679d" +dependencies = [ + "bitflags 2.6.0", + "block", + "core-foundation", + "core-graphics-types", + "libc", + "objc", +] + [[package]] name = "color_quant" version = "1.1.0" @@ -226,12 +262,46 @@ dependencies = [ "crossbeam-utils", ] +[[package]] +name = "core-foundation" +version = "0.10.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b55271e5c8c478ad3f38ad24ef34923091e0548492a266d19b3c0b4d82574c63" +dependencies = [ + "core-foundation-sys", + "libc", +] + [[package]] name = "core-foundation-sys" version = "0.8.7" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "773648b94d0e5d620f64f280777445740e61fe701025087ec8b57f45c791888b" +[[package]] +name = "core-graphics" +version = "0.24.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "fa95a34622365fa5bbf40b20b75dba8dfa8c94c734aea8ac9a5ca38af14316f1" +dependencies = [ + "bitflags 2.6.0", + "core-foundation", + "core-graphics-types", + "foreign-types", + "libc", +] + +[[package]] +name = "core-graphics-types" +version = "0.2.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "3d44a101f213f6c4cdc1853d4b78aef6db6bdfa3468798cc1d9912f4735013eb" +dependencies = [ + "bitflags 2.6.0", + "core-foundation", + "libc", +] + [[package]] name = "core_maths" version = "0.1.0" @@ -366,6 +436,33 @@ version = "1.0.7" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "3f9eec918d3f24069decb9af1554cad7c880e2da24a9afd88aca000531ab82c1" +[[package]] +name = "foreign-types" +version = "0.5.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d737d9aa519fb7b749cbc3b962edcf310a8dd1f4b67c91c4f83975dbdd17d965" +dependencies = [ + "foreign-types-macros", + "foreign-types-shared", +] + +[[package]] +name = "foreign-types-macros" +version = "0.2.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1a5c6c585bc94aaf2c7b51dd4c2ba22680844aba4c687be581871a6f518c5742" +dependencies = [ + "proc-macro2", + "quote", + "syn", +] + +[[package]] +name = "foreign-types-shared" +version = "0.3.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "aa9a19cbb55df58761df49b23516a86d432839add4af60fc256da840f66ed35b" + [[package]] name = "form_urlencoded" version = "1.2.1" @@ -480,6 +577,7 @@ dependencies = [ name = "gdk4-macos" version = "0.10.0" dependencies = [ + "cocoa", "gdk4", "gdk4-macos-sys", "gio", @@ -1318,6 +1416,15 @@ version = "0.12.5" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "234cf4f4a04dc1f57e24b96cc0cd600cf2af460d4161ac5ecdd0af8e1f3b2a38" +[[package]] +name = "malloc_buf" +version = "0.0.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "62bb907fe88d54d8d9ce32a3cceab4218ed2f6b7d35617cafe9adf84e43919cb" +dependencies = [ + "libc", +] + [[package]] name = "memchr" version = "2.7.4" @@ -1369,6 +1476,15 @@ dependencies = [ "autocfg", ] +[[package]] +name = "objc" +version = "0.2.7" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "915b1b472bc21c53464d6c8461c9d3af805ba1ef837e1cac254428f4a77177b1" +dependencies = [ + "malloc_buf", +] + [[package]] name = "object" version = "0.36.5" diff --git a/gdk4-macos/Cargo.toml b/gdk4-macos/Cargo.toml index 6c6824625630..e8e52bfab08d 100644 --- a/gdk4-macos/Cargo.toml +++ b/gdk4-macos/Cargo.toml @@ -22,6 +22,7 @@ gdk.workspace = true gio.workspace = true glib.workspace = true libc.workspace = true +cocoa = "0.26" [dev-dependencies] gir-format-check.workspace = true diff --git a/gdk4-macos/Gir.toml b/gdk4-macos/Gir.toml index 1deea6c27fb7..20284535c9cc 100644 --- a/gdk4-macos/Gir.toml +++ b/gdk4-macos/Gir.toml @@ -17,7 +17,6 @@ generate = [ "GdkMacos.MacosGLContext", "GdkMacos.MacosKeymap", "GdkMacos.MacosSeat", - "GdkMacos.MacosSurface", ] manual = [ @@ -36,4 +35,11 @@ name = "GdkMacos.MacosMonitor" status = "generate" [[object.function]] name = "get_geometry" - ignore = true # The function does not exists \ No newline at end of file + ignore = true # The function does not exists + +[[object]] +name = "GdkMacos.MacosSurface" +status = "generate" + [[object.function]] + name = "get_native_window" + manual = true diff --git a/gdk4-macos/src/auto/macos_surface.rs b/gdk4-macos/src/auto/macos_surface.rs index 8dc628bd49ec..9459166b05ee 100644 --- a/gdk4-macos/src/auto/macos_surface.rs +++ b/gdk4-macos/src/auto/macos_surface.rs @@ -20,14 +20,6 @@ glib::wrapper! { } impl MacosSurface { - //#[cfg(feature = "v4_8")] - //#[cfg_attr(docsrs, doc(cfg(feature = "v4_8")))] - //#[doc(alias = "gdk_macos_surface_get_native_window")] - //#[doc(alias = "get_native_window")] - //pub fn native_window(&self) -> /*Unimplemented*/Option { - // unsafe { TODO: call ffi:gdk_macos_surface_get_native_window() } - //} - //pub fn native(&self) -> /*Unimplemented*/Basic: Pointer { // ObjectExt::property(self, "native") //} diff --git a/gdk4-macos/src/lib.rs b/gdk4-macos/src/lib.rs index c9ff34a3d8b2..93d15cfbd764 100644 --- a/gdk4-macos/src/lib.rs +++ b/gdk4-macos/src/lib.rs @@ -16,3 +16,5 @@ mod auto; pub mod prelude; pub use auto::*; + +mod macos_surface; diff --git a/gdk4-macos/src/macos_surface.rs b/gdk4-macos/src/macos_surface.rs new file mode 100644 index 000000000000..15438a579449 --- /dev/null +++ b/gdk4-macos/src/macos_surface.rs @@ -0,0 +1,26 @@ +// Take a look at the license at the top of the repository in the LICENSE file. + +#[cfg(feature = "v4_8")] +use crate::ffi; +use crate::MacosSurface; +#[cfg(feature = "v4_8")] +use cocoa::base::id; +#[cfg(feature = "v4_8")] +use glib::translate::*; + +impl MacosSurface { + #[cfg(feature = "v4_8")] + #[cfg_attr(docsrs, doc(cfg(feature = "v4_8")))] + #[doc(alias = "gdk_macos_surface_get_native_window")] + #[doc(alias = "get_native_window")] + pub fn native_window(&self) -> Option { + unsafe { + let native_window_ptr = ffi::gdk_macos_surface_get_native_window(self.to_glib_none().0); + if native_window_ptr.is_null() { + None + } else { + Some(native_window_ptr as id) + } + } + } +}