blob: 7b83d0345b72f9ef09708222292062d559b2462d [file] [log] [blame]
#include "analyzer-decls.h"
#define NULL ((void *)0)
/* Verify that the analyzer makes the simplifying assumption that we don't
hit NULL when incrementing pointers to non-NULL memory regions. */
static int * __attribute__((noinline))
maybe_inc_int_ptr (int *ptr)
{
if (!ptr)
return NULL;
return ++ptr;
}
int
test_1 (void)
{
int stack;
int *a = &stack;
a = maybe_inc_int_ptr (a);
a = maybe_inc_int_ptr (a);
__analyzer_eval (a == NULL); /* { dg-warning "FALSE" } */
__analyzer_eval (a != NULL); /* { dg-warning "TRUE" } */
return *a; /* { dg-warning "use of uninitialized value '\\*a'" } */
/* TODO: a complaint about out-of-bounds would be a better warning. */
}
static const char * __attribute__((noinline))
maybe_inc_char_ptr (const char *ptr)
{
if (!ptr)
return NULL;
return ++ptr;
}
char
test_s (void)
{
const char *msg = "hello world";
const char *a = msg;
__analyzer_eval (*a == 'h'); /* { dg-warning "TRUE" } */
a = maybe_inc_char_ptr (a);
__analyzer_eval (*a == 'e'); /* { dg-warning "TRUE" } */
a = maybe_inc_char_ptr (a);
__analyzer_eval (*a == 'l'); /* { dg-warning "TRUE" } */
a = maybe_inc_char_ptr (a);
__analyzer_eval (*a == 'l'); /* { dg-warning "TRUE" } */
a = maybe_inc_char_ptr (a);
__analyzer_eval (*a == 'o'); /* { dg-warning "TRUE" } */
}