Skip to main content

visionkit/
data_scanner_view_controller.rs

1use core::ffi::c_char;
2use core::ptr;
3
4use crate::error::VisionKitError;
5use crate::ffi;
6use crate::private::{error_from_status, parse_area_support_info_ptr};
7use crate::support::AreaSupportInfo;
8
9/// Wraps the VisionKit DataScannerViewController counterpart.
10pub struct DataScannerViewController;
11
12impl DataScannerViewController {
13    /// Returns VisionKit availability metadata for this area.
14    pub fn support_info() -> Result<AreaSupportInfo, VisionKitError> {
15        let mut support_json: *mut c_char = ptr::null_mut();
16        let mut err_msg: *mut c_char = ptr::null_mut();
17        let status = unsafe {
18            ffi::data_scanner_view_controller::vk_data_scanner_view_controller_support_json(
19                &mut support_json,
20                &mut err_msg,
21            )
22        };
23        if status == ffi::status::OK {
24            unsafe {
25                parse_area_support_info_ptr(support_json, "DataScannerViewController support info")
26            }
27        } else {
28            Err(unsafe { error_from_status(status, err_msg) })
29        }
30    }
31
32    /// Returns whether this VisionKit area is available on the current platform.
33    pub fn is_available_on_current_platform() -> Result<bool, VisionKitError> {
34        Ok(Self::support_info()?.available_on_current_platform)
35    }
36
37    /// Creates the VisionKit `DataScannerViewController` wrapper.
38    pub fn new() -> Result<Self, VisionKitError> {
39        let info = Self::support_info()?;
40        if info.available_on_current_platform {
41            Ok(Self)
42        } else {
43            Err(info.unavailable_error())
44        }
45    }
46}