Home | History | Annotate | Download | only in Analysis
      1 // RUN: %clang_cc1 -analyze -analyzer-store=region -analyzer-constraints=range -fblocks -analyzer-opt-analyze-nested-blocks -analyzer-checker=core,alpha.deadcode.IdempotentOperations -analyzer-max-loop 3 -verify %s
      2 // RUN: %clang_cc1 -analyze -analyzer-store=region -analyzer-constraints=range -fblocks -analyzer-opt-analyze-nested-blocks -analyzer-checker=core,alpha.deadcode.IdempotentOperations -analyzer-max-loop 4 -verify %s
      3 // RUN: %clang_cc1 -analyze -analyzer-store=region -analyzer-constraints=range -fblocks -analyzer-opt-analyze-nested-blocks -analyzer-checker=core,alpha.deadcode.IdempotentOperations %s -verify
      4 
      5 void always_warning() { int *p = 0; *p = 0xDEADBEEF; } // expected-warning{{Dereference of null pointer (loaded from variable 'p')}}
      6 
      7 // This test case previously caused a bogus idempotent operation warning
      8 // due to us not properly culling warnings due to incomplete analysis of loops.
      9 int pr8403()
     10 {
     11         int i;
     12         for(i=0; i<10; i++)
     13         {
     14                 int j;
     15                 for(j=0; j+1<i; j++)
     16                 {
     17                 }
     18         }
     19         return 0;
     20 }
     21 
     22