| // clang-format off |
| |
| // REQUIRES: system-windows |
| // RUN: %build -o %t.exe -- %s |
| // RUN: env LLDB_USE_NATIVE_PDB_READER=1 %lldb -f %t.exe -s \ |
| // RUN: %p/Inputs/local-variables.lldbinit 2>&1 | FileCheck %s |
| |
| int Function(int Param1, char Param2) { |
| unsigned Local1 = Param1 + 1; |
| char Local2 = Param2 + 1; |
| ++Local1; |
| ++Local2; |
| return Local1; |
| } |
| |
| int main(int argc, char **argv) { |
| int SomeLocal = argc * 2; |
| return Function(SomeLocal, 'a'); |
| } |
| |
| // CHECK: (lldb) target create "{{.*}}local-variables.cpp.tmp.exe" |
| // CHECK-NEXT: Current executable set to '{{.*}}local-variables.cpp.tmp.exe' |
| // CHECK-NEXT: (lldb) command source -s 0 '{{.*}}local-variables.lldbinit' |
| // CHECK-NEXT: Executing commands in '{{.*}}local-variables.lldbinit'. |
| // CHECK-NEXT: (lldb) break set -f local-variables.cpp -l 17 |
| // CHECK-NEXT: Breakpoint 1: where = local-variables.cpp.tmp.exe`main + {{.*}} at local-variables.cpp:{{.*}}, address = {{.*}} |
| // CHECK-NEXT: (lldb) run a b c d e f g |
| // CHECK-NEXT: Process {{.*}} launched: '{{.*}}local-variables.cpp.tmp.exe' |
| // CHECK-NEXT: Process {{.*}} stopped |
| // CHECK-NEXT: * thread #1, stop reason = breakpoint 1.1 |
| // CHECK-NEXT: frame #0: {{.*}} local-variables.cpp.tmp.exe`main(argc=8, argv={{.*}}) at local-variables.cpp:{{.*}} |
| // CHECK-NEXT: 14 } |
| // CHECK-NEXT: 15 |
| // CHECK-NEXT: 16 int main(int argc, char **argv) { |
| // CHECK-NEXT: -> 17 int SomeLocal = argc * 2; |
| // CHECK-NEXT: 18 return Function(SomeLocal, 'a'); |
| // CHECK-NEXT: 19 } |
| // CHECK-NEXT: 20 |
| |
| // CHECK: (lldb) expression argc |
| // CHECK-NEXT: (int) $0 = 8 |
| // CHECK-NEXT: (lldb) step |
| // CHECK-NEXT: Process {{.*}} stopped |
| // CHECK-NEXT: * thread #1, stop reason = step in |
| // CHECK-NEXT: frame #0: {{.*}} local-variables.cpp.tmp.exe`main(argc=8, argv={{.*}}) at local-variables.cpp:{{.*}} |
| // CHECK-NEXT: 15 |
| // CHECK-NEXT: 16 int main(int argc, char **argv) { |
| // CHECK-NEXT: 17 int SomeLocal = argc * 2; |
| // CHECK-NEXT: -> 18 return Function(SomeLocal, 'a'); |
| // CHECK-NEXT: 19 } |
| // CHECK-NEXT: 20 |
| |
| // CHECK: (lldb) expression SomeLocal |
| // CHECK-NEXT: (int) $1 = 16 |
| // CHECK-NEXT: (lldb) step |
| // CHECK-NEXT: Process {{.*}} stopped |
| // CHECK-NEXT: * thread #1, stop reason = step in |
| // CHECK-NEXT: frame #0: {{.*}} local-variables.cpp.tmp.exe`Function(Param1=16, Param2='a') at local-variables.cpp:{{.*}} |
| // CHECK-NEXT: 6 |
| // CHECK-NEXT: 7 |
| // CHECK-NEXT: 8 int Function(int Param1, char Param2) { |
| // CHECK-NEXT: -> 9 unsigned Local1 = Param1 + 1; |
| // CHECK-NEXT: 10 char Local2 = Param2 + 1; |
| // CHECK-NEXT: 11 ++Local1; |
| // CHECK-NEXT: 12 ++Local2; |
| |
| // CHECK: (lldb) expression Param1 |
| // CHECK-NEXT: (int) $2 = 16 |
| // CHECK-NEXT: (lldb) expression Param2 |
| // CHECK-NEXT: (char) $3 = 'a' |
| // CHECK-NEXT: (lldb) step |
| // CHECK-NEXT: Process {{.*}} stopped |
| // CHECK-NEXT: * thread #1, stop reason = step in |
| // CHECK-NEXT: frame #0: {{.*}} local-variables.cpp.tmp.exe`Function(Param1=16, Param2='a') at local-variables.cpp:{{.*}} |
| // CHECK-NEXT: 7 |
| // CHECK-NEXT: 8 int Function(int Param1, char Param2) { |
| // CHECK-NEXT: 9 unsigned Local1 = Param1 + 1; |
| // CHECK-NEXT: -> 10 char Local2 = Param2 + 1; |
| // CHECK-NEXT: 11 ++Local1; |
| // CHECK-NEXT: 12 ++Local2; |
| // CHECK-NEXT: 13 return Local1; |
| |
| // CHECK: (lldb) expression Param1 |
| // CHECK-NEXT: (int) $4 = 16 |
| // CHECK-NEXT: (lldb) expression Param2 |
| // CHECK-NEXT: (char) $5 = 'a' |
| // CHECK-NEXT: (lldb) expression Local1 |
| // CHECK-NEXT: (unsigned int) $6 = 17 |
| // CHECK-NEXT: (lldb) step |
| // CHECK-NEXT: Process {{.*}} stopped |
| // CHECK-NEXT: * thread #1, stop reason = step in |
| // CHECK-NEXT: frame #0: {{.*}} local-variables.cpp.tmp.exe`Function(Param1=16, Param2='a') at local-variables.cpp:{{.*}} |
| // CHECK-NEXT: 8 int Function(int Param1, char Param2) { |
| // CHECK-NEXT: 9 unsigned Local1 = Param1 + 1; |
| // CHECK-NEXT: 10 char Local2 = Param2 + 1; |
| // CHECK-NEXT: -> 11 ++Local1; |
| // CHECK-NEXT: 12 ++Local2; |
| // CHECK-NEXT: 13 return Local1; |
| // CHECK-NEXT: 14 } |
| |
| // CHECK: (lldb) expression Param1 |
| // CHECK-NEXT: (int) $7 = 16 |
| // CHECK-NEXT: (lldb) expression Param2 |
| // CHECK-NEXT: (char) $8 = 'a' |
| // CHECK-NEXT: (lldb) expression Local1 |
| // CHECK-NEXT: (unsigned int) $9 = 17 |
| // CHECK-NEXT: (lldb) expression Local2 |
| // CHECK-NEXT: (char) $10 = 'b' |
| // CHECK-NEXT: (lldb) step |
| // CHECK-NEXT: Process {{.*}} stopped |
| // CHECK-NEXT: * thread #1, stop reason = step in |
| // CHECK-NEXT: frame #0: {{.*}} local-variables.cpp.tmp.exe`Function(Param1=16, Param2='a') at local-variables.cpp:{{.*}} |
| // CHECK-NEXT: 9 unsigned Local1 = Param1 + 1; |
| // CHECK-NEXT: 10 char Local2 = Param2 + 1; |
| // CHECK-NEXT: 11 ++Local1; |
| // CHECK-NEXT: -> 12 ++Local2; |
| // CHECK-NEXT: 13 return Local1; |
| // CHECK-NEXT: 14 } |
| // CHECK-NEXT: 15 |
| |
| // CHECK: (lldb) expression Param1 |
| // CHECK-NEXT: (int) $11 = 16 |
| // CHECK-NEXT: (lldb) expression Param2 |
| // CHECK-NEXT: (char) $12 = 'a' |
| // CHECK-NEXT: (lldb) expression Local1 |
| // CHECK-NEXT: (unsigned int) $13 = 18 |
| // CHECK-NEXT: (lldb) expression Local2 |
| // CHECK-NEXT: (char) $14 = 'b' |
| // CHECK-NEXT: (lldb) step |
| // CHECK-NEXT: Process {{.*}} stopped |
| // CHECK-NEXT: * thread #1, stop reason = step in |
| // CHECK-NEXT: frame #0: {{.*}} local-variables.cpp.tmp.exe`Function(Param1=16, Param2='a') at local-variables.cpp:{{.*}} |
| // CHECK-NEXT: 10 char Local2 = Param2 + 1; |
| // CHECK-NEXT: 11 ++Local1; |
| // CHECK-NEXT: 12 ++Local2; |
| // CHECK-NEXT: -> 13 return Local1; |
| // CHECK-NEXT: 14 } |
| // CHECK-NEXT: 15 |
| // CHECK-NEXT: 16 int main(int argc, char **argv) { |
| |
| // CHECK: (lldb) expression Param1 |
| // CHECK-NEXT: (int) $15 = 16 |
| // CHECK-NEXT: (lldb) expression Param2 |
| // CHECK-NEXT: (char) $16 = 'a' |
| // CHECK-NEXT: (lldb) expression Local1 |
| // CHECK-NEXT: (unsigned int) $17 = 18 |
| // CHECK-NEXT: (lldb) expression Local2 |
| // CHECK-NEXT: (char) $18 = 'c' |
| // CHECK-NEXT: (lldb) continue |
| // CHECK-NEXT: Process {{.*}} resuming |
| // CHECK-NEXT: Process {{.*}} exited with status = 18 (0x00000012) |
| |
| // CHECK: (lldb) target modules dump ast |
| // CHECK-NEXT: Dumping clang ast for {{.*}} modules. |
| // CHECK-NEXT: TranslationUnitDecl |
| // CHECK-NEXT: |-FunctionDecl {{.*}} main 'int (int, char **)' |
| // CHECK-NEXT: | |-ParmVarDecl {{.*}} argc 'int' |
| // CHECK-NEXT: | `-ParmVarDecl {{.*}} argv 'char **' |
| // CHECK-NEXT: |-FunctionDecl {{.*}} __scrt_common_main_seh 'int ()' static |
| // CHECK-NEXT: |-FunctionDecl {{.*}} invoke_main 'int ()' inline |
| // CHECK: `-FunctionDecl {{.*}} Function 'int (int, char)' |
| // CHECK-NEXT: |-ParmVarDecl {{.*}} Param1 'int' |
| // CHECK-NEXT: `-ParmVarDecl {{.*}} Param2 'char' |