// This file was autogenerated by some hot garbage in the `uniffi` crate.
// Trust me, you don't want to mess with it!
// swiftlint:disable all
import Foundation
// Depending on the consumer's build setup, the low-level FFI code
// might be in a separate module, or it might be compiled inline into
// this module. This is a bit of light hackery to work with both.
#if canImport(ProofModeFFI)
import ProofModeFFI
#endif
fileprivate extension RustBuffer {
// Allocate a new buffer, copying the contents of a `UInt8` array.
init(bytes: [UInt8]) {
let rbuf = bytes.withUnsafeBufferPointer { ptr in
RustBuffer.from(ptr)
}
self.init(capacity: rbuf.capacity, len: rbuf.len, data: rbuf.data)
}
static func empty() -> RustBuffer {
RustBuffer(capacity: 0, len:0, data: nil)
}
static func from(_ ptr: UnsafeBufferPointer<UInt8>) -> RustBuffer {
try! rustCall { ffi_proofmode_rustbuffer_from_bytes(ForeignBytes(bufferPointer: ptr), $0) }
}
// Frees the buffer in place.
// The buffer must not be used after this is called.
func deallocate() {
try! rustCall { ffi_proofmode_rustbuffer_free(self, $0) }
}
}
fileprivate extension ForeignBytes {
init(bufferPointer: UnsafeBufferPointer<UInt8>) {
self.init(len: Int32(bufferPointer.count), data: bufferPointer.baseAddress)
}
}
// For every type used in the interface, we provide helper methods for conveniently
// lifting and lowering that type from C-compatible data, and for reading and writing
// values of that type in a buffer.
// Helper classes/extensions that don't change.
// Someday, this will be in a library of its own.
fileprivate extension Data {
init(rustBuffer: RustBuffer) {
self.init(
bytesNoCopy: rustBuffer.data!,
count: Int(rustBuffer.len),
deallocator: .none
)
}
}
// Define reader functionality. Normally this would be defined in a class or
// struct, but we use standalone functions instead in order to make external
// types work.
//
// With external types, one swift source file needs to be able to call the read
// method on another source file's FfiConverter, but then what visibility
// should Reader have?
// - If Reader is fileprivate, then this means the read() must also
// be fileprivate, which doesn't work with external types.
// - If Reader is internal/public, we'll get compile errors since both source
// files will try define the same type.
//
// Instead, the read() method and these helper functions input a tuple of data
fileprivate func createReader(data: Data) -> (data: Data, offset: Data.Index) {
(data: data, offset: 0)
}
// Reads an integer at the current offset, in big-endian order, and advances
// the offset on success. Throws if reading the integer would move the
// offset past the end of the buffer.
fileprivate func readInt<T: FixedWidthInteger>(_ reader: inout (data: Data, offset: Data.Index)) throws -> T {
let range = reader.offset..<reader.offset + MemoryLayout<T>.size
guard reader.data.count >= range.upperBound else {
throw UniffiInternalError.bufferOverflow
}
if T.self == UInt8.self {
let value = reader.data[reader.offset]
reader.offset += 1
return value as! T
}
var value: T = 0
let _ = withUnsafeMutableBytes(of: &value, { reader.data.copyBytes(to: $0, from: range)})
reader.offset = range.upperBound
return value.bigEndian
}
// Reads an arbitrary number of bytes, to be used to read
// raw bytes, this is useful when lifting strings
fileprivate func readBytes(_ reader: inout (data: Data, offset: Data.Index), count: Int) throws -> Array<UInt8> {
let range = reader.offset..<(reader.offset+count)
guard reader.data.count >= range.upperBound else {
throw UniffiInternalError.bufferOverflow
}
var value = [UInt8](repeating: 0, count: count)
value.withUnsafeMutableBufferPointer({ buffer in
reader.data.copyBytes(to: buffer, from: range)
})
reader.offset = range.upperBound
return value
}
// Reads a float at the current offset.
fileprivate func readFloat(_ reader: inout (data: Data, offset: Data.Index)) throws -> Float {
return Float(bitPattern: try readInt(&reader))
}
// Reads a float at the current offset.
fileprivate func readDouble(_ reader: inout (data: Data, offset: Data.Index)) throws -> Double {
return Double(bitPattern: try readInt(&reader))
}
// Indicates if the offset has reached the end of the buffer.
fileprivate func hasRemaining(_ reader: (data: Data, offset: Data.Index)) -> Bool {
return reader.offset < reader.data.count
}
// Define writer functionality. Normally this would be defined in a class or
// struct, but we use standalone functions instead in order to make external
// types work. See the above discussion on Readers for details.
fileprivate func createWriter() -> [UInt8] {
return []
}
fileprivate func writeBytes<S>(_ writer: inout [UInt8], _ byteArr: S) where S: Sequence, S.Element == UInt8 {
writer.append(contentsOf: byteArr)
}
// Writes an integer in big-endian order.
//
// Warning: make sure what you are trying to write
// is in the correct type!
fileprivate func writeInt<T: FixedWidthInteger>(_ writer: inout [UInt8], _ value: T) {
var value = value.bigEndian
withUnsafeBytes(of: &value) { writer.append(contentsOf: $0) }
}
fileprivate func writeFloat(_ writer: inout [UInt8], _ value: Float) {
writeInt(&writer, value.bitPattern)
}
fileprivate func writeDouble(_ writer: inout [UInt8], _ value: Double) {
writeInt(&writer, value.bitPattern)
}
// Protocol for types that transfer other types across the FFI. This is
// analogous to the Rust trait of the same name.
fileprivate protocol FfiConverter {
associatedtype FfiType
associatedtype SwiftType
static func lift(_ value: FfiType) throws -> SwiftType
static func lower(_ value: SwiftType) -> FfiType
static func read(from buf: inout (data: Data, offset: Data.Index)) throws -> SwiftType
static func write(_ value: SwiftType, into buf: inout [UInt8])
}
// Types conforming to `Primitive` pass themselves directly over the FFI.
fileprivate protocol FfiConverterPrimitive: FfiConverter where FfiType == SwiftType { }
extension FfiConverterPrimitive {
#if swift(>=5.8)
@_documentation(visibility: private)
#endif
public static func lift(_ value: FfiType) throws -> SwiftType {
return value
}
#if swift(>=5.8)
@_documentation(visibility: private)
#endif
public static func lower(_ value: SwiftType) -> FfiType {
return value
}
}
// Types conforming to `FfiConverterRustBuffer` lift and lower into a `RustBuffer`.
// Used for complex types where it's hard to write a custom lift/lower.
fileprivate protocol FfiConverterRustBuffer: FfiConverter where FfiType == RustBuffer {}
extension FfiConverterRustBuffer {
#if swift(>=5.8)
@_documentation(visibility: private)
#endif
public static func lift(_ buf: RustBuffer) throws -> SwiftType {
var reader = createReader(data: Data(rustBuffer: buf))
let value = try read(from: &reader)
if hasRemaining(reader) {
throw UniffiInternalError.incompleteData
}
buf.deallocate()
return value
}
#if swift(>=5.8)
@_documentation(visibility: private)
#endif
public static func lower(_ value: SwiftType) -> RustBuffer {
var writer = createWriter()
write(value, into: &writer)
return RustBuffer(bytes: writer)
}
}
// An error type for FFI errors. These errors occur at the UniFFI level, not
// the library level.
fileprivate enum UniffiInternalError: LocalizedError {
case bufferOverflow
case incompleteData
case unexpectedOptionalTag
case unexpectedEnumCase
case unexpectedNullPointer
case unexpectedRustCallStatusCode
case unexpectedRustCallError
case unexpectedStaleHandle
case rustPanic(_ message: String)
public var errorDescription: String? {
switch self {
case .bufferOverflow: return "Reading the requested value would read past the end of the buffer"
case .incompleteData: return "The buffer still has data after lifting its containing value"
case .unexpectedOptionalTag: return "Unexpected optional tag; should be 0 or 1"
case .unexpectedEnumCase: return "Raw enum value doesn't match any cases"
case .unexpectedNullPointer: return "Raw pointer value was null"
case .unexpectedRustCallStatusCode: return "Unexpected RustCallStatus code"
case .unexpectedRustCallError: return "CALL_ERROR but no errorClass specified"
case .unexpectedStaleHandle: return "The object in the handle map has been dropped already"
case let .rustPanic(message): return message
}
}
}
fileprivate extension NSLock {
func withLock<T>(f: () throws -> T) rethrows -> T {
self.lock()
defer { self.unlock() }
return try f()
}
}
fileprivate let CALL_SUCCESS: Int8 = 0
fileprivate let CALL_ERROR: Int8 = 1
fileprivate let CALL_UNEXPECTED_ERROR: Int8 = 2
fileprivate let CALL_CANCELLED: Int8 = 3
fileprivate extension RustCallStatus {
init() {
self.init(
code: CALL_SUCCESS,
errorBuf: RustBuffer.init(
capacity: 0,
len: 0,
data: nil
)
)
}
}
private func rustCall<T>(_ callback: (UnsafeMutablePointer<RustCallStatus>) -> T) throws -> T {
let neverThrow: ((RustBuffer) throws -> Never)? = nil
return try makeRustCall(callback, errorHandler: neverThrow)
}
private func rustCallWithError<T, E: Swift.Error>(
_ errorHandler: @escaping (RustBuffer) throws -> E,
_ callback: (UnsafeMutablePointer<RustCallStatus>) -> T) throws -> T {
try makeRustCall(callback, errorHandler: errorHandler)
}
private func makeRustCall<T, E: Swift.Error>(
_ callback: (UnsafeMutablePointer<RustCallStatus>) -> T,
errorHandler: ((RustBuffer) throws -> E)?
) throws -> T {
uniffiEnsureProofmodeInitialized()
var callStatus = RustCallStatus.init()
let returnedVal = callback(&callStatus)
try uniffiCheckCallStatus(callStatus: callStatus, errorHandler: errorHandler)
return returnedVal
}
private func uniffiCheckCallStatus<E: Swift.Error>(
callStatus: RustCallStatus,
errorHandler: ((RustBuffer) throws -> E)?
) throws {
switch callStatus.code {
case CALL_SUCCESS:
return
case CALL_ERROR:
if let errorHandler = errorHandler {
throw try errorHandler(callStatus.errorBuf)
} else {
callStatus.errorBuf.deallocate()
throw UniffiInternalError.unexpectedRustCallError
}
case CALL_UNEXPECTED_ERROR:
// When the rust code sees a panic, it tries to construct a RustBuffer
// with the message. But if that code panics, then it just sends back
// an empty buffer.
if callStatus.errorBuf.len > 0 {
throw UniffiInternalError.rustPanic(try FfiConverterString.lift(callStatus.errorBuf))
} else {
callStatus.errorBuf.deallocate()
throw UniffiInternalError.rustPanic("Rust panic")
}
case CALL_CANCELLED:
fatalError("Cancellation not supported yet")
default:
throw UniffiInternalError.unexpectedRustCallStatusCode
}
}
private func uniffiTraitInterfaceCall<T>(
callStatus: UnsafeMutablePointer<RustCallStatus>,
makeCall: () throws -> T,
writeReturn: (T) -> ()
) {
do {
try writeReturn(makeCall())
} catch let error {
callStatus.pointee.code = CALL_UNEXPECTED_ERROR
callStatus.pointee.errorBuf = FfiConverterString.lower(String(describing: error))
}
}
private func uniffiTraitInterfaceCallWithError<T, E>(
callStatus: UnsafeMutablePointer<RustCallStatus>,
makeCall: () throws -> T,
writeReturn: (T) -> (),
lowerError: (E) -> RustBuffer
) {
do {
try writeReturn(makeCall())
} catch let error as E {
callStatus.pointee.code = CALL_ERROR
callStatus.pointee.errorBuf = lowerError(error)
} catch {
callStatus.pointee.code = CALL_UNEXPECTED_ERROR
callStatus.pointee.errorBuf = FfiConverterString.lower(String(describing: error))
}
}
// Initial value and increment amount for handles.
// These ensure that SWIFT handles always have the lowest bit set
fileprivate let UNIFFI_HANDLEMAP_INITIAL: UInt64 = 1
fileprivate let UNIFFI_HANDLEMAP_DELTA: UInt64 = 2
fileprivate final class UniffiHandleMap<T>: @unchecked Sendable {
// All mutation happens with this lock held, which is why we implement @unchecked Sendable.
private let lock = NSLock()
private var map: [UInt64: T] = [:]
private var currentHandle: UInt64 = UNIFFI_HANDLEMAP_INITIAL
func insert(obj: T) -> UInt64 {
lock.withLock {
return doInsert(obj)
}
}
// Low-level insert function, this assumes `lock` is held.
private func doInsert(_ obj: T) -> UInt64 {
let handle = currentHandle
currentHandle += UNIFFI_HANDLEMAP_DELTA
map[handle] = obj
return handle
}
func get(handle: UInt64) throws -> T {
try lock.withLock {
guard let obj = map[handle] else {
throw UniffiInternalError.unexpectedStaleHandle
}
return obj
}
}
func clone(handle: UInt64) throws -> UInt64 {
try lock.withLock {
guard let obj = map[handle] else {
throw UniffiInternalError.unexpectedStaleHandle
}
return doInsert(obj)
}
}
@discardableResult
func remove(handle: UInt64) throws -> T {
try lock.withLock {
guard let obj = map.removeValue(forKey: handle) else {
throw UniffiInternalError.unexpectedStaleHandle
}
return obj
}
}
var count: Int {
get {
map.count
}
}
}
// Public interface members begin here.
// Magic number for the Rust proxy to call using the same mechanism as every other method,
// to free the callback once it's dropped by Rust.
private let IDX_CALLBACK_FREE: Int32 = 0
// Callback return codes
private let UNIFFI_CALLBACK_SUCCESS: Int32 = 0
private let UNIFFI_CALLBACK_ERROR: Int32 = 1
private let UNIFFI_CALLBACK_UNEXPECTED_ERROR: Int32 = 2
#if swift(>=5.8)
@_documentation(visibility: private)
#endif
fileprivate struct FfiConverterDouble: FfiConverterPrimitive {
typealias FfiType = Double
typealias SwiftType = Double
public static func read(from buf: inout (data: Data, offset: Data.Index)) throws -> Double {
return try lift(readDouble(&buf))
}
public static func write(_ value: Double, into buf: inout [UInt8]) {
writeDouble(&buf, lower(value))
}
}
#if swift(>=5.8)
@_documentation(visibility: private)
#endif
fileprivate struct FfiConverterBool : FfiConverter {
typealias FfiType = Int8
typealias SwiftType = Bool
public static func lift(_ value: Int8) throws -> Bool {
return value != 0
}
public static func lower(_ value: Bool) -> Int8 {
return value ? 1 : 0
}
public static func read(from buf: inout (data: Data, offset: Data.Index)) throws -> Bool {
return try lift(readInt(&buf))
}
public static func write(_ value: Bool, into buf: inout [UInt8]) {
writeInt(&buf, lower(value))
}
}
#if swift(>=5.8)
@_documentation(visibility: private)
#endif
fileprivate struct FfiConverterString: FfiConverter {
typealias SwiftType = String
typealias FfiType = RustBuffer
public static func lift(_ value: RustBuffer) throws -> String {
defer {
value.deallocate()
}
if value.data == nil {
return String()
}
let bytes = UnsafeBufferPointer<UInt8>(start: value.data!, count: Int(value.len))
return String(bytes: bytes, encoding: String.Encoding.utf8)!
}
public static func lower(_ value: String) -> RustBuffer {
return value.utf8CString.withUnsafeBufferPointer { ptr in
// The swift string gives us int8_t, we want uint8_t.
ptr.withMemoryRebound(to: UInt8.self) { ptr in
// The swift string gives us a trailing null byte, we don't want it.
let buf = UnsafeBufferPointer(rebasing: ptr.prefix(upTo: ptr.count - 1))
return RustBuffer.from(buf)
}
}
}
public static func read(from buf: inout (data: Data, offset: Data.Index)) throws -> String {
let len: Int32 = try readInt(&buf)
return String(bytes: try readBytes(&buf, count: Int(len)), encoding: String.Encoding.utf8)!
}
public static func write(_ value: String, into buf: inout [UInt8]) {
let len = Int32(value.utf8.count)
writeInt(&buf, len)
writeBytes(&buf, value.utf8)
}
}
#if swift(>=5.8)
@_documentation(visibility: private)
#endif
fileprivate struct FfiConverterData: FfiConverterRustBuffer {
typealias SwiftType = Data
public static func read(from buf: inout (data: Data, offset: Data.Index)) throws -> Data {
let len: Int32 = try readInt(&buf)
return Data(try readBytes(&buf, count: Int(len)))
}
public static func write(_ value: Data, into buf: inout [UInt8]) {
let len = Int32(value.count)
writeInt(&buf, len)
writeBytes(&buf, value)
}
}
public protocol ProofModeCallbacks: AnyObject, Sendable {
func getLocation() -> LocationData?
func getDeviceInfo() -> DeviceData?
func getNetworkInfo() -> NetworkData?
func saveData(hash: String, filename: String, data: Data) -> Bool
func saveText(hash: String, filename: String, text: String) -> Bool
func signData(data: Data) -> Data?
func reportProgress(message: String)
}
open class ProofModeCallbacksImpl: ProofModeCallbacks, @unchecked Sendable {
fileprivate let handle: UInt64
/// Used to instantiate a [FFIObject] without an actual handle, for fakes in tests, mostly.
#if swift(>=5.8)
@_documentation(visibility: private)
#endif
public struct NoHandle {
public init() {}
}
// TODO: We'd like this to be `private` but for Swifty reasons,
// we can't implement `FfiConverter` without making this `required` and we can't
// make it `required` without making it `public`.
#if swift(>=5.8)
@_documentation(visibility: private)
#endif
required public init(unsafeFromHandle handle: UInt64) {
self.handle = handle
}
// This constructor can be used to instantiate a fake object.
// - Parameter noHandle: Placeholder value so we can have a constructor separate from the default empty one that may be implemented for classes extending [FFIObject].
//
// - Warning:
// Any object instantiated with this constructor cannot be passed to an actual Rust-backed object. Since there isn't a backing handle the FFI lower functions will crash.
#if swift(>=5.8)
@_documentation(visibility: private)
#endif
public init(noHandle: NoHandle) {
self.handle = 0
}
#if swift(>=5.8)
@_documentation(visibility: private)
#endif
public func uniffiCloneHandle() -> UInt64 {
return try! rustCall { uniffi_proofmode_fn_clone_proofmodecallbacks(self.handle, $0) }
}
// No primary constructor declared for this class.
deinit {
if handle == 0 {
// Mock objects have handle=0 don't try to free them
return
}
try! rustCall { uniffi_proofmode_fn_free_proofmodecallbacks(handle, $0) }
}
open func getLocation() -> LocationData? {
return try! FfiConverterOptionTypeLocationData.lift(try! rustCall() {
uniffi_proofmode_fn_method_proofmodecallbacks_get_location(
self.uniffiCloneHandle(),$0
)
})
}
open func getDeviceInfo() -> DeviceData? {
return try! FfiConverterOptionTypeDeviceData.lift(try! rustCall() {
uniffi_proofmode_fn_method_proofmodecallbacks_get_device_info(
self.uniffiCloneHandle(),$0
)
})
}
open func getNetworkInfo() -> NetworkData? {
return try! FfiConverterOptionTypeNetworkData.lift(try! rustCall() {
uniffi_proofmode_fn_method_proofmodecallbacks_get_network_info(
self.uniffiCloneHandle(),$0
)
})
}
open func saveData(hash: String, filename: String, data: Data) -> Bool {
return try! FfiConverterBool.lift(try! rustCall() {
uniffi_proofmode_fn_method_proofmodecallbacks_save_data(
self.uniffiCloneHandle(),
FfiConverterString.lower(hash),
FfiConverterString.lower(filename),
FfiConverterData.lower(data),$0
)
})
}
open func saveText(hash: String, filename: String, text: String) -> Bool {
return try! FfiConverterBool.lift(try! rustCall() {
uniffi_proofmode_fn_method_proofmodecallbacks_save_text(
self.uniffiCloneHandle(),
FfiConverterString.lower(hash),
FfiConverterString.lower(filename),
FfiConverterString.lower(text),$0
)
})
}
open func signData(data: Data) -> Data? {
return try! FfiConverterOptionData.lift(try! rustCall() {
uniffi_proofmode_fn_method_proofmodecallbacks_sign_data(
self.uniffiCloneHandle(),
FfiConverterData.lower(data),$0
)
})
}
open func reportProgress(message: String) {try! rustCall() {
uniffi_proofmode_fn_method_proofmodecallbacks_report_progress(
self.uniffiCloneHandle(),
FfiConverterString.lower(message),$0
)
}
}
}
// Put the implementation in a struct so we don't pollute the top-level namespace
fileprivate struct UniffiCallbackInterfaceProofModeCallbacks {
// Create the VTable using a series of closures.
// Swift automatically converts these into C callback functions.
//
// This creates 1-element array, since this seems to be the only way to construct a const
// pointer that we can pass to the Rust code.
static let vtable: [UniffiVTableCallbackInterfaceProofModeCallbacks] = [UniffiVTableCallbackInterfaceProofModeCallbacks(
uniffiFree: { (uniffiHandle: UInt64) -> () in
do {
try FfiConverterTypeProofModeCallbacks.handleMap.remove(handle: uniffiHandle)
} catch {
print("Uniffi callback interface ProofModeCallbacks: handle missing in uniffiFree")
}
},
uniffiClone: { (uniffiHandle: UInt64) -> UInt64 in
do {
return try FfiConverterTypeProofModeCallbacks.handleMap.clone(handle: uniffiHandle)
} catch {
fatalError("Uniffi callback interface ProofModeCallbacks: handle missing in uniffiClone")
}
},
getLocation: { (
uniffiHandle: UInt64,
uniffiOutReturn: UnsafeMutablePointer<RustBuffer>,
uniffiCallStatus: UnsafeMutablePointer<RustCallStatus>
) in
let makeCall = {
() throws -> LocationData? in
guard let uniffiObj = try? FfiConverterTypeProofModeCallbacks.handleMap.get(handle: uniffiHandle) else {
throw UniffiInternalError.unexpectedStaleHandle
}
return uniffiObj.getLocation(
)
}
let writeReturn = { uniffiOutReturn.pointee = FfiConverterOptionTypeLocationData.lower($0) }
uniffiTraitInterfaceCall(
callStatus: uniffiCallStatus,
makeCall: makeCall,
writeReturn: writeReturn
)
},
getDeviceInfo: { (
uniffiHandle: UInt64,
uniffiOutReturn: UnsafeMutablePointer<RustBuffer>,
uniffiCallStatus: UnsafeMutablePointer<RustCallStatus>
) in
let makeCall = {
() throws -> DeviceData? in
guard let uniffiObj = try? FfiConverterTypeProofModeCallbacks.handleMap.get(handle: uniffiHandle) else {
throw UniffiInternalError.unexpectedStaleHandle
}
return uniffiObj.getDeviceInfo(
)
}
let writeReturn = { uniffiOutReturn.pointee = FfiConverterOptionTypeDeviceData.lower($0) }
uniffiTraitInterfaceCall(
callStatus: uniffiCallStatus,
makeCall: makeCall,
writeReturn: writeReturn
)
},
getNetworkInfo: { (
uniffiHandle: UInt64,
uniffiOutReturn: UnsafeMutablePointer<RustBuffer>,
uniffiCallStatus: UnsafeMutablePointer<RustCallStatus>
) in
let makeCall = {
() throws -> NetworkData? in
guard let uniffiObj = try? FfiConverterTypeProofModeCallbacks.handleMap.get(handle: uniffiHandle) else {
throw UniffiInternalError.unexpectedStaleHandle
}
return uniffiObj.getNetworkInfo(
)
}
let writeReturn = { uniffiOutReturn.pointee = FfiConverterOptionTypeNetworkData.lower($0) }
uniffiTraitInterfaceCall(
callStatus: uniffiCallStatus,
makeCall: makeCall,
writeReturn: writeReturn
)
},
saveData: { (
uniffiHandle: UInt64,
hash: RustBuffer,
filename: RustBuffer,
data: RustBuffer,
uniffiOutReturn: UnsafeMutablePointer<Int8>,
uniffiCallStatus: UnsafeMutablePointer<RustCallStatus>
) in
let makeCall = {
() throws -> Bool in
guard let uniffiObj = try? FfiConverterTypeProofModeCallbacks.handleMap.get(handle: uniffiHandle) else {
throw UniffiInternalError.unexpectedStaleHandle
}
return uniffiObj.saveData(
hash: try FfiConverterString.lift(hash),
filename: try FfiConverterString.lift(filename),
data: try FfiConverterData.lift(data)
)
}
let writeReturn = { uniffiOutReturn.pointee = FfiConverterBool.lower($0) }
uniffiTraitInterfaceCall(
callStatus: uniffiCallStatus,
makeCall: makeCall,
writeReturn: writeReturn
)
},
saveText: { (
uniffiHandle: UInt64,
hash: RustBuffer,
filename: RustBuffer,
text: RustBuffer,
uniffiOutReturn: UnsafeMutablePointer<Int8>,
uniffiCallStatus: UnsafeMutablePointer<RustCallStatus>
) in
let makeCall = {
() throws -> Bool in
guard let uniffiObj = try? FfiConverterTypeProofModeCallbacks.handleMap.get(handle: uniffiHandle) else {
throw UniffiInternalError.unexpectedStaleHandle
}
return uniffiObj.saveText(
hash: try FfiConverterString.lift(hash),
filename: try FfiConverterString.lift(filename),
text: try FfiConverterString.lift(text)
)
}
let writeReturn = { uniffiOutReturn.pointee = FfiConverterBool.lower($0) }
uniffiTraitInterfaceCall(
callStatus: uniffiCallStatus,
makeCall: makeCall,
writeReturn: writeReturn
)
},
signData: { (
uniffiHandle: UInt64,
data: RustBuffer,
uniffiOutReturn: UnsafeMutablePointer<RustBuffer>,
uniffiCallStatus: UnsafeMutablePointer<RustCallStatus>
) in
let makeCall = {
() throws -> Data? in
guard let uniffiObj = try? FfiConverterTypeProofModeCallbacks.handleMap.get(handle: uniffiHandle) else {
throw UniffiInternalError.unexpectedStaleHandle
}
return uniffiObj.signData(
data: try FfiConverterData.lift(data)
)
}
let writeReturn = { uniffiOutReturn.pointee = FfiConverterOptionData.lower($0) }
uniffiTraitInterfaceCall(
callStatus: uniffiCallStatus,
makeCall: makeCall,
writeReturn: writeReturn
)
},
reportProgress: { (
uniffiHandle: UInt64,
message: RustBuffer,
uniffiOutReturn: UnsafeMutableRawPointer,
uniffiCallStatus: UnsafeMutablePointer<RustCallStatus>
) in
let makeCall = {
() throws -> () in
guard let uniffiObj = try? FfiConverterTypeProofModeCallbacks.handleMap.get(handle: uniffiHandle) else {
throw UniffiInternalError.unexpectedStaleHandle
}
return uniffiObj.reportProgress(
message: try FfiConverterString.lift(message)
)
}
let writeReturn = { () }
uniffiTraitInterfaceCall(
callStatus: uniffiCallStatus,
makeCall: makeCall,
writeReturn: writeReturn
)
}
)]
}
private func uniffiCallbackInitProofModeCallbacks() {
uniffi_proofmode_fn_init_callback_vtable_proofmodecallbacks(UniffiCallbackInterfaceProofModeCallbacks.vtable)
}
#if swift(>=5.8)
@_documentation(visibility: private)
#endif
public struct FfiConverterTypeProofModeCallbacks: FfiConverter {
fileprivate static let handleMap = UniffiHandleMap<ProofModeCallbacks>()
typealias FfiType = UInt64
typealias SwiftType = ProofModeCallbacks
public static func lift(_ handle: UInt64) throws -> ProofModeCallbacks {
if ((handle & 1) == 0) {
// Rust-generated handle, construct a new class that uses the handle to implement the
// interface
return ProofModeCallbacksImpl(unsafeFromHandle: handle)
} else {
// Swift-generated handle, get the object from the handle map
return try handleMap.remove(handle: handle)
}
}
public static func lower(_ value: ProofModeCallbacks) -> UInt64 {
if let rustImpl = value as? ProofModeCallbacksImpl {
// Rust-implemented object. Clone the handle and return it
return rustImpl.uniffiCloneHandle()
} else {
// Swift object, generate a new vtable handle and return that.
return handleMap.insert(obj: value)
}
}
public static func read(from buf: inout (data: Data, offset: Data.Index)) throws -> ProofModeCallbacks {
let handle: UInt64 = try readInt(&buf)
return try lift(handle)
}
public static func write(_ value: ProofModeCallbacks, into buf: inout [UInt8]) {
writeInt(&buf, lower(value))
}
}
#if swift(>=5.8)
@_documentation(visibility: private)
#endif
public func FfiConverterTypeProofModeCallbacks_lift(_ handle: UInt64) throws -> ProofModeCallbacks {
return try FfiConverterTypeProofModeCallbacks.lift(handle)
}
#if swift(>=5.8)
@_documentation(visibility: private)
#endif
public func FfiConverterTypeProofModeCallbacks_lower(_ value: ProofModeCallbacks) -> UInt64 {
return FfiConverterTypeProofModeCallbacks.lower(value)
}
public struct CellInfo: Equatable, Hashable {
public var carrier: String
public var cellId: String?
public var lac: String?
// Default memberwise initializers are never public by default, so we
// declare one manually.
public init(carrier: String, cellId: String?, lac: String?) {
self.carrier = carrier
self.cellId = cellId
self.lac = lac
}
}
#if compiler(>=6)
extension CellInfo: Sendable {}
#endif
#if swift(>=5.8)
@_documentation(visibility: private)
#endif
public struct FfiConverterTypeCellInfo: FfiConverterRustBuffer {
public static func read(from buf: inout (data: Data, offset: Data.Index)) throws -> CellInfo {
return
try CellInfo(
carrier: FfiConverterString.read(from: &buf),
cellId: FfiConverterOptionString.read(from: &buf),
lac: FfiConverterOptionString.read(from: &buf)
)
}
public static func write(_ value: CellInfo, into buf: inout [UInt8]) {
FfiConverterString.write(value.carrier, into: &buf)
FfiConverterOptionString.write(value.cellId, into: &buf)
FfiConverterOptionString.write(value.lac, into: &buf)
}
}
#if swift(>=5.8)
@_documentation(visibility: private)
#endif
public func FfiConverterTypeCellInfo_lift(_ buf: RustBuffer) throws -> CellInfo {
return try FfiConverterTypeCellInfo.lift(buf)
}
#if swift(>=5.8)
@_documentation(visibility: private)
#endif
public func FfiConverterTypeCellInfo_lower(_ value: CellInfo) -> RustBuffer {
return FfiConverterTypeCellInfo.lower(value)
}
public struct DeviceData: Equatable, Hashable {
public var manufacturer: String
public var model: String
public var osVersion: String
public var deviceId: String?
// Default memberwise initializers are never public by default, so we
// declare one manually.
public init(manufacturer: String, model: String, osVersion: String, deviceId: String?) {
self.manufacturer = manufacturer
self.model = model
self.osVersion = osVersion
self.deviceId = deviceId
}
}
#if compiler(>=6)
extension DeviceData: Sendable {}
#endif
#if swift(>=5.8)
@_documentation(visibility: private)
#endif
public struct FfiConverterTypeDeviceData: FfiConverterRustBuffer {
public static func read(from buf: inout (data: Data, offset: Data.Index)) throws -> DeviceData {
return
try DeviceData(
manufacturer: FfiConverterString.read(from: &buf),
model: FfiConverterString.read(from: &buf),
osVersion: FfiConverterString.read(from: &buf),
deviceId: FfiConverterOptionString.read(from: &buf)
)
}
public static func write(_ value: DeviceData, into buf: inout [UInt8]) {
FfiConverterString.write(value.manufacturer, into: &buf)
FfiConverterString.write(value.model, into: &buf)
FfiConverterString.write(value.osVersion, into: &buf)
FfiConverterOptionString.write(value.deviceId, into: &buf)
}
}
#if swift(>=5.8)
@_documentation(visibility: private)
#endif
public func FfiConverterTypeDeviceData_lift(_ buf: RustBuffer) throws -> DeviceData {
return try FfiConverterTypeDeviceData.lift(buf)
}
#if swift(>=5.8)
@_documentation(visibility: private)
#endif
public func FfiConverterTypeDeviceData_lower(_ value: DeviceData) -> RustBuffer {
return FfiConverterTypeDeviceData.lower(value)
}
public struct LocationData: Equatable, Hashable {
public var latitude: Double
public var longitude: Double
public var altitude: Double?
public var accuracy: Double?
public var provider: String?
// Default memberwise initializers are never public by default, so we
// declare one manually.
public init(latitude: Double, longitude: Double, altitude: Double?, accuracy: Double?, provider: String?) {
self.latitude = latitude
self.longitude = longitude
self.altitude = altitude
self.accuracy = accuracy
self.provider = provider
}
}
#if compiler(>=6)
extension LocationData: Sendable {}
#endif
#if swift(>=5.8)
@_documentation(visibility: private)
#endif
public struct FfiConverterTypeLocationData: FfiConverterRustBuffer {
public static func read(from buf: inout (data: Data, offset: Data.Index)) throws -> LocationData {
return
try LocationData(
latitude: FfiConverterDouble.read(from: &buf),
longitude: FfiConverterDouble.read(from: &buf),
altitude: FfiConverterOptionDouble.read(from: &buf),
accuracy: FfiConverterOptionDouble.read(from: &buf),
provider: FfiConverterOptionString.read(from: &buf)
)
}
public static func write(_ value: LocationData, into buf: inout [UInt8]) {
FfiConverterDouble.write(value.latitude, into: &buf)
FfiConverterDouble.write(value.longitude, into: &buf)
FfiConverterOptionDouble.write(value.altitude, into: &buf)
FfiConverterOptionDouble.write(value.accuracy, into: &buf)
FfiConverterOptionString.write(value.provider, into: &buf)
}
}
#if swift(>=5.8)
@_documentation(visibility: private)
#endif
public func FfiConverterTypeLocationData_lift(_ buf: RustBuffer) throws -> LocationData {
return try FfiConverterTypeLocationData.lift(buf)
}
#if swift(>=5.8)
@_documentation(visibility: private)
#endif
public func FfiConverterTypeLocationData_lower(_ value: LocationData) -> RustBuffer {
return FfiConverterTypeLocationData.lower(value)
}
public struct NetworkData: Equatable, Hashable {
public var networkType: String
public var wifiSsid: String?
public var cellInfo: CellInfo?
// Default memberwise initializers are never public by default, so we
// declare one manually.
public init(networkType: String, wifiSsid: String?, cellInfo: CellInfo?) {
self.networkType = networkType
self.wifiSsid = wifiSsid
self.cellInfo = cellInfo
}
}
#if compiler(>=6)
extension NetworkData: Sendable {}
#endif
#if swift(>=5.8)
@_documentation(visibility: private)
#endif
public struct FfiConverterTypeNetworkData: FfiConverterRustBuffer {
public static func read(from buf: inout (data: Data, offset: Data.Index)) throws -> NetworkData {
return
try NetworkData(
networkType: FfiConverterString.read(from: &buf),
wifiSsid: FfiConverterOptionString.read(from: &buf),
cellInfo: FfiConverterOptionTypeCellInfo.read(from: &buf)
)
}
public static func write(_ value: NetworkData, into buf: inout [UInt8]) {
FfiConverterString.write(value.networkType, into: &buf)
FfiConverterOptionString.write(value.wifiSsid, into: &buf)
FfiConverterOptionTypeCellInfo.write(value.cellInfo, into: &buf)
}
}
#if swift(>=5.8)
@_documentation(visibility: private)
#endif
public func FfiConverterTypeNetworkData_lift(_ buf: RustBuffer) throws -> NetworkData {
return try FfiConverterTypeNetworkData.lift(buf)
}
#if swift(>=5.8)
@_documentation(visibility: private)
#endif
public func FfiConverterTypeNetworkData_lower(_ value: NetworkData) -> RustBuffer {
return FfiConverterTypeNetworkData.lower(value)
}
public struct ProofModeConfig: Equatable, Hashable {
public var autoNotarize: Bool
public var trackLocation: Bool
public var trackDeviceId: Bool
public var trackNetwork: Bool
public var addCredentials: Bool
public var embedC2pa: Bool
// Default memberwise initializers are never public by default, so we
// declare one manually.
public init(autoNotarize: Bool, trackLocation: Bool, trackDeviceId: Bool, trackNetwork: Bool, addCredentials: Bool, embedC2pa: Bool) {
self.autoNotarize = autoNotarize
self.trackLocation = trackLocation
self.trackDeviceId = trackDeviceId
self.trackNetwork = trackNetwork
self.addCredentials = addCredentials
self.embedC2pa = embedC2pa
}
}
#if compiler(>=6)
extension ProofModeConfig: Sendable {}
#endif
#if swift(>=5.8)
@_documentation(visibility: private)
#endif
public struct FfiConverterTypeProofModeConfig: FfiConverterRustBuffer {
public static func read(from buf: inout (data: Data, offset: Data.Index)) throws -> ProofModeConfig {
return
try ProofModeConfig(
autoNotarize: FfiConverterBool.read(from: &buf),
trackLocation: FfiConverterBool.read(from: &buf),
trackDeviceId: FfiConverterBool.read(from: &buf),
trackNetwork: FfiConverterBool.read(from: &buf),
addCredentials: FfiConverterBool.read(from: &buf),
embedC2pa: FfiConverterBool.read(from: &buf)
)
}
public static func write(_ value: ProofModeConfig, into buf: inout [UInt8]) {
FfiConverterBool.write(value.autoNotarize, into: &buf)
FfiConverterBool.write(value.trackLocation, into: &buf)
FfiConverterBool.write(value.trackDeviceId, into: &buf)
FfiConverterBool.write(value.trackNetwork, into: &buf)
FfiConverterBool.write(value.addCredentials, into: &buf)
FfiConverterBool.write(value.embedC2pa, into: &buf)
}
}
#if swift(>=5.8)
@_documentation(visibility: private)
#endif
public func FfiConverterTypeProofModeConfig_lift(_ buf: RustBuffer) throws -> ProofModeConfig {
return try FfiConverterTypeProofModeConfig.lift(buf)
}
#if swift(>=5.8)
@_documentation(visibility: private)
#endif
public func FfiConverterTypeProofModeConfig_lower(_ value: ProofModeConfig) -> RustBuffer {
return FfiConverterTypeProofModeConfig.lower(value)
}
public enum ProofModeError: Swift.Error, Equatable, Hashable, Foundation.LocalizedError {
case Io(message: String
)
case Generation(message: String
)
case Check(message: String
)
public var errorDescription: String? {
String(reflecting: self)
}
}
#if compiler(>=6)
extension ProofModeError: Sendable {}
#endif
#if swift(>=5.8)
@_documentation(visibility: private)
#endif
public struct FfiConverterTypeProofModeError: FfiConverterRustBuffer {
typealias SwiftType = ProofModeError
public static func read(from buf: inout (data: Data, offset: Data.Index)) throws -> ProofModeError {
let variant: Int32 = try readInt(&buf)
switch variant {
case 1: return .Io(
message: try FfiConverterString.read(from: &buf)
)
case 2: return .Generation(
message: try FfiConverterString.read(from: &buf)
)
case 3: return .Check(
message: try FfiConverterString.read(from: &buf)
)
default: throw UniffiInternalError.unexpectedEnumCase
}
}
public static func write(_ value: ProofModeError, into buf: inout [UInt8]) {
switch value {
case let .Io(message):
writeInt(&buf, Int32(1))
FfiConverterString.write(message, into: &buf)
case let .Generation(message):
writeInt(&buf, Int32(2))
FfiConverterString.write(message, into: &buf)
case let .Check(message):
writeInt(&buf, Int32(3))
FfiConverterString.write(message, into: &buf)
}
}
}
#if swift(>=5.8)
@_documentation(visibility: private)
#endif
public func FfiConverterTypeProofModeError_lift(_ buf: RustBuffer) throws -> ProofModeError {
return try FfiConverterTypeProofModeError.lift(buf)
}
#if swift(>=5.8)
@_documentation(visibility: private)
#endif
public func FfiConverterTypeProofModeError_lower(_ value: ProofModeError) -> RustBuffer {
return FfiConverterTypeProofModeError.lower(value)
}
#if swift(>=5.8)
@_documentation(visibility: private)
#endif
fileprivate struct FfiConverterOptionDouble: FfiConverterRustBuffer {
typealias SwiftType = Double?
public static func write(_ value: SwiftType, into buf: inout [UInt8]) {
guard let value = value else {
writeInt(&buf, Int8(0))
return
}
writeInt(&buf, Int8(1))
FfiConverterDouble.write(value, into: &buf)
}
public static func read(from buf: inout (data: Data, offset: Data.Index)) throws -> SwiftType {
switch try readInt(&buf) as Int8 {
case 0: return nil
case 1: return try FfiConverterDouble.read(from: &buf)
default: throw UniffiInternalError.unexpectedOptionalTag
}
}
}
#if swift(>=5.8)
@_documentation(visibility: private)
#endif
fileprivate struct FfiConverterOptionString: FfiConverterRustBuffer {
typealias SwiftType = String?
public static func write(_ value: SwiftType, into buf: inout [UInt8]) {
guard let value = value else {
writeInt(&buf, Int8(0))
return
}
writeInt(&buf, Int8(1))
FfiConverterString.write(value, into: &buf)
}
public static func read(from buf: inout (data: Data, offset: Data.Index)) throws -> SwiftType {
switch try readInt(&buf) as Int8 {
case 0: return nil
case 1: return try FfiConverterString.read(from: &buf)
default: throw UniffiInternalError.unexpectedOptionalTag
}
}
}
#if swift(>=5.8)
@_documentation(visibility: private)
#endif
fileprivate struct FfiConverterOptionData: FfiConverterRustBuffer {
typealias SwiftType = Data?
public static func write(_ value: SwiftType, into buf: inout [UInt8]) {
guard let value = value else {
writeInt(&buf, Int8(0))
return
}
writeInt(&buf, Int8(1))
FfiConverterData.write(value, into: &buf)
}
public static func read(from buf: inout (data: Data, offset: Data.Index)) throws -> SwiftType {
switch try readInt(&buf) as Int8 {
case 0: return nil
case 1: return try FfiConverterData.read(from: &buf)
default: throw UniffiInternalError.unexpectedOptionalTag
}
}
}
#if swift(>=5.8)
@_documentation(visibility: private)
#endif
fileprivate struct FfiConverterOptionTypeCellInfo: FfiConverterRustBuffer {
typealias SwiftType = CellInfo?
public static func write(_ value: SwiftType, into buf: inout [UInt8]) {
guard let value = value else {
writeInt(&buf, Int8(0))
return
}
writeInt(&buf, Int8(1))
FfiConverterTypeCellInfo.write(value, into: &buf)
}
public static func read(from buf: inout (data: Data, offset: Data.Index)) throws -> SwiftType {
switch try readInt(&buf) as Int8 {
case 0: return nil
case 1: return try FfiConverterTypeCellInfo.read(from: &buf)
default: throw UniffiInternalError.unexpectedOptionalTag
}
}
}
#if swift(>=5.8)
@_documentation(visibility: private)
#endif
fileprivate struct FfiConverterOptionTypeDeviceData: FfiConverterRustBuffer {
typealias SwiftType = DeviceData?
public static func write(_ value: SwiftType, into buf: inout [UInt8]) {
guard let value = value else {
writeInt(&buf, Int8(0))
return
}
writeInt(&buf, Int8(1))
FfiConverterTypeDeviceData.write(value, into: &buf)
}
public static func read(from buf: inout (data: Data, offset: Data.Index)) throws -> SwiftType {
switch try readInt(&buf) as Int8 {
case 0: return nil
case 1: return try FfiConverterTypeDeviceData.read(from: &buf)
default: throw UniffiInternalError.unexpectedOptionalTag
}
}
}
#if swift(>=5.8)
@_documentation(visibility: private)
#endif
fileprivate struct FfiConverterOptionTypeLocationData: FfiConverterRustBuffer {
typealias SwiftType = LocationData?
public static func write(_ value: SwiftType, into buf: inout [UInt8]) {
guard let value = value else {
writeInt(&buf, Int8(0))
return
}
writeInt(&buf, Int8(1))
FfiConverterTypeLocationData.write(value, into: &buf)
}
public static func read(from buf: inout (data: Data, offset: Data.Index)) throws -> SwiftType {
switch try readInt(&buf) as Int8 {
case 0: return nil
case 1: return try FfiConverterTypeLocationData.read(from: &buf)
default: throw UniffiInternalError.unexpectedOptionalTag
}
}
}
#if swift(>=5.8)
@_documentation(visibility: private)
#endif
fileprivate struct FfiConverterOptionTypeNetworkData: FfiConverterRustBuffer {
typealias SwiftType = NetworkData?
public static func write(_ value: SwiftType, into buf: inout [UInt8]) {
guard let value = value else {
writeInt(&buf, Int8(0))
return
}
writeInt(&buf, Int8(1))
FfiConverterTypeNetworkData.write(value, into: &buf)
}
public static func read(from buf: inout (data: Data, offset: Data.Index)) throws -> SwiftType {
switch try readInt(&buf) as Int8 {
case 0: return nil
case 1: return try FfiConverterTypeNetworkData.read(from: &buf)
default: throw UniffiInternalError.unexpectedOptionalTag
}
}
}
#if swift(>=5.8)
@_documentation(visibility: private)
#endif
fileprivate struct FfiConverterSequenceString: FfiConverterRustBuffer {
typealias SwiftType = [String]
public static func write(_ value: [String], into buf: inout [UInt8]) {
let len = Int32(value.count)
writeInt(&buf, len)
for item in value {
FfiConverterString.write(item, into: &buf)
}
}
public static func read(from buf: inout (data: Data, offset: Data.Index)) throws -> [String] {
let len: Int32 = try readInt(&buf)
var seq = [String]()
seq.reserveCapacity(Int(len))
for _ in 0 ..< len {
seq.append(try FfiConverterString.read(from: &buf))
}
return seq
}
}
#if swift(>=5.8)
@_documentation(visibility: private)
#endif
fileprivate struct FfiConverterDictionaryStringString: FfiConverterRustBuffer {
public static func write(_ value: [String: String], into buf: inout [UInt8]) {
let len = Int32(value.count)
writeInt(&buf, len)
for (key, value) in value {
FfiConverterString.write(key, into: &buf)
FfiConverterString.write(value, into: &buf)
}
}
public static func read(from buf: inout (data: Data, offset: Data.Index)) throws -> [String: String] {
let len: Int32 = try readInt(&buf)
var dict = [String: String]()
dict.reserveCapacity(Int(len))
for _ in 0..<len {
let key = try FfiConverterString.read(from: &buf)
let value = try FfiConverterString.read(from: &buf)
dict[key] = value
}
return dict
}
}
public func checkFiles(filePaths: [String], callbacks: ProofModeCallbacks)throws -> String {
return try FfiConverterString.lift(try rustCallWithError(FfiConverterTypeProofModeError_lift) {
uniffi_proofmode_fn_func_check_files(
FfiConverterSequenceString.lower(filePaths),
FfiConverterTypeProofModeCallbacks_lower(callbacks),$0
)
})
}
public func generateProof(mediaData: Data, metadata: [String: String], config: ProofModeConfig, callbacks: ProofModeCallbacks)throws -> String {
return try FfiConverterString.lift(try rustCallWithError(FfiConverterTypeProofModeError_lift) {
uniffi_proofmode_fn_func_generate_proof(
FfiConverterData.lower(mediaData),
FfiConverterDictionaryStringString.lower(metadata),
FfiConverterTypeProofModeConfig_lower(config),
FfiConverterTypeProofModeCallbacks_lower(callbacks),$0
)
})
}
public func getFileHash(mediaData: Data) -> String {
return try! FfiConverterString.lift(try! rustCall() {
uniffi_proofmode_fn_func_get_file_hash(
FfiConverterData.lower(mediaData),$0
)
})
}
public func getVersion() -> String {
return try! FfiConverterString.lift(try! rustCall() {
uniffi_proofmode_fn_func_get_version($0
)
})
}
private enum InitializationResult {
case ok
case contractVersionMismatch
case apiChecksumMismatch
}
// Use a global variable to perform the versioning checks. Swift ensures that
// the code inside is only computed once.
private let initializationResult: InitializationResult = {
// Get the bindings contract version from our ComponentInterface
let bindings_contract_version = 30
// Get the scaffolding contract version by calling the into the dylib
let scaffolding_contract_version = ffi_proofmode_uniffi_contract_version()
if bindings_contract_version != scaffolding_contract_version {
return InitializationResult.contractVersionMismatch
}
if (uniffi_proofmode_checksum_func_check_files() != 58334) {
return InitializationResult.apiChecksumMismatch
}
if (uniffi_proofmode_checksum_func_generate_proof() != 39920) {
return InitializationResult.apiChecksumMismatch
}
if (uniffi_proofmode_checksum_func_get_file_hash() != 15454) {
return InitializationResult.apiChecksumMismatch
}
if (uniffi_proofmode_checksum_func_get_version() != 32374) {
return InitializationResult.apiChecksumMismatch
}
if (uniffi_proofmode_checksum_method_proofmodecallbacks_get_location() != 12001) {
return InitializationResult.apiChecksumMismatch
}
if (uniffi_proofmode_checksum_method_proofmodecallbacks_get_device_info() != 20653) {
return InitializationResult.apiChecksumMismatch
}
if (uniffi_proofmode_checksum_method_proofmodecallbacks_get_network_info() != 60237) {
return InitializationResult.apiChecksumMismatch
}
if (uniffi_proofmode_checksum_method_proofmodecallbacks_save_data() != 3939) {
return InitializationResult.apiChecksumMismatch
}
if (uniffi_proofmode_checksum_method_proofmodecallbacks_save_text() != 14388) {
return InitializationResult.apiChecksumMismatch
}
if (uniffi_proofmode_checksum_method_proofmodecallbacks_sign_data() != 9305) {
return InitializationResult.apiChecksumMismatch
}
if (uniffi_proofmode_checksum_method_proofmodecallbacks_report_progress() != 31753) {
return InitializationResult.apiChecksumMismatch
}
uniffiCallbackInitProofModeCallbacks()
return InitializationResult.ok
}()
// Make the ensure init function public so that other modules which have external type references to
// our types can call it.
public func uniffiEnsureProofmodeInitialized() {
switch initializationResult {
case .ok:
break
case .contractVersionMismatch:
fatalError("UniFFI contract version mismatch: try cleaning and rebuilding your project")
case .apiChecksumMismatch:
fatalError("UniFFI API checksum mismatch: try cleaning and rebuilding your project")
}
}
// swiftlint:enable all