| /* { dg-do compile } */ |
| /* { dg-options "-Wno-attributes -fdiagnostics-show-caret -O1" } */ |
| |
| extern void __emit_warning (const char *message); |
| |
| __attribute__((always_inline)) |
| static void foo (void) |
| { |
| __emit_warning ("message"); |
| } |
| |
| __attribute__((always_inline)) |
| static void bar (void) |
| { |
| foo (); |
| } |
| |
| int main() |
| { |
| bar (); |
| return 0; |
| } |
| |
| /* Reproducer for PR tree-optimization/83336: when optimization is |
| enabled, but debuginfo isn't, the diagnostics subsystem doesn't |
| report the full inlining chain at a middle-end warning. |
| |
| This is a copy of diagnostic-test-inlining-1.c, but with -O1. |
| |
| Ideally the diagnostics subsystem would report: |
| In function 'foo', inlined from 'bar' at LOC A, inlined from 'main' at LOC B: |
| but with -O1 it only reports: |
| In function 'foo', inlined from 'main' at LOC A: |
| |
| This test case captures this behavior. */ |
| |
| /* { dg-regexp "In function 'foo'," "" } */ |
| /* { dg-regexp " inlined from 'bar' at .+/diagnostic-test-inlining-3.c:15:3," "" } */ |
| /* { dg-regexp " inlined from 'main' at .+/diagnostic-test-inlining-3.c:20:3:" "" } */ |
| /* { dg-warning "3: message" "" { target *-*-* } 9 } */ |
| /* { dg-begin-multiline-output "" } |
| __emit_warning ("message"); |
| ^~~~~~~~~~~~~~~~~~~~~~~~~~ |
| { dg-end-multiline-output "" } */ |