blob: 9996f4493ce6bb2a0ca049e88588c9ce0fe0d795 [file] [log] [blame]
Austin Schuh58b9b472020-11-25 19:12:44 -08001/*
James Kuszmaul8e62b022022-03-22 09:33:25 -07002 * Copyright 2021 Google Inc. All rights reserved.
Austin Schuh58b9b472020-11-25 19:12:44 -08003 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
Austin Schuh2dd86a92022-09-14 21:19:23 -070017#if !os(WASI)
Austin Schuh272c6132020-11-14 16:37:52 -080018import Foundation
Austin Schuh2dd86a92022-09-14 21:19:23 -070019#else
20import SwiftOverlayShims
21#endif
Austin Schuh272c6132020-11-14 16:37:52 -080022
James Kuszmaul8e62b022022-03-22 09:33:25 -070023/// Struct is a representation of a mutable `Flatbuffers` struct
24/// since native structs are value types and cant be mutated
25@frozen
Austin Schuh272c6132020-11-14 16:37:52 -080026public struct Struct {
James Kuszmaul8e62b022022-03-22 09:33:25 -070027
28 /// Hosting Bytebuffer
Austin Schuh58b9b472020-11-25 19:12:44 -080029 public private(set) var bb: ByteBuffer
James Kuszmaul8e62b022022-03-22 09:33:25 -070030 /// Current position of the struct
Austin Schuh58b9b472020-11-25 19:12:44 -080031 public private(set) var postion: Int32
32
James Kuszmaul8e62b022022-03-22 09:33:25 -070033 /// Initializer for a mutable flatbuffers struct
34 /// - Parameters:
35 /// - bb: Current hosting Bytebuffer
36 /// - position: Current position for the struct in the ByteBuffer
Austin Schuh58b9b472020-11-25 19:12:44 -080037 public init(bb: ByteBuffer, position: Int32 = 0) {
38 self.bb = bb
39 postion = position
40 }
41
James Kuszmaul8e62b022022-03-22 09:33:25 -070042 /// Reads data from the buffer directly at offset O
43 /// - Parameters:
44 /// - type: Type of data to be read
45 /// - o: Current offset of the data
46 /// - Returns: Data of Type T that conforms to type Scalar
Austin Schuh58b9b472020-11-25 19:12:44 -080047 public func readBuffer<T: Scalar>(of type: T.Type, at o: Int32) -> T {
48 let r = bb.read(def: T.self, position: Int(o + postion))
49 return r
50 }
Austin Schuh272c6132020-11-14 16:37:52 -080051}