use objc2::{Message, extern_protocol, msg_send, rc::Retained, runtime::ProtocolObject};
use objc2_foundation::{NSObjectProtocol, NSString};
use crate::{
MTLDevice, MTLIntersectionFunctionTableDescriptor, MTLResourceID, MTLVisibleFunctionTable,
MTLVisibleFunctionTableDescriptor,
};
extern_protocol!(
pub unsafe trait MTLComputePipelineState: NSObjectProtocol + Send + Sync {
#[unsafe(method(device))]
#[unsafe(method_family = none)]
fn device(&self) -> Retained<ProtocolObject<dyn MTLDevice>>;
#[unsafe(method(maxTotalThreadsPerThreadgroup))]
#[unsafe(method_family = none)]
fn max_total_threads_per_threadgroup(&self) -> usize;
#[unsafe(method(threadExecutionWidth))]
#[unsafe(method_family = none)]
fn thread_execution_width(&self) -> usize;
#[unsafe(method(staticThreadgroupMemoryLength))]
#[unsafe(method_family = none)]
fn static_threadgroup_memory_length(&self) -> usize;
#[unsafe(method(gpuResourceID))]
#[unsafe(method_family = none)]
fn gpu_resource_id(&self) -> MTLResourceID;
#[unsafe(method(reflection))]
#[unsafe(method_family = none)]
fn reflection(&self) -> Option<Retained<super::MTLComputePipelineReflection>>;
#[unsafe(method(newVisibleFunctionTableWithDescriptor:))]
#[unsafe(method_family = new)]
fn new_visible_function_table_with_descriptor(
&self,
descriptor: &MTLVisibleFunctionTableDescriptor,
) -> Option<Retained<ProtocolObject<dyn MTLVisibleFunctionTable>>>;
#[unsafe(method(newIntersectionFunctionTableWithDescriptor:))]
#[unsafe(method_family = new)]
fn new_intersection_function_table_with_descriptor(
&self,
descriptor: &MTLIntersectionFunctionTableDescriptor,
) -> Option<Retained<ProtocolObject<dyn crate::MTLIntersectionFunctionTable>>>;
}
);
#[allow(unused)]
pub trait MTLComputePipelineStateExt: MTLComputePipelineState + Message {
fn label(&self) -> Option<String>;
}
impl MTLComputePipelineStateExt for ProtocolObject<dyn MTLComputePipelineState> {
fn label(&self) -> Option<String> {
let label: Option<Retained<NSString>> = unsafe { msg_send![self, label] };
label.map(|s| s.to_string())
}
}