mirror of
https://github.com/apple/swift.git
synced 2025-12-14 20:36:38 +01:00
Based off the PlaygroundTransform, this new ASTWalker leaves calls to __builtin_pc_before and __builtin_pc_after before and after a user would expect a program counter to enter a range of source code.
31 lines
1.1 KiB
Swift
31 lines
1.1 KiB
Swift
// RUN: rm -rf %t && mkdir -p %t
|
|
// RUN: cp %s %t/main.swift
|
|
// RUN: %target-build-swift -Xfrontend -playground -Xfrontend -debugger-support -o %t/main %S/Inputs/PlaygroundsRuntime.swift %t/main.swift
|
|
// RUN: %target-run %t/main | %FileCheck %s
|
|
// RUN: %target-build-swift -Xfrontend -pc-macro -Xfrontend -playground -Xfrontend -debugger-support -o %t/main %S/Inputs/PlaygroundsRuntime.swift %S/Inputs/SilentPCMacroRuntime.swift %t/main.swift
|
|
// RUN: %target-run %t/main | %FileCheck %s
|
|
// REQUIRES: executable_test
|
|
struct S {
|
|
var a : [Int] = [] {
|
|
didSet {
|
|
print("Set")
|
|
}
|
|
}
|
|
}
|
|
|
|
var s = S()
|
|
s.a = [3,2]
|
|
s.a.append(300)
|
|
|
|
// CHECK: [{{.*}}] $builtin_log[s='S(a: [])']
|
|
// CHECK-NEXT: [{{.*}}] $builtin_log_scope_entry
|
|
// CHECK-NEXT: Set
|
|
// CHECK-NEXT: [{{.*}}] $builtin_postPrint
|
|
// CHECK-NEXT: [{{.*}}] $builtin_log_scope_exit
|
|
// CHECK-NEXT: [{{.*}}] $builtin_log[s='S(a: [3, 2])']
|
|
// CHECK-NEXT: [{{.*}}] $builtin_log_scope_entry
|
|
// CHECK-NEXT: Set
|
|
// CHECK-NEXT: [{{.*}}] $builtin_postPrint
|
|
// CHECK-NEXT: [{{.*}}] $builtin_log_scope_exit
|
|
// CHECK-NEXT: [{{.*}}] $builtin_log[a='[3, 2, 300]']
|