///
/// AuthDataTypes.swift
/// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
/// https://github.com/mrousavy/nitro
/// Copyright © Marc Rousavy @ Margelo
///

import NitroModules

/**
 * Represents an instance of `AuthDataTypes`, backed by a C++ struct.
 */
public typealias AuthDataTypes = margelo.nitro.healthkit.AuthDataTypes

public extension AuthDataTypes {
  private typealias bridge = margelo.nitro.healthkit.bridge.swift

  /**
   * Create a new instance of `AuthDataTypes`.
   */
  init(toShare: [SampleTypeIdentifierWriteable]?, toRead: [ObjectTypeIdentifier]?) {
    self.init({ () -> bridge.std__optional_std__vector_SampleTypeIdentifierWriteable__ in
      if let __unwrappedValue = toShare {
        return bridge.create_std__optional_std__vector_SampleTypeIdentifierWriteable__({ () -> bridge.std__vector_SampleTypeIdentifierWriteable_ in
          var __vector = bridge.create_std__vector_SampleTypeIdentifierWriteable_(__unwrappedValue.count)
          for __item in __unwrappedValue {
            __vector.push_back(__item)
          }
          return __vector
        }())
      } else {
        return .init()
      }
    }(), { () -> bridge.std__optional_std__vector_ObjectTypeIdentifier__ in
      if let __unwrappedValue = toRead {
        return bridge.create_std__optional_std__vector_ObjectTypeIdentifier__({ () -> bridge.std__vector_ObjectTypeIdentifier_ in
          var __vector = bridge.create_std__vector_ObjectTypeIdentifier_(__unwrappedValue.count)
          for __item in __unwrappedValue {
            __vector.push_back(__item)
          }
          return __vector
        }())
      } else {
        return .init()
      }
    }())
  }

  @inline(__always)
  var toShare: [SampleTypeIdentifierWriteable]? {
    return { () -> [SampleTypeIdentifierWriteable]? in
      if bridge.has_value_std__optional_std__vector_SampleTypeIdentifierWriteable__(self.__toShare) {
        let __unwrapped = bridge.get_std__optional_std__vector_SampleTypeIdentifierWriteable__(self.__toShare)
        return __unwrapped.map({ __item in __item })
      } else {
        return nil
      }
    }()
  }
  
  @inline(__always)
  var toRead: [ObjectTypeIdentifier]? {
    return { () -> [ObjectTypeIdentifier]? in
      if bridge.has_value_std__optional_std__vector_ObjectTypeIdentifier__(self.__toRead) {
        let __unwrapped = bridge.get_std__optional_std__vector_ObjectTypeIdentifier__(self.__toRead)
        return __unwrapped.map({ __item in __item })
      } else {
        return nil
      }
    }()
  }
}
