|  | // RUN: %clang_analyze_cc1 -verify %s 2>&1 \ | 
|  | // RUN:   -analyzer-display-progress \ | 
|  | // RUN:   -analyzer-checker=debug.ExprInspection \ | 
|  | // RUN:   -analyzer-output=text \ | 
|  | // RUN: | FileCheck %s | 
|  |  | 
|  | void clang_analyzer_warnIfReached(); | 
|  |  | 
|  | // expected-note@+2 {{[debug] analyzing from f()}} | 
|  | // expected-warning@+1 {{REACHABLE}} expected-note@+1 {{REACHABLE}} | 
|  | void f() { clang_analyzer_warnIfReached(); } | 
|  |  | 
|  | // expected-note@+2 {{[debug] analyzing from g()}} | 
|  | // expected-warning@+1 {{REACHABLE}} expected-note@+1 {{REACHABLE}} | 
|  | void g() { clang_analyzer_warnIfReached(); } | 
|  |  | 
|  | // expected-note@+2 {{[debug] analyzing from h()}} | 
|  | // expected-warning@+1 {{REACHABLE}} expected-note@+1 {{REACHABLE}} | 
|  | void h() { clang_analyzer_warnIfReached(); } | 
|  |  | 
|  | struct SomeStruct { | 
|  | // expected-note@+2 {{[debug] analyzing from SomeStruct::f()}} | 
|  | // expected-warning@+1 {{REACHABLE}} expected-note@+1 {{REACHABLE}} | 
|  | void f() { clang_analyzer_warnIfReached(); } | 
|  | }; | 
|  |  | 
|  | struct SomeOtherStruct { | 
|  | // expected-note@+2 {{[debug] analyzing from SomeOtherStruct::f()}} | 
|  | // expected-warning@+1 {{REACHABLE}} expected-note@+1 {{REACHABLE}} | 
|  | void f() { clang_analyzer_warnIfReached(); } | 
|  | }; | 
|  |  | 
|  | namespace ns { | 
|  | struct SomeStruct { | 
|  | // expected-note@+2 {{[debug] analyzing from ns::SomeStruct::f(int)}} | 
|  | // expected-warning@+1 {{REACHABLE}} expected-note@+1 {{REACHABLE}} | 
|  | void f(int) { clang_analyzer_warnIfReached(); } | 
|  | // expected-note@+2 {{[debug] analyzing from ns::SomeStruct::f(float, ::SomeStruct)}} | 
|  | // expected-warning@+1 {{REACHABLE}} expected-note@+1 {{REACHABLE}} | 
|  | void f(float, ::SomeStruct) { clang_analyzer_warnIfReached(); } | 
|  | // expected-note@+2 {{[debug] analyzing from ns::SomeStruct::f(float, SomeStruct)}} | 
|  | // expected-warning@+1 {{REACHABLE}} expected-note@+1 {{REACHABLE}} | 
|  | void f(float, SomeStruct) { clang_analyzer_warnIfReached(); } | 
|  | }; | 
|  | } | 
|  |  | 
|  | // CHECK: analyzer-display-progress.cpp f() : {{[0-9]+}} | 
|  | // CHECK: analyzer-display-progress.cpp g() : {{[0-9]+}} | 
|  | // CHECK: analyzer-display-progress.cpp h() : {{[0-9]+}} | 
|  | // CHECK: analyzer-display-progress.cpp SomeStruct::f() : {{[0-9]+}} | 
|  | // CHECK: analyzer-display-progress.cpp SomeOtherStruct::f() : {{[0-9]+}} | 
|  | // CHECK: analyzer-display-progress.cpp ns::SomeStruct::f(int) : {{[0-9]+}} | 
|  | // CHECK: analyzer-display-progress.cpp ns::SomeStruct::f(float, ::SomeStruct) : {{[0-9]+}} | 
|  | // CHECK: analyzer-display-progress.cpp ns::SomeStruct::f(float, SomeStruct) : {{[0-9]+}} |