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

import Foundation
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]?) {
    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()
      }
    }())
  }

  var onProgress: ((_ progress: Double) -> Void)? {
    @inline(__always)
    get {
      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)
    set {
      self.__onProgress = { () -> bridge.std__optional_std__function_void_double____progress______ in
        if let __unwrappedValue = newValue {
          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()
        }
      }()
    }
  }
  
  var additionalContext: [LLMMessage]? {
    @inline(__always)
    get {
      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)
    set {
      self.__additionalContext = { () -> bridge.std__optional_std__vector_LLMMessage__ in
        if let __unwrappedValue = newValue {
          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()
        }
      }()
    }
  }
  
  var manageHistory: Bool? {
    @inline(__always)
    get {
      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)
    set {
      self.__manageHistory = { () -> bridge.std__optional_bool_ in
        if let __unwrappedValue = newValue {
          return bridge.create_std__optional_bool_(__unwrappedValue)
        } else {
          return .init()
        }
      }()
    }
  }
  
  var tools: [ToolDefinition]? {
    @inline(__always)
    get {
      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)
    set {
      self.__tools = { () -> bridge.std__optional_std__vector_ToolDefinition__ in
        if let __unwrappedValue = newValue {
          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()
        }
      }()
    }
  }
}
