aboutsummaryrefslogtreecommitdiff
path: root/clang/test/Analysis/pch_macro.cpp
blob: afc371d50460f2b3db7844f8d578fcfa915dbe91 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
// RUN: rm -rf %t
// RUN: mkdir -p %t
// RUN: split-file %s %t

// DEFINE: %{emit-pch-action} = \
// DEFINE:   %clang_cc1 -x c++ -emit-pch -o %t/header.pch %t/header.h

// DEFINE: %{analyze-action} = \
// DEFINE:   %clang_analyze_cc1 -include-pch %t/header.pch \
// DEFINE:   -analyzer-checker=core,apiModeling,unix.StdCLibraryFunctions \
// DEFINE:   -verify %t/main.cpp

// RUN: %{emit-pch-action} -triple x86_64-apple-macosx10.15.0
// RUN: %{analyze-action}  -triple x86_64-apple-macosx10.15.0
// RUN: %{emit-pch-action}
// RUN: %{analyze-action}


//--- header.h


// Pre-compiled header

int foo();

// Literal data for macro values will be null as they are defined in a PCH
#define EOF -1
#define AT_FDCWD -2


//--- main.cpp


// Source file
// expected-no-diagnostics
int test() {
  // we need a function call here to initiate erroneous routine
  return foo(); // no-crash
}

// Test that StdLibraryFunctionsChecker can obtain the definition of
// AT_FDCWD even if it is from a PCH:
int faccessat(int, const char *, int, int);

void test_faccessat() {
  char fileSystemPath[10] = { 0 };

  if (0 != faccessat(AT_FDCWD, fileSystemPath, 2, 0x0030)) {}
}