2018-12-07 20:29:02 +08:00
|
|
|
// RUN: rm -rf %t && mkdir %t
|
|
|
|
// RUN: mkdir -p %t/ctudir
|
|
|
|
// RUN: %clang_cc1 -triple x86_64-pc-linux-gnu \
|
|
|
|
// RUN: -emit-pch -o %t/ctudir/ctu-other.cpp.ast %S/Inputs/ctu-other.cpp
|
|
|
|
// RUN: %clang_cc1 -triple x86_64-pc-linux-gnu \
|
|
|
|
// RUN: -emit-pch -o %t/ctudir/ctu-chain.cpp.ast %S/Inputs/ctu-chain.cpp
|
[analyzer][CrossTU][NFC] Generalize to external definitions instead of external functions
Summary: This is just changing naming and documentation to be general about external definitions that can be imported for cross translation unit analysis. There is at least a plan to add VarDecls: D46421
Reviewers: NoQ, xazax.hun, martong, a.sidorin, george.karpenkov, serge-sans-paille
Reviewed By: xazax.hun, martong
Subscribers: mgorny, whisperity, baloghadamsoftware, szepet, rnkovacs, mikhail.ramalho, Szelethus, donat.nagy, dkrupp, cfe-commits
Differential Revision: https://reviews.llvm.org/D56441
llvm-svn: 350852
2019-01-11 01:44:04 +08:00
|
|
|
// RUN: cp %S/Inputs/ctu-other.cpp.externalDefMap.txt %t/ctudir/externalDefMap.txt
|
2018-12-07 20:29:02 +08:00
|
|
|
// RUN: %clang_analyze_cc1 -triple x86_64-pc-linux-gnu \
|
|
|
|
// RUN: -analyzer-checker=core,debug.ExprInspection \
|
|
|
|
// RUN: -analyzer-config experimental-enable-naive-ctu-analysis=true \
|
|
|
|
// RUN: -analyzer-config ctu-dir=%t/ctudir \
|
|
|
|
// RUN: -verify %s
|
[CTU] Add DisplayCTUProgress analyzer switch
Summary:
With a new switch we may be able to print to stderr if a new TU is being loaded
during CTU. This is very important for higher level scripts (like CodeChecker)
to be able to parse this output so they can create e.g. a zip file in case of
a Clang crash which contains all the related TU files.
Reviewers: xazax.hun, Szelethus, a_sidorin, george.karpenkov
Subscribers: whisperity, baloghadamsoftware, szepet, rnkovacs, a.sidorin, mikhail.ramalho, donat.nagy, dkrupp,
Differential Revision: https://reviews.llvm.org/D55135
llvm-svn: 348594
2018-12-07 22:56:02 +08:00
|
|
|
// RUN: %clang_analyze_cc1 -triple x86_64-pc-linux-gnu \
|
|
|
|
// RUN: -analyzer-checker=core,debug.ExprInspection \
|
|
|
|
// RUN: -analyzer-config experimental-enable-naive-ctu-analysis=true \
|
|
|
|
// RUN: -analyzer-config ctu-dir=%t/ctudir \
|
|
|
|
// RUN: -analyzer-config display-ctu-progress=true 2>&1 %s | FileCheck %s
|
|
|
|
|
2018-12-08 01:36:44 +08:00
|
|
|
// CHECK: CTU loaded AST file: {{.*}}ctu-other.cpp.ast
|
|
|
|
// CHECK: CTU loaded AST file: {{.*}}ctu-chain.cpp.ast
|
2018-03-01 22:54:16 +08:00
|
|
|
|
2018-07-04 22:12:58 +08:00
|
|
|
#include "ctu-hdr.h"
|
|
|
|
|
2018-03-01 22:54:16 +08:00
|
|
|
void clang_analyzer_eval(int);
|
|
|
|
|
|
|
|
int f(int);
|
|
|
|
int g(int);
|
|
|
|
int h(int);
|
|
|
|
|
|
|
|
int callback_to_main(int x) { return x + 1; }
|
|
|
|
|
|
|
|
namespace myns {
|
|
|
|
int fns(int x);
|
|
|
|
|
|
|
|
namespace embed_ns {
|
|
|
|
int fens(int x);
|
|
|
|
}
|
|
|
|
|
|
|
|
class embed_cls {
|
|
|
|
public:
|
|
|
|
int fecl(int x);
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
class mycls {
|
|
|
|
public:
|
|
|
|
int fcl(int x);
|
2019-07-04 19:39:00 +08:00
|
|
|
virtual int fvcl(int x);
|
2018-03-01 22:54:16 +08:00
|
|
|
static int fscl(int x);
|
|
|
|
|
|
|
|
class embed_cls2 {
|
|
|
|
public:
|
|
|
|
int fecl2(int x);
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2019-07-04 19:39:00 +08:00
|
|
|
class derived : public mycls {
|
|
|
|
public:
|
|
|
|
virtual int fvcl(int x) override;
|
|
|
|
};
|
|
|
|
|
2018-03-01 22:54:16 +08:00
|
|
|
namespace chns {
|
|
|
|
int chf1(int x);
|
|
|
|
}
|
|
|
|
|
2018-04-24 18:11:53 +08:00
|
|
|
int fun_using_anon_struct(int);
|
2018-07-04 22:12:58 +08:00
|
|
|
int other_macro_diag(int);
|
2018-04-24 18:11:53 +08:00
|
|
|
|
[analyzer][CrossTU] Extend CTU to VarDecls with initializer
Summary:
The existing CTU mechanism imports `FunctionDecl`s where the definition is available in another TU. This patch extends that to VarDecls, to bind more constants.
- Add VarDecl importing functionality to CrossTranslationUnitContext
- Import Decls while traversing them in AnalysisConsumer
- Add VarDecls to CTU external mappings generator
- Name changes from "external function map" to "external definition map"
Reviewers: NoQ, dcoughlin, xazax.hun, george.karpenkov, martong
Reviewed By: xazax.hun
Subscribers: Charusso, baloghadamsoftware, mikhail.ramalho, Szelethus, donat.nagy, dkrupp, george.karpenkov, mgorny, whisperity, szepet, rnkovacs, a.sidorin, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D46421
llvm-svn: 358968
2019-04-23 19:04:41 +08:00
|
|
|
extern const int extInt;
|
|
|
|
namespace intns {
|
|
|
|
extern const int extInt;
|
|
|
|
}
|
|
|
|
struct S {
|
|
|
|
int a;
|
|
|
|
};
|
|
|
|
extern const S extS;
|
|
|
|
extern const int extHere;
|
|
|
|
const int extHere = 6;
|
|
|
|
struct A {
|
|
|
|
static const int a;
|
|
|
|
};
|
|
|
|
struct SC {
|
|
|
|
const int a;
|
|
|
|
};
|
|
|
|
extern SC extSC;
|
|
|
|
struct ST {
|
|
|
|
static struct SC sc;
|
|
|
|
};
|
|
|
|
struct SCNest {
|
|
|
|
struct SCN {
|
|
|
|
const int a;
|
|
|
|
} scn;
|
|
|
|
};
|
|
|
|
extern SCNest extSCN;
|
|
|
|
extern SCNest::SCN extSubSCN;
|
|
|
|
struct SCC {
|
|
|
|
SCC(int c);
|
|
|
|
const int a;
|
|
|
|
};
|
|
|
|
extern SCC extSCC;
|
|
|
|
union U {
|
|
|
|
const int a;
|
|
|
|
const unsigned int b;
|
|
|
|
};
|
|
|
|
extern U extU;
|
|
|
|
|
2019-07-04 19:39:00 +08:00
|
|
|
void test_virtual_functions(mycls* obj) {
|
|
|
|
// The dynamic type is known.
|
|
|
|
clang_analyzer_eval(mycls().fvcl(1) == 8); // expected-warning{{TRUE}}
|
|
|
|
clang_analyzer_eval(derived().fvcl(1) == 9); // expected-warning{{TRUE}}
|
|
|
|
// We cannot decide about the dynamic type.
|
|
|
|
clang_analyzer_eval(obj->fvcl(1) == 8); // expected-warning{{FALSE}} expected-warning{{TRUE}}
|
|
|
|
}
|
|
|
|
|
2018-03-01 22:54:16 +08:00
|
|
|
int main() {
|
|
|
|
clang_analyzer_eval(f(3) == 2); // expected-warning{{TRUE}}
|
|
|
|
clang_analyzer_eval(f(4) == 3); // expected-warning{{TRUE}}
|
|
|
|
clang_analyzer_eval(f(5) == 3); // expected-warning{{FALSE}}
|
|
|
|
clang_analyzer_eval(g(4) == 6); // expected-warning{{TRUE}}
|
|
|
|
clang_analyzer_eval(h(2) == 8); // expected-warning{{TRUE}}
|
|
|
|
|
|
|
|
clang_analyzer_eval(myns::fns(2) == 9); // expected-warning{{TRUE}}
|
|
|
|
clang_analyzer_eval(myns::embed_ns::fens(2) == -1); // expected-warning{{TRUE}}
|
|
|
|
clang_analyzer_eval(mycls().fcl(1) == 6); // expected-warning{{TRUE}}
|
|
|
|
clang_analyzer_eval(mycls::fscl(1) == 7); // expected-warning{{TRUE}}
|
|
|
|
clang_analyzer_eval(myns::embed_cls().fecl(1) == -6); // expected-warning{{TRUE}}
|
|
|
|
clang_analyzer_eval(mycls::embed_cls2().fecl2(0) == -11); // expected-warning{{TRUE}}
|
|
|
|
|
|
|
|
clang_analyzer_eval(chns::chf1(4) == 12); // expected-warning{{TRUE}}
|
2018-04-24 18:11:53 +08:00
|
|
|
clang_analyzer_eval(fun_using_anon_struct(8) == 8); // expected-warning{{TRUE}}
|
2018-07-04 22:12:58 +08:00
|
|
|
|
|
|
|
clang_analyzer_eval(other_macro_diag(1) == 1); // expected-warning{{TRUE}}
|
2019-07-04 19:39:00 +08:00
|
|
|
// expected-warning@Inputs/ctu-other.cpp:93{{REACHABLE}}
|
2018-07-04 22:12:58 +08:00
|
|
|
MACRODIAG(); // expected-warning{{REACHABLE}}
|
[analyzer][CrossTU] Extend CTU to VarDecls with initializer
Summary:
The existing CTU mechanism imports `FunctionDecl`s where the definition is available in another TU. This patch extends that to VarDecls, to bind more constants.
- Add VarDecl importing functionality to CrossTranslationUnitContext
- Import Decls while traversing them in AnalysisConsumer
- Add VarDecls to CTU external mappings generator
- Name changes from "external function map" to "external definition map"
Reviewers: NoQ, dcoughlin, xazax.hun, george.karpenkov, martong
Reviewed By: xazax.hun
Subscribers: Charusso, baloghadamsoftware, mikhail.ramalho, Szelethus, donat.nagy, dkrupp, george.karpenkov, mgorny, whisperity, szepet, rnkovacs, a.sidorin, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D46421
llvm-svn: 358968
2019-04-23 19:04:41 +08:00
|
|
|
|
|
|
|
clang_analyzer_eval(extInt == 2); // expected-warning{{TRUE}}
|
|
|
|
clang_analyzer_eval(intns::extInt == 3); // expected-warning{{TRUE}}
|
|
|
|
clang_analyzer_eval(extS.a == 4); // expected-warning{{TRUE}}
|
|
|
|
clang_analyzer_eval(extHere == 6); // expected-warning{{TRUE}}
|
|
|
|
clang_analyzer_eval(A::a == 3); // expected-warning{{TRUE}}
|
|
|
|
clang_analyzer_eval(extSC.a == 8); // expected-warning{{TRUE}}
|
|
|
|
clang_analyzer_eval(ST::sc.a == 2); // expected-warning{{TRUE}}
|
|
|
|
// clang_analyzer_eval(extSCN.scn.a == 9); // TODO
|
|
|
|
clang_analyzer_eval(extSubSCN.a == 1); // expected-warning{{TRUE}}
|
|
|
|
// clang_analyzer_eval(extSCC.a == 7); // TODO
|
|
|
|
clang_analyzer_eval(extU.a == 4); // expected-warning{{TRUE}}
|
2018-03-01 22:54:16 +08:00
|
|
|
}
|