objc2-virtualization 0.3.2

Bindings to the Virtualization framework
Documentation
//! This file has been automatically generated by `objc2`'s `header-translator`.
//! DO NOT EDIT
use core::ffi::*;
use core::ptr::NonNull;
use objc2::__framework_prelude::*;

use crate::*;

extern_class!(
    /// The VZVirtioSocketConnection object represents a Virtio socket device's connection.
    ///
    /// The connection encompasses a source port, destination port, and an associated file descriptor.
    ///
    /// See: VZVirtioSocketDevice
    ///
    /// See also [Apple's documentation](https://developer.apple.com/documentation/virtualization/vzvirtiosocketconnection?language=objc)
    #[unsafe(super(NSObject))]
    #[derive(Debug, PartialEq, Eq, Hash)]
    pub struct VZVirtioSocketConnection;
);

extern_conformance!(
    unsafe impl NSObjectProtocol for VZVirtioSocketConnection {}
);

impl VZVirtioSocketConnection {
    extern_methods!(
        #[unsafe(method(new))]
        #[unsafe(method_family = new)]
        pub unsafe fn new() -> Retained<Self>;

        #[unsafe(method(init))]
        #[unsafe(method_family = init)]
        pub unsafe fn init(this: Allocated<Self>) -> Retained<Self>;

        /// The destination port number of the connection.
        #[unsafe(method(destinationPort))]
        #[unsafe(method_family = none)]
        pub unsafe fn destinationPort(&self) -> u32;

        /// The source port number of the connection.
        #[unsafe(method(sourcePort))]
        #[unsafe(method_family = none)]
        pub unsafe fn sourcePort(&self) -> u32;

        /// The file descriptor associated with the socket.
        ///
        /// Data is sent by writing to the file descriptor.
        /// Data is received by reading from the file descriptor.
        /// A file descriptor of -1 indicates a closed connection.
        ///
        /// The file descriptor is owned by the VZVirtioSocketConnection. It is automatically closed when the object is destroyed.
        #[unsafe(method(fileDescriptor))]
        #[unsafe(method_family = none)]
        pub unsafe fn fileDescriptor(&self) -> c_int;

        /// Close the file descriptor that's associated with the socket.
        #[unsafe(method(close))]
        #[unsafe(method_family = none)]
        pub unsafe fn close(&self);
    );
}