File: SyntaxAnyVisitorFile.swift

package info (click to toggle)
swiftlang 6.0.3-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 2,519,992 kB
  • sloc: cpp: 9,107,863; ansic: 2,040,022; asm: 1,135,751; python: 296,500; objc: 82,456; f90: 60,502; lisp: 34,951; pascal: 19,946; sh: 18,133; perl: 7,482; ml: 4,937; javascript: 4,117; makefile: 3,840; awk: 3,535; xml: 914; fortran: 619; cs: 573; ruby: 573
file content (102 lines) | stat: -rw-r--r-- 3,052 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
//===----------------------------------------------------------------------===//
//
// This source file is part of the Swift.org open source project
//
// Copyright (c) 2014 - 2023 Apple Inc. and the Swift project authors
// Licensed under Apache License v2.0 with Runtime Library Exception
//
// See https://swift.org/LICENSE.txt for license information
// See https://swift.org/CONTRIBUTORS.txt for the list of Swift project authors
//
//===----------------------------------------------------------------------===//

import SwiftSyntax
import SwiftSyntaxBuilder
import SyntaxSupport
import Utils

let syntaxAnyVisitorFile = SourceFileSyntax(leadingTrivia: copyrightHeader) {
  try! ClassDeclSyntax(
    """
    /// A `SyntaxVisitor` that can visit the nodes as generic ``Syntax`` values.
    ///
    /// This subclass of `SyntaxVisitor` is slower than the type-specific visitation
    /// of `SyntaxVisitor`. Use `SyntaxAnyVisitor` if the `visitAny(_)` function
    /// would be useful to have, otherwise inherit from `SyntaxVisitor`.
    ///
    /// This works by overriding the type-specific visit function that delegate to
    /// `visitAny(_)`. A subclass that provides a custom type-specific visit
    /// function, should also call `visitAny(_)` in its implementation, if calling
    /// `visitAny` is needed:
    ///
    /// ```swift
    /// struct MyVisitor: SyntaxAnyVisitor {
    ///   func visitAny(_ node: Syntax) -> SyntaxVisitorContinueKind {
    ///     <code>
    ///   }
    ///
    ///   func visit(_ token: TokenSyntax) -> SyntaxVisitorContinueKind {
    ///     <code>
    ///     // Call this to pass tokens to `visitAny(_)` as well if needed
    ///     visitAny(token)
    ///   }
    /// }
    /// ```
    open class SyntaxAnyVisitor: SyntaxVisitor
    """
  ) {
    DeclSyntax(
      """
      open func visitAny(_ node: Syntax) -> SyntaxVisitorContinueKind {
        return .visitChildren
      }
      """
    )

    DeclSyntax(
      """
      /// The function called after visiting the node and its descendants.
      ///   - node: the node we just finished visiting.
      open func visitAnyPost(_ node: Syntax) {}
      """
    )

    DeclSyntax(
      """
      // MARK: Override type specific visit methods

      override open func visit(_ token: TokenSyntax) -> SyntaxVisitorContinueKind {
        return visitAny(token._syntaxNode)
      }
      """
    )

    DeclSyntax(
      """
      override open func visitPost(_ node: TokenSyntax) {
        visitAnyPost(node._syntaxNode)
      }
      """
    )

    for node in SYNTAX_NODES where !node.kind.isBase {
      DeclSyntax(
        """
        \(node.apiAttributes())\
        override open func visit(_ node: \(node.kind.syntaxType)) -> SyntaxVisitorContinueKind {
          return visitAny(node._syntaxNode)
        }
        """
      )

      DeclSyntax(
        """
        \(node.apiAttributes())\
        override open func visitPost(_ node: \(node.kind.syntaxType)) {
          visitAnyPost(node._syntaxNode)
        }
        """
      )
    }
  }
}