@freestanding(expression) macro stringify(_ value: T) -> (T, String) = #externalMacro(module: "MacroDefinition", type: "StringifyMacro") func testStringify(a: Int, b: Int) { _ = #stringify(a + b) } @attached(memberAttribute) @attached(member) macro myTypeWrapper() = #externalMacro(module: "MacroDefinition", type: "TypeWrapperMacro") @attached(accessor) macro accessViaStorage() = #externalMacro(module: "MacroDefinition", type: "AccessViaStorageMacro") struct _Storage { var x: Int = 0 { willSet { print("setting \(newValue)") } } var y: Int = 0 { willSet { print("setting \(newValue)") } } } @myTypeWrapper struct S { var x: Int var y: Int } struct S2 { private var _storage = _Storage() @accessViaStorage var x: Int @accessViaStorage var y: Int = 17 } @attached(peer) macro addCompletionHandler() = #externalMacro(module: "MacroDefinition", type: "AddCompletionHandler") @available(macOS 10.15, *) struct S3 { @addCompletionHandler func f(a: Int, for b: String, _ value: Double) async -> String { return b } } @attached(conformance) macro Hashable() = #externalMacro(module: "MacroDefinition", type: "HashableMacro") @Hashable struct S4 { } // FIXME: Swift parser is not enabled on Linux CI yet. // REQUIRES: OS=macosx // REQUIRES: executable_test // REQUIRES=shell // RUN: %empty-directory(%t) //##-- Prepare the macro plugin. // RUN: %target-build-swift -swift-version 5 -I %swift-host-lib-dir -L %swift-host-lib-dir -emit-library -o %t/%target-library-name(MacroDefinition) -module-name=MacroDefinition %S/../../Macros/Inputs/syntax_macro_definitions.swift -g -no-toolchain-stdlib-rpath // RUN: COMPILER_ARGS_WITHOUT_SOURCE=( \ // RUN: -swift-version 5 \ // RUN: -load-plugin-library %t/%target-library-name(MacroDefinition) \ // RUN: -I %swift-host-lib-dir \ // RUN: -module-name MacroUser \ // RUN: ) // RUN: COMPILER_ARGS=( \ // RUN: ${COMPILER_ARGS_WITHOUT_SOURCE[@]} \ // RUN: %s \ // RUN: ) //##-- cursor-info on macro expression // RUN: %sourcekitd-test -req=cursor -pos=4:7 -cursor-action -req-opts=retrieve_symbol_graph=1 %s -- ${COMPILER_ARGS[@]} | %FileCheck -check-prefix=CURSOR_MACRO_EXPR %s // RUN: %sourcekitd-test -req=cursor -pos=4:8 -cursor-action -req-opts=retrieve_symbol_graph=1 %s -- ${COMPILER_ARGS[@]} | %FileCheck -check-prefix=CURSOR_MACRO_EXPR %s // CURSOR_MACRO_EXPR: source.lang.swift.ref.macro (1:33-1:42) // CURSOR_MACRO_EXPR: (T) -> (T, String) // CURSOR_MACRO_EXPR: @freestanding(expression) macro stringify<T>(_ value: T) -> (T, String) = #externalMacro(module: "MacroDefinition", type: "StringifyMacro") // CURSOR_MACRO_EXPR: @freestanding(expression) macro stringify<T>(_ value: T) -> (T, String) = #externalMacro(module: "MacroDefinition", type: "StringifyMacro") // CURSOR_MACRO_EXPR-LABEL: SYMBOL GRAPH BEGIN // CURSOR_MACRO_EXPR: "identifier": { // CURSOR_MACRO_EXPR-NEXT: "interfaceLanguage": "swift", // CURSOR_MACRO_EXPR-NEXT: "precise": "s:9MacroUser9stringifyyx_SStxclufm" // CURSOR_MACRO_EXPR-NEXT: }, // CURSOR_MACRO_EXPR-NEXT: "kind": { // CURSOR_MACRO_EXPR-NEXT: "displayName": "Macro", // CURSOR_MACRO_EXPR-NEXT: "identifier": "swift.macro" // CURSOR_MACRO_EXPR-NEXT: }, // CURSOR_MACRO_EXPR: SYMBOL GRAPH END // CURSOR_MACRO_EXPR-LABEL: ACTIONS BEGIN // CURSOR_MACRO_EXPR: source.refactoring.kind.rename.global // CURSOR_MACRO_EXPR-NEXT: Global Rename // CURSOR_MACRO_EXPR: source.refactoring.kind.expand.macro // CURSOR_MACRO_EXPR-NEXT: Expand Macro // CURSOR_MACRO_EXPR: ACTIONS END //##-- Refactoring on macro expression // RUN: %sourcekitd-test -req=refactoring.expand.macro -pos=4:7 %s -- ${COMPILER_ARGS[@]} | %FileCheck -check-prefix=EXPAND %s // RUN: %sourcekitd-test -req=refactoring.expand.macro -pos=4:8 %s -- ${COMPILER_ARGS[@]} | %FileCheck -check-prefix=EXPAND %s // EXPAND: source.edit.kind.active: // EXPAND-NEXT: 4:7-4:24 (@__swiftmacro_9MacroUser13testStringify1a1bySi_SitF9stringifyfMf_.swift) "(a + b, "a + b")" //##-- cursor-info on attached macro // RUN: %sourcekitd-test -req=cursor -pos=21:1 -cursor-action -req-opts=retrieve_symbol_graph=1 %s -- ${COMPILER_ARGS[@]} | %FileCheck -check-prefix=CURSOR_ATTACHED %s // RUN: %sourcekitd-test -req=cursor -pos=21:2 -cursor-action -req-opts=retrieve_symbol_graph=1 %s -- ${COMPILER_ARGS[@]} | %FileCheck -check-prefix=CURSOR_ATTACHED %s // CURSOR_ATTACHED: source.lang.swift.ref.macro (9:7-9:20) // CURSOR_ATTACHED-LABEL: SYMBOL GRAPH BEGIN // CURSOR_ATTACHED: "identifier": { // CURSOR_ATTACHED-NEXT: "interfaceLanguage": "swift", // CURSOR_ATTACHED-NEXT: "precise": "s:9MacroUser13myTypeWrapperyycfm" // CURSOR_ATTACHED-NEXT: }, // CURSOR_ATTACHED-NEXT: "kind": { // CURSOR_ATTACHED-NEXT: "displayName": "Macro", // CURSOR_ATTACHED-NEXT: "identifier": "swift.macro" // CURSOR_ATTACHED-NEXT: }, // CURSOR_ATTACHED: SYMBOL GRAPH END // CURSOR_ATTACHED-LABEL: ACTIONS BEGIN // CURSOR_ATTACHED: source.refactoring.kind.expand.macro // CURSOR_ATTACHED-NEXT: Expand Macro // CURSOR_ATTACHED: ACTIONS END //##-- Refactoring on attached macro // RUN: %sourcekitd-test -req=refactoring.expand.macro -pos=21:1 %s -- ${COMPILER_ARGS[@]} | %FileCheck -check-prefix=ATTACHED_EXPAND %s // RUN: %sourcekitd-test -req=refactoring.expand.macro -pos=21:2 %s -- ${COMPILER_ARGS[@]} | %FileCheck -check-prefix=ATTACHED_EXPAND %s // ATTACHED_EXPAND: source.edit.kind.active: // ATTACHED_EXPAND-NEXT: 23:3-23:3 (@__swiftmacro_9MacroUser1SV13myTypeWrapperfMA_.swift) "@accessViaStorage " // ATTACHED_EXPAND-NEXT: source.edit.kind.active: // ATTACHED_EXPAND-NEXT: 24:3-24:3 (@__swiftmacro_9MacroUser1SV13myTypeWrapperfMA0_.swift) "@accessViaStorage " // ATTACHED_EXPAND-NEXT: source.edit.kind.active: // ATTACHED_EXPAND-NEXT: 25:1-25:1 (@__swiftmacro_9MacroUser1SV13myTypeWrapperfMm_.swift) " // ATTACHED_EXPAND-EMPTY: // ATTACHED_EXPAND-NEXT: private var _storage = _Storage() // ATTACHED_EXPAND-NEXT: " // ATTACHED_EXPAND-NEXT: source.edit.kind.active: // ATTACHED_EXPAND-NEXT: 21:1-21:15 "" //##-- Refactoring on the attribute expanded by @myTypeWrapper // RUN: %sourcekitd-test -req=refactoring.expand.macro -pos=1:2 @__swiftmacro_9MacroUser1SV13myTypeWrapperfMA_.swift -primary-file %s -- ${COMPILER_ARGS[@]} | %FileCheck -check-prefix=NESTED_ATTACHED_EXPAND %s // NESTED_ATTACHED_EXPAND: source.edit.kind.active: // NESTED_ATTACHED_EXPAND-NEXT: Macros/macro_basic.swift 23:13-23:13 (@__swiftmacro_9MacroUser1SV1xSivp16accessViaStoragefMa_.swift) "{ // NESTED_ATTACHED_EXPAND-NEXT: get { _storage.x } // NESTED_ATTACHED_EXPAND-EMPTY: // NESTED_ATTACHED_EXPAND-NEXT: set { _storage.x = newValue } // NESTED_ATTACHED_EXPAND-NEXT: }" // NESTED_ATTACHED_EXPAND-NEXT: source.edit.kind.active: // NESTED_ATTACHED_EXPAND-NEXT: 1:1-1:18 "" //##-- Refactoring expanding the first accessor macro // RUN: %sourcekitd-test -req=refactoring.expand.macro -pos=30:4 %s -- ${COMPILER_ARGS[@]} | %FileCheck -check-prefix=ACCESSOR1_EXPAND %s // ACCESSOR1_EXPAND: source.edit.kind.active: // ACCESSOR1_EXPAND-NEXT: 31:13-31:13 (@__swiftmacro_9MacroUser2S2V1xSivp16accessViaStoragefMa_.swift) "{ // ACCESSOR1_EXPAND-NEXT: get { _storage.x } // ACCESSOR1_EXPAND-EMPTY: // ACCESSOR1_EXPAND-NEXT: set { _storage.x = newValue } // ACCESSOR1_EXPAND-NEXT: }" // ACCESSOR1_EXPAND-NEXT: source.edit.kind.active: // ACCESSOR1_EXPAND-NEXT: 30:3-30:20 "" //##-- Refactoring expanding the second accessor macro // RUN: %sourcekitd-test -req=refactoring.expand.macro -pos=33:13 %s -- ${COMPILER_ARGS[@]} | %FileCheck -check-prefix=ACCESSOR2_EXPAND %s // ACCESSOR2_EXPAND: source.edit.kind.active: // ACCESSOR2_EXPAND-NEXT: 34:14-34:18 (@__swiftmacro_9MacroUser2S2V1ySivp16accessViaStoragefMa_.swift) "{ // ACCESSOR2_EXPAND-NEXT: get { _storage.y } // ACCESSOR2_EXPAND-EMPTY: // ACCESSOR2_EXPAND-NEXT: set { _storage.y = newValue } // ACCESSOR2_EXPAND-NEXT: }" // ACCESSOR2_EXPAND-NEXT: source.edit.kind.active: // ACCESSOR2_EXPAND-NEXT: 33:3-33:20 "" //##-- Refactoring expanding the addCompletionHandler macro. // RUN: %sourcekitd-test -req=refactoring.expand.macro -pos=42:5 %s -- ${COMPILER_ARGS[@]} | %FileCheck -check-prefix=PEER_EXPAND %s // PEER_EXPAND: source.edit.kind.active: // PEER_EXPAND-NEXT: 45:4-45:4 (@__swiftmacro_9MacroUser2S3V1f1a3for_SSSi_SSSdtYaF20addCompletionHandlerfMp_.swift) " // PEER_EXPAND-EMPTY: // PEER_EXPAND-NEXT: func f(a: Int, for b: String, _ value: Double, completionHandler: @escaping (String) -> Void) { // PEER_EXPAND-NEXT: Task { // PEER_EXPAND-NEXT: completionHandler(await f(a: a, for: b, value)) // PEER_EXPAND-NEXT: } // PEER_EXPAND-NEXT: } // PEER_EXPAND-NEXT: " // PEER_EXPAND-NEXT: source.edit.kind.active: // PEER_EXPAND-NEXT: 42:3-42:24 "" //##-- Refactoring expanding a conformance macro. // RUN: %sourcekitd-test -req=refactoring.expand.macro -pos=51:5 %s -- ${COMPILER_ARGS[@]} | %FileCheck -check-prefix=CONFORMANCE_EXPAND %s // CONFORMANCE_EXPAND: source.edit.kind.active: // CONFORMANCE_EXPAND-NEXT: 52:14-52:14 (@__swiftmacro_9MacroUser2S4V8HashablefMc_.swift) " // CONFORMANCE_EXPAND-EMPTY: // CONFORMANCE_EXPAND-NEXT: extension S4 : Hashable {} // CONFORMANCE_EXPAND-NEXT: " // CONFORMANCE_EXPAND-NEXT: source.edit.kind.active: // CONFORMANCE_EXPAND-NEXT: 51:1-51:10 "" //##-- Doc info, mostly just checking we don't crash because of the separate buffers // RUN: %sourcekitd-test -req=doc-info %s -- ${COMPILER_ARGS_WITHOUT_SOURCE[@]} | %FileCheck -check-prefix=DOCINFO %s // DOCINFO: key.name: "myTypeWrapper()" // DOCINFO-NEXT: key.usr: "s:9MacroUser13myTypeWrapperyycfm" // DOCINFO-NEXT: key.offset: 621 // DOCINFO: key.name: "myTypeWrapper()" // DOCINFO-NEXT: key.usr: "s:9MacroUser13myTypeWrapperyycfm" // DOCINFO-NEXT: key.offset: 250 //##-- Formatting shouldn't include the added attribute (or crash) // RUN: %sourcekitd-test -req=format -line=23 -length=1 %s | %FileCheck -check-prefix=FORMATTED %s // FORMATTED: " var x: Int"