You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
The swift-syntax package is a set of libraries that work on a source-accurate tree representation of Swift source code, called the SwiftSyntax tree. The SwiftSyntax tree forms the backbone of Swift’s macro system – the macro expansion nodes are represented as SwiftSyntax nodes and a macro generates a SwiftSyntax tree to be inserted into the source file.
A set of example usages of swift-syntax can be found in Examples.
Releases
Releases of SwiftSyntax are aligned with corresponding language and tooling releases, for example the major version 509 of swift-syntax is aligned with Swift 5.9.
To depend on swift-syntax in a SwiftPM package, add the following to your Package.swift.
To add swift-syntax as a dependency of your Xcode project, go to the Package Dependencies tab of your Xcode project, click the plus button and search for https://github.com/swiftlang/swift-syntax.git.
Reporting Issues
If you should hit any issues while using SwiftSyntax, we appreciate bug reports on GitHub Issue.
Contributing
Start contributing to SwiftSyntax see this guide for more information.
Bazel
SwiftSyntax provides an experimental Bazel build configuration, maintained by Keith Smiley.
To use it, you can pull the source archive from the relevant release tag
into your MODULE.bazel file (preferred and recommended) with bazel_dep. Bzlmod support was added starting release of 509.0.0 and above. All available versions can be found in the Bazel Central Registry
bazel_dep(name="swift-syntax", version="600.0.1")
You can also pull source archive with WORKSPACE but note that it is preferred to use MODULE.bazel. To use WORKSPACE and swift-syntax, you can use http_archive as such
and depend on the libraries you need from the
BUILD.bazel file. Each library also has an associated
Library_opt target (such as SwiftSyntax_opt) which forces
SwiftSyntax to always build with optimizations enabled. This may help
local runtime performance at the cost of debuggability, and initial
build time. Please tag any issues related to the Bazel configuration with the label "Bazel".