
This patch works towards consolidating all Clang debug-info into the `clang/test/DebugInfo` directory (https://discourse.llvm.org/t/clang-test-location-of-clang-debug-info-tests/87958). Here we move only the `clang/test/CodeGenCXX` tests. I created a `CXX` subdirectory for now because many of the tests I checked actually did seem C++-specific. There is probably overlap between the `Generic` and `CXX` subdirectory, but I haven't gone through and audited them all. The list of files i came up with is: 1. searched for anything with `*debug-info*` in the filename 2. searched for occurrences of `debug-info-kind` in the tests There's a couple of tests in `clang/test/CodeGenCXX` that still set `-debug-info-kind`. They probably don't need to do that, but I'm not changing that as part of this PR.
36 lines
1.3 KiB
C++
36 lines
1.3 KiB
C++
// RUN: %clang_cc1 -emit-llvm -debug-info-kind=limited %s -o - | FileCheck %s
|
|
|
|
struct vec {
|
|
using itr = int*;
|
|
itr begin() { return nullptr; }
|
|
itr end() { return nullptr; }
|
|
};
|
|
|
|
void test() {
|
|
vec as, bs, cs;
|
|
|
|
for (auto a : as)
|
|
for (auto b : bs)
|
|
for (auto c : cs) {
|
|
}
|
|
}
|
|
|
|
// CHECK: #dbg_declare(ptr %__range1, ![[RANGE1:[0-9]+]]
|
|
// CHECK: #dbg_declare(ptr {{[^,]*}}, ![[BEGIN1:[0-9]+]]
|
|
// CHECK: #dbg_declare(ptr {{[^,]*}}, ![[END1:[0-9]+]]
|
|
// CHECK: #dbg_declare(ptr %__range2, ![[RANGE2:[0-9]+]]
|
|
// CHECK: #dbg_declare(ptr {{[^,]*}}, ![[BEGIN2:[0-9]+]]
|
|
// CHECK: #dbg_declare(ptr {{[^,]*}}, ![[END2:[0-9]+]]
|
|
// CHECK: #dbg_declare(ptr %__range3, ![[RANGE3:[0-9]+]]
|
|
// CHECK: #dbg_declare(ptr {{[^,]*}}, ![[BEGIN3:[0-9]+]]
|
|
// CHECK: #dbg_declare(ptr {{[^,]*}}, ![[END3:[0-9]+]]
|
|
// CHECK: ![[RANGE1]] = !DILocalVariable(name: "__range1",
|
|
// CHECK: ![[BEGIN1]] = !DILocalVariable(name: "__begin1",
|
|
// CHECK: ![[END1]] = !DILocalVariable(name: "__end1",
|
|
// CHECK: ![[RANGE2]] = !DILocalVariable(name: "__range2",
|
|
// CHECK: ![[BEGIN2]] = !DILocalVariable(name: "__begin2",
|
|
// CHECK: ![[END2]] = !DILocalVariable(name: "__end2",
|
|
// CHECK: ![[RANGE3]] = !DILocalVariable(name: "__range3",
|
|
// CHECK: ![[BEGIN3]] = !DILocalVariable(name: "__begin3",
|
|
// CHECK: ![[END3]] = !DILocalVariable(name: "__end3",
|