Swift-Macros 项目教程
2024-08-28 11:54:46作者:虞亚竹Luna
1. 项目的目录结构及介绍
Swift-Macros 项目的目录结构如下:
Swift-Macros/
├── README.md
├── Sources/
│ └── SwiftMacros/
│ ├── MacroKit.swift
│ ├── PublicInit.swift
│ ├── GenerateMock.swift
│ ├── KeyPathIterable.swift
│ ├── StaticMemberIterable.swift
│ └── MoreMacros.swift
├── Tests/
│ └── SwiftMacrosTests/
│ ├── XCTestManifests.swift
│ ├── MacroKitTests.swift
│ ├── PublicInitTests.swift
│ ├── GenerateMockTests.swift
│ ├── KeyPathIterableTests.swift
│ ├── StaticMemberIterableTests.swift
│ └── MoreMacrosTests.swift
├── Package.swift
└── .gitignore
目录结构介绍
- README.md: 项目说明文档。
- Sources/SwiftMacros/: 包含所有宏的实现文件。
- MacroKit.swift: 宏工具包的入口文件。
- PublicInit.swift: 生成公共成员初始化器的宏。
- GenerateMock.swift: 生成测试模拟对象的宏。
- KeyPathIterable.swift: 类似于 CaseIterable,但用于可用的键路径。
- StaticMemberIterable.swift: 类似于 CaseIterable,但用于可用的静态成员。
- MoreMacros.swift: 包含更多宏的实现。
- Tests/SwiftMacrosTests/: 包含所有宏的测试文件。
- XCTestManifests.swift: 测试清单文件。
- MacroKitTests.swift: 宏工具包的测试文件。
- PublicInitTests.swift: 公共成员初始化器的测试文件。
- GenerateMockTests.swift: 生成测试模拟对象的测试文件。
- KeyPathIterableTests.swift: 键路径可迭代宏的测试文件。
- StaticMemberIterableTests.swift: 静态成员可迭代宏的测试文件。
- MoreMacrosTests.swift: 更多宏的测试文件。
- Package.swift: Swift 包管理文件。
- .gitignore: Git 忽略文件配置。
2. 项目的启动文件介绍
项目的启动文件是 Sources/SwiftMacros/MacroKit.swift。这个文件是宏工具包的入口文件,包含了项目中所有宏的注册和初始化逻辑。
import SwiftSyntax
import SwiftSyntaxBuilder
import SwiftSyntaxMacros
public struct MacroKit: MacroProtocol {
public static func register() {
// 注册所有宏
PublicInitMacro.register()
GenerateMockMacro.register()
KeyPathIterableMacro.register()
StaticMemberIterableMacro.register()
// 其他宏的注册
}
}
3. 项目的配置文件介绍
项目的配置文件是 Package.swift。这个文件定义了 Swift 包的依赖关系、目标和产品。
// swift-tools-version:5.5
import PackageDescription
let package = Package(
name: "SwiftMacros",
products: [
.library(name: "SwiftMacros", targets: ["SwiftMacros"]),
],
dependencies: [
.package(url: "https://github.com/apple/swift-syntax.git", from: "0.50500.0"),
],
targets: [
.target(name: "SwiftMacros", dependencies: [
.product(name: "SwiftSyntax", package: "swift-syntax"),
.product(name: "SwiftSyntaxBuilder", package: "swift-syntax"),
.product(name: "SwiftSyntaxMacros", package: "swift-syntax"),
]),
.testTarget(name: "SwiftMacrosTests", dependencies: ["SwiftMacros"]),
]
)
配置文件介绍
- name: 包的名称。
- products: 定义了包提供的产品,这里是一个库
SwiftMacros。 - dependencies: 定义了包的依赖关系,这里依赖了
swift-syntax包。 - targets: 定义了包的目标,包括主目标
SwiftMacros和测试目标SwiftMacrosTests
登录后查看全文
热门项目推荐
相关项目推荐
Kimi-K2.5Kimi K2.5 是一款开源的原生多模态智能体模型,它在 Kimi-K2-Base 的基础上,通过对约 15 万亿混合视觉和文本 tokens 进行持续预训练构建而成。该模型将视觉与语言理解、高级智能体能力、即时模式与思考模式,以及对话式与智能体范式无缝融合。Python00- QQwen3-Coder-Next2026年2月4日,正式发布的Qwen3-Coder-Next,一款专为编码智能体和本地开发场景设计的开源语言模型。Python00
xw-cli实现国产算力大模型零门槛部署,一键跑通 Qwen、GLM-4.7、Minimax-2.1、DeepSeek-OCR 等模型Go06
PaddleOCR-VL-1.5PaddleOCR-VL-1.5 是 PaddleOCR-VL 的新一代进阶模型,在 OmniDocBench v1.5 上实现了 94.5% 的全新 state-of-the-art 准确率。 为了严格评估模型在真实物理畸变下的鲁棒性——包括扫描伪影、倾斜、扭曲、屏幕拍摄和光照变化——我们提出了 Real5-OmniDocBench 基准测试集。实验结果表明,该增强模型在新构建的基准测试集上达到了 SOTA 性能。此外,我们通过整合印章识别和文本检测识别(text spotting)任务扩展了模型的能力,同时保持 0.9B 的超紧凑 VLM 规模,具备高效率特性。Python00
KuiklyUI基于KMP技术的高性能、全平台开发框架,具备统一代码库、极致易用性和动态灵活性。 Provide a high-performance, full-platform development framework with unified codebase, ultimate ease of use, and dynamic flexibility. 注意:本仓库为Github仓库镜像,PR或Issue请移步至Github发起,感谢支持!Kotlin08
VLOOKVLOOK™ 是优雅好用的 Typora/Markdown 主题包和增强插件。 VLOOK™ is an elegant and practical THEME PACKAGE × ENHANCEMENT PLUGIN for Typora/Markdown.Less00
热门内容推荐
最新内容推荐
项目优选
收起
deepin linux kernel
C
27
11
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
532
3.75 K
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
12
1
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
67
20
暂无简介
Dart
772
191
Ascend Extension for PyTorch
Python
340
405
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
886
596
喝着茶写代码!最易用的自托管一站式代码托管平台,包含Git托管,代码审查,团队协作,软件包和CI/CD。
Go
23
0
React Native鸿蒙化仓库
JavaScript
303
355
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
336
178