Convert Figma logo to code with AI

swiftlang logoswift-syntax

A set of Swift libraries for parsing, inspecting, generating, and transforming Swift source code.

3,285
416
3,285
109

Top Related Projects

67,740

The Swift Programming Language

18,717

A tool to enforce Swift style and conventions.

This maintains proposals for changes and user-visible enhancements to the Swift Programming Language.

The Package Manager for the Swift Programming Language

Language Server Protocol implementation for Swift and C-based languages

Quick Overview

Swift Syntax is a set of Swift libraries for parsing, inspecting, generating, and transforming Swift source code. It provides a robust foundation for building Swift tooling, including code formatters, linters, and source code analysis tools. The project is an integral part of the Swift ecosystem and is maintained by the Swift project.

Pros

  • Provides a powerful and flexible API for working with Swift source code
  • Officially maintained by the Swift project, ensuring compatibility and regular updates
  • Supports both parsing and generating Swift code, enabling a wide range of use cases
  • Offers high performance and efficiency, suitable for large-scale code analysis

Cons

  • Steep learning curve due to the complexity of the API and Swift language intricacies
  • Documentation can be sparse in some areas, requiring users to explore the source code
  • Limited support for older Swift versions, as it focuses on the latest language features
  • May require frequent updates to keep up with Swift language evolution

Code Examples

  1. Parsing Swift source code:
import SwiftSyntax
import SwiftParser

let source = "func greet(_ name: String) { print(\"Hello, \\(name)!\") }"
let sourceFile = Parser.parse(source: source)
print(sourceFile.description)
  1. Traversing the syntax tree:
import SwiftSyntax

class FunctionVisitor: SyntaxVisitor {
    override func visit(_ node: FunctionDeclSyntax) -> SyntaxVisitorContinueKind {
        print("Found function: \(node.identifier)")
        return .visitChildren
    }
}

let visitor = FunctionVisitor()
visitor.walk(sourceFile)
  1. Modifying syntax:
import SwiftSyntax

let modified = sourceFile.withLeadingTrivia(.spaces(4))
print(modified.description)

Getting Started

To use Swift Syntax in your project, add it as a dependency in your Package.swift file:

dependencies: [
    .package(url: "https://github.com/apple/swift-syntax.git", from: "509.0.0")
],
targets: [
    .target(
        name: "YourTarget",
        dependencies: [
            .product(name: "SwiftSyntax", package: "swift-syntax"),
            .product(name: "SwiftParser", package: "swift-syntax"),
        ]
    )
]

Then, import the necessary modules in your Swift files:

import SwiftSyntax
import SwiftParser

You can now use the Swift Syntax API to parse, analyze, and transform Swift code in your project.

Competitor Comparisons

67,740

The Swift Programming Language

Pros of Swift

  • Comprehensive repository containing the entire Swift programming language
  • Includes compiler, standard library, and core components
  • Provides deeper access to Swift's internals and development process

Cons of Swift

  • Larger and more complex codebase, potentially harder to navigate
  • Requires more setup and resources to build and contribute
  • May be overwhelming for those only interested in syntax-related features

Code Comparison

Swift (compiler implementation):

func parseTopLevelDecl() -> Decl {
  switch tok.kind {
  case .kw_func:
    return parseFuncDecl()
  case .kw_var, .kw_let:
    return parseVarDecl()
  default:
    diagnose(.expectedDeclaration)
    return makeParserErrorDecl()
  }
}

Swift-syntax (syntax tree representation):

struct FunctionDeclSyntax: DeclSyntaxProtocol {
  var funcKeyword: TokenSyntax
  var identifier: TokenSyntax
  var genericParameterClause: GenericParameterClauseSyntax?
  var signature: FunctionSignatureSyntax
  var body: CodeBlockSyntax?
}

Swift-syntax focuses specifically on Swift's syntax representation and parsing, making it more suitable for tasks like source code analysis and transformation. Swift, on the other hand, provides a complete implementation of the language, including the compiler and runtime components, offering a broader scope but with increased complexity.

18,717

A tool to enforce Swift style and conventions.

Pros of SwiftLint

  • Easier to set up and use for basic linting tasks
  • Provides a comprehensive set of pre-defined rules
  • Integrates well with Xcode and CI/CD pipelines

Cons of SwiftLint

  • Less flexible for creating custom rules
  • May not cover all advanced Swift syntax features
  • Can be slower for large codebases due to its design

Code Comparison

SwiftLint configuration:

disabled_rules:
  - trailing_whitespace
opt_in_rules:
  - empty_count
  - missing_docs

swift-syntax usage:

import SwiftSyntax
import SwiftSyntaxParser

let sourceFile = try SyntaxParser.parse(source: "let x = 5")
let visitor = MyCustomVisitor()
visitor.walk(sourceFile)

Summary

SwiftLint is a popular linting tool for Swift, offering ease of use and a wide range of pre-defined rules. It's great for teams looking for quick setup and standard code style enforcement. On the other hand, swift-syntax provides a more powerful and flexible foundation for creating custom Swift tools, including linters. While it requires more setup and coding, swift-syntax offers greater control and the ability to work with advanced Swift syntax features. The choice between the two depends on the specific needs of the project and the team's expertise in Swift tooling.

This maintains proposals for changes and user-visible enhancements to the Swift Programming Language.

Pros of swift-evolution

  • Focuses on the Swift language evolution process, providing a centralized place for proposals and discussions
  • Offers a comprehensive view of Swift's development history and future direction
  • Encourages community involvement in shaping the language's future

Cons of swift-evolution

  • Less technical in nature, primarily containing textual proposals rather than code
  • May be overwhelming for developers looking for specific syntax information
  • Updates less frequently than swift-syntax, as language evolution occurs at a slower pace

Code comparison

swift-evolution typically contains proposal documents rather than code. However, it may include code examples to illustrate proposed changes:

// swift-evolution example (hypothetical syntax proposal)
func greet(_ name: String?) {
    guard let name else {
        print("Hello, stranger!")
        return
    }
    print("Hello, \(name)!")
}

swift-syntax, on the other hand, contains actual Swift code for parsing and manipulating Swift source code:

import SwiftSyntax

let sourceFile = try SyntaxParser.parse(source: "let x = 5")
let variableDecl = sourceFile.statements.first?.item as? VariableDeclSyntax
print(variableDecl?.bindings.first?.pattern)

This comparison highlights the different focuses of the two repositories: swift-evolution for language design and swift-syntax for programmatic manipulation of Swift code.

The Package Manager for the Swift Programming Language

Pros of Swift Package Manager

  • More comprehensive functionality for managing dependencies and building Swift projects
  • Integrated directly into Xcode, providing a seamless development experience
  • Supports a wide range of platforms, including iOS, macOS, tvOS, and watchOS

Cons of Swift Package Manager

  • Larger codebase and more complex architecture, potentially making it harder to contribute
  • Slower release cycle due to its broader scope and integration with the Swift ecosystem
  • May have a steeper learning curve for newcomers compared to Swift Syntax

Code Comparison

Swift Package Manager:

import PackageDescription

let package = Package(
    name: "MyPackage",
    dependencies: [
        .package(url: "https://github.com/example/example-package.git", from: "1.0.0"),
    ],
    targets: [
        .target(name: "MyTarget", dependencies: ["ExamplePackage"]),
    ]
)

Swift Syntax:

import SwiftSyntax

let sourceFile = try SyntaxParser.parse(source: "let x = 5")
let variableName = sourceFile.statements.first?.item.as(VariableDeclSyntax.self)?.bindings.first?.pattern
print(variableName?.description ?? "No variable found")

Language Server Protocol implementation for Swift and C-based languages

Pros of SourceKit-LSP

  • Provides a complete Language Server Protocol implementation for Swift
  • Offers broader IDE integration capabilities beyond syntax parsing
  • Supports advanced features like code completion, refactoring, and diagnostics

Cons of SourceKit-LSP

  • More complex setup and configuration compared to Swift Syntax
  • Potentially higher resource usage due to its comprehensive feature set
  • May have a steeper learning curve for developers new to LSP

Code Comparison

Swift Syntax:

import SwiftSyntax

let sourceFile = try SyntaxParser.parse(source: "let x = 5")
let variableName = sourceFile.statements.first?.item.as(VariableDeclSyntax.self)?.bindings.first?.pattern

SourceKit-LSP:

import SourceKitLSP

let server = SourceKitServer()
server.run()
// LSP requests and responses are handled through JSON-RPC

Summary

Swift Syntax focuses on parsing and manipulating Swift source code, while SourceKit-LSP provides a full-featured language server implementation. Swift Syntax is more lightweight and easier to integrate for specific syntax-related tasks, whereas SourceKit-LSP offers comprehensive IDE support but requires more setup and resources.

Convert Figma logo designs to code with AI

Visual Copilot

Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.

Try Visual Copilot

README

Swift Syntax

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.

Documentation

You can read SwiftSyntax’s documentation on swiftpackageindex.com.

A great way to interactively explore the SwiftSyntax tree of a source file is https://swift-ast-explorer.com, developed by @kishikawakatsumi.

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.

dependencies: [
  .package(url: "https://github.com/swiftlang/swift-syntax.git", from: "<#latest swift-syntax tag#>"),
],

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

http_archive(
    name = "SwiftSyntax",
    sha256 = "f070fd44db9b33f430fd5b5d2700f1e2001c0028711859600e80cc975074fab0",
    strip_prefix = "swift-syntax-509.1.0",
    url = "https://github.com/apple/swift-syntax/archive/refs/tags/509.1.0.tar.gz",
)

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".

License

Please see LICENSE for more information.