///
/// LLMLoadOptions.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 `LLMLoadOptions`, backed by a C++ struct.
 */
public typealias LLMLoadOptions = margelo.nitro.mlxreactnative.LLMLoadOptions

public extension LLMLoadOptions {
  private typealias bridge = margelo.nitro.mlxreactnative.bridge.swift

  /**
   * Create a new instance of `LLMLoadOptions`.
   */
  init(onProgress: ((_ progress: Double) -> Void)?, additionalContext: [LLMMessage]?, manageHistory: Bool?, tools: [ToolDefinition]?, generationConfig: LLMGenerationConfig?, tokenBatchSize: Double?, contextConfig: LLMContextConfig?) {
    self.init({ () -> bridge.std__optional_std__function_void_double____progress______ in
      if let __unwrappedValue = onProgress {
        return bridge.create_std__optional_std__function_void_double____progress______({ () -> bridge.Func_void_double in
          let __closureWrapper = Func_void_double(__unwrappedValue)
          return bridge.create_Func_void_double(__closureWrapper.toUnsafe())
        }())
      } else {
        return .init()
      }
    }(), { () -> bridge.std__optional_std__vector_LLMMessage__ in
      if let __unwrappedValue = additionalContext {
        return bridge.create_std__optional_std__vector_LLMMessage__({ () -> bridge.std__vector_LLMMessage_ in
          var __vector = bridge.create_std__vector_LLMMessage_(__unwrappedValue.count)
          for __item in __unwrappedValue {
            __vector.push_back(__item)
          }
          return __vector
        }())
      } else {
        return .init()
      }
    }(), { () -> bridge.std__optional_bool_ in
      if let __unwrappedValue = manageHistory {
        return bridge.create_std__optional_bool_(__unwrappedValue)
      } else {
        return .init()
      }
    }(), { () -> bridge.std__optional_std__vector_ToolDefinition__ in
      if let __unwrappedValue = tools {
        return bridge.create_std__optional_std__vector_ToolDefinition__({ () -> bridge.std__vector_ToolDefinition_ in
          var __vector = bridge.create_std__vector_ToolDefinition_(__unwrappedValue.count)
          for __item in __unwrappedValue {
            __vector.push_back(__item)
          }
          return __vector
        }())
      } else {
        return .init()
      }
    }(), { () -> bridge.std__optional_LLMGenerationConfig_ in
      if let __unwrappedValue = generationConfig {
        return bridge.create_std__optional_LLMGenerationConfig_(__unwrappedValue)
      } else {
        return .init()
      }
    }(), { () -> bridge.std__optional_double_ in
      if let __unwrappedValue = tokenBatchSize {
        return bridge.create_std__optional_double_(__unwrappedValue)
      } else {
        return .init()
      }
    }(), { () -> bridge.std__optional_LLMContextConfig_ in
      if let __unwrappedValue = contextConfig {
        return bridge.create_std__optional_LLMContextConfig_(__unwrappedValue)
      } else {
        return .init()
      }
    }())
  }

  @inline(__always)
  var onProgress: ((_ progress: Double) -> Void)? {
    return { () -> ((_ progress: Double) -> Void)? in
      if bridge.has_value_std__optional_std__function_void_double____progress______(self.__onProgress) {
        let __unwrapped = bridge.get_std__optional_std__function_void_double____progress______(self.__onProgress)
        return { () -> (Double) -> Void in
          let __wrappedFunction = bridge.wrap_Func_void_double(__unwrapped)
          return { (__progress: Double) -> Void in
            __wrappedFunction.call(__progress)
          }
        }()
      } else {
        return nil
      }
    }()
  }
  
  @inline(__always)
  var additionalContext: [LLMMessage]? {
    return { () -> [LLMMessage]? in
      if bridge.has_value_std__optional_std__vector_LLMMessage__(self.__additionalContext) {
        let __unwrapped = bridge.get_std__optional_std__vector_LLMMessage__(self.__additionalContext)
        return __unwrapped.map({ __item in __item })
      } else {
        return nil
      }
    }()
  }
  
  @inline(__always)
  var manageHistory: Bool? {
    return { () -> Bool? in
      if bridge.has_value_std__optional_bool_(self.__manageHistory) {
        let __unwrapped = bridge.get_std__optional_bool_(self.__manageHistory)
        return __unwrapped
      } else {
        return nil
      }
    }()
  }
  
  @inline(__always)
  var tools: [ToolDefinition]? {
    return { () -> [ToolDefinition]? in
      if bridge.has_value_std__optional_std__vector_ToolDefinition__(self.__tools) {
        let __unwrapped = bridge.get_std__optional_std__vector_ToolDefinition__(self.__tools)
        return __unwrapped.map({ __item in __item })
      } else {
        return nil
      }
    }()
  }
  
  @inline(__always)
  var generationConfig: LLMGenerationConfig? {
    return self.__generationConfig.value
  }
  
  @inline(__always)
  var tokenBatchSize: Double? {
    return { () -> Double? in
      if bridge.has_value_std__optional_double_(self.__tokenBatchSize) {
        let __unwrapped = bridge.get_std__optional_double_(self.__tokenBatchSize)
        return __unwrapped
      } else {
        return nil
      }
    }()
  }
  
  @inline(__always)
  var contextConfig: LLMContextConfig? {
    return self.__contextConfig.value
  }
}
