forked from OSchip/llvm-project
				
			
		
			
				
	
	
		
			42 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			C++
		
	
	
	
			
		
		
	
	
			42 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			C++
		
	
	
	
// RUN: %clang_analyze_cc1 -std=c++14 \
 | 
						|
// RUN:  -analyzer-checker=core,debug.ExprInspection \
 | 
						|
// RUN:  -verify %s
 | 
						|
 | 
						|
void clang_analyzer_eval(bool);
 | 
						|
void clang_analyzer_warnIfReached();
 | 
						|
 | 
						|
typedef __typeof__(sizeof(int)) size_t;
 | 
						|
 | 
						|
void *operator new(size_t size) throw() {
 | 
						|
  return nullptr;
 | 
						|
  // expected-warning@-1 {{null returned from function that requires a non-null return value}}
 | 
						|
}
 | 
						|
void *operator new[](size_t size) throw() {
 | 
						|
  return nullptr;
 | 
						|
  // expected-warning@-1 {{null returned from function that requires a non-null return value}}
 | 
						|
}
 | 
						|
 | 
						|
struct S {
 | 
						|
  int x;
 | 
						|
  S() : x(1) {
 | 
						|
    // FIXME: Constructor should not be called with null this, even if it was
 | 
						|
    // returned by operator new().
 | 
						|
    clang_analyzer_warnIfReached(); // expected-warning{{REACHABLE}}
 | 
						|
  }
 | 
						|
  ~S() {}
 | 
						|
};
 | 
						|
 | 
						|
void testArrays() {
 | 
						|
  S *s = new S[10]; // no-crash
 | 
						|
  s[0].x = 2;
 | 
						|
  // no-warning: 'Dereference of null pointer' suppressed by ReturnVisitor.
 | 
						|
}
 | 
						|
 | 
						|
int global;
 | 
						|
void testInvalidationOnConstructionIntoNull() {
 | 
						|
  global = 0;
 | 
						|
  S *s = new S();
 | 
						|
  // FIXME: Should be FALSE - we should not invalidate globals.
 | 
						|
  clang_analyzer_eval(global); // expected-warning{{UNKNOWN}}
 | 
						|
}
 |