From 13be03222faa22b1a1088ea5c1a00014934b9ee4 Mon Sep 17 00:00:00 2001 From: DeLesley Hutchins Date: Fri, 18 Oct 2013 23:11:49 +0000 Subject: [PATCH] Consumed analysis: fix assert failure. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@193010 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/Analysis/Consumed.cpp | 28 +++++++++++----- test/SemaCXX/warn-consumed-analysis.cpp | 43 +++++++++++++++++++++++++ 2 files changed, 63 insertions(+), 8 deletions(-) diff --git a/lib/Analysis/Consumed.cpp b/lib/Analysis/Consumed.cpp index 8358b6b4e1..ed806ce671 100644 --- a/lib/Analysis/Consumed.cpp +++ b/lib/Analysis/Consumed.cpp @@ -414,6 +414,15 @@ class ConsumedStmtVisitor : public ConstStmtVisitor { void propagateReturnType(const Stmt *Call, const FunctionDecl *Fun, QualType ReturnType); + inline ConsumedState getPInfoState(const PropagationInfo& PInfo) { + if (PInfo.isVar()) + return StateMap->getState(PInfo.getVar()); + else if (PInfo.isState()) + return PInfo.getState(); + else + return CS_None; + } + public: void checkCallability(const PropagationInfo &PInfo, const FunctionDecl *FunDecl, @@ -927,15 +936,18 @@ void ConsumedStmtVisitor::VisitUnaryOperator(const UnaryOperator *UOp) { void ConsumedStmtVisitor::VisitVarDecl(const VarDecl *Var) { if (isConsumableType(Var->getType())) { if (Var->hasInit()) { - PropagationInfo PInfo = - PropagationMap.find(Var->getInit())->second; - - StateMap->setState(Var, PInfo.isVar() ? - StateMap->getState(PInfo.getVar()) : PInfo.getState()); - - } else { - StateMap->setState(Var, consumed::CS_Unknown); + MapType::iterator VIT = PropagationMap.find(Var->getInit()); + if (VIT != PropagationMap.end()) { + PropagationInfo PInfo = VIT->second; + ConsumedState St = getPInfoState(PInfo); + if (St != consumed::CS_None) { + StateMap->setState(Var, St); + return; + } + } } + // Otherwise + StateMap->setState(Var, consumed::CS_Unknown); } } }} // end clang::consumed::ConsumedStmtVisitor diff --git a/test/SemaCXX/warn-consumed-analysis.cpp b/test/SemaCXX/warn-consumed-analysis.cpp index 14deae58f9..cf94431ac2 100644 --- a/test/SemaCXX/warn-consumed-analysis.cpp +++ b/test/SemaCXX/warn-consumed-analysis.cpp @@ -642,3 +642,46 @@ void read(bool sf) { } // end namespace ContinueICETest + +namespace InitializerAssertionFailTest { + +class CONSUMABLE(unconsumed) Status { + int code; + +public: + Status() RETURN_TYPESTATE(consumed); + Status(int c) RETURN_TYPESTATE(unconsumed); + + Status(const Status &other); + //Status(Status &&other); + + Status& operator=(const Status &other) CALLABLE_WHEN("unknown", "consumed"); + //Status& operator=(Status &&other) CALLABLE_WHEN("unknown", "consumed"); + + bool check() const SET_TYPESTATE(consumed); + void ignore() const SET_TYPESTATE(consumed); + // Status& markAsChecked() { return *this; } + + void clear() CALLABLE_WHEN("unknown", "consumed") SET_TYPESTATE(consumed); + + ~Status() CALLABLE_WHEN("unknown", "consumed"); +}; + + +bool cond(); +Status doSomething(); +void handleStatus(const Status& s); +void handleStatusPtr(const Status* s); + +int a; + + +void test() { + if (cond()) { + Status s = doSomething(); + return; // Warning: Store it, but don't check. + } +} + +} // end namespace InitializerAssertionFailTest + -- 2.40.0