跳到主要内容
版本:1.0.0

Schema 元数据

本页介绍 Swift 中宏级别的 schema 元数据。

可用的宏属性

  • 结构体/类模型上的 @ForyStruct
  • C 风格枚举模型上的 @ForyEnum
  • 带关联值枚举模型上的 @ForyUnion@ForyCase
  • 数值字段上的 @ForyField(encoding: ...)
  • 用于集合字段元数据的 @ListField@ArrayField@SetField@MapField

@ForyField(encoding:)

使用 @ForyField 覆盖整数编码策略。

@ForyStruct
struct Metrics: Equatable {
@ForyField(encoding: .fixed)
var u32Fixed: UInt32 = 0

@ForyField(encoding: .tagged)
var u64Tagged: UInt64 = 0
}

支持的组合

Swift type支持的 encoding 值默认 encoding
Int32.varint, .fixed.varint
UInt32.varint, .fixed.varint
Int64.varint, .fixed, .tagged.varint
UInt64.varint, .fixed, .tagged.varint
Int.varint, .fixed, .tagged.varint
UInt.varint, .fixed, .tagged.varint

编译期校验会拒绝不支持的组合(例如 Int32 搭配 .tagged)。

嵌套集合字段元数据

当集合字段需要类型特定的编码格式元数据时,例如容器内部使用定长或带 tag 的整数编码,请使用 @ListField@ArrayField@SetField@MapField。密集的非空 bool、整数和浮点数组使用 @ArrayField

@ForyStruct
struct NestedMetrics: Equatable {
@ListField(element: .encoding(.fixed))
var values: [Int32?] = []

@ArrayField(element: .int32())
var denseValues: [Int32] = []

@SetField(element: .encoding(.fixed))
var ids: Set<UInt32?> = []

@MapField(key: .encoding(.fixed), value: .encoding(.tagged))
var byId: [Int32: UInt64] = [:]

@MapField(value: .list(element: .encoding(.fixed)))
var groups: [String: [Int32?]] = [:]
}

带有定长有符号或无符号整数元数据的非空 List 元素,会被分类并编码为匹配的 Fory primitive packed-array 类型。Set 字段仍分类为 Fory set,包括定长整数 set。

当 Swift 属性类型是别名,或因其他原因需要完整提示时,请使用 @ForyField(type:)

typealias MetricsMap = [String: [Int32?]]

@ForyStruct
struct AliasMetrics: Equatable {
@ForyField(type: .map(
key: .string,
value: .list(.int32(nullable: true, encoding: .fixed))
))
var metrics: MetricsMap = [:]
}

Union 载荷通过 @ForyCase(payload:) 使用同一套 DSL:

@ForyUnion
enum Event: Equatable {
@ForyCase(id: 1)
case created(String)

@ForyCase(id: 2, payload: .uint64(encoding: .fixed))
case deleted(UInt64)
}

模型宏要求

结构体和类字段

  • 存储属性必须声明显式类型
  • 计算属性会被忽略
  • 静态/类属性会被忽略

类要求

标注 @ForyStruct 的类必须提供 required init() 以进行默认构造。

@ForyStruct
final class Node {
var value: Int32 = 0
var next: Node? = nil

required init() {}
}

宏类型中的动态 Any 字段

Fory 模型宏支持动态字段和嵌套容器:

  • Any, AnyObject, any Serializer
  • AnyHashable
  • [Any]
  • [String: Any]
  • [Int32: Any]
  • [AnyHashable: Any]

当前限制:

  • 仅当 KStringInt32AnyHashable 时,才支持 Dictionary<K, Any>