aboutsummaryrefslogtreecommitdiff
path: root/gcc/testsuite/gcc.dg/plugin/diagnostic-test-inlining-4.c
blob: dfb939db17d53a7a0dbe7e0c54b6dcd1b03d1e8f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
/* { dg-do compile } */
/* { dg-options "-Wno-attributes -fdiagnostics-show-caret" } */

extern void __emit_warning (const char *message);

__attribute__((always_inline))
static void depth_0 (void)
{
  __emit_warning ("message");
}

__attribute__((always_inline))
static void depth_1 (void)
{
  depth_0 ();
}

__attribute__((always_inline))
static void depth_2 (void)
{
  depth_1 ();
}

__attribute__((always_inline))
static void depth_3 (void)
{
  depth_2 ();
}

__attribute__((always_inline))
static void depth_4 (void)
{
  depth_3 ();
}

int main()
{
  depth_4 ();
  return 0;
}

/* Verify that the diagnostic subsytem describes the chain of inlining
   when reporting the warning, for an example showing many levels of
   inlining.  */

/* { dg-regexp "In function 'depth_0'," "" } */
/* { dg-regexp "    inlined from 'depth_1' at .+/diagnostic-test-inlining-4.c:15:3," "" } */
/* { dg-regexp "    inlined from 'depth_2' at .+/diagnostic-test-inlining-4.c:21:3," "" } */
/* { dg-regexp "    inlined from 'depth_3' at .+/diagnostic-test-inlining-4.c:27:3," "" } */
/* { dg-regexp "    inlined from 'depth_4' at .+/diagnostic-test-inlining-4.c:33:3," "" } */
/* { dg-regexp "    inlined from 'main' at .+/diagnostic-test-inlining-4.c:38:3:" "" } */
/* { dg-warning "3: message" "" { target *-*-* } 9 } */
/* { dg-begin-multiline-output "" }
   __emit_warning ("message");
   ^~~~~~~~~~~~~~~~~~~~~~~~~~
   { dg-end-multiline-output "" } */