gdk4/auto/
vulkan_context.rs

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
// This file was generated by gir (https://github.com/gtk-rs/gir)
// from gir-files (https://github.com/gtk-rs/gir-files)
// DO NOT EDIT

use crate::{ffi, DrawContext};
use glib::{
    prelude::*,
    signal::{connect_raw, SignalHandlerId},
    translate::*,
};
use std::boxed::Box as Box_;

glib::wrapper! {
    /// GTK does not expose any Vulkan internals. This
    ///   struct is a leftover that was accidentally exposed.
    /// [`VulkanContext`][crate::VulkanContext] is an object representing the platform-specific
    /// Vulkan draw context.
    ///
    /// [`VulkanContext`][crate::VulkanContext]s are created for a surface using
    /// [`SurfaceExt::create_vulkan_context()`][crate::prelude::SurfaceExt::create_vulkan_context()], and the context will match
    /// the characteristics of the surface.
    ///
    /// Support for [`VulkanContext`][crate::VulkanContext] is platform-specific and context creation
    /// can fail, returning [`None`] context.
    ///
    /// This is an Abstract Base Class, you cannot instantiate it.
    ///
    /// ## Signals
    ///
    ///
    /// #### `images-updated`
    ///  Emitted when the images managed by this context have changed.
    ///
    /// Usually this means that the swapchain had to be recreated,
    /// for example in response to a change of the surface size.
    ///
    ///
    ///
    /// # Implements
    ///
    /// [`DrawContextExt`][trait@crate::prelude::DrawContextExt], [`trait@gio::prelude::InitableExt`], [`DrawContextExtManual`][trait@crate::prelude::DrawContextExtManual]
    #[doc(alias = "GdkVulkanContext")]
    pub struct VulkanContext(Object<ffi::GdkVulkanContext>) @extends DrawContext, @implements gio::Initable;

    match fn {
        type_ => || ffi::gdk_vulkan_context_get_type(),
    }
}

impl VulkanContext {
    /// Emitted when the images managed by this context have changed.
    ///
    /// Usually this means that the swapchain had to be recreated,
    /// for example in response to a change of the surface size.
    #[doc(alias = "images-updated")]
    pub fn connect_images_updated<F: Fn(&Self) + 'static>(&self, f: F) -> SignalHandlerId {
        unsafe extern "C" fn images_updated_trampoline<F: Fn(&VulkanContext) + 'static>(
            this: *mut ffi::GdkVulkanContext,
            f: glib::ffi::gpointer,
        ) {
            let f: &F = &*(f as *const F);
            f(&from_glib_borrow(this))
        }
        unsafe {
            let f: Box_<F> = Box_::new(f);
            connect_raw(
                self.as_ptr() as *mut _,
                c"images-updated".as_ptr() as *const _,
                Some(std::mem::transmute::<*const (), unsafe extern "C" fn()>(
                    images_updated_trampoline::<F> as *const (),
                )),
                Box_::into_raw(f),
            )
        }
    }
}