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
77
78
79
80
81
82
83
84
85
use std::mem;
use mach::kern_return;
use core_foundation::base::{CFType, TCFType};
use core_foundation::dictionary::CFMutableDictionaryRef;
use core_foundation::string::CFString;
use core_foundation::base::kCFAllocatorDefault;
use core_foundation::dictionary::{CFDictionary, CFMutableDictionary};
use crate::{Result, Error};
use super::ffi;
use std::convert::AsRef;
#[derive(Debug)]
pub struct IoObject(ffi::io_object_t);
impl IoObject {
pub fn properties(&self) -> Result<CFDictionary<CFString, CFType>> {
unsafe {
let mut props: CFMutableDictionaryRef = mem::uninitialized();
let result = ffi::IORegistryEntryCreateCFProperties(
self.0,
&mut props,
kCFAllocatorDefault,
0
);
if result != kern_return::KERN_SUCCESS {
Err(Error::last_os_error())
} else {
Ok(CFMutableDictionary::wrap_under_create_rule(props).to_immutable())
}
}
}
pub fn parent(&self, plane: &[u8]) -> Result<IoObject> {
let mut parent: ffi::io_object_t = unsafe {
mem::uninitialized()
};
let result = unsafe {
ffi::IORegistryEntryGetParentEntry(
self.0,
plane.as_ref().as_ptr() as *const libc::c_char,
&mut parent as *mut _ as *mut ffi::io_registry_entry_t
)
};
if result != kern_return::KERN_SUCCESS {
Err(Error::last_os_error())
} else {
Ok(parent.into())
}
}
pub fn conforms_to(&self, class_name: &[u8]) -> bool {
let result = unsafe {
ffi::IOObjectConformsTo(
self.0,
class_name.as_ptr() as *const libc::c_char
)
};
result != 0
}
}
impl From<ffi::io_object_t> for IoObject {
fn from(obj: ffi::io_object_t) -> IoObject {
IoObject(obj)
}
}
impl Drop for IoObject {
fn drop(&mut self) {
let result = unsafe {
ffi::IOObjectRelease(self.0)
};
assert_eq!(result, kern_return::KERN_SUCCESS);
}
}