blob: ac701d469696e39bc1a4414ce30b25dfda488624 [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 Schuh272c6132020-11-14 16:37:52 -080017import Foundation
18
James Kuszmaul8e62b022022-03-22 09:33:25 -070019/// Struct is a representation of a mutable `Flatbuffers` struct
20/// since native structs are value types and cant be mutated
21@frozen
Austin Schuh272c6132020-11-14 16:37:52 -080022public struct Struct {
James Kuszmaul8e62b022022-03-22 09:33:25 -070023
24 /// Hosting Bytebuffer
Austin Schuh58b9b472020-11-25 19:12:44 -080025 public private(set) var bb: ByteBuffer
James Kuszmaul8e62b022022-03-22 09:33:25 -070026 /// Current position of the struct
Austin Schuh58b9b472020-11-25 19:12:44 -080027 public private(set) var postion: Int32
28
James Kuszmaul8e62b022022-03-22 09:33:25 -070029 /// Initializer for a mutable flatbuffers struct
30 /// - Parameters:
31 /// - bb: Current hosting Bytebuffer
32 /// - position: Current position for the struct in the ByteBuffer
Austin Schuh58b9b472020-11-25 19:12:44 -080033 public init(bb: ByteBuffer, position: Int32 = 0) {
34 self.bb = bb
35 postion = position
36 }
37
James Kuszmaul8e62b022022-03-22 09:33:25 -070038 /// Reads data from the buffer directly at offset O
39 /// - Parameters:
40 /// - type: Type of data to be read
41 /// - o: Current offset of the data
42 /// - Returns: Data of Type T that conforms to type Scalar
Austin Schuh58b9b472020-11-25 19:12:44 -080043 public func readBuffer<T: Scalar>(of type: T.Type, at o: Int32) -> T {
44 let r = bb.read(def: T.self, position: Int(o + postion))
45 return r
46 }
Austin Schuh272c6132020-11-14 16:37:52 -080047}