mirror of
https://github.com/apple/swift.git
synced 2025-12-21 12:14:44 +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.
48 lines
1.6 KiB
Swift
48 lines
1.6 KiB
Swift
// RUN: rm -rf %t
|
|
// RUN: 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
|
|
|
|
func doSomething() throws -> Int { return 5 }
|
|
|
|
do {
|
|
try doSomething()
|
|
} catch {
|
|
print(error)
|
|
}
|
|
|
|
// CHECK: [{{.*}}] $builtin_log_scope_entry
|
|
// CHECK-NEXT: [{{.*}}] $builtin_log_scope_entry
|
|
// CHECK-NEXT: [{{.*}}] $builtin_log[='5']
|
|
// CHECK-NEXT: [{{.*}}] $builtin_log_scope_exit
|
|
// CHECK-NEXT: [{{.*}}] $builtin_log[='5']
|
|
// CHECK-NEXT: [{{.*}}] $builtin_log_scope_exit
|
|
|
|
1
|
|
try doSomething()
|
|
// CHECK-LABEL: [{{.*}}] $builtin_log[='1']
|
|
// CHECK-NEXT: [{{.*}}] $builtin_log_scope_entry
|
|
// CHECK-NEXT: [{{.*}}] $builtin_log[='5']
|
|
// CHECK-NEXT: [{{.*}}] $builtin_log_scope_exit
|
|
// CHECK-NEXT: [{{.*}}] $builtin_log[='5']
|
|
|
|
2
|
|
try! doSomething()
|
|
// CHECK-LABEL: [{{.*}}] $builtin_log[='2']
|
|
// CHECK-NEXT: [{{.*}}] $builtin_log_scope_entry
|
|
// CHECK-NEXT: [{{.*}}] $builtin_log[='5']
|
|
// CHECK-NEXT: [{{.*}}] $builtin_log_scope_exit
|
|
// CHECK-NEXT: [{{.*}}] $builtin_log[='5']
|
|
|
|
3
|
|
try? doSomething()
|
|
// CHECK-LABEL: [{{.*}}] $builtin_log[='3']
|
|
// CHECK-NEXT: [{{.*}}] $builtin_log_scope_entry
|
|
// CHECK-NEXT: [{{.*}}] $builtin_log[='5']
|
|
// CHECK-NEXT: [{{.*}}] $builtin_log_scope_exit
|
|
// CHECK-NEXT: [{{.*}}] $builtin_log[='Optional(5)']
|