15ffd83dbSDimitry Andric //===- ComputeDependence.cpp ----------------------------------------------===//
25ffd83dbSDimitry Andric //
35ffd83dbSDimitry Andric // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
45ffd83dbSDimitry Andric // See https://llvm.org/LICENSE.txt for license information.
55ffd83dbSDimitry Andric // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
65ffd83dbSDimitry Andric //
75ffd83dbSDimitry Andric //===----------------------------------------------------------------------===//
85ffd83dbSDimitry Andric 
95ffd83dbSDimitry Andric #include "clang/AST/ComputeDependence.h"
105ffd83dbSDimitry Andric #include "clang/AST/Attr.h"
115ffd83dbSDimitry Andric #include "clang/AST/DeclCXX.h"
125ffd83dbSDimitry Andric #include "clang/AST/DeclarationName.h"
135ffd83dbSDimitry Andric #include "clang/AST/DependenceFlags.h"
145ffd83dbSDimitry Andric #include "clang/AST/Expr.h"
155ffd83dbSDimitry Andric #include "clang/AST/ExprCXX.h"
165ffd83dbSDimitry Andric #include "clang/AST/ExprConcepts.h"
175ffd83dbSDimitry Andric #include "clang/AST/ExprObjC.h"
185ffd83dbSDimitry Andric #include "clang/AST/ExprOpenMP.h"
195ffd83dbSDimitry Andric #include "clang/Basic/ExceptionSpecificationType.h"
205ffd83dbSDimitry Andric #include "llvm/ADT/ArrayRef.h"
215ffd83dbSDimitry Andric 
225ffd83dbSDimitry Andric using namespace clang;
235ffd83dbSDimitry Andric 
computeDependence(FullExpr * E)245ffd83dbSDimitry Andric ExprDependence clang::computeDependence(FullExpr *E) {
255ffd83dbSDimitry Andric   return E->getSubExpr()->getDependence();
265ffd83dbSDimitry Andric }
275ffd83dbSDimitry Andric 
computeDependence(OpaqueValueExpr * E)285ffd83dbSDimitry Andric ExprDependence clang::computeDependence(OpaqueValueExpr *E) {
293b7f365eSDimitry Andric   auto D = toExprDependenceForImpliedType(E->getType()->getDependence());
305ffd83dbSDimitry Andric   if (auto *S = E->getSourceExpr())
315ffd83dbSDimitry Andric     D |= S->getDependence();
325ffd83dbSDimitry Andric   assert(!(D & ExprDependence::UnexpandedPack));
335ffd83dbSDimitry Andric   return D;
345ffd83dbSDimitry Andric }
355ffd83dbSDimitry Andric 
computeDependence(ParenExpr * E)365ffd83dbSDimitry Andric ExprDependence clang::computeDependence(ParenExpr *E) {
375ffd83dbSDimitry Andric   return E->getSubExpr()->getDependence();
385ffd83dbSDimitry Andric }
395ffd83dbSDimitry Andric 
computeDependence(UnaryOperator * E,const ASTContext & Ctx)40e8d8bef9SDimitry Andric ExprDependence clang::computeDependence(UnaryOperator *E,
41e8d8bef9SDimitry Andric                                         const ASTContext &Ctx) {
423b7f365eSDimitry Andric   ExprDependence Dep =
433b7f365eSDimitry Andric       // FIXME: Do we need to look at the type?
443b7f365eSDimitry Andric       toExprDependenceForImpliedType(E->getType()->getDependence()) |
455ffd83dbSDimitry Andric       E->getSubExpr()->getDependence();
46e8d8bef9SDimitry Andric 
47e8d8bef9SDimitry Andric   // C++ [temp.dep.constexpr]p5:
48e8d8bef9SDimitry Andric   //   An expression of the form & qualified-id where the qualified-id names a
49e8d8bef9SDimitry Andric   //   dependent member of the current instantiation is value-dependent. An
50e8d8bef9SDimitry Andric   //   expression of the form & cast-expression is also value-dependent if
51e8d8bef9SDimitry Andric   //   evaluating cast-expression as a core constant expression succeeds and
52e8d8bef9SDimitry Andric   //   the result of the evaluation refers to a templated entity that is an
53e8d8bef9SDimitry Andric   //   object with static or thread storage duration or a member function.
54e8d8bef9SDimitry Andric   //
55e8d8bef9SDimitry Andric   // What this amounts to is: constant-evaluate the operand and check whether it
56e8d8bef9SDimitry Andric   // refers to a templated entity other than a variable with local storage.
57e8d8bef9SDimitry Andric   if (Ctx.getLangOpts().CPlusPlus && E->getOpcode() == UO_AddrOf &&
58e8d8bef9SDimitry Andric       !(Dep & ExprDependence::Value)) {
59e8d8bef9SDimitry Andric     Expr::EvalResult Result;
60e8d8bef9SDimitry Andric     SmallVector<PartialDiagnosticAt, 8> Diag;
61e8d8bef9SDimitry Andric     Result.Diag = &Diag;
62e8d8bef9SDimitry Andric     // FIXME: This doesn't enforce the C++98 constant expression rules.
63e8d8bef9SDimitry Andric     if (E->getSubExpr()->EvaluateAsConstantExpr(Result, Ctx) && Diag.empty() &&
64e8d8bef9SDimitry Andric         Result.Val.isLValue()) {
65e8d8bef9SDimitry Andric       auto *VD = Result.Val.getLValueBase().dyn_cast<const ValueDecl *>();
66e8d8bef9SDimitry Andric       if (VD && VD->isTemplated()) {
67e8d8bef9SDimitry Andric         auto *VarD = dyn_cast<VarDecl>(VD);
68e8d8bef9SDimitry Andric         if (!VarD || !VarD->hasLocalStorage())
69e8d8bef9SDimitry Andric           Dep |= ExprDependence::Value;
70e8d8bef9SDimitry Andric       }
71e8d8bef9SDimitry Andric     }
72e8d8bef9SDimitry Andric   }
73e8d8bef9SDimitry Andric 
74e8d8bef9SDimitry Andric   return Dep;
755ffd83dbSDimitry Andric }
765ffd83dbSDimitry Andric 
computeDependence(UnaryExprOrTypeTraitExpr * E)775ffd83dbSDimitry Andric ExprDependence clang::computeDependence(UnaryExprOrTypeTraitExpr *E) {
785ffd83dbSDimitry Andric   // Never type-dependent (C++ [temp.dep.expr]p3).
795ffd83dbSDimitry Andric   // Value-dependent if the argument is type-dependent.
805ffd83dbSDimitry Andric   if (E->isArgumentType())
815ffd83dbSDimitry Andric     return turnTypeToValueDependence(
823b7f365eSDimitry Andric         toExprDependenceAsWritten(E->getArgumentType()->getDependence()));
835ffd83dbSDimitry Andric 
845ffd83dbSDimitry Andric   auto ArgDeps = E->getArgumentExpr()->getDependence();
855ffd83dbSDimitry Andric   auto Deps = ArgDeps & ~ExprDependence::TypeValue;
865ffd83dbSDimitry Andric   // Value-dependent if the argument is type-dependent.
875ffd83dbSDimitry Andric   if (ArgDeps & ExprDependence::Type)
885ffd83dbSDimitry Andric     Deps |= ExprDependence::Value;
895ffd83dbSDimitry Andric   // Check to see if we are in the situation where alignof(decl) should be
905ffd83dbSDimitry Andric   // dependent because decl's alignment is dependent.
915ffd83dbSDimitry Andric   auto ExprKind = E->getKind();
925ffd83dbSDimitry Andric   if (ExprKind != UETT_AlignOf && ExprKind != UETT_PreferredAlignOf)
935ffd83dbSDimitry Andric     return Deps;
945ffd83dbSDimitry Andric   if ((Deps & ExprDependence::Value) && (Deps & ExprDependence::Instantiation))
955ffd83dbSDimitry Andric     return Deps;
965ffd83dbSDimitry Andric 
975ffd83dbSDimitry Andric   auto *NoParens = E->getArgumentExpr()->IgnoreParens();
985ffd83dbSDimitry Andric   const ValueDecl *D = nullptr;
995ffd83dbSDimitry Andric   if (const auto *DRE = dyn_cast<DeclRefExpr>(NoParens))
1005ffd83dbSDimitry Andric     D = DRE->getDecl();
1015ffd83dbSDimitry Andric   else if (const auto *ME = dyn_cast<MemberExpr>(NoParens))
1025ffd83dbSDimitry Andric     D = ME->getMemberDecl();
1035ffd83dbSDimitry Andric   if (!D)
1045ffd83dbSDimitry Andric     return Deps;
1055ffd83dbSDimitry Andric   for (const auto *I : D->specific_attrs<AlignedAttr>()) {
1065ffd83dbSDimitry Andric     if (I->isAlignmentErrorDependent())
1075ffd83dbSDimitry Andric       Deps |= ExprDependence::Error;
1085ffd83dbSDimitry Andric     if (I->isAlignmentDependent())
1095ffd83dbSDimitry Andric       Deps |= ExprDependence::ValueInstantiation;
1105ffd83dbSDimitry Andric   }
1115ffd83dbSDimitry Andric   return Deps;
1125ffd83dbSDimitry Andric }
1135ffd83dbSDimitry Andric 
computeDependence(ArraySubscriptExpr * E)1145ffd83dbSDimitry Andric ExprDependence clang::computeDependence(ArraySubscriptExpr *E) {
1155ffd83dbSDimitry Andric   return E->getLHS()->getDependence() | E->getRHS()->getDependence();
1165ffd83dbSDimitry Andric }
1175ffd83dbSDimitry Andric 
computeDependence(MatrixSubscriptExpr * E)1185ffd83dbSDimitry Andric ExprDependence clang::computeDependence(MatrixSubscriptExpr *E) {
1195ffd83dbSDimitry Andric   return E->getBase()->getDependence() | E->getRowIdx()->getDependence() |
1205ffd83dbSDimitry Andric          (E->getColumnIdx() ? E->getColumnIdx()->getDependence()
1215ffd83dbSDimitry Andric                             : ExprDependence::None);
1225ffd83dbSDimitry Andric }
1235ffd83dbSDimitry Andric 
computeDependence(CompoundLiteralExpr * E)1245ffd83dbSDimitry Andric ExprDependence clang::computeDependence(CompoundLiteralExpr *E) {
1253b7f365eSDimitry Andric   return toExprDependenceAsWritten(
1263b7f365eSDimitry Andric              E->getTypeSourceInfo()->getType()->getDependence()) |
1273b7f365eSDimitry Andric          toExprDependenceForImpliedType(E->getType()->getDependence()) |
1285ffd83dbSDimitry Andric          turnTypeToValueDependence(E->getInitializer()->getDependence());
1295ffd83dbSDimitry Andric }
1305ffd83dbSDimitry Andric 
computeDependence(ImplicitCastExpr * E)1313b7f365eSDimitry Andric ExprDependence clang::computeDependence(ImplicitCastExpr *E) {
1323b7f365eSDimitry Andric   // We model implicit conversions as combining the dependence of their
1333b7f365eSDimitry Andric   // subexpression, apart from its type, with the semantic portion of the
1343b7f365eSDimitry Andric   // target type.
1353b7f365eSDimitry Andric   ExprDependence D =
1363b7f365eSDimitry Andric       toExprDependenceForImpliedType(E->getType()->getDependence());
1373b7f365eSDimitry Andric   if (auto *S = E->getSubExpr())
1383b7f365eSDimitry Andric     D |= S->getDependence() & ~ExprDependence::Type;
1393b7f365eSDimitry Andric   return D;
1403b7f365eSDimitry Andric }
1413b7f365eSDimitry Andric 
computeDependence(ExplicitCastExpr * E)1423b7f365eSDimitry Andric ExprDependence clang::computeDependence(ExplicitCastExpr *E) {
1435ffd83dbSDimitry Andric   // Cast expressions are type-dependent if the type is
1445ffd83dbSDimitry Andric   // dependent (C++ [temp.dep.expr]p3).
1455ffd83dbSDimitry Andric   // Cast expressions are value-dependent if the type is
1465ffd83dbSDimitry Andric   // dependent or if the subexpression is value-dependent.
1473b7f365eSDimitry Andric   //
1483b7f365eSDimitry Andric   // Note that we also need to consider the dependence of the actual type here,
1493b7f365eSDimitry Andric   // because when the type as written is a deduced type, that type is not
1503b7f365eSDimitry Andric   // dependent, but it may be deduced as a dependent type.
1513b7f365eSDimitry Andric   ExprDependence D =
1523b7f365eSDimitry Andric       toExprDependenceAsWritten(
1533b7f365eSDimitry Andric           cast<ExplicitCastExpr>(E)->getTypeAsWritten()->getDependence()) |
1543b7f365eSDimitry Andric       toExprDependenceForImpliedType(E->getType()->getDependence());
1555ffd83dbSDimitry Andric   if (auto *S = E->getSubExpr())
1565ffd83dbSDimitry Andric     D |= S->getDependence() & ~ExprDependence::Type;
1575ffd83dbSDimitry Andric   return D;
1585ffd83dbSDimitry Andric }
1595ffd83dbSDimitry Andric 
computeDependence(BinaryOperator * E)1605ffd83dbSDimitry Andric ExprDependence clang::computeDependence(BinaryOperator *E) {
1615ffd83dbSDimitry Andric   return E->getLHS()->getDependence() | E->getRHS()->getDependence();
1625ffd83dbSDimitry Andric }
1635ffd83dbSDimitry Andric 
computeDependence(ConditionalOperator * E)1645ffd83dbSDimitry Andric ExprDependence clang::computeDependence(ConditionalOperator *E) {
1655ffd83dbSDimitry Andric   // The type of the conditional operator depends on the type of the conditional
1665ffd83dbSDimitry Andric   // to support the GCC vector conditional extension. Additionally,
1675ffd83dbSDimitry Andric   // [temp.dep.expr] does specify state that this should be dependent on ALL sub
1685ffd83dbSDimitry Andric   // expressions.
1695ffd83dbSDimitry Andric   return E->getCond()->getDependence() | E->getLHS()->getDependence() |
1705ffd83dbSDimitry Andric          E->getRHS()->getDependence();
1715ffd83dbSDimitry Andric }
1725ffd83dbSDimitry Andric 
computeDependence(BinaryConditionalOperator * E)1735ffd83dbSDimitry Andric ExprDependence clang::computeDependence(BinaryConditionalOperator *E) {
1745ffd83dbSDimitry Andric   return E->getCommon()->getDependence() | E->getFalseExpr()->getDependence();
1755ffd83dbSDimitry Andric }
1765ffd83dbSDimitry Andric 
computeDependence(StmtExpr * E,unsigned TemplateDepth)1775ffd83dbSDimitry Andric ExprDependence clang::computeDependence(StmtExpr *E, unsigned TemplateDepth) {
1783b7f365eSDimitry Andric   auto D = toExprDependenceForImpliedType(E->getType()->getDependence());
1795ffd83dbSDimitry Andric   // Propagate dependence of the result.
1805ffd83dbSDimitry Andric   if (const auto *CompoundExprResult =
1815ffd83dbSDimitry Andric           dyn_cast_or_null<ValueStmt>(E->getSubStmt()->getStmtExprResult()))
1825ffd83dbSDimitry Andric     if (const Expr *ResultExpr = CompoundExprResult->getExprStmt())
1835ffd83dbSDimitry Andric       D |= ResultExpr->getDependence();
1845ffd83dbSDimitry Andric   // Note: we treat a statement-expression in a dependent context as always
1855ffd83dbSDimitry Andric   // being value- and instantiation-dependent. This matches the behavior of
1865ffd83dbSDimitry Andric   // lambda-expressions and GCC.
1875ffd83dbSDimitry Andric   if (TemplateDepth)
1885ffd83dbSDimitry Andric     D |= ExprDependence::ValueInstantiation;
1895ffd83dbSDimitry Andric   // A param pack cannot be expanded over stmtexpr boundaries.
1905ffd83dbSDimitry Andric   return D & ~ExprDependence::UnexpandedPack;
1915ffd83dbSDimitry Andric }
1925ffd83dbSDimitry Andric 
computeDependence(ConvertVectorExpr * E)1935ffd83dbSDimitry Andric ExprDependence clang::computeDependence(ConvertVectorExpr *E) {
1943b7f365eSDimitry Andric   auto D = toExprDependenceAsWritten(
1953b7f365eSDimitry Andric                E->getTypeSourceInfo()->getType()->getDependence()) |
1965ffd83dbSDimitry Andric            E->getSrcExpr()->getDependence();
1975ffd83dbSDimitry Andric   if (!E->getType()->isDependentType())
1985ffd83dbSDimitry Andric     D &= ~ExprDependence::Type;
1995ffd83dbSDimitry Andric   return D;
2005ffd83dbSDimitry Andric }
2015ffd83dbSDimitry Andric 
computeDependence(ChooseExpr * E)2025ffd83dbSDimitry Andric ExprDependence clang::computeDependence(ChooseExpr *E) {
2035ffd83dbSDimitry Andric   if (E->isConditionDependent())
2045ffd83dbSDimitry Andric     return ExprDependence::TypeValueInstantiation |
2055ffd83dbSDimitry Andric            E->getCond()->getDependence() | E->getLHS()->getDependence() |
2065ffd83dbSDimitry Andric            E->getRHS()->getDependence();
2075ffd83dbSDimitry Andric 
2085ffd83dbSDimitry Andric   auto Cond = E->getCond()->getDependence();
2095ffd83dbSDimitry Andric   auto Active = E->getLHS()->getDependence();
2105ffd83dbSDimitry Andric   auto Inactive = E->getRHS()->getDependence();
2115ffd83dbSDimitry Andric   if (!E->isConditionTrue())
2125ffd83dbSDimitry Andric     std::swap(Active, Inactive);
2135ffd83dbSDimitry Andric   // Take type- and value- dependency from the active branch. Propagate all
2145ffd83dbSDimitry Andric   // other flags from all branches.
2155ffd83dbSDimitry Andric   return (Active & ExprDependence::TypeValue) |
2165ffd83dbSDimitry Andric          ((Cond | Active | Inactive) & ~ExprDependence::TypeValue);
2175ffd83dbSDimitry Andric }
2185ffd83dbSDimitry Andric 
computeDependence(ParenListExpr * P)2195ffd83dbSDimitry Andric ExprDependence clang::computeDependence(ParenListExpr *P) {
2205ffd83dbSDimitry Andric   auto D = ExprDependence::None;
2215ffd83dbSDimitry Andric   for (auto *E : P->exprs())
2225ffd83dbSDimitry Andric     D |= E->getDependence();
2235ffd83dbSDimitry Andric   return D;
2245ffd83dbSDimitry Andric }
2255ffd83dbSDimitry Andric 
computeDependence(VAArgExpr * E)2265ffd83dbSDimitry Andric ExprDependence clang::computeDependence(VAArgExpr *E) {
2273b7f365eSDimitry Andric   auto D = toExprDependenceAsWritten(
2283b7f365eSDimitry Andric                E->getWrittenTypeInfo()->getType()->getDependence()) |
2295ffd83dbSDimitry Andric            (E->getSubExpr()->getDependence() & ~ExprDependence::Type);
23006c3fb27SDimitry Andric   return D;
2315ffd83dbSDimitry Andric }
2325ffd83dbSDimitry Andric 
computeDependence(NoInitExpr * E)2335ffd83dbSDimitry Andric ExprDependence clang::computeDependence(NoInitExpr *E) {
2343b7f365eSDimitry Andric   return toExprDependenceForImpliedType(E->getType()->getDependence()) &
2355ffd83dbSDimitry Andric          (ExprDependence::Instantiation | ExprDependence::Error);
2365ffd83dbSDimitry Andric }
2375ffd83dbSDimitry Andric 
computeDependence(ArrayInitLoopExpr * E)2385ffd83dbSDimitry Andric ExprDependence clang::computeDependence(ArrayInitLoopExpr *E) {
2395ffd83dbSDimitry Andric   auto D = E->getCommonExpr()->getDependence() |
2405ffd83dbSDimitry Andric            E->getSubExpr()->getDependence() | ExprDependence::Instantiation;
2415ffd83dbSDimitry Andric   if (!E->getType()->isInstantiationDependentType())
2425ffd83dbSDimitry Andric     D &= ~ExprDependence::Instantiation;
2435ffd83dbSDimitry Andric   return turnTypeToValueDependence(D);
2445ffd83dbSDimitry Andric }
2455ffd83dbSDimitry Andric 
computeDependence(ImplicitValueInitExpr * E)2465ffd83dbSDimitry Andric ExprDependence clang::computeDependence(ImplicitValueInitExpr *E) {
2473b7f365eSDimitry Andric   return toExprDependenceForImpliedType(E->getType()->getDependence()) &
2485ffd83dbSDimitry Andric          ExprDependence::Instantiation;
2495ffd83dbSDimitry Andric }
2505ffd83dbSDimitry Andric 
computeDependence(ExtVectorElementExpr * E)2515ffd83dbSDimitry Andric ExprDependence clang::computeDependence(ExtVectorElementExpr *E) {
2525ffd83dbSDimitry Andric   return E->getBase()->getDependence();
2535ffd83dbSDimitry Andric }
2545ffd83dbSDimitry Andric 
computeDependence(BlockExpr * E)2555ffd83dbSDimitry Andric ExprDependence clang::computeDependence(BlockExpr *E) {
2563b7f365eSDimitry Andric   auto D = toExprDependenceForImpliedType(E->getType()->getDependence());
2575ffd83dbSDimitry Andric   if (E->getBlockDecl()->isDependentContext())
2585ffd83dbSDimitry Andric     D |= ExprDependence::Instantiation;
2593b7f365eSDimitry Andric   return D;
2605ffd83dbSDimitry Andric }
2615ffd83dbSDimitry Andric 
computeDependence(AsTypeExpr * E)2625ffd83dbSDimitry Andric ExprDependence clang::computeDependence(AsTypeExpr *E) {
2633b7f365eSDimitry Andric   // FIXME: AsTypeExpr doesn't store the type as written. Assume the expression
2643b7f365eSDimitry Andric   // type has identical sugar for now, so is a type-as-written.
2653b7f365eSDimitry Andric   auto D = toExprDependenceAsWritten(E->getType()->getDependence()) |
2665ffd83dbSDimitry Andric            E->getSrcExpr()->getDependence();
2675ffd83dbSDimitry Andric   if (!E->getType()->isDependentType())
2685ffd83dbSDimitry Andric     D &= ~ExprDependence::Type;
2695ffd83dbSDimitry Andric   return D;
2705ffd83dbSDimitry Andric }
2715ffd83dbSDimitry Andric 
computeDependence(CXXRewrittenBinaryOperator * E)2725ffd83dbSDimitry Andric ExprDependence clang::computeDependence(CXXRewrittenBinaryOperator *E) {
2735ffd83dbSDimitry Andric   return E->getSemanticForm()->getDependence();
2745ffd83dbSDimitry Andric }
2755ffd83dbSDimitry Andric 
computeDependence(CXXStdInitializerListExpr * E)2765ffd83dbSDimitry Andric ExprDependence clang::computeDependence(CXXStdInitializerListExpr *E) {
2775ffd83dbSDimitry Andric   auto D = turnTypeToValueDependence(E->getSubExpr()->getDependence());
2783b7f365eSDimitry Andric   D |= toExprDependenceForImpliedType(E->getType()->getDependence());
2795ffd83dbSDimitry Andric   return D;
2805ffd83dbSDimitry Andric }
2815ffd83dbSDimitry Andric 
computeDependence(CXXTypeidExpr * E)2825ffd83dbSDimitry Andric ExprDependence clang::computeDependence(CXXTypeidExpr *E) {
2835ffd83dbSDimitry Andric   auto D = ExprDependence::None;
2845ffd83dbSDimitry Andric   if (E->isTypeOperand())
2853b7f365eSDimitry Andric     D = toExprDependenceAsWritten(
2865ffd83dbSDimitry Andric         E->getTypeOperandSourceInfo()->getType()->getDependence());
2875ffd83dbSDimitry Andric   else
2885ffd83dbSDimitry Andric     D = turnTypeToValueDependence(E->getExprOperand()->getDependence());
2895ffd83dbSDimitry Andric   // typeid is never type-dependent (C++ [temp.dep.expr]p4)
2905ffd83dbSDimitry Andric   return D & ~ExprDependence::Type;
2915ffd83dbSDimitry Andric }
2925ffd83dbSDimitry Andric 
computeDependence(MSPropertyRefExpr * E)2935ffd83dbSDimitry Andric ExprDependence clang::computeDependence(MSPropertyRefExpr *E) {
2945ffd83dbSDimitry Andric   return E->getBaseExpr()->getDependence() & ~ExprDependence::Type;
2955ffd83dbSDimitry Andric }
2965ffd83dbSDimitry Andric 
computeDependence(MSPropertySubscriptExpr * E)2975ffd83dbSDimitry Andric ExprDependence clang::computeDependence(MSPropertySubscriptExpr *E) {
2985ffd83dbSDimitry Andric   return E->getIdx()->getDependence();
2995ffd83dbSDimitry Andric }
3005ffd83dbSDimitry Andric 
computeDependence(CXXUuidofExpr * E)3015ffd83dbSDimitry Andric ExprDependence clang::computeDependence(CXXUuidofExpr *E) {
3025ffd83dbSDimitry Andric   if (E->isTypeOperand())
3033b7f365eSDimitry Andric     return turnTypeToValueDependence(toExprDependenceAsWritten(
3045ffd83dbSDimitry Andric         E->getTypeOperandSourceInfo()->getType()->getDependence()));
3055ffd83dbSDimitry Andric 
3065ffd83dbSDimitry Andric   return turnTypeToValueDependence(E->getExprOperand()->getDependence());
3075ffd83dbSDimitry Andric }
3085ffd83dbSDimitry Andric 
computeDependence(CXXThisExpr * E)3095ffd83dbSDimitry Andric ExprDependence clang::computeDependence(CXXThisExpr *E) {
3105ffd83dbSDimitry Andric   // 'this' is type-dependent if the class type of the enclosing
3115ffd83dbSDimitry Andric   // member function is dependent (C++ [temp.dep.expr]p2)
3123b7f365eSDimitry Andric   auto D = toExprDependenceForImpliedType(E->getType()->getDependence());
3135ffd83dbSDimitry Andric   assert(!(D & ExprDependence::UnexpandedPack));
3145ffd83dbSDimitry Andric   return D;
3155ffd83dbSDimitry Andric }
3165ffd83dbSDimitry Andric 
computeDependence(CXXThrowExpr * E)3175ffd83dbSDimitry Andric ExprDependence clang::computeDependence(CXXThrowExpr *E) {
3185ffd83dbSDimitry Andric   auto *Op = E->getSubExpr();
3195ffd83dbSDimitry Andric   if (!Op)
3205ffd83dbSDimitry Andric     return ExprDependence::None;
3215ffd83dbSDimitry Andric   return Op->getDependence() & ~ExprDependence::TypeValue;
3225ffd83dbSDimitry Andric }
3235ffd83dbSDimitry Andric 
computeDependence(CXXBindTemporaryExpr * E)3245ffd83dbSDimitry Andric ExprDependence clang::computeDependence(CXXBindTemporaryExpr *E) {
3255ffd83dbSDimitry Andric   return E->getSubExpr()->getDependence();
3265ffd83dbSDimitry Andric }
3275ffd83dbSDimitry Andric 
computeDependence(CXXScalarValueInitExpr * E)3285ffd83dbSDimitry Andric ExprDependence clang::computeDependence(CXXScalarValueInitExpr *E) {
3293b7f365eSDimitry Andric   auto D = toExprDependenceForImpliedType(E->getType()->getDependence());
3303b7f365eSDimitry Andric   if (auto *TSI = E->getTypeSourceInfo())
3313b7f365eSDimitry Andric     D |= toExprDependenceAsWritten(TSI->getType()->getDependence());
3323b7f365eSDimitry Andric   return D;
3335ffd83dbSDimitry Andric }
3345ffd83dbSDimitry Andric 
computeDependence(CXXDeleteExpr * E)3355ffd83dbSDimitry Andric ExprDependence clang::computeDependence(CXXDeleteExpr *E) {
3365ffd83dbSDimitry Andric   return turnTypeToValueDependence(E->getArgument()->getDependence());
3375ffd83dbSDimitry Andric }
3385ffd83dbSDimitry Andric 
computeDependence(ArrayTypeTraitExpr * E)3395ffd83dbSDimitry Andric ExprDependence clang::computeDependence(ArrayTypeTraitExpr *E) {
3403b7f365eSDimitry Andric   auto D = toExprDependenceAsWritten(E->getQueriedType()->getDependence());
3415ffd83dbSDimitry Andric   if (auto *Dim = E->getDimensionExpression())
3425ffd83dbSDimitry Andric     D |= Dim->getDependence();
3435ffd83dbSDimitry Andric   return turnTypeToValueDependence(D);
3445ffd83dbSDimitry Andric }
3455ffd83dbSDimitry Andric 
computeDependence(ExpressionTraitExpr * E)3465ffd83dbSDimitry Andric ExprDependence clang::computeDependence(ExpressionTraitExpr *E) {
3475ffd83dbSDimitry Andric   // Never type-dependent.
3485ffd83dbSDimitry Andric   auto D = E->getQueriedExpression()->getDependence() & ~ExprDependence::Type;
3495ffd83dbSDimitry Andric   // Value-dependent if the argument is type-dependent.
3505ffd83dbSDimitry Andric   if (E->getQueriedExpression()->isTypeDependent())
3515ffd83dbSDimitry Andric     D |= ExprDependence::Value;
3525ffd83dbSDimitry Andric   return D;
3535ffd83dbSDimitry Andric }
3545ffd83dbSDimitry Andric 
computeDependence(CXXNoexceptExpr * E,CanThrowResult CT)3555ffd83dbSDimitry Andric ExprDependence clang::computeDependence(CXXNoexceptExpr *E, CanThrowResult CT) {
3565ffd83dbSDimitry Andric   auto D = E->getOperand()->getDependence() & ~ExprDependence::TypeValue;
3575ffd83dbSDimitry Andric   if (CT == CT_Dependent)
3585ffd83dbSDimitry Andric     D |= ExprDependence::ValueInstantiation;
3595ffd83dbSDimitry Andric   return D;
3605ffd83dbSDimitry Andric }
3615ffd83dbSDimitry Andric 
computeDependence(PackExpansionExpr * E)3625ffd83dbSDimitry Andric ExprDependence clang::computeDependence(PackExpansionExpr *E) {
3635ffd83dbSDimitry Andric   return (E->getPattern()->getDependence() & ~ExprDependence::UnexpandedPack) |
3645ffd83dbSDimitry Andric          ExprDependence::TypeValueInstantiation;
3655ffd83dbSDimitry Andric }
3665ffd83dbSDimitry Andric 
computeDependence(SubstNonTypeTemplateParmExpr * E)3675ffd83dbSDimitry Andric ExprDependence clang::computeDependence(SubstNonTypeTemplateParmExpr *E) {
3685ffd83dbSDimitry Andric   return E->getReplacement()->getDependence();
3695ffd83dbSDimitry Andric }
3705ffd83dbSDimitry Andric 
computeDependence(CoroutineSuspendExpr * E)3715ffd83dbSDimitry Andric ExprDependence clang::computeDependence(CoroutineSuspendExpr *E) {
3725ffd83dbSDimitry Andric   if (auto *Resume = E->getResumeExpr())
3735ffd83dbSDimitry Andric     return (Resume->getDependence() &
3745ffd83dbSDimitry Andric             (ExprDependence::TypeValue | ExprDependence::Error)) |
3755ffd83dbSDimitry Andric            (E->getCommonExpr()->getDependence() & ~ExprDependence::TypeValue);
3765ffd83dbSDimitry Andric   return E->getCommonExpr()->getDependence() |
3775ffd83dbSDimitry Andric          ExprDependence::TypeValueInstantiation;
3785ffd83dbSDimitry Andric }
3795ffd83dbSDimitry Andric 
computeDependence(DependentCoawaitExpr * E)3805ffd83dbSDimitry Andric ExprDependence clang::computeDependence(DependentCoawaitExpr *E) {
3815ffd83dbSDimitry Andric   return E->getOperand()->getDependence() |
3825ffd83dbSDimitry Andric          ExprDependence::TypeValueInstantiation;
3835ffd83dbSDimitry Andric }
3845ffd83dbSDimitry Andric 
computeDependence(ObjCBoxedExpr * E)3855ffd83dbSDimitry Andric ExprDependence clang::computeDependence(ObjCBoxedExpr *E) {
3865ffd83dbSDimitry Andric   return E->getSubExpr()->getDependence();
3875ffd83dbSDimitry Andric }
3885ffd83dbSDimitry Andric 
computeDependence(ObjCEncodeExpr * E)3895ffd83dbSDimitry Andric ExprDependence clang::computeDependence(ObjCEncodeExpr *E) {
3903b7f365eSDimitry Andric   return toExprDependenceAsWritten(E->getEncodedType()->getDependence());
3915ffd83dbSDimitry Andric }
3925ffd83dbSDimitry Andric 
computeDependence(ObjCIvarRefExpr * E)3935ffd83dbSDimitry Andric ExprDependence clang::computeDependence(ObjCIvarRefExpr *E) {
3945ffd83dbSDimitry Andric   return turnTypeToValueDependence(E->getBase()->getDependence());
3955ffd83dbSDimitry Andric }
3965ffd83dbSDimitry Andric 
computeDependence(ObjCPropertyRefExpr * E)3975ffd83dbSDimitry Andric ExprDependence clang::computeDependence(ObjCPropertyRefExpr *E) {
3985ffd83dbSDimitry Andric   if (E->isObjectReceiver())
3995ffd83dbSDimitry Andric     return E->getBase()->getDependence() & ~ExprDependence::Type;
4005ffd83dbSDimitry Andric   if (E->isSuperReceiver())
4013b7f365eSDimitry Andric     return toExprDependenceForImpliedType(
4023b7f365eSDimitry Andric                E->getSuperReceiverType()->getDependence()) &
4035ffd83dbSDimitry Andric            ~ExprDependence::TypeValue;
4045ffd83dbSDimitry Andric   assert(E->isClassReceiver());
4055ffd83dbSDimitry Andric   return ExprDependence::None;
4065ffd83dbSDimitry Andric }
4075ffd83dbSDimitry Andric 
computeDependence(ObjCSubscriptRefExpr * E)4085ffd83dbSDimitry Andric ExprDependence clang::computeDependence(ObjCSubscriptRefExpr *E) {
4095ffd83dbSDimitry Andric   return E->getBaseExpr()->getDependence() | E->getKeyExpr()->getDependence();
4105ffd83dbSDimitry Andric }
4115ffd83dbSDimitry Andric 
computeDependence(ObjCIsaExpr * E)4125ffd83dbSDimitry Andric ExprDependence clang::computeDependence(ObjCIsaExpr *E) {
4135ffd83dbSDimitry Andric   return E->getBase()->getDependence() & ~ExprDependence::Type &
4145ffd83dbSDimitry Andric          ~ExprDependence::UnexpandedPack;
4155ffd83dbSDimitry Andric }
4165ffd83dbSDimitry Andric 
computeDependence(ObjCIndirectCopyRestoreExpr * E)4175ffd83dbSDimitry Andric ExprDependence clang::computeDependence(ObjCIndirectCopyRestoreExpr *E) {
4185ffd83dbSDimitry Andric   return E->getSubExpr()->getDependence();
4195ffd83dbSDimitry Andric }
4205ffd83dbSDimitry Andric 
computeDependence(OMPArraySectionExpr * E)4215ffd83dbSDimitry Andric ExprDependence clang::computeDependence(OMPArraySectionExpr *E) {
4225ffd83dbSDimitry Andric   auto D = E->getBase()->getDependence();
4235ffd83dbSDimitry Andric   if (auto *LB = E->getLowerBound())
4245ffd83dbSDimitry Andric     D |= LB->getDependence();
4255ffd83dbSDimitry Andric   if (auto *Len = E->getLength())
4265ffd83dbSDimitry Andric     D |= Len->getDependence();
4275ffd83dbSDimitry Andric   return D;
4285ffd83dbSDimitry Andric }
4295ffd83dbSDimitry Andric 
computeDependence(OMPArrayShapingExpr * E)4305ffd83dbSDimitry Andric ExprDependence clang::computeDependence(OMPArrayShapingExpr *E) {
4313b7f365eSDimitry Andric   auto D = E->getBase()->getDependence();
4325ffd83dbSDimitry Andric   for (Expr *Dim: E->getDimensions())
4335ffd83dbSDimitry Andric     if (Dim)
4343b7f365eSDimitry Andric       D |= turnValueToTypeDependence(Dim->getDependence());
4355ffd83dbSDimitry Andric   return D;
4365ffd83dbSDimitry Andric }
4375ffd83dbSDimitry Andric 
computeDependence(OMPIteratorExpr * E)4385ffd83dbSDimitry Andric ExprDependence clang::computeDependence(OMPIteratorExpr *E) {
4393b7f365eSDimitry Andric   auto D = toExprDependenceForImpliedType(E->getType()->getDependence());
4405ffd83dbSDimitry Andric   for (unsigned I = 0, End = E->numOfIterators(); I < End; ++I) {
4413b7f365eSDimitry Andric     if (auto *DD = cast_or_null<DeclaratorDecl>(E->getIteratorDecl(I))) {
4423b7f365eSDimitry Andric       // If the type is omitted, it's 'int', and is not dependent in any way.
4433b7f365eSDimitry Andric       if (auto *TSI = DD->getTypeSourceInfo()) {
4443b7f365eSDimitry Andric         D |= toExprDependenceAsWritten(TSI->getType()->getDependence());
4453b7f365eSDimitry Andric       }
4463b7f365eSDimitry Andric     }
4475ffd83dbSDimitry Andric     OMPIteratorExpr::IteratorRange IR = E->getIteratorRange(I);
4485ffd83dbSDimitry Andric     if (Expr *BE = IR.Begin)
4495ffd83dbSDimitry Andric       D |= BE->getDependence();
4505ffd83dbSDimitry Andric     if (Expr *EE = IR.End)
4515ffd83dbSDimitry Andric       D |= EE->getDependence();
4525ffd83dbSDimitry Andric     if (Expr *SE = IR.Step)
4535ffd83dbSDimitry Andric       D |= SE->getDependence();
4545ffd83dbSDimitry Andric   }
4555ffd83dbSDimitry Andric   return D;
4565ffd83dbSDimitry Andric }
4575ffd83dbSDimitry Andric 
4585ffd83dbSDimitry Andric /// Compute the type-, value-, and instantiation-dependence of a
4595ffd83dbSDimitry Andric /// declaration reference
4605ffd83dbSDimitry Andric /// based on the declaration being referenced.
computeDependence(DeclRefExpr * E,const ASTContext & Ctx)4615ffd83dbSDimitry Andric ExprDependence clang::computeDependence(DeclRefExpr *E, const ASTContext &Ctx) {
4625ffd83dbSDimitry Andric   auto Deps = ExprDependence::None;
4635ffd83dbSDimitry Andric 
4645ffd83dbSDimitry Andric   if (auto *NNS = E->getQualifier())
4655ffd83dbSDimitry Andric     Deps |= toExprDependence(NNS->getDependence() &
4665ffd83dbSDimitry Andric                              ~NestedNameSpecifierDependence::Dependent);
4675ffd83dbSDimitry Andric 
4685ffd83dbSDimitry Andric   if (auto *FirstArg = E->getTemplateArgs()) {
4695ffd83dbSDimitry Andric     unsigned NumArgs = E->getNumTemplateArgs();
4705ffd83dbSDimitry Andric     for (auto *Arg = FirstArg, *End = FirstArg + NumArgs; Arg < End; ++Arg)
4715ffd83dbSDimitry Andric       Deps |= toExprDependence(Arg->getArgument().getDependence());
4725ffd83dbSDimitry Andric   }
4735ffd83dbSDimitry Andric 
4745ffd83dbSDimitry Andric   auto *Decl = E->getDecl();
4755ffd83dbSDimitry Andric   auto Type = E->getType();
4765ffd83dbSDimitry Andric 
4775ffd83dbSDimitry Andric   if (Decl->isParameterPack())
4785ffd83dbSDimitry Andric     Deps |= ExprDependence::UnexpandedPack;
4793b7f365eSDimitry Andric   Deps |= toExprDependenceForImpliedType(Type->getDependence()) &
4803b7f365eSDimitry Andric           ExprDependence::Error;
4815ffd83dbSDimitry Andric 
482e8d8bef9SDimitry Andric   // C++ [temp.dep.expr]p3:
4835ffd83dbSDimitry Andric   //   An id-expression is type-dependent if it contains:
4845ffd83dbSDimitry Andric 
485e8d8bef9SDimitry Andric   //    - an identifier associated by name lookup with one or more declarations
486e8d8bef9SDimitry Andric   //      declared with a dependent type
4875f757f3fSDimitry Andric   //    - an identifier associated by name lookup with an entity captured by
4885f757f3fSDimitry Andric   //    copy ([expr.prim.lambda.capture])
4895f757f3fSDimitry Andric   //      in a lambda-expression that has an explicit object parameter whose
4905f757f3fSDimitry Andric   //      type is dependent ([dcl.fct]),
491e8d8bef9SDimitry Andric   //
492e8d8bef9SDimitry Andric   // [The "or more" case is not modeled as a DeclRefExpr. There are a bunch
493e8d8bef9SDimitry Andric   // more bullets here that we handle by treating the declaration as having a
494e8d8bef9SDimitry Andric   // dependent type if they involve a placeholder type that can't be deduced.]
4955ffd83dbSDimitry Andric   if (Type->isDependentType())
4968d0cab88SDimitry Andric     Deps |= ExprDependence::TypeValueInstantiation;
4975ffd83dbSDimitry Andric   else if (Type->isInstantiationDependentType())
4985ffd83dbSDimitry Andric     Deps |= ExprDependence::Instantiation;
4995ffd83dbSDimitry Andric 
5005f757f3fSDimitry Andric   //    - an identifier associated by name lookup with an entity captured by
5015f757f3fSDimitry Andric   //    copy ([expr.prim.lambda.capture])
5025f757f3fSDimitry Andric   if (E->isCapturedByCopyInLambdaWithExplicitObjectParameter())
5035f757f3fSDimitry Andric     Deps |= ExprDependence::Type;
5045f757f3fSDimitry Andric 
505e8d8bef9SDimitry Andric   //    - a conversion-function-id that specifies a dependent type
5065ffd83dbSDimitry Andric   if (Decl->getDeclName().getNameKind() ==
5075ffd83dbSDimitry Andric       DeclarationName::CXXConversionFunctionName) {
5085ffd83dbSDimitry Andric     QualType T = Decl->getDeclName().getCXXNameType();
5095ffd83dbSDimitry Andric     if (T->isDependentType())
5105ffd83dbSDimitry Andric       return Deps | ExprDependence::TypeValueInstantiation;
5115ffd83dbSDimitry Andric 
5125ffd83dbSDimitry Andric     if (T->isInstantiationDependentType())
5135ffd83dbSDimitry Andric       Deps |= ExprDependence::Instantiation;
5145ffd83dbSDimitry Andric   }
5155ffd83dbSDimitry Andric 
516e8d8bef9SDimitry Andric   //   - a template-id that is dependent,
517e8d8bef9SDimitry Andric   //   - a nested-name-specifier or a qualified-id that names a member of an
518e8d8bef9SDimitry Andric   //     unknown specialization
519e8d8bef9SDimitry Andric   //   [These are not modeled as DeclRefExprs.]
520e8d8bef9SDimitry Andric 
521e8d8bef9SDimitry Andric   //   or if it names a dependent member of the current instantiation that is a
522e8d8bef9SDimitry Andric   //   static data member of type "array of unknown bound of T" for some T
523e8d8bef9SDimitry Andric   //   [handled below].
524e8d8bef9SDimitry Andric 
525e8d8bef9SDimitry Andric   // C++ [temp.dep.constexpr]p2:
526e8d8bef9SDimitry Andric   //  An id-expression is value-dependent if:
527e8d8bef9SDimitry Andric 
528e8d8bef9SDimitry Andric   //    - it is type-dependent [handled above]
529e8d8bef9SDimitry Andric 
530e8d8bef9SDimitry Andric   //    - it is the name of a non-type template parameter,
5315ffd83dbSDimitry Andric   if (isa<NonTypeTemplateParmDecl>(Decl))
5325ffd83dbSDimitry Andric     return Deps | ExprDependence::ValueInstantiation;
5335ffd83dbSDimitry Andric 
534e8d8bef9SDimitry Andric   //   - it names a potentially-constant variable that is initialized with an
535e8d8bef9SDimitry Andric   //     expression that is value-dependent
536e8d8bef9SDimitry Andric   if (const auto *Var = dyn_cast<VarDecl>(Decl)) {
537e8d8bef9SDimitry Andric     if (const Expr *Init = Var->getAnyInitializer()) {
538e8d8bef9SDimitry Andric       if (Init->containsErrors())
539e8d8bef9SDimitry Andric         Deps |= ExprDependence::Error;
5408d0cab88SDimitry Andric 
5418d0cab88SDimitry Andric       if (Var->mightBeUsableInConstantExpressions(Ctx) &&
5428d0cab88SDimitry Andric           Init->isValueDependent())
5438d0cab88SDimitry Andric         Deps |= ExprDependence::ValueInstantiation;
5445ffd83dbSDimitry Andric     }
5455ffd83dbSDimitry Andric 
546e8d8bef9SDimitry Andric     // - it names a static data member that is a dependent member of the
547e8d8bef9SDimitry Andric     //   current instantiation and is not initialized in a member-declarator,
5485ffd83dbSDimitry Andric     if (Var->isStaticDataMember() &&
549e8d8bef9SDimitry Andric         Var->getDeclContext()->isDependentContext() &&
550e8d8bef9SDimitry Andric         !Var->getFirstDecl()->hasInit()) {
551e8d8bef9SDimitry Andric       const VarDecl *First = Var->getFirstDecl();
552e8d8bef9SDimitry Andric       TypeSourceInfo *TInfo = First->getTypeSourceInfo();
553e8d8bef9SDimitry Andric       if (TInfo->getType()->isIncompleteArrayType()) {
554e8d8bef9SDimitry Andric         Deps |= ExprDependence::TypeValueInstantiation;
555e8d8bef9SDimitry Andric       } else if (!First->hasInit()) {
5565ffd83dbSDimitry Andric         Deps |= ExprDependence::ValueInstantiation;
557e8d8bef9SDimitry Andric       }
5585ffd83dbSDimitry Andric     }
5595ffd83dbSDimitry Andric 
5605ffd83dbSDimitry Andric     return Deps;
5615ffd83dbSDimitry Andric   }
5625ffd83dbSDimitry Andric 
563e8d8bef9SDimitry Andric   //   - it names a static member function that is a dependent member of the
564e8d8bef9SDimitry Andric   //     current instantiation
565e8d8bef9SDimitry Andric   //
566e8d8bef9SDimitry Andric   // FIXME: It's unclear that the restriction to static members here has any
567e8d8bef9SDimitry Andric   // effect: any use of a non-static member function name requires either
568e8d8bef9SDimitry Andric   // forming a pointer-to-member or providing an object parameter, either of
569e8d8bef9SDimitry Andric   // which makes the overall expression value-dependent.
570e8d8bef9SDimitry Andric   if (auto *MD = dyn_cast<CXXMethodDecl>(Decl)) {
571e8d8bef9SDimitry Andric     if (MD->isStatic() && Decl->getDeclContext()->isDependentContext())
5725ffd83dbSDimitry Andric       Deps |= ExprDependence::ValueInstantiation;
573e8d8bef9SDimitry Andric   }
574e8d8bef9SDimitry Andric 
5755ffd83dbSDimitry Andric   return Deps;
5765ffd83dbSDimitry Andric }
5775ffd83dbSDimitry Andric 
computeDependence(RecoveryExpr * E)5785ffd83dbSDimitry Andric ExprDependence clang::computeDependence(RecoveryExpr *E) {
5795ffd83dbSDimitry Andric   // RecoveryExpr is
5805ffd83dbSDimitry Andric   //   - always value-dependent, and therefore instantiation dependent
5815ffd83dbSDimitry Andric   //   - contains errors (ExprDependence::Error), by definition
5825ffd83dbSDimitry Andric   //   - type-dependent if we don't know the type (fallback to an opaque
5835ffd83dbSDimitry Andric   //     dependent type), or the type is known and dependent, or it has
5845ffd83dbSDimitry Andric   //     type-dependent subexpressions.
585bdd1243dSDimitry Andric   auto D = toExprDependenceAsWritten(E->getType()->getDependence()) |
586e8d8bef9SDimitry Andric            ExprDependence::ErrorDependent;
5875ffd83dbSDimitry Andric   // FIXME: remove the type-dependent bit from subexpressions, if the
5885ffd83dbSDimitry Andric   // RecoveryExpr has a non-dependent type.
5895ffd83dbSDimitry Andric   for (auto *S : E->subExpressions())
5905ffd83dbSDimitry Andric     D |= S->getDependence();
5915ffd83dbSDimitry Andric   return D;
5925ffd83dbSDimitry Andric }
5935ffd83dbSDimitry Andric 
computeDependence(SYCLUniqueStableNameExpr * E)594fe6060f1SDimitry Andric ExprDependence clang::computeDependence(SYCLUniqueStableNameExpr *E) {
5953b7f365eSDimitry Andric   return toExprDependenceAsWritten(
5963b7f365eSDimitry Andric       E->getTypeSourceInfo()->getType()->getDependence());
597fe6060f1SDimitry Andric }
598fe6060f1SDimitry Andric 
computeDependence(PredefinedExpr * E)5995ffd83dbSDimitry Andric ExprDependence clang::computeDependence(PredefinedExpr *E) {
6003b7f365eSDimitry Andric   return toExprDependenceForImpliedType(E->getType()->getDependence());
6015ffd83dbSDimitry Andric }
6025ffd83dbSDimitry Andric 
computeDependence(CallExpr * E,llvm::ArrayRef<Expr * > PreArgs)6035ffd83dbSDimitry Andric ExprDependence clang::computeDependence(CallExpr *E,
6045ffd83dbSDimitry Andric                                         llvm::ArrayRef<Expr *> PreArgs) {
6055ffd83dbSDimitry Andric   auto D = E->getCallee()->getDependence();
6061db9f3b2SDimitry Andric   if (E->getType()->isDependentType())
6071db9f3b2SDimitry Andric     D |= ExprDependence::Type;
608bdd1243dSDimitry Andric   for (auto *A : llvm::ArrayRef(E->getArgs(), E->getNumArgs())) {
6095ffd83dbSDimitry Andric     if (A)
6105ffd83dbSDimitry Andric       D |= A->getDependence();
6115ffd83dbSDimitry Andric   }
6125ffd83dbSDimitry Andric   for (auto *A : PreArgs)
6135ffd83dbSDimitry Andric     D |= A->getDependence();
6145ffd83dbSDimitry Andric   return D;
6155ffd83dbSDimitry Andric }
6165ffd83dbSDimitry Andric 
computeDependence(OffsetOfExpr * E)6175ffd83dbSDimitry Andric ExprDependence clang::computeDependence(OffsetOfExpr *E) {
6183b7f365eSDimitry Andric   auto D = turnTypeToValueDependence(toExprDependenceAsWritten(
6193b7f365eSDimitry Andric       E->getTypeSourceInfo()->getType()->getDependence()));
6205ffd83dbSDimitry Andric   for (unsigned I = 0, N = E->getNumExpressions(); I < N; ++I)
6215ffd83dbSDimitry Andric     D |= turnTypeToValueDependence(E->getIndexExpr(I)->getDependence());
6225ffd83dbSDimitry Andric   return D;
6235ffd83dbSDimitry Andric }
6245ffd83dbSDimitry Andric 
getDependenceInExpr(DeclarationNameInfo Name)62506c3fb27SDimitry Andric static inline ExprDependence getDependenceInExpr(DeclarationNameInfo Name) {
62606c3fb27SDimitry Andric   auto D = ExprDependence::None;
62706c3fb27SDimitry Andric   if (Name.isInstantiationDependent())
62806c3fb27SDimitry Andric     D |= ExprDependence::Instantiation;
62906c3fb27SDimitry Andric   if (Name.containsUnexpandedParameterPack())
63006c3fb27SDimitry Andric     D |= ExprDependence::UnexpandedPack;
63106c3fb27SDimitry Andric   return D;
63206c3fb27SDimitry Andric }
63306c3fb27SDimitry Andric 
computeDependence(MemberExpr * E)6345ffd83dbSDimitry Andric ExprDependence clang::computeDependence(MemberExpr *E) {
6355ffd83dbSDimitry Andric   auto D = E->getBase()->getDependence();
63606c3fb27SDimitry Andric   D |= getDependenceInExpr(E->getMemberNameInfo());
63706c3fb27SDimitry Andric 
63806c3fb27SDimitry Andric   if (auto *NNS = E->getQualifier())
63906c3fb27SDimitry Andric     D |= toExprDependence(NNS->getDependence() &
64006c3fb27SDimitry Andric                           ~NestedNameSpecifierDependence::Dependent);
64106c3fb27SDimitry Andric 
64206c3fb27SDimitry Andric   auto *MemberDecl = E->getMemberDecl();
6435ffd83dbSDimitry Andric   if (FieldDecl *FD = dyn_cast<FieldDecl>(MemberDecl)) {
6445ffd83dbSDimitry Andric     DeclContext *DC = MemberDecl->getDeclContext();
6455ffd83dbSDimitry Andric     // dyn_cast_or_null is used to handle objC variables which do not
6465ffd83dbSDimitry Andric     // have a declaration context.
6475ffd83dbSDimitry Andric     CXXRecordDecl *RD = dyn_cast_or_null<CXXRecordDecl>(DC);
6485ffd83dbSDimitry Andric     if (RD && RD->isDependentContext() && RD->isCurrentInstantiation(DC)) {
6495ffd83dbSDimitry Andric       if (!E->getType()->isDependentType())
6505ffd83dbSDimitry Andric         D &= ~ExprDependence::Type;
6515ffd83dbSDimitry Andric     }
6525ffd83dbSDimitry Andric 
6535ffd83dbSDimitry Andric     // Bitfield with value-dependent width is type-dependent.
6545ffd83dbSDimitry Andric     if (FD && FD->isBitField() && FD->getBitWidth()->isValueDependent()) {
6555ffd83dbSDimitry Andric       D |= ExprDependence::Type;
6565ffd83dbSDimitry Andric     }
6575ffd83dbSDimitry Andric   }
6585ffd83dbSDimitry Andric   // FIXME: move remaining dependence computation from MemberExpr::Create()
6595ffd83dbSDimitry Andric   return D;
6605ffd83dbSDimitry Andric }
6615ffd83dbSDimitry Andric 
computeDependence(InitListExpr * E)6625ffd83dbSDimitry Andric ExprDependence clang::computeDependence(InitListExpr *E) {
6635ffd83dbSDimitry Andric   auto D = ExprDependence::None;
6645ffd83dbSDimitry Andric   for (auto *A : E->inits())
6655ffd83dbSDimitry Andric     D |= A->getDependence();
6665ffd83dbSDimitry Andric   return D;
6675ffd83dbSDimitry Andric }
6685ffd83dbSDimitry Andric 
computeDependence(ShuffleVectorExpr * E)6695ffd83dbSDimitry Andric ExprDependence clang::computeDependence(ShuffleVectorExpr *E) {
6703b7f365eSDimitry Andric   auto D = toExprDependenceForImpliedType(E->getType()->getDependence());
671bdd1243dSDimitry Andric   for (auto *C : llvm::ArrayRef(E->getSubExprs(), E->getNumSubExprs()))
6725ffd83dbSDimitry Andric     D |= C->getDependence();
6735ffd83dbSDimitry Andric   return D;
6745ffd83dbSDimitry Andric }
6755ffd83dbSDimitry Andric 
computeDependence(GenericSelectionExpr * E,bool ContainsUnexpandedPack)6765ffd83dbSDimitry Andric ExprDependence clang::computeDependence(GenericSelectionExpr *E,
6775ffd83dbSDimitry Andric                                         bool ContainsUnexpandedPack) {
6785ffd83dbSDimitry Andric   auto D = ContainsUnexpandedPack ? ExprDependence::UnexpandedPack
6795ffd83dbSDimitry Andric                                   : ExprDependence::None;
6805ffd83dbSDimitry Andric   for (auto *AE : E->getAssocExprs())
6815ffd83dbSDimitry Andric     D |= AE->getDependence() & ExprDependence::Error;
68206c3fb27SDimitry Andric 
68306c3fb27SDimitry Andric   if (E->isExprPredicate())
6845ffd83dbSDimitry Andric     D |= E->getControllingExpr()->getDependence() & ExprDependence::Error;
68506c3fb27SDimitry Andric   else
68606c3fb27SDimitry Andric     D |= toExprDependenceAsWritten(
68706c3fb27SDimitry Andric         E->getControllingType()->getType()->getDependence());
6885ffd83dbSDimitry Andric 
6895ffd83dbSDimitry Andric   if (E->isResultDependent())
6905ffd83dbSDimitry Andric     return D | ExprDependence::TypeValueInstantiation;
6915ffd83dbSDimitry Andric   return D | (E->getResultExpr()->getDependence() &
6925ffd83dbSDimitry Andric               ~ExprDependence::UnexpandedPack);
6935ffd83dbSDimitry Andric }
6945ffd83dbSDimitry Andric 
computeDependence(DesignatedInitExpr * E)6955ffd83dbSDimitry Andric ExprDependence clang::computeDependence(DesignatedInitExpr *E) {
6965ffd83dbSDimitry Andric   auto Deps = E->getInit()->getDependence();
69706c3fb27SDimitry Andric   for (const auto &D : E->designators()) {
6985ffd83dbSDimitry Andric     auto DesignatorDeps = ExprDependence::None;
6995ffd83dbSDimitry Andric     if (D.isArrayDesignator())
7005ffd83dbSDimitry Andric       DesignatorDeps |= E->getArrayIndex(D)->getDependence();
7015ffd83dbSDimitry Andric     else if (D.isArrayRangeDesignator())
7025ffd83dbSDimitry Andric       DesignatorDeps |= E->getArrayRangeStart(D)->getDependence() |
7035ffd83dbSDimitry Andric                         E->getArrayRangeEnd(D)->getDependence();
7045ffd83dbSDimitry Andric     Deps |= DesignatorDeps;
7055ffd83dbSDimitry Andric     if (DesignatorDeps & ExprDependence::TypeValue)
7065ffd83dbSDimitry Andric       Deps |= ExprDependence::TypeValueInstantiation;
7075ffd83dbSDimitry Andric   }
7085ffd83dbSDimitry Andric   return Deps;
7095ffd83dbSDimitry Andric }
7105ffd83dbSDimitry Andric 
computeDependence(PseudoObjectExpr * O)7115ffd83dbSDimitry Andric ExprDependence clang::computeDependence(PseudoObjectExpr *O) {
7125ffd83dbSDimitry Andric   auto D = O->getSyntacticForm()->getDependence();
7135ffd83dbSDimitry Andric   for (auto *E : O->semantics())
7145ffd83dbSDimitry Andric     D |= E->getDependence();
7155ffd83dbSDimitry Andric   return D;
7165ffd83dbSDimitry Andric }
7175ffd83dbSDimitry Andric 
computeDependence(AtomicExpr * A)7185ffd83dbSDimitry Andric ExprDependence clang::computeDependence(AtomicExpr *A) {
7195ffd83dbSDimitry Andric   auto D = ExprDependence::None;
720bdd1243dSDimitry Andric   for (auto *E : llvm::ArrayRef(A->getSubExprs(), A->getNumSubExprs()))
7215ffd83dbSDimitry Andric     D |= E->getDependence();
7225ffd83dbSDimitry Andric   return D;
7235ffd83dbSDimitry Andric }
7245ffd83dbSDimitry Andric 
computeDependence(CXXNewExpr * E)7255ffd83dbSDimitry Andric ExprDependence clang::computeDependence(CXXNewExpr *E) {
7263b7f365eSDimitry Andric   auto D = toExprDependenceAsWritten(
7273b7f365eSDimitry Andric       E->getAllocatedTypeSourceInfo()->getType()->getDependence());
7283b7f365eSDimitry Andric   D |= toExprDependenceForImpliedType(E->getAllocatedType()->getDependence());
7295ffd83dbSDimitry Andric   auto Size = E->getArraySize();
73081ad6265SDimitry Andric   if (Size && *Size)
7315ffd83dbSDimitry Andric     D |= turnTypeToValueDependence((*Size)->getDependence());
7325ffd83dbSDimitry Andric   if (auto *I = E->getInitializer())
7335ffd83dbSDimitry Andric     D |= turnTypeToValueDependence(I->getDependence());
7345ffd83dbSDimitry Andric   for (auto *A : E->placement_arguments())
7355ffd83dbSDimitry Andric     D |= turnTypeToValueDependence(A->getDependence());
7365ffd83dbSDimitry Andric   return D;
7375ffd83dbSDimitry Andric }
7385ffd83dbSDimitry Andric 
computeDependence(CXXPseudoDestructorExpr * E)7395ffd83dbSDimitry Andric ExprDependence clang::computeDependence(CXXPseudoDestructorExpr *E) {
7405ffd83dbSDimitry Andric   auto D = E->getBase()->getDependence();
7413b7f365eSDimitry Andric   if (auto *TSI = E->getDestroyedTypeInfo())
7423b7f365eSDimitry Andric     D |= toExprDependenceAsWritten(TSI->getType()->getDependence());
7435ffd83dbSDimitry Andric   if (auto *ST = E->getScopeTypeInfo())
7445ffd83dbSDimitry Andric     D |= turnTypeToValueDependence(
7453b7f365eSDimitry Andric         toExprDependenceAsWritten(ST->getType()->getDependence()));
7465ffd83dbSDimitry Andric   if (auto *Q = E->getQualifier())
7475ffd83dbSDimitry Andric     D |= toExprDependence(Q->getDependence() &
7485ffd83dbSDimitry Andric                           ~NestedNameSpecifierDependence::Dependent);
7495ffd83dbSDimitry Andric   return D;
7505ffd83dbSDimitry Andric }
7515ffd83dbSDimitry Andric 
7525ffd83dbSDimitry Andric ExprDependence
computeDependence(OverloadExpr * E,bool KnownDependent,bool KnownInstantiationDependent,bool KnownContainsUnexpandedParameterPack)7535ffd83dbSDimitry Andric clang::computeDependence(OverloadExpr *E, bool KnownDependent,
7545ffd83dbSDimitry Andric                          bool KnownInstantiationDependent,
7555ffd83dbSDimitry Andric                          bool KnownContainsUnexpandedParameterPack) {
7565ffd83dbSDimitry Andric   auto Deps = ExprDependence::None;
7575ffd83dbSDimitry Andric   if (KnownDependent)
7585ffd83dbSDimitry Andric     Deps |= ExprDependence::TypeValue;
7595ffd83dbSDimitry Andric   if (KnownInstantiationDependent)
7605ffd83dbSDimitry Andric     Deps |= ExprDependence::Instantiation;
7615ffd83dbSDimitry Andric   if (KnownContainsUnexpandedParameterPack)
7625ffd83dbSDimitry Andric     Deps |= ExprDependence::UnexpandedPack;
7635ffd83dbSDimitry Andric   Deps |= getDependenceInExpr(E->getNameInfo());
7645ffd83dbSDimitry Andric   if (auto *Q = E->getQualifier())
7655ffd83dbSDimitry Andric     Deps |= toExprDependence(Q->getDependence() &
7665ffd83dbSDimitry Andric                              ~NestedNameSpecifierDependence::Dependent);
7675ffd83dbSDimitry Andric   for (auto *D : E->decls()) {
7685ffd83dbSDimitry Andric     if (D->getDeclContext()->isDependentContext() ||
7695ffd83dbSDimitry Andric         isa<UnresolvedUsingValueDecl>(D))
7705ffd83dbSDimitry Andric       Deps |= ExprDependence::TypeValueInstantiation;
7715ffd83dbSDimitry Andric   }
7725ffd83dbSDimitry Andric   // If we have explicit template arguments, check for dependent
7735ffd83dbSDimitry Andric   // template arguments and whether they contain any unexpanded pack
7745ffd83dbSDimitry Andric   // expansions.
77506c3fb27SDimitry Andric   for (const auto &A : E->template_arguments())
7765ffd83dbSDimitry Andric     Deps |= toExprDependence(A.getArgument().getDependence());
7775ffd83dbSDimitry Andric   return Deps;
7785ffd83dbSDimitry Andric }
7795ffd83dbSDimitry Andric 
computeDependence(DependentScopeDeclRefExpr * E)7805ffd83dbSDimitry Andric ExprDependence clang::computeDependence(DependentScopeDeclRefExpr *E) {
7815ffd83dbSDimitry Andric   auto D = ExprDependence::TypeValue;
7825ffd83dbSDimitry Andric   D |= getDependenceInExpr(E->getNameInfo());
7835ffd83dbSDimitry Andric   if (auto *Q = E->getQualifier())
7845ffd83dbSDimitry Andric     D |= toExprDependence(Q->getDependence());
78506c3fb27SDimitry Andric   for (const auto &A : E->template_arguments())
7865ffd83dbSDimitry Andric     D |= toExprDependence(A.getArgument().getDependence());
7875ffd83dbSDimitry Andric   return D;
7885ffd83dbSDimitry Andric }
7895ffd83dbSDimitry Andric 
computeDependence(CXXConstructExpr * E)7905ffd83dbSDimitry Andric ExprDependence clang::computeDependence(CXXConstructExpr *E) {
7913b7f365eSDimitry Andric   ExprDependence D =
7923b7f365eSDimitry Andric       toExprDependenceForImpliedType(E->getType()->getDependence());
7935ffd83dbSDimitry Andric   for (auto *A : E->arguments())
7945ffd83dbSDimitry Andric     D |= A->getDependence() & ~ExprDependence::Type;
7955ffd83dbSDimitry Andric   return D;
7965ffd83dbSDimitry Andric }
7975ffd83dbSDimitry Andric 
computeDependence(CXXTemporaryObjectExpr * E)7983b7f365eSDimitry Andric ExprDependence clang::computeDependence(CXXTemporaryObjectExpr *E) {
7993b7f365eSDimitry Andric   CXXConstructExpr *BaseE = E;
8003b7f365eSDimitry Andric   return toExprDependenceAsWritten(
8013b7f365eSDimitry Andric              E->getTypeSourceInfo()->getType()->getDependence()) |
8023b7f365eSDimitry Andric          computeDependence(BaseE);
8033b7f365eSDimitry Andric }
8043b7f365eSDimitry Andric 
computeDependence(CXXDefaultInitExpr * E)805e8d8bef9SDimitry Andric ExprDependence clang::computeDependence(CXXDefaultInitExpr *E) {
806e8d8bef9SDimitry Andric   return E->getExpr()->getDependence();
807e8d8bef9SDimitry Andric }
808e8d8bef9SDimitry Andric 
computeDependence(CXXDefaultArgExpr * E)809fe6060f1SDimitry Andric ExprDependence clang::computeDependence(CXXDefaultArgExpr *E) {
810fe6060f1SDimitry Andric   return E->getExpr()->getDependence();
811fe6060f1SDimitry Andric }
812fe6060f1SDimitry Andric 
computeDependence(LambdaExpr * E,bool ContainsUnexpandedParameterPack)8135ffd83dbSDimitry Andric ExprDependence clang::computeDependence(LambdaExpr *E,
8145ffd83dbSDimitry Andric                                         bool ContainsUnexpandedParameterPack) {
8153b7f365eSDimitry Andric   auto D = toExprDependenceForImpliedType(E->getType()->getDependence());
8165ffd83dbSDimitry Andric   if (ContainsUnexpandedParameterPack)
8175ffd83dbSDimitry Andric     D |= ExprDependence::UnexpandedPack;
8185ffd83dbSDimitry Andric   return D;
8195ffd83dbSDimitry Andric }
8205ffd83dbSDimitry Andric 
computeDependence(CXXUnresolvedConstructExpr * E)8215ffd83dbSDimitry Andric ExprDependence clang::computeDependence(CXXUnresolvedConstructExpr *E) {
8225ffd83dbSDimitry Andric   auto D = ExprDependence::ValueInstantiation;
8233b7f365eSDimitry Andric   D |= toExprDependenceAsWritten(E->getTypeAsWritten()->getDependence());
8243b7f365eSDimitry Andric   D |= toExprDependenceForImpliedType(E->getType()->getDependence());
8255ffd83dbSDimitry Andric   for (auto *A : E->arguments())
8265ffd83dbSDimitry Andric     D |= A->getDependence() &
8275ffd83dbSDimitry Andric          (ExprDependence::UnexpandedPack | ExprDependence::Error);
8285ffd83dbSDimitry Andric   return D;
8295ffd83dbSDimitry Andric }
8305ffd83dbSDimitry Andric 
computeDependence(CXXDependentScopeMemberExpr * E)8315ffd83dbSDimitry Andric ExprDependence clang::computeDependence(CXXDependentScopeMemberExpr *E) {
8325ffd83dbSDimitry Andric   auto D = ExprDependence::TypeValueInstantiation;
8335ffd83dbSDimitry Andric   if (!E->isImplicitAccess())
8345ffd83dbSDimitry Andric     D |= E->getBase()->getDependence();
8355ffd83dbSDimitry Andric   if (auto *Q = E->getQualifier())
8365ffd83dbSDimitry Andric     D |= toExprDependence(Q->getDependence());
8375ffd83dbSDimitry Andric   D |= getDependenceInExpr(E->getMemberNameInfo());
83806c3fb27SDimitry Andric   for (const auto &A : E->template_arguments())
8395ffd83dbSDimitry Andric     D |= toExprDependence(A.getArgument().getDependence());
8405ffd83dbSDimitry Andric   return D;
8415ffd83dbSDimitry Andric }
8425ffd83dbSDimitry Andric 
computeDependence(MaterializeTemporaryExpr * E)8435ffd83dbSDimitry Andric ExprDependence clang::computeDependence(MaterializeTemporaryExpr *E) {
8445ffd83dbSDimitry Andric   return E->getSubExpr()->getDependence();
8455ffd83dbSDimitry Andric }
8465ffd83dbSDimitry Andric 
computeDependence(CXXFoldExpr * E)8475ffd83dbSDimitry Andric ExprDependence clang::computeDependence(CXXFoldExpr *E) {
8485ffd83dbSDimitry Andric   auto D = ExprDependence::TypeValueInstantiation;
8495ffd83dbSDimitry Andric   for (const auto *C : {E->getLHS(), E->getRHS()}) {
8505ffd83dbSDimitry Andric     if (C)
8515ffd83dbSDimitry Andric       D |= C->getDependence() & ~ExprDependence::UnexpandedPack;
8525ffd83dbSDimitry Andric   }
8535ffd83dbSDimitry Andric   return D;
8545ffd83dbSDimitry Andric }
8555ffd83dbSDimitry Andric 
computeDependence(CXXParenListInitExpr * E)856bdd1243dSDimitry Andric ExprDependence clang::computeDependence(CXXParenListInitExpr *E) {
857bdd1243dSDimitry Andric   auto D = ExprDependence::None;
858bdd1243dSDimitry Andric   for (const auto *A : E->getInitExprs())
859bdd1243dSDimitry Andric     D |= A->getDependence();
860bdd1243dSDimitry Andric   return D;
861bdd1243dSDimitry Andric }
862bdd1243dSDimitry Andric 
computeDependence(TypeTraitExpr * E)8635ffd83dbSDimitry Andric ExprDependence clang::computeDependence(TypeTraitExpr *E) {
8645ffd83dbSDimitry Andric   auto D = ExprDependence::None;
8655ffd83dbSDimitry Andric   for (const auto *A : E->getArgs())
8663b7f365eSDimitry Andric     D |= toExprDependenceAsWritten(A->getType()->getDependence()) &
8673b7f365eSDimitry Andric          ~ExprDependence::Type;
8685ffd83dbSDimitry Andric   return D;
8695ffd83dbSDimitry Andric }
8705ffd83dbSDimitry Andric 
computeDependence(ConceptSpecializationExpr * E,bool ValueDependent)8715ffd83dbSDimitry Andric ExprDependence clang::computeDependence(ConceptSpecializationExpr *E,
8725ffd83dbSDimitry Andric                                         bool ValueDependent) {
8735ffd83dbSDimitry Andric   auto TA = TemplateArgumentDependence::None;
8745ffd83dbSDimitry Andric   const auto InterestingDeps = TemplateArgumentDependence::Instantiation |
8755ffd83dbSDimitry Andric                                TemplateArgumentDependence::UnexpandedPack;
8765ffd83dbSDimitry Andric   for (const TemplateArgumentLoc &ArgLoc :
8775ffd83dbSDimitry Andric        E->getTemplateArgsAsWritten()->arguments()) {
8785ffd83dbSDimitry Andric     TA |= ArgLoc.getArgument().getDependence() & InterestingDeps;
8795ffd83dbSDimitry Andric     if (TA == InterestingDeps)
8805ffd83dbSDimitry Andric       break;
8815ffd83dbSDimitry Andric   }
8825ffd83dbSDimitry Andric 
8835ffd83dbSDimitry Andric   ExprDependence D =
8845ffd83dbSDimitry Andric       ValueDependent ? ExprDependence::Value : ExprDependence::None;
885bdd1243dSDimitry Andric   auto Res = D | toExprDependence(TA);
886bdd1243dSDimitry Andric   if(!ValueDependent && E->getSatisfaction().ContainsErrors)
887bdd1243dSDimitry Andric     Res |= ExprDependence::Error;
888bdd1243dSDimitry Andric   return Res;
8895ffd83dbSDimitry Andric }
8905ffd83dbSDimitry Andric 
computeDependence(ObjCArrayLiteral * E)8915ffd83dbSDimitry Andric ExprDependence clang::computeDependence(ObjCArrayLiteral *E) {
8925ffd83dbSDimitry Andric   auto D = ExprDependence::None;
8935ffd83dbSDimitry Andric   Expr **Elements = E->getElements();
8945ffd83dbSDimitry Andric   for (unsigned I = 0, N = E->getNumElements(); I != N; ++I)
8955ffd83dbSDimitry Andric     D |= turnTypeToValueDependence(Elements[I]->getDependence());
8965ffd83dbSDimitry Andric   return D;
8975ffd83dbSDimitry Andric }
8985ffd83dbSDimitry Andric 
computeDependence(ObjCDictionaryLiteral * E)8995ffd83dbSDimitry Andric ExprDependence clang::computeDependence(ObjCDictionaryLiteral *E) {
9005ffd83dbSDimitry Andric   auto Deps = ExprDependence::None;
9015ffd83dbSDimitry Andric   for (unsigned I = 0, N = E->getNumElements(); I < N; ++I) {
9025ffd83dbSDimitry Andric     auto KV = E->getKeyValueElement(I);
9035ffd83dbSDimitry Andric     auto KVDeps = turnTypeToValueDependence(KV.Key->getDependence() |
9045ffd83dbSDimitry Andric                                             KV.Value->getDependence());
9055ffd83dbSDimitry Andric     if (KV.EllipsisLoc.isValid())
9065ffd83dbSDimitry Andric       KVDeps &= ~ExprDependence::UnexpandedPack;
9075ffd83dbSDimitry Andric     Deps |= KVDeps;
9085ffd83dbSDimitry Andric   }
9095ffd83dbSDimitry Andric   return Deps;
9105ffd83dbSDimitry Andric }
9115ffd83dbSDimitry Andric 
computeDependence(ObjCMessageExpr * E)9125ffd83dbSDimitry Andric ExprDependence clang::computeDependence(ObjCMessageExpr *E) {
9135ffd83dbSDimitry Andric   auto D = ExprDependence::None;
9145ffd83dbSDimitry Andric   if (auto *R = E->getInstanceReceiver())
9155ffd83dbSDimitry Andric     D |= R->getDependence();
9165ffd83dbSDimitry Andric   else
9173b7f365eSDimitry Andric     D |= toExprDependenceForImpliedType(E->getType()->getDependence());
9185ffd83dbSDimitry Andric   for (auto *A : E->arguments())
9195ffd83dbSDimitry Andric     D |= A->getDependence();
9205ffd83dbSDimitry Andric   return D;
9215ffd83dbSDimitry Andric }
922