1 //===--- SemaExpr.cpp - Semantic Analysis for Expressions -----------------===//
2 //
3 //                     The LLVM Compiler Infrastructure
4 //
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
7 //
8 //===----------------------------------------------------------------------===//
9 //
10 //  This file implements semantic analysis for expressions.
11 //
12 //===----------------------------------------------------------------------===//
13 
14 #include "clang/Sema/SemaInternal.h"
15 #include "TreeTransform.h"
16 #include "clang/AST/ASTConsumer.h"
17 #include "clang/AST/ASTContext.h"
18 #include "clang/AST/ASTLambda.h"
19 #include "clang/AST/ASTMutationListener.h"
20 #include "clang/AST/CXXInheritance.h"
21 #include "clang/AST/DeclObjC.h"
22 #include "clang/AST/DeclTemplate.h"
23 #include "clang/AST/EvaluatedExprVisitor.h"
24 #include "clang/AST/Expr.h"
25 #include "clang/AST/ExprCXX.h"
26 #include "clang/AST/ExprObjC.h"
27 #include "clang/AST/RecursiveASTVisitor.h"
28 #include "clang/AST/TypeLoc.h"
29 #include "clang/Basic/PartialDiagnostic.h"
30 #include "clang/Basic/SourceManager.h"
31 #include "clang/Basic/TargetInfo.h"
32 #include "clang/Lex/LiteralSupport.h"
33 #include "clang/Lex/Preprocessor.h"
34 #include "clang/Sema/AnalysisBasedWarnings.h"
35 #include "clang/Sema/DeclSpec.h"
36 #include "clang/Sema/DelayedDiagnostic.h"
37 #include "clang/Sema/Designator.h"
38 #include "clang/Sema/Initialization.h"
39 #include "clang/Sema/Lookup.h"
40 #include "clang/Sema/ParsedTemplate.h"
41 #include "clang/Sema/Scope.h"
42 #include "clang/Sema/ScopeInfo.h"
43 #include "clang/Sema/SemaFixItUtils.h"
44 #include "clang/Sema/Template.h"
45 using namespace clang;
46 using namespace sema;
47 
48 /// \brief Determine whether the use of this declaration is valid, without
49 /// emitting diagnostics.
50 bool Sema::CanUseDecl(NamedDecl *D) {
51   // See if this is an auto-typed variable whose initializer we are parsing.
52   if (ParsingInitForAutoVars.count(D))
53     return false;
54 
55   // See if this is a deleted function.
56   if (FunctionDecl *FD = dyn_cast<FunctionDecl>(D)) {
57     if (FD->isDeleted())
58       return false;
59 
60     // If the function has a deduced return type, and we can't deduce it,
61     // then we can't use it either.
62     if (getLangOpts().CPlusPlus1y && FD->getResultType()->isUndeducedType() &&
63         DeduceReturnType(FD, SourceLocation(), /*Diagnose*/false))
64       return false;
65   }
66 
67   // See if this function is unavailable.
68   if (D->getAvailability() == AR_Unavailable &&
69       cast<Decl>(CurContext)->getAvailability() != AR_Unavailable)
70     return false;
71 
72   return true;
73 }
74 
75 static void DiagnoseUnusedOfDecl(Sema &S, NamedDecl *D, SourceLocation Loc) {
76   // Warn if this is used but marked unused.
77   if (D->hasAttr<UnusedAttr>()) {
78     const Decl *DC = cast<Decl>(S.getCurObjCLexicalContext());
79     if (!DC->hasAttr<UnusedAttr>())
80       S.Diag(Loc, diag::warn_used_but_marked_unused) << D->getDeclName();
81   }
82 }
83 
84 static AvailabilityResult DiagnoseAvailabilityOfDecl(Sema &S,
85                               NamedDecl *D, SourceLocation Loc,
86                               const ObjCInterfaceDecl *UnknownObjCClass) {
87   // See if this declaration is unavailable or deprecated.
88   std::string Message;
89   AvailabilityResult Result = D->getAvailability(&Message);
90   if (const EnumConstantDecl *ECD = dyn_cast<EnumConstantDecl>(D))
91     if (Result == AR_Available) {
92       const DeclContext *DC = ECD->getDeclContext();
93       if (const EnumDecl *TheEnumDecl = dyn_cast<EnumDecl>(DC))
94         Result = TheEnumDecl->getAvailability(&Message);
95     }
96 
97   const ObjCPropertyDecl *ObjCPDecl = 0;
98   if (Result == AR_Deprecated || Result == AR_Unavailable) {
99     if (const ObjCMethodDecl *MD = dyn_cast<ObjCMethodDecl>(D)) {
100       if (const ObjCPropertyDecl *PD = MD->findPropertyDecl()) {
101         AvailabilityResult PDeclResult = PD->getAvailability(0);
102         if (PDeclResult == Result)
103           ObjCPDecl = PD;
104       }
105     }
106   }
107 
108   switch (Result) {
109     case AR_Available:
110     case AR_NotYetIntroduced:
111       break;
112 
113     case AR_Deprecated:
114       if (S.getCurContextAvailability() != AR_Deprecated)
115         S.EmitAvailabilityWarning(Sema::AD_Deprecation,
116                                   D, Message, Loc, UnknownObjCClass, ObjCPDecl);
117       break;
118 
119     case AR_Unavailable:
120       if (S.getCurContextAvailability() != AR_Unavailable)
121         S.EmitAvailabilityWarning(Sema::AD_Unavailable,
122                                   D, Message, Loc, UnknownObjCClass, ObjCPDecl);
123       break;
124 
125     }
126     return Result;
127 }
128 
129 /// \brief Emit a note explaining that this function is deleted.
130 void Sema::NoteDeletedFunction(FunctionDecl *Decl) {
131   assert(Decl->isDeleted());
132 
133   CXXMethodDecl *Method = dyn_cast<CXXMethodDecl>(Decl);
134 
135   if (Method && Method->isDeleted() && Method->isDefaulted()) {
136     // If the method was explicitly defaulted, point at that declaration.
137     if (!Method->isImplicit())
138       Diag(Decl->getLocation(), diag::note_implicitly_deleted);
139 
140     // Try to diagnose why this special member function was implicitly
141     // deleted. This might fail, if that reason no longer applies.
142     CXXSpecialMember CSM = getSpecialMember(Method);
143     if (CSM != CXXInvalid)
144       ShouldDeleteSpecialMember(Method, CSM, /*Diagnose=*/true);
145 
146     return;
147   }
148 
149   if (CXXConstructorDecl *CD = dyn_cast<CXXConstructorDecl>(Decl)) {
150     if (CXXConstructorDecl *BaseCD =
151             const_cast<CXXConstructorDecl*>(CD->getInheritedConstructor())) {
152       Diag(Decl->getLocation(), diag::note_inherited_deleted_here);
153       if (BaseCD->isDeleted()) {
154         NoteDeletedFunction(BaseCD);
155       } else {
156         // FIXME: An explanation of why exactly it can't be inherited
157         // would be nice.
158         Diag(BaseCD->getLocation(), diag::note_cannot_inherit);
159       }
160       return;
161     }
162   }
163 
164   Diag(Decl->getLocation(), diag::note_availability_specified_here)
165     << Decl << true;
166 }
167 
168 /// \brief Determine whether a FunctionDecl was ever declared with an
169 /// explicit storage class.
170 static bool hasAnyExplicitStorageClass(const FunctionDecl *D) {
171   for (FunctionDecl::redecl_iterator I = D->redecls_begin(),
172                                      E = D->redecls_end();
173        I != E; ++I) {
174     if (I->getStorageClass() != SC_None)
175       return true;
176   }
177   return false;
178 }
179 
180 /// \brief Check whether we're in an extern inline function and referring to a
181 /// variable or function with internal linkage (C11 6.7.4p3).
182 ///
183 /// This is only a warning because we used to silently accept this code, but
184 /// in many cases it will not behave correctly. This is not enabled in C++ mode
185 /// because the restriction language is a bit weaker (C++11 [basic.def.odr]p6)
186 /// and so while there may still be user mistakes, most of the time we can't
187 /// prove that there are errors.
188 static void diagnoseUseOfInternalDeclInInlineFunction(Sema &S,
189                                                       const NamedDecl *D,
190                                                       SourceLocation Loc) {
191   // This is disabled under C++; there are too many ways for this to fire in
192   // contexts where the warning is a false positive, or where it is technically
193   // correct but benign.
194   if (S.getLangOpts().CPlusPlus)
195     return;
196 
197   // Check if this is an inlined function or method.
198   FunctionDecl *Current = S.getCurFunctionDecl();
199   if (!Current)
200     return;
201   if (!Current->isInlined())
202     return;
203   if (!Current->isExternallyVisible())
204     return;
205 
206   // Check if the decl has internal linkage.
207   if (D->getFormalLinkage() != InternalLinkage)
208     return;
209 
210   // Downgrade from ExtWarn to Extension if
211   //  (1) the supposedly external inline function is in the main file,
212   //      and probably won't be included anywhere else.
213   //  (2) the thing we're referencing is a pure function.
214   //  (3) the thing we're referencing is another inline function.
215   // This last can give us false negatives, but it's better than warning on
216   // wrappers for simple C library functions.
217   const FunctionDecl *UsedFn = dyn_cast<FunctionDecl>(D);
218   bool DowngradeWarning = S.getSourceManager().isInMainFile(Loc);
219   if (!DowngradeWarning && UsedFn)
220     DowngradeWarning = UsedFn->isInlined() || UsedFn->hasAttr<ConstAttr>();
221 
222   S.Diag(Loc, DowngradeWarning ? diag::ext_internal_in_extern_inline
223                                : diag::warn_internal_in_extern_inline)
224     << /*IsVar=*/!UsedFn << D;
225 
226   S.MaybeSuggestAddingStaticToDecl(Current);
227 
228   S.Diag(D->getCanonicalDecl()->getLocation(),
229          diag::note_internal_decl_declared_here)
230     << D;
231 }
232 
233 void Sema::MaybeSuggestAddingStaticToDecl(const FunctionDecl *Cur) {
234   const FunctionDecl *First = Cur->getFirstDecl();
235 
236   // Suggest "static" on the function, if possible.
237   if (!hasAnyExplicitStorageClass(First)) {
238     SourceLocation DeclBegin = First->getSourceRange().getBegin();
239     Diag(DeclBegin, diag::note_convert_inline_to_static)
240       << Cur << FixItHint::CreateInsertion(DeclBegin, "static ");
241   }
242 }
243 
244 /// \brief Determine whether the use of this declaration is valid, and
245 /// emit any corresponding diagnostics.
246 ///
247 /// This routine diagnoses various problems with referencing
248 /// declarations that can occur when using a declaration. For example,
249 /// it might warn if a deprecated or unavailable declaration is being
250 /// used, or produce an error (and return true) if a C++0x deleted
251 /// function is being used.
252 ///
253 /// \returns true if there was an error (this declaration cannot be
254 /// referenced), false otherwise.
255 ///
256 bool Sema::DiagnoseUseOfDecl(NamedDecl *D, SourceLocation Loc,
257                              const ObjCInterfaceDecl *UnknownObjCClass) {
258   if (getLangOpts().CPlusPlus && isa<FunctionDecl>(D)) {
259     // If there were any diagnostics suppressed by template argument deduction,
260     // emit them now.
261     SuppressedDiagnosticsMap::iterator
262       Pos = SuppressedDiagnostics.find(D->getCanonicalDecl());
263     if (Pos != SuppressedDiagnostics.end()) {
264       SmallVectorImpl<PartialDiagnosticAt> &Suppressed = Pos->second;
265       for (unsigned I = 0, N = Suppressed.size(); I != N; ++I)
266         Diag(Suppressed[I].first, Suppressed[I].second);
267 
268       // Clear out the list of suppressed diagnostics, so that we don't emit
269       // them again for this specialization. However, we don't obsolete this
270       // entry from the table, because we want to avoid ever emitting these
271       // diagnostics again.
272       Suppressed.clear();
273     }
274   }
275 
276   // See if this is an auto-typed variable whose initializer we are parsing.
277   if (ParsingInitForAutoVars.count(D)) {
278     Diag(Loc, diag::err_auto_variable_cannot_appear_in_own_initializer)
279       << D->getDeclName();
280     return true;
281   }
282 
283   // See if this is a deleted function.
284   if (FunctionDecl *FD = dyn_cast<FunctionDecl>(D)) {
285     if (FD->isDeleted()) {
286       Diag(Loc, diag::err_deleted_function_use);
287       NoteDeletedFunction(FD);
288       return true;
289     }
290 
291     // If the function has a deduced return type, and we can't deduce it,
292     // then we can't use it either.
293     if (getLangOpts().CPlusPlus1y && FD->getResultType()->isUndeducedType() &&
294         DeduceReturnType(FD, Loc))
295       return true;
296   }
297   DiagnoseAvailabilityOfDecl(*this, D, Loc, UnknownObjCClass);
298 
299   DiagnoseUnusedOfDecl(*this, D, Loc);
300 
301   diagnoseUseOfInternalDeclInInlineFunction(*this, D, Loc);
302 
303   return false;
304 }
305 
306 /// \brief Retrieve the message suffix that should be added to a
307 /// diagnostic complaining about the given function being deleted or
308 /// unavailable.
309 std::string Sema::getDeletedOrUnavailableSuffix(const FunctionDecl *FD) {
310   std::string Message;
311   if (FD->getAvailability(&Message))
312     return ": " + Message;
313 
314   return std::string();
315 }
316 
317 /// DiagnoseSentinelCalls - This routine checks whether a call or
318 /// message-send is to a declaration with the sentinel attribute, and
319 /// if so, it checks that the requirements of the sentinel are
320 /// satisfied.
321 void Sema::DiagnoseSentinelCalls(NamedDecl *D, SourceLocation Loc,
322                                  ArrayRef<Expr *> Args) {
323   const SentinelAttr *attr = D->getAttr<SentinelAttr>();
324   if (!attr)
325     return;
326 
327   // The number of formal parameters of the declaration.
328   unsigned numFormalParams;
329 
330   // The kind of declaration.  This is also an index into a %select in
331   // the diagnostic.
332   enum CalleeType { CT_Function, CT_Method, CT_Block } calleeType;
333 
334   if (ObjCMethodDecl *MD = dyn_cast<ObjCMethodDecl>(D)) {
335     numFormalParams = MD->param_size();
336     calleeType = CT_Method;
337   } else if (FunctionDecl *FD = dyn_cast<FunctionDecl>(D)) {
338     numFormalParams = FD->param_size();
339     calleeType = CT_Function;
340   } else if (isa<VarDecl>(D)) {
341     QualType type = cast<ValueDecl>(D)->getType();
342     const FunctionType *fn = 0;
343     if (const PointerType *ptr = type->getAs<PointerType>()) {
344       fn = ptr->getPointeeType()->getAs<FunctionType>();
345       if (!fn) return;
346       calleeType = CT_Function;
347     } else if (const BlockPointerType *ptr = type->getAs<BlockPointerType>()) {
348       fn = ptr->getPointeeType()->castAs<FunctionType>();
349       calleeType = CT_Block;
350     } else {
351       return;
352     }
353 
354     if (const FunctionProtoType *proto = dyn_cast<FunctionProtoType>(fn)) {
355       numFormalParams = proto->getNumArgs();
356     } else {
357       numFormalParams = 0;
358     }
359   } else {
360     return;
361   }
362 
363   // "nullPos" is the number of formal parameters at the end which
364   // effectively count as part of the variadic arguments.  This is
365   // useful if you would prefer to not have *any* formal parameters,
366   // but the language forces you to have at least one.
367   unsigned nullPos = attr->getNullPos();
368   assert((nullPos == 0 || nullPos == 1) && "invalid null position on sentinel");
369   numFormalParams = (nullPos > numFormalParams ? 0 : numFormalParams - nullPos);
370 
371   // The number of arguments which should follow the sentinel.
372   unsigned numArgsAfterSentinel = attr->getSentinel();
373 
374   // If there aren't enough arguments for all the formal parameters,
375   // the sentinel, and the args after the sentinel, complain.
376   if (Args.size() < numFormalParams + numArgsAfterSentinel + 1) {
377     Diag(Loc, diag::warn_not_enough_argument) << D->getDeclName();
378     Diag(D->getLocation(), diag::note_sentinel_here) << int(calleeType);
379     return;
380   }
381 
382   // Otherwise, find the sentinel expression.
383   Expr *sentinelExpr = Args[Args.size() - numArgsAfterSentinel - 1];
384   if (!sentinelExpr) return;
385   if (sentinelExpr->isValueDependent()) return;
386   if (Context.isSentinelNullExpr(sentinelExpr)) return;
387 
388   // Pick a reasonable string to insert.  Optimistically use 'nil' or
389   // 'NULL' if those are actually defined in the context.  Only use
390   // 'nil' for ObjC methods, where it's much more likely that the
391   // variadic arguments form a list of object pointers.
392   SourceLocation MissingNilLoc
393     = PP.getLocForEndOfToken(sentinelExpr->getLocEnd());
394   std::string NullValue;
395   if (calleeType == CT_Method &&
396       PP.getIdentifierInfo("nil")->hasMacroDefinition())
397     NullValue = "nil";
398   else if (PP.getIdentifierInfo("NULL")->hasMacroDefinition())
399     NullValue = "NULL";
400   else
401     NullValue = "(void*) 0";
402 
403   if (MissingNilLoc.isInvalid())
404     Diag(Loc, diag::warn_missing_sentinel) << int(calleeType);
405   else
406     Diag(MissingNilLoc, diag::warn_missing_sentinel)
407       << int(calleeType)
408       << FixItHint::CreateInsertion(MissingNilLoc, ", " + NullValue);
409   Diag(D->getLocation(), diag::note_sentinel_here) << int(calleeType);
410 }
411 
412 SourceRange Sema::getExprRange(Expr *E) const {
413   return E ? E->getSourceRange() : SourceRange();
414 }
415 
416 //===----------------------------------------------------------------------===//
417 //  Standard Promotions and Conversions
418 //===----------------------------------------------------------------------===//
419 
420 /// DefaultFunctionArrayConversion (C99 6.3.2.1p3, C99 6.3.2.1p4).
421 ExprResult Sema::DefaultFunctionArrayConversion(Expr *E) {
422   // Handle any placeholder expressions which made it here.
423   if (E->getType()->isPlaceholderType()) {
424     ExprResult result = CheckPlaceholderExpr(E);
425     if (result.isInvalid()) return ExprError();
426     E = result.take();
427   }
428 
429   QualType Ty = E->getType();
430   assert(!Ty.isNull() && "DefaultFunctionArrayConversion - missing type");
431 
432   if (Ty->isFunctionType())
433     E = ImpCastExprToType(E, Context.getPointerType(Ty),
434                           CK_FunctionToPointerDecay).take();
435   else if (Ty->isArrayType()) {
436     // In C90 mode, arrays only promote to pointers if the array expression is
437     // an lvalue.  The relevant legalese is C90 6.2.2.1p3: "an lvalue that has
438     // type 'array of type' is converted to an expression that has type 'pointer
439     // to type'...".  In C99 this was changed to: C99 6.3.2.1p3: "an expression
440     // that has type 'array of type' ...".  The relevant change is "an lvalue"
441     // (C90) to "an expression" (C99).
442     //
443     // C++ 4.2p1:
444     // An lvalue or rvalue of type "array of N T" or "array of unknown bound of
445     // T" can be converted to an rvalue of type "pointer to T".
446     //
447     if (getLangOpts().C99 || getLangOpts().CPlusPlus || E->isLValue())
448       E = ImpCastExprToType(E, Context.getArrayDecayedType(Ty),
449                             CK_ArrayToPointerDecay).take();
450   }
451   return Owned(E);
452 }
453 
454 static void CheckForNullPointerDereference(Sema &S, Expr *E) {
455   // Check to see if we are dereferencing a null pointer.  If so,
456   // and if not volatile-qualified, this is undefined behavior that the
457   // optimizer will delete, so warn about it.  People sometimes try to use this
458   // to get a deterministic trap and are surprised by clang's behavior.  This
459   // only handles the pattern "*null", which is a very syntactic check.
460   if (UnaryOperator *UO = dyn_cast<UnaryOperator>(E->IgnoreParenCasts()))
461     if (UO->getOpcode() == UO_Deref &&
462         UO->getSubExpr()->IgnoreParenCasts()->
463           isNullPointerConstant(S.Context, Expr::NPC_ValueDependentIsNotNull) &&
464         !UO->getType().isVolatileQualified()) {
465     S.DiagRuntimeBehavior(UO->getOperatorLoc(), UO,
466                           S.PDiag(diag::warn_indirection_through_null)
467                             << UO->getSubExpr()->getSourceRange());
468     S.DiagRuntimeBehavior(UO->getOperatorLoc(), UO,
469                         S.PDiag(diag::note_indirection_through_null));
470   }
471 }
472 
473 static void DiagnoseDirectIsaAccess(Sema &S, const ObjCIvarRefExpr *OIRE,
474                                     SourceLocation AssignLoc,
475                                     const Expr* RHS) {
476   const ObjCIvarDecl *IV = OIRE->getDecl();
477   if (!IV)
478     return;
479 
480   DeclarationName MemberName = IV->getDeclName();
481   IdentifierInfo *Member = MemberName.getAsIdentifierInfo();
482   if (!Member || !Member->isStr("isa"))
483     return;
484 
485   const Expr *Base = OIRE->getBase();
486   QualType BaseType = Base->getType();
487   if (OIRE->isArrow())
488     BaseType = BaseType->getPointeeType();
489   if (const ObjCObjectType *OTy = BaseType->getAs<ObjCObjectType>())
490     if (ObjCInterfaceDecl *IDecl = OTy->getInterface()) {
491       ObjCInterfaceDecl *ClassDeclared = 0;
492       ObjCIvarDecl *IV = IDecl->lookupInstanceVariable(Member, ClassDeclared);
493       if (!ClassDeclared->getSuperClass()
494           && (*ClassDeclared->ivar_begin()) == IV) {
495         if (RHS) {
496           NamedDecl *ObjectSetClass =
497             S.LookupSingleName(S.TUScope,
498                                &S.Context.Idents.get("object_setClass"),
499                                SourceLocation(), S.LookupOrdinaryName);
500           if (ObjectSetClass) {
501             SourceLocation RHSLocEnd = S.PP.getLocForEndOfToken(RHS->getLocEnd());
502             S.Diag(OIRE->getExprLoc(), diag::warn_objc_isa_assign) <<
503             FixItHint::CreateInsertion(OIRE->getLocStart(), "object_setClass(") <<
504             FixItHint::CreateReplacement(SourceRange(OIRE->getOpLoc(),
505                                                      AssignLoc), ",") <<
506             FixItHint::CreateInsertion(RHSLocEnd, ")");
507           }
508           else
509             S.Diag(OIRE->getLocation(), diag::warn_objc_isa_assign);
510         } else {
511           NamedDecl *ObjectGetClass =
512             S.LookupSingleName(S.TUScope,
513                                &S.Context.Idents.get("object_getClass"),
514                                SourceLocation(), S.LookupOrdinaryName);
515           if (ObjectGetClass)
516             S.Diag(OIRE->getExprLoc(), diag::warn_objc_isa_use) <<
517             FixItHint::CreateInsertion(OIRE->getLocStart(), "object_getClass(") <<
518             FixItHint::CreateReplacement(
519                                          SourceRange(OIRE->getOpLoc(),
520                                                      OIRE->getLocEnd()), ")");
521           else
522             S.Diag(OIRE->getLocation(), diag::warn_objc_isa_use);
523         }
524         S.Diag(IV->getLocation(), diag::note_ivar_decl);
525       }
526     }
527 }
528 
529 ExprResult Sema::DefaultLvalueConversion(Expr *E) {
530   // Handle any placeholder expressions which made it here.
531   if (E->getType()->isPlaceholderType()) {
532     ExprResult result = CheckPlaceholderExpr(E);
533     if (result.isInvalid()) return ExprError();
534     E = result.take();
535   }
536 
537   // C++ [conv.lval]p1:
538   //   A glvalue of a non-function, non-array type T can be
539   //   converted to a prvalue.
540   if (!E->isGLValue()) return Owned(E);
541 
542   QualType T = E->getType();
543   assert(!T.isNull() && "r-value conversion on typeless expression?");
544 
545   // We don't want to throw lvalue-to-rvalue casts on top of
546   // expressions of certain types in C++.
547   if (getLangOpts().CPlusPlus &&
548       (E->getType() == Context.OverloadTy ||
549        T->isDependentType() ||
550        T->isRecordType()))
551     return Owned(E);
552 
553   // The C standard is actually really unclear on this point, and
554   // DR106 tells us what the result should be but not why.  It's
555   // generally best to say that void types just doesn't undergo
556   // lvalue-to-rvalue at all.  Note that expressions of unqualified
557   // 'void' type are never l-values, but qualified void can be.
558   if (T->isVoidType())
559     return Owned(E);
560 
561   // OpenCL usually rejects direct accesses to values of 'half' type.
562   if (getLangOpts().OpenCL && !getOpenCLOptions().cl_khr_fp16 &&
563       T->isHalfType()) {
564     Diag(E->getExprLoc(), diag::err_opencl_half_load_store)
565       << 0 << T;
566     return ExprError();
567   }
568 
569   CheckForNullPointerDereference(*this, E);
570   if (const ObjCIsaExpr *OISA = dyn_cast<ObjCIsaExpr>(E->IgnoreParenCasts())) {
571     NamedDecl *ObjectGetClass = LookupSingleName(TUScope,
572                                      &Context.Idents.get("object_getClass"),
573                                      SourceLocation(), LookupOrdinaryName);
574     if (ObjectGetClass)
575       Diag(E->getExprLoc(), diag::warn_objc_isa_use) <<
576         FixItHint::CreateInsertion(OISA->getLocStart(), "object_getClass(") <<
577         FixItHint::CreateReplacement(
578                     SourceRange(OISA->getOpLoc(), OISA->getIsaMemberLoc()), ")");
579     else
580       Diag(E->getExprLoc(), diag::warn_objc_isa_use);
581   }
582   else if (const ObjCIvarRefExpr *OIRE =
583             dyn_cast<ObjCIvarRefExpr>(E->IgnoreParenCasts()))
584     DiagnoseDirectIsaAccess(*this, OIRE, SourceLocation(), /* Expr*/0);
585 
586   // C++ [conv.lval]p1:
587   //   [...] If T is a non-class type, the type of the prvalue is the
588   //   cv-unqualified version of T. Otherwise, the type of the
589   //   rvalue is T.
590   //
591   // C99 6.3.2.1p2:
592   //   If the lvalue has qualified type, the value has the unqualified
593   //   version of the type of the lvalue; otherwise, the value has the
594   //   type of the lvalue.
595   if (T.hasQualifiers())
596     T = T.getUnqualifiedType();
597 
598   UpdateMarkingForLValueToRValue(E);
599 
600   // Loading a __weak object implicitly retains the value, so we need a cleanup to
601   // balance that.
602   if (getLangOpts().ObjCAutoRefCount &&
603       E->getType().getObjCLifetime() == Qualifiers::OCL_Weak)
604     ExprNeedsCleanups = true;
605 
606   ExprResult Res = Owned(ImplicitCastExpr::Create(Context, T, CK_LValueToRValue,
607                                                   E, 0, VK_RValue));
608 
609   // C11 6.3.2.1p2:
610   //   ... if the lvalue has atomic type, the value has the non-atomic version
611   //   of the type of the lvalue ...
612   if (const AtomicType *Atomic = T->getAs<AtomicType>()) {
613     T = Atomic->getValueType().getUnqualifiedType();
614     Res = Owned(ImplicitCastExpr::Create(Context, T, CK_AtomicToNonAtomic,
615                                          Res.get(), 0, VK_RValue));
616   }
617 
618   return Res;
619 }
620 
621 ExprResult Sema::DefaultFunctionArrayLvalueConversion(Expr *E) {
622   ExprResult Res = DefaultFunctionArrayConversion(E);
623   if (Res.isInvalid())
624     return ExprError();
625   Res = DefaultLvalueConversion(Res.take());
626   if (Res.isInvalid())
627     return ExprError();
628   return Res;
629 }
630 
631 
632 /// UsualUnaryConversions - Performs various conversions that are common to most
633 /// operators (C99 6.3). The conversions of array and function types are
634 /// sometimes suppressed. For example, the array->pointer conversion doesn't
635 /// apply if the array is an argument to the sizeof or address (&) operators.
636 /// In these instances, this routine should *not* be called.
637 ExprResult Sema::UsualUnaryConversions(Expr *E) {
638   // First, convert to an r-value.
639   ExprResult Res = DefaultFunctionArrayLvalueConversion(E);
640   if (Res.isInvalid())
641     return ExprError();
642   E = Res.take();
643 
644   QualType Ty = E->getType();
645   assert(!Ty.isNull() && "UsualUnaryConversions - missing type");
646 
647   // Half FP have to be promoted to float unless it is natively supported
648   if (Ty->isHalfType() && !getLangOpts().NativeHalfType)
649     return ImpCastExprToType(Res.take(), Context.FloatTy, CK_FloatingCast);
650 
651   // Try to perform integral promotions if the object has a theoretically
652   // promotable type.
653   if (Ty->isIntegralOrUnscopedEnumerationType()) {
654     // C99 6.3.1.1p2:
655     //
656     //   The following may be used in an expression wherever an int or
657     //   unsigned int may be used:
658     //     - an object or expression with an integer type whose integer
659     //       conversion rank is less than or equal to the rank of int
660     //       and unsigned int.
661     //     - A bit-field of type _Bool, int, signed int, or unsigned int.
662     //
663     //   If an int can represent all values of the original type, the
664     //   value is converted to an int; otherwise, it is converted to an
665     //   unsigned int. These are called the integer promotions. All
666     //   other types are unchanged by the integer promotions.
667 
668     QualType PTy = Context.isPromotableBitField(E);
669     if (!PTy.isNull()) {
670       E = ImpCastExprToType(E, PTy, CK_IntegralCast).take();
671       return Owned(E);
672     }
673     if (Ty->isPromotableIntegerType()) {
674       QualType PT = Context.getPromotedIntegerType(Ty);
675       E = ImpCastExprToType(E, PT, CK_IntegralCast).take();
676       return Owned(E);
677     }
678   }
679   return Owned(E);
680 }
681 
682 /// DefaultArgumentPromotion (C99 6.5.2.2p6). Used for function calls that
683 /// do not have a prototype. Arguments that have type float or __fp16
684 /// are promoted to double. All other argument types are converted by
685 /// UsualUnaryConversions().
686 ExprResult Sema::DefaultArgumentPromotion(Expr *E) {
687   QualType Ty = E->getType();
688   assert(!Ty.isNull() && "DefaultArgumentPromotion - missing type");
689 
690   ExprResult Res = UsualUnaryConversions(E);
691   if (Res.isInvalid())
692     return ExprError();
693   E = Res.take();
694 
695   // If this is a 'float' or '__fp16' (CVR qualified or typedef) promote to
696   // double.
697   const BuiltinType *BTy = Ty->getAs<BuiltinType>();
698   if (BTy && (BTy->getKind() == BuiltinType::Half ||
699               BTy->getKind() == BuiltinType::Float))
700     E = ImpCastExprToType(E, Context.DoubleTy, CK_FloatingCast).take();
701 
702   // C++ performs lvalue-to-rvalue conversion as a default argument
703   // promotion, even on class types, but note:
704   //   C++11 [conv.lval]p2:
705   //     When an lvalue-to-rvalue conversion occurs in an unevaluated
706   //     operand or a subexpression thereof the value contained in the
707   //     referenced object is not accessed. Otherwise, if the glvalue
708   //     has a class type, the conversion copy-initializes a temporary
709   //     of type T from the glvalue and the result of the conversion
710   //     is a prvalue for the temporary.
711   // FIXME: add some way to gate this entire thing for correctness in
712   // potentially potentially evaluated contexts.
713   if (getLangOpts().CPlusPlus && E->isGLValue() && !isUnevaluatedContext()) {
714     ExprResult Temp = PerformCopyInitialization(
715                        InitializedEntity::InitializeTemporary(E->getType()),
716                                                 E->getExprLoc(),
717                                                 Owned(E));
718     if (Temp.isInvalid())
719       return ExprError();
720     E = Temp.get();
721   }
722 
723   return Owned(E);
724 }
725 
726 /// Determine the degree of POD-ness for an expression.
727 /// Incomplete types are considered POD, since this check can be performed
728 /// when we're in an unevaluated context.
729 Sema::VarArgKind Sema::isValidVarArgType(const QualType &Ty) {
730   if (Ty->isIncompleteType()) {
731     // C++11 [expr.call]p7:
732     //   After these conversions, if the argument does not have arithmetic,
733     //   enumeration, pointer, pointer to member, or class type, the program
734     //   is ill-formed.
735     //
736     // Since we've already performed array-to-pointer and function-to-pointer
737     // decay, the only such type in C++ is cv void. This also handles
738     // initializer lists as variadic arguments.
739     if (Ty->isVoidType())
740       return VAK_Invalid;
741 
742     if (Ty->isObjCObjectType())
743       return VAK_Invalid;
744     return VAK_Valid;
745   }
746 
747   if (Ty.isCXX98PODType(Context))
748     return VAK_Valid;
749 
750   // C++11 [expr.call]p7:
751   //   Passing a potentially-evaluated argument of class type (Clause 9)
752   //   having a non-trivial copy constructor, a non-trivial move constructor,
753   //   or a non-trivial destructor, with no corresponding parameter,
754   //   is conditionally-supported with implementation-defined semantics.
755   if (getLangOpts().CPlusPlus11 && !Ty->isDependentType())
756     if (CXXRecordDecl *Record = Ty->getAsCXXRecordDecl())
757       if (!Record->hasNonTrivialCopyConstructor() &&
758           !Record->hasNonTrivialMoveConstructor() &&
759           !Record->hasNonTrivialDestructor())
760         return VAK_ValidInCXX11;
761 
762   if (getLangOpts().ObjCAutoRefCount && Ty->isObjCLifetimeType())
763     return VAK_Valid;
764 
765   if (Ty->isObjCObjectType())
766     return VAK_Invalid;
767 
768   // FIXME: In C++11, these cases are conditionally-supported, meaning we're
769   // permitted to reject them. We should consider doing so.
770   return VAK_Undefined;
771 }
772 
773 void Sema::checkVariadicArgument(const Expr *E, VariadicCallType CT) {
774   // Don't allow one to pass an Objective-C interface to a vararg.
775   const QualType &Ty = E->getType();
776   VarArgKind VAK = isValidVarArgType(Ty);
777 
778   // Complain about passing non-POD types through varargs.
779   switch (VAK) {
780   case VAK_Valid:
781     break;
782 
783   case VAK_ValidInCXX11:
784     DiagRuntimeBehavior(
785         E->getLocStart(), 0,
786         PDiag(diag::warn_cxx98_compat_pass_non_pod_arg_to_vararg)
787           << E->getType() << CT);
788     break;
789 
790   case VAK_Undefined:
791     DiagRuntimeBehavior(
792         E->getLocStart(), 0,
793         PDiag(diag::warn_cannot_pass_non_pod_arg_to_vararg)
794           << getLangOpts().CPlusPlus11 << Ty << CT);
795     break;
796 
797   case VAK_Invalid:
798     if (Ty->isObjCObjectType())
799       DiagRuntimeBehavior(
800           E->getLocStart(), 0,
801           PDiag(diag::err_cannot_pass_objc_interface_to_vararg)
802             << Ty << CT);
803     else
804       Diag(E->getLocStart(), diag::err_cannot_pass_to_vararg)
805         << isa<InitListExpr>(E) << Ty << CT;
806     break;
807   }
808 }
809 
810 /// DefaultVariadicArgumentPromotion - Like DefaultArgumentPromotion, but
811 /// will create a trap if the resulting type is not a POD type.
812 ExprResult Sema::DefaultVariadicArgumentPromotion(Expr *E, VariadicCallType CT,
813                                                   FunctionDecl *FDecl) {
814   if (const BuiltinType *PlaceholderTy = E->getType()->getAsPlaceholderType()) {
815     // Strip the unbridged-cast placeholder expression off, if applicable.
816     if (PlaceholderTy->getKind() == BuiltinType::ARCUnbridgedCast &&
817         (CT == VariadicMethod ||
818          (FDecl && FDecl->hasAttr<CFAuditedTransferAttr>()))) {
819       E = stripARCUnbridgedCast(E);
820 
821     // Otherwise, do normal placeholder checking.
822     } else {
823       ExprResult ExprRes = CheckPlaceholderExpr(E);
824       if (ExprRes.isInvalid())
825         return ExprError();
826       E = ExprRes.take();
827     }
828   }
829 
830   ExprResult ExprRes = DefaultArgumentPromotion(E);
831   if (ExprRes.isInvalid())
832     return ExprError();
833   E = ExprRes.take();
834 
835   // Diagnostics regarding non-POD argument types are
836   // emitted along with format string checking in Sema::CheckFunctionCall().
837   if (isValidVarArgType(E->getType()) == VAK_Undefined) {
838     // Turn this into a trap.
839     CXXScopeSpec SS;
840     SourceLocation TemplateKWLoc;
841     UnqualifiedId Name;
842     Name.setIdentifier(PP.getIdentifierInfo("__builtin_trap"),
843                        E->getLocStart());
844     ExprResult TrapFn = ActOnIdExpression(TUScope, SS, TemplateKWLoc,
845                                           Name, true, false);
846     if (TrapFn.isInvalid())
847       return ExprError();
848 
849     ExprResult Call = ActOnCallExpr(TUScope, TrapFn.get(),
850                                     E->getLocStart(), None,
851                                     E->getLocEnd());
852     if (Call.isInvalid())
853       return ExprError();
854 
855     ExprResult Comma = ActOnBinOp(TUScope, E->getLocStart(), tok::comma,
856                                   Call.get(), E);
857     if (Comma.isInvalid())
858       return ExprError();
859     return Comma.get();
860   }
861 
862   if (!getLangOpts().CPlusPlus &&
863       RequireCompleteType(E->getExprLoc(), E->getType(),
864                           diag::err_call_incomplete_argument))
865     return ExprError();
866 
867   return Owned(E);
868 }
869 
870 /// \brief Converts an integer to complex float type.  Helper function of
871 /// UsualArithmeticConversions()
872 ///
873 /// \return false if the integer expression is an integer type and is
874 /// successfully converted to the complex type.
875 static bool handleIntegerToComplexFloatConversion(Sema &S, ExprResult &IntExpr,
876                                                   ExprResult &ComplexExpr,
877                                                   QualType IntTy,
878                                                   QualType ComplexTy,
879                                                   bool SkipCast) {
880   if (IntTy->isComplexType() || IntTy->isRealFloatingType()) return true;
881   if (SkipCast) return false;
882   if (IntTy->isIntegerType()) {
883     QualType fpTy = cast<ComplexType>(ComplexTy)->getElementType();
884     IntExpr = S.ImpCastExprToType(IntExpr.take(), fpTy, CK_IntegralToFloating);
885     IntExpr = S.ImpCastExprToType(IntExpr.take(), ComplexTy,
886                                   CK_FloatingRealToComplex);
887   } else {
888     assert(IntTy->isComplexIntegerType());
889     IntExpr = S.ImpCastExprToType(IntExpr.take(), ComplexTy,
890                                   CK_IntegralComplexToFloatingComplex);
891   }
892   return false;
893 }
894 
895 /// \brief Takes two complex float types and converts them to the same type.
896 /// Helper function of UsualArithmeticConversions()
897 static QualType
898 handleComplexFloatToComplexFloatConverstion(Sema &S, ExprResult &LHS,
899                                             ExprResult &RHS, QualType LHSType,
900                                             QualType RHSType,
901                                             bool IsCompAssign) {
902   int order = S.Context.getFloatingTypeOrder(LHSType, RHSType);
903 
904   if (order < 0) {
905     // _Complex float -> _Complex double
906     if (!IsCompAssign)
907       LHS = S.ImpCastExprToType(LHS.take(), RHSType, CK_FloatingComplexCast);
908     return RHSType;
909   }
910   if (order > 0)
911     // _Complex float -> _Complex double
912     RHS = S.ImpCastExprToType(RHS.take(), LHSType, CK_FloatingComplexCast);
913   return LHSType;
914 }
915 
916 /// \brief Converts otherExpr to complex float and promotes complexExpr if
917 /// necessary.  Helper function of UsualArithmeticConversions()
918 static QualType handleOtherComplexFloatConversion(Sema &S,
919                                                   ExprResult &ComplexExpr,
920                                                   ExprResult &OtherExpr,
921                                                   QualType ComplexTy,
922                                                   QualType OtherTy,
923                                                   bool ConvertComplexExpr,
924                                                   bool ConvertOtherExpr) {
925   int order = S.Context.getFloatingTypeOrder(ComplexTy, OtherTy);
926 
927   // If just the complexExpr is complex, the otherExpr needs to be converted,
928   // and the complexExpr might need to be promoted.
929   if (order > 0) { // complexExpr is wider
930     // float -> _Complex double
931     if (ConvertOtherExpr) {
932       QualType fp = cast<ComplexType>(ComplexTy)->getElementType();
933       OtherExpr = S.ImpCastExprToType(OtherExpr.take(), fp, CK_FloatingCast);
934       OtherExpr = S.ImpCastExprToType(OtherExpr.take(), ComplexTy,
935                                       CK_FloatingRealToComplex);
936     }
937     return ComplexTy;
938   }
939 
940   // otherTy is at least as wide.  Find its corresponding complex type.
941   QualType result = (order == 0 ? ComplexTy :
942                                   S.Context.getComplexType(OtherTy));
943 
944   // double -> _Complex double
945   if (ConvertOtherExpr)
946     OtherExpr = S.ImpCastExprToType(OtherExpr.take(), result,
947                                     CK_FloatingRealToComplex);
948 
949   // _Complex float -> _Complex double
950   if (ConvertComplexExpr && order < 0)
951     ComplexExpr = S.ImpCastExprToType(ComplexExpr.take(), result,
952                                       CK_FloatingComplexCast);
953 
954   return result;
955 }
956 
957 /// \brief Handle arithmetic conversion with complex types.  Helper function of
958 /// UsualArithmeticConversions()
959 static QualType handleComplexFloatConversion(Sema &S, ExprResult &LHS,
960                                              ExprResult &RHS, QualType LHSType,
961                                              QualType RHSType,
962                                              bool IsCompAssign) {
963   // if we have an integer operand, the result is the complex type.
964   if (!handleIntegerToComplexFloatConversion(S, RHS, LHS, RHSType, LHSType,
965                                              /*skipCast*/false))
966     return LHSType;
967   if (!handleIntegerToComplexFloatConversion(S, LHS, RHS, LHSType, RHSType,
968                                              /*skipCast*/IsCompAssign))
969     return RHSType;
970 
971   // This handles complex/complex, complex/float, or float/complex.
972   // When both operands are complex, the shorter operand is converted to the
973   // type of the longer, and that is the type of the result. This corresponds
974   // to what is done when combining two real floating-point operands.
975   // The fun begins when size promotion occur across type domains.
976   // From H&S 6.3.4: When one operand is complex and the other is a real
977   // floating-point type, the less precise type is converted, within it's
978   // real or complex domain, to the precision of the other type. For example,
979   // when combining a "long double" with a "double _Complex", the
980   // "double _Complex" is promoted to "long double _Complex".
981 
982   bool LHSComplexFloat = LHSType->isComplexType();
983   bool RHSComplexFloat = RHSType->isComplexType();
984 
985   // If both are complex, just cast to the more precise type.
986   if (LHSComplexFloat && RHSComplexFloat)
987     return handleComplexFloatToComplexFloatConverstion(S, LHS, RHS,
988                                                        LHSType, RHSType,
989                                                        IsCompAssign);
990 
991   // If only one operand is complex, promote it if necessary and convert the
992   // other operand to complex.
993   if (LHSComplexFloat)
994     return handleOtherComplexFloatConversion(
995         S, LHS, RHS, LHSType, RHSType, /*convertComplexExpr*/!IsCompAssign,
996         /*convertOtherExpr*/ true);
997 
998   assert(RHSComplexFloat);
999   return handleOtherComplexFloatConversion(
1000       S, RHS, LHS, RHSType, LHSType, /*convertComplexExpr*/true,
1001       /*convertOtherExpr*/ !IsCompAssign);
1002 }
1003 
1004 /// \brief Hande arithmetic conversion from integer to float.  Helper function
1005 /// of UsualArithmeticConversions()
1006 static QualType handleIntToFloatConversion(Sema &S, ExprResult &FloatExpr,
1007                                            ExprResult &IntExpr,
1008                                            QualType FloatTy, QualType IntTy,
1009                                            bool ConvertFloat, bool ConvertInt) {
1010   if (IntTy->isIntegerType()) {
1011     if (ConvertInt)
1012       // Convert intExpr to the lhs floating point type.
1013       IntExpr = S.ImpCastExprToType(IntExpr.take(), FloatTy,
1014                                     CK_IntegralToFloating);
1015     return FloatTy;
1016   }
1017 
1018   // Convert both sides to the appropriate complex float.
1019   assert(IntTy->isComplexIntegerType());
1020   QualType result = S.Context.getComplexType(FloatTy);
1021 
1022   // _Complex int -> _Complex float
1023   if (ConvertInt)
1024     IntExpr = S.ImpCastExprToType(IntExpr.take(), result,
1025                                   CK_IntegralComplexToFloatingComplex);
1026 
1027   // float -> _Complex float
1028   if (ConvertFloat)
1029     FloatExpr = S.ImpCastExprToType(FloatExpr.take(), result,
1030                                     CK_FloatingRealToComplex);
1031 
1032   return result;
1033 }
1034 
1035 /// \brief Handle arithmethic conversion with floating point types.  Helper
1036 /// function of UsualArithmeticConversions()
1037 static QualType handleFloatConversion(Sema &S, ExprResult &LHS,
1038                                       ExprResult &RHS, QualType LHSType,
1039                                       QualType RHSType, bool IsCompAssign) {
1040   bool LHSFloat = LHSType->isRealFloatingType();
1041   bool RHSFloat = RHSType->isRealFloatingType();
1042 
1043   // If we have two real floating types, convert the smaller operand
1044   // to the bigger result.
1045   if (LHSFloat && RHSFloat) {
1046     int order = S.Context.getFloatingTypeOrder(LHSType, RHSType);
1047     if (order > 0) {
1048       RHS = S.ImpCastExprToType(RHS.take(), LHSType, CK_FloatingCast);
1049       return LHSType;
1050     }
1051 
1052     assert(order < 0 && "illegal float comparison");
1053     if (!IsCompAssign)
1054       LHS = S.ImpCastExprToType(LHS.take(), RHSType, CK_FloatingCast);
1055     return RHSType;
1056   }
1057 
1058   if (LHSFloat)
1059     return handleIntToFloatConversion(S, LHS, RHS, LHSType, RHSType,
1060                                       /*convertFloat=*/!IsCompAssign,
1061                                       /*convertInt=*/ true);
1062   assert(RHSFloat);
1063   return handleIntToFloatConversion(S, RHS, LHS, RHSType, LHSType,
1064                                     /*convertInt=*/ true,
1065                                     /*convertFloat=*/!IsCompAssign);
1066 }
1067 
1068 typedef ExprResult PerformCastFn(Sema &S, Expr *operand, QualType toType);
1069 
1070 namespace {
1071 /// These helper callbacks are placed in an anonymous namespace to
1072 /// permit their use as function template parameters.
1073 ExprResult doIntegralCast(Sema &S, Expr *op, QualType toType) {
1074   return S.ImpCastExprToType(op, toType, CK_IntegralCast);
1075 }
1076 
1077 ExprResult doComplexIntegralCast(Sema &S, Expr *op, QualType toType) {
1078   return S.ImpCastExprToType(op, S.Context.getComplexType(toType),
1079                              CK_IntegralComplexCast);
1080 }
1081 }
1082 
1083 /// \brief Handle integer arithmetic conversions.  Helper function of
1084 /// UsualArithmeticConversions()
1085 template <PerformCastFn doLHSCast, PerformCastFn doRHSCast>
1086 static QualType handleIntegerConversion(Sema &S, ExprResult &LHS,
1087                                         ExprResult &RHS, QualType LHSType,
1088                                         QualType RHSType, bool IsCompAssign) {
1089   // The rules for this case are in C99 6.3.1.8
1090   int order = S.Context.getIntegerTypeOrder(LHSType, RHSType);
1091   bool LHSSigned = LHSType->hasSignedIntegerRepresentation();
1092   bool RHSSigned = RHSType->hasSignedIntegerRepresentation();
1093   if (LHSSigned == RHSSigned) {
1094     // Same signedness; use the higher-ranked type
1095     if (order >= 0) {
1096       RHS = (*doRHSCast)(S, RHS.take(), LHSType);
1097       return LHSType;
1098     } else if (!IsCompAssign)
1099       LHS = (*doLHSCast)(S, LHS.take(), RHSType);
1100     return RHSType;
1101   } else if (order != (LHSSigned ? 1 : -1)) {
1102     // The unsigned type has greater than or equal rank to the
1103     // signed type, so use the unsigned type
1104     if (RHSSigned) {
1105       RHS = (*doRHSCast)(S, RHS.take(), LHSType);
1106       return LHSType;
1107     } else if (!IsCompAssign)
1108       LHS = (*doLHSCast)(S, LHS.take(), RHSType);
1109     return RHSType;
1110   } else if (S.Context.getIntWidth(LHSType) != S.Context.getIntWidth(RHSType)) {
1111     // The two types are different widths; if we are here, that
1112     // means the signed type is larger than the unsigned type, so
1113     // use the signed type.
1114     if (LHSSigned) {
1115       RHS = (*doRHSCast)(S, RHS.take(), LHSType);
1116       return LHSType;
1117     } else if (!IsCompAssign)
1118       LHS = (*doLHSCast)(S, LHS.take(), RHSType);
1119     return RHSType;
1120   } else {
1121     // The signed type is higher-ranked than the unsigned type,
1122     // but isn't actually any bigger (like unsigned int and long
1123     // on most 32-bit systems).  Use the unsigned type corresponding
1124     // to the signed type.
1125     QualType result =
1126       S.Context.getCorrespondingUnsignedType(LHSSigned ? LHSType : RHSType);
1127     RHS = (*doRHSCast)(S, RHS.take(), result);
1128     if (!IsCompAssign)
1129       LHS = (*doLHSCast)(S, LHS.take(), result);
1130     return result;
1131   }
1132 }
1133 
1134 /// \brief Handle conversions with GCC complex int extension.  Helper function
1135 /// of UsualArithmeticConversions()
1136 static QualType handleComplexIntConversion(Sema &S, ExprResult &LHS,
1137                                            ExprResult &RHS, QualType LHSType,
1138                                            QualType RHSType,
1139                                            bool IsCompAssign) {
1140   const ComplexType *LHSComplexInt = LHSType->getAsComplexIntegerType();
1141   const ComplexType *RHSComplexInt = RHSType->getAsComplexIntegerType();
1142 
1143   if (LHSComplexInt && RHSComplexInt) {
1144     QualType LHSEltType = LHSComplexInt->getElementType();
1145     QualType RHSEltType = RHSComplexInt->getElementType();
1146     QualType ScalarType =
1147       handleIntegerConversion<doComplexIntegralCast, doComplexIntegralCast>
1148         (S, LHS, RHS, LHSEltType, RHSEltType, IsCompAssign);
1149 
1150     return S.Context.getComplexType(ScalarType);
1151   }
1152 
1153   if (LHSComplexInt) {
1154     QualType LHSEltType = LHSComplexInt->getElementType();
1155     QualType ScalarType =
1156       handleIntegerConversion<doComplexIntegralCast, doIntegralCast>
1157         (S, LHS, RHS, LHSEltType, RHSType, IsCompAssign);
1158     QualType ComplexType = S.Context.getComplexType(ScalarType);
1159     RHS = S.ImpCastExprToType(RHS.take(), ComplexType,
1160                               CK_IntegralRealToComplex);
1161 
1162     return ComplexType;
1163   }
1164 
1165   assert(RHSComplexInt);
1166 
1167   QualType RHSEltType = RHSComplexInt->getElementType();
1168   QualType ScalarType =
1169     handleIntegerConversion<doIntegralCast, doComplexIntegralCast>
1170       (S, LHS, RHS, LHSType, RHSEltType, IsCompAssign);
1171   QualType ComplexType = S.Context.getComplexType(ScalarType);
1172 
1173   if (!IsCompAssign)
1174     LHS = S.ImpCastExprToType(LHS.take(), ComplexType,
1175                               CK_IntegralRealToComplex);
1176   return ComplexType;
1177 }
1178 
1179 /// UsualArithmeticConversions - Performs various conversions that are common to
1180 /// binary operators (C99 6.3.1.8). If both operands aren't arithmetic, this
1181 /// routine returns the first non-arithmetic type found. The client is
1182 /// responsible for emitting appropriate error diagnostics.
1183 QualType Sema::UsualArithmeticConversions(ExprResult &LHS, ExprResult &RHS,
1184                                           bool IsCompAssign) {
1185   if (!IsCompAssign) {
1186     LHS = UsualUnaryConversions(LHS.take());
1187     if (LHS.isInvalid())
1188       return QualType();
1189   }
1190 
1191   RHS = UsualUnaryConversions(RHS.take());
1192   if (RHS.isInvalid())
1193     return QualType();
1194 
1195   // For conversion purposes, we ignore any qualifiers.
1196   // For example, "const float" and "float" are equivalent.
1197   QualType LHSType =
1198     Context.getCanonicalType(LHS.get()->getType()).getUnqualifiedType();
1199   QualType RHSType =
1200     Context.getCanonicalType(RHS.get()->getType()).getUnqualifiedType();
1201 
1202   // For conversion purposes, we ignore any atomic qualifier on the LHS.
1203   if (const AtomicType *AtomicLHS = LHSType->getAs<AtomicType>())
1204     LHSType = AtomicLHS->getValueType();
1205 
1206   // If both types are identical, no conversion is needed.
1207   if (LHSType == RHSType)
1208     return LHSType;
1209 
1210   // If either side is a non-arithmetic type (e.g. a pointer), we are done.
1211   // The caller can deal with this (e.g. pointer + int).
1212   if (!LHSType->isArithmeticType() || !RHSType->isArithmeticType())
1213     return QualType();
1214 
1215   // Apply unary and bitfield promotions to the LHS's type.
1216   QualType LHSUnpromotedType = LHSType;
1217   if (LHSType->isPromotableIntegerType())
1218     LHSType = Context.getPromotedIntegerType(LHSType);
1219   QualType LHSBitfieldPromoteTy = Context.isPromotableBitField(LHS.get());
1220   if (!LHSBitfieldPromoteTy.isNull())
1221     LHSType = LHSBitfieldPromoteTy;
1222   if (LHSType != LHSUnpromotedType && !IsCompAssign)
1223     LHS = ImpCastExprToType(LHS.take(), LHSType, CK_IntegralCast);
1224 
1225   // If both types are identical, no conversion is needed.
1226   if (LHSType == RHSType)
1227     return LHSType;
1228 
1229   // At this point, we have two different arithmetic types.
1230 
1231   // Handle complex types first (C99 6.3.1.8p1).
1232   if (LHSType->isComplexType() || RHSType->isComplexType())
1233     return handleComplexFloatConversion(*this, LHS, RHS, LHSType, RHSType,
1234                                         IsCompAssign);
1235 
1236   // Now handle "real" floating types (i.e. float, double, long double).
1237   if (LHSType->isRealFloatingType() || RHSType->isRealFloatingType())
1238     return handleFloatConversion(*this, LHS, RHS, LHSType, RHSType,
1239                                  IsCompAssign);
1240 
1241   // Handle GCC complex int extension.
1242   if (LHSType->isComplexIntegerType() || RHSType->isComplexIntegerType())
1243     return handleComplexIntConversion(*this, LHS, RHS, LHSType, RHSType,
1244                                       IsCompAssign);
1245 
1246   // Finally, we have two differing integer types.
1247   return handleIntegerConversion<doIntegralCast, doIntegralCast>
1248            (*this, LHS, RHS, LHSType, RHSType, IsCompAssign);
1249 }
1250 
1251 
1252 //===----------------------------------------------------------------------===//
1253 //  Semantic Analysis for various Expression Types
1254 //===----------------------------------------------------------------------===//
1255 
1256 
1257 ExprResult
1258 Sema::ActOnGenericSelectionExpr(SourceLocation KeyLoc,
1259                                 SourceLocation DefaultLoc,
1260                                 SourceLocation RParenLoc,
1261                                 Expr *ControllingExpr,
1262                                 ArrayRef<ParsedType> ArgTypes,
1263                                 ArrayRef<Expr *> ArgExprs) {
1264   unsigned NumAssocs = ArgTypes.size();
1265   assert(NumAssocs == ArgExprs.size());
1266 
1267   TypeSourceInfo **Types = new TypeSourceInfo*[NumAssocs];
1268   for (unsigned i = 0; i < NumAssocs; ++i) {
1269     if (ArgTypes[i])
1270       (void) GetTypeFromParser(ArgTypes[i], &Types[i]);
1271     else
1272       Types[i] = 0;
1273   }
1274 
1275   ExprResult ER = CreateGenericSelectionExpr(KeyLoc, DefaultLoc, RParenLoc,
1276                                              ControllingExpr,
1277                                              llvm::makeArrayRef(Types, NumAssocs),
1278                                              ArgExprs);
1279   delete [] Types;
1280   return ER;
1281 }
1282 
1283 ExprResult
1284 Sema::CreateGenericSelectionExpr(SourceLocation KeyLoc,
1285                                  SourceLocation DefaultLoc,
1286                                  SourceLocation RParenLoc,
1287                                  Expr *ControllingExpr,
1288                                  ArrayRef<TypeSourceInfo *> Types,
1289                                  ArrayRef<Expr *> Exprs) {
1290   unsigned NumAssocs = Types.size();
1291   assert(NumAssocs == Exprs.size());
1292   if (ControllingExpr->getType()->isPlaceholderType()) {
1293     ExprResult result = CheckPlaceholderExpr(ControllingExpr);
1294     if (result.isInvalid()) return ExprError();
1295     ControllingExpr = result.take();
1296   }
1297 
1298   bool TypeErrorFound = false,
1299        IsResultDependent = ControllingExpr->isTypeDependent(),
1300        ContainsUnexpandedParameterPack
1301          = ControllingExpr->containsUnexpandedParameterPack();
1302 
1303   for (unsigned i = 0; i < NumAssocs; ++i) {
1304     if (Exprs[i]->containsUnexpandedParameterPack())
1305       ContainsUnexpandedParameterPack = true;
1306 
1307     if (Types[i]) {
1308       if (Types[i]->getType()->containsUnexpandedParameterPack())
1309         ContainsUnexpandedParameterPack = true;
1310 
1311       if (Types[i]->getType()->isDependentType()) {
1312         IsResultDependent = true;
1313       } else {
1314         // C11 6.5.1.1p2 "The type name in a generic association shall specify a
1315         // complete object type other than a variably modified type."
1316         unsigned D = 0;
1317         if (Types[i]->getType()->isIncompleteType())
1318           D = diag::err_assoc_type_incomplete;
1319         else if (!Types[i]->getType()->isObjectType())
1320           D = diag::err_assoc_type_nonobject;
1321         else if (Types[i]->getType()->isVariablyModifiedType())
1322           D = diag::err_assoc_type_variably_modified;
1323 
1324         if (D != 0) {
1325           Diag(Types[i]->getTypeLoc().getBeginLoc(), D)
1326             << Types[i]->getTypeLoc().getSourceRange()
1327             << Types[i]->getType();
1328           TypeErrorFound = true;
1329         }
1330 
1331         // C11 6.5.1.1p2 "No two generic associations in the same generic
1332         // selection shall specify compatible types."
1333         for (unsigned j = i+1; j < NumAssocs; ++j)
1334           if (Types[j] && !Types[j]->getType()->isDependentType() &&
1335               Context.typesAreCompatible(Types[i]->getType(),
1336                                          Types[j]->getType())) {
1337             Diag(Types[j]->getTypeLoc().getBeginLoc(),
1338                  diag::err_assoc_compatible_types)
1339               << Types[j]->getTypeLoc().getSourceRange()
1340               << Types[j]->getType()
1341               << Types[i]->getType();
1342             Diag(Types[i]->getTypeLoc().getBeginLoc(),
1343                  diag::note_compat_assoc)
1344               << Types[i]->getTypeLoc().getSourceRange()
1345               << Types[i]->getType();
1346             TypeErrorFound = true;
1347           }
1348       }
1349     }
1350   }
1351   if (TypeErrorFound)
1352     return ExprError();
1353 
1354   // If we determined that the generic selection is result-dependent, don't
1355   // try to compute the result expression.
1356   if (IsResultDependent)
1357     return Owned(new (Context) GenericSelectionExpr(
1358                    Context, KeyLoc, ControllingExpr,
1359                    Types, Exprs,
1360                    DefaultLoc, RParenLoc, ContainsUnexpandedParameterPack));
1361 
1362   SmallVector<unsigned, 1> CompatIndices;
1363   unsigned DefaultIndex = -1U;
1364   for (unsigned i = 0; i < NumAssocs; ++i) {
1365     if (!Types[i])
1366       DefaultIndex = i;
1367     else if (Context.typesAreCompatible(ControllingExpr->getType(),
1368                                         Types[i]->getType()))
1369       CompatIndices.push_back(i);
1370   }
1371 
1372   // C11 6.5.1.1p2 "The controlling expression of a generic selection shall have
1373   // type compatible with at most one of the types named in its generic
1374   // association list."
1375   if (CompatIndices.size() > 1) {
1376     // We strip parens here because the controlling expression is typically
1377     // parenthesized in macro definitions.
1378     ControllingExpr = ControllingExpr->IgnoreParens();
1379     Diag(ControllingExpr->getLocStart(), diag::err_generic_sel_multi_match)
1380       << ControllingExpr->getSourceRange() << ControllingExpr->getType()
1381       << (unsigned) CompatIndices.size();
1382     for (SmallVectorImpl<unsigned>::iterator I = CompatIndices.begin(),
1383          E = CompatIndices.end(); I != E; ++I) {
1384       Diag(Types[*I]->getTypeLoc().getBeginLoc(),
1385            diag::note_compat_assoc)
1386         << Types[*I]->getTypeLoc().getSourceRange()
1387         << Types[*I]->getType();
1388     }
1389     return ExprError();
1390   }
1391 
1392   // C11 6.5.1.1p2 "If a generic selection has no default generic association,
1393   // its controlling expression shall have type compatible with exactly one of
1394   // the types named in its generic association list."
1395   if (DefaultIndex == -1U && CompatIndices.size() == 0) {
1396     // We strip parens here because the controlling expression is typically
1397     // parenthesized in macro definitions.
1398     ControllingExpr = ControllingExpr->IgnoreParens();
1399     Diag(ControllingExpr->getLocStart(), diag::err_generic_sel_no_match)
1400       << ControllingExpr->getSourceRange() << ControllingExpr->getType();
1401     return ExprError();
1402   }
1403 
1404   // C11 6.5.1.1p3 "If a generic selection has a generic association with a
1405   // type name that is compatible with the type of the controlling expression,
1406   // then the result expression of the generic selection is the expression
1407   // in that generic association. Otherwise, the result expression of the
1408   // generic selection is the expression in the default generic association."
1409   unsigned ResultIndex =
1410     CompatIndices.size() ? CompatIndices[0] : DefaultIndex;
1411 
1412   return Owned(new (Context) GenericSelectionExpr(
1413                  Context, KeyLoc, ControllingExpr,
1414                  Types, Exprs,
1415                  DefaultLoc, RParenLoc, ContainsUnexpandedParameterPack,
1416                  ResultIndex));
1417 }
1418 
1419 /// getUDSuffixLoc - Create a SourceLocation for a ud-suffix, given the
1420 /// location of the token and the offset of the ud-suffix within it.
1421 static SourceLocation getUDSuffixLoc(Sema &S, SourceLocation TokLoc,
1422                                      unsigned Offset) {
1423   return Lexer::AdvanceToTokenCharacter(TokLoc, Offset, S.getSourceManager(),
1424                                         S.getLangOpts());
1425 }
1426 
1427 /// BuildCookedLiteralOperatorCall - A user-defined literal was found. Look up
1428 /// the corresponding cooked (non-raw) literal operator, and build a call to it.
1429 static ExprResult BuildCookedLiteralOperatorCall(Sema &S, Scope *Scope,
1430                                                  IdentifierInfo *UDSuffix,
1431                                                  SourceLocation UDSuffixLoc,
1432                                                  ArrayRef<Expr*> Args,
1433                                                  SourceLocation LitEndLoc) {
1434   assert(Args.size() <= 2 && "too many arguments for literal operator");
1435 
1436   QualType ArgTy[2];
1437   for (unsigned ArgIdx = 0; ArgIdx != Args.size(); ++ArgIdx) {
1438     ArgTy[ArgIdx] = Args[ArgIdx]->getType();
1439     if (ArgTy[ArgIdx]->isArrayType())
1440       ArgTy[ArgIdx] = S.Context.getArrayDecayedType(ArgTy[ArgIdx]);
1441   }
1442 
1443   DeclarationName OpName =
1444     S.Context.DeclarationNames.getCXXLiteralOperatorName(UDSuffix);
1445   DeclarationNameInfo OpNameInfo(OpName, UDSuffixLoc);
1446   OpNameInfo.setCXXLiteralOperatorNameLoc(UDSuffixLoc);
1447 
1448   LookupResult R(S, OpName, UDSuffixLoc, Sema::LookupOrdinaryName);
1449   if (S.LookupLiteralOperator(Scope, R, llvm::makeArrayRef(ArgTy, Args.size()),
1450                               /*AllowRaw*/false, /*AllowTemplate*/false,
1451                               /*AllowStringTemplate*/false) == Sema::LOLR_Error)
1452     return ExprError();
1453 
1454   return S.BuildLiteralOperatorCall(R, OpNameInfo, Args, LitEndLoc);
1455 }
1456 
1457 /// ActOnStringLiteral - The specified tokens were lexed as pasted string
1458 /// fragments (e.g. "foo" "bar" L"baz").  The result string has to handle string
1459 /// concatenation ([C99 5.1.1.2, translation phase #6]), so it may come from
1460 /// multiple tokens.  However, the common case is that StringToks points to one
1461 /// string.
1462 ///
1463 ExprResult
1464 Sema::ActOnStringLiteral(const Token *StringToks, unsigned NumStringToks,
1465                          Scope *UDLScope) {
1466   assert(NumStringToks && "Must have at least one string!");
1467 
1468   StringLiteralParser Literal(StringToks, NumStringToks, PP);
1469   if (Literal.hadError)
1470     return ExprError();
1471 
1472   SmallVector<SourceLocation, 4> StringTokLocs;
1473   for (unsigned i = 0; i != NumStringToks; ++i)
1474     StringTokLocs.push_back(StringToks[i].getLocation());
1475 
1476   QualType CharTy = Context.CharTy;
1477   StringLiteral::StringKind Kind = StringLiteral::Ascii;
1478   if (Literal.isWide()) {
1479     CharTy = Context.getWideCharType();
1480     Kind = StringLiteral::Wide;
1481   } else if (Literal.isUTF8()) {
1482     Kind = StringLiteral::UTF8;
1483   } else if (Literal.isUTF16()) {
1484     CharTy = Context.Char16Ty;
1485     Kind = StringLiteral::UTF16;
1486   } else if (Literal.isUTF32()) {
1487     CharTy = Context.Char32Ty;
1488     Kind = StringLiteral::UTF32;
1489   } else if (Literal.isPascal()) {
1490     CharTy = Context.UnsignedCharTy;
1491   }
1492 
1493   QualType CharTyConst = CharTy;
1494   // A C++ string literal has a const-qualified element type (C++ 2.13.4p1).
1495   if (getLangOpts().CPlusPlus || getLangOpts().ConstStrings)
1496     CharTyConst.addConst();
1497 
1498   // Get an array type for the string, according to C99 6.4.5.  This includes
1499   // the nul terminator character as well as the string length for pascal
1500   // strings.
1501   QualType StrTy = Context.getConstantArrayType(CharTyConst,
1502                                  llvm::APInt(32, Literal.GetNumStringChars()+1),
1503                                  ArrayType::Normal, 0);
1504 
1505   // OpenCL v1.1 s6.5.3: a string literal is in the constant address space.
1506   if (getLangOpts().OpenCL) {
1507     StrTy = Context.getAddrSpaceQualType(StrTy, LangAS::opencl_constant);
1508   }
1509 
1510   // Pass &StringTokLocs[0], StringTokLocs.size() to factory!
1511   StringLiteral *Lit = StringLiteral::Create(Context, Literal.GetString(),
1512                                              Kind, Literal.Pascal, StrTy,
1513                                              &StringTokLocs[0],
1514                                              StringTokLocs.size());
1515   if (Literal.getUDSuffix().empty())
1516     return Owned(Lit);
1517 
1518   // We're building a user-defined literal.
1519   IdentifierInfo *UDSuffix = &Context.Idents.get(Literal.getUDSuffix());
1520   SourceLocation UDSuffixLoc =
1521     getUDSuffixLoc(*this, StringTokLocs[Literal.getUDSuffixToken()],
1522                    Literal.getUDSuffixOffset());
1523 
1524   // Make sure we're allowed user-defined literals here.
1525   if (!UDLScope)
1526     return ExprError(Diag(UDSuffixLoc, diag::err_invalid_string_udl));
1527 
1528   // C++11 [lex.ext]p5: The literal L is treated as a call of the form
1529   //   operator "" X (str, len)
1530   QualType SizeType = Context.getSizeType();
1531 
1532   DeclarationName OpName =
1533     Context.DeclarationNames.getCXXLiteralOperatorName(UDSuffix);
1534   DeclarationNameInfo OpNameInfo(OpName, UDSuffixLoc);
1535   OpNameInfo.setCXXLiteralOperatorNameLoc(UDSuffixLoc);
1536 
1537   QualType ArgTy[] = {
1538     Context.getArrayDecayedType(StrTy), SizeType
1539   };
1540 
1541   LookupResult R(*this, OpName, UDSuffixLoc, LookupOrdinaryName);
1542   switch (LookupLiteralOperator(UDLScope, R, ArgTy,
1543                                 /*AllowRaw*/false, /*AllowTemplate*/false,
1544                                 /*AllowStringTemplate*/true)) {
1545 
1546   case LOLR_Cooked: {
1547     llvm::APInt Len(Context.getIntWidth(SizeType), Literal.GetNumStringChars());
1548     IntegerLiteral *LenArg = IntegerLiteral::Create(Context, Len, SizeType,
1549                                                     StringTokLocs[0]);
1550     Expr *Args[] = { Lit, LenArg };
1551 
1552     return BuildLiteralOperatorCall(R, OpNameInfo, Args, StringTokLocs.back());
1553   }
1554 
1555   case LOLR_StringTemplate: {
1556     TemplateArgumentListInfo ExplicitArgs;
1557 
1558     unsigned CharBits = Context.getIntWidth(CharTy);
1559     bool CharIsUnsigned = CharTy->isUnsignedIntegerType();
1560     llvm::APSInt Value(CharBits, CharIsUnsigned);
1561 
1562     TemplateArgument TypeArg(CharTy);
1563     TemplateArgumentLocInfo TypeArgInfo(Context.getTrivialTypeSourceInfo(CharTy));
1564     ExplicitArgs.addArgument(TemplateArgumentLoc(TypeArg, TypeArgInfo));
1565 
1566     for (unsigned I = 0, N = Lit->getLength(); I != N; ++I) {
1567       Value = Lit->getCodeUnit(I);
1568       TemplateArgument Arg(Context, Value, CharTy);
1569       TemplateArgumentLocInfo ArgInfo;
1570       ExplicitArgs.addArgument(TemplateArgumentLoc(Arg, ArgInfo));
1571     }
1572     return BuildLiteralOperatorCall(R, OpNameInfo, None, StringTokLocs.back(),
1573                                     &ExplicitArgs);
1574   }
1575   case LOLR_Raw:
1576   case LOLR_Template:
1577     llvm_unreachable("unexpected literal operator lookup result");
1578   case LOLR_Error:
1579     return ExprError();
1580   }
1581   llvm_unreachable("unexpected literal operator lookup result");
1582 }
1583 
1584 ExprResult
1585 Sema::BuildDeclRefExpr(ValueDecl *D, QualType Ty, ExprValueKind VK,
1586                        SourceLocation Loc,
1587                        const CXXScopeSpec *SS) {
1588   DeclarationNameInfo NameInfo(D->getDeclName(), Loc);
1589   return BuildDeclRefExpr(D, Ty, VK, NameInfo, SS);
1590 }
1591 
1592 /// BuildDeclRefExpr - Build an expression that references a
1593 /// declaration that does not require a closure capture.
1594 ExprResult
1595 Sema::BuildDeclRefExpr(ValueDecl *D, QualType Ty, ExprValueKind VK,
1596                        const DeclarationNameInfo &NameInfo,
1597                        const CXXScopeSpec *SS, NamedDecl *FoundD,
1598                        const TemplateArgumentListInfo *TemplateArgs) {
1599   if (getLangOpts().CUDA)
1600     if (const FunctionDecl *Caller = dyn_cast<FunctionDecl>(CurContext))
1601       if (const FunctionDecl *Callee = dyn_cast<FunctionDecl>(D)) {
1602         CUDAFunctionTarget CallerTarget = IdentifyCUDATarget(Caller),
1603                            CalleeTarget = IdentifyCUDATarget(Callee);
1604         if (CheckCUDATarget(CallerTarget, CalleeTarget)) {
1605           Diag(NameInfo.getLoc(), diag::err_ref_bad_target)
1606             << CalleeTarget << D->getIdentifier() << CallerTarget;
1607           Diag(D->getLocation(), diag::note_previous_decl)
1608             << D->getIdentifier();
1609           return ExprError();
1610         }
1611       }
1612 
1613   bool refersToEnclosingScope =
1614     (CurContext != D->getDeclContext() &&
1615      D->getDeclContext()->isFunctionOrMethod()) ||
1616     (isa<VarDecl>(D) &&
1617      cast<VarDecl>(D)->isInitCapture());
1618 
1619   DeclRefExpr *E;
1620   if (isa<VarTemplateSpecializationDecl>(D)) {
1621     VarTemplateSpecializationDecl *VarSpec =
1622         cast<VarTemplateSpecializationDecl>(D);
1623 
1624     E = DeclRefExpr::Create(
1625         Context,
1626         SS ? SS->getWithLocInContext(Context) : NestedNameSpecifierLoc(),
1627         VarSpec->getTemplateKeywordLoc(), D, refersToEnclosingScope,
1628         NameInfo.getLoc(), Ty, VK, FoundD, TemplateArgs);
1629   } else {
1630     assert(!TemplateArgs && "No template arguments for non-variable"
1631                             " template specialization references");
1632     E = DeclRefExpr::Create(
1633         Context,
1634         SS ? SS->getWithLocInContext(Context) : NestedNameSpecifierLoc(),
1635         SourceLocation(), D, refersToEnclosingScope, NameInfo, Ty, VK, FoundD);
1636   }
1637 
1638   MarkDeclRefReferenced(E);
1639 
1640   if (getLangOpts().ObjCARCWeak && isa<VarDecl>(D) &&
1641       Ty.getObjCLifetime() == Qualifiers::OCL_Weak) {
1642     DiagnosticsEngine::Level Level =
1643       Diags.getDiagnosticLevel(diag::warn_arc_repeated_use_of_weak,
1644                                E->getLocStart());
1645     if (Level != DiagnosticsEngine::Ignored)
1646       recordUseOfEvaluatedWeak(E);
1647   }
1648 
1649   // Just in case we're building an illegal pointer-to-member.
1650   FieldDecl *FD = dyn_cast<FieldDecl>(D);
1651   if (FD && FD->isBitField())
1652     E->setObjectKind(OK_BitField);
1653 
1654   return Owned(E);
1655 }
1656 
1657 /// Decomposes the given name into a DeclarationNameInfo, its location, and
1658 /// possibly a list of template arguments.
1659 ///
1660 /// If this produces template arguments, it is permitted to call
1661 /// DecomposeTemplateName.
1662 ///
1663 /// This actually loses a lot of source location information for
1664 /// non-standard name kinds; we should consider preserving that in
1665 /// some way.
1666 void
1667 Sema::DecomposeUnqualifiedId(const UnqualifiedId &Id,
1668                              TemplateArgumentListInfo &Buffer,
1669                              DeclarationNameInfo &NameInfo,
1670                              const TemplateArgumentListInfo *&TemplateArgs) {
1671   if (Id.getKind() == UnqualifiedId::IK_TemplateId) {
1672     Buffer.setLAngleLoc(Id.TemplateId->LAngleLoc);
1673     Buffer.setRAngleLoc(Id.TemplateId->RAngleLoc);
1674 
1675     ASTTemplateArgsPtr TemplateArgsPtr(Id.TemplateId->getTemplateArgs(),
1676                                        Id.TemplateId->NumArgs);
1677     translateTemplateArguments(TemplateArgsPtr, Buffer);
1678 
1679     TemplateName TName = Id.TemplateId->Template.get();
1680     SourceLocation TNameLoc = Id.TemplateId->TemplateNameLoc;
1681     NameInfo = Context.getNameForTemplate(TName, TNameLoc);
1682     TemplateArgs = &Buffer;
1683   } else {
1684     NameInfo = GetNameFromUnqualifiedId(Id);
1685     TemplateArgs = 0;
1686   }
1687 }
1688 
1689 /// Diagnose an empty lookup.
1690 ///
1691 /// \return false if new lookup candidates were found
1692 bool Sema::DiagnoseEmptyLookup(Scope *S, CXXScopeSpec &SS, LookupResult &R,
1693                                CorrectionCandidateCallback &CCC,
1694                                TemplateArgumentListInfo *ExplicitTemplateArgs,
1695                                ArrayRef<Expr *> Args) {
1696   DeclarationName Name = R.getLookupName();
1697 
1698   unsigned diagnostic = diag::err_undeclared_var_use;
1699   unsigned diagnostic_suggest = diag::err_undeclared_var_use_suggest;
1700   if (Name.getNameKind() == DeclarationName::CXXOperatorName ||
1701       Name.getNameKind() == DeclarationName::CXXLiteralOperatorName ||
1702       Name.getNameKind() == DeclarationName::CXXConversionFunctionName) {
1703     diagnostic = diag::err_undeclared_use;
1704     diagnostic_suggest = diag::err_undeclared_use_suggest;
1705   }
1706 
1707   // If the original lookup was an unqualified lookup, fake an
1708   // unqualified lookup.  This is useful when (for example) the
1709   // original lookup would not have found something because it was a
1710   // dependent name.
1711   DeclContext *DC = (SS.isEmpty() && !CallsUndergoingInstantiation.empty())
1712     ? CurContext : 0;
1713   while (DC) {
1714     if (isa<CXXRecordDecl>(DC)) {
1715       LookupQualifiedName(R, DC);
1716 
1717       if (!R.empty()) {
1718         // Don't give errors about ambiguities in this lookup.
1719         R.suppressDiagnostics();
1720 
1721         // During a default argument instantiation the CurContext points
1722         // to a CXXMethodDecl; but we can't apply a this-> fixit inside a
1723         // function parameter list, hence add an explicit check.
1724         bool isDefaultArgument = !ActiveTemplateInstantiations.empty() &&
1725                               ActiveTemplateInstantiations.back().Kind ==
1726             ActiveTemplateInstantiation::DefaultFunctionArgumentInstantiation;
1727         CXXMethodDecl *CurMethod = dyn_cast<CXXMethodDecl>(CurContext);
1728         bool isInstance = CurMethod &&
1729                           CurMethod->isInstance() &&
1730                           DC == CurMethod->getParent() && !isDefaultArgument;
1731 
1732 
1733         // Give a code modification hint to insert 'this->'.
1734         // TODO: fixit for inserting 'Base<T>::' in the other cases.
1735         // Actually quite difficult!
1736         if (getLangOpts().MSVCCompat)
1737           diagnostic = diag::warn_found_via_dependent_bases_lookup;
1738         if (isInstance) {
1739           Diag(R.getNameLoc(), diagnostic) << Name
1740             << FixItHint::CreateInsertion(R.getNameLoc(), "this->");
1741           UnresolvedLookupExpr *ULE = cast<UnresolvedLookupExpr>(
1742               CallsUndergoingInstantiation.back()->getCallee());
1743 
1744           CXXMethodDecl *DepMethod;
1745           if (CurMethod->isDependentContext())
1746             DepMethod = CurMethod;
1747           else if (CurMethod->getTemplatedKind() ==
1748               FunctionDecl::TK_FunctionTemplateSpecialization)
1749             DepMethod = cast<CXXMethodDecl>(CurMethod->getPrimaryTemplate()->
1750                 getInstantiatedFromMemberTemplate()->getTemplatedDecl());
1751           else
1752             DepMethod = cast<CXXMethodDecl>(
1753                 CurMethod->getInstantiatedFromMemberFunction());
1754           assert(DepMethod && "No template pattern found");
1755 
1756           QualType DepThisType = DepMethod->getThisType(Context);
1757           CheckCXXThisCapture(R.getNameLoc());
1758           CXXThisExpr *DepThis = new (Context) CXXThisExpr(
1759                                      R.getNameLoc(), DepThisType, false);
1760           TemplateArgumentListInfo TList;
1761           if (ULE->hasExplicitTemplateArgs())
1762             ULE->copyTemplateArgumentsInto(TList);
1763 
1764           CXXScopeSpec SS;
1765           SS.Adopt(ULE->getQualifierLoc());
1766           CXXDependentScopeMemberExpr *DepExpr =
1767               CXXDependentScopeMemberExpr::Create(
1768                   Context, DepThis, DepThisType, true, SourceLocation(),
1769                   SS.getWithLocInContext(Context),
1770                   ULE->getTemplateKeywordLoc(), 0,
1771                   R.getLookupNameInfo(),
1772                   ULE->hasExplicitTemplateArgs() ? &TList : 0);
1773           CallsUndergoingInstantiation.back()->setCallee(DepExpr);
1774         } else {
1775           Diag(R.getNameLoc(), diagnostic) << Name;
1776         }
1777 
1778         // Do we really want to note all of these?
1779         for (LookupResult::iterator I = R.begin(), E = R.end(); I != E; ++I)
1780           Diag((*I)->getLocation(), diag::note_dependent_var_use);
1781 
1782         // Return true if we are inside a default argument instantiation
1783         // and the found name refers to an instance member function, otherwise
1784         // the function calling DiagnoseEmptyLookup will try to create an
1785         // implicit member call and this is wrong for default argument.
1786         if (isDefaultArgument && ((*R.begin())->isCXXInstanceMember())) {
1787           Diag(R.getNameLoc(), diag::err_member_call_without_object);
1788           return true;
1789         }
1790 
1791         // Tell the callee to try to recover.
1792         return false;
1793       }
1794 
1795       R.clear();
1796     }
1797 
1798     // In Microsoft mode, if we are performing lookup from within a friend
1799     // function definition declared at class scope then we must set
1800     // DC to the lexical parent to be able to search into the parent
1801     // class.
1802     if (getLangOpts().MSVCCompat && isa<FunctionDecl>(DC) &&
1803         cast<FunctionDecl>(DC)->getFriendObjectKind() &&
1804         DC->getLexicalParent()->isRecord())
1805       DC = DC->getLexicalParent();
1806     else
1807       DC = DC->getParent();
1808   }
1809 
1810   // We didn't find anything, so try to correct for a typo.
1811   TypoCorrection Corrected;
1812   if (S && (Corrected = CorrectTypo(R.getLookupNameInfo(), R.getLookupKind(),
1813                                     S, &SS, CCC))) {
1814     std::string CorrectedStr(Corrected.getAsString(getLangOpts()));
1815     bool DroppedSpecifier =
1816         Corrected.WillReplaceSpecifier() && Name.getAsString() == CorrectedStr;
1817     R.setLookupName(Corrected.getCorrection());
1818 
1819     bool AcceptableWithRecovery = false;
1820     bool AcceptableWithoutRecovery = false;
1821     NamedDecl *ND = Corrected.getCorrectionDecl();
1822     if (ND) {
1823       if (Corrected.isOverloaded()) {
1824         OverloadCandidateSet OCS(R.getNameLoc());
1825         OverloadCandidateSet::iterator Best;
1826         for (TypoCorrection::decl_iterator CD = Corrected.begin(),
1827                                         CDEnd = Corrected.end();
1828              CD != CDEnd; ++CD) {
1829           if (FunctionTemplateDecl *FTD =
1830                    dyn_cast<FunctionTemplateDecl>(*CD))
1831             AddTemplateOverloadCandidate(
1832                 FTD, DeclAccessPair::make(FTD, AS_none), ExplicitTemplateArgs,
1833                 Args, OCS);
1834           else if (FunctionDecl *FD = dyn_cast<FunctionDecl>(*CD))
1835             if (!ExplicitTemplateArgs || ExplicitTemplateArgs->size() == 0)
1836               AddOverloadCandidate(FD, DeclAccessPair::make(FD, AS_none),
1837                                    Args, OCS);
1838         }
1839         switch (OCS.BestViableFunction(*this, R.getNameLoc(), Best)) {
1840         case OR_Success:
1841           ND = Best->Function;
1842           Corrected.setCorrectionDecl(ND);
1843           break;
1844         default:
1845           // FIXME: Arbitrarily pick the first declaration for the note.
1846           Corrected.setCorrectionDecl(ND);
1847           break;
1848         }
1849       }
1850       R.addDecl(ND);
1851 
1852       AcceptableWithRecovery =
1853           isa<ValueDecl>(ND) || isa<FunctionTemplateDecl>(ND);
1854       // FIXME: If we ended up with a typo for a type name or
1855       // Objective-C class name, we're in trouble because the parser
1856       // is in the wrong place to recover. Suggest the typo
1857       // correction, but don't make it a fix-it since we're not going
1858       // to recover well anyway.
1859       AcceptableWithoutRecovery =
1860           isa<TypeDecl>(ND) || isa<ObjCInterfaceDecl>(ND);
1861     } else {
1862       // FIXME: We found a keyword. Suggest it, but don't provide a fix-it
1863       // because we aren't able to recover.
1864       AcceptableWithoutRecovery = true;
1865     }
1866 
1867     if (AcceptableWithRecovery || AcceptableWithoutRecovery) {
1868       unsigned NoteID = (Corrected.getCorrectionDecl() &&
1869                          isa<ImplicitParamDecl>(Corrected.getCorrectionDecl()))
1870                             ? diag::note_implicit_param_decl
1871                             : diag::note_previous_decl;
1872       if (SS.isEmpty())
1873         diagnoseTypo(Corrected, PDiag(diagnostic_suggest) << Name,
1874                      PDiag(NoteID), AcceptableWithRecovery);
1875       else
1876         diagnoseTypo(Corrected, PDiag(diag::err_no_member_suggest)
1877                                   << Name << computeDeclContext(SS, false)
1878                                   << DroppedSpecifier << SS.getRange(),
1879                      PDiag(NoteID), AcceptableWithRecovery);
1880 
1881       // Tell the callee whether to try to recover.
1882       return !AcceptableWithRecovery;
1883     }
1884   }
1885   R.clear();
1886 
1887   // Emit a special diagnostic for failed member lookups.
1888   // FIXME: computing the declaration context might fail here (?)
1889   if (!SS.isEmpty()) {
1890     Diag(R.getNameLoc(), diag::err_no_member)
1891       << Name << computeDeclContext(SS, false)
1892       << SS.getRange();
1893     return true;
1894   }
1895 
1896   // Give up, we can't recover.
1897   Diag(R.getNameLoc(), diagnostic) << Name;
1898   return true;
1899 }
1900 
1901 ExprResult Sema::ActOnIdExpression(Scope *S,
1902                                    CXXScopeSpec &SS,
1903                                    SourceLocation TemplateKWLoc,
1904                                    UnqualifiedId &Id,
1905                                    bool HasTrailingLParen,
1906                                    bool IsAddressOfOperand,
1907                                    CorrectionCandidateCallback *CCC,
1908                                    bool IsInlineAsmIdentifier) {
1909   assert(!(IsAddressOfOperand && HasTrailingLParen) &&
1910          "cannot be direct & operand and have a trailing lparen");
1911   if (SS.isInvalid())
1912     return ExprError();
1913 
1914   TemplateArgumentListInfo TemplateArgsBuffer;
1915 
1916   // Decompose the UnqualifiedId into the following data.
1917   DeclarationNameInfo NameInfo;
1918   const TemplateArgumentListInfo *TemplateArgs;
1919   DecomposeUnqualifiedId(Id, TemplateArgsBuffer, NameInfo, TemplateArgs);
1920 
1921   DeclarationName Name = NameInfo.getName();
1922   IdentifierInfo *II = Name.getAsIdentifierInfo();
1923   SourceLocation NameLoc = NameInfo.getLoc();
1924 
1925   // C++ [temp.dep.expr]p3:
1926   //   An id-expression is type-dependent if it contains:
1927   //     -- an identifier that was declared with a dependent type,
1928   //        (note: handled after lookup)
1929   //     -- a template-id that is dependent,
1930   //        (note: handled in BuildTemplateIdExpr)
1931   //     -- a conversion-function-id that specifies a dependent type,
1932   //     -- a nested-name-specifier that contains a class-name that
1933   //        names a dependent type.
1934   // Determine whether this is a member of an unknown specialization;
1935   // we need to handle these differently.
1936   bool DependentID = false;
1937   if (Name.getNameKind() == DeclarationName::CXXConversionFunctionName &&
1938       Name.getCXXNameType()->isDependentType()) {
1939     DependentID = true;
1940   } else if (SS.isSet()) {
1941     if (DeclContext *DC = computeDeclContext(SS, false)) {
1942       if (RequireCompleteDeclContext(SS, DC))
1943         return ExprError();
1944     } else {
1945       DependentID = true;
1946     }
1947   }
1948 
1949   if (DependentID)
1950     return ActOnDependentIdExpression(SS, TemplateKWLoc, NameInfo,
1951                                       IsAddressOfOperand, TemplateArgs);
1952 
1953   // Perform the required lookup.
1954   LookupResult R(*this, NameInfo,
1955                  (Id.getKind() == UnqualifiedId::IK_ImplicitSelfParam)
1956                   ? LookupObjCImplicitSelfParam : LookupOrdinaryName);
1957   if (TemplateArgs) {
1958     // Lookup the template name again to correctly establish the context in
1959     // which it was found. This is really unfortunate as we already did the
1960     // lookup to determine that it was a template name in the first place. If
1961     // this becomes a performance hit, we can work harder to preserve those
1962     // results until we get here but it's likely not worth it.
1963     bool MemberOfUnknownSpecialization;
1964     LookupTemplateName(R, S, SS, QualType(), /*EnteringContext=*/false,
1965                        MemberOfUnknownSpecialization);
1966 
1967     if (MemberOfUnknownSpecialization ||
1968         (R.getResultKind() == LookupResult::NotFoundInCurrentInstantiation))
1969       return ActOnDependentIdExpression(SS, TemplateKWLoc, NameInfo,
1970                                         IsAddressOfOperand, TemplateArgs);
1971   } else {
1972     bool IvarLookupFollowUp = II && !SS.isSet() && getCurMethodDecl();
1973     LookupParsedName(R, S, &SS, !IvarLookupFollowUp);
1974 
1975     // If the result might be in a dependent base class, this is a dependent
1976     // id-expression.
1977     if (R.getResultKind() == LookupResult::NotFoundInCurrentInstantiation)
1978       return ActOnDependentIdExpression(SS, TemplateKWLoc, NameInfo,
1979                                         IsAddressOfOperand, TemplateArgs);
1980 
1981     // If this reference is in an Objective-C method, then we need to do
1982     // some special Objective-C lookup, too.
1983     if (IvarLookupFollowUp) {
1984       ExprResult E(LookupInObjCMethod(R, S, II, true));
1985       if (E.isInvalid())
1986         return ExprError();
1987 
1988       if (Expr *Ex = E.takeAs<Expr>())
1989         return Owned(Ex);
1990     }
1991   }
1992 
1993   if (R.isAmbiguous())
1994     return ExprError();
1995 
1996   // Determine whether this name might be a candidate for
1997   // argument-dependent lookup.
1998   bool ADL = UseArgumentDependentLookup(SS, R, HasTrailingLParen);
1999 
2000   if (R.empty() && !ADL) {
2001 
2002     // Otherwise, this could be an implicitly declared function reference (legal
2003     // in C90, extension in C99, forbidden in C++).
2004     if (HasTrailingLParen && II && !getLangOpts().CPlusPlus) {
2005       NamedDecl *D = ImplicitlyDefineFunction(NameLoc, *II, S);
2006       if (D) R.addDecl(D);
2007     }
2008 
2009     // If this name wasn't predeclared and if this is not a function
2010     // call, diagnose the problem.
2011     if (R.empty()) {
2012       // In Microsoft mode, if we are inside a template class member function
2013       // whose parent class has dependent base classes, and we can't resolve
2014       // an identifier, then assume the identifier is a member of a dependent
2015       // base class.  The goal is to postpone name lookup to instantiation time
2016       // to be able to search into the type dependent base classes.
2017       // FIXME: If we want 100% compatibility with MSVC, we will have delay all
2018       // unqualified name lookup.  Any name lookup during template parsing means
2019       // clang might find something that MSVC doesn't.  For now, we only handle
2020       // the common case of members of a dependent base class.
2021       if (getLangOpts().MSVCCompat) {
2022         CXXMethodDecl *MD = dyn_cast<CXXMethodDecl>(CurContext);
2023         if (MD && MD->isInstance() && MD->getParent()->hasAnyDependentBases()) {
2024           assert(SS.isEmpty() && "qualifiers should be already handled");
2025           QualType ThisType = MD->getThisType(Context);
2026           // Since the 'this' expression is synthesized, we don't need to
2027           // perform the double-lookup check.
2028           NamedDecl *FirstQualifierInScope = 0;
2029           return Owned(CXXDependentScopeMemberExpr::Create(
2030               Context, /*This=*/0, ThisType, /*IsArrow=*/true,
2031               /*Op=*/SourceLocation(), SS.getWithLocInContext(Context),
2032               TemplateKWLoc, FirstQualifierInScope, NameInfo, TemplateArgs));
2033         }
2034       }
2035 
2036       // Don't diagnose an empty lookup for inline assmebly.
2037       if (IsInlineAsmIdentifier)
2038         return ExprError();
2039 
2040       CorrectionCandidateCallback DefaultValidator;
2041       if (DiagnoseEmptyLookup(S, SS, R, CCC ? *CCC : DefaultValidator))
2042         return ExprError();
2043 
2044       assert(!R.empty() &&
2045              "DiagnoseEmptyLookup returned false but added no results");
2046 
2047       // If we found an Objective-C instance variable, let
2048       // LookupInObjCMethod build the appropriate expression to
2049       // reference the ivar.
2050       if (ObjCIvarDecl *Ivar = R.getAsSingle<ObjCIvarDecl>()) {
2051         R.clear();
2052         ExprResult E(LookupInObjCMethod(R, S, Ivar->getIdentifier()));
2053         // In a hopelessly buggy code, Objective-C instance variable
2054         // lookup fails and no expression will be built to reference it.
2055         if (!E.isInvalid() && !E.get())
2056           return ExprError();
2057         return E;
2058       }
2059     }
2060   }
2061 
2062   // This is guaranteed from this point on.
2063   assert(!R.empty() || ADL);
2064 
2065   // Check whether this might be a C++ implicit instance member access.
2066   // C++ [class.mfct.non-static]p3:
2067   //   When an id-expression that is not part of a class member access
2068   //   syntax and not used to form a pointer to member is used in the
2069   //   body of a non-static member function of class X, if name lookup
2070   //   resolves the name in the id-expression to a non-static non-type
2071   //   member of some class C, the id-expression is transformed into a
2072   //   class member access expression using (*this) as the
2073   //   postfix-expression to the left of the . operator.
2074   //
2075   // But we don't actually need to do this for '&' operands if R
2076   // resolved to a function or overloaded function set, because the
2077   // expression is ill-formed if it actually works out to be a
2078   // non-static member function:
2079   //
2080   // C++ [expr.ref]p4:
2081   //   Otherwise, if E1.E2 refers to a non-static member function. . .
2082   //   [t]he expression can be used only as the left-hand operand of a
2083   //   member function call.
2084   //
2085   // There are other safeguards against such uses, but it's important
2086   // to get this right here so that we don't end up making a
2087   // spuriously dependent expression if we're inside a dependent
2088   // instance method.
2089   if (!R.empty() && (*R.begin())->isCXXClassMember()) {
2090     bool MightBeImplicitMember;
2091     if (!IsAddressOfOperand)
2092       MightBeImplicitMember = true;
2093     else if (!SS.isEmpty())
2094       MightBeImplicitMember = false;
2095     else if (R.isOverloadedResult())
2096       MightBeImplicitMember = false;
2097     else if (R.isUnresolvableResult())
2098       MightBeImplicitMember = true;
2099     else
2100       MightBeImplicitMember = isa<FieldDecl>(R.getFoundDecl()) ||
2101                               isa<IndirectFieldDecl>(R.getFoundDecl()) ||
2102                               isa<MSPropertyDecl>(R.getFoundDecl());
2103 
2104     if (MightBeImplicitMember)
2105       return BuildPossibleImplicitMemberExpr(SS, TemplateKWLoc,
2106                                              R, TemplateArgs);
2107   }
2108 
2109   if (TemplateArgs || TemplateKWLoc.isValid()) {
2110 
2111     // In C++1y, if this is a variable template id, then check it
2112     // in BuildTemplateIdExpr().
2113     // The single lookup result must be a variable template declaration.
2114     if (Id.getKind() == UnqualifiedId::IK_TemplateId && Id.TemplateId &&
2115         Id.TemplateId->Kind == TNK_Var_template) {
2116       assert(R.getAsSingle<VarTemplateDecl>() &&
2117              "There should only be one declaration found.");
2118     }
2119 
2120     return BuildTemplateIdExpr(SS, TemplateKWLoc, R, ADL, TemplateArgs);
2121   }
2122 
2123   return BuildDeclarationNameExpr(SS, R, ADL);
2124 }
2125 
2126 /// BuildQualifiedDeclarationNameExpr - Build a C++ qualified
2127 /// declaration name, generally during template instantiation.
2128 /// There's a large number of things which don't need to be done along
2129 /// this path.
2130 ExprResult
2131 Sema::BuildQualifiedDeclarationNameExpr(CXXScopeSpec &SS,
2132                                         const DeclarationNameInfo &NameInfo,
2133                                         bool IsAddressOfOperand) {
2134   DeclContext *DC = computeDeclContext(SS, false);
2135   if (!DC)
2136     return BuildDependentDeclRefExpr(SS, /*TemplateKWLoc=*/SourceLocation(),
2137                                      NameInfo, /*TemplateArgs=*/0);
2138 
2139   if (RequireCompleteDeclContext(SS, DC))
2140     return ExprError();
2141 
2142   LookupResult R(*this, NameInfo, LookupOrdinaryName);
2143   LookupQualifiedName(R, DC);
2144 
2145   if (R.isAmbiguous())
2146     return ExprError();
2147 
2148   if (R.getResultKind() == LookupResult::NotFoundInCurrentInstantiation)
2149     return BuildDependentDeclRefExpr(SS, /*TemplateKWLoc=*/SourceLocation(),
2150                                      NameInfo, /*TemplateArgs=*/0);
2151 
2152   if (R.empty()) {
2153     Diag(NameInfo.getLoc(), diag::err_no_member)
2154       << NameInfo.getName() << DC << SS.getRange();
2155     return ExprError();
2156   }
2157 
2158   // Defend against this resolving to an implicit member access. We usually
2159   // won't get here if this might be a legitimate a class member (we end up in
2160   // BuildMemberReferenceExpr instead), but this can be valid if we're forming
2161   // a pointer-to-member or in an unevaluated context in C++11.
2162   if (!R.empty() && (*R.begin())->isCXXClassMember() && !IsAddressOfOperand)
2163     return BuildPossibleImplicitMemberExpr(SS,
2164                                            /*TemplateKWLoc=*/SourceLocation(),
2165                                            R, /*TemplateArgs=*/0);
2166 
2167   return BuildDeclarationNameExpr(SS, R, /* ADL */ false);
2168 }
2169 
2170 /// LookupInObjCMethod - The parser has read a name in, and Sema has
2171 /// detected that we're currently inside an ObjC method.  Perform some
2172 /// additional lookup.
2173 ///
2174 /// Ideally, most of this would be done by lookup, but there's
2175 /// actually quite a lot of extra work involved.
2176 ///
2177 /// Returns a null sentinel to indicate trivial success.
2178 ExprResult
2179 Sema::LookupInObjCMethod(LookupResult &Lookup, Scope *S,
2180                          IdentifierInfo *II, bool AllowBuiltinCreation) {
2181   SourceLocation Loc = Lookup.getNameLoc();
2182   ObjCMethodDecl *CurMethod = getCurMethodDecl();
2183 
2184   // Check for error condition which is already reported.
2185   if (!CurMethod)
2186     return ExprError();
2187 
2188   // There are two cases to handle here.  1) scoped lookup could have failed,
2189   // in which case we should look for an ivar.  2) scoped lookup could have
2190   // found a decl, but that decl is outside the current instance method (i.e.
2191   // a global variable).  In these two cases, we do a lookup for an ivar with
2192   // this name, if the lookup sucedes, we replace it our current decl.
2193 
2194   // If we're in a class method, we don't normally want to look for
2195   // ivars.  But if we don't find anything else, and there's an
2196   // ivar, that's an error.
2197   bool IsClassMethod = CurMethod->isClassMethod();
2198 
2199   bool LookForIvars;
2200   if (Lookup.empty())
2201     LookForIvars = true;
2202   else if (IsClassMethod)
2203     LookForIvars = false;
2204   else
2205     LookForIvars = (Lookup.isSingleResult() &&
2206                     Lookup.getFoundDecl()->isDefinedOutsideFunctionOrMethod());
2207   ObjCInterfaceDecl *IFace = 0;
2208   if (LookForIvars) {
2209     IFace = CurMethod->getClassInterface();
2210     ObjCInterfaceDecl *ClassDeclared;
2211     ObjCIvarDecl *IV = 0;
2212     if (IFace && (IV = IFace->lookupInstanceVariable(II, ClassDeclared))) {
2213       // Diagnose using an ivar in a class method.
2214       if (IsClassMethod)
2215         return ExprError(Diag(Loc, diag::error_ivar_use_in_class_method)
2216                          << IV->getDeclName());
2217 
2218       // If we're referencing an invalid decl, just return this as a silent
2219       // error node.  The error diagnostic was already emitted on the decl.
2220       if (IV->isInvalidDecl())
2221         return ExprError();
2222 
2223       // Check if referencing a field with __attribute__((deprecated)).
2224       if (DiagnoseUseOfDecl(IV, Loc))
2225         return ExprError();
2226 
2227       // Diagnose the use of an ivar outside of the declaring class.
2228       if (IV->getAccessControl() == ObjCIvarDecl::Private &&
2229           !declaresSameEntity(ClassDeclared, IFace) &&
2230           !getLangOpts().DebuggerSupport)
2231         Diag(Loc, diag::error_private_ivar_access) << IV->getDeclName();
2232 
2233       // FIXME: This should use a new expr for a direct reference, don't
2234       // turn this into Self->ivar, just return a BareIVarExpr or something.
2235       IdentifierInfo &II = Context.Idents.get("self");
2236       UnqualifiedId SelfName;
2237       SelfName.setIdentifier(&II, SourceLocation());
2238       SelfName.setKind(UnqualifiedId::IK_ImplicitSelfParam);
2239       CXXScopeSpec SelfScopeSpec;
2240       SourceLocation TemplateKWLoc;
2241       ExprResult SelfExpr = ActOnIdExpression(S, SelfScopeSpec, TemplateKWLoc,
2242                                               SelfName, false, false);
2243       if (SelfExpr.isInvalid())
2244         return ExprError();
2245 
2246       SelfExpr = DefaultLvalueConversion(SelfExpr.take());
2247       if (SelfExpr.isInvalid())
2248         return ExprError();
2249 
2250       MarkAnyDeclReferenced(Loc, IV, true);
2251 
2252       ObjCMethodFamily MF = CurMethod->getMethodFamily();
2253       if (MF != OMF_init && MF != OMF_dealloc && MF != OMF_finalize &&
2254           !IvarBacksCurrentMethodAccessor(IFace, CurMethod, IV))
2255         Diag(Loc, diag::warn_direct_ivar_access) << IV->getDeclName();
2256 
2257       ObjCIvarRefExpr *Result = new (Context) ObjCIvarRefExpr(IV, IV->getType(),
2258                                                               Loc, IV->getLocation(),
2259                                                               SelfExpr.take(),
2260                                                               true, true);
2261 
2262       if (getLangOpts().ObjCAutoRefCount) {
2263         if (IV->getType().getObjCLifetime() == Qualifiers::OCL_Weak) {
2264           DiagnosticsEngine::Level Level =
2265             Diags.getDiagnosticLevel(diag::warn_arc_repeated_use_of_weak, Loc);
2266           if (Level != DiagnosticsEngine::Ignored)
2267             recordUseOfEvaluatedWeak(Result);
2268         }
2269         if (CurContext->isClosure())
2270           Diag(Loc, diag::warn_implicitly_retains_self)
2271             << FixItHint::CreateInsertion(Loc, "self->");
2272       }
2273 
2274       return Owned(Result);
2275     }
2276   } else if (CurMethod->isInstanceMethod()) {
2277     // We should warn if a local variable hides an ivar.
2278     if (ObjCInterfaceDecl *IFace = CurMethod->getClassInterface()) {
2279       ObjCInterfaceDecl *ClassDeclared;
2280       if (ObjCIvarDecl *IV = IFace->lookupInstanceVariable(II, ClassDeclared)) {
2281         if (IV->getAccessControl() != ObjCIvarDecl::Private ||
2282             declaresSameEntity(IFace, ClassDeclared))
2283           Diag(Loc, diag::warn_ivar_use_hidden) << IV->getDeclName();
2284       }
2285     }
2286   } else if (Lookup.isSingleResult() &&
2287              Lookup.getFoundDecl()->isDefinedOutsideFunctionOrMethod()) {
2288     // If accessing a stand-alone ivar in a class method, this is an error.
2289     if (const ObjCIvarDecl *IV = dyn_cast<ObjCIvarDecl>(Lookup.getFoundDecl()))
2290       return ExprError(Diag(Loc, diag::error_ivar_use_in_class_method)
2291                        << IV->getDeclName());
2292   }
2293 
2294   if (Lookup.empty() && II && AllowBuiltinCreation) {
2295     // FIXME. Consolidate this with similar code in LookupName.
2296     if (unsigned BuiltinID = II->getBuiltinID()) {
2297       if (!(getLangOpts().CPlusPlus &&
2298             Context.BuiltinInfo.isPredefinedLibFunction(BuiltinID))) {
2299         NamedDecl *D = LazilyCreateBuiltin((IdentifierInfo *)II, BuiltinID,
2300                                            S, Lookup.isForRedeclaration(),
2301                                            Lookup.getNameLoc());
2302         if (D) Lookup.addDecl(D);
2303       }
2304     }
2305   }
2306   // Sentinel value saying that we didn't do anything special.
2307   return Owned((Expr*) 0);
2308 }
2309 
2310 /// \brief Cast a base object to a member's actual type.
2311 ///
2312 /// Logically this happens in three phases:
2313 ///
2314 /// * First we cast from the base type to the naming class.
2315 ///   The naming class is the class into which we were looking
2316 ///   when we found the member;  it's the qualifier type if a
2317 ///   qualifier was provided, and otherwise it's the base type.
2318 ///
2319 /// * Next we cast from the naming class to the declaring class.
2320 ///   If the member we found was brought into a class's scope by
2321 ///   a using declaration, this is that class;  otherwise it's
2322 ///   the class declaring the member.
2323 ///
2324 /// * Finally we cast from the declaring class to the "true"
2325 ///   declaring class of the member.  This conversion does not
2326 ///   obey access control.
2327 ExprResult
2328 Sema::PerformObjectMemberConversion(Expr *From,
2329                                     NestedNameSpecifier *Qualifier,
2330                                     NamedDecl *FoundDecl,
2331                                     NamedDecl *Member) {
2332   CXXRecordDecl *RD = dyn_cast<CXXRecordDecl>(Member->getDeclContext());
2333   if (!RD)
2334     return Owned(From);
2335 
2336   QualType DestRecordType;
2337   QualType DestType;
2338   QualType FromRecordType;
2339   QualType FromType = From->getType();
2340   bool PointerConversions = false;
2341   if (isa<FieldDecl>(Member)) {
2342     DestRecordType = Context.getCanonicalType(Context.getTypeDeclType(RD));
2343 
2344     if (FromType->getAs<PointerType>()) {
2345       DestType = Context.getPointerType(DestRecordType);
2346       FromRecordType = FromType->getPointeeType();
2347       PointerConversions = true;
2348     } else {
2349       DestType = DestRecordType;
2350       FromRecordType = FromType;
2351     }
2352   } else if (CXXMethodDecl *Method = dyn_cast<CXXMethodDecl>(Member)) {
2353     if (Method->isStatic())
2354       return Owned(From);
2355 
2356     DestType = Method->getThisType(Context);
2357     DestRecordType = DestType->getPointeeType();
2358 
2359     if (FromType->getAs<PointerType>()) {
2360       FromRecordType = FromType->getPointeeType();
2361       PointerConversions = true;
2362     } else {
2363       FromRecordType = FromType;
2364       DestType = DestRecordType;
2365     }
2366   } else {
2367     // No conversion necessary.
2368     return Owned(From);
2369   }
2370 
2371   if (DestType->isDependentType() || FromType->isDependentType())
2372     return Owned(From);
2373 
2374   // If the unqualified types are the same, no conversion is necessary.
2375   if (Context.hasSameUnqualifiedType(FromRecordType, DestRecordType))
2376     return Owned(From);
2377 
2378   SourceRange FromRange = From->getSourceRange();
2379   SourceLocation FromLoc = FromRange.getBegin();
2380 
2381   ExprValueKind VK = From->getValueKind();
2382 
2383   // C++ [class.member.lookup]p8:
2384   //   [...] Ambiguities can often be resolved by qualifying a name with its
2385   //   class name.
2386   //
2387   // If the member was a qualified name and the qualified referred to a
2388   // specific base subobject type, we'll cast to that intermediate type
2389   // first and then to the object in which the member is declared. That allows
2390   // one to resolve ambiguities in, e.g., a diamond-shaped hierarchy such as:
2391   //
2392   //   class Base { public: int x; };
2393   //   class Derived1 : public Base { };
2394   //   class Derived2 : public Base { };
2395   //   class VeryDerived : public Derived1, public Derived2 { void f(); };
2396   //
2397   //   void VeryDerived::f() {
2398   //     x = 17; // error: ambiguous base subobjects
2399   //     Derived1::x = 17; // okay, pick the Base subobject of Derived1
2400   //   }
2401   if (Qualifier && Qualifier->getAsType()) {
2402     QualType QType = QualType(Qualifier->getAsType(), 0);
2403     assert(QType->isRecordType() && "lookup done with non-record type");
2404 
2405     QualType QRecordType = QualType(QType->getAs<RecordType>(), 0);
2406 
2407     // In C++98, the qualifier type doesn't actually have to be a base
2408     // type of the object type, in which case we just ignore it.
2409     // Otherwise build the appropriate casts.
2410     if (IsDerivedFrom(FromRecordType, QRecordType)) {
2411       CXXCastPath BasePath;
2412       if (CheckDerivedToBaseConversion(FromRecordType, QRecordType,
2413                                        FromLoc, FromRange, &BasePath))
2414         return ExprError();
2415 
2416       if (PointerConversions)
2417         QType = Context.getPointerType(QType);
2418       From = ImpCastExprToType(From, QType, CK_UncheckedDerivedToBase,
2419                                VK, &BasePath).take();
2420 
2421       FromType = QType;
2422       FromRecordType = QRecordType;
2423 
2424       // If the qualifier type was the same as the destination type,
2425       // we're done.
2426       if (Context.hasSameUnqualifiedType(FromRecordType, DestRecordType))
2427         return Owned(From);
2428     }
2429   }
2430 
2431   bool IgnoreAccess = false;
2432 
2433   // If we actually found the member through a using declaration, cast
2434   // down to the using declaration's type.
2435   //
2436   // Pointer equality is fine here because only one declaration of a
2437   // class ever has member declarations.
2438   if (FoundDecl->getDeclContext() != Member->getDeclContext()) {
2439     assert(isa<UsingShadowDecl>(FoundDecl));
2440     QualType URecordType = Context.getTypeDeclType(
2441                            cast<CXXRecordDecl>(FoundDecl->getDeclContext()));
2442 
2443     // We only need to do this if the naming-class to declaring-class
2444     // conversion is non-trivial.
2445     if (!Context.hasSameUnqualifiedType(FromRecordType, URecordType)) {
2446       assert(IsDerivedFrom(FromRecordType, URecordType));
2447       CXXCastPath BasePath;
2448       if (CheckDerivedToBaseConversion(FromRecordType, URecordType,
2449                                        FromLoc, FromRange, &BasePath))
2450         return ExprError();
2451 
2452       QualType UType = URecordType;
2453       if (PointerConversions)
2454         UType = Context.getPointerType(UType);
2455       From = ImpCastExprToType(From, UType, CK_UncheckedDerivedToBase,
2456                                VK, &BasePath).take();
2457       FromType = UType;
2458       FromRecordType = URecordType;
2459     }
2460 
2461     // We don't do access control for the conversion from the
2462     // declaring class to the true declaring class.
2463     IgnoreAccess = true;
2464   }
2465 
2466   CXXCastPath BasePath;
2467   if (CheckDerivedToBaseConversion(FromRecordType, DestRecordType,
2468                                    FromLoc, FromRange, &BasePath,
2469                                    IgnoreAccess))
2470     return ExprError();
2471 
2472   return ImpCastExprToType(From, DestType, CK_UncheckedDerivedToBase,
2473                            VK, &BasePath);
2474 }
2475 
2476 bool Sema::UseArgumentDependentLookup(const CXXScopeSpec &SS,
2477                                       const LookupResult &R,
2478                                       bool HasTrailingLParen) {
2479   // Only when used directly as the postfix-expression of a call.
2480   if (!HasTrailingLParen)
2481     return false;
2482 
2483   // Never if a scope specifier was provided.
2484   if (SS.isSet())
2485     return false;
2486 
2487   // Only in C++ or ObjC++.
2488   if (!getLangOpts().CPlusPlus)
2489     return false;
2490 
2491   // Turn off ADL when we find certain kinds of declarations during
2492   // normal lookup:
2493   for (LookupResult::iterator I = R.begin(), E = R.end(); I != E; ++I) {
2494     NamedDecl *D = *I;
2495 
2496     // C++0x [basic.lookup.argdep]p3:
2497     //     -- a declaration of a class member
2498     // Since using decls preserve this property, we check this on the
2499     // original decl.
2500     if (D->isCXXClassMember())
2501       return false;
2502 
2503     // C++0x [basic.lookup.argdep]p3:
2504     //     -- a block-scope function declaration that is not a
2505     //        using-declaration
2506     // NOTE: we also trigger this for function templates (in fact, we
2507     // don't check the decl type at all, since all other decl types
2508     // turn off ADL anyway).
2509     if (isa<UsingShadowDecl>(D))
2510       D = cast<UsingShadowDecl>(D)->getTargetDecl();
2511     else if (D->getLexicalDeclContext()->isFunctionOrMethod())
2512       return false;
2513 
2514     // C++0x [basic.lookup.argdep]p3:
2515     //     -- a declaration that is neither a function or a function
2516     //        template
2517     // And also for builtin functions.
2518     if (isa<FunctionDecl>(D)) {
2519       FunctionDecl *FDecl = cast<FunctionDecl>(D);
2520 
2521       // But also builtin functions.
2522       if (FDecl->getBuiltinID() && FDecl->isImplicit())
2523         return false;
2524     } else if (!isa<FunctionTemplateDecl>(D))
2525       return false;
2526   }
2527 
2528   return true;
2529 }
2530 
2531 
2532 /// Diagnoses obvious problems with the use of the given declaration
2533 /// as an expression.  This is only actually called for lookups that
2534 /// were not overloaded, and it doesn't promise that the declaration
2535 /// will in fact be used.
2536 static bool CheckDeclInExpr(Sema &S, SourceLocation Loc, NamedDecl *D) {
2537   if (isa<TypedefNameDecl>(D)) {
2538     S.Diag(Loc, diag::err_unexpected_typedef) << D->getDeclName();
2539     return true;
2540   }
2541 
2542   if (isa<ObjCInterfaceDecl>(D)) {
2543     S.Diag(Loc, diag::err_unexpected_interface) << D->getDeclName();
2544     return true;
2545   }
2546 
2547   if (isa<NamespaceDecl>(D)) {
2548     S.Diag(Loc, diag::err_unexpected_namespace) << D->getDeclName();
2549     return true;
2550   }
2551 
2552   return false;
2553 }
2554 
2555 ExprResult
2556 Sema::BuildDeclarationNameExpr(const CXXScopeSpec &SS,
2557                                LookupResult &R,
2558                                bool NeedsADL) {
2559   // If this is a single, fully-resolved result and we don't need ADL,
2560   // just build an ordinary singleton decl ref.
2561   if (!NeedsADL && R.isSingleResult() && !R.getAsSingle<FunctionTemplateDecl>())
2562     return BuildDeclarationNameExpr(SS, R.getLookupNameInfo(), R.getFoundDecl(),
2563                                     R.getRepresentativeDecl());
2564 
2565   // We only need to check the declaration if there's exactly one
2566   // result, because in the overloaded case the results can only be
2567   // functions and function templates.
2568   if (R.isSingleResult() &&
2569       CheckDeclInExpr(*this, R.getNameLoc(), R.getFoundDecl()))
2570     return ExprError();
2571 
2572   // Otherwise, just build an unresolved lookup expression.  Suppress
2573   // any lookup-related diagnostics; we'll hash these out later, when
2574   // we've picked a target.
2575   R.suppressDiagnostics();
2576 
2577   UnresolvedLookupExpr *ULE
2578     = UnresolvedLookupExpr::Create(Context, R.getNamingClass(),
2579                                    SS.getWithLocInContext(Context),
2580                                    R.getLookupNameInfo(),
2581                                    NeedsADL, R.isOverloadedResult(),
2582                                    R.begin(), R.end());
2583 
2584   return Owned(ULE);
2585 }
2586 
2587 /// \brief Complete semantic analysis for a reference to the given declaration.
2588 ExprResult Sema::BuildDeclarationNameExpr(
2589     const CXXScopeSpec &SS, const DeclarationNameInfo &NameInfo, NamedDecl *D,
2590     NamedDecl *FoundD, const TemplateArgumentListInfo *TemplateArgs) {
2591   assert(D && "Cannot refer to a NULL declaration");
2592   assert(!isa<FunctionTemplateDecl>(D) &&
2593          "Cannot refer unambiguously to a function template");
2594 
2595   SourceLocation Loc = NameInfo.getLoc();
2596   if (CheckDeclInExpr(*this, Loc, D))
2597     return ExprError();
2598 
2599   if (TemplateDecl *Template = dyn_cast<TemplateDecl>(D)) {
2600     // Specifically diagnose references to class templates that are missing
2601     // a template argument list.
2602     Diag(Loc, diag::err_template_decl_ref) << (isa<VarTemplateDecl>(D) ? 1 : 0)
2603                                            << Template << SS.getRange();
2604     Diag(Template->getLocation(), diag::note_template_decl_here);
2605     return ExprError();
2606   }
2607 
2608   // Make sure that we're referring to a value.
2609   ValueDecl *VD = dyn_cast<ValueDecl>(D);
2610   if (!VD) {
2611     Diag(Loc, diag::err_ref_non_value)
2612       << D << SS.getRange();
2613     Diag(D->getLocation(), diag::note_declared_at);
2614     return ExprError();
2615   }
2616 
2617   // Check whether this declaration can be used. Note that we suppress
2618   // this check when we're going to perform argument-dependent lookup
2619   // on this function name, because this might not be the function
2620   // that overload resolution actually selects.
2621   if (DiagnoseUseOfDecl(VD, Loc))
2622     return ExprError();
2623 
2624   // Only create DeclRefExpr's for valid Decl's.
2625   if (VD->isInvalidDecl())
2626     return ExprError();
2627 
2628   // Handle members of anonymous structs and unions.  If we got here,
2629   // and the reference is to a class member indirect field, then this
2630   // must be the subject of a pointer-to-member expression.
2631   if (IndirectFieldDecl *indirectField = dyn_cast<IndirectFieldDecl>(VD))
2632     if (!indirectField->isCXXClassMember())
2633       return BuildAnonymousStructUnionMemberReference(SS, NameInfo.getLoc(),
2634                                                       indirectField);
2635 
2636   {
2637     QualType type = VD->getType();
2638     ExprValueKind valueKind = VK_RValue;
2639 
2640     switch (D->getKind()) {
2641     // Ignore all the non-ValueDecl kinds.
2642 #define ABSTRACT_DECL(kind)
2643 #define VALUE(type, base)
2644 #define DECL(type, base) \
2645     case Decl::type:
2646 #include "clang/AST/DeclNodes.inc"
2647       llvm_unreachable("invalid value decl kind");
2648 
2649     // These shouldn't make it here.
2650     case Decl::ObjCAtDefsField:
2651     case Decl::ObjCIvar:
2652       llvm_unreachable("forming non-member reference to ivar?");
2653 
2654     // Enum constants are always r-values and never references.
2655     // Unresolved using declarations are dependent.
2656     case Decl::EnumConstant:
2657     case Decl::UnresolvedUsingValue:
2658       valueKind = VK_RValue;
2659       break;
2660 
2661     // Fields and indirect fields that got here must be for
2662     // pointer-to-member expressions; we just call them l-values for
2663     // internal consistency, because this subexpression doesn't really
2664     // exist in the high-level semantics.
2665     case Decl::Field:
2666     case Decl::IndirectField:
2667       assert(getLangOpts().CPlusPlus &&
2668              "building reference to field in C?");
2669 
2670       // These can't have reference type in well-formed programs, but
2671       // for internal consistency we do this anyway.
2672       type = type.getNonReferenceType();
2673       valueKind = VK_LValue;
2674       break;
2675 
2676     // Non-type template parameters are either l-values or r-values
2677     // depending on the type.
2678     case Decl::NonTypeTemplateParm: {
2679       if (const ReferenceType *reftype = type->getAs<ReferenceType>()) {
2680         type = reftype->getPointeeType();
2681         valueKind = VK_LValue; // even if the parameter is an r-value reference
2682         break;
2683       }
2684 
2685       // For non-references, we need to strip qualifiers just in case
2686       // the template parameter was declared as 'const int' or whatever.
2687       valueKind = VK_RValue;
2688       type = type.getUnqualifiedType();
2689       break;
2690     }
2691 
2692     case Decl::Var:
2693     case Decl::VarTemplateSpecialization:
2694     case Decl::VarTemplatePartialSpecialization:
2695       // In C, "extern void blah;" is valid and is an r-value.
2696       if (!getLangOpts().CPlusPlus &&
2697           !type.hasQualifiers() &&
2698           type->isVoidType()) {
2699         valueKind = VK_RValue;
2700         break;
2701       }
2702       // fallthrough
2703 
2704     case Decl::ImplicitParam:
2705     case Decl::ParmVar: {
2706       // These are always l-values.
2707       valueKind = VK_LValue;
2708       type = type.getNonReferenceType();
2709 
2710       // FIXME: Does the addition of const really only apply in
2711       // potentially-evaluated contexts? Since the variable isn't actually
2712       // captured in an unevaluated context, it seems that the answer is no.
2713       if (!isUnevaluatedContext()) {
2714         QualType CapturedType = getCapturedDeclRefType(cast<VarDecl>(VD), Loc);
2715         if (!CapturedType.isNull())
2716           type = CapturedType;
2717       }
2718 
2719       break;
2720     }
2721 
2722     case Decl::Function: {
2723       if (unsigned BID = cast<FunctionDecl>(VD)->getBuiltinID()) {
2724         if (!Context.BuiltinInfo.isPredefinedLibFunction(BID)) {
2725           type = Context.BuiltinFnTy;
2726           valueKind = VK_RValue;
2727           break;
2728         }
2729       }
2730 
2731       const FunctionType *fty = type->castAs<FunctionType>();
2732 
2733       // If we're referring to a function with an __unknown_anytype
2734       // result type, make the entire expression __unknown_anytype.
2735       if (fty->getResultType() == Context.UnknownAnyTy) {
2736         type = Context.UnknownAnyTy;
2737         valueKind = VK_RValue;
2738         break;
2739       }
2740 
2741       // Functions are l-values in C++.
2742       if (getLangOpts().CPlusPlus) {
2743         valueKind = VK_LValue;
2744         break;
2745       }
2746 
2747       // C99 DR 316 says that, if a function type comes from a
2748       // function definition (without a prototype), that type is only
2749       // used for checking compatibility. Therefore, when referencing
2750       // the function, we pretend that we don't have the full function
2751       // type.
2752       if (!cast<FunctionDecl>(VD)->hasPrototype() &&
2753           isa<FunctionProtoType>(fty))
2754         type = Context.getFunctionNoProtoType(fty->getResultType(),
2755                                               fty->getExtInfo());
2756 
2757       // Functions are r-values in C.
2758       valueKind = VK_RValue;
2759       break;
2760     }
2761 
2762     case Decl::MSProperty:
2763       valueKind = VK_LValue;
2764       break;
2765 
2766     case Decl::CXXMethod:
2767       // If we're referring to a method with an __unknown_anytype
2768       // result type, make the entire expression __unknown_anytype.
2769       // This should only be possible with a type written directly.
2770       if (const FunctionProtoType *proto
2771             = dyn_cast<FunctionProtoType>(VD->getType()))
2772         if (proto->getResultType() == Context.UnknownAnyTy) {
2773           type = Context.UnknownAnyTy;
2774           valueKind = VK_RValue;
2775           break;
2776         }
2777 
2778       // C++ methods are l-values if static, r-values if non-static.
2779       if (cast<CXXMethodDecl>(VD)->isStatic()) {
2780         valueKind = VK_LValue;
2781         break;
2782       }
2783       // fallthrough
2784 
2785     case Decl::CXXConversion:
2786     case Decl::CXXDestructor:
2787     case Decl::CXXConstructor:
2788       valueKind = VK_RValue;
2789       break;
2790     }
2791 
2792     return BuildDeclRefExpr(VD, type, valueKind, NameInfo, &SS, FoundD,
2793                             TemplateArgs);
2794   }
2795 }
2796 
2797 ExprResult Sema::BuildPredefinedExpr(SourceLocation Loc,
2798                                      PredefinedExpr::IdentType IT) {
2799   // Pick the current block, lambda, captured statement or function.
2800   Decl *currentDecl = 0;
2801   if (const BlockScopeInfo *BSI = getCurBlock())
2802     currentDecl = BSI->TheDecl;
2803   else if (const LambdaScopeInfo *LSI = getCurLambda())
2804     currentDecl = LSI->CallOperator;
2805   else if (const CapturedRegionScopeInfo *CSI = getCurCapturedRegion())
2806     currentDecl = CSI->TheCapturedDecl;
2807   else
2808     currentDecl = getCurFunctionOrMethodDecl();
2809 
2810   if (!currentDecl) {
2811     Diag(Loc, diag::ext_predef_outside_function);
2812     currentDecl = Context.getTranslationUnitDecl();
2813   }
2814 
2815   QualType ResTy;
2816   if (cast<DeclContext>(currentDecl)->isDependentContext())
2817     ResTy = Context.DependentTy;
2818   else {
2819     // Pre-defined identifiers are of type char[x], where x is the length of
2820     // the string.
2821     unsigned Length = PredefinedExpr::ComputeName(IT, currentDecl).length();
2822 
2823     llvm::APInt LengthI(32, Length + 1);
2824     if (IT == PredefinedExpr::LFunction)
2825       ResTy = Context.WideCharTy.withConst();
2826     else
2827       ResTy = Context.CharTy.withConst();
2828     ResTy = Context.getConstantArrayType(ResTy, LengthI, ArrayType::Normal, 0);
2829   }
2830 
2831   return Owned(new (Context) PredefinedExpr(Loc, ResTy, IT));
2832 }
2833 
2834 ExprResult Sema::ActOnPredefinedExpr(SourceLocation Loc, tok::TokenKind Kind) {
2835   PredefinedExpr::IdentType IT;
2836 
2837   switch (Kind) {
2838   default: llvm_unreachable("Unknown simple primary expr!");
2839   case tok::kw___func__: IT = PredefinedExpr::Func; break; // [C99 6.4.2.2]
2840   case tok::kw___FUNCTION__: IT = PredefinedExpr::Function; break;
2841   case tok::kw___FUNCDNAME__: IT = PredefinedExpr::FuncDName; break; // [MS]
2842   case tok::kw_L__FUNCTION__: IT = PredefinedExpr::LFunction; break;
2843   case tok::kw___PRETTY_FUNCTION__: IT = PredefinedExpr::PrettyFunction; break;
2844   }
2845 
2846   return BuildPredefinedExpr(Loc, IT);
2847 }
2848 
2849 ExprResult Sema::ActOnCharacterConstant(const Token &Tok, Scope *UDLScope) {
2850   SmallString<16> CharBuffer;
2851   bool Invalid = false;
2852   StringRef ThisTok = PP.getSpelling(Tok, CharBuffer, &Invalid);
2853   if (Invalid)
2854     return ExprError();
2855 
2856   CharLiteralParser Literal(ThisTok.begin(), ThisTok.end(), Tok.getLocation(),
2857                             PP, Tok.getKind());
2858   if (Literal.hadError())
2859     return ExprError();
2860 
2861   QualType Ty;
2862   if (Literal.isWide())
2863     Ty = Context.WideCharTy; // L'x' -> wchar_t in C and C++.
2864   else if (Literal.isUTF16())
2865     Ty = Context.Char16Ty; // u'x' -> char16_t in C11 and C++11.
2866   else if (Literal.isUTF32())
2867     Ty = Context.Char32Ty; // U'x' -> char32_t in C11 and C++11.
2868   else if (!getLangOpts().CPlusPlus || Literal.isMultiChar())
2869     Ty = Context.IntTy;   // 'x' -> int in C, 'wxyz' -> int in C++.
2870   else
2871     Ty = Context.CharTy;  // 'x' -> char in C++
2872 
2873   CharacterLiteral::CharacterKind Kind = CharacterLiteral::Ascii;
2874   if (Literal.isWide())
2875     Kind = CharacterLiteral::Wide;
2876   else if (Literal.isUTF16())
2877     Kind = CharacterLiteral::UTF16;
2878   else if (Literal.isUTF32())
2879     Kind = CharacterLiteral::UTF32;
2880 
2881   Expr *Lit = new (Context) CharacterLiteral(Literal.getValue(), Kind, Ty,
2882                                              Tok.getLocation());
2883 
2884   if (Literal.getUDSuffix().empty())
2885     return Owned(Lit);
2886 
2887   // We're building a user-defined literal.
2888   IdentifierInfo *UDSuffix = &Context.Idents.get(Literal.getUDSuffix());
2889   SourceLocation UDSuffixLoc =
2890     getUDSuffixLoc(*this, Tok.getLocation(), Literal.getUDSuffixOffset());
2891 
2892   // Make sure we're allowed user-defined literals here.
2893   if (!UDLScope)
2894     return ExprError(Diag(UDSuffixLoc, diag::err_invalid_character_udl));
2895 
2896   // C++11 [lex.ext]p6: The literal L is treated as a call of the form
2897   //   operator "" X (ch)
2898   return BuildCookedLiteralOperatorCall(*this, UDLScope, UDSuffix, UDSuffixLoc,
2899                                         Lit, Tok.getLocation());
2900 }
2901 
2902 ExprResult Sema::ActOnIntegerConstant(SourceLocation Loc, uint64_t Val) {
2903   unsigned IntSize = Context.getTargetInfo().getIntWidth();
2904   return Owned(IntegerLiteral::Create(Context, llvm::APInt(IntSize, Val),
2905                                       Context.IntTy, Loc));
2906 }
2907 
2908 static Expr *BuildFloatingLiteral(Sema &S, NumericLiteralParser &Literal,
2909                                   QualType Ty, SourceLocation Loc) {
2910   const llvm::fltSemantics &Format = S.Context.getFloatTypeSemantics(Ty);
2911 
2912   using llvm::APFloat;
2913   APFloat Val(Format);
2914 
2915   APFloat::opStatus result = Literal.GetFloatValue(Val);
2916 
2917   // Overflow is always an error, but underflow is only an error if
2918   // we underflowed to zero (APFloat reports denormals as underflow).
2919   if ((result & APFloat::opOverflow) ||
2920       ((result & APFloat::opUnderflow) && Val.isZero())) {
2921     unsigned diagnostic;
2922     SmallString<20> buffer;
2923     if (result & APFloat::opOverflow) {
2924       diagnostic = diag::warn_float_overflow;
2925       APFloat::getLargest(Format).toString(buffer);
2926     } else {
2927       diagnostic = diag::warn_float_underflow;
2928       APFloat::getSmallest(Format).toString(buffer);
2929     }
2930 
2931     S.Diag(Loc, diagnostic)
2932       << Ty
2933       << StringRef(buffer.data(), buffer.size());
2934   }
2935 
2936   bool isExact = (result == APFloat::opOK);
2937   return FloatingLiteral::Create(S.Context, Val, isExact, Ty, Loc);
2938 }
2939 
2940 ExprResult Sema::ActOnNumericConstant(const Token &Tok, Scope *UDLScope) {
2941   // Fast path for a single digit (which is quite common).  A single digit
2942   // cannot have a trigraph, escaped newline, radix prefix, or suffix.
2943   if (Tok.getLength() == 1) {
2944     const char Val = PP.getSpellingOfSingleCharacterNumericConstant(Tok);
2945     return ActOnIntegerConstant(Tok.getLocation(), Val-'0');
2946   }
2947 
2948   SmallString<128> SpellingBuffer;
2949   // NumericLiteralParser wants to overread by one character.  Add padding to
2950   // the buffer in case the token is copied to the buffer.  If getSpelling()
2951   // returns a StringRef to the memory buffer, it should have a null char at
2952   // the EOF, so it is also safe.
2953   SpellingBuffer.resize(Tok.getLength() + 1);
2954 
2955   // Get the spelling of the token, which eliminates trigraphs, etc.
2956   bool Invalid = false;
2957   StringRef TokSpelling = PP.getSpelling(Tok, SpellingBuffer, &Invalid);
2958   if (Invalid)
2959     return ExprError();
2960 
2961   NumericLiteralParser Literal(TokSpelling, Tok.getLocation(), PP);
2962   if (Literal.hadError)
2963     return ExprError();
2964 
2965   if (Literal.hasUDSuffix()) {
2966     // We're building a user-defined literal.
2967     IdentifierInfo *UDSuffix = &Context.Idents.get(Literal.getUDSuffix());
2968     SourceLocation UDSuffixLoc =
2969       getUDSuffixLoc(*this, Tok.getLocation(), Literal.getUDSuffixOffset());
2970 
2971     // Make sure we're allowed user-defined literals here.
2972     if (!UDLScope)
2973       return ExprError(Diag(UDSuffixLoc, diag::err_invalid_numeric_udl));
2974 
2975     QualType CookedTy;
2976     if (Literal.isFloatingLiteral()) {
2977       // C++11 [lex.ext]p4: If S contains a literal operator with parameter type
2978       // long double, the literal is treated as a call of the form
2979       //   operator "" X (f L)
2980       CookedTy = Context.LongDoubleTy;
2981     } else {
2982       // C++11 [lex.ext]p3: If S contains a literal operator with parameter type
2983       // unsigned long long, the literal is treated as a call of the form
2984       //   operator "" X (n ULL)
2985       CookedTy = Context.UnsignedLongLongTy;
2986     }
2987 
2988     DeclarationName OpName =
2989       Context.DeclarationNames.getCXXLiteralOperatorName(UDSuffix);
2990     DeclarationNameInfo OpNameInfo(OpName, UDSuffixLoc);
2991     OpNameInfo.setCXXLiteralOperatorNameLoc(UDSuffixLoc);
2992 
2993     SourceLocation TokLoc = Tok.getLocation();
2994 
2995     // Perform literal operator lookup to determine if we're building a raw
2996     // literal or a cooked one.
2997     LookupResult R(*this, OpName, UDSuffixLoc, LookupOrdinaryName);
2998     switch (LookupLiteralOperator(UDLScope, R, CookedTy,
2999                                   /*AllowRaw*/true, /*AllowTemplate*/true,
3000                                   /*AllowStringTemplate*/false)) {
3001     case LOLR_Error:
3002       return ExprError();
3003 
3004     case LOLR_Cooked: {
3005       Expr *Lit;
3006       if (Literal.isFloatingLiteral()) {
3007         Lit = BuildFloatingLiteral(*this, Literal, CookedTy, Tok.getLocation());
3008       } else {
3009         llvm::APInt ResultVal(Context.getTargetInfo().getLongLongWidth(), 0);
3010         if (Literal.GetIntegerValue(ResultVal))
3011           Diag(Tok.getLocation(), diag::err_integer_too_large);
3012         Lit = IntegerLiteral::Create(Context, ResultVal, CookedTy,
3013                                      Tok.getLocation());
3014       }
3015       return BuildLiteralOperatorCall(R, OpNameInfo, Lit, TokLoc);
3016     }
3017 
3018     case LOLR_Raw: {
3019       // C++11 [lit.ext]p3, p4: If S contains a raw literal operator, the
3020       // literal is treated as a call of the form
3021       //   operator "" X ("n")
3022       unsigned Length = Literal.getUDSuffixOffset();
3023       QualType StrTy = Context.getConstantArrayType(
3024           Context.CharTy.withConst(), llvm::APInt(32, Length + 1),
3025           ArrayType::Normal, 0);
3026       Expr *Lit = StringLiteral::Create(
3027           Context, StringRef(TokSpelling.data(), Length), StringLiteral::Ascii,
3028           /*Pascal*/false, StrTy, &TokLoc, 1);
3029       return BuildLiteralOperatorCall(R, OpNameInfo, Lit, TokLoc);
3030     }
3031 
3032     case LOLR_Template: {
3033       // C++11 [lit.ext]p3, p4: Otherwise (S contains a literal operator
3034       // template), L is treated as a call fo the form
3035       //   operator "" X <'c1', 'c2', ... 'ck'>()
3036       // where n is the source character sequence c1 c2 ... ck.
3037       TemplateArgumentListInfo ExplicitArgs;
3038       unsigned CharBits = Context.getIntWidth(Context.CharTy);
3039       bool CharIsUnsigned = Context.CharTy->isUnsignedIntegerType();
3040       llvm::APSInt Value(CharBits, CharIsUnsigned);
3041       for (unsigned I = 0, N = Literal.getUDSuffixOffset(); I != N; ++I) {
3042         Value = TokSpelling[I];
3043         TemplateArgument Arg(Context, Value, Context.CharTy);
3044         TemplateArgumentLocInfo ArgInfo;
3045         ExplicitArgs.addArgument(TemplateArgumentLoc(Arg, ArgInfo));
3046       }
3047       return BuildLiteralOperatorCall(R, OpNameInfo, None, TokLoc,
3048                                       &ExplicitArgs);
3049     }
3050     case LOLR_StringTemplate:
3051       llvm_unreachable("unexpected literal operator lookup result");
3052     }
3053   }
3054 
3055   Expr *Res;
3056 
3057   if (Literal.isFloatingLiteral()) {
3058     QualType Ty;
3059     if (Literal.isFloat)
3060       Ty = Context.FloatTy;
3061     else if (!Literal.isLong)
3062       Ty = Context.DoubleTy;
3063     else
3064       Ty = Context.LongDoubleTy;
3065 
3066     Res = BuildFloatingLiteral(*this, Literal, Ty, Tok.getLocation());
3067 
3068     if (Ty == Context.DoubleTy) {
3069       if (getLangOpts().SinglePrecisionConstants) {
3070         Res = ImpCastExprToType(Res, Context.FloatTy, CK_FloatingCast).take();
3071       } else if (getLangOpts().OpenCL && !getOpenCLOptions().cl_khr_fp64) {
3072         Diag(Tok.getLocation(), diag::warn_double_const_requires_fp64);
3073         Res = ImpCastExprToType(Res, Context.FloatTy, CK_FloatingCast).take();
3074       }
3075     }
3076   } else if (!Literal.isIntegerLiteral()) {
3077     return ExprError();
3078   } else {
3079     QualType Ty;
3080 
3081     // 'long long' is a C99 or C++11 feature.
3082     if (!getLangOpts().C99 && Literal.isLongLong) {
3083       if (getLangOpts().CPlusPlus)
3084         Diag(Tok.getLocation(),
3085              getLangOpts().CPlusPlus11 ?
3086              diag::warn_cxx98_compat_longlong : diag::ext_cxx11_longlong);
3087       else
3088         Diag(Tok.getLocation(), diag::ext_c99_longlong);
3089     }
3090 
3091     // Get the value in the widest-possible width.
3092     unsigned MaxWidth = Context.getTargetInfo().getIntMaxTWidth();
3093     // The microsoft literal suffix extensions support 128-bit literals, which
3094     // may be wider than [u]intmax_t.
3095     // FIXME: Actually, they don't. We seem to have accidentally invented the
3096     //        i128 suffix.
3097     if (Literal.isMicrosoftInteger && MaxWidth < 128 &&
3098         PP.getTargetInfo().hasInt128Type())
3099       MaxWidth = 128;
3100     llvm::APInt ResultVal(MaxWidth, 0);
3101 
3102     if (Literal.GetIntegerValue(ResultVal)) {
3103       // If this value didn't fit into uintmax_t, error and force to ull.
3104       Diag(Tok.getLocation(), diag::err_integer_too_large);
3105       Ty = Context.UnsignedLongLongTy;
3106       assert(Context.getTypeSize(Ty) == ResultVal.getBitWidth() &&
3107              "long long is not intmax_t?");
3108     } else {
3109       // If this value fits into a ULL, try to figure out what else it fits into
3110       // according to the rules of C99 6.4.4.1p5.
3111 
3112       // Octal, Hexadecimal, and integers with a U suffix are allowed to
3113       // be an unsigned int.
3114       bool AllowUnsigned = Literal.isUnsigned || Literal.getRadix() != 10;
3115 
3116       // Check from smallest to largest, picking the smallest type we can.
3117       unsigned Width = 0;
3118       if (!Literal.isLong && !Literal.isLongLong) {
3119         // Are int/unsigned possibilities?
3120         unsigned IntSize = Context.getTargetInfo().getIntWidth();
3121 
3122         // Does it fit in a unsigned int?
3123         if (ResultVal.isIntN(IntSize)) {
3124           // Does it fit in a signed int?
3125           if (!Literal.isUnsigned && ResultVal[IntSize-1] == 0)
3126             Ty = Context.IntTy;
3127           else if (AllowUnsigned)
3128             Ty = Context.UnsignedIntTy;
3129           Width = IntSize;
3130         }
3131       }
3132 
3133       // Are long/unsigned long possibilities?
3134       if (Ty.isNull() && !Literal.isLongLong) {
3135         unsigned LongSize = Context.getTargetInfo().getLongWidth();
3136 
3137         // Does it fit in a unsigned long?
3138         if (ResultVal.isIntN(LongSize)) {
3139           // Does it fit in a signed long?
3140           if (!Literal.isUnsigned && ResultVal[LongSize-1] == 0)
3141             Ty = Context.LongTy;
3142           else if (AllowUnsigned)
3143             Ty = Context.UnsignedLongTy;
3144           Width = LongSize;
3145         }
3146       }
3147 
3148       // Check long long if needed.
3149       if (Ty.isNull()) {
3150         unsigned LongLongSize = Context.getTargetInfo().getLongLongWidth();
3151 
3152         // Does it fit in a unsigned long long?
3153         if (ResultVal.isIntN(LongLongSize)) {
3154           // Does it fit in a signed long long?
3155           // To be compatible with MSVC, hex integer literals ending with the
3156           // LL or i64 suffix are always signed in Microsoft mode.
3157           if (!Literal.isUnsigned && (ResultVal[LongLongSize-1] == 0 ||
3158               (getLangOpts().MicrosoftExt && Literal.isLongLong)))
3159             Ty = Context.LongLongTy;
3160           else if (AllowUnsigned)
3161             Ty = Context.UnsignedLongLongTy;
3162           Width = LongLongSize;
3163         }
3164       }
3165 
3166       // If it doesn't fit in unsigned long long, and we're using Microsoft
3167       // extensions, then its a 128-bit integer literal.
3168       if (Ty.isNull() && Literal.isMicrosoftInteger &&
3169           PP.getTargetInfo().hasInt128Type()) {
3170         if (Literal.isUnsigned)
3171           Ty = Context.UnsignedInt128Ty;
3172         else
3173           Ty = Context.Int128Ty;
3174         Width = 128;
3175       }
3176 
3177       // If we still couldn't decide a type, we probably have something that
3178       // does not fit in a signed long long, but has no U suffix.
3179       if (Ty.isNull()) {
3180         Diag(Tok.getLocation(), diag::warn_integer_too_large_for_signed);
3181         Ty = Context.UnsignedLongLongTy;
3182         Width = Context.getTargetInfo().getLongLongWidth();
3183       }
3184 
3185       if (ResultVal.getBitWidth() != Width)
3186         ResultVal = ResultVal.trunc(Width);
3187     }
3188     Res = IntegerLiteral::Create(Context, ResultVal, Ty, Tok.getLocation());
3189   }
3190 
3191   // If this is an imaginary literal, create the ImaginaryLiteral wrapper.
3192   if (Literal.isImaginary)
3193     Res = new (Context) ImaginaryLiteral(Res,
3194                                         Context.getComplexType(Res->getType()));
3195 
3196   return Owned(Res);
3197 }
3198 
3199 ExprResult Sema::ActOnParenExpr(SourceLocation L, SourceLocation R, Expr *E) {
3200   assert((E != 0) && "ActOnParenExpr() missing expr");
3201   return Owned(new (Context) ParenExpr(L, R, E));
3202 }
3203 
3204 static bool CheckVecStepTraitOperandType(Sema &S, QualType T,
3205                                          SourceLocation Loc,
3206                                          SourceRange ArgRange) {
3207   // [OpenCL 1.1 6.11.12] "The vec_step built-in function takes a built-in
3208   // scalar or vector data type argument..."
3209   // Every built-in scalar type (OpenCL 1.1 6.1.1) is either an arithmetic
3210   // type (C99 6.2.5p18) or void.
3211   if (!(T->isArithmeticType() || T->isVoidType() || T->isVectorType())) {
3212     S.Diag(Loc, diag::err_vecstep_non_scalar_vector_type)
3213       << T << ArgRange;
3214     return true;
3215   }
3216 
3217   assert((T->isVoidType() || !T->isIncompleteType()) &&
3218          "Scalar types should always be complete");
3219   return false;
3220 }
3221 
3222 static bool CheckExtensionTraitOperandType(Sema &S, QualType T,
3223                                            SourceLocation Loc,
3224                                            SourceRange ArgRange,
3225                                            UnaryExprOrTypeTrait TraitKind) {
3226   // Invalid types must be hard errors for SFINAE in C++.
3227   if (S.LangOpts.CPlusPlus)
3228     return true;
3229 
3230   // C99 6.5.3.4p1:
3231   if (T->isFunctionType() &&
3232       (TraitKind == UETT_SizeOf || TraitKind == UETT_AlignOf)) {
3233     // sizeof(function)/alignof(function) is allowed as an extension.
3234     S.Diag(Loc, diag::ext_sizeof_alignof_function_type)
3235       << TraitKind << ArgRange;
3236     return false;
3237   }
3238 
3239   // Allow sizeof(void)/alignof(void) as an extension, unless in OpenCL where
3240   // this is an error (OpenCL v1.1 s6.3.k)
3241   if (T->isVoidType()) {
3242     unsigned DiagID = S.LangOpts.OpenCL ? diag::err_opencl_sizeof_alignof_type
3243                                         : diag::ext_sizeof_alignof_void_type;
3244     S.Diag(Loc, DiagID) << TraitKind << ArgRange;
3245     return false;
3246   }
3247 
3248   return true;
3249 }
3250 
3251 static bool CheckObjCTraitOperandConstraints(Sema &S, QualType T,
3252                                              SourceLocation Loc,
3253                                              SourceRange ArgRange,
3254                                              UnaryExprOrTypeTrait TraitKind) {
3255   // Reject sizeof(interface) and sizeof(interface<proto>) if the
3256   // runtime doesn't allow it.
3257   if (!S.LangOpts.ObjCRuntime.allowsSizeofAlignof() && T->isObjCObjectType()) {
3258     S.Diag(Loc, diag::err_sizeof_nonfragile_interface)
3259       << T << (TraitKind == UETT_SizeOf)
3260       << ArgRange;
3261     return true;
3262   }
3263 
3264   return false;
3265 }
3266 
3267 /// \brief Check whether E is a pointer from a decayed array type (the decayed
3268 /// pointer type is equal to T) and emit a warning if it is.
3269 static void warnOnSizeofOnArrayDecay(Sema &S, SourceLocation Loc, QualType T,
3270                                      Expr *E) {
3271   // Don't warn if the operation changed the type.
3272   if (T != E->getType())
3273     return;
3274 
3275   // Now look for array decays.
3276   ImplicitCastExpr *ICE = dyn_cast<ImplicitCastExpr>(E);
3277   if (!ICE || ICE->getCastKind() != CK_ArrayToPointerDecay)
3278     return;
3279 
3280   S.Diag(Loc, diag::warn_sizeof_array_decay) << ICE->getSourceRange()
3281                                              << ICE->getType()
3282                                              << ICE->getSubExpr()->getType();
3283 }
3284 
3285 /// \brief Check the constraints on expression operands to unary type expression
3286 /// and type traits.
3287 ///
3288 /// Completes any types necessary and validates the constraints on the operand
3289 /// expression. The logic mostly mirrors the type-based overload, but may modify
3290 /// the expression as it completes the type for that expression through template
3291 /// instantiation, etc.
3292 bool Sema::CheckUnaryExprOrTypeTraitOperand(Expr *E,
3293                                             UnaryExprOrTypeTrait ExprKind) {
3294   QualType ExprTy = E->getType();
3295   assert(!ExprTy->isReferenceType());
3296 
3297   if (ExprKind == UETT_VecStep)
3298     return CheckVecStepTraitOperandType(*this, ExprTy, E->getExprLoc(),
3299                                         E->getSourceRange());
3300 
3301   // Whitelist some types as extensions
3302   if (!CheckExtensionTraitOperandType(*this, ExprTy, E->getExprLoc(),
3303                                       E->getSourceRange(), ExprKind))
3304     return false;
3305 
3306   if (RequireCompleteExprType(E,
3307                               diag::err_sizeof_alignof_incomplete_type,
3308                               ExprKind, E->getSourceRange()))
3309     return true;
3310 
3311   // Completing the expression's type may have changed it.
3312   ExprTy = E->getType();
3313   assert(!ExprTy->isReferenceType());
3314 
3315   if (ExprTy->isFunctionType()) {
3316     Diag(E->getExprLoc(), diag::err_sizeof_alignof_function_type)
3317       << ExprKind << E->getSourceRange();
3318     return true;
3319   }
3320 
3321   if (CheckObjCTraitOperandConstraints(*this, ExprTy, E->getExprLoc(),
3322                                        E->getSourceRange(), ExprKind))
3323     return true;
3324 
3325   if (ExprKind == UETT_SizeOf) {
3326     if (DeclRefExpr *DeclRef = dyn_cast<DeclRefExpr>(E->IgnoreParens())) {
3327       if (ParmVarDecl *PVD = dyn_cast<ParmVarDecl>(DeclRef->getFoundDecl())) {
3328         QualType OType = PVD->getOriginalType();
3329         QualType Type = PVD->getType();
3330         if (Type->isPointerType() && OType->isArrayType()) {
3331           Diag(E->getExprLoc(), diag::warn_sizeof_array_param)
3332             << Type << OType;
3333           Diag(PVD->getLocation(), diag::note_declared_at);
3334         }
3335       }
3336     }
3337 
3338     // Warn on "sizeof(array op x)" and "sizeof(x op array)", where the array
3339     // decays into a pointer and returns an unintended result. This is most
3340     // likely a typo for "sizeof(array) op x".
3341     if (BinaryOperator *BO = dyn_cast<BinaryOperator>(E->IgnoreParens())) {
3342       warnOnSizeofOnArrayDecay(*this, BO->getOperatorLoc(), BO->getType(),
3343                                BO->getLHS());
3344       warnOnSizeofOnArrayDecay(*this, BO->getOperatorLoc(), BO->getType(),
3345                                BO->getRHS());
3346     }
3347   }
3348 
3349   return false;
3350 }
3351 
3352 /// \brief Check the constraints on operands to unary expression and type
3353 /// traits.
3354 ///
3355 /// This will complete any types necessary, and validate the various constraints
3356 /// on those operands.
3357 ///
3358 /// The UsualUnaryConversions() function is *not* called by this routine.
3359 /// C99 6.3.2.1p[2-4] all state:
3360 ///   Except when it is the operand of the sizeof operator ...
3361 ///
3362 /// C++ [expr.sizeof]p4
3363 ///   The lvalue-to-rvalue, array-to-pointer, and function-to-pointer
3364 ///   standard conversions are not applied to the operand of sizeof.
3365 ///
3366 /// This policy is followed for all of the unary trait expressions.
3367 bool Sema::CheckUnaryExprOrTypeTraitOperand(QualType ExprType,
3368                                             SourceLocation OpLoc,
3369                                             SourceRange ExprRange,
3370                                             UnaryExprOrTypeTrait ExprKind) {
3371   if (ExprType->isDependentType())
3372     return false;
3373 
3374   // C++ [expr.sizeof]p2: "When applied to a reference or a reference type,
3375   //   the result is the size of the referenced type."
3376   // C++ [expr.alignof]p3: "When alignof is applied to a reference type, the
3377   //   result shall be the alignment of the referenced type."
3378   if (const ReferenceType *Ref = ExprType->getAs<ReferenceType>())
3379     ExprType = Ref->getPointeeType();
3380 
3381   if (ExprKind == UETT_VecStep)
3382     return CheckVecStepTraitOperandType(*this, ExprType, OpLoc, ExprRange);
3383 
3384   // Whitelist some types as extensions
3385   if (!CheckExtensionTraitOperandType(*this, ExprType, OpLoc, ExprRange,
3386                                       ExprKind))
3387     return false;
3388 
3389   if (RequireCompleteType(OpLoc, ExprType,
3390                           diag::err_sizeof_alignof_incomplete_type,
3391                           ExprKind, ExprRange))
3392     return true;
3393 
3394   if (ExprType->isFunctionType()) {
3395     Diag(OpLoc, diag::err_sizeof_alignof_function_type)
3396       << ExprKind << ExprRange;
3397     return true;
3398   }
3399 
3400   if (CheckObjCTraitOperandConstraints(*this, ExprType, OpLoc, ExprRange,
3401                                        ExprKind))
3402     return true;
3403 
3404   return false;
3405 }
3406 
3407 static bool CheckAlignOfExpr(Sema &S, Expr *E) {
3408   E = E->IgnoreParens();
3409 
3410   // Cannot know anything else if the expression is dependent.
3411   if (E->isTypeDependent())
3412     return false;
3413 
3414   if (E->getObjectKind() == OK_BitField) {
3415     S.Diag(E->getExprLoc(), diag::err_sizeof_alignof_bitfield)
3416        << 1 << E->getSourceRange();
3417     return true;
3418   }
3419 
3420   ValueDecl *D = 0;
3421   if (DeclRefExpr *DRE = dyn_cast<DeclRefExpr>(E)) {
3422     D = DRE->getDecl();
3423   } else if (MemberExpr *ME = dyn_cast<MemberExpr>(E)) {
3424     D = ME->getMemberDecl();
3425   }
3426 
3427   // If it's a field, require the containing struct to have a
3428   // complete definition so that we can compute the layout.
3429   //
3430   // This requires a very particular set of circumstances.  For a
3431   // field to be contained within an incomplete type, we must in the
3432   // process of parsing that type.  To have an expression refer to a
3433   // field, it must be an id-expression or a member-expression, but
3434   // the latter are always ill-formed when the base type is
3435   // incomplete, including only being partially complete.  An
3436   // id-expression can never refer to a field in C because fields
3437   // are not in the ordinary namespace.  In C++, an id-expression
3438   // can implicitly be a member access, but only if there's an
3439   // implicit 'this' value, and all such contexts are subject to
3440   // delayed parsing --- except for trailing return types in C++11.
3441   // And if an id-expression referring to a field occurs in a
3442   // context that lacks a 'this' value, it's ill-formed --- except,
3443   // again, in C++11, where such references are allowed in an
3444   // unevaluated context.  So C++11 introduces some new complexity.
3445   //
3446   // For the record, since __alignof__ on expressions is a GCC
3447   // extension, GCC seems to permit this but always gives the
3448   // nonsensical answer 0.
3449   //
3450   // We don't really need the layout here --- we could instead just
3451   // directly check for all the appropriate alignment-lowing
3452   // attributes --- but that would require duplicating a lot of
3453   // logic that just isn't worth duplicating for such a marginal
3454   // use-case.
3455   if (FieldDecl *FD = dyn_cast_or_null<FieldDecl>(D)) {
3456     // Fast path this check, since we at least know the record has a
3457     // definition if we can find a member of it.
3458     if (!FD->getParent()->isCompleteDefinition()) {
3459       S.Diag(E->getExprLoc(), diag::err_alignof_member_of_incomplete_type)
3460         << E->getSourceRange();
3461       return true;
3462     }
3463 
3464     // Otherwise, if it's a field, and the field doesn't have
3465     // reference type, then it must have a complete type (or be a
3466     // flexible array member, which we explicitly want to
3467     // white-list anyway), which makes the following checks trivial.
3468     if (!FD->getType()->isReferenceType())
3469       return false;
3470   }
3471 
3472   return S.CheckUnaryExprOrTypeTraitOperand(E, UETT_AlignOf);
3473 }
3474 
3475 bool Sema::CheckVecStepExpr(Expr *E) {
3476   E = E->IgnoreParens();
3477 
3478   // Cannot know anything else if the expression is dependent.
3479   if (E->isTypeDependent())
3480     return false;
3481 
3482   return CheckUnaryExprOrTypeTraitOperand(E, UETT_VecStep);
3483 }
3484 
3485 /// \brief Build a sizeof or alignof expression given a type operand.
3486 ExprResult
3487 Sema::CreateUnaryExprOrTypeTraitExpr(TypeSourceInfo *TInfo,
3488                                      SourceLocation OpLoc,
3489                                      UnaryExprOrTypeTrait ExprKind,
3490                                      SourceRange R) {
3491   if (!TInfo)
3492     return ExprError();
3493 
3494   QualType T = TInfo->getType();
3495 
3496   if (!T->isDependentType() &&
3497       CheckUnaryExprOrTypeTraitOperand(T, OpLoc, R, ExprKind))
3498     return ExprError();
3499 
3500   // C99 6.5.3.4p4: the type (an unsigned integer type) is size_t.
3501   return Owned(new (Context) UnaryExprOrTypeTraitExpr(ExprKind, TInfo,
3502                                                       Context.getSizeType(),
3503                                                       OpLoc, R.getEnd()));
3504 }
3505 
3506 /// \brief Build a sizeof or alignof expression given an expression
3507 /// operand.
3508 ExprResult
3509 Sema::CreateUnaryExprOrTypeTraitExpr(Expr *E, SourceLocation OpLoc,
3510                                      UnaryExprOrTypeTrait ExprKind) {
3511   ExprResult PE = CheckPlaceholderExpr(E);
3512   if (PE.isInvalid())
3513     return ExprError();
3514 
3515   E = PE.get();
3516 
3517   // Verify that the operand is valid.
3518   bool isInvalid = false;
3519   if (E->isTypeDependent()) {
3520     // Delay type-checking for type-dependent expressions.
3521   } else if (ExprKind == UETT_AlignOf) {
3522     isInvalid = CheckAlignOfExpr(*this, E);
3523   } else if (ExprKind == UETT_VecStep) {
3524     isInvalid = CheckVecStepExpr(E);
3525   } else if (E->refersToBitField()) {  // C99 6.5.3.4p1.
3526     Diag(E->getExprLoc(), diag::err_sizeof_alignof_bitfield) << 0;
3527     isInvalid = true;
3528   } else {
3529     isInvalid = CheckUnaryExprOrTypeTraitOperand(E, UETT_SizeOf);
3530   }
3531 
3532   if (isInvalid)
3533     return ExprError();
3534 
3535   if (ExprKind == UETT_SizeOf && E->getType()->isVariableArrayType()) {
3536     PE = TransformToPotentiallyEvaluated(E);
3537     if (PE.isInvalid()) return ExprError();
3538     E = PE.take();
3539   }
3540 
3541   // C99 6.5.3.4p4: the type (an unsigned integer type) is size_t.
3542   return Owned(new (Context) UnaryExprOrTypeTraitExpr(
3543       ExprKind, E, Context.getSizeType(), OpLoc,
3544       E->getSourceRange().getEnd()));
3545 }
3546 
3547 /// ActOnUnaryExprOrTypeTraitExpr - Handle @c sizeof(type) and @c sizeof @c
3548 /// expr and the same for @c alignof and @c __alignof
3549 /// Note that the ArgRange is invalid if isType is false.
3550 ExprResult
3551 Sema::ActOnUnaryExprOrTypeTraitExpr(SourceLocation OpLoc,
3552                                     UnaryExprOrTypeTrait ExprKind, bool IsType,
3553                                     void *TyOrEx, const SourceRange &ArgRange) {
3554   // If error parsing type, ignore.
3555   if (TyOrEx == 0) return ExprError();
3556 
3557   if (IsType) {
3558     TypeSourceInfo *TInfo;
3559     (void) GetTypeFromParser(ParsedType::getFromOpaquePtr(TyOrEx), &TInfo);
3560     return CreateUnaryExprOrTypeTraitExpr(TInfo, OpLoc, ExprKind, ArgRange);
3561   }
3562 
3563   Expr *ArgEx = (Expr *)TyOrEx;
3564   ExprResult Result = CreateUnaryExprOrTypeTraitExpr(ArgEx, OpLoc, ExprKind);
3565   return Result;
3566 }
3567 
3568 static QualType CheckRealImagOperand(Sema &S, ExprResult &V, SourceLocation Loc,
3569                                      bool IsReal) {
3570   if (V.get()->isTypeDependent())
3571     return S.Context.DependentTy;
3572 
3573   // _Real and _Imag are only l-values for normal l-values.
3574   if (V.get()->getObjectKind() != OK_Ordinary) {
3575     V = S.DefaultLvalueConversion(V.take());
3576     if (V.isInvalid())
3577       return QualType();
3578   }
3579 
3580   // These operators return the element type of a complex type.
3581   if (const ComplexType *CT = V.get()->getType()->getAs<ComplexType>())
3582     return CT->getElementType();
3583 
3584   // Otherwise they pass through real integer and floating point types here.
3585   if (V.get()->getType()->isArithmeticType())
3586     return V.get()->getType();
3587 
3588   // Test for placeholders.
3589   ExprResult PR = S.CheckPlaceholderExpr(V.get());
3590   if (PR.isInvalid()) return QualType();
3591   if (PR.get() != V.get()) {
3592     V = PR;
3593     return CheckRealImagOperand(S, V, Loc, IsReal);
3594   }
3595 
3596   // Reject anything else.
3597   S.Diag(Loc, diag::err_realimag_invalid_type) << V.get()->getType()
3598     << (IsReal ? "__real" : "__imag");
3599   return QualType();
3600 }
3601 
3602 
3603 
3604 ExprResult
3605 Sema::ActOnPostfixUnaryOp(Scope *S, SourceLocation OpLoc,
3606                           tok::TokenKind Kind, Expr *Input) {
3607   UnaryOperatorKind Opc;
3608   switch (Kind) {
3609   default: llvm_unreachable("Unknown unary op!");
3610   case tok::plusplus:   Opc = UO_PostInc; break;
3611   case tok::minusminus: Opc = UO_PostDec; break;
3612   }
3613 
3614   // Since this might is a postfix expression, get rid of ParenListExprs.
3615   ExprResult Result = MaybeConvertParenListExprToParenExpr(S, Input);
3616   if (Result.isInvalid()) return ExprError();
3617   Input = Result.take();
3618 
3619   return BuildUnaryOp(S, OpLoc, Opc, Input);
3620 }
3621 
3622 /// \brief Diagnose if arithmetic on the given ObjC pointer is illegal.
3623 ///
3624 /// \return true on error
3625 static bool checkArithmeticOnObjCPointer(Sema &S,
3626                                          SourceLocation opLoc,
3627                                          Expr *op) {
3628   assert(op->getType()->isObjCObjectPointerType());
3629   if (S.LangOpts.ObjCRuntime.allowsPointerArithmetic() &&
3630       !S.LangOpts.ObjCSubscriptingLegacyRuntime)
3631     return false;
3632 
3633   S.Diag(opLoc, diag::err_arithmetic_nonfragile_interface)
3634     << op->getType()->castAs<ObjCObjectPointerType>()->getPointeeType()
3635     << op->getSourceRange();
3636   return true;
3637 }
3638 
3639 ExprResult
3640 Sema::ActOnArraySubscriptExpr(Scope *S, Expr *base, SourceLocation lbLoc,
3641                               Expr *idx, SourceLocation rbLoc) {
3642   // Since this might be a postfix expression, get rid of ParenListExprs.
3643   if (isa<ParenListExpr>(base)) {
3644     ExprResult result = MaybeConvertParenListExprToParenExpr(S, base);
3645     if (result.isInvalid()) return ExprError();
3646     base = result.take();
3647   }
3648 
3649   // Handle any non-overload placeholder types in the base and index
3650   // expressions.  We can't handle overloads here because the other
3651   // operand might be an overloadable type, in which case the overload
3652   // resolution for the operator overload should get the first crack
3653   // at the overload.
3654   if (base->getType()->isNonOverloadPlaceholderType()) {
3655     ExprResult result = CheckPlaceholderExpr(base);
3656     if (result.isInvalid()) return ExprError();
3657     base = result.take();
3658   }
3659   if (idx->getType()->isNonOverloadPlaceholderType()) {
3660     ExprResult result = CheckPlaceholderExpr(idx);
3661     if (result.isInvalid()) return ExprError();
3662     idx = result.take();
3663   }
3664 
3665   // Build an unanalyzed expression if either operand is type-dependent.
3666   if (getLangOpts().CPlusPlus &&
3667       (base->isTypeDependent() || idx->isTypeDependent())) {
3668     return Owned(new (Context) ArraySubscriptExpr(base, idx,
3669                                                   Context.DependentTy,
3670                                                   VK_LValue, OK_Ordinary,
3671                                                   rbLoc));
3672   }
3673 
3674   // Use C++ overloaded-operator rules if either operand has record
3675   // type.  The spec says to do this if either type is *overloadable*,
3676   // but enum types can't declare subscript operators or conversion
3677   // operators, so there's nothing interesting for overload resolution
3678   // to do if there aren't any record types involved.
3679   //
3680   // ObjC pointers have their own subscripting logic that is not tied
3681   // to overload resolution and so should not take this path.
3682   if (getLangOpts().CPlusPlus &&
3683       (base->getType()->isRecordType() ||
3684        (!base->getType()->isObjCObjectPointerType() &&
3685         idx->getType()->isRecordType()))) {
3686     return CreateOverloadedArraySubscriptExpr(lbLoc, rbLoc, base, idx);
3687   }
3688 
3689   return CreateBuiltinArraySubscriptExpr(base, lbLoc, idx, rbLoc);
3690 }
3691 
3692 ExprResult
3693 Sema::CreateBuiltinArraySubscriptExpr(Expr *Base, SourceLocation LLoc,
3694                                       Expr *Idx, SourceLocation RLoc) {
3695   Expr *LHSExp = Base;
3696   Expr *RHSExp = Idx;
3697 
3698   // Perform default conversions.
3699   if (!LHSExp->getType()->getAs<VectorType>()) {
3700     ExprResult Result = DefaultFunctionArrayLvalueConversion(LHSExp);
3701     if (Result.isInvalid())
3702       return ExprError();
3703     LHSExp = Result.take();
3704   }
3705   ExprResult Result = DefaultFunctionArrayLvalueConversion(RHSExp);
3706   if (Result.isInvalid())
3707     return ExprError();
3708   RHSExp = Result.take();
3709 
3710   QualType LHSTy = LHSExp->getType(), RHSTy = RHSExp->getType();
3711   ExprValueKind VK = VK_LValue;
3712   ExprObjectKind OK = OK_Ordinary;
3713 
3714   // C99 6.5.2.1p2: the expression e1[e2] is by definition precisely equivalent
3715   // to the expression *((e1)+(e2)). This means the array "Base" may actually be
3716   // in the subscript position. As a result, we need to derive the array base
3717   // and index from the expression types.
3718   Expr *BaseExpr, *IndexExpr;
3719   QualType ResultType;
3720   if (LHSTy->isDependentType() || RHSTy->isDependentType()) {
3721     BaseExpr = LHSExp;
3722     IndexExpr = RHSExp;
3723     ResultType = Context.DependentTy;
3724   } else if (const PointerType *PTy = LHSTy->getAs<PointerType>()) {
3725     BaseExpr = LHSExp;
3726     IndexExpr = RHSExp;
3727     ResultType = PTy->getPointeeType();
3728   } else if (const ObjCObjectPointerType *PTy =
3729                LHSTy->getAs<ObjCObjectPointerType>()) {
3730     BaseExpr = LHSExp;
3731     IndexExpr = RHSExp;
3732 
3733     // Use custom logic if this should be the pseudo-object subscript
3734     // expression.
3735     if (!LangOpts.isSubscriptPointerArithmetic())
3736       return BuildObjCSubscriptExpression(RLoc, BaseExpr, IndexExpr, 0, 0);
3737 
3738     ResultType = PTy->getPointeeType();
3739   } else if (const PointerType *PTy = RHSTy->getAs<PointerType>()) {
3740      // Handle the uncommon case of "123[Ptr]".
3741     BaseExpr = RHSExp;
3742     IndexExpr = LHSExp;
3743     ResultType = PTy->getPointeeType();
3744   } else if (const ObjCObjectPointerType *PTy =
3745                RHSTy->getAs<ObjCObjectPointerType>()) {
3746      // Handle the uncommon case of "123[Ptr]".
3747     BaseExpr = RHSExp;
3748     IndexExpr = LHSExp;
3749     ResultType = PTy->getPointeeType();
3750     if (!LangOpts.isSubscriptPointerArithmetic()) {
3751       Diag(LLoc, diag::err_subscript_nonfragile_interface)
3752         << ResultType << BaseExpr->getSourceRange();
3753       return ExprError();
3754     }
3755   } else if (const VectorType *VTy = LHSTy->getAs<VectorType>()) {
3756     BaseExpr = LHSExp;    // vectors: V[123]
3757     IndexExpr = RHSExp;
3758     VK = LHSExp->getValueKind();
3759     if (VK != VK_RValue)
3760       OK = OK_VectorComponent;
3761 
3762     // FIXME: need to deal with const...
3763     ResultType = VTy->getElementType();
3764   } else if (LHSTy->isArrayType()) {
3765     // If we see an array that wasn't promoted by
3766     // DefaultFunctionArrayLvalueConversion, it must be an array that
3767     // wasn't promoted because of the C90 rule that doesn't
3768     // allow promoting non-lvalue arrays.  Warn, then
3769     // force the promotion here.
3770     Diag(LHSExp->getLocStart(), diag::ext_subscript_non_lvalue) <<
3771         LHSExp->getSourceRange();
3772     LHSExp = ImpCastExprToType(LHSExp, Context.getArrayDecayedType(LHSTy),
3773                                CK_ArrayToPointerDecay).take();
3774     LHSTy = LHSExp->getType();
3775 
3776     BaseExpr = LHSExp;
3777     IndexExpr = RHSExp;
3778     ResultType = LHSTy->getAs<PointerType>()->getPointeeType();
3779   } else if (RHSTy->isArrayType()) {
3780     // Same as previous, except for 123[f().a] case
3781     Diag(RHSExp->getLocStart(), diag::ext_subscript_non_lvalue) <<
3782         RHSExp->getSourceRange();
3783     RHSExp = ImpCastExprToType(RHSExp, Context.getArrayDecayedType(RHSTy),
3784                                CK_ArrayToPointerDecay).take();
3785     RHSTy = RHSExp->getType();
3786 
3787     BaseExpr = RHSExp;
3788     IndexExpr = LHSExp;
3789     ResultType = RHSTy->getAs<PointerType>()->getPointeeType();
3790   } else {
3791     return ExprError(Diag(LLoc, diag::err_typecheck_subscript_value)
3792        << LHSExp->getSourceRange() << RHSExp->getSourceRange());
3793   }
3794   // C99 6.5.2.1p1
3795   if (!IndexExpr->getType()->isIntegerType() && !IndexExpr->isTypeDependent())
3796     return ExprError(Diag(LLoc, diag::err_typecheck_subscript_not_integer)
3797                      << IndexExpr->getSourceRange());
3798 
3799   if ((IndexExpr->getType()->isSpecificBuiltinType(BuiltinType::Char_S) ||
3800        IndexExpr->getType()->isSpecificBuiltinType(BuiltinType::Char_U))
3801          && !IndexExpr->isTypeDependent())
3802     Diag(LLoc, diag::warn_subscript_is_char) << IndexExpr->getSourceRange();
3803 
3804   // C99 6.5.2.1p1: "shall have type "pointer to *object* type". Similarly,
3805   // C++ [expr.sub]p1: The type "T" shall be a completely-defined object
3806   // type. Note that Functions are not objects, and that (in C99 parlance)
3807   // incomplete types are not object types.
3808   if (ResultType->isFunctionType()) {
3809     Diag(BaseExpr->getLocStart(), diag::err_subscript_function_type)
3810       << ResultType << BaseExpr->getSourceRange();
3811     return ExprError();
3812   }
3813 
3814   if (ResultType->isVoidType() && !getLangOpts().CPlusPlus) {
3815     // GNU extension: subscripting on pointer to void
3816     Diag(LLoc, diag::ext_gnu_subscript_void_type)
3817       << BaseExpr->getSourceRange();
3818 
3819     // C forbids expressions of unqualified void type from being l-values.
3820     // See IsCForbiddenLValueType.
3821     if (!ResultType.hasQualifiers()) VK = VK_RValue;
3822   } else if (!ResultType->isDependentType() &&
3823       RequireCompleteType(LLoc, ResultType,
3824                           diag::err_subscript_incomplete_type, BaseExpr))
3825     return ExprError();
3826 
3827   assert(VK == VK_RValue || LangOpts.CPlusPlus ||
3828          !ResultType.isCForbiddenLValueType());
3829 
3830   return Owned(new (Context) ArraySubscriptExpr(LHSExp, RHSExp,
3831                                                 ResultType, VK, OK, RLoc));
3832 }
3833 
3834 ExprResult Sema::BuildCXXDefaultArgExpr(SourceLocation CallLoc,
3835                                         FunctionDecl *FD,
3836                                         ParmVarDecl *Param) {
3837   if (Param->hasUnparsedDefaultArg()) {
3838     Diag(CallLoc,
3839          diag::err_use_of_default_argument_to_function_declared_later) <<
3840       FD << cast<CXXRecordDecl>(FD->getDeclContext())->getDeclName();
3841     Diag(UnparsedDefaultArgLocs[Param],
3842          diag::note_default_argument_declared_here);
3843     return ExprError();
3844   }
3845 
3846   if (Param->hasUninstantiatedDefaultArg()) {
3847     Expr *UninstExpr = Param->getUninstantiatedDefaultArg();
3848 
3849     EnterExpressionEvaluationContext EvalContext(*this, PotentiallyEvaluated,
3850                                                  Param);
3851 
3852     // Instantiate the expression.
3853     MultiLevelTemplateArgumentList MutiLevelArgList
3854       = getTemplateInstantiationArgs(FD, 0, /*RelativeToPrimary=*/true);
3855 
3856     InstantiatingTemplate Inst(*this, CallLoc, Param,
3857                                MutiLevelArgList.getInnermost());
3858     if (Inst.isInvalid())
3859       return ExprError();
3860 
3861     ExprResult Result;
3862     {
3863       // C++ [dcl.fct.default]p5:
3864       //   The names in the [default argument] expression are bound, and
3865       //   the semantic constraints are checked, at the point where the
3866       //   default argument expression appears.
3867       ContextRAII SavedContext(*this, FD);
3868       LocalInstantiationScope Local(*this);
3869       Result = SubstExpr(UninstExpr, MutiLevelArgList);
3870     }
3871     if (Result.isInvalid())
3872       return ExprError();
3873 
3874     // Check the expression as an initializer for the parameter.
3875     InitializedEntity Entity
3876       = InitializedEntity::InitializeParameter(Context, Param);
3877     InitializationKind Kind
3878       = InitializationKind::CreateCopy(Param->getLocation(),
3879              /*FIXME:EqualLoc*/UninstExpr->getLocStart());
3880     Expr *ResultE = Result.takeAs<Expr>();
3881 
3882     InitializationSequence InitSeq(*this, Entity, Kind, ResultE);
3883     Result = InitSeq.Perform(*this, Entity, Kind, ResultE);
3884     if (Result.isInvalid())
3885       return ExprError();
3886 
3887     Expr *Arg = Result.takeAs<Expr>();
3888     CheckCompletedExpr(Arg, Param->getOuterLocStart());
3889     // Build the default argument expression.
3890     return Owned(CXXDefaultArgExpr::Create(Context, CallLoc, Param, Arg));
3891   }
3892 
3893   // If the default expression creates temporaries, we need to
3894   // push them to the current stack of expression temporaries so they'll
3895   // be properly destroyed.
3896   // FIXME: We should really be rebuilding the default argument with new
3897   // bound temporaries; see the comment in PR5810.
3898   // We don't need to do that with block decls, though, because
3899   // blocks in default argument expression can never capture anything.
3900   if (isa<ExprWithCleanups>(Param->getInit())) {
3901     // Set the "needs cleanups" bit regardless of whether there are
3902     // any explicit objects.
3903     ExprNeedsCleanups = true;
3904 
3905     // Append all the objects to the cleanup list.  Right now, this
3906     // should always be a no-op, because blocks in default argument
3907     // expressions should never be able to capture anything.
3908     assert(!cast<ExprWithCleanups>(Param->getInit())->getNumObjects() &&
3909            "default argument expression has capturing blocks?");
3910   }
3911 
3912   // We already type-checked the argument, so we know it works.
3913   // Just mark all of the declarations in this potentially-evaluated expression
3914   // as being "referenced".
3915   MarkDeclarationsReferencedInExpr(Param->getDefaultArg(),
3916                                    /*SkipLocalVariables=*/true);
3917   return Owned(CXXDefaultArgExpr::Create(Context, CallLoc, Param));
3918 }
3919 
3920 
3921 Sema::VariadicCallType
3922 Sema::getVariadicCallType(FunctionDecl *FDecl, const FunctionProtoType *Proto,
3923                           Expr *Fn) {
3924   if (Proto && Proto->isVariadic()) {
3925     if (dyn_cast_or_null<CXXConstructorDecl>(FDecl))
3926       return VariadicConstructor;
3927     else if (Fn && Fn->getType()->isBlockPointerType())
3928       return VariadicBlock;
3929     else if (FDecl) {
3930       if (CXXMethodDecl *Method = dyn_cast_or_null<CXXMethodDecl>(FDecl))
3931         if (Method->isInstance())
3932           return VariadicMethod;
3933     } else if (Fn && Fn->getType() == Context.BoundMemberTy)
3934       return VariadicMethod;
3935     return VariadicFunction;
3936   }
3937   return VariadicDoesNotApply;
3938 }
3939 
3940 namespace {
3941 class FunctionCallCCC : public FunctionCallFilterCCC {
3942 public:
3943   FunctionCallCCC(Sema &SemaRef, const IdentifierInfo *FuncName,
3944                   unsigned NumArgs, bool HasExplicitTemplateArgs)
3945       : FunctionCallFilterCCC(SemaRef, NumArgs, HasExplicitTemplateArgs),
3946         FunctionName(FuncName) {}
3947 
3948   virtual bool ValidateCandidate(const TypoCorrection &candidate) {
3949     if (!candidate.getCorrectionSpecifier() ||
3950         candidate.getCorrectionAsIdentifierInfo() != FunctionName) {
3951       return false;
3952     }
3953 
3954     return FunctionCallFilterCCC::ValidateCandidate(candidate);
3955   }
3956 
3957 private:
3958   const IdentifierInfo *const FunctionName;
3959 };
3960 }
3961 
3962 static TypoCorrection TryTypoCorrectionForCall(Sema &S,
3963                                                DeclarationNameInfo FuncName,
3964                                                ArrayRef<Expr *> Args) {
3965   FunctionCallCCC CCC(S, FuncName.getName().getAsIdentifierInfo(),
3966                       Args.size(), false);
3967   if (TypoCorrection Corrected =
3968           S.CorrectTypo(FuncName, Sema::LookupOrdinaryName,
3969                         S.getScopeForContext(S.CurContext), NULL, CCC)) {
3970     if (NamedDecl *ND = Corrected.getCorrectionDecl()) {
3971       if (Corrected.isOverloaded()) {
3972         OverloadCandidateSet OCS(FuncName.getLoc());
3973         OverloadCandidateSet::iterator Best;
3974         for (TypoCorrection::decl_iterator CD = Corrected.begin(),
3975                                            CDEnd = Corrected.end();
3976              CD != CDEnd; ++CD) {
3977           if (FunctionDecl *FD = dyn_cast<FunctionDecl>(*CD))
3978             S.AddOverloadCandidate(FD, DeclAccessPair::make(FD, AS_none), Args,
3979                                    OCS);
3980         }
3981         switch (OCS.BestViableFunction(S, FuncName.getLoc(), Best)) {
3982         case OR_Success:
3983           ND = Best->Function;
3984           Corrected.setCorrectionDecl(ND);
3985           break;
3986         default:
3987           break;
3988         }
3989       }
3990       if (isa<ValueDecl>(ND) || isa<FunctionTemplateDecl>(ND)) {
3991         return Corrected;
3992       }
3993     }
3994   }
3995   return TypoCorrection();
3996 }
3997 
3998 /// ConvertArgumentsForCall - Converts the arguments specified in
3999 /// Args/NumArgs to the parameter types of the function FDecl with
4000 /// function prototype Proto. Call is the call expression itself, and
4001 /// Fn is the function expression. For a C++ member function, this
4002 /// routine does not attempt to convert the object argument. Returns
4003 /// true if the call is ill-formed.
4004 bool
4005 Sema::ConvertArgumentsForCall(CallExpr *Call, Expr *Fn,
4006                               FunctionDecl *FDecl,
4007                               const FunctionProtoType *Proto,
4008                               ArrayRef<Expr *> Args,
4009                               SourceLocation RParenLoc,
4010                               bool IsExecConfig) {
4011   // Bail out early if calling a builtin with custom typechecking.
4012   // We don't need to do this in the
4013   if (FDecl)
4014     if (unsigned ID = FDecl->getBuiltinID())
4015       if (Context.BuiltinInfo.hasCustomTypechecking(ID))
4016         return false;
4017 
4018   // C99 6.5.2.2p7 - the arguments are implicitly converted, as if by
4019   // assignment, to the types of the corresponding parameter, ...
4020   unsigned NumArgsInProto = Proto->getNumArgs();
4021   bool Invalid = false;
4022   unsigned MinArgs = FDecl ? FDecl->getMinRequiredArguments() : NumArgsInProto;
4023   unsigned FnKind = Fn->getType()->isBlockPointerType()
4024                        ? 1 /* block */
4025                        : (IsExecConfig ? 3 /* kernel function (exec config) */
4026                                        : 0 /* function */);
4027 
4028   // If too few arguments are available (and we don't have default
4029   // arguments for the remaining parameters), don't make the call.
4030   if (Args.size() < NumArgsInProto) {
4031     if (Args.size() < MinArgs) {
4032       MemberExpr *ME = dyn_cast<MemberExpr>(Fn);
4033       TypoCorrection TC;
4034       if (FDecl && (TC = TryTypoCorrectionForCall(
4035                         *this, DeclarationNameInfo(FDecl->getDeclName(),
4036                                                    (ME ? ME->getMemberLoc()
4037                                                        : Fn->getLocStart())),
4038                         Args))) {
4039         unsigned diag_id =
4040             MinArgs == NumArgsInProto && !Proto->isVariadic()
4041                 ? diag::err_typecheck_call_too_few_args_suggest
4042                 : diag::err_typecheck_call_too_few_args_at_least_suggest;
4043         diagnoseTypo(TC, PDiag(diag_id) << FnKind << MinArgs
4044                                         << static_cast<unsigned>(Args.size())
4045                                         << Fn->getSourceRange());
4046       } else if (MinArgs == 1 && FDecl && FDecl->getParamDecl(0)->getDeclName())
4047         Diag(RParenLoc, MinArgs == NumArgsInProto && !Proto->isVariadic()
4048                           ? diag::err_typecheck_call_too_few_args_one
4049                           : diag::err_typecheck_call_too_few_args_at_least_one)
4050           << FnKind
4051           << FDecl->getParamDecl(0) << Fn->getSourceRange();
4052       else
4053         Diag(RParenLoc, MinArgs == NumArgsInProto && !Proto->isVariadic()
4054                           ? diag::err_typecheck_call_too_few_args
4055                           : diag::err_typecheck_call_too_few_args_at_least)
4056           << FnKind
4057           << MinArgs << static_cast<unsigned>(Args.size())
4058           << Fn->getSourceRange();
4059 
4060       // Emit the location of the prototype.
4061       if (!TC && FDecl && !FDecl->getBuiltinID() && !IsExecConfig)
4062         Diag(FDecl->getLocStart(), diag::note_callee_decl)
4063           << FDecl;
4064 
4065       return true;
4066     }
4067     Call->setNumArgs(Context, NumArgsInProto);
4068   }
4069 
4070   // If too many are passed and not variadic, error on the extras and drop
4071   // them.
4072   if (Args.size() > NumArgsInProto) {
4073     if (!Proto->isVariadic()) {
4074       TypoCorrection TC;
4075       if (FDecl && (TC = TryTypoCorrectionForCall(
4076                         *this, DeclarationNameInfo(FDecl->getDeclName(),
4077                                                    Fn->getLocStart()),
4078                         Args))) {
4079         unsigned diag_id =
4080             MinArgs == NumArgsInProto && !Proto->isVariadic()
4081                 ? diag::err_typecheck_call_too_many_args_suggest
4082                 : diag::err_typecheck_call_too_many_args_at_most_suggest;
4083         diagnoseTypo(TC, PDiag(diag_id) << FnKind << NumArgsInProto
4084                                         << static_cast<unsigned>(Args.size())
4085                                         << Fn->getSourceRange());
4086       } else if (NumArgsInProto == 1 && FDecl &&
4087                  FDecl->getParamDecl(0)->getDeclName())
4088         Diag(Args[NumArgsInProto]->getLocStart(),
4089              MinArgs == NumArgsInProto
4090                ? diag::err_typecheck_call_too_many_args_one
4091                : diag::err_typecheck_call_too_many_args_at_most_one)
4092           << FnKind
4093           << FDecl->getParamDecl(0) << static_cast<unsigned>(Args.size())
4094           << Fn->getSourceRange()
4095           << SourceRange(Args[NumArgsInProto]->getLocStart(),
4096                          Args.back()->getLocEnd());
4097       else
4098         Diag(Args[NumArgsInProto]->getLocStart(),
4099              MinArgs == NumArgsInProto
4100                ? diag::err_typecheck_call_too_many_args
4101                : diag::err_typecheck_call_too_many_args_at_most)
4102           << FnKind
4103           << NumArgsInProto << static_cast<unsigned>(Args.size())
4104           << Fn->getSourceRange()
4105           << SourceRange(Args[NumArgsInProto]->getLocStart(),
4106                          Args.back()->getLocEnd());
4107 
4108       // Emit the location of the prototype.
4109       if (!TC && FDecl && !FDecl->getBuiltinID() && !IsExecConfig)
4110         Diag(FDecl->getLocStart(), diag::note_callee_decl)
4111           << FDecl;
4112 
4113       // This deletes the extra arguments.
4114       Call->setNumArgs(Context, NumArgsInProto);
4115       return true;
4116     }
4117   }
4118   SmallVector<Expr *, 8> AllArgs;
4119   VariadicCallType CallType = getVariadicCallType(FDecl, Proto, Fn);
4120 
4121   Invalid = GatherArgumentsForCall(Call->getLocStart(), FDecl,
4122                                    Proto, 0, Args, AllArgs, CallType);
4123   if (Invalid)
4124     return true;
4125   unsigned TotalNumArgs = AllArgs.size();
4126   for (unsigned i = 0; i < TotalNumArgs; ++i)
4127     Call->setArg(i, AllArgs[i]);
4128 
4129   return false;
4130 }
4131 
4132 bool Sema::GatherArgumentsForCall(SourceLocation CallLoc,
4133                                   FunctionDecl *FDecl,
4134                                   const FunctionProtoType *Proto,
4135                                   unsigned FirstProtoArg,
4136                                   ArrayRef<Expr *> Args,
4137                                   SmallVectorImpl<Expr *> &AllArgs,
4138                                   VariadicCallType CallType,
4139                                   bool AllowExplicit,
4140                                   bool IsListInitialization) {
4141   unsigned NumArgsInProto = Proto->getNumArgs();
4142   unsigned NumArgsToCheck = Args.size();
4143   bool Invalid = false;
4144   if (Args.size() != NumArgsInProto)
4145     // Use default arguments for missing arguments
4146     NumArgsToCheck = NumArgsInProto;
4147   unsigned ArgIx = 0;
4148   // Continue to check argument types (even if we have too few/many args).
4149   for (unsigned i = FirstProtoArg; i != NumArgsToCheck; i++) {
4150     QualType ProtoArgType = Proto->getArgType(i);
4151 
4152     Expr *Arg;
4153     ParmVarDecl *Param;
4154     if (ArgIx < Args.size()) {
4155       Arg = Args[ArgIx++];
4156 
4157       if (RequireCompleteType(Arg->getLocStart(),
4158                               ProtoArgType,
4159                               diag::err_call_incomplete_argument, Arg))
4160         return true;
4161 
4162       // Pass the argument
4163       Param = 0;
4164       if (FDecl && i < FDecl->getNumParams())
4165         Param = FDecl->getParamDecl(i);
4166 
4167       // Strip the unbridged-cast placeholder expression off, if applicable.
4168       bool CFAudited = false;
4169       if (Arg->getType() == Context.ARCUnbridgedCastTy &&
4170           FDecl && FDecl->hasAttr<CFAuditedTransferAttr>() &&
4171           (!Param || !Param->hasAttr<CFConsumedAttr>()))
4172         Arg = stripARCUnbridgedCast(Arg);
4173       else if (getLangOpts().ObjCAutoRefCount &&
4174                FDecl && FDecl->hasAttr<CFAuditedTransferAttr>() &&
4175                (!Param || !Param->hasAttr<CFConsumedAttr>()))
4176         CFAudited = true;
4177 
4178       InitializedEntity Entity = Param ?
4179           InitializedEntity::InitializeParameter(Context, Param, ProtoArgType)
4180         : InitializedEntity::InitializeParameter(Context, ProtoArgType,
4181                                                  Proto->isArgConsumed(i));
4182 
4183       // Remember that parameter belongs to a CF audited API.
4184       if (CFAudited)
4185         Entity.setParameterCFAudited();
4186 
4187       ExprResult ArgE = PerformCopyInitialization(Entity,
4188                                                   SourceLocation(),
4189                                                   Owned(Arg),
4190                                                   IsListInitialization,
4191                                                   AllowExplicit);
4192       if (ArgE.isInvalid())
4193         return true;
4194 
4195       Arg = ArgE.takeAs<Expr>();
4196     } else {
4197       assert(FDecl && "can't use default arguments without a known callee");
4198       Param = FDecl->getParamDecl(i);
4199 
4200       ExprResult ArgExpr =
4201         BuildCXXDefaultArgExpr(CallLoc, FDecl, Param);
4202       if (ArgExpr.isInvalid())
4203         return true;
4204 
4205       Arg = ArgExpr.takeAs<Expr>();
4206     }
4207 
4208     // Check for array bounds violations for each argument to the call. This
4209     // check only triggers warnings when the argument isn't a more complex Expr
4210     // with its own checking, such as a BinaryOperator.
4211     CheckArrayAccess(Arg);
4212 
4213     // Check for violations of C99 static array rules (C99 6.7.5.3p7).
4214     CheckStaticArrayArgument(CallLoc, Param, Arg);
4215 
4216     AllArgs.push_back(Arg);
4217   }
4218 
4219   // If this is a variadic call, handle args passed through "...".
4220   if (CallType != VariadicDoesNotApply) {
4221     // Assume that extern "C" functions with variadic arguments that
4222     // return __unknown_anytype aren't *really* variadic.
4223     if (Proto->getResultType() == Context.UnknownAnyTy &&
4224         FDecl && FDecl->isExternC()) {
4225       for (unsigned i = ArgIx, e = Args.size(); i != e; ++i) {
4226         QualType paramType; // ignored
4227         ExprResult arg = checkUnknownAnyArg(CallLoc, Args[i], paramType);
4228         Invalid |= arg.isInvalid();
4229         AllArgs.push_back(arg.take());
4230       }
4231 
4232     // Otherwise do argument promotion, (C99 6.5.2.2p7).
4233     } else {
4234       for (unsigned i = ArgIx, e = Args.size(); i != e; ++i) {
4235         ExprResult Arg = DefaultVariadicArgumentPromotion(Args[i], CallType,
4236                                                           FDecl);
4237         Invalid |= Arg.isInvalid();
4238         AllArgs.push_back(Arg.take());
4239       }
4240     }
4241 
4242     // Check for array bounds violations.
4243     for (unsigned i = ArgIx, e = Args.size(); i != e; ++i)
4244       CheckArrayAccess(Args[i]);
4245   }
4246   return Invalid;
4247 }
4248 
4249 static void DiagnoseCalleeStaticArrayParam(Sema &S, ParmVarDecl *PVD) {
4250   TypeLoc TL = PVD->getTypeSourceInfo()->getTypeLoc();
4251   if (DecayedTypeLoc DTL = TL.getAs<DecayedTypeLoc>())
4252     TL = DTL.getOriginalLoc();
4253   if (ArrayTypeLoc ATL = TL.getAs<ArrayTypeLoc>())
4254     S.Diag(PVD->getLocation(), diag::note_callee_static_array)
4255       << ATL.getLocalSourceRange();
4256 }
4257 
4258 /// CheckStaticArrayArgument - If the given argument corresponds to a static
4259 /// array parameter, check that it is non-null, and that if it is formed by
4260 /// array-to-pointer decay, the underlying array is sufficiently large.
4261 ///
4262 /// C99 6.7.5.3p7: If the keyword static also appears within the [ and ] of the
4263 /// array type derivation, then for each call to the function, the value of the
4264 /// corresponding actual argument shall provide access to the first element of
4265 /// an array with at least as many elements as specified by the size expression.
4266 void
4267 Sema::CheckStaticArrayArgument(SourceLocation CallLoc,
4268                                ParmVarDecl *Param,
4269                                const Expr *ArgExpr) {
4270   // Static array parameters are not supported in C++.
4271   if (!Param || getLangOpts().CPlusPlus)
4272     return;
4273 
4274   QualType OrigTy = Param->getOriginalType();
4275 
4276   const ArrayType *AT = Context.getAsArrayType(OrigTy);
4277   if (!AT || AT->getSizeModifier() != ArrayType::Static)
4278     return;
4279 
4280   if (ArgExpr->isNullPointerConstant(Context,
4281                                      Expr::NPC_NeverValueDependent)) {
4282     Diag(CallLoc, diag::warn_null_arg) << ArgExpr->getSourceRange();
4283     DiagnoseCalleeStaticArrayParam(*this, Param);
4284     return;
4285   }
4286 
4287   const ConstantArrayType *CAT = dyn_cast<ConstantArrayType>(AT);
4288   if (!CAT)
4289     return;
4290 
4291   const ConstantArrayType *ArgCAT =
4292     Context.getAsConstantArrayType(ArgExpr->IgnoreParenImpCasts()->getType());
4293   if (!ArgCAT)
4294     return;
4295 
4296   if (ArgCAT->getSize().ult(CAT->getSize())) {
4297     Diag(CallLoc, diag::warn_static_array_too_small)
4298       << ArgExpr->getSourceRange()
4299       << (unsigned) ArgCAT->getSize().getZExtValue()
4300       << (unsigned) CAT->getSize().getZExtValue();
4301     DiagnoseCalleeStaticArrayParam(*this, Param);
4302   }
4303 }
4304 
4305 /// Given a function expression of unknown-any type, try to rebuild it
4306 /// to have a function type.
4307 static ExprResult rebuildUnknownAnyFunction(Sema &S, Expr *fn);
4308 
4309 /// Is the given type a placeholder that we need to lower out
4310 /// immediately during argument processing?
4311 static bool isPlaceholderToRemoveAsArg(QualType type) {
4312   // Placeholders are never sugared.
4313   const BuiltinType *placeholder = dyn_cast<BuiltinType>(type);
4314   if (!placeholder) return false;
4315 
4316   switch (placeholder->getKind()) {
4317   // Ignore all the non-placeholder types.
4318 #define PLACEHOLDER_TYPE(ID, SINGLETON_ID)
4319 #define BUILTIN_TYPE(ID, SINGLETON_ID) case BuiltinType::ID:
4320 #include "clang/AST/BuiltinTypes.def"
4321     return false;
4322 
4323   // We cannot lower out overload sets; they might validly be resolved
4324   // by the call machinery.
4325   case BuiltinType::Overload:
4326     return false;
4327 
4328   // Unbridged casts in ARC can be handled in some call positions and
4329   // should be left in place.
4330   case BuiltinType::ARCUnbridgedCast:
4331     return false;
4332 
4333   // Pseudo-objects should be converted as soon as possible.
4334   case BuiltinType::PseudoObject:
4335     return true;
4336 
4337   // The debugger mode could theoretically but currently does not try
4338   // to resolve unknown-typed arguments based on known parameter types.
4339   case BuiltinType::UnknownAny:
4340     return true;
4341 
4342   // These are always invalid as call arguments and should be reported.
4343   case BuiltinType::BoundMember:
4344   case BuiltinType::BuiltinFn:
4345     return true;
4346   }
4347   llvm_unreachable("bad builtin type kind");
4348 }
4349 
4350 /// Check an argument list for placeholders that we won't try to
4351 /// handle later.
4352 static bool checkArgsForPlaceholders(Sema &S, MultiExprArg args) {
4353   // Apply this processing to all the arguments at once instead of
4354   // dying at the first failure.
4355   bool hasInvalid = false;
4356   for (size_t i = 0, e = args.size(); i != e; i++) {
4357     if (isPlaceholderToRemoveAsArg(args[i]->getType())) {
4358       ExprResult result = S.CheckPlaceholderExpr(args[i]);
4359       if (result.isInvalid()) hasInvalid = true;
4360       else args[i] = result.take();
4361     }
4362   }
4363   return hasInvalid;
4364 }
4365 
4366 /// ActOnCallExpr - Handle a call to Fn with the specified array of arguments.
4367 /// This provides the location of the left/right parens and a list of comma
4368 /// locations.
4369 ExprResult
4370 Sema::ActOnCallExpr(Scope *S, Expr *Fn, SourceLocation LParenLoc,
4371                     MultiExprArg ArgExprs, SourceLocation RParenLoc,
4372                     Expr *ExecConfig, bool IsExecConfig) {
4373   // Since this might be a postfix expression, get rid of ParenListExprs.
4374   ExprResult Result = MaybeConvertParenListExprToParenExpr(S, Fn);
4375   if (Result.isInvalid()) return ExprError();
4376   Fn = Result.take();
4377 
4378   if (checkArgsForPlaceholders(*this, ArgExprs))
4379     return ExprError();
4380 
4381   if (getLangOpts().CPlusPlus) {
4382     // If this is a pseudo-destructor expression, build the call immediately.
4383     if (isa<CXXPseudoDestructorExpr>(Fn)) {
4384       if (!ArgExprs.empty()) {
4385         // Pseudo-destructor calls should not have any arguments.
4386         Diag(Fn->getLocStart(), diag::err_pseudo_dtor_call_with_args)
4387           << FixItHint::CreateRemoval(
4388                                     SourceRange(ArgExprs[0]->getLocStart(),
4389                                                 ArgExprs.back()->getLocEnd()));
4390       }
4391 
4392       return Owned(new (Context) CallExpr(Context, Fn, None,
4393                                           Context.VoidTy, VK_RValue,
4394                                           RParenLoc));
4395     }
4396     if (Fn->getType() == Context.PseudoObjectTy) {
4397       ExprResult result = CheckPlaceholderExpr(Fn);
4398       if (result.isInvalid()) return ExprError();
4399       Fn = result.take();
4400     }
4401 
4402     // Determine whether this is a dependent call inside a C++ template,
4403     // in which case we won't do any semantic analysis now.
4404     // FIXME: Will need to cache the results of name lookup (including ADL) in
4405     // Fn.
4406     bool Dependent = false;
4407     if (Fn->isTypeDependent())
4408       Dependent = true;
4409     else if (Expr::hasAnyTypeDependentArguments(ArgExprs))
4410       Dependent = true;
4411 
4412     if (Dependent) {
4413       if (ExecConfig) {
4414         return Owned(new (Context) CUDAKernelCallExpr(
4415             Context, Fn, cast<CallExpr>(ExecConfig), ArgExprs,
4416             Context.DependentTy, VK_RValue, RParenLoc));
4417       } else {
4418         return Owned(new (Context) CallExpr(Context, Fn, ArgExprs,
4419                                             Context.DependentTy, VK_RValue,
4420                                             RParenLoc));
4421       }
4422     }
4423 
4424     // Determine whether this is a call to an object (C++ [over.call.object]).
4425     if (Fn->getType()->isRecordType())
4426       return Owned(BuildCallToObjectOfClassType(S, Fn, LParenLoc,
4427                                                 ArgExprs, RParenLoc));
4428 
4429     if (Fn->getType() == Context.UnknownAnyTy) {
4430       ExprResult result = rebuildUnknownAnyFunction(*this, Fn);
4431       if (result.isInvalid()) return ExprError();
4432       Fn = result.take();
4433     }
4434 
4435     if (Fn->getType() == Context.BoundMemberTy) {
4436       return BuildCallToMemberFunction(S, Fn, LParenLoc, ArgExprs, RParenLoc);
4437     }
4438   }
4439 
4440   // Check for overloaded calls.  This can happen even in C due to extensions.
4441   if (Fn->getType() == Context.OverloadTy) {
4442     OverloadExpr::FindResult find = OverloadExpr::find(Fn);
4443 
4444     // We aren't supposed to apply this logic for if there's an '&' involved.
4445     if (!find.HasFormOfMemberPointer) {
4446       OverloadExpr *ovl = find.Expression;
4447       if (isa<UnresolvedLookupExpr>(ovl)) {
4448         UnresolvedLookupExpr *ULE = cast<UnresolvedLookupExpr>(ovl);
4449         return BuildOverloadedCallExpr(S, Fn, ULE, LParenLoc, ArgExprs,
4450                                        RParenLoc, ExecConfig);
4451       } else {
4452         return BuildCallToMemberFunction(S, Fn, LParenLoc, ArgExprs,
4453                                          RParenLoc);
4454       }
4455     }
4456   }
4457 
4458   // If we're directly calling a function, get the appropriate declaration.
4459   if (Fn->getType() == Context.UnknownAnyTy) {
4460     ExprResult result = rebuildUnknownAnyFunction(*this, Fn);
4461     if (result.isInvalid()) return ExprError();
4462     Fn = result.take();
4463   }
4464 
4465   Expr *NakedFn = Fn->IgnoreParens();
4466 
4467   NamedDecl *NDecl = 0;
4468   if (UnaryOperator *UnOp = dyn_cast<UnaryOperator>(NakedFn))
4469     if (UnOp->getOpcode() == UO_AddrOf)
4470       NakedFn = UnOp->getSubExpr()->IgnoreParens();
4471 
4472   if (isa<DeclRefExpr>(NakedFn))
4473     NDecl = cast<DeclRefExpr>(NakedFn)->getDecl();
4474   else if (isa<MemberExpr>(NakedFn))
4475     NDecl = cast<MemberExpr>(NakedFn)->getMemberDecl();
4476 
4477   if (FunctionDecl *FD = dyn_cast_or_null<FunctionDecl>(NDecl)) {
4478     if (FD->hasAttr<EnableIfAttr>()) {
4479       if (const EnableIfAttr *Attr = CheckEnableIf(FD, ArgExprs, true)) {
4480         Diag(Fn->getLocStart(),
4481              isa<CXXMethodDecl>(FD) ?
4482                  diag::err_ovl_no_viable_member_function_in_call :
4483                  diag::err_ovl_no_viable_function_in_call)
4484           << FD << FD->getSourceRange();
4485         Diag(FD->getLocation(),
4486              diag::note_ovl_candidate_disabled_by_enable_if_attr)
4487             << Attr->getCond()->getSourceRange() << Attr->getMessage();
4488       }
4489     }
4490   }
4491 
4492   return BuildResolvedCallExpr(Fn, NDecl, LParenLoc, ArgExprs, RParenLoc,
4493                                ExecConfig, IsExecConfig);
4494 }
4495 
4496 ExprResult
4497 Sema::ActOnCUDAExecConfigExpr(Scope *S, SourceLocation LLLLoc,
4498                               MultiExprArg ExecConfig, SourceLocation GGGLoc) {
4499   FunctionDecl *ConfigDecl = Context.getcudaConfigureCallDecl();
4500   if (!ConfigDecl)
4501     return ExprError(Diag(LLLLoc, diag::err_undeclared_var_use)
4502                           << "cudaConfigureCall");
4503   QualType ConfigQTy = ConfigDecl->getType();
4504 
4505   DeclRefExpr *ConfigDR = new (Context) DeclRefExpr(
4506       ConfigDecl, false, ConfigQTy, VK_LValue, LLLLoc);
4507   MarkFunctionReferenced(LLLLoc, ConfigDecl);
4508 
4509   return ActOnCallExpr(S, ConfigDR, LLLLoc, ExecConfig, GGGLoc, 0,
4510                        /*IsExecConfig=*/true);
4511 }
4512 
4513 /// ActOnAsTypeExpr - create a new asType (bitcast) from the arguments.
4514 ///
4515 /// __builtin_astype( value, dst type )
4516 ///
4517 ExprResult Sema::ActOnAsTypeExpr(Expr *E, ParsedType ParsedDestTy,
4518                                  SourceLocation BuiltinLoc,
4519                                  SourceLocation RParenLoc) {
4520   ExprValueKind VK = VK_RValue;
4521   ExprObjectKind OK = OK_Ordinary;
4522   QualType DstTy = GetTypeFromParser(ParsedDestTy);
4523   QualType SrcTy = E->getType();
4524   if (Context.getTypeSize(DstTy) != Context.getTypeSize(SrcTy))
4525     return ExprError(Diag(BuiltinLoc,
4526                           diag::err_invalid_astype_of_different_size)
4527                      << DstTy
4528                      << SrcTy
4529                      << E->getSourceRange());
4530   return Owned(new (Context) AsTypeExpr(E, DstTy, VK, OK, BuiltinLoc,
4531                RParenLoc));
4532 }
4533 
4534 /// ActOnConvertVectorExpr - create a new convert-vector expression from the
4535 /// provided arguments.
4536 ///
4537 /// __builtin_convertvector( value, dst type )
4538 ///
4539 ExprResult Sema::ActOnConvertVectorExpr(Expr *E, ParsedType ParsedDestTy,
4540                                         SourceLocation BuiltinLoc,
4541                                         SourceLocation RParenLoc) {
4542   TypeSourceInfo *TInfo;
4543   GetTypeFromParser(ParsedDestTy, &TInfo);
4544   return SemaConvertVectorExpr(E, TInfo, BuiltinLoc, RParenLoc);
4545 }
4546 
4547 /// BuildResolvedCallExpr - Build a call to a resolved expression,
4548 /// i.e. an expression not of \p OverloadTy.  The expression should
4549 /// unary-convert to an expression of function-pointer or
4550 /// block-pointer type.
4551 ///
4552 /// \param NDecl the declaration being called, if available
4553 ExprResult
4554 Sema::BuildResolvedCallExpr(Expr *Fn, NamedDecl *NDecl,
4555                             SourceLocation LParenLoc,
4556                             ArrayRef<Expr *> Args,
4557                             SourceLocation RParenLoc,
4558                             Expr *Config, bool IsExecConfig) {
4559   FunctionDecl *FDecl = dyn_cast_or_null<FunctionDecl>(NDecl);
4560   unsigned BuiltinID = (FDecl ? FDecl->getBuiltinID() : 0);
4561 
4562   // Promote the function operand.
4563   // We special-case function promotion here because we only allow promoting
4564   // builtin functions to function pointers in the callee of a call.
4565   ExprResult Result;
4566   if (BuiltinID &&
4567       Fn->getType()->isSpecificBuiltinType(BuiltinType::BuiltinFn)) {
4568     Result = ImpCastExprToType(Fn, Context.getPointerType(FDecl->getType()),
4569                                CK_BuiltinFnToFnPtr).take();
4570   } else {
4571     Result = UsualUnaryConversions(Fn);
4572   }
4573   if (Result.isInvalid())
4574     return ExprError();
4575   Fn = Result.take();
4576 
4577   // Make the call expr early, before semantic checks.  This guarantees cleanup
4578   // of arguments and function on error.
4579   CallExpr *TheCall;
4580   if (Config)
4581     TheCall = new (Context) CUDAKernelCallExpr(Context, Fn,
4582                                                cast<CallExpr>(Config), Args,
4583                                                Context.BoolTy, VK_RValue,
4584                                                RParenLoc);
4585   else
4586     TheCall = new (Context) CallExpr(Context, Fn, Args, Context.BoolTy,
4587                                      VK_RValue, RParenLoc);
4588 
4589   // Bail out early if calling a builtin with custom typechecking.
4590   if (BuiltinID && Context.BuiltinInfo.hasCustomTypechecking(BuiltinID))
4591     return CheckBuiltinFunctionCall(BuiltinID, TheCall);
4592 
4593  retry:
4594   const FunctionType *FuncT;
4595   if (const PointerType *PT = Fn->getType()->getAs<PointerType>()) {
4596     // C99 6.5.2.2p1 - "The expression that denotes the called function shall
4597     // have type pointer to function".
4598     FuncT = PT->getPointeeType()->getAs<FunctionType>();
4599     if (FuncT == 0)
4600       return ExprError(Diag(LParenLoc, diag::err_typecheck_call_not_function)
4601                          << Fn->getType() << Fn->getSourceRange());
4602   } else if (const BlockPointerType *BPT =
4603                Fn->getType()->getAs<BlockPointerType>()) {
4604     FuncT = BPT->getPointeeType()->castAs<FunctionType>();
4605   } else {
4606     // Handle calls to expressions of unknown-any type.
4607     if (Fn->getType() == Context.UnknownAnyTy) {
4608       ExprResult rewrite = rebuildUnknownAnyFunction(*this, Fn);
4609       if (rewrite.isInvalid()) return ExprError();
4610       Fn = rewrite.take();
4611       TheCall->setCallee(Fn);
4612       goto retry;
4613     }
4614 
4615     return ExprError(Diag(LParenLoc, diag::err_typecheck_call_not_function)
4616       << Fn->getType() << Fn->getSourceRange());
4617   }
4618 
4619   if (getLangOpts().CUDA) {
4620     if (Config) {
4621       // CUDA: Kernel calls must be to global functions
4622       if (FDecl && !FDecl->hasAttr<CUDAGlobalAttr>())
4623         return ExprError(Diag(LParenLoc,diag::err_kern_call_not_global_function)
4624             << FDecl->getName() << Fn->getSourceRange());
4625 
4626       // CUDA: Kernel function must have 'void' return type
4627       if (!FuncT->getResultType()->isVoidType())
4628         return ExprError(Diag(LParenLoc, diag::err_kern_type_not_void_return)
4629             << Fn->getType() << Fn->getSourceRange());
4630     } else {
4631       // CUDA: Calls to global functions must be configured
4632       if (FDecl && FDecl->hasAttr<CUDAGlobalAttr>())
4633         return ExprError(Diag(LParenLoc, diag::err_global_call_not_config)
4634             << FDecl->getName() << Fn->getSourceRange());
4635     }
4636   }
4637 
4638   // Check for a valid return type
4639   if (CheckCallReturnType(FuncT->getResultType(),
4640                           Fn->getLocStart(), TheCall,
4641                           FDecl))
4642     return ExprError();
4643 
4644   // We know the result type of the call, set it.
4645   TheCall->setType(FuncT->getCallResultType(Context));
4646   TheCall->setValueKind(Expr::getValueKindForType(FuncT->getResultType()));
4647 
4648   const FunctionProtoType *Proto = dyn_cast<FunctionProtoType>(FuncT);
4649   if (Proto) {
4650     if (ConvertArgumentsForCall(TheCall, Fn, FDecl, Proto, Args, RParenLoc,
4651                                 IsExecConfig))
4652       return ExprError();
4653   } else {
4654     assert(isa<FunctionNoProtoType>(FuncT) && "Unknown FunctionType!");
4655 
4656     if (FDecl) {
4657       // Check if we have too few/too many template arguments, based
4658       // on our knowledge of the function definition.
4659       const FunctionDecl *Def = 0;
4660       if (FDecl->hasBody(Def) && Args.size() != Def->param_size()) {
4661         Proto = Def->getType()->getAs<FunctionProtoType>();
4662        if (!Proto || !(Proto->isVariadic() && Args.size() >= Def->param_size()))
4663           Diag(RParenLoc, diag::warn_call_wrong_number_of_arguments)
4664           << (Args.size() > Def->param_size()) << FDecl << Fn->getSourceRange();
4665       }
4666 
4667       // If the function we're calling isn't a function prototype, but we have
4668       // a function prototype from a prior declaratiom, use that prototype.
4669       if (!FDecl->hasPrototype())
4670         Proto = FDecl->getType()->getAs<FunctionProtoType>();
4671     }
4672 
4673     // Promote the arguments (C99 6.5.2.2p6).
4674     for (unsigned i = 0, e = Args.size(); i != e; i++) {
4675       Expr *Arg = Args[i];
4676 
4677       if (Proto && i < Proto->getNumArgs()) {
4678         InitializedEntity Entity
4679           = InitializedEntity::InitializeParameter(Context,
4680                                                    Proto->getArgType(i),
4681                                                    Proto->isArgConsumed(i));
4682         ExprResult ArgE = PerformCopyInitialization(Entity,
4683                                                     SourceLocation(),
4684                                                     Owned(Arg));
4685         if (ArgE.isInvalid())
4686           return true;
4687 
4688         Arg = ArgE.takeAs<Expr>();
4689 
4690       } else {
4691         ExprResult ArgE = DefaultArgumentPromotion(Arg);
4692 
4693         if (ArgE.isInvalid())
4694           return true;
4695 
4696         Arg = ArgE.takeAs<Expr>();
4697       }
4698 
4699       if (RequireCompleteType(Arg->getLocStart(),
4700                               Arg->getType(),
4701                               diag::err_call_incomplete_argument, Arg))
4702         return ExprError();
4703 
4704       TheCall->setArg(i, Arg);
4705     }
4706   }
4707 
4708   if (CXXMethodDecl *Method = dyn_cast_or_null<CXXMethodDecl>(FDecl))
4709     if (!Method->isStatic())
4710       return ExprError(Diag(LParenLoc, diag::err_member_call_without_object)
4711         << Fn->getSourceRange());
4712 
4713   // Check for sentinels
4714   if (NDecl)
4715     DiagnoseSentinelCalls(NDecl, LParenLoc, Args);
4716 
4717   // Do special checking on direct calls to functions.
4718   if (FDecl) {
4719     if (CheckFunctionCall(FDecl, TheCall, Proto))
4720       return ExprError();
4721 
4722     if (BuiltinID)
4723       return CheckBuiltinFunctionCall(BuiltinID, TheCall);
4724   } else if (NDecl) {
4725     if (CheckPointerCall(NDecl, TheCall, Proto))
4726       return ExprError();
4727   } else {
4728     if (CheckOtherCall(TheCall, Proto))
4729       return ExprError();
4730   }
4731 
4732   return MaybeBindToTemporary(TheCall);
4733 }
4734 
4735 ExprResult
4736 Sema::ActOnCompoundLiteral(SourceLocation LParenLoc, ParsedType Ty,
4737                            SourceLocation RParenLoc, Expr *InitExpr) {
4738   assert(Ty && "ActOnCompoundLiteral(): missing type");
4739   // FIXME: put back this assert when initializers are worked out.
4740   //assert((InitExpr != 0) && "ActOnCompoundLiteral(): missing expression");
4741 
4742   TypeSourceInfo *TInfo;
4743   QualType literalType = GetTypeFromParser(Ty, &TInfo);
4744   if (!TInfo)
4745     TInfo = Context.getTrivialTypeSourceInfo(literalType);
4746 
4747   return BuildCompoundLiteralExpr(LParenLoc, TInfo, RParenLoc, InitExpr);
4748 }
4749 
4750 ExprResult
4751 Sema::BuildCompoundLiteralExpr(SourceLocation LParenLoc, TypeSourceInfo *TInfo,
4752                                SourceLocation RParenLoc, Expr *LiteralExpr) {
4753   QualType literalType = TInfo->getType();
4754 
4755   if (literalType->isArrayType()) {
4756     if (RequireCompleteType(LParenLoc, Context.getBaseElementType(literalType),
4757           diag::err_illegal_decl_array_incomplete_type,
4758           SourceRange(LParenLoc,
4759                       LiteralExpr->getSourceRange().getEnd())))
4760       return ExprError();
4761     if (literalType->isVariableArrayType())
4762       return ExprError(Diag(LParenLoc, diag::err_variable_object_no_init)
4763         << SourceRange(LParenLoc, LiteralExpr->getSourceRange().getEnd()));
4764   } else if (!literalType->isDependentType() &&
4765              RequireCompleteType(LParenLoc, literalType,
4766                diag::err_typecheck_decl_incomplete_type,
4767                SourceRange(LParenLoc, LiteralExpr->getSourceRange().getEnd())))
4768     return ExprError();
4769 
4770   InitializedEntity Entity
4771     = InitializedEntity::InitializeCompoundLiteralInit(TInfo);
4772   InitializationKind Kind
4773     = InitializationKind::CreateCStyleCast(LParenLoc,
4774                                            SourceRange(LParenLoc, RParenLoc),
4775                                            /*InitList=*/true);
4776   InitializationSequence InitSeq(*this, Entity, Kind, LiteralExpr);
4777   ExprResult Result = InitSeq.Perform(*this, Entity, Kind, LiteralExpr,
4778                                       &literalType);
4779   if (Result.isInvalid())
4780     return ExprError();
4781   LiteralExpr = Result.get();
4782 
4783   bool isFileScope = getCurFunctionOrMethodDecl() == 0;
4784   if (isFileScope &&
4785       !LiteralExpr->isTypeDependent() &&
4786       !LiteralExpr->isValueDependent() &&
4787       !literalType->isDependentType()) { // 6.5.2.5p3
4788     if (CheckForConstantInitializer(LiteralExpr, literalType))
4789       return ExprError();
4790   }
4791 
4792   // In C, compound literals are l-values for some reason.
4793   ExprValueKind VK = getLangOpts().CPlusPlus ? VK_RValue : VK_LValue;
4794 
4795   return MaybeBindToTemporary(
4796            new (Context) CompoundLiteralExpr(LParenLoc, TInfo, literalType,
4797                                              VK, LiteralExpr, isFileScope));
4798 }
4799 
4800 ExprResult
4801 Sema::ActOnInitList(SourceLocation LBraceLoc, MultiExprArg InitArgList,
4802                     SourceLocation RBraceLoc) {
4803   // Immediately handle non-overload placeholders.  Overloads can be
4804   // resolved contextually, but everything else here can't.
4805   for (unsigned I = 0, E = InitArgList.size(); I != E; ++I) {
4806     if (InitArgList[I]->getType()->isNonOverloadPlaceholderType()) {
4807       ExprResult result = CheckPlaceholderExpr(InitArgList[I]);
4808 
4809       // Ignore failures; dropping the entire initializer list because
4810       // of one failure would be terrible for indexing/etc.
4811       if (result.isInvalid()) continue;
4812 
4813       InitArgList[I] = result.take();
4814     }
4815   }
4816 
4817   // Semantic analysis for initializers is done by ActOnDeclarator() and
4818   // CheckInitializer() - it requires knowledge of the object being intialized.
4819 
4820   InitListExpr *E = new (Context) InitListExpr(Context, LBraceLoc, InitArgList,
4821                                                RBraceLoc);
4822   E->setType(Context.VoidTy); // FIXME: just a place holder for now.
4823   return Owned(E);
4824 }
4825 
4826 /// Do an explicit extend of the given block pointer if we're in ARC.
4827 static void maybeExtendBlockObject(Sema &S, ExprResult &E) {
4828   assert(E.get()->getType()->isBlockPointerType());
4829   assert(E.get()->isRValue());
4830 
4831   // Only do this in an r-value context.
4832   if (!S.getLangOpts().ObjCAutoRefCount) return;
4833 
4834   E = ImplicitCastExpr::Create(S.Context, E.get()->getType(),
4835                                CK_ARCExtendBlockObject, E.get(),
4836                                /*base path*/ 0, VK_RValue);
4837   S.ExprNeedsCleanups = true;
4838 }
4839 
4840 /// Prepare a conversion of the given expression to an ObjC object
4841 /// pointer type.
4842 CastKind Sema::PrepareCastToObjCObjectPointer(ExprResult &E) {
4843   QualType type = E.get()->getType();
4844   if (type->isObjCObjectPointerType()) {
4845     return CK_BitCast;
4846   } else if (type->isBlockPointerType()) {
4847     maybeExtendBlockObject(*this, E);
4848     return CK_BlockPointerToObjCPointerCast;
4849   } else {
4850     assert(type->isPointerType());
4851     return CK_CPointerToObjCPointerCast;
4852   }
4853 }
4854 
4855 /// Prepares for a scalar cast, performing all the necessary stages
4856 /// except the final cast and returning the kind required.
4857 CastKind Sema::PrepareScalarCast(ExprResult &Src, QualType DestTy) {
4858   // Both Src and Dest are scalar types, i.e. arithmetic or pointer.
4859   // Also, callers should have filtered out the invalid cases with
4860   // pointers.  Everything else should be possible.
4861 
4862   QualType SrcTy = Src.get()->getType();
4863   if (Context.hasSameUnqualifiedType(SrcTy, DestTy))
4864     return CK_NoOp;
4865 
4866   switch (Type::ScalarTypeKind SrcKind = SrcTy->getScalarTypeKind()) {
4867   case Type::STK_MemberPointer:
4868     llvm_unreachable("member pointer type in C");
4869 
4870   case Type::STK_CPointer:
4871   case Type::STK_BlockPointer:
4872   case Type::STK_ObjCObjectPointer:
4873     switch (DestTy->getScalarTypeKind()) {
4874     case Type::STK_CPointer: {
4875       unsigned SrcAS = SrcTy->getPointeeType().getAddressSpace();
4876       unsigned DestAS = DestTy->getPointeeType().getAddressSpace();
4877       if (SrcAS != DestAS)
4878         return CK_AddressSpaceConversion;
4879       return CK_BitCast;
4880     }
4881     case Type::STK_BlockPointer:
4882       return (SrcKind == Type::STK_BlockPointer
4883                 ? CK_BitCast : CK_AnyPointerToBlockPointerCast);
4884     case Type::STK_ObjCObjectPointer:
4885       if (SrcKind == Type::STK_ObjCObjectPointer)
4886         return CK_BitCast;
4887       if (SrcKind == Type::STK_CPointer)
4888         return CK_CPointerToObjCPointerCast;
4889       maybeExtendBlockObject(*this, Src);
4890       return CK_BlockPointerToObjCPointerCast;
4891     case Type::STK_Bool:
4892       return CK_PointerToBoolean;
4893     case Type::STK_Integral:
4894       return CK_PointerToIntegral;
4895     case Type::STK_Floating:
4896     case Type::STK_FloatingComplex:
4897     case Type::STK_IntegralComplex:
4898     case Type::STK_MemberPointer:
4899       llvm_unreachable("illegal cast from pointer");
4900     }
4901     llvm_unreachable("Should have returned before this");
4902 
4903   case Type::STK_Bool: // casting from bool is like casting from an integer
4904   case Type::STK_Integral:
4905     switch (DestTy->getScalarTypeKind()) {
4906     case Type::STK_CPointer:
4907     case Type::STK_ObjCObjectPointer:
4908     case Type::STK_BlockPointer:
4909       if (Src.get()->isNullPointerConstant(Context,
4910                                            Expr::NPC_ValueDependentIsNull))
4911         return CK_NullToPointer;
4912       return CK_IntegralToPointer;
4913     case Type::STK_Bool:
4914       return CK_IntegralToBoolean;
4915     case Type::STK_Integral:
4916       return CK_IntegralCast;
4917     case Type::STK_Floating:
4918       return CK_IntegralToFloating;
4919     case Type::STK_IntegralComplex:
4920       Src = ImpCastExprToType(Src.take(),
4921                               DestTy->castAs<ComplexType>()->getElementType(),
4922                               CK_IntegralCast);
4923       return CK_IntegralRealToComplex;
4924     case Type::STK_FloatingComplex:
4925       Src = ImpCastExprToType(Src.take(),
4926                               DestTy->castAs<ComplexType>()->getElementType(),
4927                               CK_IntegralToFloating);
4928       return CK_FloatingRealToComplex;
4929     case Type::STK_MemberPointer:
4930       llvm_unreachable("member pointer type in C");
4931     }
4932     llvm_unreachable("Should have returned before this");
4933 
4934   case Type::STK_Floating:
4935     switch (DestTy->getScalarTypeKind()) {
4936     case Type::STK_Floating:
4937       return CK_FloatingCast;
4938     case Type::STK_Bool:
4939       return CK_FloatingToBoolean;
4940     case Type::STK_Integral:
4941       return CK_FloatingToIntegral;
4942     case Type::STK_FloatingComplex:
4943       Src = ImpCastExprToType(Src.take(),
4944                               DestTy->castAs<ComplexType>()->getElementType(),
4945                               CK_FloatingCast);
4946       return CK_FloatingRealToComplex;
4947     case Type::STK_IntegralComplex:
4948       Src = ImpCastExprToType(Src.take(),
4949                               DestTy->castAs<ComplexType>()->getElementType(),
4950                               CK_FloatingToIntegral);
4951       return CK_IntegralRealToComplex;
4952     case Type::STK_CPointer:
4953     case Type::STK_ObjCObjectPointer:
4954     case Type::STK_BlockPointer:
4955       llvm_unreachable("valid float->pointer cast?");
4956     case Type::STK_MemberPointer:
4957       llvm_unreachable("member pointer type in C");
4958     }
4959     llvm_unreachable("Should have returned before this");
4960 
4961   case Type::STK_FloatingComplex:
4962     switch (DestTy->getScalarTypeKind()) {
4963     case Type::STK_FloatingComplex:
4964       return CK_FloatingComplexCast;
4965     case Type::STK_IntegralComplex:
4966       return CK_FloatingComplexToIntegralComplex;
4967     case Type::STK_Floating: {
4968       QualType ET = SrcTy->castAs<ComplexType>()->getElementType();
4969       if (Context.hasSameType(ET, DestTy))
4970         return CK_FloatingComplexToReal;
4971       Src = ImpCastExprToType(Src.take(), ET, CK_FloatingComplexToReal);
4972       return CK_FloatingCast;
4973     }
4974     case Type::STK_Bool:
4975       return CK_FloatingComplexToBoolean;
4976     case Type::STK_Integral:
4977       Src = ImpCastExprToType(Src.take(),
4978                               SrcTy->castAs<ComplexType>()->getElementType(),
4979                               CK_FloatingComplexToReal);
4980       return CK_FloatingToIntegral;
4981     case Type::STK_CPointer:
4982     case Type::STK_ObjCObjectPointer:
4983     case Type::STK_BlockPointer:
4984       llvm_unreachable("valid complex float->pointer cast?");
4985     case Type::STK_MemberPointer:
4986       llvm_unreachable("member pointer type in C");
4987     }
4988     llvm_unreachable("Should have returned before this");
4989 
4990   case Type::STK_IntegralComplex:
4991     switch (DestTy->getScalarTypeKind()) {
4992     case Type::STK_FloatingComplex:
4993       return CK_IntegralComplexToFloatingComplex;
4994     case Type::STK_IntegralComplex:
4995       return CK_IntegralComplexCast;
4996     case Type::STK_Integral: {
4997       QualType ET = SrcTy->castAs<ComplexType>()->getElementType();
4998       if (Context.hasSameType(ET, DestTy))
4999         return CK_IntegralComplexToReal;
5000       Src = ImpCastExprToType(Src.take(), ET, CK_IntegralComplexToReal);
5001       return CK_IntegralCast;
5002     }
5003     case Type::STK_Bool:
5004       return CK_IntegralComplexToBoolean;
5005     case Type::STK_Floating:
5006       Src = ImpCastExprToType(Src.take(),
5007                               SrcTy->castAs<ComplexType>()->getElementType(),
5008                               CK_IntegralComplexToReal);
5009       return CK_IntegralToFloating;
5010     case Type::STK_CPointer:
5011     case Type::STK_ObjCObjectPointer:
5012     case Type::STK_BlockPointer:
5013       llvm_unreachable("valid complex int->pointer cast?");
5014     case Type::STK_MemberPointer:
5015       llvm_unreachable("member pointer type in C");
5016     }
5017     llvm_unreachable("Should have returned before this");
5018   }
5019 
5020   llvm_unreachable("Unhandled scalar cast");
5021 }
5022 
5023 bool Sema::CheckVectorCast(SourceRange R, QualType VectorTy, QualType Ty,
5024                            CastKind &Kind) {
5025   assert(VectorTy->isVectorType() && "Not a vector type!");
5026 
5027   if (Ty->isVectorType() || Ty->isIntegerType()) {
5028     if (Context.getTypeSize(VectorTy) != Context.getTypeSize(Ty))
5029       return Diag(R.getBegin(),
5030                   Ty->isVectorType() ?
5031                   diag::err_invalid_conversion_between_vectors :
5032                   diag::err_invalid_conversion_between_vector_and_integer)
5033         << VectorTy << Ty << R;
5034   } else
5035     return Diag(R.getBegin(),
5036                 diag::err_invalid_conversion_between_vector_and_scalar)
5037       << VectorTy << Ty << R;
5038 
5039   Kind = CK_BitCast;
5040   return false;
5041 }
5042 
5043 ExprResult Sema::CheckExtVectorCast(SourceRange R, QualType DestTy,
5044                                     Expr *CastExpr, CastKind &Kind) {
5045   assert(DestTy->isExtVectorType() && "Not an extended vector type!");
5046 
5047   QualType SrcTy = CastExpr->getType();
5048 
5049   // If SrcTy is a VectorType, the total size must match to explicitly cast to
5050   // an ExtVectorType.
5051   // In OpenCL, casts between vectors of different types are not allowed.
5052   // (See OpenCL 6.2).
5053   if (SrcTy->isVectorType()) {
5054     if (Context.getTypeSize(DestTy) != Context.getTypeSize(SrcTy)
5055         || (getLangOpts().OpenCL &&
5056             (DestTy.getCanonicalType() != SrcTy.getCanonicalType()))) {
5057       Diag(R.getBegin(),diag::err_invalid_conversion_between_ext_vectors)
5058         << DestTy << SrcTy << R;
5059       return ExprError();
5060     }
5061     Kind = CK_BitCast;
5062     return Owned(CastExpr);
5063   }
5064 
5065   // All non-pointer scalars can be cast to ExtVector type.  The appropriate
5066   // conversion will take place first from scalar to elt type, and then
5067   // splat from elt type to vector.
5068   if (SrcTy->isPointerType())
5069     return Diag(R.getBegin(),
5070                 diag::err_invalid_conversion_between_vector_and_scalar)
5071       << DestTy << SrcTy << R;
5072 
5073   QualType DestElemTy = DestTy->getAs<ExtVectorType>()->getElementType();
5074   ExprResult CastExprRes = Owned(CastExpr);
5075   CastKind CK = PrepareScalarCast(CastExprRes, DestElemTy);
5076   if (CastExprRes.isInvalid())
5077     return ExprError();
5078   CastExpr = ImpCastExprToType(CastExprRes.take(), DestElemTy, CK).take();
5079 
5080   Kind = CK_VectorSplat;
5081   return Owned(CastExpr);
5082 }
5083 
5084 ExprResult
5085 Sema::ActOnCastExpr(Scope *S, SourceLocation LParenLoc,
5086                     Declarator &D, ParsedType &Ty,
5087                     SourceLocation RParenLoc, Expr *CastExpr) {
5088   assert(!D.isInvalidType() && (CastExpr != 0) &&
5089          "ActOnCastExpr(): missing type or expr");
5090 
5091   TypeSourceInfo *castTInfo = GetTypeForDeclaratorCast(D, CastExpr->getType());
5092   if (D.isInvalidType())
5093     return ExprError();
5094 
5095   if (getLangOpts().CPlusPlus) {
5096     // Check that there are no default arguments (C++ only).
5097     CheckExtraCXXDefaultArguments(D);
5098   }
5099 
5100   checkUnusedDeclAttributes(D);
5101 
5102   QualType castType = castTInfo->getType();
5103   Ty = CreateParsedType(castType, castTInfo);
5104 
5105   bool isVectorLiteral = false;
5106 
5107   // Check for an altivec or OpenCL literal,
5108   // i.e. all the elements are integer constants.
5109   ParenExpr *PE = dyn_cast<ParenExpr>(CastExpr);
5110   ParenListExpr *PLE = dyn_cast<ParenListExpr>(CastExpr);
5111   if ((getLangOpts().AltiVec || getLangOpts().OpenCL)
5112        && castType->isVectorType() && (PE || PLE)) {
5113     if (PLE && PLE->getNumExprs() == 0) {
5114       Diag(PLE->getExprLoc(), diag::err_altivec_empty_initializer);
5115       return ExprError();
5116     }
5117     if (PE || PLE->getNumExprs() == 1) {
5118       Expr *E = (PE ? PE->getSubExpr() : PLE->getExpr(0));
5119       if (!E->getType()->isVectorType())
5120         isVectorLiteral = true;
5121     }
5122     else
5123       isVectorLiteral = true;
5124   }
5125 
5126   // If this is a vector initializer, '(' type ')' '(' init, ..., init ')'
5127   // then handle it as such.
5128   if (isVectorLiteral)
5129     return BuildVectorLiteral(LParenLoc, RParenLoc, CastExpr, castTInfo);
5130 
5131   // If the Expr being casted is a ParenListExpr, handle it specially.
5132   // This is not an AltiVec-style cast, so turn the ParenListExpr into a
5133   // sequence of BinOp comma operators.
5134   if (isa<ParenListExpr>(CastExpr)) {
5135     ExprResult Result = MaybeConvertParenListExprToParenExpr(S, CastExpr);
5136     if (Result.isInvalid()) return ExprError();
5137     CastExpr = Result.take();
5138   }
5139 
5140   if (getLangOpts().CPlusPlus && !castType->isVoidType() &&
5141       !getSourceManager().isInSystemMacro(LParenLoc))
5142     Diag(LParenLoc, diag::warn_old_style_cast) << CastExpr->getSourceRange();
5143 
5144   return BuildCStyleCastExpr(LParenLoc, castTInfo, RParenLoc, CastExpr);
5145 }
5146 
5147 ExprResult Sema::BuildVectorLiteral(SourceLocation LParenLoc,
5148                                     SourceLocation RParenLoc, Expr *E,
5149                                     TypeSourceInfo *TInfo) {
5150   assert((isa<ParenListExpr>(E) || isa<ParenExpr>(E)) &&
5151          "Expected paren or paren list expression");
5152 
5153   Expr **exprs;
5154   unsigned numExprs;
5155   Expr *subExpr;
5156   SourceLocation LiteralLParenLoc, LiteralRParenLoc;
5157   if (ParenListExpr *PE = dyn_cast<ParenListExpr>(E)) {
5158     LiteralLParenLoc = PE->getLParenLoc();
5159     LiteralRParenLoc = PE->getRParenLoc();
5160     exprs = PE->getExprs();
5161     numExprs = PE->getNumExprs();
5162   } else { // isa<ParenExpr> by assertion at function entrance
5163     LiteralLParenLoc = cast<ParenExpr>(E)->getLParen();
5164     LiteralRParenLoc = cast<ParenExpr>(E)->getRParen();
5165     subExpr = cast<ParenExpr>(E)->getSubExpr();
5166     exprs = &subExpr;
5167     numExprs = 1;
5168   }
5169 
5170   QualType Ty = TInfo->getType();
5171   assert(Ty->isVectorType() && "Expected vector type");
5172 
5173   SmallVector<Expr *, 8> initExprs;
5174   const VectorType *VTy = Ty->getAs<VectorType>();
5175   unsigned numElems = Ty->getAs<VectorType>()->getNumElements();
5176 
5177   // '(...)' form of vector initialization in AltiVec: the number of
5178   // initializers must be one or must match the size of the vector.
5179   // If a single value is specified in the initializer then it will be
5180   // replicated to all the components of the vector
5181   if (VTy->getVectorKind() == VectorType::AltiVecVector) {
5182     // The number of initializers must be one or must match the size of the
5183     // vector. If a single value is specified in the initializer then it will
5184     // be replicated to all the components of the vector
5185     if (numExprs == 1) {
5186       QualType ElemTy = Ty->getAs<VectorType>()->getElementType();
5187       ExprResult Literal = DefaultLvalueConversion(exprs[0]);
5188       if (Literal.isInvalid())
5189         return ExprError();
5190       Literal = ImpCastExprToType(Literal.take(), ElemTy,
5191                                   PrepareScalarCast(Literal, ElemTy));
5192       return BuildCStyleCastExpr(LParenLoc, TInfo, RParenLoc, Literal.take());
5193     }
5194     else if (numExprs < numElems) {
5195       Diag(E->getExprLoc(),
5196            diag::err_incorrect_number_of_vector_initializers);
5197       return ExprError();
5198     }
5199     else
5200       initExprs.append(exprs, exprs + numExprs);
5201   }
5202   else {
5203     // For OpenCL, when the number of initializers is a single value,
5204     // it will be replicated to all components of the vector.
5205     if (getLangOpts().OpenCL &&
5206         VTy->getVectorKind() == VectorType::GenericVector &&
5207         numExprs == 1) {
5208         QualType ElemTy = Ty->getAs<VectorType>()->getElementType();
5209         ExprResult Literal = DefaultLvalueConversion(exprs[0]);
5210         if (Literal.isInvalid())
5211           return ExprError();
5212         Literal = ImpCastExprToType(Literal.take(), ElemTy,
5213                                     PrepareScalarCast(Literal, ElemTy));
5214         return BuildCStyleCastExpr(LParenLoc, TInfo, RParenLoc, Literal.take());
5215     }
5216 
5217     initExprs.append(exprs, exprs + numExprs);
5218   }
5219   // FIXME: This means that pretty-printing the final AST will produce curly
5220   // braces instead of the original commas.
5221   InitListExpr *initE = new (Context) InitListExpr(Context, LiteralLParenLoc,
5222                                                    initExprs, LiteralRParenLoc);
5223   initE->setType(Ty);
5224   return BuildCompoundLiteralExpr(LParenLoc, TInfo, RParenLoc, initE);
5225 }
5226 
5227 /// This is not an AltiVec-style cast or or C++ direct-initialization, so turn
5228 /// the ParenListExpr into a sequence of comma binary operators.
5229 ExprResult
5230 Sema::MaybeConvertParenListExprToParenExpr(Scope *S, Expr *OrigExpr) {
5231   ParenListExpr *E = dyn_cast<ParenListExpr>(OrigExpr);
5232   if (!E)
5233     return Owned(OrigExpr);
5234 
5235   ExprResult Result(E->getExpr(0));
5236 
5237   for (unsigned i = 1, e = E->getNumExprs(); i != e && !Result.isInvalid(); ++i)
5238     Result = ActOnBinOp(S, E->getExprLoc(), tok::comma, Result.get(),
5239                         E->getExpr(i));
5240 
5241   if (Result.isInvalid()) return ExprError();
5242 
5243   return ActOnParenExpr(E->getLParenLoc(), E->getRParenLoc(), Result.get());
5244 }
5245 
5246 ExprResult Sema::ActOnParenListExpr(SourceLocation L,
5247                                     SourceLocation R,
5248                                     MultiExprArg Val) {
5249   Expr *expr = new (Context) ParenListExpr(Context, L, Val, R);
5250   return Owned(expr);
5251 }
5252 
5253 /// \brief Emit a specialized diagnostic when one expression is a null pointer
5254 /// constant and the other is not a pointer.  Returns true if a diagnostic is
5255 /// emitted.
5256 bool Sema::DiagnoseConditionalForNull(Expr *LHSExpr, Expr *RHSExpr,
5257                                       SourceLocation QuestionLoc) {
5258   Expr *NullExpr = LHSExpr;
5259   Expr *NonPointerExpr = RHSExpr;
5260   Expr::NullPointerConstantKind NullKind =
5261       NullExpr->isNullPointerConstant(Context,
5262                                       Expr::NPC_ValueDependentIsNotNull);
5263 
5264   if (NullKind == Expr::NPCK_NotNull) {
5265     NullExpr = RHSExpr;
5266     NonPointerExpr = LHSExpr;
5267     NullKind =
5268         NullExpr->isNullPointerConstant(Context,
5269                                         Expr::NPC_ValueDependentIsNotNull);
5270   }
5271 
5272   if (NullKind == Expr::NPCK_NotNull)
5273     return false;
5274 
5275   if (NullKind == Expr::NPCK_ZeroExpression)
5276     return false;
5277 
5278   if (NullKind == Expr::NPCK_ZeroLiteral) {
5279     // In this case, check to make sure that we got here from a "NULL"
5280     // string in the source code.
5281     NullExpr = NullExpr->IgnoreParenImpCasts();
5282     SourceLocation loc = NullExpr->getExprLoc();
5283     if (!findMacroSpelling(loc, "NULL"))
5284       return false;
5285   }
5286 
5287   int DiagType = (NullKind == Expr::NPCK_CXX11_nullptr);
5288   Diag(QuestionLoc, diag::err_typecheck_cond_incompatible_operands_null)
5289       << NonPointerExpr->getType() << DiagType
5290       << NonPointerExpr->getSourceRange();
5291   return true;
5292 }
5293 
5294 /// \brief Return false if the condition expression is valid, true otherwise.
5295 static bool checkCondition(Sema &S, Expr *Cond) {
5296   QualType CondTy = Cond->getType();
5297 
5298   // C99 6.5.15p2
5299   if (CondTy->isScalarType()) return false;
5300 
5301   // OpenCL v1.1 s6.3.i says the condition is allowed to be a vector or scalar.
5302   if (S.getLangOpts().OpenCL && CondTy->isVectorType())
5303     return false;
5304 
5305   // Emit the proper error message.
5306   S.Diag(Cond->getLocStart(), S.getLangOpts().OpenCL ?
5307                               diag::err_typecheck_cond_expect_scalar :
5308                               diag::err_typecheck_cond_expect_scalar_or_vector)
5309     << CondTy;
5310   return true;
5311 }
5312 
5313 /// \brief Return false if the two expressions can be converted to a vector,
5314 /// true otherwise
5315 static bool checkConditionalConvertScalarsToVectors(Sema &S, ExprResult &LHS,
5316                                                     ExprResult &RHS,
5317                                                     QualType CondTy) {
5318   // Both operands should be of scalar type.
5319   if (!LHS.get()->getType()->isScalarType()) {
5320     S.Diag(LHS.get()->getLocStart(), diag::err_typecheck_cond_expect_scalar)
5321       << CondTy;
5322     return true;
5323   }
5324   if (!RHS.get()->getType()->isScalarType()) {
5325     S.Diag(RHS.get()->getLocStart(), diag::err_typecheck_cond_expect_scalar)
5326       << CondTy;
5327     return true;
5328   }
5329 
5330   // Implicity convert these scalars to the type of the condition.
5331   LHS = S.ImpCastExprToType(LHS.take(), CondTy, CK_IntegralCast);
5332   RHS = S.ImpCastExprToType(RHS.take(), CondTy, CK_IntegralCast);
5333   return false;
5334 }
5335 
5336 /// \brief Handle when one or both operands are void type.
5337 static QualType checkConditionalVoidType(Sema &S, ExprResult &LHS,
5338                                          ExprResult &RHS) {
5339     Expr *LHSExpr = LHS.get();
5340     Expr *RHSExpr = RHS.get();
5341 
5342     if (!LHSExpr->getType()->isVoidType())
5343       S.Diag(RHSExpr->getLocStart(), diag::ext_typecheck_cond_one_void)
5344         << RHSExpr->getSourceRange();
5345     if (!RHSExpr->getType()->isVoidType())
5346       S.Diag(LHSExpr->getLocStart(), diag::ext_typecheck_cond_one_void)
5347         << LHSExpr->getSourceRange();
5348     LHS = S.ImpCastExprToType(LHS.take(), S.Context.VoidTy, CK_ToVoid);
5349     RHS = S.ImpCastExprToType(RHS.take(), S.Context.VoidTy, CK_ToVoid);
5350     return S.Context.VoidTy;
5351 }
5352 
5353 /// \brief Return false if the NullExpr can be promoted to PointerTy,
5354 /// true otherwise.
5355 static bool checkConditionalNullPointer(Sema &S, ExprResult &NullExpr,
5356                                         QualType PointerTy) {
5357   if ((!PointerTy->isAnyPointerType() && !PointerTy->isBlockPointerType()) ||
5358       !NullExpr.get()->isNullPointerConstant(S.Context,
5359                                             Expr::NPC_ValueDependentIsNull))
5360     return true;
5361 
5362   NullExpr = S.ImpCastExprToType(NullExpr.take(), PointerTy, CK_NullToPointer);
5363   return false;
5364 }
5365 
5366 /// \brief Checks compatibility between two pointers and return the resulting
5367 /// type.
5368 static QualType checkConditionalPointerCompatibility(Sema &S, ExprResult &LHS,
5369                                                      ExprResult &RHS,
5370                                                      SourceLocation Loc) {
5371   QualType LHSTy = LHS.get()->getType();
5372   QualType RHSTy = RHS.get()->getType();
5373 
5374   if (S.Context.hasSameType(LHSTy, RHSTy)) {
5375     // Two identical pointers types are always compatible.
5376     return LHSTy;
5377   }
5378 
5379   QualType lhptee, rhptee;
5380 
5381   // Get the pointee types.
5382   bool IsBlockPointer = false;
5383   if (const BlockPointerType *LHSBTy = LHSTy->getAs<BlockPointerType>()) {
5384     lhptee = LHSBTy->getPointeeType();
5385     rhptee = RHSTy->castAs<BlockPointerType>()->getPointeeType();
5386     IsBlockPointer = true;
5387   } else {
5388     lhptee = LHSTy->castAs<PointerType>()->getPointeeType();
5389     rhptee = RHSTy->castAs<PointerType>()->getPointeeType();
5390   }
5391 
5392   // C99 6.5.15p6: If both operands are pointers to compatible types or to
5393   // differently qualified versions of compatible types, the result type is
5394   // a pointer to an appropriately qualified version of the composite
5395   // type.
5396 
5397   // Only CVR-qualifiers exist in the standard, and the differently-qualified
5398   // clause doesn't make sense for our extensions. E.g. address space 2 should
5399   // be incompatible with address space 3: they may live on different devices or
5400   // anything.
5401   Qualifiers lhQual = lhptee.getQualifiers();
5402   Qualifiers rhQual = rhptee.getQualifiers();
5403 
5404   unsigned MergedCVRQual = lhQual.getCVRQualifiers() | rhQual.getCVRQualifiers();
5405   lhQual.removeCVRQualifiers();
5406   rhQual.removeCVRQualifiers();
5407 
5408   lhptee = S.Context.getQualifiedType(lhptee.getUnqualifiedType(), lhQual);
5409   rhptee = S.Context.getQualifiedType(rhptee.getUnqualifiedType(), rhQual);
5410 
5411   QualType CompositeTy = S.Context.mergeTypes(lhptee, rhptee);
5412 
5413   if (CompositeTy.isNull()) {
5414     S.Diag(Loc, diag::warn_typecheck_cond_incompatible_pointers)
5415       << LHSTy << RHSTy << LHS.get()->getSourceRange()
5416       << RHS.get()->getSourceRange();
5417     // In this situation, we assume void* type. No especially good
5418     // reason, but this is what gcc does, and we do have to pick
5419     // to get a consistent AST.
5420     QualType incompatTy = S.Context.getPointerType(S.Context.VoidTy);
5421     LHS = S.ImpCastExprToType(LHS.take(), incompatTy, CK_BitCast);
5422     RHS = S.ImpCastExprToType(RHS.take(), incompatTy, CK_BitCast);
5423     return incompatTy;
5424   }
5425 
5426   // The pointer types are compatible.
5427   QualType ResultTy = CompositeTy.withCVRQualifiers(MergedCVRQual);
5428   if (IsBlockPointer)
5429     ResultTy = S.Context.getBlockPointerType(ResultTy);
5430   else
5431     ResultTy = S.Context.getPointerType(ResultTy);
5432 
5433   LHS = S.ImpCastExprToType(LHS.take(), ResultTy, CK_BitCast);
5434   RHS = S.ImpCastExprToType(RHS.take(), ResultTy, CK_BitCast);
5435   return ResultTy;
5436 }
5437 
5438 /// \brief Return the resulting type when the operands are both block pointers.
5439 static QualType checkConditionalBlockPointerCompatibility(Sema &S,
5440                                                           ExprResult &LHS,
5441                                                           ExprResult &RHS,
5442                                                           SourceLocation Loc) {
5443   QualType LHSTy = LHS.get()->getType();
5444   QualType RHSTy = RHS.get()->getType();
5445 
5446   if (!LHSTy->isBlockPointerType() || !RHSTy->isBlockPointerType()) {
5447     if (LHSTy->isVoidPointerType() || RHSTy->isVoidPointerType()) {
5448       QualType destType = S.Context.getPointerType(S.Context.VoidTy);
5449       LHS = S.ImpCastExprToType(LHS.take(), destType, CK_BitCast);
5450       RHS = S.ImpCastExprToType(RHS.take(), destType, CK_BitCast);
5451       return destType;
5452     }
5453     S.Diag(Loc, diag::err_typecheck_cond_incompatible_operands)
5454       << LHSTy << RHSTy << LHS.get()->getSourceRange()
5455       << RHS.get()->getSourceRange();
5456     return QualType();
5457   }
5458 
5459   // We have 2 block pointer types.
5460   return checkConditionalPointerCompatibility(S, LHS, RHS, Loc);
5461 }
5462 
5463 /// \brief Return the resulting type when the operands are both pointers.
5464 static QualType
5465 checkConditionalObjectPointersCompatibility(Sema &S, ExprResult &LHS,
5466                                             ExprResult &RHS,
5467                                             SourceLocation Loc) {
5468   // get the pointer types
5469   QualType LHSTy = LHS.get()->getType();
5470   QualType RHSTy = RHS.get()->getType();
5471 
5472   // get the "pointed to" types
5473   QualType lhptee = LHSTy->getAs<PointerType>()->getPointeeType();
5474   QualType rhptee = RHSTy->getAs<PointerType>()->getPointeeType();
5475 
5476   // ignore qualifiers on void (C99 6.5.15p3, clause 6)
5477   if (lhptee->isVoidType() && rhptee->isIncompleteOrObjectType()) {
5478     // Figure out necessary qualifiers (C99 6.5.15p6)
5479     QualType destPointee
5480       = S.Context.getQualifiedType(lhptee, rhptee.getQualifiers());
5481     QualType destType = S.Context.getPointerType(destPointee);
5482     // Add qualifiers if necessary.
5483     LHS = S.ImpCastExprToType(LHS.take(), destType, CK_NoOp);
5484     // Promote to void*.
5485     RHS = S.ImpCastExprToType(RHS.take(), destType, CK_BitCast);
5486     return destType;
5487   }
5488   if (rhptee->isVoidType() && lhptee->isIncompleteOrObjectType()) {
5489     QualType destPointee
5490       = S.Context.getQualifiedType(rhptee, lhptee.getQualifiers());
5491     QualType destType = S.Context.getPointerType(destPointee);
5492     // Add qualifiers if necessary.
5493     RHS = S.ImpCastExprToType(RHS.take(), destType, CK_NoOp);
5494     // Promote to void*.
5495     LHS = S.ImpCastExprToType(LHS.take(), destType, CK_BitCast);
5496     return destType;
5497   }
5498 
5499   return checkConditionalPointerCompatibility(S, LHS, RHS, Loc);
5500 }
5501 
5502 /// \brief Return false if the first expression is not an integer and the second
5503 /// expression is not a pointer, true otherwise.
5504 static bool checkPointerIntegerMismatch(Sema &S, ExprResult &Int,
5505                                         Expr* PointerExpr, SourceLocation Loc,
5506                                         bool IsIntFirstExpr) {
5507   if (!PointerExpr->getType()->isPointerType() ||
5508       !Int.get()->getType()->isIntegerType())
5509     return false;
5510 
5511   Expr *Expr1 = IsIntFirstExpr ? Int.get() : PointerExpr;
5512   Expr *Expr2 = IsIntFirstExpr ? PointerExpr : Int.get();
5513 
5514   S.Diag(Loc, diag::warn_typecheck_cond_pointer_integer_mismatch)
5515     << Expr1->getType() << Expr2->getType()
5516     << Expr1->getSourceRange() << Expr2->getSourceRange();
5517   Int = S.ImpCastExprToType(Int.take(), PointerExpr->getType(),
5518                             CK_IntegralToPointer);
5519   return true;
5520 }
5521 
5522 /// Note that LHS is not null here, even if this is the gnu "x ?: y" extension.
5523 /// In that case, LHS = cond.
5524 /// C99 6.5.15
5525 QualType Sema::CheckConditionalOperands(ExprResult &Cond, ExprResult &LHS,
5526                                         ExprResult &RHS, ExprValueKind &VK,
5527                                         ExprObjectKind &OK,
5528                                         SourceLocation QuestionLoc) {
5529 
5530   ExprResult LHSResult = CheckPlaceholderExpr(LHS.get());
5531   if (!LHSResult.isUsable()) return QualType();
5532   LHS = LHSResult;
5533 
5534   ExprResult RHSResult = CheckPlaceholderExpr(RHS.get());
5535   if (!RHSResult.isUsable()) return QualType();
5536   RHS = RHSResult;
5537 
5538   // C++ is sufficiently different to merit its own checker.
5539   if (getLangOpts().CPlusPlus)
5540     return CXXCheckConditionalOperands(Cond, LHS, RHS, VK, OK, QuestionLoc);
5541 
5542   VK = VK_RValue;
5543   OK = OK_Ordinary;
5544 
5545   // First, check the condition.
5546   Cond = UsualUnaryConversions(Cond.take());
5547   if (Cond.isInvalid())
5548     return QualType();
5549   if (checkCondition(*this, Cond.get()))
5550     return QualType();
5551 
5552   // Now check the two expressions.
5553   if (LHS.get()->getType()->isVectorType() ||
5554       RHS.get()->getType()->isVectorType())
5555     return CheckVectorOperands(LHS, RHS, QuestionLoc, /*isCompAssign*/false);
5556 
5557   UsualArithmeticConversions(LHS, RHS);
5558   if (LHS.isInvalid() || RHS.isInvalid())
5559     return QualType();
5560 
5561   QualType CondTy = Cond.get()->getType();
5562   QualType LHSTy = LHS.get()->getType();
5563   QualType RHSTy = RHS.get()->getType();
5564 
5565   // If the condition is a vector, and both operands are scalar,
5566   // attempt to implicity convert them to the vector type to act like the
5567   // built in select. (OpenCL v1.1 s6.3.i)
5568   if (getLangOpts().OpenCL && CondTy->isVectorType())
5569     if (checkConditionalConvertScalarsToVectors(*this, LHS, RHS, CondTy))
5570       return QualType();
5571 
5572   // If both operands have arithmetic type, do the usual arithmetic conversions
5573   // to find a common type: C99 6.5.15p3,5.
5574   if (LHSTy->isArithmeticType() && RHSTy->isArithmeticType())
5575     return LHS.get()->getType();
5576 
5577   // If both operands are the same structure or union type, the result is that
5578   // type.
5579   if (const RecordType *LHSRT = LHSTy->getAs<RecordType>()) {    // C99 6.5.15p3
5580     if (const RecordType *RHSRT = RHSTy->getAs<RecordType>())
5581       if (LHSRT->getDecl() == RHSRT->getDecl())
5582         // "If both the operands have structure or union type, the result has
5583         // that type."  This implies that CV qualifiers are dropped.
5584         return LHSTy.getUnqualifiedType();
5585     // FIXME: Type of conditional expression must be complete in C mode.
5586   }
5587 
5588   // C99 6.5.15p5: "If both operands have void type, the result has void type."
5589   // The following || allows only one side to be void (a GCC-ism).
5590   if (LHSTy->isVoidType() || RHSTy->isVoidType()) {
5591     return checkConditionalVoidType(*this, LHS, RHS);
5592   }
5593 
5594   // C99 6.5.15p6 - "if one operand is a null pointer constant, the result has
5595   // the type of the other operand."
5596   if (!checkConditionalNullPointer(*this, RHS, LHSTy)) return LHSTy;
5597   if (!checkConditionalNullPointer(*this, LHS, RHSTy)) return RHSTy;
5598 
5599   // All objective-c pointer type analysis is done here.
5600   QualType compositeType = FindCompositeObjCPointerType(LHS, RHS,
5601                                                         QuestionLoc);
5602   if (LHS.isInvalid() || RHS.isInvalid())
5603     return QualType();
5604   if (!compositeType.isNull())
5605     return compositeType;
5606 
5607 
5608   // Handle block pointer types.
5609   if (LHSTy->isBlockPointerType() || RHSTy->isBlockPointerType())
5610     return checkConditionalBlockPointerCompatibility(*this, LHS, RHS,
5611                                                      QuestionLoc);
5612 
5613   // Check constraints for C object pointers types (C99 6.5.15p3,6).
5614   if (LHSTy->isPointerType() && RHSTy->isPointerType())
5615     return checkConditionalObjectPointersCompatibility(*this, LHS, RHS,
5616                                                        QuestionLoc);
5617 
5618   // GCC compatibility: soften pointer/integer mismatch.  Note that
5619   // null pointers have been filtered out by this point.
5620   if (checkPointerIntegerMismatch(*this, LHS, RHS.get(), QuestionLoc,
5621       /*isIntFirstExpr=*/true))
5622     return RHSTy;
5623   if (checkPointerIntegerMismatch(*this, RHS, LHS.get(), QuestionLoc,
5624       /*isIntFirstExpr=*/false))
5625     return LHSTy;
5626 
5627   // Emit a better diagnostic if one of the expressions is a null pointer
5628   // constant and the other is not a pointer type. In this case, the user most
5629   // likely forgot to take the address of the other expression.
5630   if (DiagnoseConditionalForNull(LHS.get(), RHS.get(), QuestionLoc))
5631     return QualType();
5632 
5633   // Otherwise, the operands are not compatible.
5634   Diag(QuestionLoc, diag::err_typecheck_cond_incompatible_operands)
5635     << LHSTy << RHSTy << LHS.get()->getSourceRange()
5636     << RHS.get()->getSourceRange();
5637   return QualType();
5638 }
5639 
5640 /// FindCompositeObjCPointerType - Helper method to find composite type of
5641 /// two objective-c pointer types of the two input expressions.
5642 QualType Sema::FindCompositeObjCPointerType(ExprResult &LHS, ExprResult &RHS,
5643                                             SourceLocation QuestionLoc) {
5644   QualType LHSTy = LHS.get()->getType();
5645   QualType RHSTy = RHS.get()->getType();
5646 
5647   // Handle things like Class and struct objc_class*.  Here we case the result
5648   // to the pseudo-builtin, because that will be implicitly cast back to the
5649   // redefinition type if an attempt is made to access its fields.
5650   if (LHSTy->isObjCClassType() &&
5651       (Context.hasSameType(RHSTy, Context.getObjCClassRedefinitionType()))) {
5652     RHS = ImpCastExprToType(RHS.take(), LHSTy, CK_CPointerToObjCPointerCast);
5653     return LHSTy;
5654   }
5655   if (RHSTy->isObjCClassType() &&
5656       (Context.hasSameType(LHSTy, Context.getObjCClassRedefinitionType()))) {
5657     LHS = ImpCastExprToType(LHS.take(), RHSTy, CK_CPointerToObjCPointerCast);
5658     return RHSTy;
5659   }
5660   // And the same for struct objc_object* / id
5661   if (LHSTy->isObjCIdType() &&
5662       (Context.hasSameType(RHSTy, Context.getObjCIdRedefinitionType()))) {
5663     RHS = ImpCastExprToType(RHS.take(), LHSTy, CK_CPointerToObjCPointerCast);
5664     return LHSTy;
5665   }
5666   if (RHSTy->isObjCIdType() &&
5667       (Context.hasSameType(LHSTy, Context.getObjCIdRedefinitionType()))) {
5668     LHS = ImpCastExprToType(LHS.take(), RHSTy, CK_CPointerToObjCPointerCast);
5669     return RHSTy;
5670   }
5671   // And the same for struct objc_selector* / SEL
5672   if (Context.isObjCSelType(LHSTy) &&
5673       (Context.hasSameType(RHSTy, Context.getObjCSelRedefinitionType()))) {
5674     RHS = ImpCastExprToType(RHS.take(), LHSTy, CK_BitCast);
5675     return LHSTy;
5676   }
5677   if (Context.isObjCSelType(RHSTy) &&
5678       (Context.hasSameType(LHSTy, Context.getObjCSelRedefinitionType()))) {
5679     LHS = ImpCastExprToType(LHS.take(), RHSTy, CK_BitCast);
5680     return RHSTy;
5681   }
5682   // Check constraints for Objective-C object pointers types.
5683   if (LHSTy->isObjCObjectPointerType() && RHSTy->isObjCObjectPointerType()) {
5684 
5685     if (Context.getCanonicalType(LHSTy) == Context.getCanonicalType(RHSTy)) {
5686       // Two identical object pointer types are always compatible.
5687       return LHSTy;
5688     }
5689     const ObjCObjectPointerType *LHSOPT = LHSTy->castAs<ObjCObjectPointerType>();
5690     const ObjCObjectPointerType *RHSOPT = RHSTy->castAs<ObjCObjectPointerType>();
5691     QualType compositeType = LHSTy;
5692 
5693     // If both operands are interfaces and either operand can be
5694     // assigned to the other, use that type as the composite
5695     // type. This allows
5696     //   xxx ? (A*) a : (B*) b
5697     // where B is a subclass of A.
5698     //
5699     // Additionally, as for assignment, if either type is 'id'
5700     // allow silent coercion. Finally, if the types are
5701     // incompatible then make sure to use 'id' as the composite
5702     // type so the result is acceptable for sending messages to.
5703 
5704     // FIXME: Consider unifying with 'areComparableObjCPointerTypes'.
5705     // It could return the composite type.
5706     if (Context.canAssignObjCInterfaces(LHSOPT, RHSOPT)) {
5707       compositeType = RHSOPT->isObjCBuiltinType() ? RHSTy : LHSTy;
5708     } else if (Context.canAssignObjCInterfaces(RHSOPT, LHSOPT)) {
5709       compositeType = LHSOPT->isObjCBuiltinType() ? LHSTy : RHSTy;
5710     } else if ((LHSTy->isObjCQualifiedIdType() ||
5711                 RHSTy->isObjCQualifiedIdType()) &&
5712                Context.ObjCQualifiedIdTypesAreCompatible(LHSTy, RHSTy, true)) {
5713       // Need to handle "id<xx>" explicitly.
5714       // GCC allows qualified id and any Objective-C type to devolve to
5715       // id. Currently localizing to here until clear this should be
5716       // part of ObjCQualifiedIdTypesAreCompatible.
5717       compositeType = Context.getObjCIdType();
5718     } else if (LHSTy->isObjCIdType() || RHSTy->isObjCIdType()) {
5719       compositeType = Context.getObjCIdType();
5720     } else if (!(compositeType =
5721                  Context.areCommonBaseCompatible(LHSOPT, RHSOPT)).isNull())
5722       ;
5723     else {
5724       Diag(QuestionLoc, diag::ext_typecheck_cond_incompatible_operands)
5725       << LHSTy << RHSTy
5726       << LHS.get()->getSourceRange() << RHS.get()->getSourceRange();
5727       QualType incompatTy = Context.getObjCIdType();
5728       LHS = ImpCastExprToType(LHS.take(), incompatTy, CK_BitCast);
5729       RHS = ImpCastExprToType(RHS.take(), incompatTy, CK_BitCast);
5730       return incompatTy;
5731     }
5732     // The object pointer types are compatible.
5733     LHS = ImpCastExprToType(LHS.take(), compositeType, CK_BitCast);
5734     RHS = ImpCastExprToType(RHS.take(), compositeType, CK_BitCast);
5735     return compositeType;
5736   }
5737   // Check Objective-C object pointer types and 'void *'
5738   if (LHSTy->isVoidPointerType() && RHSTy->isObjCObjectPointerType()) {
5739     if (getLangOpts().ObjCAutoRefCount) {
5740       // ARC forbids the implicit conversion of object pointers to 'void *',
5741       // so these types are not compatible.
5742       Diag(QuestionLoc, diag::err_cond_voidptr_arc) << LHSTy << RHSTy
5743           << LHS.get()->getSourceRange() << RHS.get()->getSourceRange();
5744       LHS = RHS = true;
5745       return QualType();
5746     }
5747     QualType lhptee = LHSTy->getAs<PointerType>()->getPointeeType();
5748     QualType rhptee = RHSTy->getAs<ObjCObjectPointerType>()->getPointeeType();
5749     QualType destPointee
5750     = Context.getQualifiedType(lhptee, rhptee.getQualifiers());
5751     QualType destType = Context.getPointerType(destPointee);
5752     // Add qualifiers if necessary.
5753     LHS = ImpCastExprToType(LHS.take(), destType, CK_NoOp);
5754     // Promote to void*.
5755     RHS = ImpCastExprToType(RHS.take(), destType, CK_BitCast);
5756     return destType;
5757   }
5758   if (LHSTy->isObjCObjectPointerType() && RHSTy->isVoidPointerType()) {
5759     if (getLangOpts().ObjCAutoRefCount) {
5760       // ARC forbids the implicit conversion of object pointers to 'void *',
5761       // so these types are not compatible.
5762       Diag(QuestionLoc, diag::err_cond_voidptr_arc) << LHSTy << RHSTy
5763           << LHS.get()->getSourceRange() << RHS.get()->getSourceRange();
5764       LHS = RHS = true;
5765       return QualType();
5766     }
5767     QualType lhptee = LHSTy->getAs<ObjCObjectPointerType>()->getPointeeType();
5768     QualType rhptee = RHSTy->getAs<PointerType>()->getPointeeType();
5769     QualType destPointee
5770     = Context.getQualifiedType(rhptee, lhptee.getQualifiers());
5771     QualType destType = Context.getPointerType(destPointee);
5772     // Add qualifiers if necessary.
5773     RHS = ImpCastExprToType(RHS.take(), destType, CK_NoOp);
5774     // Promote to void*.
5775     LHS = ImpCastExprToType(LHS.take(), destType, CK_BitCast);
5776     return destType;
5777   }
5778   return QualType();
5779 }
5780 
5781 /// SuggestParentheses - Emit a note with a fixit hint that wraps
5782 /// ParenRange in parentheses.
5783 static void SuggestParentheses(Sema &Self, SourceLocation Loc,
5784                                const PartialDiagnostic &Note,
5785                                SourceRange ParenRange) {
5786   SourceLocation EndLoc = Self.PP.getLocForEndOfToken(ParenRange.getEnd());
5787   if (ParenRange.getBegin().isFileID() && ParenRange.getEnd().isFileID() &&
5788       EndLoc.isValid()) {
5789     Self.Diag(Loc, Note)
5790       << FixItHint::CreateInsertion(ParenRange.getBegin(), "(")
5791       << FixItHint::CreateInsertion(EndLoc, ")");
5792   } else {
5793     // We can't display the parentheses, so just show the bare note.
5794     Self.Diag(Loc, Note) << ParenRange;
5795   }
5796 }
5797 
5798 static bool IsArithmeticOp(BinaryOperatorKind Opc) {
5799   return Opc >= BO_Mul && Opc <= BO_Shr;
5800 }
5801 
5802 /// IsArithmeticBinaryExpr - Returns true if E is an arithmetic binary
5803 /// expression, either using a built-in or overloaded operator,
5804 /// and sets *OpCode to the opcode and *RHSExprs to the right-hand side
5805 /// expression.
5806 static bool IsArithmeticBinaryExpr(Expr *E, BinaryOperatorKind *Opcode,
5807                                    Expr **RHSExprs) {
5808   // Don't strip parenthesis: we should not warn if E is in parenthesis.
5809   E = E->IgnoreImpCasts();
5810   E = E->IgnoreConversionOperator();
5811   E = E->IgnoreImpCasts();
5812 
5813   // Built-in binary operator.
5814   if (BinaryOperator *OP = dyn_cast<BinaryOperator>(E)) {
5815     if (IsArithmeticOp(OP->getOpcode())) {
5816       *Opcode = OP->getOpcode();
5817       *RHSExprs = OP->getRHS();
5818       return true;
5819     }
5820   }
5821 
5822   // Overloaded operator.
5823   if (CXXOperatorCallExpr *Call = dyn_cast<CXXOperatorCallExpr>(E)) {
5824     if (Call->getNumArgs() != 2)
5825       return false;
5826 
5827     // Make sure this is really a binary operator that is safe to pass into
5828     // BinaryOperator::getOverloadedOpcode(), e.g. it's not a subscript op.
5829     OverloadedOperatorKind OO = Call->getOperator();
5830     if (OO < OO_Plus || OO > OO_Arrow ||
5831         OO == OO_PlusPlus || OO == OO_MinusMinus)
5832       return false;
5833 
5834     BinaryOperatorKind OpKind = BinaryOperator::getOverloadedOpcode(OO);
5835     if (IsArithmeticOp(OpKind)) {
5836       *Opcode = OpKind;
5837       *RHSExprs = Call->getArg(1);
5838       return true;
5839     }
5840   }
5841 
5842   return false;
5843 }
5844 
5845 static bool IsLogicOp(BinaryOperatorKind Opc) {
5846   return (Opc >= BO_LT && Opc <= BO_NE) || (Opc >= BO_LAnd && Opc <= BO_LOr);
5847 }
5848 
5849 /// ExprLooksBoolean - Returns true if E looks boolean, i.e. it has boolean type
5850 /// or is a logical expression such as (x==y) which has int type, but is
5851 /// commonly interpreted as boolean.
5852 static bool ExprLooksBoolean(Expr *E) {
5853   E = E->IgnoreParenImpCasts();
5854 
5855   if (E->getType()->isBooleanType())
5856     return true;
5857   if (BinaryOperator *OP = dyn_cast<BinaryOperator>(E))
5858     return IsLogicOp(OP->getOpcode());
5859   if (UnaryOperator *OP = dyn_cast<UnaryOperator>(E))
5860     return OP->getOpcode() == UO_LNot;
5861 
5862   return false;
5863 }
5864 
5865 /// DiagnoseConditionalPrecedence - Emit a warning when a conditional operator
5866 /// and binary operator are mixed in a way that suggests the programmer assumed
5867 /// the conditional operator has higher precedence, for example:
5868 /// "int x = a + someBinaryCondition ? 1 : 2".
5869 static void DiagnoseConditionalPrecedence(Sema &Self,
5870                                           SourceLocation OpLoc,
5871                                           Expr *Condition,
5872                                           Expr *LHSExpr,
5873                                           Expr *RHSExpr) {
5874   BinaryOperatorKind CondOpcode;
5875   Expr *CondRHS;
5876 
5877   if (!IsArithmeticBinaryExpr(Condition, &CondOpcode, &CondRHS))
5878     return;
5879   if (!ExprLooksBoolean(CondRHS))
5880     return;
5881 
5882   // The condition is an arithmetic binary expression, with a right-
5883   // hand side that looks boolean, so warn.
5884 
5885   Self.Diag(OpLoc, diag::warn_precedence_conditional)
5886       << Condition->getSourceRange()
5887       << BinaryOperator::getOpcodeStr(CondOpcode);
5888 
5889   SuggestParentheses(Self, OpLoc,
5890     Self.PDiag(diag::note_precedence_silence)
5891       << BinaryOperator::getOpcodeStr(CondOpcode),
5892     SourceRange(Condition->getLocStart(), Condition->getLocEnd()));
5893 
5894   SuggestParentheses(Self, OpLoc,
5895     Self.PDiag(diag::note_precedence_conditional_first),
5896     SourceRange(CondRHS->getLocStart(), RHSExpr->getLocEnd()));
5897 }
5898 
5899 /// ActOnConditionalOp - Parse a ?: operation.  Note that 'LHS' may be null
5900 /// in the case of a the GNU conditional expr extension.
5901 ExprResult Sema::ActOnConditionalOp(SourceLocation QuestionLoc,
5902                                     SourceLocation ColonLoc,
5903                                     Expr *CondExpr, Expr *LHSExpr,
5904                                     Expr *RHSExpr) {
5905   // If this is the gnu "x ?: y" extension, analyze the types as though the LHS
5906   // was the condition.
5907   OpaqueValueExpr *opaqueValue = 0;
5908   Expr *commonExpr = 0;
5909   if (LHSExpr == 0) {
5910     commonExpr = CondExpr;
5911     // Lower out placeholder types first.  This is important so that we don't
5912     // try to capture a placeholder. This happens in few cases in C++; such
5913     // as Objective-C++'s dictionary subscripting syntax.
5914     if (commonExpr->hasPlaceholderType()) {
5915       ExprResult result = CheckPlaceholderExpr(commonExpr);
5916       if (!result.isUsable()) return ExprError();
5917       commonExpr = result.take();
5918     }
5919     // We usually want to apply unary conversions *before* saving, except
5920     // in the special case of a C++ l-value conditional.
5921     if (!(getLangOpts().CPlusPlus
5922           && !commonExpr->isTypeDependent()
5923           && commonExpr->getValueKind() == RHSExpr->getValueKind()
5924           && commonExpr->isGLValue()
5925           && commonExpr->isOrdinaryOrBitFieldObject()
5926           && RHSExpr->isOrdinaryOrBitFieldObject()
5927           && Context.hasSameType(commonExpr->getType(), RHSExpr->getType()))) {
5928       ExprResult commonRes = UsualUnaryConversions(commonExpr);
5929       if (commonRes.isInvalid())
5930         return ExprError();
5931       commonExpr = commonRes.take();
5932     }
5933 
5934     opaqueValue = new (Context) OpaqueValueExpr(commonExpr->getExprLoc(),
5935                                                 commonExpr->getType(),
5936                                                 commonExpr->getValueKind(),
5937                                                 commonExpr->getObjectKind(),
5938                                                 commonExpr);
5939     LHSExpr = CondExpr = opaqueValue;
5940   }
5941 
5942   ExprValueKind VK = VK_RValue;
5943   ExprObjectKind OK = OK_Ordinary;
5944   ExprResult Cond = Owned(CondExpr), LHS = Owned(LHSExpr), RHS = Owned(RHSExpr);
5945   QualType result = CheckConditionalOperands(Cond, LHS, RHS,
5946                                              VK, OK, QuestionLoc);
5947   if (result.isNull() || Cond.isInvalid() || LHS.isInvalid() ||
5948       RHS.isInvalid())
5949     return ExprError();
5950 
5951   DiagnoseConditionalPrecedence(*this, QuestionLoc, Cond.get(), LHS.get(),
5952                                 RHS.get());
5953 
5954   if (!commonExpr)
5955     return Owned(new (Context) ConditionalOperator(Cond.take(), QuestionLoc,
5956                                                    LHS.take(), ColonLoc,
5957                                                    RHS.take(), result, VK, OK));
5958 
5959   return Owned(new (Context)
5960     BinaryConditionalOperator(commonExpr, opaqueValue, Cond.take(), LHS.take(),
5961                               RHS.take(), QuestionLoc, ColonLoc, result, VK,
5962                               OK));
5963 }
5964 
5965 // checkPointerTypesForAssignment - This is a very tricky routine (despite
5966 // being closely modeled after the C99 spec:-). The odd characteristic of this
5967 // routine is it effectively iqnores the qualifiers on the top level pointee.
5968 // This circumvents the usual type rules specified in 6.2.7p1 & 6.7.5.[1-3].
5969 // FIXME: add a couple examples in this comment.
5970 static Sema::AssignConvertType
5971 checkPointerTypesForAssignment(Sema &S, QualType LHSType, QualType RHSType) {
5972   assert(LHSType.isCanonical() && "LHS not canonicalized!");
5973   assert(RHSType.isCanonical() && "RHS not canonicalized!");
5974 
5975   // get the "pointed to" type (ignoring qualifiers at the top level)
5976   const Type *lhptee, *rhptee;
5977   Qualifiers lhq, rhq;
5978   llvm::tie(lhptee, lhq) = cast<PointerType>(LHSType)->getPointeeType().split();
5979   llvm::tie(rhptee, rhq) = cast<PointerType>(RHSType)->getPointeeType().split();
5980 
5981   Sema::AssignConvertType ConvTy = Sema::Compatible;
5982 
5983   // C99 6.5.16.1p1: This following citation is common to constraints
5984   // 3 & 4 (below). ...and the type *pointed to* by the left has all the
5985   // qualifiers of the type *pointed to* by the right;
5986 
5987   // As a special case, 'non-__weak A *' -> 'non-__weak const *' is okay.
5988   if (lhq.getObjCLifetime() != rhq.getObjCLifetime() &&
5989       lhq.compatiblyIncludesObjCLifetime(rhq)) {
5990     // Ignore lifetime for further calculation.
5991     lhq.removeObjCLifetime();
5992     rhq.removeObjCLifetime();
5993   }
5994 
5995   if (!lhq.compatiblyIncludes(rhq)) {
5996     // Treat address-space mismatches as fatal.  TODO: address subspaces
5997     if (lhq.getAddressSpace() != rhq.getAddressSpace())
5998       ConvTy = Sema::IncompatiblePointerDiscardsQualifiers;
5999 
6000     // It's okay to add or remove GC or lifetime qualifiers when converting to
6001     // and from void*.
6002     else if (lhq.withoutObjCGCAttr().withoutObjCLifetime()
6003                         .compatiblyIncludes(
6004                                 rhq.withoutObjCGCAttr().withoutObjCLifetime())
6005              && (lhptee->isVoidType() || rhptee->isVoidType()))
6006       ; // keep old
6007 
6008     // Treat lifetime mismatches as fatal.
6009     else if (lhq.getObjCLifetime() != rhq.getObjCLifetime())
6010       ConvTy = Sema::IncompatiblePointerDiscardsQualifiers;
6011 
6012     // For GCC compatibility, other qualifier mismatches are treated
6013     // as still compatible in C.
6014     else ConvTy = Sema::CompatiblePointerDiscardsQualifiers;
6015   }
6016 
6017   // C99 6.5.16.1p1 (constraint 4): If one operand is a pointer to an object or
6018   // incomplete type and the other is a pointer to a qualified or unqualified
6019   // version of void...
6020   if (lhptee->isVoidType()) {
6021     if (rhptee->isIncompleteOrObjectType())
6022       return ConvTy;
6023 
6024     // As an extension, we allow cast to/from void* to function pointer.
6025     assert(rhptee->isFunctionType());
6026     return Sema::FunctionVoidPointer;
6027   }
6028 
6029   if (rhptee->isVoidType()) {
6030     if (lhptee->isIncompleteOrObjectType())
6031       return ConvTy;
6032 
6033     // As an extension, we allow cast to/from void* to function pointer.
6034     assert(lhptee->isFunctionType());
6035     return Sema::FunctionVoidPointer;
6036   }
6037 
6038   // C99 6.5.16.1p1 (constraint 3): both operands are pointers to qualified or
6039   // unqualified versions of compatible types, ...
6040   QualType ltrans = QualType(lhptee, 0), rtrans = QualType(rhptee, 0);
6041   if (!S.Context.typesAreCompatible(ltrans, rtrans)) {
6042     // Check if the pointee types are compatible ignoring the sign.
6043     // We explicitly check for char so that we catch "char" vs
6044     // "unsigned char" on systems where "char" is unsigned.
6045     if (lhptee->isCharType())
6046       ltrans = S.Context.UnsignedCharTy;
6047     else if (lhptee->hasSignedIntegerRepresentation())
6048       ltrans = S.Context.getCorrespondingUnsignedType(ltrans);
6049 
6050     if (rhptee->isCharType())
6051       rtrans = S.Context.UnsignedCharTy;
6052     else if (rhptee->hasSignedIntegerRepresentation())
6053       rtrans = S.Context.getCorrespondingUnsignedType(rtrans);
6054 
6055     if (ltrans == rtrans) {
6056       // Types are compatible ignoring the sign. Qualifier incompatibility
6057       // takes priority over sign incompatibility because the sign
6058       // warning can be disabled.
6059       if (ConvTy != Sema::Compatible)
6060         return ConvTy;
6061 
6062       return Sema::IncompatiblePointerSign;
6063     }
6064 
6065     // If we are a multi-level pointer, it's possible that our issue is simply
6066     // one of qualification - e.g. char ** -> const char ** is not allowed. If
6067     // the eventual target type is the same and the pointers have the same
6068     // level of indirection, this must be the issue.
6069     if (isa<PointerType>(lhptee) && isa<PointerType>(rhptee)) {
6070       do {
6071         lhptee = cast<PointerType>(lhptee)->getPointeeType().getTypePtr();
6072         rhptee = cast<PointerType>(rhptee)->getPointeeType().getTypePtr();
6073       } while (isa<PointerType>(lhptee) && isa<PointerType>(rhptee));
6074 
6075       if (lhptee == rhptee)
6076         return Sema::IncompatibleNestedPointerQualifiers;
6077     }
6078 
6079     // General pointer incompatibility takes priority over qualifiers.
6080     return Sema::IncompatiblePointer;
6081   }
6082   if (!S.getLangOpts().CPlusPlus &&
6083       S.IsNoReturnConversion(ltrans, rtrans, ltrans))
6084     return Sema::IncompatiblePointer;
6085   return ConvTy;
6086 }
6087 
6088 /// checkBlockPointerTypesForAssignment - This routine determines whether two
6089 /// block pointer types are compatible or whether a block and normal pointer
6090 /// are compatible. It is more restrict than comparing two function pointer
6091 // types.
6092 static Sema::AssignConvertType
6093 checkBlockPointerTypesForAssignment(Sema &S, QualType LHSType,
6094                                     QualType RHSType) {
6095   assert(LHSType.isCanonical() && "LHS not canonicalized!");
6096   assert(RHSType.isCanonical() && "RHS not canonicalized!");
6097 
6098   QualType lhptee, rhptee;
6099 
6100   // get the "pointed to" type (ignoring qualifiers at the top level)
6101   lhptee = cast<BlockPointerType>(LHSType)->getPointeeType();
6102   rhptee = cast<BlockPointerType>(RHSType)->getPointeeType();
6103 
6104   // In C++, the types have to match exactly.
6105   if (S.getLangOpts().CPlusPlus)
6106     return Sema::IncompatibleBlockPointer;
6107 
6108   Sema::AssignConvertType ConvTy = Sema::Compatible;
6109 
6110   // For blocks we enforce that qualifiers are identical.
6111   if (lhptee.getLocalQualifiers() != rhptee.getLocalQualifiers())
6112     ConvTy = Sema::CompatiblePointerDiscardsQualifiers;
6113 
6114   if (!S.Context.typesAreBlockPointerCompatible(LHSType, RHSType))
6115     return Sema::IncompatibleBlockPointer;
6116 
6117   return ConvTy;
6118 }
6119 
6120 /// checkObjCPointerTypesForAssignment - Compares two objective-c pointer types
6121 /// for assignment compatibility.
6122 static Sema::AssignConvertType
6123 checkObjCPointerTypesForAssignment(Sema &S, QualType LHSType,
6124                                    QualType RHSType) {
6125   assert(LHSType.isCanonical() && "LHS was not canonicalized!");
6126   assert(RHSType.isCanonical() && "RHS was not canonicalized!");
6127 
6128   if (LHSType->isObjCBuiltinType()) {
6129     // Class is not compatible with ObjC object pointers.
6130     if (LHSType->isObjCClassType() && !RHSType->isObjCBuiltinType() &&
6131         !RHSType->isObjCQualifiedClassType())
6132       return Sema::IncompatiblePointer;
6133     return Sema::Compatible;
6134   }
6135   if (RHSType->isObjCBuiltinType()) {
6136     if (RHSType->isObjCClassType() && !LHSType->isObjCBuiltinType() &&
6137         !LHSType->isObjCQualifiedClassType())
6138       return Sema::IncompatiblePointer;
6139     return Sema::Compatible;
6140   }
6141   QualType lhptee = LHSType->getAs<ObjCObjectPointerType>()->getPointeeType();
6142   QualType rhptee = RHSType->getAs<ObjCObjectPointerType>()->getPointeeType();
6143 
6144   if (!lhptee.isAtLeastAsQualifiedAs(rhptee) &&
6145       // make an exception for id<P>
6146       !LHSType->isObjCQualifiedIdType())
6147     return Sema::CompatiblePointerDiscardsQualifiers;
6148 
6149   if (S.Context.typesAreCompatible(LHSType, RHSType))
6150     return Sema::Compatible;
6151   if (LHSType->isObjCQualifiedIdType() || RHSType->isObjCQualifiedIdType())
6152     return Sema::IncompatibleObjCQualifiedId;
6153   return Sema::IncompatiblePointer;
6154 }
6155 
6156 Sema::AssignConvertType
6157 Sema::CheckAssignmentConstraints(SourceLocation Loc,
6158                                  QualType LHSType, QualType RHSType) {
6159   // Fake up an opaque expression.  We don't actually care about what
6160   // cast operations are required, so if CheckAssignmentConstraints
6161   // adds casts to this they'll be wasted, but fortunately that doesn't
6162   // usually happen on valid code.
6163   OpaqueValueExpr RHSExpr(Loc, RHSType, VK_RValue);
6164   ExprResult RHSPtr = &RHSExpr;
6165   CastKind K = CK_Invalid;
6166 
6167   return CheckAssignmentConstraints(LHSType, RHSPtr, K);
6168 }
6169 
6170 /// CheckAssignmentConstraints (C99 6.5.16) - This routine currently
6171 /// has code to accommodate several GCC extensions when type checking
6172 /// pointers. Here are some objectionable examples that GCC considers warnings:
6173 ///
6174 ///  int a, *pint;
6175 ///  short *pshort;
6176 ///  struct foo *pfoo;
6177 ///
6178 ///  pint = pshort; // warning: assignment from incompatible pointer type
6179 ///  a = pint; // warning: assignment makes integer from pointer without a cast
6180 ///  pint = a; // warning: assignment makes pointer from integer without a cast
6181 ///  pint = pfoo; // warning: assignment from incompatible pointer type
6182 ///
6183 /// As a result, the code for dealing with pointers is more complex than the
6184 /// C99 spec dictates.
6185 ///
6186 /// Sets 'Kind' for any result kind except Incompatible.
6187 Sema::AssignConvertType
6188 Sema::CheckAssignmentConstraints(QualType LHSType, ExprResult &RHS,
6189                                  CastKind &Kind) {
6190   QualType RHSType = RHS.get()->getType();
6191   QualType OrigLHSType = LHSType;
6192 
6193   // Get canonical types.  We're not formatting these types, just comparing
6194   // them.
6195   LHSType = Context.getCanonicalType(LHSType).getUnqualifiedType();
6196   RHSType = Context.getCanonicalType(RHSType).getUnqualifiedType();
6197 
6198   // Common case: no conversion required.
6199   if (LHSType == RHSType) {
6200     Kind = CK_NoOp;
6201     return Compatible;
6202   }
6203 
6204   // If we have an atomic type, try a non-atomic assignment, then just add an
6205   // atomic qualification step.
6206   if (const AtomicType *AtomicTy = dyn_cast<AtomicType>(LHSType)) {
6207     Sema::AssignConvertType result =
6208       CheckAssignmentConstraints(AtomicTy->getValueType(), RHS, Kind);
6209     if (result != Compatible)
6210       return result;
6211     if (Kind != CK_NoOp)
6212       RHS = ImpCastExprToType(RHS.take(), AtomicTy->getValueType(), Kind);
6213     Kind = CK_NonAtomicToAtomic;
6214     return Compatible;
6215   }
6216 
6217   // If the left-hand side is a reference type, then we are in a
6218   // (rare!) case where we've allowed the use of references in C,
6219   // e.g., as a parameter type in a built-in function. In this case,
6220   // just make sure that the type referenced is compatible with the
6221   // right-hand side type. The caller is responsible for adjusting
6222   // LHSType so that the resulting expression does not have reference
6223   // type.
6224   if (const ReferenceType *LHSTypeRef = LHSType->getAs<ReferenceType>()) {
6225     if (Context.typesAreCompatible(LHSTypeRef->getPointeeType(), RHSType)) {
6226       Kind = CK_LValueBitCast;
6227       return Compatible;
6228     }
6229     return Incompatible;
6230   }
6231 
6232   // Allow scalar to ExtVector assignments, and assignments of an ExtVector type
6233   // to the same ExtVector type.
6234   if (LHSType->isExtVectorType()) {
6235     if (RHSType->isExtVectorType())
6236       return Incompatible;
6237     if (RHSType->isArithmeticType()) {
6238       // CK_VectorSplat does T -> vector T, so first cast to the
6239       // element type.
6240       QualType elType = cast<ExtVectorType>(LHSType)->getElementType();
6241       if (elType != RHSType) {
6242         Kind = PrepareScalarCast(RHS, elType);
6243         RHS = ImpCastExprToType(RHS.take(), elType, Kind);
6244       }
6245       Kind = CK_VectorSplat;
6246       return Compatible;
6247     }
6248   }
6249 
6250   // Conversions to or from vector type.
6251   if (LHSType->isVectorType() || RHSType->isVectorType()) {
6252     if (LHSType->isVectorType() && RHSType->isVectorType()) {
6253       // Allow assignments of an AltiVec vector type to an equivalent GCC
6254       // vector type and vice versa
6255       if (Context.areCompatibleVectorTypes(LHSType, RHSType)) {
6256         Kind = CK_BitCast;
6257         return Compatible;
6258       }
6259 
6260       // If we are allowing lax vector conversions, and LHS and RHS are both
6261       // vectors, the total size only needs to be the same. This is a bitcast;
6262       // no bits are changed but the result type is different.
6263       if (getLangOpts().LaxVectorConversions &&
6264           (Context.getTypeSize(LHSType) == Context.getTypeSize(RHSType))) {
6265         Kind = CK_BitCast;
6266         return IncompatibleVectors;
6267       }
6268     }
6269     return Incompatible;
6270   }
6271 
6272   // Arithmetic conversions.
6273   if (LHSType->isArithmeticType() && RHSType->isArithmeticType() &&
6274       !(getLangOpts().CPlusPlus && LHSType->isEnumeralType())) {
6275     Kind = PrepareScalarCast(RHS, LHSType);
6276     return Compatible;
6277   }
6278 
6279   // Conversions to normal pointers.
6280   if (const PointerType *LHSPointer = dyn_cast<PointerType>(LHSType)) {
6281     // U* -> T*
6282     if (isa<PointerType>(RHSType)) {
6283       Kind = CK_BitCast;
6284       return checkPointerTypesForAssignment(*this, LHSType, RHSType);
6285     }
6286 
6287     // int -> T*
6288     if (RHSType->isIntegerType()) {
6289       Kind = CK_IntegralToPointer; // FIXME: null?
6290       return IntToPointer;
6291     }
6292 
6293     // C pointers are not compatible with ObjC object pointers,
6294     // with two exceptions:
6295     if (isa<ObjCObjectPointerType>(RHSType)) {
6296       //  - conversions to void*
6297       if (LHSPointer->getPointeeType()->isVoidType()) {
6298         Kind = CK_BitCast;
6299         return Compatible;
6300       }
6301 
6302       //  - conversions from 'Class' to the redefinition type
6303       if (RHSType->isObjCClassType() &&
6304           Context.hasSameType(LHSType,
6305                               Context.getObjCClassRedefinitionType())) {
6306         Kind = CK_BitCast;
6307         return Compatible;
6308       }
6309 
6310       Kind = CK_BitCast;
6311       return IncompatiblePointer;
6312     }
6313 
6314     // U^ -> void*
6315     if (RHSType->getAs<BlockPointerType>()) {
6316       if (LHSPointer->getPointeeType()->isVoidType()) {
6317         Kind = CK_BitCast;
6318         return Compatible;
6319       }
6320     }
6321 
6322     return Incompatible;
6323   }
6324 
6325   // Conversions to block pointers.
6326   if (isa<BlockPointerType>(LHSType)) {
6327     // U^ -> T^
6328     if (RHSType->isBlockPointerType()) {
6329       Kind = CK_BitCast;
6330       return checkBlockPointerTypesForAssignment(*this, LHSType, RHSType);
6331     }
6332 
6333     // int or null -> T^
6334     if (RHSType->isIntegerType()) {
6335       Kind = CK_IntegralToPointer; // FIXME: null
6336       return IntToBlockPointer;
6337     }
6338 
6339     // id -> T^
6340     if (getLangOpts().ObjC1 && RHSType->isObjCIdType()) {
6341       Kind = CK_AnyPointerToBlockPointerCast;
6342       return Compatible;
6343     }
6344 
6345     // void* -> T^
6346     if (const PointerType *RHSPT = RHSType->getAs<PointerType>())
6347       if (RHSPT->getPointeeType()->isVoidType()) {
6348         Kind = CK_AnyPointerToBlockPointerCast;
6349         return Compatible;
6350       }
6351 
6352     return Incompatible;
6353   }
6354 
6355   // Conversions to Objective-C pointers.
6356   if (isa<ObjCObjectPointerType>(LHSType)) {
6357     // A* -> B*
6358     if (RHSType->isObjCObjectPointerType()) {
6359       Kind = CK_BitCast;
6360       Sema::AssignConvertType result =
6361         checkObjCPointerTypesForAssignment(*this, LHSType, RHSType);
6362       if (getLangOpts().ObjCAutoRefCount &&
6363           result == Compatible &&
6364           !CheckObjCARCUnavailableWeakConversion(OrigLHSType, RHSType))
6365         result = IncompatibleObjCWeakRef;
6366       return result;
6367     }
6368 
6369     // int or null -> A*
6370     if (RHSType->isIntegerType()) {
6371       Kind = CK_IntegralToPointer; // FIXME: null
6372       return IntToPointer;
6373     }
6374 
6375     // In general, C pointers are not compatible with ObjC object pointers,
6376     // with two exceptions:
6377     if (isa<PointerType>(RHSType)) {
6378       Kind = CK_CPointerToObjCPointerCast;
6379 
6380       //  - conversions from 'void*'
6381       if (RHSType->isVoidPointerType()) {
6382         return Compatible;
6383       }
6384 
6385       //  - conversions to 'Class' from its redefinition type
6386       if (LHSType->isObjCClassType() &&
6387           Context.hasSameType(RHSType,
6388                               Context.getObjCClassRedefinitionType())) {
6389         return Compatible;
6390       }
6391 
6392       return IncompatiblePointer;
6393     }
6394 
6395     // T^ -> A*
6396     if (RHSType->isBlockPointerType()) {
6397       maybeExtendBlockObject(*this, RHS);
6398       Kind = CK_BlockPointerToObjCPointerCast;
6399       return Compatible;
6400     }
6401 
6402     return Incompatible;
6403   }
6404 
6405   // Conversions from pointers that are not covered by the above.
6406   if (isa<PointerType>(RHSType)) {
6407     // T* -> _Bool
6408     if (LHSType == Context.BoolTy) {
6409       Kind = CK_PointerToBoolean;
6410       return Compatible;
6411     }
6412 
6413     // T* -> int
6414     if (LHSType->isIntegerType()) {
6415       Kind = CK_PointerToIntegral;
6416       return PointerToInt;
6417     }
6418 
6419     return Incompatible;
6420   }
6421 
6422   // Conversions from Objective-C pointers that are not covered by the above.
6423   if (isa<ObjCObjectPointerType>(RHSType)) {
6424     // T* -> _Bool
6425     if (LHSType == Context.BoolTy) {
6426       Kind = CK_PointerToBoolean;
6427       return Compatible;
6428     }
6429 
6430     // T* -> int
6431     if (LHSType->isIntegerType()) {
6432       Kind = CK_PointerToIntegral;
6433       return PointerToInt;
6434     }
6435 
6436     return Incompatible;
6437   }
6438 
6439   // struct A -> struct B
6440   if (isa<TagType>(LHSType) && isa<TagType>(RHSType)) {
6441     if (Context.typesAreCompatible(LHSType, RHSType)) {
6442       Kind = CK_NoOp;
6443       return Compatible;
6444     }
6445   }
6446 
6447   return Incompatible;
6448 }
6449 
6450 /// \brief Constructs a transparent union from an expression that is
6451 /// used to initialize the transparent union.
6452 static void ConstructTransparentUnion(Sema &S, ASTContext &C,
6453                                       ExprResult &EResult, QualType UnionType,
6454                                       FieldDecl *Field) {
6455   // Build an initializer list that designates the appropriate member
6456   // of the transparent union.
6457   Expr *E = EResult.take();
6458   InitListExpr *Initializer = new (C) InitListExpr(C, SourceLocation(),
6459                                                    E, SourceLocation());
6460   Initializer->setType(UnionType);
6461   Initializer->setInitializedFieldInUnion(Field);
6462 
6463   // Build a compound literal constructing a value of the transparent
6464   // union type from this initializer list.
6465   TypeSourceInfo *unionTInfo = C.getTrivialTypeSourceInfo(UnionType);
6466   EResult = S.Owned(
6467     new (C) CompoundLiteralExpr(SourceLocation(), unionTInfo, UnionType,
6468                                 VK_RValue, Initializer, false));
6469 }
6470 
6471 Sema::AssignConvertType
6472 Sema::CheckTransparentUnionArgumentConstraints(QualType ArgType,
6473                                                ExprResult &RHS) {
6474   QualType RHSType = RHS.get()->getType();
6475 
6476   // If the ArgType is a Union type, we want to handle a potential
6477   // transparent_union GCC extension.
6478   const RecordType *UT = ArgType->getAsUnionType();
6479   if (!UT || !UT->getDecl()->hasAttr<TransparentUnionAttr>())
6480     return Incompatible;
6481 
6482   // The field to initialize within the transparent union.
6483   RecordDecl *UD = UT->getDecl();
6484   FieldDecl *InitField = 0;
6485   // It's compatible if the expression matches any of the fields.
6486   for (RecordDecl::field_iterator it = UD->field_begin(),
6487          itend = UD->field_end();
6488        it != itend; ++it) {
6489     if (it->getType()->isPointerType()) {
6490       // If the transparent union contains a pointer type, we allow:
6491       // 1) void pointer
6492       // 2) null pointer constant
6493       if (RHSType->isPointerType())
6494         if (RHSType->castAs<PointerType>()->getPointeeType()->isVoidType()) {
6495           RHS = ImpCastExprToType(RHS.take(), it->getType(), CK_BitCast);
6496           InitField = *it;
6497           break;
6498         }
6499 
6500       if (RHS.get()->isNullPointerConstant(Context,
6501                                            Expr::NPC_ValueDependentIsNull)) {
6502         RHS = ImpCastExprToType(RHS.take(), it->getType(),
6503                                 CK_NullToPointer);
6504         InitField = *it;
6505         break;
6506       }
6507     }
6508 
6509     CastKind Kind = CK_Invalid;
6510     if (CheckAssignmentConstraints(it->getType(), RHS, Kind)
6511           == Compatible) {
6512       RHS = ImpCastExprToType(RHS.take(), it->getType(), Kind);
6513       InitField = *it;
6514       break;
6515     }
6516   }
6517 
6518   if (!InitField)
6519     return Incompatible;
6520 
6521   ConstructTransparentUnion(*this, Context, RHS, ArgType, InitField);
6522   return Compatible;
6523 }
6524 
6525 Sema::AssignConvertType
6526 Sema::CheckSingleAssignmentConstraints(QualType LHSType, ExprResult &RHS,
6527                                        bool Diagnose,
6528                                        bool DiagnoseCFAudited) {
6529   if (getLangOpts().CPlusPlus) {
6530     if (!LHSType->isRecordType() && !LHSType->isAtomicType()) {
6531       // C++ 5.17p3: If the left operand is not of class type, the
6532       // expression is implicitly converted (C++ 4) to the
6533       // cv-unqualified type of the left operand.
6534       ExprResult Res;
6535       if (Diagnose) {
6536         Res = PerformImplicitConversion(RHS.get(), LHSType.getUnqualifiedType(),
6537                                         AA_Assigning);
6538       } else {
6539         ImplicitConversionSequence ICS =
6540             TryImplicitConversion(RHS.get(), LHSType.getUnqualifiedType(),
6541                                   /*SuppressUserConversions=*/false,
6542                                   /*AllowExplicit=*/false,
6543                                   /*InOverloadResolution=*/false,
6544                                   /*CStyle=*/false,
6545                                   /*AllowObjCWritebackConversion=*/false);
6546         if (ICS.isFailure())
6547           return Incompatible;
6548         Res = PerformImplicitConversion(RHS.get(), LHSType.getUnqualifiedType(),
6549                                         ICS, AA_Assigning);
6550       }
6551       if (Res.isInvalid())
6552         return Incompatible;
6553       Sema::AssignConvertType result = Compatible;
6554       if (getLangOpts().ObjCAutoRefCount &&
6555           !CheckObjCARCUnavailableWeakConversion(LHSType,
6556                                                  RHS.get()->getType()))
6557         result = IncompatibleObjCWeakRef;
6558       RHS = Res;
6559       return result;
6560     }
6561 
6562     // FIXME: Currently, we fall through and treat C++ classes like C
6563     // structures.
6564     // FIXME: We also fall through for atomics; not sure what should
6565     // happen there, though.
6566   }
6567 
6568   // C99 6.5.16.1p1: the left operand is a pointer and the right is
6569   // a null pointer constant.
6570   if ((LHSType->isPointerType() || LHSType->isObjCObjectPointerType() ||
6571        LHSType->isBlockPointerType()) &&
6572       RHS.get()->isNullPointerConstant(Context,
6573                                        Expr::NPC_ValueDependentIsNull)) {
6574     CastKind Kind;
6575     CXXCastPath Path;
6576     CheckPointerConversion(RHS.get(), LHSType, Kind, Path, false);
6577     RHS = ImpCastExprToType(RHS.take(), LHSType, Kind, VK_RValue, &Path);
6578     return Compatible;
6579   }
6580 
6581   // This check seems unnatural, however it is necessary to ensure the proper
6582   // conversion of functions/arrays. If the conversion were done for all
6583   // DeclExpr's (created by ActOnIdExpression), it would mess up the unary
6584   // expressions that suppress this implicit conversion (&, sizeof).
6585   //
6586   // Suppress this for references: C++ 8.5.3p5.
6587   if (!LHSType->isReferenceType()) {
6588     RHS = DefaultFunctionArrayLvalueConversion(RHS.take());
6589     if (RHS.isInvalid())
6590       return Incompatible;
6591   }
6592 
6593   CastKind Kind = CK_Invalid;
6594   Sema::AssignConvertType result =
6595     CheckAssignmentConstraints(LHSType, RHS, Kind);
6596 
6597   // C99 6.5.16.1p2: The value of the right operand is converted to the
6598   // type of the assignment expression.
6599   // CheckAssignmentConstraints allows the left-hand side to be a reference,
6600   // so that we can use references in built-in functions even in C.
6601   // The getNonReferenceType() call makes sure that the resulting expression
6602   // does not have reference type.
6603   if (result != Incompatible && RHS.get()->getType() != LHSType) {
6604     QualType Ty = LHSType.getNonLValueExprType(Context);
6605     Expr *E = RHS.take();
6606     if (getLangOpts().ObjCAutoRefCount)
6607       CheckObjCARCConversion(SourceRange(), Ty, E, CCK_ImplicitConversion,
6608                              DiagnoseCFAudited);
6609     if (getLangOpts().ObjC1 &&
6610         (CheckObjCBridgeRelatedConversions(E->getLocStart(),
6611                                           LHSType, E->getType(), E) ||
6612          ConversionToObjCStringLiteralCheck(LHSType, E))) {
6613       RHS = Owned(E);
6614       return Compatible;
6615     }
6616 
6617     RHS = ImpCastExprToType(E, Ty, Kind);
6618   }
6619   return result;
6620 }
6621 
6622 QualType Sema::InvalidOperands(SourceLocation Loc, ExprResult &LHS,
6623                                ExprResult &RHS) {
6624   Diag(Loc, diag::err_typecheck_invalid_operands)
6625     << LHS.get()->getType() << RHS.get()->getType()
6626     << LHS.get()->getSourceRange() << RHS.get()->getSourceRange();
6627   return QualType();
6628 }
6629 
6630 static bool areVectorOperandsLaxBitCastable(ASTContext &Ctx,
6631                                             QualType LHSType, QualType RHSType){
6632   if (!Ctx.getLangOpts().LaxVectorConversions)
6633     return false;
6634 
6635   if (!(LHSType->isVectorType() || LHSType->isScalarType()) ||
6636       !(RHSType->isVectorType() || RHSType->isScalarType()))
6637     return false;
6638 
6639   unsigned LHSSize = Ctx.getTypeSize(LHSType);
6640   unsigned RHSSize = Ctx.getTypeSize(RHSType);
6641   if (LHSSize != RHSSize)
6642     return false;
6643 
6644   // For a non-power-of-2 vector ASTContext::getTypeSize returns the size
6645   // rounded to the next power-of-2, but the LLVM IR type that we create
6646   // is considered to have num-of-elements*width-of-element width.
6647   // Make sure such width is the same between the types, otherwise we may end
6648   // up with an invalid bitcast.
6649   unsigned LHSIRSize, RHSIRSize;
6650   if (LHSType->isVectorType()) {
6651     const VectorType *Vec = LHSType->getAs<VectorType>();
6652     LHSIRSize = Vec->getNumElements() *
6653         Ctx.getTypeSize(Vec->getElementType());
6654   } else {
6655     LHSIRSize = LHSSize;
6656   }
6657   if (RHSType->isVectorType()) {
6658     const VectorType *Vec = RHSType->getAs<VectorType>();
6659     RHSIRSize = Vec->getNumElements() *
6660         Ctx.getTypeSize(Vec->getElementType());
6661   } else {
6662     RHSIRSize = RHSSize;
6663   }
6664   if (LHSIRSize != RHSIRSize)
6665     return false;
6666 
6667   return true;
6668 }
6669 
6670 QualType Sema::CheckVectorOperands(ExprResult &LHS, ExprResult &RHS,
6671                                    SourceLocation Loc, bool IsCompAssign) {
6672   if (!IsCompAssign) {
6673     LHS = DefaultFunctionArrayLvalueConversion(LHS.take());
6674     if (LHS.isInvalid())
6675       return QualType();
6676   }
6677   RHS = DefaultFunctionArrayLvalueConversion(RHS.take());
6678   if (RHS.isInvalid())
6679     return QualType();
6680 
6681   // For conversion purposes, we ignore any qualifiers.
6682   // For example, "const float" and "float" are equivalent.
6683   QualType LHSType =
6684     Context.getCanonicalType(LHS.get()->getType()).getUnqualifiedType();
6685   QualType RHSType =
6686     Context.getCanonicalType(RHS.get()->getType()).getUnqualifiedType();
6687 
6688   // If the vector types are identical, return.
6689   if (LHSType == RHSType)
6690     return LHSType;
6691 
6692   // Handle the case of equivalent AltiVec and GCC vector types
6693   if (LHSType->isVectorType() && RHSType->isVectorType() &&
6694       Context.areCompatibleVectorTypes(LHSType, RHSType)) {
6695     if (LHSType->isExtVectorType()) {
6696       RHS = ImpCastExprToType(RHS.take(), LHSType, CK_BitCast);
6697       return LHSType;
6698     }
6699 
6700     if (!IsCompAssign)
6701       LHS = ImpCastExprToType(LHS.take(), RHSType, CK_BitCast);
6702     return RHSType;
6703   }
6704 
6705   if (areVectorOperandsLaxBitCastable(Context, LHSType, RHSType)) {
6706     // If we are allowing lax vector conversions, and LHS and RHS are both
6707     // vectors, the total size only needs to be the same. This is a
6708     // bitcast; no bits are changed but the result type is different.
6709     // FIXME: Should we really be allowing this?
6710     RHS = ImpCastExprToType(RHS.take(), LHSType, CK_BitCast);
6711     return LHSType;
6712   }
6713 
6714   if (!(LHSType->isVectorType() || LHSType->isScalarType()) ||
6715       !(RHSType->isVectorType() || RHSType->isScalarType())) {
6716     Diag(Loc, diag::err_typecheck_vector_not_convertable_non_scalar)
6717     << LHS.get()->getType() << RHS.get()->getType()
6718     << LHS.get()->getSourceRange() << RHS.get()->getSourceRange();
6719     return QualType();
6720   }
6721 
6722   // Canonicalize the ExtVector to the LHS, remember if we swapped so we can
6723   // swap back (so that we don't reverse the inputs to a subtract, for instance.
6724   bool swapped = false;
6725   if (RHSType->isExtVectorType() && !IsCompAssign) {
6726     swapped = true;
6727     std::swap(RHS, LHS);
6728     std::swap(RHSType, LHSType);
6729   }
6730 
6731   // Handle the case of an ext vector and scalar.
6732   if (const ExtVectorType *LV = LHSType->getAs<ExtVectorType>()) {
6733     QualType EltTy = LV->getElementType();
6734     if (EltTy->isIntegralType(Context) && RHSType->isIntegralType(Context)) {
6735       int order = Context.getIntegerTypeOrder(EltTy, RHSType);
6736       if (order > 0)
6737         RHS = ImpCastExprToType(RHS.take(), EltTy, CK_IntegralCast);
6738       if (order >= 0) {
6739         RHS = ImpCastExprToType(RHS.take(), LHSType, CK_VectorSplat);
6740         if (swapped) std::swap(RHS, LHS);
6741         return LHSType;
6742       }
6743     }
6744     if (EltTy->isRealFloatingType() && RHSType->isScalarType()) {
6745       if (RHSType->isRealFloatingType()) {
6746         int order = Context.getFloatingTypeOrder(EltTy, RHSType);
6747         if (order > 0)
6748           RHS = ImpCastExprToType(RHS.take(), EltTy, CK_FloatingCast);
6749         if (order >= 0) {
6750           RHS = ImpCastExprToType(RHS.take(), LHSType, CK_VectorSplat);
6751           if (swapped) std::swap(RHS, LHS);
6752           return LHSType;
6753         }
6754       }
6755       if (RHSType->isIntegralType(Context)) {
6756         RHS = ImpCastExprToType(RHS.take(), EltTy, CK_IntegralToFloating);
6757         RHS = ImpCastExprToType(RHS.take(), LHSType, CK_VectorSplat);
6758         if (swapped) std::swap(RHS, LHS);
6759         return LHSType;
6760       }
6761     }
6762   }
6763 
6764   // Vectors of different size or scalar and non-ext-vector are errors.
6765   if (swapped) std::swap(RHS, LHS);
6766   Diag(Loc, diag::err_typecheck_vector_not_convertable)
6767     << LHS.get()->getType() << RHS.get()->getType()
6768     << LHS.get()->getSourceRange() << RHS.get()->getSourceRange();
6769   return QualType();
6770 }
6771 
6772 // checkArithmeticNull - Detect when a NULL constant is used improperly in an
6773 // expression.  These are mainly cases where the null pointer is used as an
6774 // integer instead of a pointer.
6775 static void checkArithmeticNull(Sema &S, ExprResult &LHS, ExprResult &RHS,
6776                                 SourceLocation Loc, bool IsCompare) {
6777   // The canonical way to check for a GNU null is with isNullPointerConstant,
6778   // but we use a bit of a hack here for speed; this is a relatively
6779   // hot path, and isNullPointerConstant is slow.
6780   bool LHSNull = isa<GNUNullExpr>(LHS.get()->IgnoreParenImpCasts());
6781   bool RHSNull = isa<GNUNullExpr>(RHS.get()->IgnoreParenImpCasts());
6782 
6783   QualType NonNullType = LHSNull ? RHS.get()->getType() : LHS.get()->getType();
6784 
6785   // Avoid analyzing cases where the result will either be invalid (and
6786   // diagnosed as such) or entirely valid and not something to warn about.
6787   if ((!LHSNull && !RHSNull) || NonNullType->isBlockPointerType() ||
6788       NonNullType->isMemberPointerType() || NonNullType->isFunctionType())
6789     return;
6790 
6791   // Comparison operations would not make sense with a null pointer no matter
6792   // what the other expression is.
6793   if (!IsCompare) {
6794     S.Diag(Loc, diag::warn_null_in_arithmetic_operation)
6795         << (LHSNull ? LHS.get()->getSourceRange() : SourceRange())
6796         << (RHSNull ? RHS.get()->getSourceRange() : SourceRange());
6797     return;
6798   }
6799 
6800   // The rest of the operations only make sense with a null pointer
6801   // if the other expression is a pointer.
6802   if (LHSNull == RHSNull || NonNullType->isAnyPointerType() ||
6803       NonNullType->canDecayToPointerType())
6804     return;
6805 
6806   S.Diag(Loc, diag::warn_null_in_comparison_operation)
6807       << LHSNull /* LHS is NULL */ << NonNullType
6808       << LHS.get()->getSourceRange() << RHS.get()->getSourceRange();
6809 }
6810 
6811 QualType Sema::CheckMultiplyDivideOperands(ExprResult &LHS, ExprResult &RHS,
6812                                            SourceLocation Loc,
6813                                            bool IsCompAssign, bool IsDiv) {
6814   checkArithmeticNull(*this, LHS, RHS, Loc, /*isCompare=*/false);
6815 
6816   if (LHS.get()->getType()->isVectorType() ||
6817       RHS.get()->getType()->isVectorType())
6818     return CheckVectorOperands(LHS, RHS, Loc, IsCompAssign);
6819 
6820   QualType compType = UsualArithmeticConversions(LHS, RHS, IsCompAssign);
6821   if (LHS.isInvalid() || RHS.isInvalid())
6822     return QualType();
6823 
6824 
6825   if (compType.isNull() || !compType->isArithmeticType())
6826     return InvalidOperands(Loc, LHS, RHS);
6827 
6828   // Check for division by zero.
6829   llvm::APSInt RHSValue;
6830   if (IsDiv && !RHS.get()->isValueDependent() &&
6831       RHS.get()->EvaluateAsInt(RHSValue, Context) && RHSValue == 0)
6832     DiagRuntimeBehavior(Loc, RHS.get(),
6833                         PDiag(diag::warn_division_by_zero)
6834                           << RHS.get()->getSourceRange());
6835 
6836   return compType;
6837 }
6838 
6839 QualType Sema::CheckRemainderOperands(
6840   ExprResult &LHS, ExprResult &RHS, SourceLocation Loc, bool IsCompAssign) {
6841   checkArithmeticNull(*this, LHS, RHS, Loc, /*isCompare=*/false);
6842 
6843   if (LHS.get()->getType()->isVectorType() ||
6844       RHS.get()->getType()->isVectorType()) {
6845     if (LHS.get()->getType()->hasIntegerRepresentation() &&
6846         RHS.get()->getType()->hasIntegerRepresentation())
6847       return CheckVectorOperands(LHS, RHS, Loc, IsCompAssign);
6848     return InvalidOperands(Loc, LHS, RHS);
6849   }
6850 
6851   QualType compType = UsualArithmeticConversions(LHS, RHS, IsCompAssign);
6852   if (LHS.isInvalid() || RHS.isInvalid())
6853     return QualType();
6854 
6855   if (compType.isNull() || !compType->isIntegerType())
6856     return InvalidOperands(Loc, LHS, RHS);
6857 
6858   // Check for remainder by zero.
6859   llvm::APSInt RHSValue;
6860   if (!RHS.get()->isValueDependent() &&
6861       RHS.get()->EvaluateAsInt(RHSValue, Context) && RHSValue == 0)
6862     DiagRuntimeBehavior(Loc, RHS.get(),
6863                         PDiag(diag::warn_remainder_by_zero)
6864                           << RHS.get()->getSourceRange());
6865 
6866   return compType;
6867 }
6868 
6869 /// \brief Diagnose invalid arithmetic on two void pointers.
6870 static void diagnoseArithmeticOnTwoVoidPointers(Sema &S, SourceLocation Loc,
6871                                                 Expr *LHSExpr, Expr *RHSExpr) {
6872   S.Diag(Loc, S.getLangOpts().CPlusPlus
6873                 ? diag::err_typecheck_pointer_arith_void_type
6874                 : diag::ext_gnu_void_ptr)
6875     << 1 /* two pointers */ << LHSExpr->getSourceRange()
6876                             << RHSExpr->getSourceRange();
6877 }
6878 
6879 /// \brief Diagnose invalid arithmetic on a void pointer.
6880 static void diagnoseArithmeticOnVoidPointer(Sema &S, SourceLocation Loc,
6881                                             Expr *Pointer) {
6882   S.Diag(Loc, S.getLangOpts().CPlusPlus
6883                 ? diag::err_typecheck_pointer_arith_void_type
6884                 : diag::ext_gnu_void_ptr)
6885     << 0 /* one pointer */ << Pointer->getSourceRange();
6886 }
6887 
6888 /// \brief Diagnose invalid arithmetic on two function pointers.
6889 static void diagnoseArithmeticOnTwoFunctionPointers(Sema &S, SourceLocation Loc,
6890                                                     Expr *LHS, Expr *RHS) {
6891   assert(LHS->getType()->isAnyPointerType());
6892   assert(RHS->getType()->isAnyPointerType());
6893   S.Diag(Loc, S.getLangOpts().CPlusPlus
6894                 ? diag::err_typecheck_pointer_arith_function_type
6895                 : diag::ext_gnu_ptr_func_arith)
6896     << 1 /* two pointers */ << LHS->getType()->getPointeeType()
6897     // We only show the second type if it differs from the first.
6898     << (unsigned)!S.Context.hasSameUnqualifiedType(LHS->getType(),
6899                                                    RHS->getType())
6900     << RHS->getType()->getPointeeType()
6901     << LHS->getSourceRange() << RHS->getSourceRange();
6902 }
6903 
6904 /// \brief Diagnose invalid arithmetic on a function pointer.
6905 static void diagnoseArithmeticOnFunctionPointer(Sema &S, SourceLocation Loc,
6906                                                 Expr *Pointer) {
6907   assert(Pointer->getType()->isAnyPointerType());
6908   S.Diag(Loc, S.getLangOpts().CPlusPlus
6909                 ? diag::err_typecheck_pointer_arith_function_type
6910                 : diag::ext_gnu_ptr_func_arith)
6911     << 0 /* one pointer */ << Pointer->getType()->getPointeeType()
6912     << 0 /* one pointer, so only one type */
6913     << Pointer->getSourceRange();
6914 }
6915 
6916 /// \brief Emit error if Operand is incomplete pointer type
6917 ///
6918 /// \returns True if pointer has incomplete type
6919 static bool checkArithmeticIncompletePointerType(Sema &S, SourceLocation Loc,
6920                                                  Expr *Operand) {
6921   assert(Operand->getType()->isAnyPointerType() &&
6922          !Operand->getType()->isDependentType());
6923   QualType PointeeTy = Operand->getType()->getPointeeType();
6924   return S.RequireCompleteType(Loc, PointeeTy,
6925                                diag::err_typecheck_arithmetic_incomplete_type,
6926                                PointeeTy, Operand->getSourceRange());
6927 }
6928 
6929 /// \brief Check the validity of an arithmetic pointer operand.
6930 ///
6931 /// If the operand has pointer type, this code will check for pointer types
6932 /// which are invalid in arithmetic operations. These will be diagnosed
6933 /// appropriately, including whether or not the use is supported as an
6934 /// extension.
6935 ///
6936 /// \returns True when the operand is valid to use (even if as an extension).
6937 static bool checkArithmeticOpPointerOperand(Sema &S, SourceLocation Loc,
6938                                             Expr *Operand) {
6939   if (!Operand->getType()->isAnyPointerType()) return true;
6940 
6941   QualType PointeeTy = Operand->getType()->getPointeeType();
6942   if (PointeeTy->isVoidType()) {
6943     diagnoseArithmeticOnVoidPointer(S, Loc, Operand);
6944     return !S.getLangOpts().CPlusPlus;
6945   }
6946   if (PointeeTy->isFunctionType()) {
6947     diagnoseArithmeticOnFunctionPointer(S, Loc, Operand);
6948     return !S.getLangOpts().CPlusPlus;
6949   }
6950 
6951   if (checkArithmeticIncompletePointerType(S, Loc, Operand)) return false;
6952 
6953   return true;
6954 }
6955 
6956 /// \brief Check the validity of a binary arithmetic operation w.r.t. pointer
6957 /// operands.
6958 ///
6959 /// This routine will diagnose any invalid arithmetic on pointer operands much
6960 /// like \see checkArithmeticOpPointerOperand. However, it has special logic
6961 /// for emitting a single diagnostic even for operations where both LHS and RHS
6962 /// are (potentially problematic) pointers.
6963 ///
6964 /// \returns True when the operand is valid to use (even if as an extension).
6965 static bool checkArithmeticBinOpPointerOperands(Sema &S, SourceLocation Loc,
6966                                                 Expr *LHSExpr, Expr *RHSExpr) {
6967   bool isLHSPointer = LHSExpr->getType()->isAnyPointerType();
6968   bool isRHSPointer = RHSExpr->getType()->isAnyPointerType();
6969   if (!isLHSPointer && !isRHSPointer) return true;
6970 
6971   QualType LHSPointeeTy, RHSPointeeTy;
6972   if (isLHSPointer) LHSPointeeTy = LHSExpr->getType()->getPointeeType();
6973   if (isRHSPointer) RHSPointeeTy = RHSExpr->getType()->getPointeeType();
6974 
6975   // Check for arithmetic on pointers to incomplete types.
6976   bool isLHSVoidPtr = isLHSPointer && LHSPointeeTy->isVoidType();
6977   bool isRHSVoidPtr = isRHSPointer && RHSPointeeTy->isVoidType();
6978   if (isLHSVoidPtr || isRHSVoidPtr) {
6979     if (!isRHSVoidPtr) diagnoseArithmeticOnVoidPointer(S, Loc, LHSExpr);
6980     else if (!isLHSVoidPtr) diagnoseArithmeticOnVoidPointer(S, Loc, RHSExpr);
6981     else diagnoseArithmeticOnTwoVoidPointers(S, Loc, LHSExpr, RHSExpr);
6982 
6983     return !S.getLangOpts().CPlusPlus;
6984   }
6985 
6986   bool isLHSFuncPtr = isLHSPointer && LHSPointeeTy->isFunctionType();
6987   bool isRHSFuncPtr = isRHSPointer && RHSPointeeTy->isFunctionType();
6988   if (isLHSFuncPtr || isRHSFuncPtr) {
6989     if (!isRHSFuncPtr) diagnoseArithmeticOnFunctionPointer(S, Loc, LHSExpr);
6990     else if (!isLHSFuncPtr) diagnoseArithmeticOnFunctionPointer(S, Loc,
6991                                                                 RHSExpr);
6992     else diagnoseArithmeticOnTwoFunctionPointers(S, Loc, LHSExpr, RHSExpr);
6993 
6994     return !S.getLangOpts().CPlusPlus;
6995   }
6996 
6997   if (isLHSPointer && checkArithmeticIncompletePointerType(S, Loc, LHSExpr))
6998     return false;
6999   if (isRHSPointer && checkArithmeticIncompletePointerType(S, Loc, RHSExpr))
7000     return false;
7001 
7002   return true;
7003 }
7004 
7005 /// diagnoseStringPlusInt - Emit a warning when adding an integer to a string
7006 /// literal.
7007 static void diagnoseStringPlusInt(Sema &Self, SourceLocation OpLoc,
7008                                   Expr *LHSExpr, Expr *RHSExpr) {
7009   StringLiteral* StrExpr = dyn_cast<StringLiteral>(LHSExpr->IgnoreImpCasts());
7010   Expr* IndexExpr = RHSExpr;
7011   if (!StrExpr) {
7012     StrExpr = dyn_cast<StringLiteral>(RHSExpr->IgnoreImpCasts());
7013     IndexExpr = LHSExpr;
7014   }
7015 
7016   bool IsStringPlusInt = StrExpr &&
7017       IndexExpr->getType()->isIntegralOrUnscopedEnumerationType();
7018   if (!IsStringPlusInt)
7019     return;
7020 
7021   llvm::APSInt index;
7022   if (IndexExpr->EvaluateAsInt(index, Self.getASTContext())) {
7023     unsigned StrLenWithNull = StrExpr->getLength() + 1;
7024     if (index.isNonNegative() &&
7025         index <= llvm::APSInt(llvm::APInt(index.getBitWidth(), StrLenWithNull),
7026                               index.isUnsigned()))
7027       return;
7028   }
7029 
7030   SourceRange DiagRange(LHSExpr->getLocStart(), RHSExpr->getLocEnd());
7031   Self.Diag(OpLoc, diag::warn_string_plus_int)
7032       << DiagRange << IndexExpr->IgnoreImpCasts()->getType();
7033 
7034   // Only print a fixit for "str" + int, not for int + "str".
7035   if (IndexExpr == RHSExpr) {
7036     SourceLocation EndLoc = Self.PP.getLocForEndOfToken(RHSExpr->getLocEnd());
7037     Self.Diag(OpLoc, diag::note_string_plus_scalar_silence)
7038         << FixItHint::CreateInsertion(LHSExpr->getLocStart(), "&")
7039         << FixItHint::CreateReplacement(SourceRange(OpLoc), "[")
7040         << FixItHint::CreateInsertion(EndLoc, "]");
7041   } else
7042     Self.Diag(OpLoc, diag::note_string_plus_scalar_silence);
7043 }
7044 
7045 /// \brief Emit a warning when adding a char literal to a string.
7046 static void diagnoseStringPlusChar(Sema &Self, SourceLocation OpLoc,
7047                                    Expr *LHSExpr, Expr *RHSExpr) {
7048   const DeclRefExpr *StringRefExpr =
7049       dyn_cast<DeclRefExpr>(LHSExpr->IgnoreImpCasts());
7050   const CharacterLiteral *CharExpr =
7051       dyn_cast<CharacterLiteral>(RHSExpr->IgnoreImpCasts());
7052   if (!StringRefExpr) {
7053     StringRefExpr = dyn_cast<DeclRefExpr>(RHSExpr->IgnoreImpCasts());
7054     CharExpr = dyn_cast<CharacterLiteral>(LHSExpr->IgnoreImpCasts());
7055   }
7056 
7057   if (!CharExpr || !StringRefExpr)
7058     return;
7059 
7060   const QualType StringType = StringRefExpr->getType();
7061 
7062   // Return if not a PointerType.
7063   if (!StringType->isAnyPointerType())
7064     return;
7065 
7066   // Return if not a CharacterType.
7067   if (!StringType->getPointeeType()->isAnyCharacterType())
7068     return;
7069 
7070   ASTContext &Ctx = Self.getASTContext();
7071   SourceRange DiagRange(LHSExpr->getLocStart(), RHSExpr->getLocEnd());
7072 
7073   const QualType CharType = CharExpr->getType();
7074   if (!CharType->isAnyCharacterType() &&
7075       CharType->isIntegerType() &&
7076       llvm::isUIntN(Ctx.getCharWidth(), CharExpr->getValue())) {
7077     Self.Diag(OpLoc, diag::warn_string_plus_char)
7078         << DiagRange << Ctx.CharTy;
7079   } else {
7080     Self.Diag(OpLoc, diag::warn_string_plus_char)
7081         << DiagRange << CharExpr->getType();
7082   }
7083 
7084   // Only print a fixit for str + char, not for char + str.
7085   if (isa<CharacterLiteral>(RHSExpr->IgnoreImpCasts())) {
7086     SourceLocation EndLoc = Self.PP.getLocForEndOfToken(RHSExpr->getLocEnd());
7087     Self.Diag(OpLoc, diag::note_string_plus_scalar_silence)
7088         << FixItHint::CreateInsertion(LHSExpr->getLocStart(), "&")
7089         << FixItHint::CreateReplacement(SourceRange(OpLoc), "[")
7090         << FixItHint::CreateInsertion(EndLoc, "]");
7091   } else {
7092     Self.Diag(OpLoc, diag::note_string_plus_scalar_silence);
7093   }
7094 }
7095 
7096 /// \brief Emit error when two pointers are incompatible.
7097 static void diagnosePointerIncompatibility(Sema &S, SourceLocation Loc,
7098                                            Expr *LHSExpr, Expr *RHSExpr) {
7099   assert(LHSExpr->getType()->isAnyPointerType());
7100   assert(RHSExpr->getType()->isAnyPointerType());
7101   S.Diag(Loc, diag::err_typecheck_sub_ptr_compatible)
7102     << LHSExpr->getType() << RHSExpr->getType() << LHSExpr->getSourceRange()
7103     << RHSExpr->getSourceRange();
7104 }
7105 
7106 QualType Sema::CheckAdditionOperands( // C99 6.5.6
7107     ExprResult &LHS, ExprResult &RHS, SourceLocation Loc, unsigned Opc,
7108     QualType* CompLHSTy) {
7109   checkArithmeticNull(*this, LHS, RHS, Loc, /*isCompare=*/false);
7110 
7111   if (LHS.get()->getType()->isVectorType() ||
7112       RHS.get()->getType()->isVectorType()) {
7113     QualType compType = CheckVectorOperands(LHS, RHS, Loc, CompLHSTy);
7114     if (CompLHSTy) *CompLHSTy = compType;
7115     return compType;
7116   }
7117 
7118   QualType compType = UsualArithmeticConversions(LHS, RHS, CompLHSTy);
7119   if (LHS.isInvalid() || RHS.isInvalid())
7120     return QualType();
7121 
7122   // Diagnose "string literal" '+' int and string '+' "char literal".
7123   if (Opc == BO_Add) {
7124     diagnoseStringPlusInt(*this, Loc, LHS.get(), RHS.get());
7125     diagnoseStringPlusChar(*this, Loc, LHS.get(), RHS.get());
7126   }
7127 
7128   // handle the common case first (both operands are arithmetic).
7129   if (!compType.isNull() && compType->isArithmeticType()) {
7130     if (CompLHSTy) *CompLHSTy = compType;
7131     return compType;
7132   }
7133 
7134   // Type-checking.  Ultimately the pointer's going to be in PExp;
7135   // note that we bias towards the LHS being the pointer.
7136   Expr *PExp = LHS.get(), *IExp = RHS.get();
7137 
7138   bool isObjCPointer;
7139   if (PExp->getType()->isPointerType()) {
7140     isObjCPointer = false;
7141   } else if (PExp->getType()->isObjCObjectPointerType()) {
7142     isObjCPointer = true;
7143   } else {
7144     std::swap(PExp, IExp);
7145     if (PExp->getType()->isPointerType()) {
7146       isObjCPointer = false;
7147     } else if (PExp->getType()->isObjCObjectPointerType()) {
7148       isObjCPointer = true;
7149     } else {
7150       return InvalidOperands(Loc, LHS, RHS);
7151     }
7152   }
7153   assert(PExp->getType()->isAnyPointerType());
7154 
7155   if (!IExp->getType()->isIntegerType())
7156     return InvalidOperands(Loc, LHS, RHS);
7157 
7158   if (!checkArithmeticOpPointerOperand(*this, Loc, PExp))
7159     return QualType();
7160 
7161   if (isObjCPointer && checkArithmeticOnObjCPointer(*this, Loc, PExp))
7162     return QualType();
7163 
7164   // Check array bounds for pointer arithemtic
7165   CheckArrayAccess(PExp, IExp);
7166 
7167   if (CompLHSTy) {
7168     QualType LHSTy = Context.isPromotableBitField(LHS.get());
7169     if (LHSTy.isNull()) {
7170       LHSTy = LHS.get()->getType();
7171       if (LHSTy->isPromotableIntegerType())
7172         LHSTy = Context.getPromotedIntegerType(LHSTy);
7173     }
7174     *CompLHSTy = LHSTy;
7175   }
7176 
7177   return PExp->getType();
7178 }
7179 
7180 // C99 6.5.6
7181 QualType Sema::CheckSubtractionOperands(ExprResult &LHS, ExprResult &RHS,
7182                                         SourceLocation Loc,
7183                                         QualType* CompLHSTy) {
7184   checkArithmeticNull(*this, LHS, RHS, Loc, /*isCompare=*/false);
7185 
7186   if (LHS.get()->getType()->isVectorType() ||
7187       RHS.get()->getType()->isVectorType()) {
7188     QualType compType = CheckVectorOperands(LHS, RHS, Loc, CompLHSTy);
7189     if (CompLHSTy) *CompLHSTy = compType;
7190     return compType;
7191   }
7192 
7193   QualType compType = UsualArithmeticConversions(LHS, RHS, CompLHSTy);
7194   if (LHS.isInvalid() || RHS.isInvalid())
7195     return QualType();
7196 
7197   // Enforce type constraints: C99 6.5.6p3.
7198 
7199   // Handle the common case first (both operands are arithmetic).
7200   if (!compType.isNull() && compType->isArithmeticType()) {
7201     if (CompLHSTy) *CompLHSTy = compType;
7202     return compType;
7203   }
7204 
7205   // Either ptr - int   or   ptr - ptr.
7206   if (LHS.get()->getType()->isAnyPointerType()) {
7207     QualType lpointee = LHS.get()->getType()->getPointeeType();
7208 
7209     // Diagnose bad cases where we step over interface counts.
7210     if (LHS.get()->getType()->isObjCObjectPointerType() &&
7211         checkArithmeticOnObjCPointer(*this, Loc, LHS.get()))
7212       return QualType();
7213 
7214     // The result type of a pointer-int computation is the pointer type.
7215     if (RHS.get()->getType()->isIntegerType()) {
7216       if (!checkArithmeticOpPointerOperand(*this, Loc, LHS.get()))
7217         return QualType();
7218 
7219       // Check array bounds for pointer arithemtic
7220       CheckArrayAccess(LHS.get(), RHS.get(), /*ArraySubscriptExpr*/0,
7221                        /*AllowOnePastEnd*/true, /*IndexNegated*/true);
7222 
7223       if (CompLHSTy) *CompLHSTy = LHS.get()->getType();
7224       return LHS.get()->getType();
7225     }
7226 
7227     // Handle pointer-pointer subtractions.
7228     if (const PointerType *RHSPTy
7229           = RHS.get()->getType()->getAs<PointerType>()) {
7230       QualType rpointee = RHSPTy->getPointeeType();
7231 
7232       if (getLangOpts().CPlusPlus) {
7233         // Pointee types must be the same: C++ [expr.add]
7234         if (!Context.hasSameUnqualifiedType(lpointee, rpointee)) {
7235           diagnosePointerIncompatibility(*this, Loc, LHS.get(), RHS.get());
7236         }
7237       } else {
7238         // Pointee types must be compatible C99 6.5.6p3
7239         if (!Context.typesAreCompatible(
7240                 Context.getCanonicalType(lpointee).getUnqualifiedType(),
7241                 Context.getCanonicalType(rpointee).getUnqualifiedType())) {
7242           diagnosePointerIncompatibility(*this, Loc, LHS.get(), RHS.get());
7243           return QualType();
7244         }
7245       }
7246 
7247       if (!checkArithmeticBinOpPointerOperands(*this, Loc,
7248                                                LHS.get(), RHS.get()))
7249         return QualType();
7250 
7251       // The pointee type may have zero size.  As an extension, a structure or
7252       // union may have zero size or an array may have zero length.  In this
7253       // case subtraction does not make sense.
7254       if (!rpointee->isVoidType() && !rpointee->isFunctionType()) {
7255         CharUnits ElementSize = Context.getTypeSizeInChars(rpointee);
7256         if (ElementSize.isZero()) {
7257           Diag(Loc,diag::warn_sub_ptr_zero_size_types)
7258             << rpointee.getUnqualifiedType()
7259             << LHS.get()->getSourceRange() << RHS.get()->getSourceRange();
7260         }
7261       }
7262 
7263       if (CompLHSTy) *CompLHSTy = LHS.get()->getType();
7264       return Context.getPointerDiffType();
7265     }
7266   }
7267 
7268   return InvalidOperands(Loc, LHS, RHS);
7269 }
7270 
7271 static bool isScopedEnumerationType(QualType T) {
7272   if (const EnumType *ET = dyn_cast<EnumType>(T))
7273     return ET->getDecl()->isScoped();
7274   return false;
7275 }
7276 
7277 static void DiagnoseBadShiftValues(Sema& S, ExprResult &LHS, ExprResult &RHS,
7278                                    SourceLocation Loc, unsigned Opc,
7279                                    QualType LHSType) {
7280   // OpenCL 6.3j: shift values are effectively % word size of LHS (more defined),
7281   // so skip remaining warnings as we don't want to modify values within Sema.
7282   if (S.getLangOpts().OpenCL)
7283     return;
7284 
7285   llvm::APSInt Right;
7286   // Check right/shifter operand
7287   if (RHS.get()->isValueDependent() ||
7288       !RHS.get()->isIntegerConstantExpr(Right, S.Context))
7289     return;
7290 
7291   if (Right.isNegative()) {
7292     S.DiagRuntimeBehavior(Loc, RHS.get(),
7293                           S.PDiag(diag::warn_shift_negative)
7294                             << RHS.get()->getSourceRange());
7295     return;
7296   }
7297   llvm::APInt LeftBits(Right.getBitWidth(),
7298                        S.Context.getTypeSize(LHS.get()->getType()));
7299   if (Right.uge(LeftBits)) {
7300     S.DiagRuntimeBehavior(Loc, RHS.get(),
7301                           S.PDiag(diag::warn_shift_gt_typewidth)
7302                             << RHS.get()->getSourceRange());
7303     return;
7304   }
7305   if (Opc != BO_Shl)
7306     return;
7307 
7308   // When left shifting an ICE which is signed, we can check for overflow which
7309   // according to C++ has undefined behavior ([expr.shift] 5.8/2). Unsigned
7310   // integers have defined behavior modulo one more than the maximum value
7311   // representable in the result type, so never warn for those.
7312   llvm::APSInt Left;
7313   if (LHS.get()->isValueDependent() ||
7314       !LHS.get()->isIntegerConstantExpr(Left, S.Context) ||
7315       LHSType->hasUnsignedIntegerRepresentation())
7316     return;
7317   llvm::APInt ResultBits =
7318       static_cast<llvm::APInt&>(Right) + Left.getMinSignedBits();
7319   if (LeftBits.uge(ResultBits))
7320     return;
7321   llvm::APSInt Result = Left.extend(ResultBits.getLimitedValue());
7322   Result = Result.shl(Right);
7323 
7324   // Print the bit representation of the signed integer as an unsigned
7325   // hexadecimal number.
7326   SmallString<40> HexResult;
7327   Result.toString(HexResult, 16, /*Signed =*/false, /*Literal =*/true);
7328 
7329   // If we are only missing a sign bit, this is less likely to result in actual
7330   // bugs -- if the result is cast back to an unsigned type, it will have the
7331   // expected value. Thus we place this behind a different warning that can be
7332   // turned off separately if needed.
7333   if (LeftBits == ResultBits - 1) {
7334     S.Diag(Loc, diag::warn_shift_result_sets_sign_bit)
7335         << HexResult.str() << LHSType
7336         << LHS.get()->getSourceRange() << RHS.get()->getSourceRange();
7337     return;
7338   }
7339 
7340   S.Diag(Loc, diag::warn_shift_result_gt_typewidth)
7341     << HexResult.str() << Result.getMinSignedBits() << LHSType
7342     << Left.getBitWidth() << LHS.get()->getSourceRange()
7343     << RHS.get()->getSourceRange();
7344 }
7345 
7346 // C99 6.5.7
7347 QualType Sema::CheckShiftOperands(ExprResult &LHS, ExprResult &RHS,
7348                                   SourceLocation Loc, unsigned Opc,
7349                                   bool IsCompAssign) {
7350   checkArithmeticNull(*this, LHS, RHS, Loc, /*isCompare=*/false);
7351 
7352   // Vector shifts promote their scalar inputs to vector type.
7353   if (LHS.get()->getType()->isVectorType() ||
7354       RHS.get()->getType()->isVectorType())
7355     return CheckVectorOperands(LHS, RHS, Loc, IsCompAssign);
7356 
7357   // Shifts don't perform usual arithmetic conversions, they just do integer
7358   // promotions on each operand. C99 6.5.7p3
7359 
7360   // For the LHS, do usual unary conversions, but then reset them away
7361   // if this is a compound assignment.
7362   ExprResult OldLHS = LHS;
7363   LHS = UsualUnaryConversions(LHS.take());
7364   if (LHS.isInvalid())
7365     return QualType();
7366   QualType LHSType = LHS.get()->getType();
7367   if (IsCompAssign) LHS = OldLHS;
7368 
7369   // The RHS is simpler.
7370   RHS = UsualUnaryConversions(RHS.take());
7371   if (RHS.isInvalid())
7372     return QualType();
7373   QualType RHSType = RHS.get()->getType();
7374 
7375   // C99 6.5.7p2: Each of the operands shall have integer type.
7376   if (!LHSType->hasIntegerRepresentation() ||
7377       !RHSType->hasIntegerRepresentation())
7378     return InvalidOperands(Loc, LHS, RHS);
7379 
7380   // C++0x: Don't allow scoped enums. FIXME: Use something better than
7381   // hasIntegerRepresentation() above instead of this.
7382   if (isScopedEnumerationType(LHSType) ||
7383       isScopedEnumerationType(RHSType)) {
7384     return InvalidOperands(Loc, LHS, RHS);
7385   }
7386   // Sanity-check shift operands
7387   DiagnoseBadShiftValues(*this, LHS, RHS, Loc, Opc, LHSType);
7388 
7389   // "The type of the result is that of the promoted left operand."
7390   return LHSType;
7391 }
7392 
7393 static bool IsWithinTemplateSpecialization(Decl *D) {
7394   if (DeclContext *DC = D->getDeclContext()) {
7395     if (isa<ClassTemplateSpecializationDecl>(DC))
7396       return true;
7397     if (FunctionDecl *FD = dyn_cast<FunctionDecl>(DC))
7398       return FD->isFunctionTemplateSpecialization();
7399   }
7400   return false;
7401 }
7402 
7403 /// If two different enums are compared, raise a warning.
7404 static void checkEnumComparison(Sema &S, SourceLocation Loc, Expr *LHS,
7405                                 Expr *RHS) {
7406   QualType LHSStrippedType = LHS->IgnoreParenImpCasts()->getType();
7407   QualType RHSStrippedType = RHS->IgnoreParenImpCasts()->getType();
7408 
7409   const EnumType *LHSEnumType = LHSStrippedType->getAs<EnumType>();
7410   if (!LHSEnumType)
7411     return;
7412   const EnumType *RHSEnumType = RHSStrippedType->getAs<EnumType>();
7413   if (!RHSEnumType)
7414     return;
7415 
7416   // Ignore anonymous enums.
7417   if (!LHSEnumType->getDecl()->getIdentifier())
7418     return;
7419   if (!RHSEnumType->getDecl()->getIdentifier())
7420     return;
7421 
7422   if (S.Context.hasSameUnqualifiedType(LHSStrippedType, RHSStrippedType))
7423     return;
7424 
7425   S.Diag(Loc, diag::warn_comparison_of_mixed_enum_types)
7426       << LHSStrippedType << RHSStrippedType
7427       << LHS->getSourceRange() << RHS->getSourceRange();
7428 }
7429 
7430 /// \brief Diagnose bad pointer comparisons.
7431 static void diagnoseDistinctPointerComparison(Sema &S, SourceLocation Loc,
7432                                               ExprResult &LHS, ExprResult &RHS,
7433                                               bool IsError) {
7434   S.Diag(Loc, IsError ? diag::err_typecheck_comparison_of_distinct_pointers
7435                       : diag::ext_typecheck_comparison_of_distinct_pointers)
7436     << LHS.get()->getType() << RHS.get()->getType()
7437     << LHS.get()->getSourceRange() << RHS.get()->getSourceRange();
7438 }
7439 
7440 /// \brief Returns false if the pointers are converted to a composite type,
7441 /// true otherwise.
7442 static bool convertPointersToCompositeType(Sema &S, SourceLocation Loc,
7443                                            ExprResult &LHS, ExprResult &RHS) {
7444   // C++ [expr.rel]p2:
7445   //   [...] Pointer conversions (4.10) and qualification
7446   //   conversions (4.4) are performed on pointer operands (or on
7447   //   a pointer operand and a null pointer constant) to bring
7448   //   them to their composite pointer type. [...]
7449   //
7450   // C++ [expr.eq]p1 uses the same notion for (in)equality
7451   // comparisons of pointers.
7452 
7453   // C++ [expr.eq]p2:
7454   //   In addition, pointers to members can be compared, or a pointer to
7455   //   member and a null pointer constant. Pointer to member conversions
7456   //   (4.11) and qualification conversions (4.4) are performed to bring
7457   //   them to a common type. If one operand is a null pointer constant,
7458   //   the common type is the type of the other operand. Otherwise, the
7459   //   common type is a pointer to member type similar (4.4) to the type
7460   //   of one of the operands, with a cv-qualification signature (4.4)
7461   //   that is the union of the cv-qualification signatures of the operand
7462   //   types.
7463 
7464   QualType LHSType = LHS.get()->getType();
7465   QualType RHSType = RHS.get()->getType();
7466   assert((LHSType->isPointerType() && RHSType->isPointerType()) ||
7467          (LHSType->isMemberPointerType() && RHSType->isMemberPointerType()));
7468 
7469   bool NonStandardCompositeType = false;
7470   bool *BoolPtr = S.isSFINAEContext() ? 0 : &NonStandardCompositeType;
7471   QualType T = S.FindCompositePointerType(Loc, LHS, RHS, BoolPtr);
7472   if (T.isNull()) {
7473     diagnoseDistinctPointerComparison(S, Loc, LHS, RHS, /*isError*/true);
7474     return true;
7475   }
7476 
7477   if (NonStandardCompositeType)
7478     S.Diag(Loc, diag::ext_typecheck_comparison_of_distinct_pointers_nonstandard)
7479       << LHSType << RHSType << T << LHS.get()->getSourceRange()
7480       << RHS.get()->getSourceRange();
7481 
7482   LHS = S.ImpCastExprToType(LHS.take(), T, CK_BitCast);
7483   RHS = S.ImpCastExprToType(RHS.take(), T, CK_BitCast);
7484   return false;
7485 }
7486 
7487 static void diagnoseFunctionPointerToVoidComparison(Sema &S, SourceLocation Loc,
7488                                                     ExprResult &LHS,
7489                                                     ExprResult &RHS,
7490                                                     bool IsError) {
7491   S.Diag(Loc, IsError ? diag::err_typecheck_comparison_of_fptr_to_void
7492                       : diag::ext_typecheck_comparison_of_fptr_to_void)
7493     << LHS.get()->getType() << RHS.get()->getType()
7494     << LHS.get()->getSourceRange() << RHS.get()->getSourceRange();
7495 }
7496 
7497 static bool isObjCObjectLiteral(ExprResult &E) {
7498   switch (E.get()->IgnoreParenImpCasts()->getStmtClass()) {
7499   case Stmt::ObjCArrayLiteralClass:
7500   case Stmt::ObjCDictionaryLiteralClass:
7501   case Stmt::ObjCStringLiteralClass:
7502   case Stmt::ObjCBoxedExprClass:
7503     return true;
7504   default:
7505     // Note that ObjCBoolLiteral is NOT an object literal!
7506     return false;
7507   }
7508 }
7509 
7510 static bool hasIsEqualMethod(Sema &S, const Expr *LHS, const Expr *RHS) {
7511   const ObjCObjectPointerType *Type =
7512     LHS->getType()->getAs<ObjCObjectPointerType>();
7513 
7514   // If this is not actually an Objective-C object, bail out.
7515   if (!Type)
7516     return false;
7517 
7518   // Get the LHS object's interface type.
7519   QualType InterfaceType = Type->getPointeeType();
7520   if (const ObjCObjectType *iQFaceTy =
7521       InterfaceType->getAsObjCQualifiedInterfaceType())
7522     InterfaceType = iQFaceTy->getBaseType();
7523 
7524   // If the RHS isn't an Objective-C object, bail out.
7525   if (!RHS->getType()->isObjCObjectPointerType())
7526     return false;
7527 
7528   // Try to find the -isEqual: method.
7529   Selector IsEqualSel = S.NSAPIObj->getIsEqualSelector();
7530   ObjCMethodDecl *Method = S.LookupMethodInObjectType(IsEqualSel,
7531                                                       InterfaceType,
7532                                                       /*instance=*/true);
7533   if (!Method) {
7534     if (Type->isObjCIdType()) {
7535       // For 'id', just check the global pool.
7536       Method = S.LookupInstanceMethodInGlobalPool(IsEqualSel, SourceRange(),
7537                                                   /*receiverId=*/true,
7538                                                   /*warn=*/false);
7539     } else {
7540       // Check protocols.
7541       Method = S.LookupMethodInQualifiedType(IsEqualSel, Type,
7542                                              /*instance=*/true);
7543     }
7544   }
7545 
7546   if (!Method)
7547     return false;
7548 
7549   QualType T = Method->param_begin()[0]->getType();
7550   if (!T->isObjCObjectPointerType())
7551     return false;
7552 
7553   QualType R = Method->getResultType();
7554   if (!R->isScalarType())
7555     return false;
7556 
7557   return true;
7558 }
7559 
7560 Sema::ObjCLiteralKind Sema::CheckLiteralKind(Expr *FromE) {
7561   FromE = FromE->IgnoreParenImpCasts();
7562   switch (FromE->getStmtClass()) {
7563     default:
7564       break;
7565     case Stmt::ObjCStringLiteralClass:
7566       // "string literal"
7567       return LK_String;
7568     case Stmt::ObjCArrayLiteralClass:
7569       // "array literal"
7570       return LK_Array;
7571     case Stmt::ObjCDictionaryLiteralClass:
7572       // "dictionary literal"
7573       return LK_Dictionary;
7574     case Stmt::BlockExprClass:
7575       return LK_Block;
7576     case Stmt::ObjCBoxedExprClass: {
7577       Expr *Inner = cast<ObjCBoxedExpr>(FromE)->getSubExpr()->IgnoreParens();
7578       switch (Inner->getStmtClass()) {
7579         case Stmt::IntegerLiteralClass:
7580         case Stmt::FloatingLiteralClass:
7581         case Stmt::CharacterLiteralClass:
7582         case Stmt::ObjCBoolLiteralExprClass:
7583         case Stmt::CXXBoolLiteralExprClass:
7584           // "numeric literal"
7585           return LK_Numeric;
7586         case Stmt::ImplicitCastExprClass: {
7587           CastKind CK = cast<CastExpr>(Inner)->getCastKind();
7588           // Boolean literals can be represented by implicit casts.
7589           if (CK == CK_IntegralToBoolean || CK == CK_IntegralCast)
7590             return LK_Numeric;
7591           break;
7592         }
7593         default:
7594           break;
7595       }
7596       return LK_Boxed;
7597     }
7598   }
7599   return LK_None;
7600 }
7601 
7602 static void diagnoseObjCLiteralComparison(Sema &S, SourceLocation Loc,
7603                                           ExprResult &LHS, ExprResult &RHS,
7604                                           BinaryOperator::Opcode Opc){
7605   Expr *Literal;
7606   Expr *Other;
7607   if (isObjCObjectLiteral(LHS)) {
7608     Literal = LHS.get();
7609     Other = RHS.get();
7610   } else {
7611     Literal = RHS.get();
7612     Other = LHS.get();
7613   }
7614 
7615   // Don't warn on comparisons against nil.
7616   Other = Other->IgnoreParenCasts();
7617   if (Other->isNullPointerConstant(S.getASTContext(),
7618                                    Expr::NPC_ValueDependentIsNotNull))
7619     return;
7620 
7621   // This should be kept in sync with warn_objc_literal_comparison.
7622   // LK_String should always be after the other literals, since it has its own
7623   // warning flag.
7624   Sema::ObjCLiteralKind LiteralKind = S.CheckLiteralKind(Literal);
7625   assert(LiteralKind != Sema::LK_Block);
7626   if (LiteralKind == Sema::LK_None) {
7627     llvm_unreachable("Unknown Objective-C object literal kind");
7628   }
7629 
7630   if (LiteralKind == Sema::LK_String)
7631     S.Diag(Loc, diag::warn_objc_string_literal_comparison)
7632       << Literal->getSourceRange();
7633   else
7634     S.Diag(Loc, diag::warn_objc_literal_comparison)
7635       << LiteralKind << Literal->getSourceRange();
7636 
7637   if (BinaryOperator::isEqualityOp(Opc) &&
7638       hasIsEqualMethod(S, LHS.get(), RHS.get())) {
7639     SourceLocation Start = LHS.get()->getLocStart();
7640     SourceLocation End = S.PP.getLocForEndOfToken(RHS.get()->getLocEnd());
7641     CharSourceRange OpRange =
7642       CharSourceRange::getCharRange(Loc, S.PP.getLocForEndOfToken(Loc));
7643 
7644     S.Diag(Loc, diag::note_objc_literal_comparison_isequal)
7645       << FixItHint::CreateInsertion(Start, Opc == BO_EQ ? "[" : "![")
7646       << FixItHint::CreateReplacement(OpRange, " isEqual:")
7647       << FixItHint::CreateInsertion(End, "]");
7648   }
7649 }
7650 
7651 static void diagnoseLogicalNotOnLHSofComparison(Sema &S, ExprResult &LHS,
7652                                                 ExprResult &RHS,
7653                                                 SourceLocation Loc,
7654                                                 unsigned OpaqueOpc) {
7655   // This checking requires bools.
7656   if (!S.getLangOpts().Bool) return;
7657 
7658   // Check that left hand side is !something.
7659   UnaryOperator *UO = dyn_cast<UnaryOperator>(LHS.get()->IgnoreImpCasts());
7660   if (!UO || UO->getOpcode() != UO_LNot) return;
7661 
7662   // Only check if the right hand side is non-bool arithmetic type.
7663   if (RHS.get()->getType()->isBooleanType()) return;
7664 
7665   // Make sure that the something in !something is not bool.
7666   Expr *SubExpr = UO->getSubExpr()->IgnoreImpCasts();
7667   if (SubExpr->getType()->isBooleanType()) return;
7668 
7669   // Emit warning.
7670   S.Diag(UO->getOperatorLoc(), diag::warn_logical_not_on_lhs_of_comparison)
7671       << Loc;
7672 
7673   // First note suggest !(x < y)
7674   SourceLocation FirstOpen = SubExpr->getLocStart();
7675   SourceLocation FirstClose = RHS.get()->getLocEnd();
7676   FirstClose = S.getPreprocessor().getLocForEndOfToken(FirstClose);
7677   if (FirstClose.isInvalid())
7678     FirstOpen = SourceLocation();
7679   S.Diag(UO->getOperatorLoc(), diag::note_logical_not_fix)
7680       << FixItHint::CreateInsertion(FirstOpen, "(")
7681       << FixItHint::CreateInsertion(FirstClose, ")");
7682 
7683   // Second note suggests (!x) < y
7684   SourceLocation SecondOpen = LHS.get()->getLocStart();
7685   SourceLocation SecondClose = LHS.get()->getLocEnd();
7686   SecondClose = S.getPreprocessor().getLocForEndOfToken(SecondClose);
7687   if (SecondClose.isInvalid())
7688     SecondOpen = SourceLocation();
7689   S.Diag(UO->getOperatorLoc(), diag::note_logical_not_silence_with_parens)
7690       << FixItHint::CreateInsertion(SecondOpen, "(")
7691       << FixItHint::CreateInsertion(SecondClose, ")");
7692 }
7693 
7694 // Get the decl for a simple expression: a reference to a variable,
7695 // an implicit C++ field reference, or an implicit ObjC ivar reference.
7696 static ValueDecl *getCompareDecl(Expr *E) {
7697   if (DeclRefExpr* DR = dyn_cast<DeclRefExpr>(E))
7698     return DR->getDecl();
7699   if (ObjCIvarRefExpr* Ivar = dyn_cast<ObjCIvarRefExpr>(E)) {
7700     if (Ivar->isFreeIvar())
7701       return Ivar->getDecl();
7702   }
7703   if (MemberExpr* Mem = dyn_cast<MemberExpr>(E)) {
7704     if (Mem->isImplicitAccess())
7705       return Mem->getMemberDecl();
7706   }
7707   return 0;
7708 }
7709 
7710 // C99 6.5.8, C++ [expr.rel]
7711 QualType Sema::CheckCompareOperands(ExprResult &LHS, ExprResult &RHS,
7712                                     SourceLocation Loc, unsigned OpaqueOpc,
7713                                     bool IsRelational) {
7714   checkArithmeticNull(*this, LHS, RHS, Loc, /*isCompare=*/true);
7715 
7716   BinaryOperatorKind Opc = (BinaryOperatorKind) OpaqueOpc;
7717 
7718   // Handle vector comparisons separately.
7719   if (LHS.get()->getType()->isVectorType() ||
7720       RHS.get()->getType()->isVectorType())
7721     return CheckVectorCompareOperands(LHS, RHS, Loc, IsRelational);
7722 
7723   QualType LHSType = LHS.get()->getType();
7724   QualType RHSType = RHS.get()->getType();
7725 
7726   Expr *LHSStripped = LHS.get()->IgnoreParenImpCasts();
7727   Expr *RHSStripped = RHS.get()->IgnoreParenImpCasts();
7728 
7729   checkEnumComparison(*this, Loc, LHS.get(), RHS.get());
7730   diagnoseLogicalNotOnLHSofComparison(*this, LHS, RHS, Loc, OpaqueOpc);
7731 
7732   if (!LHSType->hasFloatingRepresentation() &&
7733       !(LHSType->isBlockPointerType() && IsRelational) &&
7734       !LHS.get()->getLocStart().isMacroID() &&
7735       !RHS.get()->getLocStart().isMacroID() &&
7736       ActiveTemplateInstantiations.empty()) {
7737     // For non-floating point types, check for self-comparisons of the form
7738     // x == x, x != x, x < x, etc.  These always evaluate to a constant, and
7739     // often indicate logic errors in the program.
7740     //
7741     // NOTE: Don't warn about comparison expressions resulting from macro
7742     // expansion. Also don't warn about comparisons which are only self
7743     // comparisons within a template specialization. The warnings should catch
7744     // obvious cases in the definition of the template anyways. The idea is to
7745     // warn when the typed comparison operator will always evaluate to the same
7746     // result.
7747     ValueDecl *DL = getCompareDecl(LHSStripped);
7748     ValueDecl *DR = getCompareDecl(RHSStripped);
7749     if (DL && DR && DL == DR && !IsWithinTemplateSpecialization(DL)) {
7750       DiagRuntimeBehavior(Loc, 0, PDiag(diag::warn_comparison_always)
7751                           << 0 // self-
7752                           << (Opc == BO_EQ
7753                               || Opc == BO_LE
7754                               || Opc == BO_GE));
7755     } else if (DL && DR && LHSType->isArrayType() && RHSType->isArrayType() &&
7756                !DL->getType()->isReferenceType() &&
7757                !DR->getType()->isReferenceType()) {
7758         // what is it always going to eval to?
7759         char always_evals_to;
7760         switch(Opc) {
7761         case BO_EQ: // e.g. array1 == array2
7762           always_evals_to = 0; // false
7763           break;
7764         case BO_NE: // e.g. array1 != array2
7765           always_evals_to = 1; // true
7766           break;
7767         default:
7768           // best we can say is 'a constant'
7769           always_evals_to = 2; // e.g. array1 <= array2
7770           break;
7771         }
7772         DiagRuntimeBehavior(Loc, 0, PDiag(diag::warn_comparison_always)
7773                             << 1 // array
7774                             << always_evals_to);
7775     }
7776 
7777     if (isa<CastExpr>(LHSStripped))
7778       LHSStripped = LHSStripped->IgnoreParenCasts();
7779     if (isa<CastExpr>(RHSStripped))
7780       RHSStripped = RHSStripped->IgnoreParenCasts();
7781 
7782     // Warn about comparisons against a string constant (unless the other
7783     // operand is null), the user probably wants strcmp.
7784     Expr *literalString = 0;
7785     Expr *literalStringStripped = 0;
7786     if ((isa<StringLiteral>(LHSStripped) || isa<ObjCEncodeExpr>(LHSStripped)) &&
7787         !RHSStripped->isNullPointerConstant(Context,
7788                                             Expr::NPC_ValueDependentIsNull)) {
7789       literalString = LHS.get();
7790       literalStringStripped = LHSStripped;
7791     } else if ((isa<StringLiteral>(RHSStripped) ||
7792                 isa<ObjCEncodeExpr>(RHSStripped)) &&
7793                !LHSStripped->isNullPointerConstant(Context,
7794                                             Expr::NPC_ValueDependentIsNull)) {
7795       literalString = RHS.get();
7796       literalStringStripped = RHSStripped;
7797     }
7798 
7799     if (literalString) {
7800       DiagRuntimeBehavior(Loc, 0,
7801         PDiag(diag::warn_stringcompare)
7802           << isa<ObjCEncodeExpr>(literalStringStripped)
7803           << literalString->getSourceRange());
7804     }
7805   }
7806 
7807   // C99 6.5.8p3 / C99 6.5.9p4
7808   UsualArithmeticConversions(LHS, RHS);
7809   if (LHS.isInvalid() || RHS.isInvalid())
7810     return QualType();
7811 
7812   LHSType = LHS.get()->getType();
7813   RHSType = RHS.get()->getType();
7814 
7815   // The result of comparisons is 'bool' in C++, 'int' in C.
7816   QualType ResultTy = Context.getLogicalOperationType();
7817 
7818   if (IsRelational) {
7819     if (LHSType->isRealType() && RHSType->isRealType())
7820       return ResultTy;
7821   } else {
7822     // Check for comparisons of floating point operands using != and ==.
7823     if (LHSType->hasFloatingRepresentation())
7824       CheckFloatComparison(Loc, LHS.get(), RHS.get());
7825 
7826     if (LHSType->isArithmeticType() && RHSType->isArithmeticType())
7827       return ResultTy;
7828   }
7829 
7830   bool LHSIsNull = LHS.get()->isNullPointerConstant(Context,
7831                                               Expr::NPC_ValueDependentIsNull);
7832   bool RHSIsNull = RHS.get()->isNullPointerConstant(Context,
7833                                               Expr::NPC_ValueDependentIsNull);
7834 
7835   // All of the following pointer-related warnings are GCC extensions, except
7836   // when handling null pointer constants.
7837   if (LHSType->isPointerType() && RHSType->isPointerType()) { // C99 6.5.8p2
7838     QualType LCanPointeeTy =
7839       LHSType->castAs<PointerType>()->getPointeeType().getCanonicalType();
7840     QualType RCanPointeeTy =
7841       RHSType->castAs<PointerType>()->getPointeeType().getCanonicalType();
7842 
7843     if (getLangOpts().CPlusPlus) {
7844       if (LCanPointeeTy == RCanPointeeTy)
7845         return ResultTy;
7846       if (!IsRelational &&
7847           (LCanPointeeTy->isVoidType() || RCanPointeeTy->isVoidType())) {
7848         // Valid unless comparison between non-null pointer and function pointer
7849         // This is a gcc extension compatibility comparison.
7850         // In a SFINAE context, we treat this as a hard error to maintain
7851         // conformance with the C++ standard.
7852         if ((LCanPointeeTy->isFunctionType() || RCanPointeeTy->isFunctionType())
7853             && !LHSIsNull && !RHSIsNull) {
7854           diagnoseFunctionPointerToVoidComparison(
7855               *this, Loc, LHS, RHS, /*isError*/ (bool)isSFINAEContext());
7856 
7857           if (isSFINAEContext())
7858             return QualType();
7859 
7860           RHS = ImpCastExprToType(RHS.take(), LHSType, CK_BitCast);
7861           return ResultTy;
7862         }
7863       }
7864 
7865       if (convertPointersToCompositeType(*this, Loc, LHS, RHS))
7866         return QualType();
7867       else
7868         return ResultTy;
7869     }
7870     // C99 6.5.9p2 and C99 6.5.8p2
7871     if (Context.typesAreCompatible(LCanPointeeTy.getUnqualifiedType(),
7872                                    RCanPointeeTy.getUnqualifiedType())) {
7873       // Valid unless a relational comparison of function pointers
7874       if (IsRelational && LCanPointeeTy->isFunctionType()) {
7875         Diag(Loc, diag::ext_typecheck_ordered_comparison_of_function_pointers)
7876           << LHSType << RHSType << LHS.get()->getSourceRange()
7877           << RHS.get()->getSourceRange();
7878       }
7879     } else if (!IsRelational &&
7880                (LCanPointeeTy->isVoidType() || RCanPointeeTy->isVoidType())) {
7881       // Valid unless comparison between non-null pointer and function pointer
7882       if ((LCanPointeeTy->isFunctionType() || RCanPointeeTy->isFunctionType())
7883           && !LHSIsNull && !RHSIsNull)
7884         diagnoseFunctionPointerToVoidComparison(*this, Loc, LHS, RHS,
7885                                                 /*isError*/false);
7886     } else {
7887       // Invalid
7888       diagnoseDistinctPointerComparison(*this, Loc, LHS, RHS, /*isError*/false);
7889     }
7890     if (LCanPointeeTy != RCanPointeeTy) {
7891       unsigned AddrSpaceL = LCanPointeeTy.getAddressSpace();
7892       unsigned AddrSpaceR = RCanPointeeTy.getAddressSpace();
7893       CastKind Kind = AddrSpaceL != AddrSpaceR ? CK_AddressSpaceConversion
7894                                                : CK_BitCast;
7895       if (LHSIsNull && !RHSIsNull)
7896         LHS = ImpCastExprToType(LHS.take(), RHSType, Kind);
7897       else
7898         RHS = ImpCastExprToType(RHS.take(), LHSType, Kind);
7899     }
7900     return ResultTy;
7901   }
7902 
7903   if (getLangOpts().CPlusPlus) {
7904     // Comparison of nullptr_t with itself.
7905     if (LHSType->isNullPtrType() && RHSType->isNullPtrType())
7906       return ResultTy;
7907 
7908     // Comparison of pointers with null pointer constants and equality
7909     // comparisons of member pointers to null pointer constants.
7910     if (RHSIsNull &&
7911         ((LHSType->isAnyPointerType() || LHSType->isNullPtrType()) ||
7912          (!IsRelational &&
7913           (LHSType->isMemberPointerType() || LHSType->isBlockPointerType())))) {
7914       RHS = ImpCastExprToType(RHS.take(), LHSType,
7915                         LHSType->isMemberPointerType()
7916                           ? CK_NullToMemberPointer
7917                           : CK_NullToPointer);
7918       return ResultTy;
7919     }
7920     if (LHSIsNull &&
7921         ((RHSType->isAnyPointerType() || RHSType->isNullPtrType()) ||
7922          (!IsRelational &&
7923           (RHSType->isMemberPointerType() || RHSType->isBlockPointerType())))) {
7924       LHS = ImpCastExprToType(LHS.take(), RHSType,
7925                         RHSType->isMemberPointerType()
7926                           ? CK_NullToMemberPointer
7927                           : CK_NullToPointer);
7928       return ResultTy;
7929     }
7930 
7931     // Comparison of member pointers.
7932     if (!IsRelational &&
7933         LHSType->isMemberPointerType() && RHSType->isMemberPointerType()) {
7934       if (convertPointersToCompositeType(*this, Loc, LHS, RHS))
7935         return QualType();
7936       else
7937         return ResultTy;
7938     }
7939 
7940     // Handle scoped enumeration types specifically, since they don't promote
7941     // to integers.
7942     if (LHS.get()->getType()->isEnumeralType() &&
7943         Context.hasSameUnqualifiedType(LHS.get()->getType(),
7944                                        RHS.get()->getType()))
7945       return ResultTy;
7946   }
7947 
7948   // Handle block pointer types.
7949   if (!IsRelational && LHSType->isBlockPointerType() &&
7950       RHSType->isBlockPointerType()) {
7951     QualType lpointee = LHSType->castAs<BlockPointerType>()->getPointeeType();
7952     QualType rpointee = RHSType->castAs<BlockPointerType>()->getPointeeType();
7953 
7954     if (!LHSIsNull && !RHSIsNull &&
7955         !Context.typesAreCompatible(lpointee, rpointee)) {
7956       Diag(Loc, diag::err_typecheck_comparison_of_distinct_blocks)
7957         << LHSType << RHSType << LHS.get()->getSourceRange()
7958         << RHS.get()->getSourceRange();
7959     }
7960     RHS = ImpCastExprToType(RHS.take(), LHSType, CK_BitCast);
7961     return ResultTy;
7962   }
7963 
7964   // Allow block pointers to be compared with null pointer constants.
7965   if (!IsRelational
7966       && ((LHSType->isBlockPointerType() && RHSType->isPointerType())
7967           || (LHSType->isPointerType() && RHSType->isBlockPointerType()))) {
7968     if (!LHSIsNull && !RHSIsNull) {
7969       if (!((RHSType->isPointerType() && RHSType->castAs<PointerType>()
7970              ->getPointeeType()->isVoidType())
7971             || (LHSType->isPointerType() && LHSType->castAs<PointerType>()
7972                 ->getPointeeType()->isVoidType())))
7973         Diag(Loc, diag::err_typecheck_comparison_of_distinct_blocks)
7974           << LHSType << RHSType << LHS.get()->getSourceRange()
7975           << RHS.get()->getSourceRange();
7976     }
7977     if (LHSIsNull && !RHSIsNull)
7978       LHS = ImpCastExprToType(LHS.take(), RHSType,
7979                               RHSType->isPointerType() ? CK_BitCast
7980                                 : CK_AnyPointerToBlockPointerCast);
7981     else
7982       RHS = ImpCastExprToType(RHS.take(), LHSType,
7983                               LHSType->isPointerType() ? CK_BitCast
7984                                 : CK_AnyPointerToBlockPointerCast);
7985     return ResultTy;
7986   }
7987 
7988   if (LHSType->isObjCObjectPointerType() ||
7989       RHSType->isObjCObjectPointerType()) {
7990     const PointerType *LPT = LHSType->getAs<PointerType>();
7991     const PointerType *RPT = RHSType->getAs<PointerType>();
7992     if (LPT || RPT) {
7993       bool LPtrToVoid = LPT ? LPT->getPointeeType()->isVoidType() : false;
7994       bool RPtrToVoid = RPT ? RPT->getPointeeType()->isVoidType() : false;
7995 
7996       if (!LPtrToVoid && !RPtrToVoid &&
7997           !Context.typesAreCompatible(LHSType, RHSType)) {
7998         diagnoseDistinctPointerComparison(*this, Loc, LHS, RHS,
7999                                           /*isError*/false);
8000       }
8001       if (LHSIsNull && !RHSIsNull) {
8002         Expr *E = LHS.take();
8003         if (getLangOpts().ObjCAutoRefCount)
8004           CheckObjCARCConversion(SourceRange(), RHSType, E, CCK_ImplicitConversion);
8005         LHS = ImpCastExprToType(E, RHSType,
8006                                 RPT ? CK_BitCast :CK_CPointerToObjCPointerCast);
8007       }
8008       else {
8009         Expr *E = RHS.take();
8010         if (getLangOpts().ObjCAutoRefCount)
8011           CheckObjCARCConversion(SourceRange(), LHSType, E, CCK_ImplicitConversion);
8012         RHS = ImpCastExprToType(E, LHSType,
8013                                 LPT ? CK_BitCast :CK_CPointerToObjCPointerCast);
8014       }
8015       return ResultTy;
8016     }
8017     if (LHSType->isObjCObjectPointerType() &&
8018         RHSType->isObjCObjectPointerType()) {
8019       if (!Context.areComparableObjCPointerTypes(LHSType, RHSType))
8020         diagnoseDistinctPointerComparison(*this, Loc, LHS, RHS,
8021                                           /*isError*/false);
8022       if (isObjCObjectLiteral(LHS) || isObjCObjectLiteral(RHS))
8023         diagnoseObjCLiteralComparison(*this, Loc, LHS, RHS, Opc);
8024 
8025       if (LHSIsNull && !RHSIsNull)
8026         LHS = ImpCastExprToType(LHS.take(), RHSType, CK_BitCast);
8027       else
8028         RHS = ImpCastExprToType(RHS.take(), LHSType, CK_BitCast);
8029       return ResultTy;
8030     }
8031   }
8032   if ((LHSType->isAnyPointerType() && RHSType->isIntegerType()) ||
8033       (LHSType->isIntegerType() && RHSType->isAnyPointerType())) {
8034     unsigned DiagID = 0;
8035     bool isError = false;
8036     if (LangOpts.DebuggerSupport) {
8037       // Under a debugger, allow the comparison of pointers to integers,
8038       // since users tend to want to compare addresses.
8039     } else if ((LHSIsNull && LHSType->isIntegerType()) ||
8040         (RHSIsNull && RHSType->isIntegerType())) {
8041       if (IsRelational && !getLangOpts().CPlusPlus)
8042         DiagID = diag::ext_typecheck_ordered_comparison_of_pointer_and_zero;
8043     } else if (IsRelational && !getLangOpts().CPlusPlus)
8044       DiagID = diag::ext_typecheck_ordered_comparison_of_pointer_integer;
8045     else if (getLangOpts().CPlusPlus) {
8046       DiagID = diag::err_typecheck_comparison_of_pointer_integer;
8047       isError = true;
8048     } else
8049       DiagID = diag::ext_typecheck_comparison_of_pointer_integer;
8050 
8051     if (DiagID) {
8052       Diag(Loc, DiagID)
8053         << LHSType << RHSType << LHS.get()->getSourceRange()
8054         << RHS.get()->getSourceRange();
8055       if (isError)
8056         return QualType();
8057     }
8058 
8059     if (LHSType->isIntegerType())
8060       LHS = ImpCastExprToType(LHS.take(), RHSType,
8061                         LHSIsNull ? CK_NullToPointer : CK_IntegralToPointer);
8062     else
8063       RHS = ImpCastExprToType(RHS.take(), LHSType,
8064                         RHSIsNull ? CK_NullToPointer : CK_IntegralToPointer);
8065     return ResultTy;
8066   }
8067 
8068   // Handle block pointers.
8069   if (!IsRelational && RHSIsNull
8070       && LHSType->isBlockPointerType() && RHSType->isIntegerType()) {
8071     RHS = ImpCastExprToType(RHS.take(), LHSType, CK_NullToPointer);
8072     return ResultTy;
8073   }
8074   if (!IsRelational && LHSIsNull
8075       && LHSType->isIntegerType() && RHSType->isBlockPointerType()) {
8076     LHS = ImpCastExprToType(LHS.take(), RHSType, CK_NullToPointer);
8077     return ResultTy;
8078   }
8079 
8080   return InvalidOperands(Loc, LHS, RHS);
8081 }
8082 
8083 
8084 // Return a signed type that is of identical size and number of elements.
8085 // For floating point vectors, return an integer type of identical size
8086 // and number of elements.
8087 QualType Sema::GetSignedVectorType(QualType V) {
8088   const VectorType *VTy = V->getAs<VectorType>();
8089   unsigned TypeSize = Context.getTypeSize(VTy->getElementType());
8090   if (TypeSize == Context.getTypeSize(Context.CharTy))
8091     return Context.getExtVectorType(Context.CharTy, VTy->getNumElements());
8092   else if (TypeSize == Context.getTypeSize(Context.ShortTy))
8093     return Context.getExtVectorType(Context.ShortTy, VTy->getNumElements());
8094   else if (TypeSize == Context.getTypeSize(Context.IntTy))
8095     return Context.getExtVectorType(Context.IntTy, VTy->getNumElements());
8096   else if (TypeSize == Context.getTypeSize(Context.LongTy))
8097     return Context.getExtVectorType(Context.LongTy, VTy->getNumElements());
8098   assert(TypeSize == Context.getTypeSize(Context.LongLongTy) &&
8099          "Unhandled vector element size in vector compare");
8100   return Context.getExtVectorType(Context.LongLongTy, VTy->getNumElements());
8101 }
8102 
8103 /// CheckVectorCompareOperands - vector comparisons are a clang extension that
8104 /// operates on extended vector types.  Instead of producing an IntTy result,
8105 /// like a scalar comparison, a vector comparison produces a vector of integer
8106 /// types.
8107 QualType Sema::CheckVectorCompareOperands(ExprResult &LHS, ExprResult &RHS,
8108                                           SourceLocation Loc,
8109                                           bool IsRelational) {
8110   // Check to make sure we're operating on vectors of the same type and width,
8111   // Allowing one side to be a scalar of element type.
8112   QualType vType = CheckVectorOperands(LHS, RHS, Loc, /*isCompAssign*/false);
8113   if (vType.isNull())
8114     return vType;
8115 
8116   QualType LHSType = LHS.get()->getType();
8117 
8118   // If AltiVec, the comparison results in a numeric type, i.e.
8119   // bool for C++, int for C
8120   if (vType->getAs<VectorType>()->getVectorKind() == VectorType::AltiVecVector)
8121     return Context.getLogicalOperationType();
8122 
8123   // For non-floating point types, check for self-comparisons of the form
8124   // x == x, x != x, x < x, etc.  These always evaluate to a constant, and
8125   // often indicate logic errors in the program.
8126   if (!LHSType->hasFloatingRepresentation() &&
8127       ActiveTemplateInstantiations.empty()) {
8128     if (DeclRefExpr* DRL
8129           = dyn_cast<DeclRefExpr>(LHS.get()->IgnoreParenImpCasts()))
8130       if (DeclRefExpr* DRR
8131             = dyn_cast<DeclRefExpr>(RHS.get()->IgnoreParenImpCasts()))
8132         if (DRL->getDecl() == DRR->getDecl())
8133           DiagRuntimeBehavior(Loc, 0,
8134                               PDiag(diag::warn_comparison_always)
8135                                 << 0 // self-
8136                                 << 2 // "a constant"
8137                               );
8138   }
8139 
8140   // Check for comparisons of floating point operands using != and ==.
8141   if (!IsRelational && LHSType->hasFloatingRepresentation()) {
8142     assert (RHS.get()->getType()->hasFloatingRepresentation());
8143     CheckFloatComparison(Loc, LHS.get(), RHS.get());
8144   }
8145 
8146   // Return a signed type for the vector.
8147   return GetSignedVectorType(LHSType);
8148 }
8149 
8150 QualType Sema::CheckVectorLogicalOperands(ExprResult &LHS, ExprResult &RHS,
8151                                           SourceLocation Loc) {
8152   // Ensure that either both operands are of the same vector type, or
8153   // one operand is of a vector type and the other is of its element type.
8154   QualType vType = CheckVectorOperands(LHS, RHS, Loc, false);
8155   if (vType.isNull())
8156     return InvalidOperands(Loc, LHS, RHS);
8157   if (getLangOpts().OpenCL && getLangOpts().OpenCLVersion < 120 &&
8158       vType->hasFloatingRepresentation())
8159     return InvalidOperands(Loc, LHS, RHS);
8160 
8161   return GetSignedVectorType(LHS.get()->getType());
8162 }
8163 
8164 inline QualType Sema::CheckBitwiseOperands(
8165   ExprResult &LHS, ExprResult &RHS, SourceLocation Loc, bool IsCompAssign) {
8166   checkArithmeticNull(*this, LHS, RHS, Loc, /*isCompare=*/false);
8167 
8168   if (LHS.get()->getType()->isVectorType() ||
8169       RHS.get()->getType()->isVectorType()) {
8170     if (LHS.get()->getType()->hasIntegerRepresentation() &&
8171         RHS.get()->getType()->hasIntegerRepresentation())
8172       return CheckVectorOperands(LHS, RHS, Loc, IsCompAssign);
8173 
8174     return InvalidOperands(Loc, LHS, RHS);
8175   }
8176 
8177   ExprResult LHSResult = Owned(LHS), RHSResult = Owned(RHS);
8178   QualType compType = UsualArithmeticConversions(LHSResult, RHSResult,
8179                                                  IsCompAssign);
8180   if (LHSResult.isInvalid() || RHSResult.isInvalid())
8181     return QualType();
8182   LHS = LHSResult.take();
8183   RHS = RHSResult.take();
8184 
8185   if (!compType.isNull() && compType->isIntegralOrUnscopedEnumerationType())
8186     return compType;
8187   return InvalidOperands(Loc, LHS, RHS);
8188 }
8189 
8190 inline QualType Sema::CheckLogicalOperands( // C99 6.5.[13,14]
8191   ExprResult &LHS, ExprResult &RHS, SourceLocation Loc, unsigned Opc) {
8192 
8193   // Check vector operands differently.
8194   if (LHS.get()->getType()->isVectorType() || RHS.get()->getType()->isVectorType())
8195     return CheckVectorLogicalOperands(LHS, RHS, Loc);
8196 
8197   // Diagnose cases where the user write a logical and/or but probably meant a
8198   // bitwise one.  We do this when the LHS is a non-bool integer and the RHS
8199   // is a constant.
8200   if (LHS.get()->getType()->isIntegerType() &&
8201       !LHS.get()->getType()->isBooleanType() &&
8202       RHS.get()->getType()->isIntegerType() && !RHS.get()->isValueDependent() &&
8203       // Don't warn in macros or template instantiations.
8204       !Loc.isMacroID() && ActiveTemplateInstantiations.empty()) {
8205     // If the RHS can be constant folded, and if it constant folds to something
8206     // that isn't 0 or 1 (which indicate a potential logical operation that
8207     // happened to fold to true/false) then warn.
8208     // Parens on the RHS are ignored.
8209     llvm::APSInt Result;
8210     if (RHS.get()->EvaluateAsInt(Result, Context))
8211       if ((getLangOpts().Bool && !RHS.get()->getType()->isBooleanType()) ||
8212           (Result != 0 && Result != 1)) {
8213         Diag(Loc, diag::warn_logical_instead_of_bitwise)
8214           << RHS.get()->getSourceRange()
8215           << (Opc == BO_LAnd ? "&&" : "||");
8216         // Suggest replacing the logical operator with the bitwise version
8217         Diag(Loc, diag::note_logical_instead_of_bitwise_change_operator)
8218             << (Opc == BO_LAnd ? "&" : "|")
8219             << FixItHint::CreateReplacement(SourceRange(
8220                 Loc, Lexer::getLocForEndOfToken(Loc, 0, getSourceManager(),
8221                                                 getLangOpts())),
8222                                             Opc == BO_LAnd ? "&" : "|");
8223         if (Opc == BO_LAnd)
8224           // Suggest replacing "Foo() && kNonZero" with "Foo()"
8225           Diag(Loc, diag::note_logical_instead_of_bitwise_remove_constant)
8226               << FixItHint::CreateRemoval(
8227                   SourceRange(
8228                       Lexer::getLocForEndOfToken(LHS.get()->getLocEnd(),
8229                                                  0, getSourceManager(),
8230                                                  getLangOpts()),
8231                       RHS.get()->getLocEnd()));
8232       }
8233   }
8234 
8235   if (!Context.getLangOpts().CPlusPlus) {
8236     // OpenCL v1.1 s6.3.g: The logical operators and (&&), or (||) do
8237     // not operate on the built-in scalar and vector float types.
8238     if (Context.getLangOpts().OpenCL &&
8239         Context.getLangOpts().OpenCLVersion < 120) {
8240       if (LHS.get()->getType()->isFloatingType() ||
8241           RHS.get()->getType()->isFloatingType())
8242         return InvalidOperands(Loc, LHS, RHS);
8243     }
8244 
8245     LHS = UsualUnaryConversions(LHS.take());
8246     if (LHS.isInvalid())
8247       return QualType();
8248 
8249     RHS = UsualUnaryConversions(RHS.take());
8250     if (RHS.isInvalid())
8251       return QualType();
8252 
8253     if (!LHS.get()->getType()->isScalarType() ||
8254         !RHS.get()->getType()->isScalarType())
8255       return InvalidOperands(Loc, LHS, RHS);
8256 
8257     return Context.IntTy;
8258   }
8259 
8260   // The following is safe because we only use this method for
8261   // non-overloadable operands.
8262 
8263   // C++ [expr.log.and]p1
8264   // C++ [expr.log.or]p1
8265   // The operands are both contextually converted to type bool.
8266   ExprResult LHSRes = PerformContextuallyConvertToBool(LHS.get());
8267   if (LHSRes.isInvalid())
8268     return InvalidOperands(Loc, LHS, RHS);
8269   LHS = LHSRes;
8270 
8271   ExprResult RHSRes = PerformContextuallyConvertToBool(RHS.get());
8272   if (RHSRes.isInvalid())
8273     return InvalidOperands(Loc, LHS, RHS);
8274   RHS = RHSRes;
8275 
8276   // C++ [expr.log.and]p2
8277   // C++ [expr.log.or]p2
8278   // The result is a bool.
8279   return Context.BoolTy;
8280 }
8281 
8282 static bool IsReadonlyMessage(Expr *E, Sema &S) {
8283   const MemberExpr *ME = dyn_cast<MemberExpr>(E);
8284   if (!ME) return false;
8285   if (!isa<FieldDecl>(ME->getMemberDecl())) return false;
8286   ObjCMessageExpr *Base =
8287     dyn_cast<ObjCMessageExpr>(ME->getBase()->IgnoreParenImpCasts());
8288   if (!Base) return false;
8289   return Base->getMethodDecl() != 0;
8290 }
8291 
8292 /// Is the given expression (which must be 'const') a reference to a
8293 /// variable which was originally non-const, but which has become
8294 /// 'const' due to being captured within a block?
8295 enum NonConstCaptureKind { NCCK_None, NCCK_Block, NCCK_Lambda };
8296 static NonConstCaptureKind isReferenceToNonConstCapture(Sema &S, Expr *E) {
8297   assert(E->isLValue() && E->getType().isConstQualified());
8298   E = E->IgnoreParens();
8299 
8300   // Must be a reference to a declaration from an enclosing scope.
8301   DeclRefExpr *DRE = dyn_cast<DeclRefExpr>(E);
8302   if (!DRE) return NCCK_None;
8303   if (!DRE->refersToEnclosingLocal()) return NCCK_None;
8304 
8305   // The declaration must be a variable which is not declared 'const'.
8306   VarDecl *var = dyn_cast<VarDecl>(DRE->getDecl());
8307   if (!var) return NCCK_None;
8308   if (var->getType().isConstQualified()) return NCCK_None;
8309   assert(var->hasLocalStorage() && "capture added 'const' to non-local?");
8310 
8311   // Decide whether the first capture was for a block or a lambda.
8312   DeclContext *DC = S.CurContext, *Prev = 0;
8313   while (DC != var->getDeclContext()) {
8314     Prev = DC;
8315     DC = DC->getParent();
8316   }
8317   // Unless we have an init-capture, we've gone one step too far.
8318   if (!var->isInitCapture())
8319     DC = Prev;
8320   return (isa<BlockDecl>(DC) ? NCCK_Block : NCCK_Lambda);
8321 }
8322 
8323 /// CheckForModifiableLvalue - Verify that E is a modifiable lvalue.  If not,
8324 /// emit an error and return true.  If so, return false.
8325 static bool CheckForModifiableLvalue(Expr *E, SourceLocation Loc, Sema &S) {
8326   assert(!E->hasPlaceholderType(BuiltinType::PseudoObject));
8327   SourceLocation OrigLoc = Loc;
8328   Expr::isModifiableLvalueResult IsLV = E->isModifiableLvalue(S.Context,
8329                                                               &Loc);
8330   if (IsLV == Expr::MLV_ClassTemporary && IsReadonlyMessage(E, S))
8331     IsLV = Expr::MLV_InvalidMessageExpression;
8332   if (IsLV == Expr::MLV_Valid)
8333     return false;
8334 
8335   unsigned Diag = 0;
8336   bool NeedType = false;
8337   switch (IsLV) { // C99 6.5.16p2
8338   case Expr::MLV_ConstQualified:
8339     Diag = diag::err_typecheck_assign_const;
8340 
8341     // Use a specialized diagnostic when we're assigning to an object
8342     // from an enclosing function or block.
8343     if (NonConstCaptureKind NCCK = isReferenceToNonConstCapture(S, E)) {
8344       if (NCCK == NCCK_Block)
8345         Diag = diag::err_block_decl_ref_not_modifiable_lvalue;
8346       else
8347         Diag = diag::err_lambda_decl_ref_not_modifiable_lvalue;
8348       break;
8349     }
8350 
8351     // In ARC, use some specialized diagnostics for occasions where we
8352     // infer 'const'.  These are always pseudo-strong variables.
8353     if (S.getLangOpts().ObjCAutoRefCount) {
8354       DeclRefExpr *declRef = dyn_cast<DeclRefExpr>(E->IgnoreParenCasts());
8355       if (declRef && isa<VarDecl>(declRef->getDecl())) {
8356         VarDecl *var = cast<VarDecl>(declRef->getDecl());
8357 
8358         // Use the normal diagnostic if it's pseudo-__strong but the
8359         // user actually wrote 'const'.
8360         if (var->isARCPseudoStrong() &&
8361             (!var->getTypeSourceInfo() ||
8362              !var->getTypeSourceInfo()->getType().isConstQualified())) {
8363           // There are two pseudo-strong cases:
8364           //  - self
8365           ObjCMethodDecl *method = S.getCurMethodDecl();
8366           if (method && var == method->getSelfDecl())
8367             Diag = method->isClassMethod()
8368               ? diag::err_typecheck_arc_assign_self_class_method
8369               : diag::err_typecheck_arc_assign_self;
8370 
8371           //  - fast enumeration variables
8372           else
8373             Diag = diag::err_typecheck_arr_assign_enumeration;
8374 
8375           SourceRange Assign;
8376           if (Loc != OrigLoc)
8377             Assign = SourceRange(OrigLoc, OrigLoc);
8378           S.Diag(Loc, Diag) << E->getSourceRange() << Assign;
8379           // We need to preserve the AST regardless, so migration tool
8380           // can do its job.
8381           return false;
8382         }
8383       }
8384     }
8385 
8386     break;
8387   case Expr::MLV_ArrayType:
8388   case Expr::MLV_ArrayTemporary:
8389     Diag = diag::err_typecheck_array_not_modifiable_lvalue;
8390     NeedType = true;
8391     break;
8392   case Expr::MLV_NotObjectType:
8393     Diag = diag::err_typecheck_non_object_not_modifiable_lvalue;
8394     NeedType = true;
8395     break;
8396   case Expr::MLV_LValueCast:
8397     Diag = diag::err_typecheck_lvalue_casts_not_supported;
8398     break;
8399   case Expr::MLV_Valid:
8400     llvm_unreachable("did not take early return for MLV_Valid");
8401   case Expr::MLV_InvalidExpression:
8402   case Expr::MLV_MemberFunction:
8403   case Expr::MLV_ClassTemporary:
8404     Diag = diag::err_typecheck_expression_not_modifiable_lvalue;
8405     break;
8406   case Expr::MLV_IncompleteType:
8407   case Expr::MLV_IncompleteVoidType:
8408     return S.RequireCompleteType(Loc, E->getType(),
8409              diag::err_typecheck_incomplete_type_not_modifiable_lvalue, E);
8410   case Expr::MLV_DuplicateVectorComponents:
8411     Diag = diag::err_typecheck_duplicate_vector_components_not_mlvalue;
8412     break;
8413   case Expr::MLV_NoSetterProperty:
8414     llvm_unreachable("readonly properties should be processed differently");
8415   case Expr::MLV_InvalidMessageExpression:
8416     Diag = diag::error_readonly_message_assignment;
8417     break;
8418   case Expr::MLV_SubObjCPropertySetting:
8419     Diag = diag::error_no_subobject_property_setting;
8420     break;
8421   }
8422 
8423   SourceRange Assign;
8424   if (Loc != OrigLoc)
8425     Assign = SourceRange(OrigLoc, OrigLoc);
8426   if (NeedType)
8427     S.Diag(Loc, Diag) << E->getType() << E->getSourceRange() << Assign;
8428   else
8429     S.Diag(Loc, Diag) << E->getSourceRange() << Assign;
8430   return true;
8431 }
8432 
8433 static void CheckIdentityFieldAssignment(Expr *LHSExpr, Expr *RHSExpr,
8434                                          SourceLocation Loc,
8435                                          Sema &Sema) {
8436   // C / C++ fields
8437   MemberExpr *ML = dyn_cast<MemberExpr>(LHSExpr);
8438   MemberExpr *MR = dyn_cast<MemberExpr>(RHSExpr);
8439   if (ML && MR && ML->getMemberDecl() == MR->getMemberDecl()) {
8440     if (isa<CXXThisExpr>(ML->getBase()) && isa<CXXThisExpr>(MR->getBase()))
8441       Sema.Diag(Loc, diag::warn_identity_field_assign) << 0;
8442   }
8443 
8444   // Objective-C instance variables
8445   ObjCIvarRefExpr *OL = dyn_cast<ObjCIvarRefExpr>(LHSExpr);
8446   ObjCIvarRefExpr *OR = dyn_cast<ObjCIvarRefExpr>(RHSExpr);
8447   if (OL && OR && OL->getDecl() == OR->getDecl()) {
8448     DeclRefExpr *RL = dyn_cast<DeclRefExpr>(OL->getBase()->IgnoreImpCasts());
8449     DeclRefExpr *RR = dyn_cast<DeclRefExpr>(OR->getBase()->IgnoreImpCasts());
8450     if (RL && RR && RL->getDecl() == RR->getDecl())
8451       Sema.Diag(Loc, diag::warn_identity_field_assign) << 1;
8452   }
8453 }
8454 
8455 // C99 6.5.16.1
8456 QualType Sema::CheckAssignmentOperands(Expr *LHSExpr, ExprResult &RHS,
8457                                        SourceLocation Loc,
8458                                        QualType CompoundType) {
8459   assert(!LHSExpr->hasPlaceholderType(BuiltinType::PseudoObject));
8460 
8461   // Verify that LHS is a modifiable lvalue, and emit error if not.
8462   if (CheckForModifiableLvalue(LHSExpr, Loc, *this))
8463     return QualType();
8464 
8465   QualType LHSType = LHSExpr->getType();
8466   QualType RHSType = CompoundType.isNull() ? RHS.get()->getType() :
8467                                              CompoundType;
8468   AssignConvertType ConvTy;
8469   if (CompoundType.isNull()) {
8470     Expr *RHSCheck = RHS.get();
8471 
8472     CheckIdentityFieldAssignment(LHSExpr, RHSCheck, Loc, *this);
8473 
8474     QualType LHSTy(LHSType);
8475     ConvTy = CheckSingleAssignmentConstraints(LHSTy, RHS);
8476     if (RHS.isInvalid())
8477       return QualType();
8478     // Special case of NSObject attributes on c-style pointer types.
8479     if (ConvTy == IncompatiblePointer &&
8480         ((Context.isObjCNSObjectType(LHSType) &&
8481           RHSType->isObjCObjectPointerType()) ||
8482          (Context.isObjCNSObjectType(RHSType) &&
8483           LHSType->isObjCObjectPointerType())))
8484       ConvTy = Compatible;
8485 
8486     if (ConvTy == Compatible &&
8487         LHSType->isObjCObjectType())
8488         Diag(Loc, diag::err_objc_object_assignment)
8489           << LHSType;
8490 
8491     // If the RHS is a unary plus or minus, check to see if they = and + are
8492     // right next to each other.  If so, the user may have typo'd "x =+ 4"
8493     // instead of "x += 4".
8494     if (ImplicitCastExpr *ICE = dyn_cast<ImplicitCastExpr>(RHSCheck))
8495       RHSCheck = ICE->getSubExpr();
8496     if (UnaryOperator *UO = dyn_cast<UnaryOperator>(RHSCheck)) {
8497       if ((UO->getOpcode() == UO_Plus ||
8498            UO->getOpcode() == UO_Minus) &&
8499           Loc.isFileID() && UO->getOperatorLoc().isFileID() &&
8500           // Only if the two operators are exactly adjacent.
8501           Loc.getLocWithOffset(1) == UO->getOperatorLoc() &&
8502           // And there is a space or other character before the subexpr of the
8503           // unary +/-.  We don't want to warn on "x=-1".
8504           Loc.getLocWithOffset(2) != UO->getSubExpr()->getLocStart() &&
8505           UO->getSubExpr()->getLocStart().isFileID()) {
8506         Diag(Loc, diag::warn_not_compound_assign)
8507           << (UO->getOpcode() == UO_Plus ? "+" : "-")
8508           << SourceRange(UO->getOperatorLoc(), UO->getOperatorLoc());
8509       }
8510     }
8511 
8512     if (ConvTy == Compatible) {
8513       if (LHSType.getObjCLifetime() == Qualifiers::OCL_Strong) {
8514         // Warn about retain cycles where a block captures the LHS, but
8515         // not if the LHS is a simple variable into which the block is
8516         // being stored...unless that variable can be captured by reference!
8517         const Expr *InnerLHS = LHSExpr->IgnoreParenCasts();
8518         const DeclRefExpr *DRE = dyn_cast<DeclRefExpr>(InnerLHS);
8519         if (!DRE || DRE->getDecl()->hasAttr<BlocksAttr>())
8520           checkRetainCycles(LHSExpr, RHS.get());
8521 
8522         // It is safe to assign a weak reference into a strong variable.
8523         // Although this code can still have problems:
8524         //   id x = self.weakProp;
8525         //   id y = self.weakProp;
8526         // we do not warn to warn spuriously when 'x' and 'y' are on separate
8527         // paths through the function. This should be revisited if
8528         // -Wrepeated-use-of-weak is made flow-sensitive.
8529         DiagnosticsEngine::Level Level =
8530           Diags.getDiagnosticLevel(diag::warn_arc_repeated_use_of_weak,
8531                                    RHS.get()->getLocStart());
8532         if (Level != DiagnosticsEngine::Ignored)
8533           getCurFunction()->markSafeWeakUse(RHS.get());
8534 
8535       } else if (getLangOpts().ObjCAutoRefCount) {
8536         checkUnsafeExprAssigns(Loc, LHSExpr, RHS.get());
8537       }
8538     }
8539   } else {
8540     // Compound assignment "x += y"
8541     ConvTy = CheckAssignmentConstraints(Loc, LHSType, RHSType);
8542   }
8543 
8544   if (DiagnoseAssignmentResult(ConvTy, Loc, LHSType, RHSType,
8545                                RHS.get(), AA_Assigning))
8546     return QualType();
8547 
8548   CheckForNullPointerDereference(*this, LHSExpr);
8549 
8550   // C99 6.5.16p3: The type of an assignment expression is the type of the
8551   // left operand unless the left operand has qualified type, in which case
8552   // it is the unqualified version of the type of the left operand.
8553   // C99 6.5.16.1p2: In simple assignment, the value of the right operand
8554   // is converted to the type of the assignment expression (above).
8555   // C++ 5.17p1: the type of the assignment expression is that of its left
8556   // operand.
8557   return (getLangOpts().CPlusPlus
8558           ? LHSType : LHSType.getUnqualifiedType());
8559 }
8560 
8561 // C99 6.5.17
8562 static QualType CheckCommaOperands(Sema &S, ExprResult &LHS, ExprResult &RHS,
8563                                    SourceLocation Loc) {
8564   LHS = S.CheckPlaceholderExpr(LHS.take());
8565   RHS = S.CheckPlaceholderExpr(RHS.take());
8566   if (LHS.isInvalid() || RHS.isInvalid())
8567     return QualType();
8568 
8569   // C's comma performs lvalue conversion (C99 6.3.2.1) on both its
8570   // operands, but not unary promotions.
8571   // C++'s comma does not do any conversions at all (C++ [expr.comma]p1).
8572 
8573   // So we treat the LHS as a ignored value, and in C++ we allow the
8574   // containing site to determine what should be done with the RHS.
8575   LHS = S.IgnoredValueConversions(LHS.take());
8576   if (LHS.isInvalid())
8577     return QualType();
8578 
8579   S.DiagnoseUnusedExprResult(LHS.get());
8580 
8581   if (!S.getLangOpts().CPlusPlus) {
8582     RHS = S.DefaultFunctionArrayLvalueConversion(RHS.take());
8583     if (RHS.isInvalid())
8584       return QualType();
8585     if (!RHS.get()->getType()->isVoidType())
8586       S.RequireCompleteType(Loc, RHS.get()->getType(),
8587                             diag::err_incomplete_type);
8588   }
8589 
8590   return RHS.get()->getType();
8591 }
8592 
8593 /// CheckIncrementDecrementOperand - unlike most "Check" methods, this routine
8594 /// doesn't need to call UsualUnaryConversions or UsualArithmeticConversions.
8595 static QualType CheckIncrementDecrementOperand(Sema &S, Expr *Op,
8596                                                ExprValueKind &VK,
8597                                                SourceLocation OpLoc,
8598                                                bool IsInc, bool IsPrefix) {
8599   if (Op->isTypeDependent())
8600     return S.Context.DependentTy;
8601 
8602   QualType ResType = Op->getType();
8603   // Atomic types can be used for increment / decrement where the non-atomic
8604   // versions can, so ignore the _Atomic() specifier for the purpose of
8605   // checking.
8606   if (const AtomicType *ResAtomicType = ResType->getAs<AtomicType>())
8607     ResType = ResAtomicType->getValueType();
8608 
8609   assert(!ResType.isNull() && "no type for increment/decrement expression");
8610 
8611   if (S.getLangOpts().CPlusPlus && ResType->isBooleanType()) {
8612     // Decrement of bool is not allowed.
8613     if (!IsInc) {
8614       S.Diag(OpLoc, diag::err_decrement_bool) << Op->getSourceRange();
8615       return QualType();
8616     }
8617     // Increment of bool sets it to true, but is deprecated.
8618     S.Diag(OpLoc, diag::warn_increment_bool) << Op->getSourceRange();
8619   } else if (S.getLangOpts().CPlusPlus && ResType->isEnumeralType()) {
8620     // Error on enum increments and decrements in C++ mode
8621     S.Diag(OpLoc, diag::err_increment_decrement_enum) << IsInc << ResType;
8622     return QualType();
8623   } else if (ResType->isRealType()) {
8624     // OK!
8625   } else if (ResType->isPointerType()) {
8626     // C99 6.5.2.4p2, 6.5.6p2
8627     if (!checkArithmeticOpPointerOperand(S, OpLoc, Op))
8628       return QualType();
8629   } else if (ResType->isObjCObjectPointerType()) {
8630     // On modern runtimes, ObjC pointer arithmetic is forbidden.
8631     // Otherwise, we just need a complete type.
8632     if (checkArithmeticIncompletePointerType(S, OpLoc, Op) ||
8633         checkArithmeticOnObjCPointer(S, OpLoc, Op))
8634       return QualType();
8635   } else if (ResType->isAnyComplexType()) {
8636     // C99 does not support ++/-- on complex types, we allow as an extension.
8637     S.Diag(OpLoc, diag::ext_integer_increment_complex)
8638       << ResType << Op->getSourceRange();
8639   } else if (ResType->isPlaceholderType()) {
8640     ExprResult PR = S.CheckPlaceholderExpr(Op);
8641     if (PR.isInvalid()) return QualType();
8642     return CheckIncrementDecrementOperand(S, PR.take(), VK, OpLoc,
8643                                           IsInc, IsPrefix);
8644   } else if (S.getLangOpts().AltiVec && ResType->isVectorType()) {
8645     // OK! ( C/C++ Language Extensions for CBEA(Version 2.6) 10.3 )
8646   } else if(S.getLangOpts().OpenCL && ResType->isVectorType() &&
8647             ResType->getAs<VectorType>()->getElementType()->isIntegerType()) {
8648     // OpenCL V1.2 6.3 says dec/inc ops operate on integer vector types.
8649   } else {
8650     S.Diag(OpLoc, diag::err_typecheck_illegal_increment_decrement)
8651       << ResType << int(IsInc) << Op->getSourceRange();
8652     return QualType();
8653   }
8654   // At this point, we know we have a real, complex or pointer type.
8655   // Now make sure the operand is a modifiable lvalue.
8656   if (CheckForModifiableLvalue(Op, OpLoc, S))
8657     return QualType();
8658   // In C++, a prefix increment is the same type as the operand. Otherwise
8659   // (in C or with postfix), the increment is the unqualified type of the
8660   // operand.
8661   if (IsPrefix && S.getLangOpts().CPlusPlus) {
8662     VK = VK_LValue;
8663     return ResType;
8664   } else {
8665     VK = VK_RValue;
8666     return ResType.getUnqualifiedType();
8667   }
8668 }
8669 
8670 
8671 /// getPrimaryDecl - Helper function for CheckAddressOfOperand().
8672 /// This routine allows us to typecheck complex/recursive expressions
8673 /// where the declaration is needed for type checking. We only need to
8674 /// handle cases when the expression references a function designator
8675 /// or is an lvalue. Here are some examples:
8676 ///  - &(x) => x
8677 ///  - &*****f => f for f a function designator.
8678 ///  - &s.xx => s
8679 ///  - &s.zz[1].yy -> s, if zz is an array
8680 ///  - *(x + 1) -> x, if x is an array
8681 ///  - &"123"[2] -> 0
8682 ///  - & __real__ x -> x
8683 static ValueDecl *getPrimaryDecl(Expr *E) {
8684   switch (E->getStmtClass()) {
8685   case Stmt::DeclRefExprClass:
8686     return cast<DeclRefExpr>(E)->getDecl();
8687   case Stmt::MemberExprClass:
8688     // If this is an arrow operator, the address is an offset from
8689     // the base's value, so the object the base refers to is
8690     // irrelevant.
8691     if (cast<MemberExpr>(E)->isArrow())
8692       return 0;
8693     // Otherwise, the expression refers to a part of the base
8694     return getPrimaryDecl(cast<MemberExpr>(E)->getBase());
8695   case Stmt::ArraySubscriptExprClass: {
8696     // FIXME: This code shouldn't be necessary!  We should catch the implicit
8697     // promotion of register arrays earlier.
8698     Expr* Base = cast<ArraySubscriptExpr>(E)->getBase();
8699     if (ImplicitCastExpr* ICE = dyn_cast<ImplicitCastExpr>(Base)) {
8700       if (ICE->getSubExpr()->getType()->isArrayType())
8701         return getPrimaryDecl(ICE->getSubExpr());
8702     }
8703     return 0;
8704   }
8705   case Stmt::UnaryOperatorClass: {
8706     UnaryOperator *UO = cast<UnaryOperator>(E);
8707 
8708     switch(UO->getOpcode()) {
8709     case UO_Real:
8710     case UO_Imag:
8711     case UO_Extension:
8712       return getPrimaryDecl(UO->getSubExpr());
8713     default:
8714       return 0;
8715     }
8716   }
8717   case Stmt::ParenExprClass:
8718     return getPrimaryDecl(cast<ParenExpr>(E)->getSubExpr());
8719   case Stmt::ImplicitCastExprClass:
8720     // If the result of an implicit cast is an l-value, we care about
8721     // the sub-expression; otherwise, the result here doesn't matter.
8722     return getPrimaryDecl(cast<ImplicitCastExpr>(E)->getSubExpr());
8723   default:
8724     return 0;
8725   }
8726 }
8727 
8728 namespace {
8729   enum {
8730     AO_Bit_Field = 0,
8731     AO_Vector_Element = 1,
8732     AO_Property_Expansion = 2,
8733     AO_Register_Variable = 3,
8734     AO_No_Error = 4
8735   };
8736 }
8737 /// \brief Diagnose invalid operand for address of operations.
8738 ///
8739 /// \param Type The type of operand which cannot have its address taken.
8740 static void diagnoseAddressOfInvalidType(Sema &S, SourceLocation Loc,
8741                                          Expr *E, unsigned Type) {
8742   S.Diag(Loc, diag::err_typecheck_address_of) << Type << E->getSourceRange();
8743 }
8744 
8745 /// CheckAddressOfOperand - The operand of & must be either a function
8746 /// designator or an lvalue designating an object. If it is an lvalue, the
8747 /// object cannot be declared with storage class register or be a bit field.
8748 /// Note: The usual conversions are *not* applied to the operand of the &
8749 /// operator (C99 6.3.2.1p[2-4]), and its result is never an lvalue.
8750 /// In C++, the operand might be an overloaded function name, in which case
8751 /// we allow the '&' but retain the overloaded-function type.
8752 QualType Sema::CheckAddressOfOperand(ExprResult &OrigOp, SourceLocation OpLoc) {
8753   if (const BuiltinType *PTy = OrigOp.get()->getType()->getAsPlaceholderType()){
8754     if (PTy->getKind() == BuiltinType::Overload) {
8755       Expr *E = OrigOp.get()->IgnoreParens();
8756       if (!isa<OverloadExpr>(E)) {
8757         assert(cast<UnaryOperator>(E)->getOpcode() == UO_AddrOf);
8758         Diag(OpLoc, diag::err_typecheck_invalid_lvalue_addrof_addrof_function)
8759           << OrigOp.get()->getSourceRange();
8760         return QualType();
8761       }
8762 
8763       OverloadExpr *Ovl = cast<OverloadExpr>(E);
8764       if (isa<UnresolvedMemberExpr>(Ovl))
8765         if (!ResolveSingleFunctionTemplateSpecialization(Ovl)) {
8766           Diag(OpLoc, diag::err_invalid_form_pointer_member_function)
8767             << OrigOp.get()->getSourceRange();
8768           return QualType();
8769         }
8770 
8771       return Context.OverloadTy;
8772     }
8773 
8774     if (PTy->getKind() == BuiltinType::UnknownAny)
8775       return Context.UnknownAnyTy;
8776 
8777     if (PTy->getKind() == BuiltinType::BoundMember) {
8778       Diag(OpLoc, diag::err_invalid_form_pointer_member_function)
8779         << OrigOp.get()->getSourceRange();
8780       return QualType();
8781     }
8782 
8783     OrigOp = CheckPlaceholderExpr(OrigOp.take());
8784     if (OrigOp.isInvalid()) return QualType();
8785   }
8786 
8787   if (OrigOp.get()->isTypeDependent())
8788     return Context.DependentTy;
8789 
8790   assert(!OrigOp.get()->getType()->isPlaceholderType());
8791 
8792   // Make sure to ignore parentheses in subsequent checks
8793   Expr *op = OrigOp.get()->IgnoreParens();
8794 
8795   if (getLangOpts().C99) {
8796     // Implement C99-only parts of addressof rules.
8797     if (UnaryOperator* uOp = dyn_cast<UnaryOperator>(op)) {
8798       if (uOp->getOpcode() == UO_Deref)
8799         // Per C99 6.5.3.2, the address of a deref always returns a valid result
8800         // (assuming the deref expression is valid).
8801         return uOp->getSubExpr()->getType();
8802     }
8803     // Technically, there should be a check for array subscript
8804     // expressions here, but the result of one is always an lvalue anyway.
8805   }
8806   ValueDecl *dcl = getPrimaryDecl(op);
8807   Expr::LValueClassification lval = op->ClassifyLValue(Context);
8808   unsigned AddressOfError = AO_No_Error;
8809 
8810   if (lval == Expr::LV_ClassTemporary || lval == Expr::LV_ArrayTemporary) {
8811     bool sfinae = (bool)isSFINAEContext();
8812     Diag(OpLoc, isSFINAEContext() ? diag::err_typecheck_addrof_temporary
8813                                   : diag::ext_typecheck_addrof_temporary)
8814       << op->getType() << op->getSourceRange();
8815     if (sfinae)
8816       return QualType();
8817     // Materialize the temporary as an lvalue so that we can take its address.
8818     OrigOp = op = new (Context)
8819         MaterializeTemporaryExpr(op->getType(), OrigOp.take(), true, 0);
8820   } else if (isa<ObjCSelectorExpr>(op)) {
8821     return Context.getPointerType(op->getType());
8822   } else if (lval == Expr::LV_MemberFunction) {
8823     // If it's an instance method, make a member pointer.
8824     // The expression must have exactly the form &A::foo.
8825 
8826     // If the underlying expression isn't a decl ref, give up.
8827     if (!isa<DeclRefExpr>(op)) {
8828       Diag(OpLoc, diag::err_invalid_form_pointer_member_function)
8829         << OrigOp.get()->getSourceRange();
8830       return QualType();
8831     }
8832     DeclRefExpr *DRE = cast<DeclRefExpr>(op);
8833     CXXMethodDecl *MD = cast<CXXMethodDecl>(DRE->getDecl());
8834 
8835     // The id-expression was parenthesized.
8836     if (OrigOp.get() != DRE) {
8837       Diag(OpLoc, diag::err_parens_pointer_member_function)
8838         << OrigOp.get()->getSourceRange();
8839 
8840     // The method was named without a qualifier.
8841     } else if (!DRE->getQualifier()) {
8842       if (MD->getParent()->getName().empty())
8843         Diag(OpLoc, diag::err_unqualified_pointer_member_function)
8844           << op->getSourceRange();
8845       else {
8846         SmallString<32> Str;
8847         StringRef Qual = (MD->getParent()->getName() + "::").toStringRef(Str);
8848         Diag(OpLoc, diag::err_unqualified_pointer_member_function)
8849           << op->getSourceRange()
8850           << FixItHint::CreateInsertion(op->getSourceRange().getBegin(), Qual);
8851       }
8852     }
8853 
8854     // Taking the address of a dtor is illegal per C++ [class.dtor]p2.
8855     if (isa<CXXDestructorDecl>(MD))
8856       Diag(OpLoc, diag::err_typecheck_addrof_dtor) << op->getSourceRange();
8857 
8858     QualType MPTy = Context.getMemberPointerType(
8859         op->getType(), Context.getTypeDeclType(MD->getParent()).getTypePtr());
8860     if (Context.getTargetInfo().getCXXABI().isMicrosoft())
8861       RequireCompleteType(OpLoc, MPTy, 0);
8862     return MPTy;
8863   } else if (lval != Expr::LV_Valid && lval != Expr::LV_IncompleteVoidType) {
8864     // C99 6.5.3.2p1
8865     // The operand must be either an l-value or a function designator
8866     if (!op->getType()->isFunctionType()) {
8867       // Use a special diagnostic for loads from property references.
8868       if (isa<PseudoObjectExpr>(op)) {
8869         AddressOfError = AO_Property_Expansion;
8870       } else {
8871         Diag(OpLoc, diag::err_typecheck_invalid_lvalue_addrof)
8872           << op->getType() << op->getSourceRange();
8873         return QualType();
8874       }
8875     }
8876   } else if (op->getObjectKind() == OK_BitField) { // C99 6.5.3.2p1
8877     // The operand cannot be a bit-field
8878     AddressOfError = AO_Bit_Field;
8879   } else if (op->getObjectKind() == OK_VectorComponent) {
8880     // The operand cannot be an element of a vector
8881     AddressOfError = AO_Vector_Element;
8882   } else if (dcl) { // C99 6.5.3.2p1
8883     // We have an lvalue with a decl. Make sure the decl is not declared
8884     // with the register storage-class specifier.
8885     if (const VarDecl *vd = dyn_cast<VarDecl>(dcl)) {
8886       // in C++ it is not error to take address of a register
8887       // variable (c++03 7.1.1P3)
8888       if (vd->getStorageClass() == SC_Register &&
8889           !getLangOpts().CPlusPlus) {
8890         AddressOfError = AO_Register_Variable;
8891       }
8892     } else if (isa<FunctionTemplateDecl>(dcl)) {
8893       return Context.OverloadTy;
8894     } else if (isa<FieldDecl>(dcl) || isa<IndirectFieldDecl>(dcl)) {
8895       // Okay: we can take the address of a field.
8896       // Could be a pointer to member, though, if there is an explicit
8897       // scope qualifier for the class.
8898       if (isa<DeclRefExpr>(op) && cast<DeclRefExpr>(op)->getQualifier()) {
8899         DeclContext *Ctx = dcl->getDeclContext();
8900         if (Ctx && Ctx->isRecord()) {
8901           if (dcl->getType()->isReferenceType()) {
8902             Diag(OpLoc,
8903                  diag::err_cannot_form_pointer_to_member_of_reference_type)
8904               << dcl->getDeclName() << dcl->getType();
8905             return QualType();
8906           }
8907 
8908           while (cast<RecordDecl>(Ctx)->isAnonymousStructOrUnion())
8909             Ctx = Ctx->getParent();
8910 
8911           QualType MPTy = Context.getMemberPointerType(
8912               op->getType(),
8913               Context.getTypeDeclType(cast<RecordDecl>(Ctx)).getTypePtr());
8914           if (Context.getTargetInfo().getCXXABI().isMicrosoft())
8915             RequireCompleteType(OpLoc, MPTy, 0);
8916           return MPTy;
8917         }
8918       }
8919     } else if (!isa<FunctionDecl>(dcl) && !isa<NonTypeTemplateParmDecl>(dcl))
8920       llvm_unreachable("Unknown/unexpected decl type");
8921   }
8922 
8923   if (AddressOfError != AO_No_Error) {
8924     diagnoseAddressOfInvalidType(*this, OpLoc, op, AddressOfError);
8925     return QualType();
8926   }
8927 
8928   if (lval == Expr::LV_IncompleteVoidType) {
8929     // Taking the address of a void variable is technically illegal, but we
8930     // allow it in cases which are otherwise valid.
8931     // Example: "extern void x; void* y = &x;".
8932     Diag(OpLoc, diag::ext_typecheck_addrof_void) << op->getSourceRange();
8933   }
8934 
8935   // If the operand has type "type", the result has type "pointer to type".
8936   if (op->getType()->isObjCObjectType())
8937     return Context.getObjCObjectPointerType(op->getType());
8938   return Context.getPointerType(op->getType());
8939 }
8940 
8941 /// CheckIndirectionOperand - Type check unary indirection (prefix '*').
8942 static QualType CheckIndirectionOperand(Sema &S, Expr *Op, ExprValueKind &VK,
8943                                         SourceLocation OpLoc) {
8944   if (Op->isTypeDependent())
8945     return S.Context.DependentTy;
8946 
8947   ExprResult ConvResult = S.UsualUnaryConversions(Op);
8948   if (ConvResult.isInvalid())
8949     return QualType();
8950   Op = ConvResult.take();
8951   QualType OpTy = Op->getType();
8952   QualType Result;
8953 
8954   if (isa<CXXReinterpretCastExpr>(Op)) {
8955     QualType OpOrigType = Op->IgnoreParenCasts()->getType();
8956     S.CheckCompatibleReinterpretCast(OpOrigType, OpTy, /*IsDereference*/true,
8957                                      Op->getSourceRange());
8958   }
8959 
8960   // Note that per both C89 and C99, indirection is always legal, even if OpTy
8961   // is an incomplete type or void.  It would be possible to warn about
8962   // dereferencing a void pointer, but it's completely well-defined, and such a
8963   // warning is unlikely to catch any mistakes.
8964   if (const PointerType *PT = OpTy->getAs<PointerType>())
8965     Result = PT->getPointeeType();
8966   else if (const ObjCObjectPointerType *OPT =
8967              OpTy->getAs<ObjCObjectPointerType>())
8968     Result = OPT->getPointeeType();
8969   else {
8970     ExprResult PR = S.CheckPlaceholderExpr(Op);
8971     if (PR.isInvalid()) return QualType();
8972     if (PR.take() != Op)
8973       return CheckIndirectionOperand(S, PR.take(), VK, OpLoc);
8974   }
8975 
8976   if (Result.isNull()) {
8977     S.Diag(OpLoc, diag::err_typecheck_indirection_requires_pointer)
8978       << OpTy << Op->getSourceRange();
8979     return QualType();
8980   }
8981 
8982   // Dereferences are usually l-values...
8983   VK = VK_LValue;
8984 
8985   // ...except that certain expressions are never l-values in C.
8986   if (!S.getLangOpts().CPlusPlus && Result.isCForbiddenLValueType())
8987     VK = VK_RValue;
8988 
8989   return Result;
8990 }
8991 
8992 static inline BinaryOperatorKind ConvertTokenKindToBinaryOpcode(
8993   tok::TokenKind Kind) {
8994   BinaryOperatorKind Opc;
8995   switch (Kind) {
8996   default: llvm_unreachable("Unknown binop!");
8997   case tok::periodstar:           Opc = BO_PtrMemD; break;
8998   case tok::arrowstar:            Opc = BO_PtrMemI; break;
8999   case tok::star:                 Opc = BO_Mul; break;
9000   case tok::slash:                Opc = BO_Div; break;
9001   case tok::percent:              Opc = BO_Rem; break;
9002   case tok::plus:                 Opc = BO_Add; break;
9003   case tok::minus:                Opc = BO_Sub; break;
9004   case tok::lessless:             Opc = BO_Shl; break;
9005   case tok::greatergreater:       Opc = BO_Shr; break;
9006   case tok::lessequal:            Opc = BO_LE; break;
9007   case tok::less:                 Opc = BO_LT; break;
9008   case tok::greaterequal:         Opc = BO_GE; break;
9009   case tok::greater:              Opc = BO_GT; break;
9010   case tok::exclaimequal:         Opc = BO_NE; break;
9011   case tok::equalequal:           Opc = BO_EQ; break;
9012   case tok::amp:                  Opc = BO_And; break;
9013   case tok::caret:                Opc = BO_Xor; break;
9014   case tok::pipe:                 Opc = BO_Or; break;
9015   case tok::ampamp:               Opc = BO_LAnd; break;
9016   case tok::pipepipe:             Opc = BO_LOr; break;
9017   case tok::equal:                Opc = BO_Assign; break;
9018   case tok::starequal:            Opc = BO_MulAssign; break;
9019   case tok::slashequal:           Opc = BO_DivAssign; break;
9020   case tok::percentequal:         Opc = BO_RemAssign; break;
9021   case tok::plusequal:            Opc = BO_AddAssign; break;
9022   case tok::minusequal:           Opc = BO_SubAssign; break;
9023   case tok::lesslessequal:        Opc = BO_ShlAssign; break;
9024   case tok::greatergreaterequal:  Opc = BO_ShrAssign; break;
9025   case tok::ampequal:             Opc = BO_AndAssign; break;
9026   case tok::caretequal:           Opc = BO_XorAssign; break;
9027   case tok::pipeequal:            Opc = BO_OrAssign; break;
9028   case tok::comma:                Opc = BO_Comma; break;
9029   }
9030   return Opc;
9031 }
9032 
9033 static inline UnaryOperatorKind ConvertTokenKindToUnaryOpcode(
9034   tok::TokenKind Kind) {
9035   UnaryOperatorKind Opc;
9036   switch (Kind) {
9037   default: llvm_unreachable("Unknown unary op!");
9038   case tok::plusplus:     Opc = UO_PreInc; break;
9039   case tok::minusminus:   Opc = UO_PreDec; break;
9040   case tok::amp:          Opc = UO_AddrOf; break;
9041   case tok::star:         Opc = UO_Deref; break;
9042   case tok::plus:         Opc = UO_Plus; break;
9043   case tok::minus:        Opc = UO_Minus; break;
9044   case tok::tilde:        Opc = UO_Not; break;
9045   case tok::exclaim:      Opc = UO_LNot; break;
9046   case tok::kw___real:    Opc = UO_Real; break;
9047   case tok::kw___imag:    Opc = UO_Imag; break;
9048   case tok::kw___extension__: Opc = UO_Extension; break;
9049   }
9050   return Opc;
9051 }
9052 
9053 /// DiagnoseSelfAssignment - Emits a warning if a value is assigned to itself.
9054 /// This warning is only emitted for builtin assignment operations. It is also
9055 /// suppressed in the event of macro expansions.
9056 static void DiagnoseSelfAssignment(Sema &S, Expr *LHSExpr, Expr *RHSExpr,
9057                                    SourceLocation OpLoc) {
9058   if (!S.ActiveTemplateInstantiations.empty())
9059     return;
9060   if (OpLoc.isInvalid() || OpLoc.isMacroID())
9061     return;
9062   LHSExpr = LHSExpr->IgnoreParenImpCasts();
9063   RHSExpr = RHSExpr->IgnoreParenImpCasts();
9064   const DeclRefExpr *LHSDeclRef = dyn_cast<DeclRefExpr>(LHSExpr);
9065   const DeclRefExpr *RHSDeclRef = dyn_cast<DeclRefExpr>(RHSExpr);
9066   if (!LHSDeclRef || !RHSDeclRef ||
9067       LHSDeclRef->getLocation().isMacroID() ||
9068       RHSDeclRef->getLocation().isMacroID())
9069     return;
9070   const ValueDecl *LHSDecl =
9071     cast<ValueDecl>(LHSDeclRef->getDecl()->getCanonicalDecl());
9072   const ValueDecl *RHSDecl =
9073     cast<ValueDecl>(RHSDeclRef->getDecl()->getCanonicalDecl());
9074   if (LHSDecl != RHSDecl)
9075     return;
9076   if (LHSDecl->getType().isVolatileQualified())
9077     return;
9078   if (const ReferenceType *RefTy = LHSDecl->getType()->getAs<ReferenceType>())
9079     if (RefTy->getPointeeType().isVolatileQualified())
9080       return;
9081 
9082   S.Diag(OpLoc, diag::warn_self_assignment)
9083       << LHSDeclRef->getType()
9084       << LHSExpr->getSourceRange() << RHSExpr->getSourceRange();
9085 }
9086 
9087 /// Check if a bitwise-& is performed on an Objective-C pointer.  This
9088 /// is usually indicative of introspection within the Objective-C pointer.
9089 static void checkObjCPointerIntrospection(Sema &S, ExprResult &L, ExprResult &R,
9090                                           SourceLocation OpLoc) {
9091   if (!S.getLangOpts().ObjC1)
9092     return;
9093 
9094   const Expr *ObjCPointerExpr = 0, *OtherExpr = 0;
9095   const Expr *LHS = L.get();
9096   const Expr *RHS = R.get();
9097 
9098   if (LHS->IgnoreParenCasts()->getType()->isObjCObjectPointerType()) {
9099     ObjCPointerExpr = LHS;
9100     OtherExpr = RHS;
9101   }
9102   else if (RHS->IgnoreParenCasts()->getType()->isObjCObjectPointerType()) {
9103     ObjCPointerExpr = RHS;
9104     OtherExpr = LHS;
9105   }
9106 
9107   // This warning is deliberately made very specific to reduce false
9108   // positives with logic that uses '&' for hashing.  This logic mainly
9109   // looks for code trying to introspect into tagged pointers, which
9110   // code should generally never do.
9111   if (ObjCPointerExpr && isa<IntegerLiteral>(OtherExpr->IgnoreParenCasts())) {
9112     unsigned Diag = diag::warn_objc_pointer_masking;
9113     // Determine if we are introspecting the result of performSelectorXXX.
9114     const Expr *Ex = ObjCPointerExpr->IgnoreParenCasts();
9115     // Special case messages to -performSelector and friends, which
9116     // can return non-pointer values boxed in a pointer value.
9117     // Some clients may wish to silence warnings in this subcase.
9118     if (const ObjCMessageExpr *ME = dyn_cast<ObjCMessageExpr>(Ex)) {
9119       Selector S = ME->getSelector();
9120       StringRef SelArg0 = S.getNameForSlot(0);
9121       if (SelArg0.startswith("performSelector"))
9122         Diag = diag::warn_objc_pointer_masking_performSelector;
9123     }
9124 
9125     S.Diag(OpLoc, Diag)
9126       << ObjCPointerExpr->getSourceRange();
9127   }
9128 }
9129 
9130 /// CreateBuiltinBinOp - Creates a new built-in binary operation with
9131 /// operator @p Opc at location @c TokLoc. This routine only supports
9132 /// built-in operations; ActOnBinOp handles overloaded operators.
9133 ExprResult Sema::CreateBuiltinBinOp(SourceLocation OpLoc,
9134                                     BinaryOperatorKind Opc,
9135                                     Expr *LHSExpr, Expr *RHSExpr) {
9136   if (getLangOpts().CPlusPlus11 && isa<InitListExpr>(RHSExpr)) {
9137     // The syntax only allows initializer lists on the RHS of assignment,
9138     // so we don't need to worry about accepting invalid code for
9139     // non-assignment operators.
9140     // C++11 5.17p9:
9141     //   The meaning of x = {v} [...] is that of x = T(v) [...]. The meaning
9142     //   of x = {} is x = T().
9143     InitializationKind Kind =
9144         InitializationKind::CreateDirectList(RHSExpr->getLocStart());
9145     InitializedEntity Entity =
9146         InitializedEntity::InitializeTemporary(LHSExpr->getType());
9147     InitializationSequence InitSeq(*this, Entity, Kind, RHSExpr);
9148     ExprResult Init = InitSeq.Perform(*this, Entity, Kind, RHSExpr);
9149     if (Init.isInvalid())
9150       return Init;
9151     RHSExpr = Init.take();
9152   }
9153 
9154   ExprResult LHS = Owned(LHSExpr), RHS = Owned(RHSExpr);
9155   QualType ResultTy;     // Result type of the binary operator.
9156   // The following two variables are used for compound assignment operators
9157   QualType CompLHSTy;    // Type of LHS after promotions for computation
9158   QualType CompResultTy; // Type of computation result
9159   ExprValueKind VK = VK_RValue;
9160   ExprObjectKind OK = OK_Ordinary;
9161 
9162   switch (Opc) {
9163   case BO_Assign:
9164     ResultTy = CheckAssignmentOperands(LHS.get(), RHS, OpLoc, QualType());
9165     if (getLangOpts().CPlusPlus &&
9166         LHS.get()->getObjectKind() != OK_ObjCProperty) {
9167       VK = LHS.get()->getValueKind();
9168       OK = LHS.get()->getObjectKind();
9169     }
9170     if (!ResultTy.isNull())
9171       DiagnoseSelfAssignment(*this, LHS.get(), RHS.get(), OpLoc);
9172     break;
9173   case BO_PtrMemD:
9174   case BO_PtrMemI:
9175     ResultTy = CheckPointerToMemberOperands(LHS, RHS, VK, OpLoc,
9176                                             Opc == BO_PtrMemI);
9177     break;
9178   case BO_Mul:
9179   case BO_Div:
9180     ResultTy = CheckMultiplyDivideOperands(LHS, RHS, OpLoc, false,
9181                                            Opc == BO_Div);
9182     break;
9183   case BO_Rem:
9184     ResultTy = CheckRemainderOperands(LHS, RHS, OpLoc);
9185     break;
9186   case BO_Add:
9187     ResultTy = CheckAdditionOperands(LHS, RHS, OpLoc, Opc);
9188     break;
9189   case BO_Sub:
9190     ResultTy = CheckSubtractionOperands(LHS, RHS, OpLoc);
9191     break;
9192   case BO_Shl:
9193   case BO_Shr:
9194     ResultTy = CheckShiftOperands(LHS, RHS, OpLoc, Opc);
9195     break;
9196   case BO_LE:
9197   case BO_LT:
9198   case BO_GE:
9199   case BO_GT:
9200     ResultTy = CheckCompareOperands(LHS, RHS, OpLoc, Opc, true);
9201     break;
9202   case BO_EQ:
9203   case BO_NE:
9204     ResultTy = CheckCompareOperands(LHS, RHS, OpLoc, Opc, false);
9205     break;
9206   case BO_And:
9207     checkObjCPointerIntrospection(*this, LHS, RHS, OpLoc);
9208   case BO_Xor:
9209   case BO_Or:
9210     ResultTy = CheckBitwiseOperands(LHS, RHS, OpLoc);
9211     break;
9212   case BO_LAnd:
9213   case BO_LOr:
9214     ResultTy = CheckLogicalOperands(LHS, RHS, OpLoc, Opc);
9215     break;
9216   case BO_MulAssign:
9217   case BO_DivAssign:
9218     CompResultTy = CheckMultiplyDivideOperands(LHS, RHS, OpLoc, true,
9219                                                Opc == BO_DivAssign);
9220     CompLHSTy = CompResultTy;
9221     if (!CompResultTy.isNull() && !LHS.isInvalid() && !RHS.isInvalid())
9222       ResultTy = CheckAssignmentOperands(LHS.get(), RHS, OpLoc, CompResultTy);
9223     break;
9224   case BO_RemAssign:
9225     CompResultTy = CheckRemainderOperands(LHS, RHS, OpLoc, true);
9226     CompLHSTy = CompResultTy;
9227     if (!CompResultTy.isNull() && !LHS.isInvalid() && !RHS.isInvalid())
9228       ResultTy = CheckAssignmentOperands(LHS.get(), RHS, OpLoc, CompResultTy);
9229     break;
9230   case BO_AddAssign:
9231     CompResultTy = CheckAdditionOperands(LHS, RHS, OpLoc, Opc, &CompLHSTy);
9232     if (!CompResultTy.isNull() && !LHS.isInvalid() && !RHS.isInvalid())
9233       ResultTy = CheckAssignmentOperands(LHS.get(), RHS, OpLoc, CompResultTy);
9234     break;
9235   case BO_SubAssign:
9236     CompResultTy = CheckSubtractionOperands(LHS, RHS, OpLoc, &CompLHSTy);
9237     if (!CompResultTy.isNull() && !LHS.isInvalid() && !RHS.isInvalid())
9238       ResultTy = CheckAssignmentOperands(LHS.get(), RHS, OpLoc, CompResultTy);
9239     break;
9240   case BO_ShlAssign:
9241   case BO_ShrAssign:
9242     CompResultTy = CheckShiftOperands(LHS, RHS, OpLoc, Opc, true);
9243     CompLHSTy = CompResultTy;
9244     if (!CompResultTy.isNull() && !LHS.isInvalid() && !RHS.isInvalid())
9245       ResultTy = CheckAssignmentOperands(LHS.get(), RHS, OpLoc, CompResultTy);
9246     break;
9247   case BO_AndAssign:
9248   case BO_XorAssign:
9249   case BO_OrAssign:
9250     CompResultTy = CheckBitwiseOperands(LHS, RHS, OpLoc, true);
9251     CompLHSTy = CompResultTy;
9252     if (!CompResultTy.isNull() && !LHS.isInvalid() && !RHS.isInvalid())
9253       ResultTy = CheckAssignmentOperands(LHS.get(), RHS, OpLoc, CompResultTy);
9254     break;
9255   case BO_Comma:
9256     ResultTy = CheckCommaOperands(*this, LHS, RHS, OpLoc);
9257     if (getLangOpts().CPlusPlus && !RHS.isInvalid()) {
9258       VK = RHS.get()->getValueKind();
9259       OK = RHS.get()->getObjectKind();
9260     }
9261     break;
9262   }
9263   if (ResultTy.isNull() || LHS.isInvalid() || RHS.isInvalid())
9264     return ExprError();
9265 
9266   // Check for array bounds violations for both sides of the BinaryOperator
9267   CheckArrayAccess(LHS.get());
9268   CheckArrayAccess(RHS.get());
9269 
9270   if (const ObjCIsaExpr *OISA = dyn_cast<ObjCIsaExpr>(LHS.get()->IgnoreParenCasts())) {
9271     NamedDecl *ObjectSetClass = LookupSingleName(TUScope,
9272                                                  &Context.Idents.get("object_setClass"),
9273                                                  SourceLocation(), LookupOrdinaryName);
9274     if (ObjectSetClass && isa<ObjCIsaExpr>(LHS.get())) {
9275       SourceLocation RHSLocEnd = PP.getLocForEndOfToken(RHS.get()->getLocEnd());
9276       Diag(LHS.get()->getExprLoc(), diag::warn_objc_isa_assign) <<
9277       FixItHint::CreateInsertion(LHS.get()->getLocStart(), "object_setClass(") <<
9278       FixItHint::CreateReplacement(SourceRange(OISA->getOpLoc(), OpLoc), ",") <<
9279       FixItHint::CreateInsertion(RHSLocEnd, ")");
9280     }
9281     else
9282       Diag(LHS.get()->getExprLoc(), diag::warn_objc_isa_assign);
9283   }
9284   else if (const ObjCIvarRefExpr *OIRE =
9285            dyn_cast<ObjCIvarRefExpr>(LHS.get()->IgnoreParenCasts()))
9286     DiagnoseDirectIsaAccess(*this, OIRE, OpLoc, RHS.get());
9287 
9288   if (CompResultTy.isNull())
9289     return Owned(new (Context) BinaryOperator(LHS.take(), RHS.take(), Opc,
9290                                               ResultTy, VK, OK, OpLoc,
9291                                               FPFeatures.fp_contract));
9292   if (getLangOpts().CPlusPlus && LHS.get()->getObjectKind() !=
9293       OK_ObjCProperty) {
9294     VK = VK_LValue;
9295     OK = LHS.get()->getObjectKind();
9296   }
9297   return Owned(new (Context) CompoundAssignOperator(LHS.take(), RHS.take(), Opc,
9298                                                     ResultTy, VK, OK, CompLHSTy,
9299                                                     CompResultTy, OpLoc,
9300                                                     FPFeatures.fp_contract));
9301 }
9302 
9303 /// DiagnoseBitwisePrecedence - Emit a warning when bitwise and comparison
9304 /// operators are mixed in a way that suggests that the programmer forgot that
9305 /// comparison operators have higher precedence. The most typical example of
9306 /// such code is "flags & 0x0020 != 0", which is equivalent to "flags & 1".
9307 static void DiagnoseBitwisePrecedence(Sema &Self, BinaryOperatorKind Opc,
9308                                       SourceLocation OpLoc, Expr *LHSExpr,
9309                                       Expr *RHSExpr) {
9310   BinaryOperator *LHSBO = dyn_cast<BinaryOperator>(LHSExpr);
9311   BinaryOperator *RHSBO = dyn_cast<BinaryOperator>(RHSExpr);
9312 
9313   // Check that one of the sides is a comparison operator.
9314   bool isLeftComp = LHSBO && LHSBO->isComparisonOp();
9315   bool isRightComp = RHSBO && RHSBO->isComparisonOp();
9316   if (!isLeftComp && !isRightComp)
9317     return;
9318 
9319   // Bitwise operations are sometimes used as eager logical ops.
9320   // Don't diagnose this.
9321   bool isLeftBitwise = LHSBO && LHSBO->isBitwiseOp();
9322   bool isRightBitwise = RHSBO && RHSBO->isBitwiseOp();
9323   if ((isLeftComp || isLeftBitwise) && (isRightComp || isRightBitwise))
9324     return;
9325 
9326   SourceRange DiagRange = isLeftComp ? SourceRange(LHSExpr->getLocStart(),
9327                                                    OpLoc)
9328                                      : SourceRange(OpLoc, RHSExpr->getLocEnd());
9329   StringRef OpStr = isLeftComp ? LHSBO->getOpcodeStr() : RHSBO->getOpcodeStr();
9330   SourceRange ParensRange = isLeftComp ?
9331       SourceRange(LHSBO->getRHS()->getLocStart(), RHSExpr->getLocEnd())
9332     : SourceRange(LHSExpr->getLocStart(), RHSBO->getLHS()->getLocStart());
9333 
9334   Self.Diag(OpLoc, diag::warn_precedence_bitwise_rel)
9335     << DiagRange << BinaryOperator::getOpcodeStr(Opc) << OpStr;
9336   SuggestParentheses(Self, OpLoc,
9337     Self.PDiag(diag::note_precedence_silence) << OpStr,
9338     (isLeftComp ? LHSExpr : RHSExpr)->getSourceRange());
9339   SuggestParentheses(Self, OpLoc,
9340     Self.PDiag(diag::note_precedence_bitwise_first)
9341       << BinaryOperator::getOpcodeStr(Opc),
9342     ParensRange);
9343 }
9344 
9345 /// \brief It accepts a '&' expr that is inside a '|' one.
9346 /// Emit a diagnostic together with a fixit hint that wraps the '&' expression
9347 /// in parentheses.
9348 static void
9349 EmitDiagnosticForBitwiseAndInBitwiseOr(Sema &Self, SourceLocation OpLoc,
9350                                        BinaryOperator *Bop) {
9351   assert(Bop->getOpcode() == BO_And);
9352   Self.Diag(Bop->getOperatorLoc(), diag::warn_bitwise_and_in_bitwise_or)
9353       << Bop->getSourceRange() << OpLoc;
9354   SuggestParentheses(Self, Bop->getOperatorLoc(),
9355     Self.PDiag(diag::note_precedence_silence)
9356       << Bop->getOpcodeStr(),
9357     Bop->getSourceRange());
9358 }
9359 
9360 /// \brief It accepts a '&&' expr that is inside a '||' one.
9361 /// Emit a diagnostic together with a fixit hint that wraps the '&&' expression
9362 /// in parentheses.
9363 static void
9364 EmitDiagnosticForLogicalAndInLogicalOr(Sema &Self, SourceLocation OpLoc,
9365                                        BinaryOperator *Bop) {
9366   assert(Bop->getOpcode() == BO_LAnd);
9367   Self.Diag(Bop->getOperatorLoc(), diag::warn_logical_and_in_logical_or)
9368       << Bop->getSourceRange() << OpLoc;
9369   SuggestParentheses(Self, Bop->getOperatorLoc(),
9370     Self.PDiag(diag::note_precedence_silence)
9371       << Bop->getOpcodeStr(),
9372     Bop->getSourceRange());
9373 }
9374 
9375 /// \brief Returns true if the given expression can be evaluated as a constant
9376 /// 'true'.
9377 static bool EvaluatesAsTrue(Sema &S, Expr *E) {
9378   bool Res;
9379   return !E->isValueDependent() &&
9380          E->EvaluateAsBooleanCondition(Res, S.getASTContext()) && Res;
9381 }
9382 
9383 /// \brief Returns true if the given expression can be evaluated as a constant
9384 /// 'false'.
9385 static bool EvaluatesAsFalse(Sema &S, Expr *E) {
9386   bool Res;
9387   return !E->isValueDependent() &&
9388          E->EvaluateAsBooleanCondition(Res, S.getASTContext()) && !Res;
9389 }
9390 
9391 /// \brief Look for '&&' in the left hand of a '||' expr.
9392 static void DiagnoseLogicalAndInLogicalOrLHS(Sema &S, SourceLocation OpLoc,
9393                                              Expr *LHSExpr, Expr *RHSExpr) {
9394   if (BinaryOperator *Bop = dyn_cast<BinaryOperator>(LHSExpr)) {
9395     if (Bop->getOpcode() == BO_LAnd) {
9396       // If it's "a && b || 0" don't warn since the precedence doesn't matter.
9397       if (EvaluatesAsFalse(S, RHSExpr))
9398         return;
9399       // If it's "1 && a || b" don't warn since the precedence doesn't matter.
9400       if (!EvaluatesAsTrue(S, Bop->getLHS()))
9401         return EmitDiagnosticForLogicalAndInLogicalOr(S, OpLoc, Bop);
9402     } else if (Bop->getOpcode() == BO_LOr) {
9403       if (BinaryOperator *RBop = dyn_cast<BinaryOperator>(Bop->getRHS())) {
9404         // If it's "a || b && 1 || c" we didn't warn earlier for
9405         // "a || b && 1", but warn now.
9406         if (RBop->getOpcode() == BO_LAnd && EvaluatesAsTrue(S, RBop->getRHS()))
9407           return EmitDiagnosticForLogicalAndInLogicalOr(S, OpLoc, RBop);
9408       }
9409     }
9410   }
9411 }
9412 
9413 /// \brief Look for '&&' in the right hand of a '||' expr.
9414 static void DiagnoseLogicalAndInLogicalOrRHS(Sema &S, SourceLocation OpLoc,
9415                                              Expr *LHSExpr, Expr *RHSExpr) {
9416   if (BinaryOperator *Bop = dyn_cast<BinaryOperator>(RHSExpr)) {
9417     if (Bop->getOpcode() == BO_LAnd) {
9418       // If it's "0 || a && b" don't warn since the precedence doesn't matter.
9419       if (EvaluatesAsFalse(S, LHSExpr))
9420         return;
9421       // If it's "a || b && 1" don't warn since the precedence doesn't matter.
9422       if (!EvaluatesAsTrue(S, Bop->getRHS()))
9423         return EmitDiagnosticForLogicalAndInLogicalOr(S, OpLoc, Bop);
9424     }
9425   }
9426 }
9427 
9428 /// \brief Look for '&' in the left or right hand of a '|' expr.
9429 static void DiagnoseBitwiseAndInBitwiseOr(Sema &S, SourceLocation OpLoc,
9430                                              Expr *OrArg) {
9431   if (BinaryOperator *Bop = dyn_cast<BinaryOperator>(OrArg)) {
9432     if (Bop->getOpcode() == BO_And)
9433       return EmitDiagnosticForBitwiseAndInBitwiseOr(S, OpLoc, Bop);
9434   }
9435 }
9436 
9437 static void DiagnoseAdditionInShift(Sema &S, SourceLocation OpLoc,
9438                                     Expr *SubExpr, StringRef Shift) {
9439   if (BinaryOperator *Bop = dyn_cast<BinaryOperator>(SubExpr)) {
9440     if (Bop->getOpcode() == BO_Add || Bop->getOpcode() == BO_Sub) {
9441       StringRef Op = Bop->getOpcodeStr();
9442       S.Diag(Bop->getOperatorLoc(), diag::warn_addition_in_bitshift)
9443           << Bop->getSourceRange() << OpLoc << Shift << Op;
9444       SuggestParentheses(S, Bop->getOperatorLoc(),
9445           S.PDiag(diag::note_precedence_silence) << Op,
9446           Bop->getSourceRange());
9447     }
9448   }
9449 }
9450 
9451 static void DiagnoseShiftCompare(Sema &S, SourceLocation OpLoc,
9452                                  Expr *LHSExpr, Expr *RHSExpr) {
9453   CXXOperatorCallExpr *OCE = dyn_cast<CXXOperatorCallExpr>(LHSExpr);
9454   if (!OCE)
9455     return;
9456 
9457   FunctionDecl *FD = OCE->getDirectCallee();
9458   if (!FD || !FD->isOverloadedOperator())
9459     return;
9460 
9461   OverloadedOperatorKind Kind = FD->getOverloadedOperator();
9462   if (Kind != OO_LessLess && Kind != OO_GreaterGreater)
9463     return;
9464 
9465   S.Diag(OpLoc, diag::warn_overloaded_shift_in_comparison)
9466       << LHSExpr->getSourceRange() << RHSExpr->getSourceRange()
9467       << (Kind == OO_LessLess);
9468   SuggestParentheses(S, OCE->getOperatorLoc(),
9469                      S.PDiag(diag::note_precedence_silence)
9470                          << (Kind == OO_LessLess ? "<<" : ">>"),
9471                      OCE->getSourceRange());
9472   SuggestParentheses(S, OpLoc,
9473                      S.PDiag(diag::note_evaluate_comparison_first),
9474                      SourceRange(OCE->getArg(1)->getLocStart(),
9475                                  RHSExpr->getLocEnd()));
9476 }
9477 
9478 /// DiagnoseBinOpPrecedence - Emit warnings for expressions with tricky
9479 /// precedence.
9480 static void DiagnoseBinOpPrecedence(Sema &Self, BinaryOperatorKind Opc,
9481                                     SourceLocation OpLoc, Expr *LHSExpr,
9482                                     Expr *RHSExpr){
9483   // Diagnose "arg1 'bitwise' arg2 'eq' arg3".
9484   if (BinaryOperator::isBitwiseOp(Opc))
9485     DiagnoseBitwisePrecedence(Self, Opc, OpLoc, LHSExpr, RHSExpr);
9486 
9487   // Diagnose "arg1 & arg2 | arg3"
9488   if (Opc == BO_Or && !OpLoc.isMacroID()/* Don't warn in macros. */) {
9489     DiagnoseBitwiseAndInBitwiseOr(Self, OpLoc, LHSExpr);
9490     DiagnoseBitwiseAndInBitwiseOr(Self, OpLoc, RHSExpr);
9491   }
9492 
9493   // Warn about arg1 || arg2 && arg3, as GCC 4.3+ does.
9494   // We don't warn for 'assert(a || b && "bad")' since this is safe.
9495   if (Opc == BO_LOr && !OpLoc.isMacroID()/* Don't warn in macros. */) {
9496     DiagnoseLogicalAndInLogicalOrLHS(Self, OpLoc, LHSExpr, RHSExpr);
9497     DiagnoseLogicalAndInLogicalOrRHS(Self, OpLoc, LHSExpr, RHSExpr);
9498   }
9499 
9500   if ((Opc == BO_Shl && LHSExpr->getType()->isIntegralType(Self.getASTContext()))
9501       || Opc == BO_Shr) {
9502     StringRef Shift = BinaryOperator::getOpcodeStr(Opc);
9503     DiagnoseAdditionInShift(Self, OpLoc, LHSExpr, Shift);
9504     DiagnoseAdditionInShift(Self, OpLoc, RHSExpr, Shift);
9505   }
9506 
9507   // Warn on overloaded shift operators and comparisons, such as:
9508   // cout << 5 == 4;
9509   if (BinaryOperator::isComparisonOp(Opc))
9510     DiagnoseShiftCompare(Self, OpLoc, LHSExpr, RHSExpr);
9511 }
9512 
9513 // Binary Operators.  'Tok' is the token for the operator.
9514 ExprResult Sema::ActOnBinOp(Scope *S, SourceLocation TokLoc,
9515                             tok::TokenKind Kind,
9516                             Expr *LHSExpr, Expr *RHSExpr) {
9517   BinaryOperatorKind Opc = ConvertTokenKindToBinaryOpcode(Kind);
9518   assert((LHSExpr != 0) && "ActOnBinOp(): missing left expression");
9519   assert((RHSExpr != 0) && "ActOnBinOp(): missing right expression");
9520 
9521   // Emit warnings for tricky precedence issues, e.g. "bitfield & 0x4 == 0"
9522   DiagnoseBinOpPrecedence(*this, Opc, TokLoc, LHSExpr, RHSExpr);
9523 
9524   return BuildBinOp(S, TokLoc, Opc, LHSExpr, RHSExpr);
9525 }
9526 
9527 /// Build an overloaded binary operator expression in the given scope.
9528 static ExprResult BuildOverloadedBinOp(Sema &S, Scope *Sc, SourceLocation OpLoc,
9529                                        BinaryOperatorKind Opc,
9530                                        Expr *LHS, Expr *RHS) {
9531   // Find all of the overloaded operators visible from this
9532   // point. We perform both an operator-name lookup from the local
9533   // scope and an argument-dependent lookup based on the types of
9534   // the arguments.
9535   UnresolvedSet<16> Functions;
9536   OverloadedOperatorKind OverOp
9537     = BinaryOperator::getOverloadedOperator(Opc);
9538   if (Sc && OverOp != OO_None)
9539     S.LookupOverloadedOperatorName(OverOp, Sc, LHS->getType(),
9540                                    RHS->getType(), Functions);
9541 
9542   // Build the (potentially-overloaded, potentially-dependent)
9543   // binary operation.
9544   return S.CreateOverloadedBinOp(OpLoc, Opc, Functions, LHS, RHS);
9545 }
9546 
9547 ExprResult Sema::BuildBinOp(Scope *S, SourceLocation OpLoc,
9548                             BinaryOperatorKind Opc,
9549                             Expr *LHSExpr, Expr *RHSExpr) {
9550   // We want to end up calling one of checkPseudoObjectAssignment
9551   // (if the LHS is a pseudo-object), BuildOverloadedBinOp (if
9552   // both expressions are overloadable or either is type-dependent),
9553   // or CreateBuiltinBinOp (in any other case).  We also want to get
9554   // any placeholder types out of the way.
9555 
9556   // Handle pseudo-objects in the LHS.
9557   if (const BuiltinType *pty = LHSExpr->getType()->getAsPlaceholderType()) {
9558     // Assignments with a pseudo-object l-value need special analysis.
9559     if (pty->getKind() == BuiltinType::PseudoObject &&
9560         BinaryOperator::isAssignmentOp(Opc))
9561       return checkPseudoObjectAssignment(S, OpLoc, Opc, LHSExpr, RHSExpr);
9562 
9563     // Don't resolve overloads if the other type is overloadable.
9564     if (pty->getKind() == BuiltinType::Overload) {
9565       // We can't actually test that if we still have a placeholder,
9566       // though.  Fortunately, none of the exceptions we see in that
9567       // code below are valid when the LHS is an overload set.  Note
9568       // that an overload set can be dependently-typed, but it never
9569       // instantiates to having an overloadable type.
9570       ExprResult resolvedRHS = CheckPlaceholderExpr(RHSExpr);
9571       if (resolvedRHS.isInvalid()) return ExprError();
9572       RHSExpr = resolvedRHS.take();
9573 
9574       if (RHSExpr->isTypeDependent() ||
9575           RHSExpr->getType()->isOverloadableType())
9576         return BuildOverloadedBinOp(*this, S, OpLoc, Opc, LHSExpr, RHSExpr);
9577     }
9578 
9579     ExprResult LHS = CheckPlaceholderExpr(LHSExpr);
9580     if (LHS.isInvalid()) return ExprError();
9581     LHSExpr = LHS.take();
9582   }
9583 
9584   // Handle pseudo-objects in the RHS.
9585   if (const BuiltinType *pty = RHSExpr->getType()->getAsPlaceholderType()) {
9586     // An overload in the RHS can potentially be resolved by the type
9587     // being assigned to.
9588     if (Opc == BO_Assign && pty->getKind() == BuiltinType::Overload) {
9589       if (LHSExpr->isTypeDependent() || RHSExpr->isTypeDependent())
9590         return BuildOverloadedBinOp(*this, S, OpLoc, Opc, LHSExpr, RHSExpr);
9591 
9592       if (LHSExpr->getType()->isOverloadableType())
9593         return BuildOverloadedBinOp(*this, S, OpLoc, Opc, LHSExpr, RHSExpr);
9594 
9595       return CreateBuiltinBinOp(OpLoc, Opc, LHSExpr, RHSExpr);
9596     }
9597 
9598     // Don't resolve overloads if the other type is overloadable.
9599     if (pty->getKind() == BuiltinType::Overload &&
9600         LHSExpr->getType()->isOverloadableType())
9601       return BuildOverloadedBinOp(*this, S, OpLoc, Opc, LHSExpr, RHSExpr);
9602 
9603     ExprResult resolvedRHS = CheckPlaceholderExpr(RHSExpr);
9604     if (!resolvedRHS.isUsable()) return ExprError();
9605     RHSExpr = resolvedRHS.take();
9606   }
9607 
9608   if (getLangOpts().CPlusPlus) {
9609     // If either expression is type-dependent, always build an
9610     // overloaded op.
9611     if (LHSExpr->isTypeDependent() || RHSExpr->isTypeDependent())
9612       return BuildOverloadedBinOp(*this, S, OpLoc, Opc, LHSExpr, RHSExpr);
9613 
9614     // Otherwise, build an overloaded op if either expression has an
9615     // overloadable type.
9616     if (LHSExpr->getType()->isOverloadableType() ||
9617         RHSExpr->getType()->isOverloadableType())
9618       return BuildOverloadedBinOp(*this, S, OpLoc, Opc, LHSExpr, RHSExpr);
9619   }
9620 
9621   // Build a built-in binary operation.
9622   return CreateBuiltinBinOp(OpLoc, Opc, LHSExpr, RHSExpr);
9623 }
9624 
9625 ExprResult Sema::CreateBuiltinUnaryOp(SourceLocation OpLoc,
9626                                       UnaryOperatorKind Opc,
9627                                       Expr *InputExpr) {
9628   ExprResult Input = Owned(InputExpr);
9629   ExprValueKind VK = VK_RValue;
9630   ExprObjectKind OK = OK_Ordinary;
9631   QualType resultType;
9632   switch (Opc) {
9633   case UO_PreInc:
9634   case UO_PreDec:
9635   case UO_PostInc:
9636   case UO_PostDec:
9637     resultType = CheckIncrementDecrementOperand(*this, Input.get(), VK, OpLoc,
9638                                                 Opc == UO_PreInc ||
9639                                                 Opc == UO_PostInc,
9640                                                 Opc == UO_PreInc ||
9641                                                 Opc == UO_PreDec);
9642     break;
9643   case UO_AddrOf:
9644     resultType = CheckAddressOfOperand(Input, OpLoc);
9645     break;
9646   case UO_Deref: {
9647     Input = DefaultFunctionArrayLvalueConversion(Input.take());
9648     if (Input.isInvalid()) return ExprError();
9649     resultType = CheckIndirectionOperand(*this, Input.get(), VK, OpLoc);
9650     break;
9651   }
9652   case UO_Plus:
9653   case UO_Minus:
9654     Input = UsualUnaryConversions(Input.take());
9655     if (Input.isInvalid()) return ExprError();
9656     resultType = Input.get()->getType();
9657     if (resultType->isDependentType())
9658       break;
9659     if (resultType->isArithmeticType() || // C99 6.5.3.3p1
9660         resultType->isVectorType())
9661       break;
9662     else if (getLangOpts().CPlusPlus && // C++ [expr.unary.op]p6
9663              Opc == UO_Plus &&
9664              resultType->isPointerType())
9665       break;
9666 
9667     return ExprError(Diag(OpLoc, diag::err_typecheck_unary_expr)
9668       << resultType << Input.get()->getSourceRange());
9669 
9670   case UO_Not: // bitwise complement
9671     Input = UsualUnaryConversions(Input.take());
9672     if (Input.isInvalid())
9673       return ExprError();
9674     resultType = Input.get()->getType();
9675     if (resultType->isDependentType())
9676       break;
9677     // C99 6.5.3.3p1. We allow complex int and float as a GCC extension.
9678     if (resultType->isComplexType() || resultType->isComplexIntegerType())
9679       // C99 does not support '~' for complex conjugation.
9680       Diag(OpLoc, diag::ext_integer_complement_complex)
9681           << resultType << Input.get()->getSourceRange();
9682     else if (resultType->hasIntegerRepresentation())
9683       break;
9684     else if (resultType->isExtVectorType()) {
9685       if (Context.getLangOpts().OpenCL) {
9686         // OpenCL v1.1 s6.3.f: The bitwise operator not (~) does not operate
9687         // on vector float types.
9688         QualType T = resultType->getAs<ExtVectorType>()->getElementType();
9689         if (!T->isIntegerType())
9690           return ExprError(Diag(OpLoc, diag::err_typecheck_unary_expr)
9691                            << resultType << Input.get()->getSourceRange());
9692       }
9693       break;
9694     } else {
9695       return ExprError(Diag(OpLoc, diag::err_typecheck_unary_expr)
9696                        << resultType << Input.get()->getSourceRange());
9697     }
9698     break;
9699 
9700   case UO_LNot: // logical negation
9701     // Unlike +/-/~, integer promotions aren't done here (C99 6.5.3.3p5).
9702     Input = DefaultFunctionArrayLvalueConversion(Input.take());
9703     if (Input.isInvalid()) return ExprError();
9704     resultType = Input.get()->getType();
9705 
9706     // Though we still have to promote half FP to float...
9707     if (resultType->isHalfType() && !Context.getLangOpts().NativeHalfType) {
9708       Input = ImpCastExprToType(Input.take(), Context.FloatTy, CK_FloatingCast).take();
9709       resultType = Context.FloatTy;
9710     }
9711 
9712     if (resultType->isDependentType())
9713       break;
9714     if (resultType->isScalarType() && !isScopedEnumerationType(resultType)) {
9715       // C99 6.5.3.3p1: ok, fallthrough;
9716       if (Context.getLangOpts().CPlusPlus) {
9717         // C++03 [expr.unary.op]p8, C++0x [expr.unary.op]p9:
9718         // operand contextually converted to bool.
9719         Input = ImpCastExprToType(Input.take(), Context.BoolTy,
9720                                   ScalarTypeToBooleanCastKind(resultType));
9721       } else if (Context.getLangOpts().OpenCL &&
9722                  Context.getLangOpts().OpenCLVersion < 120) {
9723         // OpenCL v1.1 6.3.h: The logical operator not (!) does not
9724         // operate on scalar float types.
9725         if (!resultType->isIntegerType())
9726           return ExprError(Diag(OpLoc, diag::err_typecheck_unary_expr)
9727                            << resultType << Input.get()->getSourceRange());
9728       }
9729     } else if (resultType->isExtVectorType()) {
9730       if (Context.getLangOpts().OpenCL &&
9731           Context.getLangOpts().OpenCLVersion < 120) {
9732         // OpenCL v1.1 6.3.h: The logical operator not (!) does not
9733         // operate on vector float types.
9734         QualType T = resultType->getAs<ExtVectorType>()->getElementType();
9735         if (!T->isIntegerType())
9736           return ExprError(Diag(OpLoc, diag::err_typecheck_unary_expr)
9737                            << resultType << Input.get()->getSourceRange());
9738       }
9739       // Vector logical not returns the signed variant of the operand type.
9740       resultType = GetSignedVectorType(resultType);
9741       break;
9742     } else {
9743       return ExprError(Diag(OpLoc, diag::err_typecheck_unary_expr)
9744         << resultType << Input.get()->getSourceRange());
9745     }
9746 
9747     // LNot always has type int. C99 6.5.3.3p5.
9748     // In C++, it's bool. C++ 5.3.1p8
9749     resultType = Context.getLogicalOperationType();
9750     break;
9751   case UO_Real:
9752   case UO_Imag:
9753     resultType = CheckRealImagOperand(*this, Input, OpLoc, Opc == UO_Real);
9754     // _Real maps ordinary l-values into ordinary l-values. _Imag maps ordinary
9755     // complex l-values to ordinary l-values and all other values to r-values.
9756     if (Input.isInvalid()) return ExprError();
9757     if (Opc == UO_Real || Input.get()->getType()->isAnyComplexType()) {
9758       if (Input.get()->getValueKind() != VK_RValue &&
9759           Input.get()->getObjectKind() == OK_Ordinary)
9760         VK = Input.get()->getValueKind();
9761     } else if (!getLangOpts().CPlusPlus) {
9762       // In C, a volatile scalar is read by __imag. In C++, it is not.
9763       Input = DefaultLvalueConversion(Input.take());
9764     }
9765     break;
9766   case UO_Extension:
9767     resultType = Input.get()->getType();
9768     VK = Input.get()->getValueKind();
9769     OK = Input.get()->getObjectKind();
9770     break;
9771   }
9772   if (resultType.isNull() || Input.isInvalid())
9773     return ExprError();
9774 
9775   // Check for array bounds violations in the operand of the UnaryOperator,
9776   // except for the '*' and '&' operators that have to be handled specially
9777   // by CheckArrayAccess (as there are special cases like &array[arraysize]
9778   // that are explicitly defined as valid by the standard).
9779   if (Opc != UO_AddrOf && Opc != UO_Deref)
9780     CheckArrayAccess(Input.get());
9781 
9782   return Owned(new (Context) UnaryOperator(Input.take(), Opc, resultType,
9783                                            VK, OK, OpLoc));
9784 }
9785 
9786 /// \brief Determine whether the given expression is a qualified member
9787 /// access expression, of a form that could be turned into a pointer to member
9788 /// with the address-of operator.
9789 static bool isQualifiedMemberAccess(Expr *E) {
9790   if (DeclRefExpr *DRE = dyn_cast<DeclRefExpr>(E)) {
9791     if (!DRE->getQualifier())
9792       return false;
9793 
9794     ValueDecl *VD = DRE->getDecl();
9795     if (!VD->isCXXClassMember())
9796       return false;
9797 
9798     if (isa<FieldDecl>(VD) || isa<IndirectFieldDecl>(VD))
9799       return true;
9800     if (CXXMethodDecl *Method = dyn_cast<CXXMethodDecl>(VD))
9801       return Method->isInstance();
9802 
9803     return false;
9804   }
9805 
9806   if (UnresolvedLookupExpr *ULE = dyn_cast<UnresolvedLookupExpr>(E)) {
9807     if (!ULE->getQualifier())
9808       return false;
9809 
9810     for (UnresolvedLookupExpr::decls_iterator D = ULE->decls_begin(),
9811                                            DEnd = ULE->decls_end();
9812          D != DEnd; ++D) {
9813       if (CXXMethodDecl *Method = dyn_cast<CXXMethodDecl>(*D)) {
9814         if (Method->isInstance())
9815           return true;
9816       } else {
9817         // Overload set does not contain methods.
9818         break;
9819       }
9820     }
9821 
9822     return false;
9823   }
9824 
9825   return false;
9826 }
9827 
9828 ExprResult Sema::BuildUnaryOp(Scope *S, SourceLocation OpLoc,
9829                               UnaryOperatorKind Opc, Expr *Input) {
9830   // First things first: handle placeholders so that the
9831   // overloaded-operator check considers the right type.
9832   if (const BuiltinType *pty = Input->getType()->getAsPlaceholderType()) {
9833     // Increment and decrement of pseudo-object references.
9834     if (pty->getKind() == BuiltinType::PseudoObject &&
9835         UnaryOperator::isIncrementDecrementOp(Opc))
9836       return checkPseudoObjectIncDec(S, OpLoc, Opc, Input);
9837 
9838     // extension is always a builtin operator.
9839     if (Opc == UO_Extension)
9840       return CreateBuiltinUnaryOp(OpLoc, Opc, Input);
9841 
9842     // & gets special logic for several kinds of placeholder.
9843     // The builtin code knows what to do.
9844     if (Opc == UO_AddrOf &&
9845         (pty->getKind() == BuiltinType::Overload ||
9846          pty->getKind() == BuiltinType::UnknownAny ||
9847          pty->getKind() == BuiltinType::BoundMember))
9848       return CreateBuiltinUnaryOp(OpLoc, Opc, Input);
9849 
9850     // Anything else needs to be handled now.
9851     ExprResult Result = CheckPlaceholderExpr(Input);
9852     if (Result.isInvalid()) return ExprError();
9853     Input = Result.take();
9854   }
9855 
9856   if (getLangOpts().CPlusPlus && Input->getType()->isOverloadableType() &&
9857       UnaryOperator::getOverloadedOperator(Opc) != OO_None &&
9858       !(Opc == UO_AddrOf && isQualifiedMemberAccess(Input))) {
9859     // Find all of the overloaded operators visible from this
9860     // point. We perform both an operator-name lookup from the local
9861     // scope and an argument-dependent lookup based on the types of
9862     // the arguments.
9863     UnresolvedSet<16> Functions;
9864     OverloadedOperatorKind OverOp = UnaryOperator::getOverloadedOperator(Opc);
9865     if (S && OverOp != OO_None)
9866       LookupOverloadedOperatorName(OverOp, S, Input->getType(), QualType(),
9867                                    Functions);
9868 
9869     return CreateOverloadedUnaryOp(OpLoc, Opc, Functions, Input);
9870   }
9871 
9872   return CreateBuiltinUnaryOp(OpLoc, Opc, Input);
9873 }
9874 
9875 // Unary Operators.  'Tok' is the token for the operator.
9876 ExprResult Sema::ActOnUnaryOp(Scope *S, SourceLocation OpLoc,
9877                               tok::TokenKind Op, Expr *Input) {
9878   return BuildUnaryOp(S, OpLoc, ConvertTokenKindToUnaryOpcode(Op), Input);
9879 }
9880 
9881 /// ActOnAddrLabel - Parse the GNU address of label extension: "&&foo".
9882 ExprResult Sema::ActOnAddrLabel(SourceLocation OpLoc, SourceLocation LabLoc,
9883                                 LabelDecl *TheDecl) {
9884   TheDecl->markUsed(Context);
9885   // Create the AST node.  The address of a label always has type 'void*'.
9886   return Owned(new (Context) AddrLabelExpr(OpLoc, LabLoc, TheDecl,
9887                                        Context.getPointerType(Context.VoidTy)));
9888 }
9889 
9890 /// Given the last statement in a statement-expression, check whether
9891 /// the result is a producing expression (like a call to an
9892 /// ns_returns_retained function) and, if so, rebuild it to hoist the
9893 /// release out of the full-expression.  Otherwise, return null.
9894 /// Cannot fail.
9895 static Expr *maybeRebuildARCConsumingStmt(Stmt *Statement) {
9896   // Should always be wrapped with one of these.
9897   ExprWithCleanups *cleanups = dyn_cast<ExprWithCleanups>(Statement);
9898   if (!cleanups) return 0;
9899 
9900   ImplicitCastExpr *cast = dyn_cast<ImplicitCastExpr>(cleanups->getSubExpr());
9901   if (!cast || cast->getCastKind() != CK_ARCConsumeObject)
9902     return 0;
9903 
9904   // Splice out the cast.  This shouldn't modify any interesting
9905   // features of the statement.
9906   Expr *producer = cast->getSubExpr();
9907   assert(producer->getType() == cast->getType());
9908   assert(producer->getValueKind() == cast->getValueKind());
9909   cleanups->setSubExpr(producer);
9910   return cleanups;
9911 }
9912 
9913 void Sema::ActOnStartStmtExpr() {
9914   PushExpressionEvaluationContext(ExprEvalContexts.back().Context);
9915 }
9916 
9917 void Sema::ActOnStmtExprError() {
9918   // Note that function is also called by TreeTransform when leaving a
9919   // StmtExpr scope without rebuilding anything.
9920 
9921   DiscardCleanupsInEvaluationContext();
9922   PopExpressionEvaluationContext();
9923 }
9924 
9925 ExprResult
9926 Sema::ActOnStmtExpr(SourceLocation LPLoc, Stmt *SubStmt,
9927                     SourceLocation RPLoc) { // "({..})"
9928   assert(SubStmt && isa<CompoundStmt>(SubStmt) && "Invalid action invocation!");
9929   CompoundStmt *Compound = cast<CompoundStmt>(SubStmt);
9930 
9931   if (hasAnyUnrecoverableErrorsInThisFunction())
9932     DiscardCleanupsInEvaluationContext();
9933   assert(!ExprNeedsCleanups && "cleanups within StmtExpr not correctly bound!");
9934   PopExpressionEvaluationContext();
9935 
9936   bool isFileScope
9937     = (getCurFunctionOrMethodDecl() == 0) && (getCurBlock() == 0);
9938   if (isFileScope)
9939     return ExprError(Diag(LPLoc, diag::err_stmtexpr_file_scope));
9940 
9941   // FIXME: there are a variety of strange constraints to enforce here, for
9942   // example, it is not possible to goto into a stmt expression apparently.
9943   // More semantic analysis is needed.
9944 
9945   // If there are sub-stmts in the compound stmt, take the type of the last one
9946   // as the type of the stmtexpr.
9947   QualType Ty = Context.VoidTy;
9948   bool StmtExprMayBindToTemp = false;
9949   if (!Compound->body_empty()) {
9950     Stmt *LastStmt = Compound->body_back();
9951     LabelStmt *LastLabelStmt = 0;
9952     // If LastStmt is a label, skip down through into the body.
9953     while (LabelStmt *Label = dyn_cast<LabelStmt>(LastStmt)) {
9954       LastLabelStmt = Label;
9955       LastStmt = Label->getSubStmt();
9956     }
9957 
9958     if (Expr *LastE = dyn_cast<Expr>(LastStmt)) {
9959       // Do function/array conversion on the last expression, but not
9960       // lvalue-to-rvalue.  However, initialize an unqualified type.
9961       ExprResult LastExpr = DefaultFunctionArrayConversion(LastE);
9962       if (LastExpr.isInvalid())
9963         return ExprError();
9964       Ty = LastExpr.get()->getType().getUnqualifiedType();
9965 
9966       if (!Ty->isDependentType() && !LastExpr.get()->isTypeDependent()) {
9967         // In ARC, if the final expression ends in a consume, splice
9968         // the consume out and bind it later.  In the alternate case
9969         // (when dealing with a retainable type), the result
9970         // initialization will create a produce.  In both cases the
9971         // result will be +1, and we'll need to balance that out with
9972         // a bind.
9973         if (Expr *rebuiltLastStmt
9974               = maybeRebuildARCConsumingStmt(LastExpr.get())) {
9975           LastExpr = rebuiltLastStmt;
9976         } else {
9977           LastExpr = PerformCopyInitialization(
9978                             InitializedEntity::InitializeResult(LPLoc,
9979                                                                 Ty,
9980                                                                 false),
9981                                                    SourceLocation(),
9982                                                LastExpr);
9983         }
9984 
9985         if (LastExpr.isInvalid())
9986           return ExprError();
9987         if (LastExpr.get() != 0) {
9988           if (!LastLabelStmt)
9989             Compound->setLastStmt(LastExpr.take());
9990           else
9991             LastLabelStmt->setSubStmt(LastExpr.take());
9992           StmtExprMayBindToTemp = true;
9993         }
9994       }
9995     }
9996   }
9997 
9998   // FIXME: Check that expression type is complete/non-abstract; statement
9999   // expressions are not lvalues.
10000   Expr *ResStmtExpr = new (Context) StmtExpr(Compound, Ty, LPLoc, RPLoc);
10001   if (StmtExprMayBindToTemp)
10002     return MaybeBindToTemporary(ResStmtExpr);
10003   return Owned(ResStmtExpr);
10004 }
10005 
10006 ExprResult Sema::BuildBuiltinOffsetOf(SourceLocation BuiltinLoc,
10007                                       TypeSourceInfo *TInfo,
10008                                       OffsetOfComponent *CompPtr,
10009                                       unsigned NumComponents,
10010                                       SourceLocation RParenLoc) {
10011   QualType ArgTy = TInfo->getType();
10012   bool Dependent = ArgTy->isDependentType();
10013   SourceRange TypeRange = TInfo->getTypeLoc().getLocalSourceRange();
10014 
10015   // We must have at least one component that refers to the type, and the first
10016   // one is known to be a field designator.  Verify that the ArgTy represents
10017   // a struct/union/class.
10018   if (!Dependent && !ArgTy->isRecordType())
10019     return ExprError(Diag(BuiltinLoc, diag::err_offsetof_record_type)
10020                        << ArgTy << TypeRange);
10021 
10022   // Type must be complete per C99 7.17p3 because a declaring a variable
10023   // with an incomplete type would be ill-formed.
10024   if (!Dependent
10025       && RequireCompleteType(BuiltinLoc, ArgTy,
10026                              diag::err_offsetof_incomplete_type, TypeRange))
10027     return ExprError();
10028 
10029   // offsetof with non-identifier designators (e.g. "offsetof(x, a.b[c])") are a
10030   // GCC extension, diagnose them.
10031   // FIXME: This diagnostic isn't actually visible because the location is in
10032   // a system header!
10033   if (NumComponents != 1)
10034     Diag(BuiltinLoc, diag::ext_offsetof_extended_field_designator)
10035       << SourceRange(CompPtr[1].LocStart, CompPtr[NumComponents-1].LocEnd);
10036 
10037   bool DidWarnAboutNonPOD = false;
10038   QualType CurrentType = ArgTy;
10039   typedef OffsetOfExpr::OffsetOfNode OffsetOfNode;
10040   SmallVector<OffsetOfNode, 4> Comps;
10041   SmallVector<Expr*, 4> Exprs;
10042   for (unsigned i = 0; i != NumComponents; ++i) {
10043     const OffsetOfComponent &OC = CompPtr[i];
10044     if (OC.isBrackets) {
10045       // Offset of an array sub-field.  TODO: Should we allow vector elements?
10046       if (!CurrentType->isDependentType()) {
10047         const ArrayType *AT = Context.getAsArrayType(CurrentType);
10048         if(!AT)
10049           return ExprError(Diag(OC.LocEnd, diag::err_offsetof_array_type)
10050                            << CurrentType);
10051         CurrentType = AT->getElementType();
10052       } else
10053         CurrentType = Context.DependentTy;
10054 
10055       ExprResult IdxRval = DefaultLvalueConversion(static_cast<Expr*>(OC.U.E));
10056       if (IdxRval.isInvalid())
10057         return ExprError();
10058       Expr *Idx = IdxRval.take();
10059 
10060       // The expression must be an integral expression.
10061       // FIXME: An integral constant expression?
10062       if (!Idx->isTypeDependent() && !Idx->isValueDependent() &&
10063           !Idx->getType()->isIntegerType())
10064         return ExprError(Diag(Idx->getLocStart(),
10065                               diag::err_typecheck_subscript_not_integer)
10066                          << Idx->getSourceRange());
10067 
10068       // Record this array index.
10069       Comps.push_back(OffsetOfNode(OC.LocStart, Exprs.size(), OC.LocEnd));
10070       Exprs.push_back(Idx);
10071       continue;
10072     }
10073 
10074     // Offset of a field.
10075     if (CurrentType->isDependentType()) {
10076       // We have the offset of a field, but we can't look into the dependent
10077       // type. Just record the identifier of the field.
10078       Comps.push_back(OffsetOfNode(OC.LocStart, OC.U.IdentInfo, OC.LocEnd));
10079       CurrentType = Context.DependentTy;
10080       continue;
10081     }
10082 
10083     // We need to have a complete type to look into.
10084     if (RequireCompleteType(OC.LocStart, CurrentType,
10085                             diag::err_offsetof_incomplete_type))
10086       return ExprError();
10087 
10088     // Look for the designated field.
10089     const RecordType *RC = CurrentType->getAs<RecordType>();
10090     if (!RC)
10091       return ExprError(Diag(OC.LocEnd, diag::err_offsetof_record_type)
10092                        << CurrentType);
10093     RecordDecl *RD = RC->getDecl();
10094 
10095     // C++ [lib.support.types]p5:
10096     //   The macro offsetof accepts a restricted set of type arguments in this
10097     //   International Standard. type shall be a POD structure or a POD union
10098     //   (clause 9).
10099     // C++11 [support.types]p4:
10100     //   If type is not a standard-layout class (Clause 9), the results are
10101     //   undefined.
10102     if (CXXRecordDecl *CRD = dyn_cast<CXXRecordDecl>(RD)) {
10103       bool IsSafe = LangOpts.CPlusPlus11? CRD->isStandardLayout() : CRD->isPOD();
10104       unsigned DiagID =
10105         LangOpts.CPlusPlus11? diag::warn_offsetof_non_standardlayout_type
10106                             : diag::warn_offsetof_non_pod_type;
10107 
10108       if (!IsSafe && !DidWarnAboutNonPOD &&
10109           DiagRuntimeBehavior(BuiltinLoc, 0,
10110                               PDiag(DiagID)
10111                               << SourceRange(CompPtr[0].LocStart, OC.LocEnd)
10112                               << CurrentType))
10113         DidWarnAboutNonPOD = true;
10114     }
10115 
10116     // Look for the field.
10117     LookupResult R(*this, OC.U.IdentInfo, OC.LocStart, LookupMemberName);
10118     LookupQualifiedName(R, RD);
10119     FieldDecl *MemberDecl = R.getAsSingle<FieldDecl>();
10120     IndirectFieldDecl *IndirectMemberDecl = 0;
10121     if (!MemberDecl) {
10122       if ((IndirectMemberDecl = R.getAsSingle<IndirectFieldDecl>()))
10123         MemberDecl = IndirectMemberDecl->getAnonField();
10124     }
10125 
10126     if (!MemberDecl)
10127       return ExprError(Diag(BuiltinLoc, diag::err_no_member)
10128                        << OC.U.IdentInfo << RD << SourceRange(OC.LocStart,
10129                                                               OC.LocEnd));
10130 
10131     // C99 7.17p3:
10132     //   (If the specified member is a bit-field, the behavior is undefined.)
10133     //
10134     // We diagnose this as an error.
10135     if (MemberDecl->isBitField()) {
10136       Diag(OC.LocEnd, diag::err_offsetof_bitfield)
10137         << MemberDecl->getDeclName()
10138         << SourceRange(BuiltinLoc, RParenLoc);
10139       Diag(MemberDecl->getLocation(), diag::note_bitfield_decl);
10140       return ExprError();
10141     }
10142 
10143     RecordDecl *Parent = MemberDecl->getParent();
10144     if (IndirectMemberDecl)
10145       Parent = cast<RecordDecl>(IndirectMemberDecl->getDeclContext());
10146 
10147     // If the member was found in a base class, introduce OffsetOfNodes for
10148     // the base class indirections.
10149     CXXBasePaths Paths;
10150     if (IsDerivedFrom(CurrentType, Context.getTypeDeclType(Parent), Paths)) {
10151       if (Paths.getDetectedVirtual()) {
10152         Diag(OC.LocEnd, diag::err_offsetof_field_of_virtual_base)
10153           << MemberDecl->getDeclName()
10154           << SourceRange(BuiltinLoc, RParenLoc);
10155         return ExprError();
10156       }
10157 
10158       CXXBasePath &Path = Paths.front();
10159       for (CXXBasePath::iterator B = Path.begin(), BEnd = Path.end();
10160            B != BEnd; ++B)
10161         Comps.push_back(OffsetOfNode(B->Base));
10162     }
10163 
10164     if (IndirectMemberDecl) {
10165       for (IndirectFieldDecl::chain_iterator FI =
10166            IndirectMemberDecl->chain_begin(),
10167            FEnd = IndirectMemberDecl->chain_end(); FI != FEnd; FI++) {
10168         assert(isa<FieldDecl>(*FI));
10169         Comps.push_back(OffsetOfNode(OC.LocStart,
10170                                      cast<FieldDecl>(*FI), OC.LocEnd));
10171       }
10172     } else
10173       Comps.push_back(OffsetOfNode(OC.LocStart, MemberDecl, OC.LocEnd));
10174 
10175     CurrentType = MemberDecl->getType().getNonReferenceType();
10176   }
10177 
10178   return Owned(OffsetOfExpr::Create(Context, Context.getSizeType(), BuiltinLoc,
10179                                     TInfo, Comps, Exprs, RParenLoc));
10180 }
10181 
10182 ExprResult Sema::ActOnBuiltinOffsetOf(Scope *S,
10183                                       SourceLocation BuiltinLoc,
10184                                       SourceLocation TypeLoc,
10185                                       ParsedType ParsedArgTy,
10186                                       OffsetOfComponent *CompPtr,
10187                                       unsigned NumComponents,
10188                                       SourceLocation RParenLoc) {
10189 
10190   TypeSourceInfo *ArgTInfo;
10191   QualType ArgTy = GetTypeFromParser(ParsedArgTy, &ArgTInfo);
10192   if (ArgTy.isNull())
10193     return ExprError();
10194 
10195   if (!ArgTInfo)
10196     ArgTInfo = Context.getTrivialTypeSourceInfo(ArgTy, TypeLoc);
10197 
10198   return BuildBuiltinOffsetOf(BuiltinLoc, ArgTInfo, CompPtr, NumComponents,
10199                               RParenLoc);
10200 }
10201 
10202 
10203 ExprResult Sema::ActOnChooseExpr(SourceLocation BuiltinLoc,
10204                                  Expr *CondExpr,
10205                                  Expr *LHSExpr, Expr *RHSExpr,
10206                                  SourceLocation RPLoc) {
10207   assert((CondExpr && LHSExpr && RHSExpr) && "Missing type argument(s)");
10208 
10209   ExprValueKind VK = VK_RValue;
10210   ExprObjectKind OK = OK_Ordinary;
10211   QualType resType;
10212   bool ValueDependent = false;
10213   bool CondIsTrue = false;
10214   if (CondExpr->isTypeDependent() || CondExpr->isValueDependent()) {
10215     resType = Context.DependentTy;
10216     ValueDependent = true;
10217   } else {
10218     // The conditional expression is required to be a constant expression.
10219     llvm::APSInt condEval(32);
10220     ExprResult CondICE
10221       = VerifyIntegerConstantExpression(CondExpr, &condEval,
10222           diag::err_typecheck_choose_expr_requires_constant, false);
10223     if (CondICE.isInvalid())
10224       return ExprError();
10225     CondExpr = CondICE.take();
10226     CondIsTrue = condEval.getZExtValue();
10227 
10228     // If the condition is > zero, then the AST type is the same as the LSHExpr.
10229     Expr *ActiveExpr = CondIsTrue ? LHSExpr : RHSExpr;
10230 
10231     resType = ActiveExpr->getType();
10232     ValueDependent = ActiveExpr->isValueDependent();
10233     VK = ActiveExpr->getValueKind();
10234     OK = ActiveExpr->getObjectKind();
10235   }
10236 
10237   return Owned(new (Context) ChooseExpr(BuiltinLoc, CondExpr, LHSExpr, RHSExpr,
10238                                         resType, VK, OK, RPLoc, CondIsTrue,
10239                                         resType->isDependentType(),
10240                                         ValueDependent));
10241 }
10242 
10243 //===----------------------------------------------------------------------===//
10244 // Clang Extensions.
10245 //===----------------------------------------------------------------------===//
10246 
10247 /// ActOnBlockStart - This callback is invoked when a block literal is started.
10248 void Sema::ActOnBlockStart(SourceLocation CaretLoc, Scope *CurScope) {
10249   BlockDecl *Block = BlockDecl::Create(Context, CurContext, CaretLoc);
10250 
10251   if (LangOpts.CPlusPlus) {
10252     Decl *ManglingContextDecl;
10253     if (MangleNumberingContext *MCtx =
10254             getCurrentMangleNumberContext(Block->getDeclContext(),
10255                                           ManglingContextDecl)) {
10256       unsigned ManglingNumber = MCtx->getManglingNumber(Block);
10257       Block->setBlockMangling(ManglingNumber, ManglingContextDecl);
10258     }
10259   }
10260 
10261   PushBlockScope(CurScope, Block);
10262   CurContext->addDecl(Block);
10263   if (CurScope)
10264     PushDeclContext(CurScope, Block);
10265   else
10266     CurContext = Block;
10267 
10268   getCurBlock()->HasImplicitReturnType = true;
10269 
10270   // Enter a new evaluation context to insulate the block from any
10271   // cleanups from the enclosing full-expression.
10272   PushExpressionEvaluationContext(PotentiallyEvaluated);
10273 }
10274 
10275 void Sema::ActOnBlockArguments(SourceLocation CaretLoc, Declarator &ParamInfo,
10276                                Scope *CurScope) {
10277   assert(ParamInfo.getIdentifier()==0 && "block-id should have no identifier!");
10278   assert(ParamInfo.getContext() == Declarator::BlockLiteralContext);
10279   BlockScopeInfo *CurBlock = getCurBlock();
10280 
10281   TypeSourceInfo *Sig = GetTypeForDeclarator(ParamInfo, CurScope);
10282   QualType T = Sig->getType();
10283 
10284   // FIXME: We should allow unexpanded parameter packs here, but that would,
10285   // in turn, make the block expression contain unexpanded parameter packs.
10286   if (DiagnoseUnexpandedParameterPack(CaretLoc, Sig, UPPC_Block)) {
10287     // Drop the parameters.
10288     FunctionProtoType::ExtProtoInfo EPI;
10289     EPI.HasTrailingReturn = false;
10290     EPI.TypeQuals |= DeclSpec::TQ_const;
10291     T = Context.getFunctionType(Context.DependentTy, None, EPI);
10292     Sig = Context.getTrivialTypeSourceInfo(T);
10293   }
10294 
10295   // GetTypeForDeclarator always produces a function type for a block
10296   // literal signature.  Furthermore, it is always a FunctionProtoType
10297   // unless the function was written with a typedef.
10298   assert(T->isFunctionType() &&
10299          "GetTypeForDeclarator made a non-function block signature");
10300 
10301   // Look for an explicit signature in that function type.
10302   FunctionProtoTypeLoc ExplicitSignature;
10303 
10304   TypeLoc tmp = Sig->getTypeLoc().IgnoreParens();
10305   if ((ExplicitSignature = tmp.getAs<FunctionProtoTypeLoc>())) {
10306 
10307     // Check whether that explicit signature was synthesized by
10308     // GetTypeForDeclarator.  If so, don't save that as part of the
10309     // written signature.
10310     if (ExplicitSignature.getLocalRangeBegin() ==
10311         ExplicitSignature.getLocalRangeEnd()) {
10312       // This would be much cheaper if we stored TypeLocs instead of
10313       // TypeSourceInfos.
10314       TypeLoc Result = ExplicitSignature.getResultLoc();
10315       unsigned Size = Result.getFullDataSize();
10316       Sig = Context.CreateTypeSourceInfo(Result.getType(), Size);
10317       Sig->getTypeLoc().initializeFullCopy(Result, Size);
10318 
10319       ExplicitSignature = FunctionProtoTypeLoc();
10320     }
10321   }
10322 
10323   CurBlock->TheDecl->setSignatureAsWritten(Sig);
10324   CurBlock->FunctionType = T;
10325 
10326   const FunctionType *Fn = T->getAs<FunctionType>();
10327   QualType RetTy = Fn->getResultType();
10328   bool isVariadic =
10329     (isa<FunctionProtoType>(Fn) && cast<FunctionProtoType>(Fn)->isVariadic());
10330 
10331   CurBlock->TheDecl->setIsVariadic(isVariadic);
10332 
10333   // Context.DependentTy is used as a placeholder for a missing block
10334   // return type.  TODO:  what should we do with declarators like:
10335   //   ^ * { ... }
10336   // If the answer is "apply template argument deduction"....
10337   if (RetTy != Context.DependentTy) {
10338     CurBlock->ReturnType = RetTy;
10339     CurBlock->TheDecl->setBlockMissingReturnType(false);
10340     CurBlock->HasImplicitReturnType = false;
10341   }
10342 
10343   // Push block parameters from the declarator if we had them.
10344   SmallVector<ParmVarDecl*, 8> Params;
10345   if (ExplicitSignature) {
10346     for (unsigned I = 0, E = ExplicitSignature.getNumArgs(); I != E; ++I) {
10347       ParmVarDecl *Param = ExplicitSignature.getArg(I);
10348       if (Param->getIdentifier() == 0 &&
10349           !Param->isImplicit() &&
10350           !Param->isInvalidDecl() &&
10351           !getLangOpts().CPlusPlus)
10352         Diag(Param->getLocation(), diag::err_parameter_name_omitted);
10353       Params.push_back(Param);
10354     }
10355 
10356   // Fake up parameter variables if we have a typedef, like
10357   //   ^ fntype { ... }
10358   } else if (const FunctionProtoType *Fn = T->getAs<FunctionProtoType>()) {
10359     for (FunctionProtoType::arg_type_iterator
10360            I = Fn->arg_type_begin(), E = Fn->arg_type_end(); I != E; ++I) {
10361       ParmVarDecl *Param =
10362         BuildParmVarDeclForTypedef(CurBlock->TheDecl,
10363                                    ParamInfo.getLocStart(),
10364                                    *I);
10365       Params.push_back(Param);
10366     }
10367   }
10368 
10369   // Set the parameters on the block decl.
10370   if (!Params.empty()) {
10371     CurBlock->TheDecl->setParams(Params);
10372     CheckParmsForFunctionDef(CurBlock->TheDecl->param_begin(),
10373                              CurBlock->TheDecl->param_end(),
10374                              /*CheckParameterNames=*/false);
10375   }
10376 
10377   // Finally we can process decl attributes.
10378   ProcessDeclAttributes(CurScope, CurBlock->TheDecl, ParamInfo);
10379 
10380   // Put the parameter variables in scope.
10381   for (BlockDecl::param_iterator AI = CurBlock->TheDecl->param_begin(),
10382          E = CurBlock->TheDecl->param_end(); AI != E; ++AI) {
10383     (*AI)->setOwningFunction(CurBlock->TheDecl);
10384 
10385     // If this has an identifier, add it to the scope stack.
10386     if ((*AI)->getIdentifier()) {
10387       CheckShadow(CurBlock->TheScope, *AI);
10388 
10389       PushOnScopeChains(*AI, CurBlock->TheScope);
10390     }
10391   }
10392 }
10393 
10394 /// ActOnBlockError - If there is an error parsing a block, this callback
10395 /// is invoked to pop the information about the block from the action impl.
10396 void Sema::ActOnBlockError(SourceLocation CaretLoc, Scope *CurScope) {
10397   // Leave the expression-evaluation context.
10398   DiscardCleanupsInEvaluationContext();
10399   PopExpressionEvaluationContext();
10400 
10401   // Pop off CurBlock, handle nested blocks.
10402   PopDeclContext();
10403   PopFunctionScopeInfo();
10404 }
10405 
10406 /// ActOnBlockStmtExpr - This is called when the body of a block statement
10407 /// literal was successfully completed.  ^(int x){...}
10408 ExprResult Sema::ActOnBlockStmtExpr(SourceLocation CaretLoc,
10409                                     Stmt *Body, Scope *CurScope) {
10410   // If blocks are disabled, emit an error.
10411   if (!LangOpts.Blocks)
10412     Diag(CaretLoc, diag::err_blocks_disable);
10413 
10414   // Leave the expression-evaluation context.
10415   if (hasAnyUnrecoverableErrorsInThisFunction())
10416     DiscardCleanupsInEvaluationContext();
10417   assert(!ExprNeedsCleanups && "cleanups within block not correctly bound!");
10418   PopExpressionEvaluationContext();
10419 
10420   BlockScopeInfo *BSI = cast<BlockScopeInfo>(FunctionScopes.back());
10421 
10422   if (BSI->HasImplicitReturnType)
10423     deduceClosureReturnType(*BSI);
10424 
10425   PopDeclContext();
10426 
10427   QualType RetTy = Context.VoidTy;
10428   if (!BSI->ReturnType.isNull())
10429     RetTy = BSI->ReturnType;
10430 
10431   bool NoReturn = BSI->TheDecl->hasAttr<NoReturnAttr>();
10432   QualType BlockTy;
10433 
10434   // Set the captured variables on the block.
10435   // FIXME: Share capture structure between BlockDecl and CapturingScopeInfo!
10436   SmallVector<BlockDecl::Capture, 4> Captures;
10437   for (unsigned i = 0, e = BSI->Captures.size(); i != e; i++) {
10438     CapturingScopeInfo::Capture &Cap = BSI->Captures[i];
10439     if (Cap.isThisCapture())
10440       continue;
10441     BlockDecl::Capture NewCap(Cap.getVariable(), Cap.isBlockCapture(),
10442                               Cap.isNested(), Cap.getInitExpr());
10443     Captures.push_back(NewCap);
10444   }
10445   BSI->TheDecl->setCaptures(Context, Captures.begin(), Captures.end(),
10446                             BSI->CXXThisCaptureIndex != 0);
10447 
10448   // If the user wrote a function type in some form, try to use that.
10449   if (!BSI->FunctionType.isNull()) {
10450     const FunctionType *FTy = BSI->FunctionType->getAs<FunctionType>();
10451 
10452     FunctionType::ExtInfo Ext = FTy->getExtInfo();
10453     if (NoReturn && !Ext.getNoReturn()) Ext = Ext.withNoReturn(true);
10454 
10455     // Turn protoless block types into nullary block types.
10456     if (isa<FunctionNoProtoType>(FTy)) {
10457       FunctionProtoType::ExtProtoInfo EPI;
10458       EPI.ExtInfo = Ext;
10459       BlockTy = Context.getFunctionType(RetTy, None, EPI);
10460 
10461     // Otherwise, if we don't need to change anything about the function type,
10462     // preserve its sugar structure.
10463     } else if (FTy->getResultType() == RetTy &&
10464                (!NoReturn || FTy->getNoReturnAttr())) {
10465       BlockTy = BSI->FunctionType;
10466 
10467     // Otherwise, make the minimal modifications to the function type.
10468     } else {
10469       const FunctionProtoType *FPT = cast<FunctionProtoType>(FTy);
10470       FunctionProtoType::ExtProtoInfo EPI = FPT->getExtProtoInfo();
10471       EPI.TypeQuals = 0; // FIXME: silently?
10472       EPI.ExtInfo = Ext;
10473       BlockTy = Context.getFunctionType(RetTy, FPT->getArgTypes(), EPI);
10474     }
10475 
10476   // If we don't have a function type, just build one from nothing.
10477   } else {
10478     FunctionProtoType::ExtProtoInfo EPI;
10479     EPI.ExtInfo = FunctionType::ExtInfo().withNoReturn(NoReturn);
10480     BlockTy = Context.getFunctionType(RetTy, None, EPI);
10481   }
10482 
10483   DiagnoseUnusedParameters(BSI->TheDecl->param_begin(),
10484                            BSI->TheDecl->param_end());
10485   BlockTy = Context.getBlockPointerType(BlockTy);
10486 
10487   // If needed, diagnose invalid gotos and switches in the block.
10488   if (getCurFunction()->NeedsScopeChecking() &&
10489       !hasAnyUnrecoverableErrorsInThisFunction() &&
10490       !PP.isCodeCompletionEnabled())
10491     DiagnoseInvalidJumps(cast<CompoundStmt>(Body));
10492 
10493   BSI->TheDecl->setBody(cast<CompoundStmt>(Body));
10494 
10495   // Try to apply the named return value optimization. We have to check again
10496   // if we can do this, though, because blocks keep return statements around
10497   // to deduce an implicit return type.
10498   if (getLangOpts().CPlusPlus && RetTy->isRecordType() &&
10499       !BSI->TheDecl->isDependentContext())
10500     computeNRVO(Body, getCurBlock());
10501 
10502   BlockExpr *Result = new (Context) BlockExpr(BSI->TheDecl, BlockTy);
10503   AnalysisBasedWarnings::Policy WP = AnalysisWarnings.getDefaultPolicy();
10504   PopFunctionScopeInfo(&WP, Result->getBlockDecl(), Result);
10505 
10506   // If the block isn't obviously global, i.e. it captures anything at
10507   // all, then we need to do a few things in the surrounding context:
10508   if (Result->getBlockDecl()->hasCaptures()) {
10509     // First, this expression has a new cleanup object.
10510     ExprCleanupObjects.push_back(Result->getBlockDecl());
10511     ExprNeedsCleanups = true;
10512 
10513     // It also gets a branch-protected scope if any of the captured
10514     // variables needs destruction.
10515     for (BlockDecl::capture_const_iterator
10516            ci = Result->getBlockDecl()->capture_begin(),
10517            ce = Result->getBlockDecl()->capture_end(); ci != ce; ++ci) {
10518       const VarDecl *var = ci->getVariable();
10519       if (var->getType().isDestructedType() != QualType::DK_none) {
10520         getCurFunction()->setHasBranchProtectedScope();
10521         break;
10522       }
10523     }
10524   }
10525 
10526   return Owned(Result);
10527 }
10528 
10529 ExprResult Sema::ActOnVAArg(SourceLocation BuiltinLoc,
10530                                         Expr *E, ParsedType Ty,
10531                                         SourceLocation RPLoc) {
10532   TypeSourceInfo *TInfo;
10533   GetTypeFromParser(Ty, &TInfo);
10534   return BuildVAArgExpr(BuiltinLoc, E, TInfo, RPLoc);
10535 }
10536 
10537 ExprResult Sema::BuildVAArgExpr(SourceLocation BuiltinLoc,
10538                                 Expr *E, TypeSourceInfo *TInfo,
10539                                 SourceLocation RPLoc) {
10540   Expr *OrigExpr = E;
10541 
10542   // Get the va_list type
10543   QualType VaListType = Context.getBuiltinVaListType();
10544   if (VaListType->isArrayType()) {
10545     // Deal with implicit array decay; for example, on x86-64,
10546     // va_list is an array, but it's supposed to decay to
10547     // a pointer for va_arg.
10548     VaListType = Context.getArrayDecayedType(VaListType);
10549     // Make sure the input expression also decays appropriately.
10550     ExprResult Result = UsualUnaryConversions(E);
10551     if (Result.isInvalid())
10552       return ExprError();
10553     E = Result.take();
10554   } else if (VaListType->isRecordType() && getLangOpts().CPlusPlus) {
10555     // If va_list is a record type and we are compiling in C++ mode,
10556     // check the argument using reference binding.
10557     InitializedEntity Entity
10558       = InitializedEntity::InitializeParameter(Context,
10559           Context.getLValueReferenceType(VaListType), false);
10560     ExprResult Init = PerformCopyInitialization(Entity, SourceLocation(), E);
10561     if (Init.isInvalid())
10562       return ExprError();
10563     E = Init.takeAs<Expr>();
10564   } else {
10565     // Otherwise, the va_list argument must be an l-value because
10566     // it is modified by va_arg.
10567     if (!E->isTypeDependent() &&
10568         CheckForModifiableLvalue(E, BuiltinLoc, *this))
10569       return ExprError();
10570   }
10571 
10572   if (!E->isTypeDependent() &&
10573       !Context.hasSameType(VaListType, E->getType())) {
10574     return ExprError(Diag(E->getLocStart(),
10575                          diag::err_first_argument_to_va_arg_not_of_type_va_list)
10576       << OrigExpr->getType() << E->getSourceRange());
10577   }
10578 
10579   if (!TInfo->getType()->isDependentType()) {
10580     if (RequireCompleteType(TInfo->getTypeLoc().getBeginLoc(), TInfo->getType(),
10581                             diag::err_second_parameter_to_va_arg_incomplete,
10582                             TInfo->getTypeLoc()))
10583       return ExprError();
10584 
10585     if (RequireNonAbstractType(TInfo->getTypeLoc().getBeginLoc(),
10586                                TInfo->getType(),
10587                                diag::err_second_parameter_to_va_arg_abstract,
10588                                TInfo->getTypeLoc()))
10589       return ExprError();
10590 
10591     if (!TInfo->getType().isPODType(Context)) {
10592       Diag(TInfo->getTypeLoc().getBeginLoc(),
10593            TInfo->getType()->isObjCLifetimeType()
10594              ? diag::warn_second_parameter_to_va_arg_ownership_qualified
10595              : diag::warn_second_parameter_to_va_arg_not_pod)
10596         << TInfo->getType()
10597         << TInfo->getTypeLoc().getSourceRange();
10598     }
10599 
10600     // Check for va_arg where arguments of the given type will be promoted
10601     // (i.e. this va_arg is guaranteed to have undefined behavior).
10602     QualType PromoteType;
10603     if (TInfo->getType()->isPromotableIntegerType()) {
10604       PromoteType = Context.getPromotedIntegerType(TInfo->getType());
10605       if (Context.typesAreCompatible(PromoteType, TInfo->getType()))
10606         PromoteType = QualType();
10607     }
10608     if (TInfo->getType()->isSpecificBuiltinType(BuiltinType::Float))
10609       PromoteType = Context.DoubleTy;
10610     if (!PromoteType.isNull())
10611       DiagRuntimeBehavior(TInfo->getTypeLoc().getBeginLoc(), E,
10612                   PDiag(diag::warn_second_parameter_to_va_arg_never_compatible)
10613                           << TInfo->getType()
10614                           << PromoteType
10615                           << TInfo->getTypeLoc().getSourceRange());
10616   }
10617 
10618   QualType T = TInfo->getType().getNonLValueExprType(Context);
10619   return Owned(new (Context) VAArgExpr(BuiltinLoc, E, TInfo, RPLoc, T));
10620 }
10621 
10622 ExprResult Sema::ActOnGNUNullExpr(SourceLocation TokenLoc) {
10623   // The type of __null will be int or long, depending on the size of
10624   // pointers on the target.
10625   QualType Ty;
10626   unsigned pw = Context.getTargetInfo().getPointerWidth(0);
10627   if (pw == Context.getTargetInfo().getIntWidth())
10628     Ty = Context.IntTy;
10629   else if (pw == Context.getTargetInfo().getLongWidth())
10630     Ty = Context.LongTy;
10631   else if (pw == Context.getTargetInfo().getLongLongWidth())
10632     Ty = Context.LongLongTy;
10633   else {
10634     llvm_unreachable("I don't know size of pointer!");
10635   }
10636 
10637   return Owned(new (Context) GNUNullExpr(Ty, TokenLoc));
10638 }
10639 
10640 bool
10641 Sema::ConversionToObjCStringLiteralCheck(QualType DstType, Expr *&Exp) {
10642   if (!getLangOpts().ObjC1)
10643     return false;
10644 
10645   const ObjCObjectPointerType *PT = DstType->getAs<ObjCObjectPointerType>();
10646   if (!PT)
10647     return false;
10648 
10649   if (!PT->isObjCIdType()) {
10650     // Check if the destination is the 'NSString' interface.
10651     const ObjCInterfaceDecl *ID = PT->getInterfaceDecl();
10652     if (!ID || !ID->getIdentifier()->isStr("NSString"))
10653       return false;
10654   }
10655 
10656   // Ignore any parens, implicit casts (should only be
10657   // array-to-pointer decays), and not-so-opaque values.  The last is
10658   // important for making this trigger for property assignments.
10659   Expr *SrcExpr = Exp->IgnoreParenImpCasts();
10660   if (OpaqueValueExpr *OV = dyn_cast<OpaqueValueExpr>(SrcExpr))
10661     if (OV->getSourceExpr())
10662       SrcExpr = OV->getSourceExpr()->IgnoreParenImpCasts();
10663 
10664   StringLiteral *SL = dyn_cast<StringLiteral>(SrcExpr);
10665   if (!SL || !SL->isAscii())
10666     return false;
10667   Diag(SL->getLocStart(), diag::err_missing_atsign_prefix)
10668     << FixItHint::CreateInsertion(SL->getLocStart(), "@");
10669   Exp = BuildObjCStringLiteral(SL->getLocStart(), SL).take();
10670   return true;
10671 }
10672 
10673 bool Sema::DiagnoseAssignmentResult(AssignConvertType ConvTy,
10674                                     SourceLocation Loc,
10675                                     QualType DstType, QualType SrcType,
10676                                     Expr *SrcExpr, AssignmentAction Action,
10677                                     bool *Complained) {
10678   if (Complained)
10679     *Complained = false;
10680 
10681   // Decode the result (notice that AST's are still created for extensions).
10682   bool CheckInferredResultType = false;
10683   bool isInvalid = false;
10684   unsigned DiagKind = 0;
10685   FixItHint Hint;
10686   ConversionFixItGenerator ConvHints;
10687   bool MayHaveConvFixit = false;
10688   bool MayHaveFunctionDiff = false;
10689 
10690   switch (ConvTy) {
10691   case Compatible:
10692       DiagnoseAssignmentEnum(DstType, SrcType, SrcExpr);
10693       return false;
10694 
10695   case PointerToInt:
10696     DiagKind = diag::ext_typecheck_convert_pointer_int;
10697     ConvHints.tryToFixConversion(SrcExpr, SrcType, DstType, *this);
10698     MayHaveConvFixit = true;
10699     break;
10700   case IntToPointer:
10701     DiagKind = diag::ext_typecheck_convert_int_pointer;
10702     ConvHints.tryToFixConversion(SrcExpr, SrcType, DstType, *this);
10703     MayHaveConvFixit = true;
10704     break;
10705   case IncompatiblePointer:
10706       DiagKind =
10707         (Action == AA_Passing_CFAudited ?
10708           diag::err_arc_typecheck_convert_incompatible_pointer :
10709           diag::ext_typecheck_convert_incompatible_pointer);
10710     CheckInferredResultType = DstType->isObjCObjectPointerType() &&
10711       SrcType->isObjCObjectPointerType();
10712     if (Hint.isNull() && !CheckInferredResultType) {
10713       ConvHints.tryToFixConversion(SrcExpr, SrcType, DstType, *this);
10714     }
10715     else if (CheckInferredResultType) {
10716       SrcType = SrcType.getUnqualifiedType();
10717       DstType = DstType.getUnqualifiedType();
10718     }
10719     MayHaveConvFixit = true;
10720     break;
10721   case IncompatiblePointerSign:
10722     DiagKind = diag::ext_typecheck_convert_incompatible_pointer_sign;
10723     break;
10724   case FunctionVoidPointer:
10725     DiagKind = diag::ext_typecheck_convert_pointer_void_func;
10726     break;
10727   case IncompatiblePointerDiscardsQualifiers: {
10728     // Perform array-to-pointer decay if necessary.
10729     if (SrcType->isArrayType()) SrcType = Context.getArrayDecayedType(SrcType);
10730 
10731     Qualifiers lhq = SrcType->getPointeeType().getQualifiers();
10732     Qualifiers rhq = DstType->getPointeeType().getQualifiers();
10733     if (lhq.getAddressSpace() != rhq.getAddressSpace()) {
10734       DiagKind = diag::err_typecheck_incompatible_address_space;
10735       break;
10736 
10737 
10738     } else if (lhq.getObjCLifetime() != rhq.getObjCLifetime()) {
10739       DiagKind = diag::err_typecheck_incompatible_ownership;
10740       break;
10741     }
10742 
10743     llvm_unreachable("unknown error case for discarding qualifiers!");
10744     // fallthrough
10745   }
10746   case CompatiblePointerDiscardsQualifiers:
10747     // If the qualifiers lost were because we were applying the
10748     // (deprecated) C++ conversion from a string literal to a char*
10749     // (or wchar_t*), then there was no error (C++ 4.2p2).  FIXME:
10750     // Ideally, this check would be performed in
10751     // checkPointerTypesForAssignment. However, that would require a
10752     // bit of refactoring (so that the second argument is an
10753     // expression, rather than a type), which should be done as part
10754     // of a larger effort to fix checkPointerTypesForAssignment for
10755     // C++ semantics.
10756     if (getLangOpts().CPlusPlus &&
10757         IsStringLiteralToNonConstPointerConversion(SrcExpr, DstType))
10758       return false;
10759     DiagKind = diag::ext_typecheck_convert_discards_qualifiers;
10760     break;
10761   case IncompatibleNestedPointerQualifiers:
10762     DiagKind = diag::ext_nested_pointer_qualifier_mismatch;
10763     break;
10764   case IntToBlockPointer:
10765     DiagKind = diag::err_int_to_block_pointer;
10766     break;
10767   case IncompatibleBlockPointer:
10768     DiagKind = diag::err_typecheck_convert_incompatible_block_pointer;
10769     break;
10770   case IncompatibleObjCQualifiedId:
10771     // FIXME: Diagnose the problem in ObjCQualifiedIdTypesAreCompatible, since
10772     // it can give a more specific diagnostic.
10773     DiagKind = diag::warn_incompatible_qualified_id;
10774     break;
10775   case IncompatibleVectors:
10776     DiagKind = diag::warn_incompatible_vectors;
10777     break;
10778   case IncompatibleObjCWeakRef:
10779     DiagKind = diag::err_arc_weak_unavailable_assign;
10780     break;
10781   case Incompatible:
10782     DiagKind = diag::err_typecheck_convert_incompatible;
10783     ConvHints.tryToFixConversion(SrcExpr, SrcType, DstType, *this);
10784     MayHaveConvFixit = true;
10785     isInvalid = true;
10786     MayHaveFunctionDiff = true;
10787     break;
10788   }
10789 
10790   QualType FirstType, SecondType;
10791   switch (Action) {
10792   case AA_Assigning:
10793   case AA_Initializing:
10794     // The destination type comes first.
10795     FirstType = DstType;
10796     SecondType = SrcType;
10797     break;
10798 
10799   case AA_Returning:
10800   case AA_Passing:
10801   case AA_Passing_CFAudited:
10802   case AA_Converting:
10803   case AA_Sending:
10804   case AA_Casting:
10805     // The source type comes first.
10806     FirstType = SrcType;
10807     SecondType = DstType;
10808     break;
10809   }
10810 
10811   PartialDiagnostic FDiag = PDiag(DiagKind);
10812   if (Action == AA_Passing_CFAudited)
10813     FDiag << FirstType << SecondType << SrcExpr->getSourceRange();
10814   else
10815     FDiag << FirstType << SecondType << Action << SrcExpr->getSourceRange();
10816 
10817   // If we can fix the conversion, suggest the FixIts.
10818   assert(ConvHints.isNull() || Hint.isNull());
10819   if (!ConvHints.isNull()) {
10820     for (std::vector<FixItHint>::iterator HI = ConvHints.Hints.begin(),
10821          HE = ConvHints.Hints.end(); HI != HE; ++HI)
10822       FDiag << *HI;
10823   } else {
10824     FDiag << Hint;
10825   }
10826   if (MayHaveConvFixit) { FDiag << (unsigned) (ConvHints.Kind); }
10827 
10828   if (MayHaveFunctionDiff)
10829     HandleFunctionTypeMismatch(FDiag, SecondType, FirstType);
10830 
10831   Diag(Loc, FDiag);
10832 
10833   if (SecondType == Context.OverloadTy)
10834     NoteAllOverloadCandidates(OverloadExpr::find(SrcExpr).Expression,
10835                               FirstType);
10836 
10837   if (CheckInferredResultType)
10838     EmitRelatedResultTypeNote(SrcExpr);
10839 
10840   if (Action == AA_Returning && ConvTy == IncompatiblePointer)
10841     EmitRelatedResultTypeNoteForReturn(DstType);
10842 
10843   if (Complained)
10844     *Complained = true;
10845   return isInvalid;
10846 }
10847 
10848 ExprResult Sema::VerifyIntegerConstantExpression(Expr *E,
10849                                                  llvm::APSInt *Result) {
10850   class SimpleICEDiagnoser : public VerifyICEDiagnoser {
10851   public:
10852     virtual void diagnoseNotICE(Sema &S, SourceLocation Loc, SourceRange SR) {
10853       S.Diag(Loc, diag::err_expr_not_ice) << S.LangOpts.CPlusPlus << SR;
10854     }
10855   } Diagnoser;
10856 
10857   return VerifyIntegerConstantExpression(E, Result, Diagnoser);
10858 }
10859 
10860 ExprResult Sema::VerifyIntegerConstantExpression(Expr *E,
10861                                                  llvm::APSInt *Result,
10862                                                  unsigned DiagID,
10863                                                  bool AllowFold) {
10864   class IDDiagnoser : public VerifyICEDiagnoser {
10865     unsigned DiagID;
10866 
10867   public:
10868     IDDiagnoser(unsigned DiagID)
10869       : VerifyICEDiagnoser(DiagID == 0), DiagID(DiagID) { }
10870 
10871     virtual void diagnoseNotICE(Sema &S, SourceLocation Loc, SourceRange SR) {
10872       S.Diag(Loc, DiagID) << SR;
10873     }
10874   } Diagnoser(DiagID);
10875 
10876   return VerifyIntegerConstantExpression(E, Result, Diagnoser, AllowFold);
10877 }
10878 
10879 void Sema::VerifyICEDiagnoser::diagnoseFold(Sema &S, SourceLocation Loc,
10880                                             SourceRange SR) {
10881   S.Diag(Loc, diag::ext_expr_not_ice) << SR << S.LangOpts.CPlusPlus;
10882 }
10883 
10884 ExprResult
10885 Sema::VerifyIntegerConstantExpression(Expr *E, llvm::APSInt *Result,
10886                                       VerifyICEDiagnoser &Diagnoser,
10887                                       bool AllowFold) {
10888   SourceLocation DiagLoc = E->getLocStart();
10889 
10890   if (getLangOpts().CPlusPlus11) {
10891     // C++11 [expr.const]p5:
10892     //   If an expression of literal class type is used in a context where an
10893     //   integral constant expression is required, then that class type shall
10894     //   have a single non-explicit conversion function to an integral or
10895     //   unscoped enumeration type
10896     ExprResult Converted;
10897     class CXX11ConvertDiagnoser : public ICEConvertDiagnoser {
10898     public:
10899       CXX11ConvertDiagnoser(bool Silent)
10900           : ICEConvertDiagnoser(/*AllowScopedEnumerations*/false,
10901                                 Silent, true) {}
10902 
10903       virtual SemaDiagnosticBuilder diagnoseNotInt(Sema &S, SourceLocation Loc,
10904                                                    QualType T) {
10905         return S.Diag(Loc, diag::err_ice_not_integral) << T;
10906       }
10907 
10908       virtual SemaDiagnosticBuilder diagnoseIncomplete(
10909           Sema &S, SourceLocation Loc, QualType T) {
10910         return S.Diag(Loc, diag::err_ice_incomplete_type) << T;
10911       }
10912 
10913       virtual SemaDiagnosticBuilder diagnoseExplicitConv(
10914           Sema &S, SourceLocation Loc, QualType T, QualType ConvTy) {
10915         return S.Diag(Loc, diag::err_ice_explicit_conversion) << T << ConvTy;
10916       }
10917 
10918       virtual SemaDiagnosticBuilder noteExplicitConv(
10919           Sema &S, CXXConversionDecl *Conv, QualType ConvTy) {
10920         return S.Diag(Conv->getLocation(), diag::note_ice_conversion_here)
10921                  << ConvTy->isEnumeralType() << ConvTy;
10922       }
10923 
10924       virtual SemaDiagnosticBuilder diagnoseAmbiguous(
10925           Sema &S, SourceLocation Loc, QualType T) {
10926         return S.Diag(Loc, diag::err_ice_ambiguous_conversion) << T;
10927       }
10928 
10929       virtual SemaDiagnosticBuilder noteAmbiguous(
10930           Sema &S, CXXConversionDecl *Conv, QualType ConvTy) {
10931         return S.Diag(Conv->getLocation(), diag::note_ice_conversion_here)
10932                  << ConvTy->isEnumeralType() << ConvTy;
10933       }
10934 
10935       virtual SemaDiagnosticBuilder diagnoseConversion(
10936           Sema &S, SourceLocation Loc, QualType T, QualType ConvTy) {
10937         llvm_unreachable("conversion functions are permitted");
10938       }
10939     } ConvertDiagnoser(Diagnoser.Suppress);
10940 
10941     Converted = PerformContextualImplicitConversion(DiagLoc, E,
10942                                                     ConvertDiagnoser);
10943     if (Converted.isInvalid())
10944       return Converted;
10945     E = Converted.take();
10946     if (!E->getType()->isIntegralOrUnscopedEnumerationType())
10947       return ExprError();
10948   } else if (!E->getType()->isIntegralOrUnscopedEnumerationType()) {
10949     // An ICE must be of integral or unscoped enumeration type.
10950     if (!Diagnoser.Suppress)
10951       Diagnoser.diagnoseNotICE(*this, DiagLoc, E->getSourceRange());
10952     return ExprError();
10953   }
10954 
10955   // Circumvent ICE checking in C++11 to avoid evaluating the expression twice
10956   // in the non-ICE case.
10957   if (!getLangOpts().CPlusPlus11 && E->isIntegerConstantExpr(Context)) {
10958     if (Result)
10959       *Result = E->EvaluateKnownConstInt(Context);
10960     return Owned(E);
10961   }
10962 
10963   Expr::EvalResult EvalResult;
10964   SmallVector<PartialDiagnosticAt, 8> Notes;
10965   EvalResult.Diag = &Notes;
10966 
10967   // Try to evaluate the expression, and produce diagnostics explaining why it's
10968   // not a constant expression as a side-effect.
10969   bool Folded = E->EvaluateAsRValue(EvalResult, Context) &&
10970                 EvalResult.Val.isInt() && !EvalResult.HasSideEffects;
10971 
10972   // In C++11, we can rely on diagnostics being produced for any expression
10973   // which is not a constant expression. If no diagnostics were produced, then
10974   // this is a constant expression.
10975   if (Folded && getLangOpts().CPlusPlus11 && Notes.empty()) {
10976     if (Result)
10977       *Result = EvalResult.Val.getInt();
10978     return Owned(E);
10979   }
10980 
10981   // If our only note is the usual "invalid subexpression" note, just point
10982   // the caret at its location rather than producing an essentially
10983   // redundant note.
10984   if (Notes.size() == 1 && Notes[0].second.getDiagID() ==
10985         diag::note_invalid_subexpr_in_const_expr) {
10986     DiagLoc = Notes[0].first;
10987     Notes.clear();
10988   }
10989 
10990   if (!Folded || !AllowFold) {
10991     if (!Diagnoser.Suppress) {
10992       Diagnoser.diagnoseNotICE(*this, DiagLoc, E->getSourceRange());
10993       for (unsigned I = 0, N = Notes.size(); I != N; ++I)
10994         Diag(Notes[I].first, Notes[I].second);
10995     }
10996 
10997     return ExprError();
10998   }
10999 
11000   Diagnoser.diagnoseFold(*this, DiagLoc, E->getSourceRange());
11001   for (unsigned I = 0, N = Notes.size(); I != N; ++I)
11002     Diag(Notes[I].first, Notes[I].second);
11003 
11004   if (Result)
11005     *Result = EvalResult.Val.getInt();
11006   return Owned(E);
11007 }
11008 
11009 namespace {
11010   // Handle the case where we conclude a expression which we speculatively
11011   // considered to be unevaluated is actually evaluated.
11012   class TransformToPE : public TreeTransform<TransformToPE> {
11013     typedef TreeTransform<TransformToPE> BaseTransform;
11014 
11015   public:
11016     TransformToPE(Sema &SemaRef) : BaseTransform(SemaRef) { }
11017 
11018     // Make sure we redo semantic analysis
11019     bool AlwaysRebuild() { return true; }
11020 
11021     // Make sure we handle LabelStmts correctly.
11022     // FIXME: This does the right thing, but maybe we need a more general
11023     // fix to TreeTransform?
11024     StmtResult TransformLabelStmt(LabelStmt *S) {
11025       S->getDecl()->setStmt(0);
11026       return BaseTransform::TransformLabelStmt(S);
11027     }
11028 
11029     // We need to special-case DeclRefExprs referring to FieldDecls which
11030     // are not part of a member pointer formation; normal TreeTransforming
11031     // doesn't catch this case because of the way we represent them in the AST.
11032     // FIXME: This is a bit ugly; is it really the best way to handle this
11033     // case?
11034     //
11035     // Error on DeclRefExprs referring to FieldDecls.
11036     ExprResult TransformDeclRefExpr(DeclRefExpr *E) {
11037       if (isa<FieldDecl>(E->getDecl()) &&
11038           !SemaRef.isUnevaluatedContext())
11039         return SemaRef.Diag(E->getLocation(),
11040                             diag::err_invalid_non_static_member_use)
11041             << E->getDecl() << E->getSourceRange();
11042 
11043       return BaseTransform::TransformDeclRefExpr(E);
11044     }
11045 
11046     // Exception: filter out member pointer formation
11047     ExprResult TransformUnaryOperator(UnaryOperator *E) {
11048       if (E->getOpcode() == UO_AddrOf && E->getType()->isMemberPointerType())
11049         return E;
11050 
11051       return BaseTransform::TransformUnaryOperator(E);
11052     }
11053 
11054     ExprResult TransformLambdaExpr(LambdaExpr *E) {
11055       // Lambdas never need to be transformed.
11056       return E;
11057     }
11058   };
11059 }
11060 
11061 ExprResult Sema::TransformToPotentiallyEvaluated(Expr *E) {
11062   assert(isUnevaluatedContext() &&
11063          "Should only transform unevaluated expressions");
11064   ExprEvalContexts.back().Context =
11065       ExprEvalContexts[ExprEvalContexts.size()-2].Context;
11066   if (isUnevaluatedContext())
11067     return E;
11068   return TransformToPE(*this).TransformExpr(E);
11069 }
11070 
11071 void
11072 Sema::PushExpressionEvaluationContext(ExpressionEvaluationContext NewContext,
11073                                       Decl *LambdaContextDecl,
11074                                       bool IsDecltype) {
11075   ExprEvalContexts.push_back(
11076              ExpressionEvaluationContextRecord(NewContext,
11077                                                ExprCleanupObjects.size(),
11078                                                ExprNeedsCleanups,
11079                                                LambdaContextDecl,
11080                                                IsDecltype));
11081   ExprNeedsCleanups = false;
11082   if (!MaybeODRUseExprs.empty())
11083     std::swap(MaybeODRUseExprs, ExprEvalContexts.back().SavedMaybeODRUseExprs);
11084 }
11085 
11086 void
11087 Sema::PushExpressionEvaluationContext(ExpressionEvaluationContext NewContext,
11088                                       ReuseLambdaContextDecl_t,
11089                                       bool IsDecltype) {
11090   Decl *ClosureContextDecl = ExprEvalContexts.back().ManglingContextDecl;
11091   PushExpressionEvaluationContext(NewContext, ClosureContextDecl, IsDecltype);
11092 }
11093 
11094 void Sema::PopExpressionEvaluationContext() {
11095   ExpressionEvaluationContextRecord& Rec = ExprEvalContexts.back();
11096 
11097   if (!Rec.Lambdas.empty()) {
11098     if (Rec.isUnevaluated() || Rec.Context == ConstantEvaluated) {
11099       unsigned D;
11100       if (Rec.isUnevaluated()) {
11101         // C++11 [expr.prim.lambda]p2:
11102         //   A lambda-expression shall not appear in an unevaluated operand
11103         //   (Clause 5).
11104         D = diag::err_lambda_unevaluated_operand;
11105       } else {
11106         // C++1y [expr.const]p2:
11107         //   A conditional-expression e is a core constant expression unless the
11108         //   evaluation of e, following the rules of the abstract machine, would
11109         //   evaluate [...] a lambda-expression.
11110         D = diag::err_lambda_in_constant_expression;
11111       }
11112       for (unsigned I = 0, N = Rec.Lambdas.size(); I != N; ++I)
11113         Diag(Rec.Lambdas[I]->getLocStart(), D);
11114     } else {
11115       // Mark the capture expressions odr-used. This was deferred
11116       // during lambda expression creation.
11117       for (unsigned I = 0, N = Rec.Lambdas.size(); I != N; ++I) {
11118         LambdaExpr *Lambda = Rec.Lambdas[I];
11119         for (LambdaExpr::capture_init_iterator
11120                   C = Lambda->capture_init_begin(),
11121                CEnd = Lambda->capture_init_end();
11122              C != CEnd; ++C) {
11123           MarkDeclarationsReferencedInExpr(*C);
11124         }
11125       }
11126     }
11127   }
11128 
11129   // When are coming out of an unevaluated context, clear out any
11130   // temporaries that we may have created as part of the evaluation of
11131   // the expression in that context: they aren't relevant because they
11132   // will never be constructed.
11133   if (Rec.isUnevaluated() || Rec.Context == ConstantEvaluated) {
11134     ExprCleanupObjects.erase(ExprCleanupObjects.begin() + Rec.NumCleanupObjects,
11135                              ExprCleanupObjects.end());
11136     ExprNeedsCleanups = Rec.ParentNeedsCleanups;
11137     CleanupVarDeclMarking();
11138     std::swap(MaybeODRUseExprs, Rec.SavedMaybeODRUseExprs);
11139   // Otherwise, merge the contexts together.
11140   } else {
11141     ExprNeedsCleanups |= Rec.ParentNeedsCleanups;
11142     MaybeODRUseExprs.insert(Rec.SavedMaybeODRUseExprs.begin(),
11143                             Rec.SavedMaybeODRUseExprs.end());
11144   }
11145 
11146   // Pop the current expression evaluation context off the stack.
11147   ExprEvalContexts.pop_back();
11148 }
11149 
11150 void Sema::DiscardCleanupsInEvaluationContext() {
11151   ExprCleanupObjects.erase(
11152          ExprCleanupObjects.begin() + ExprEvalContexts.back().NumCleanupObjects,
11153          ExprCleanupObjects.end());
11154   ExprNeedsCleanups = false;
11155   MaybeODRUseExprs.clear();
11156 }
11157 
11158 ExprResult Sema::HandleExprEvaluationContextForTypeof(Expr *E) {
11159   if (!E->getType()->isVariablyModifiedType())
11160     return E;
11161   return TransformToPotentiallyEvaluated(E);
11162 }
11163 
11164 static bool IsPotentiallyEvaluatedContext(Sema &SemaRef) {
11165   // Do not mark anything as "used" within a dependent context; wait for
11166   // an instantiation.
11167   if (SemaRef.CurContext->isDependentContext())
11168     return false;
11169 
11170   switch (SemaRef.ExprEvalContexts.back().Context) {
11171     case Sema::Unevaluated:
11172     case Sema::UnevaluatedAbstract:
11173       // We are in an expression that is not potentially evaluated; do nothing.
11174       // (Depending on how you read the standard, we actually do need to do
11175       // something here for null pointer constants, but the standard's
11176       // definition of a null pointer constant is completely crazy.)
11177       return false;
11178 
11179     case Sema::ConstantEvaluated:
11180     case Sema::PotentiallyEvaluated:
11181       // We are in a potentially evaluated expression (or a constant-expression
11182       // in C++03); we need to do implicit template instantiation, implicitly
11183       // define class members, and mark most declarations as used.
11184       return true;
11185 
11186     case Sema::PotentiallyEvaluatedIfUsed:
11187       // Referenced declarations will only be used if the construct in the
11188       // containing expression is used.
11189       return false;
11190   }
11191   llvm_unreachable("Invalid context");
11192 }
11193 
11194 /// \brief Mark a function referenced, and check whether it is odr-used
11195 /// (C++ [basic.def.odr]p2, C99 6.9p3)
11196 void Sema::MarkFunctionReferenced(SourceLocation Loc, FunctionDecl *Func) {
11197   assert(Func && "No function?");
11198 
11199   Func->setReferenced();
11200 
11201   // C++11 [basic.def.odr]p3:
11202   //   A function whose name appears as a potentially-evaluated expression is
11203   //   odr-used if it is the unique lookup result or the selected member of a
11204   //   set of overloaded functions [...].
11205   //
11206   // We (incorrectly) mark overload resolution as an unevaluated context, so we
11207   // can just check that here. Skip the rest of this function if we've already
11208   // marked the function as used.
11209   if (Func->isUsed(false) || !IsPotentiallyEvaluatedContext(*this)) {
11210     // C++11 [temp.inst]p3:
11211     //   Unless a function template specialization has been explicitly
11212     //   instantiated or explicitly specialized, the function template
11213     //   specialization is implicitly instantiated when the specialization is
11214     //   referenced in a context that requires a function definition to exist.
11215     //
11216     // We consider constexpr function templates to be referenced in a context
11217     // that requires a definition to exist whenever they are referenced.
11218     //
11219     // FIXME: This instantiates constexpr functions too frequently. If this is
11220     // really an unevaluated context (and we're not just in the definition of a
11221     // function template or overload resolution or other cases which we
11222     // incorrectly consider to be unevaluated contexts), and we're not in a
11223     // subexpression which we actually need to evaluate (for instance, a
11224     // template argument, array bound or an expression in a braced-init-list),
11225     // we are not permitted to instantiate this constexpr function definition.
11226     //
11227     // FIXME: This also implicitly defines special members too frequently. They
11228     // are only supposed to be implicitly defined if they are odr-used, but they
11229     // are not odr-used from constant expressions in unevaluated contexts.
11230     // However, they cannot be referenced if they are deleted, and they are
11231     // deleted whenever the implicit definition of the special member would
11232     // fail.
11233     if (!Func->isConstexpr() || Func->getBody())
11234       return;
11235     CXXMethodDecl *MD = dyn_cast<CXXMethodDecl>(Func);
11236     if (!Func->isImplicitlyInstantiable() && (!MD || MD->isUserProvided()))
11237       return;
11238   }
11239 
11240   // Note that this declaration has been used.
11241   if (CXXConstructorDecl *Constructor = dyn_cast<CXXConstructorDecl>(Func)) {
11242     Constructor = cast<CXXConstructorDecl>(Constructor->getFirstDecl());
11243     if (Constructor->isDefaulted() && !Constructor->isDeleted()) {
11244       if (Constructor->isDefaultConstructor()) {
11245         if (Constructor->isTrivial())
11246           return;
11247         DefineImplicitDefaultConstructor(Loc, Constructor);
11248       } else if (Constructor->isCopyConstructor()) {
11249         DefineImplicitCopyConstructor(Loc, Constructor);
11250       } else if (Constructor->isMoveConstructor()) {
11251         DefineImplicitMoveConstructor(Loc, Constructor);
11252       }
11253     } else if (Constructor->getInheritedConstructor()) {
11254       DefineInheritingConstructor(Loc, Constructor);
11255     }
11256 
11257     MarkVTableUsed(Loc, Constructor->getParent());
11258   } else if (CXXDestructorDecl *Destructor =
11259                  dyn_cast<CXXDestructorDecl>(Func)) {
11260     Destructor = cast<CXXDestructorDecl>(Destructor->getFirstDecl());
11261     if (Destructor->isDefaulted() && !Destructor->isDeleted())
11262       DefineImplicitDestructor(Loc, Destructor);
11263     if (Destructor->isVirtual())
11264       MarkVTableUsed(Loc, Destructor->getParent());
11265   } else if (CXXMethodDecl *MethodDecl = dyn_cast<CXXMethodDecl>(Func)) {
11266     if (MethodDecl->isOverloadedOperator() &&
11267         MethodDecl->getOverloadedOperator() == OO_Equal) {
11268       MethodDecl = cast<CXXMethodDecl>(MethodDecl->getFirstDecl());
11269       if (MethodDecl->isDefaulted() && !MethodDecl->isDeleted()) {
11270         if (MethodDecl->isCopyAssignmentOperator())
11271           DefineImplicitCopyAssignment(Loc, MethodDecl);
11272         else
11273           DefineImplicitMoveAssignment(Loc, MethodDecl);
11274       }
11275     } else if (isa<CXXConversionDecl>(MethodDecl) &&
11276                MethodDecl->getParent()->isLambda()) {
11277       CXXConversionDecl *Conversion =
11278           cast<CXXConversionDecl>(MethodDecl->getFirstDecl());
11279       if (Conversion->isLambdaToBlockPointerConversion())
11280         DefineImplicitLambdaToBlockPointerConversion(Loc, Conversion);
11281       else
11282         DefineImplicitLambdaToFunctionPointerConversion(Loc, Conversion);
11283     } else if (MethodDecl->isVirtual())
11284       MarkVTableUsed(Loc, MethodDecl->getParent());
11285   }
11286 
11287   // Recursive functions should be marked when used from another function.
11288   // FIXME: Is this really right?
11289   if (CurContext == Func) return;
11290 
11291   // Resolve the exception specification for any function which is
11292   // used: CodeGen will need it.
11293   const FunctionProtoType *FPT = Func->getType()->getAs<FunctionProtoType>();
11294   if (FPT && isUnresolvedExceptionSpec(FPT->getExceptionSpecType()))
11295     ResolveExceptionSpec(Loc, FPT);
11296 
11297   // Implicit instantiation of function templates and member functions of
11298   // class templates.
11299   if (Func->isImplicitlyInstantiable()) {
11300     bool AlreadyInstantiated = false;
11301     SourceLocation PointOfInstantiation = Loc;
11302     if (FunctionTemplateSpecializationInfo *SpecInfo
11303                               = Func->getTemplateSpecializationInfo()) {
11304       if (SpecInfo->getPointOfInstantiation().isInvalid())
11305         SpecInfo->setPointOfInstantiation(Loc);
11306       else if (SpecInfo->getTemplateSpecializationKind()
11307                  == TSK_ImplicitInstantiation) {
11308         AlreadyInstantiated = true;
11309         PointOfInstantiation = SpecInfo->getPointOfInstantiation();
11310       }
11311     } else if (MemberSpecializationInfo *MSInfo
11312                                 = Func->getMemberSpecializationInfo()) {
11313       if (MSInfo->getPointOfInstantiation().isInvalid())
11314         MSInfo->setPointOfInstantiation(Loc);
11315       else if (MSInfo->getTemplateSpecializationKind()
11316                  == TSK_ImplicitInstantiation) {
11317         AlreadyInstantiated = true;
11318         PointOfInstantiation = MSInfo->getPointOfInstantiation();
11319       }
11320     }
11321 
11322     if (!AlreadyInstantiated || Func->isConstexpr()) {
11323       if (isa<CXXRecordDecl>(Func->getDeclContext()) &&
11324           cast<CXXRecordDecl>(Func->getDeclContext())->isLocalClass() &&
11325           ActiveTemplateInstantiations.size())
11326         PendingLocalImplicitInstantiations.push_back(
11327             std::make_pair(Func, PointOfInstantiation));
11328       else if (Func->isConstexpr())
11329         // Do not defer instantiations of constexpr functions, to avoid the
11330         // expression evaluator needing to call back into Sema if it sees a
11331         // call to such a function.
11332         InstantiateFunctionDefinition(PointOfInstantiation, Func);
11333       else {
11334         PendingInstantiations.push_back(std::make_pair(Func,
11335                                                        PointOfInstantiation));
11336         // Notify the consumer that a function was implicitly instantiated.
11337         Consumer.HandleCXXImplicitFunctionInstantiation(Func);
11338       }
11339     }
11340   } else {
11341     // Walk redefinitions, as some of them may be instantiable.
11342     for (FunctionDecl::redecl_iterator i(Func->redecls_begin()),
11343          e(Func->redecls_end()); i != e; ++i) {
11344       if (!i->isUsed(false) && i->isImplicitlyInstantiable())
11345         MarkFunctionReferenced(Loc, *i);
11346     }
11347   }
11348 
11349   // Keep track of used but undefined functions.
11350   if (!Func->isDefined()) {
11351     if (mightHaveNonExternalLinkage(Func))
11352       UndefinedButUsed.insert(std::make_pair(Func->getCanonicalDecl(), Loc));
11353     else if (Func->getMostRecentDecl()->isInlined() &&
11354              (LangOpts.CPlusPlus || !LangOpts.GNUInline) &&
11355              !Func->getMostRecentDecl()->hasAttr<GNUInlineAttr>())
11356       UndefinedButUsed.insert(std::make_pair(Func->getCanonicalDecl(), Loc));
11357   }
11358 
11359   // Normally the most current decl is marked used while processing the use and
11360   // any subsequent decls are marked used by decl merging. This fails with
11361   // template instantiation since marking can happen at the end of the file
11362   // and, because of the two phase lookup, this function is called with at
11363   // decl in the middle of a decl chain. We loop to maintain the invariant
11364   // that once a decl is used, all decls after it are also used.
11365   for (FunctionDecl *F = Func->getMostRecentDecl();; F = F->getPreviousDecl()) {
11366     F->markUsed(Context);
11367     if (F == Func)
11368       break;
11369   }
11370 }
11371 
11372 static void
11373 diagnoseUncapturableValueReference(Sema &S, SourceLocation loc,
11374                                    VarDecl *var, DeclContext *DC) {
11375   DeclContext *VarDC = var->getDeclContext();
11376 
11377   //  If the parameter still belongs to the translation unit, then
11378   //  we're actually just using one parameter in the declaration of
11379   //  the next.
11380   if (isa<ParmVarDecl>(var) &&
11381       isa<TranslationUnitDecl>(VarDC))
11382     return;
11383 
11384   // For C code, don't diagnose about capture if we're not actually in code
11385   // right now; it's impossible to write a non-constant expression outside of
11386   // function context, so we'll get other (more useful) diagnostics later.
11387   //
11388   // For C++, things get a bit more nasty... it would be nice to suppress this
11389   // diagnostic for certain cases like using a local variable in an array bound
11390   // for a member of a local class, but the correct predicate is not obvious.
11391   if (!S.getLangOpts().CPlusPlus && !S.CurContext->isFunctionOrMethod())
11392     return;
11393 
11394   if (isa<CXXMethodDecl>(VarDC) &&
11395       cast<CXXRecordDecl>(VarDC->getParent())->isLambda()) {
11396     S.Diag(loc, diag::err_reference_to_local_var_in_enclosing_lambda)
11397       << var->getIdentifier();
11398   } else if (FunctionDecl *fn = dyn_cast<FunctionDecl>(VarDC)) {
11399     S.Diag(loc, diag::err_reference_to_local_var_in_enclosing_function)
11400       << var->getIdentifier() << fn->getDeclName();
11401   } else if (isa<BlockDecl>(VarDC)) {
11402     S.Diag(loc, diag::err_reference_to_local_var_in_enclosing_block)
11403       << var->getIdentifier();
11404   } else {
11405     // FIXME: Is there any other context where a local variable can be
11406     // declared?
11407     S.Diag(loc, diag::err_reference_to_local_var_in_enclosing_context)
11408       << var->getIdentifier();
11409   }
11410 
11411   S.Diag(var->getLocation(), diag::note_local_variable_declared_here)
11412     << var->getIdentifier();
11413 
11414   // FIXME: Add additional diagnostic info about class etc. which prevents
11415   // capture.
11416 }
11417 
11418 
11419 static bool isVariableAlreadyCapturedInScopeInfo(CapturingScopeInfo *CSI, VarDecl *Var,
11420                                       bool &SubCapturesAreNested,
11421                                       QualType &CaptureType,
11422                                       QualType &DeclRefType) {
11423    // Check whether we've already captured it.
11424   if (CSI->CaptureMap.count(Var)) {
11425     // If we found a capture, any subcaptures are nested.
11426     SubCapturesAreNested = true;
11427 
11428     // Retrieve the capture type for this variable.
11429     CaptureType = CSI->getCapture(Var).getCaptureType();
11430 
11431     // Compute the type of an expression that refers to this variable.
11432     DeclRefType = CaptureType.getNonReferenceType();
11433 
11434     const CapturingScopeInfo::Capture &Cap = CSI->getCapture(Var);
11435     if (Cap.isCopyCapture() &&
11436         !(isa<LambdaScopeInfo>(CSI) && cast<LambdaScopeInfo>(CSI)->Mutable))
11437       DeclRefType.addConst();
11438     return true;
11439   }
11440   return false;
11441 }
11442 
11443 // Only block literals, captured statements, and lambda expressions can
11444 // capture; other scopes don't work.
11445 static DeclContext *getParentOfCapturingContextOrNull(DeclContext *DC, VarDecl *Var,
11446                                  SourceLocation Loc,
11447                                  const bool Diagnose, Sema &S) {
11448   if (isa<BlockDecl>(DC) || isa<CapturedDecl>(DC) || isLambdaCallOperator(DC))
11449     return getLambdaAwareParentOfDeclContext(DC);
11450   else {
11451     if (Diagnose)
11452        diagnoseUncapturableValueReference(S, Loc, Var, DC);
11453   }
11454   return 0;
11455 }
11456 
11457 // Certain capturing entities (lambdas, blocks etc.) are not allowed to capture
11458 // certain types of variables (unnamed, variably modified types etc.)
11459 // so check for eligibility.
11460 static bool isVariableCapturable(CapturingScopeInfo *CSI, VarDecl *Var,
11461                                  SourceLocation Loc,
11462                                  const bool Diagnose, Sema &S) {
11463 
11464   bool IsBlock = isa<BlockScopeInfo>(CSI);
11465   bool IsLambda = isa<LambdaScopeInfo>(CSI);
11466 
11467   // Lambdas are not allowed to capture unnamed variables
11468   // (e.g. anonymous unions).
11469   // FIXME: The C++11 rule don't actually state this explicitly, but I'm
11470   // assuming that's the intent.
11471   if (IsLambda && !Var->getDeclName()) {
11472     if (Diagnose) {
11473       S.Diag(Loc, diag::err_lambda_capture_anonymous_var);
11474       S.Diag(Var->getLocation(), diag::note_declared_at);
11475     }
11476     return false;
11477   }
11478 
11479   // Prohibit variably-modified types; they're difficult to deal with.
11480   if (Var->getType()->isVariablyModifiedType()) {
11481     if (Diagnose) {
11482       if (IsBlock)
11483         S.Diag(Loc, diag::err_ref_vm_type);
11484       else
11485         S.Diag(Loc, diag::err_lambda_capture_vm_type) << Var->getDeclName();
11486       S.Diag(Var->getLocation(), diag::note_previous_decl)
11487         << Var->getDeclName();
11488     }
11489     return false;
11490   }
11491   // Prohibit structs with flexible array members too.
11492   // We cannot capture what is in the tail end of the struct.
11493   if (const RecordType *VTTy = Var->getType()->getAs<RecordType>()) {
11494     if (VTTy->getDecl()->hasFlexibleArrayMember()) {
11495       if (Diagnose) {
11496         if (IsBlock)
11497           S.Diag(Loc, diag::err_ref_flexarray_type);
11498         else
11499           S.Diag(Loc, diag::err_lambda_capture_flexarray_type)
11500             << Var->getDeclName();
11501         S.Diag(Var->getLocation(), diag::note_previous_decl)
11502           << Var->getDeclName();
11503       }
11504       return false;
11505     }
11506   }
11507   const bool HasBlocksAttr = Var->hasAttr<BlocksAttr>();
11508   // Lambdas and captured statements are not allowed to capture __block
11509   // variables; they don't support the expected semantics.
11510   if (HasBlocksAttr && (IsLambda || isa<CapturedRegionScopeInfo>(CSI))) {
11511     if (Diagnose) {
11512       S.Diag(Loc, diag::err_capture_block_variable)
11513         << Var->getDeclName() << !IsLambda;
11514       S.Diag(Var->getLocation(), diag::note_previous_decl)
11515         << Var->getDeclName();
11516     }
11517     return false;
11518   }
11519 
11520   return true;
11521 }
11522 
11523 // Returns true if the capture by block was successful.
11524 static bool captureInBlock(BlockScopeInfo *BSI, VarDecl *Var,
11525                                  SourceLocation Loc,
11526                                  const bool BuildAndDiagnose,
11527                                  QualType &CaptureType,
11528                                  QualType &DeclRefType,
11529                                  const bool Nested,
11530                                  Sema &S) {
11531   Expr *CopyExpr = 0;
11532   bool ByRef = false;
11533 
11534   // Blocks are not allowed to capture arrays.
11535   if (CaptureType->isArrayType()) {
11536     if (BuildAndDiagnose) {
11537       S.Diag(Loc, diag::err_ref_array_type);
11538       S.Diag(Var->getLocation(), diag::note_previous_decl)
11539       << Var->getDeclName();
11540     }
11541     return false;
11542   }
11543 
11544   // Forbid the block-capture of autoreleasing variables.
11545   if (CaptureType.getObjCLifetime() == Qualifiers::OCL_Autoreleasing) {
11546     if (BuildAndDiagnose) {
11547       S.Diag(Loc, diag::err_arc_autoreleasing_capture)
11548         << /*block*/ 0;
11549       S.Diag(Var->getLocation(), diag::note_previous_decl)
11550         << Var->getDeclName();
11551     }
11552     return false;
11553   }
11554   const bool HasBlocksAttr = Var->hasAttr<BlocksAttr>();
11555   if (HasBlocksAttr || CaptureType->isReferenceType()) {
11556     // Block capture by reference does not change the capture or
11557     // declaration reference types.
11558     ByRef = true;
11559   } else {
11560     // Block capture by copy introduces 'const'.
11561     CaptureType = CaptureType.getNonReferenceType().withConst();
11562     DeclRefType = CaptureType;
11563 
11564     if (S.getLangOpts().CPlusPlus && BuildAndDiagnose) {
11565       if (const RecordType *Record = DeclRefType->getAs<RecordType>()) {
11566         // The capture logic needs the destructor, so make sure we mark it.
11567         // Usually this is unnecessary because most local variables have
11568         // their destructors marked at declaration time, but parameters are
11569         // an exception because it's technically only the call site that
11570         // actually requires the destructor.
11571         if (isa<ParmVarDecl>(Var))
11572           S.FinalizeVarWithDestructor(Var, Record);
11573 
11574         // Enter a new evaluation context to insulate the copy
11575         // full-expression.
11576         EnterExpressionEvaluationContext scope(S, S.PotentiallyEvaluated);
11577 
11578         // According to the blocks spec, the capture of a variable from
11579         // the stack requires a const copy constructor.  This is not true
11580         // of the copy/move done to move a __block variable to the heap.
11581         Expr *DeclRef = new (S.Context) DeclRefExpr(Var, Nested,
11582                                                   DeclRefType.withConst(),
11583                                                   VK_LValue, Loc);
11584 
11585         ExprResult Result
11586           = S.PerformCopyInitialization(
11587               InitializedEntity::InitializeBlock(Var->getLocation(),
11588                                                   CaptureType, false),
11589               Loc, S.Owned(DeclRef));
11590 
11591         // Build a full-expression copy expression if initialization
11592         // succeeded and used a non-trivial constructor.  Recover from
11593         // errors by pretending that the copy isn't necessary.
11594         if (!Result.isInvalid() &&
11595             !cast<CXXConstructExpr>(Result.get())->getConstructor()
11596                 ->isTrivial()) {
11597           Result = S.MaybeCreateExprWithCleanups(Result);
11598           CopyExpr = Result.take();
11599         }
11600       }
11601     }
11602   }
11603 
11604   // Actually capture the variable.
11605   if (BuildAndDiagnose)
11606     BSI->addCapture(Var, HasBlocksAttr, ByRef, Nested, Loc,
11607                     SourceLocation(), CaptureType, CopyExpr);
11608 
11609   return true;
11610 
11611 }
11612 
11613 
11614 /// \brief Capture the given variable in the captured region.
11615 static bool captureInCapturedRegion(CapturedRegionScopeInfo *RSI,
11616                                     VarDecl *Var,
11617                                     SourceLocation Loc,
11618                                     const bool BuildAndDiagnose,
11619                                     QualType &CaptureType,
11620                                     QualType &DeclRefType,
11621                                     const bool RefersToEnclosingLocal,
11622                                     Sema &S) {
11623 
11624   // By default, capture variables by reference.
11625   bool ByRef = true;
11626   // Using an LValue reference type is consistent with Lambdas (see below).
11627   CaptureType = S.Context.getLValueReferenceType(DeclRefType);
11628   Expr *CopyExpr = 0;
11629   if (BuildAndDiagnose) {
11630     // The current implementation assumes that all variables are captured
11631     // by references. Since there is no capture by copy, no expression evaluation
11632     // will be needed.
11633     //
11634     RecordDecl *RD = RSI->TheRecordDecl;
11635 
11636     FieldDecl *Field
11637       = FieldDecl::Create(S.Context, RD, Loc, Loc, 0, CaptureType,
11638                           S.Context.getTrivialTypeSourceInfo(CaptureType, Loc),
11639                           0, false, ICIS_NoInit);
11640     Field->setImplicit(true);
11641     Field->setAccess(AS_private);
11642     RD->addDecl(Field);
11643 
11644     CopyExpr = new (S.Context) DeclRefExpr(Var, RefersToEnclosingLocal,
11645                                             DeclRefType, VK_LValue, Loc);
11646     Var->setReferenced(true);
11647     Var->markUsed(S.Context);
11648   }
11649 
11650   // Actually capture the variable.
11651   if (BuildAndDiagnose)
11652     RSI->addCapture(Var, /*isBlock*/false, ByRef, RefersToEnclosingLocal, Loc,
11653                     SourceLocation(), CaptureType, CopyExpr);
11654 
11655 
11656   return true;
11657 }
11658 
11659 /// \brief Create a field within the lambda class for the variable
11660 ///  being captured.  Handle Array captures.
11661 static ExprResult addAsFieldToClosureType(Sema &S,
11662                                  LambdaScopeInfo *LSI,
11663                                   VarDecl *Var, QualType FieldType,
11664                                   QualType DeclRefType,
11665                                   SourceLocation Loc,
11666                                   bool RefersToEnclosingLocal) {
11667   CXXRecordDecl *Lambda = LSI->Lambda;
11668 
11669   // Make sure that by-copy captures are of a complete type.
11670   if (!DeclRefType->isDependentType() &&
11671       !DeclRefType->isReferenceType() &&
11672       S.RequireCompleteType(Loc, DeclRefType,
11673                             diag::err_capture_of_incomplete_type,
11674                             Var->getDeclName())) {
11675     return ExprError();
11676   }
11677 
11678   // Build the non-static data member.
11679   FieldDecl *Field
11680     = FieldDecl::Create(S.Context, Lambda, Loc, Loc, 0, FieldType,
11681                         S.Context.getTrivialTypeSourceInfo(FieldType, Loc),
11682                         0, false, ICIS_NoInit);
11683   Field->setImplicit(true);
11684   Field->setAccess(AS_private);
11685   Lambda->addDecl(Field);
11686 
11687   // C++11 [expr.prim.lambda]p21:
11688   //   When the lambda-expression is evaluated, the entities that
11689   //   are captured by copy are used to direct-initialize each
11690   //   corresponding non-static data member of the resulting closure
11691   //   object. (For array members, the array elements are
11692   //   direct-initialized in increasing subscript order.) These
11693   //   initializations are performed in the (unspecified) order in
11694   //   which the non-static data members are declared.
11695 
11696   // Introduce a new evaluation context for the initialization, so
11697   // that temporaries introduced as part of the capture are retained
11698   // to be re-"exported" from the lambda expression itself.
11699   EnterExpressionEvaluationContext scope(S, Sema::PotentiallyEvaluated);
11700 
11701   // C++ [expr.prim.labda]p12:
11702   //   An entity captured by a lambda-expression is odr-used (3.2) in
11703   //   the scope containing the lambda-expression.
11704   Expr *Ref = new (S.Context) DeclRefExpr(Var, RefersToEnclosingLocal,
11705                                           DeclRefType, VK_LValue, Loc);
11706   Var->setReferenced(true);
11707   Var->markUsed(S.Context);
11708 
11709   // When the field has array type, create index variables for each
11710   // dimension of the array. We use these index variables to subscript
11711   // the source array, and other clients (e.g., CodeGen) will perform
11712   // the necessary iteration with these index variables.
11713   SmallVector<VarDecl *, 4> IndexVariables;
11714   QualType BaseType = FieldType;
11715   QualType SizeType = S.Context.getSizeType();
11716   LSI->ArrayIndexStarts.push_back(LSI->ArrayIndexVars.size());
11717   while (const ConstantArrayType *Array
11718                         = S.Context.getAsConstantArrayType(BaseType)) {
11719     // Create the iteration variable for this array index.
11720     IdentifierInfo *IterationVarName = 0;
11721     {
11722       SmallString<8> Str;
11723       llvm::raw_svector_ostream OS(Str);
11724       OS << "__i" << IndexVariables.size();
11725       IterationVarName = &S.Context.Idents.get(OS.str());
11726     }
11727     VarDecl *IterationVar
11728       = VarDecl::Create(S.Context, S.CurContext, Loc, Loc,
11729                         IterationVarName, SizeType,
11730                         S.Context.getTrivialTypeSourceInfo(SizeType, Loc),
11731                         SC_None);
11732     IndexVariables.push_back(IterationVar);
11733     LSI->ArrayIndexVars.push_back(IterationVar);
11734 
11735     // Create a reference to the iteration variable.
11736     ExprResult IterationVarRef
11737       = S.BuildDeclRefExpr(IterationVar, SizeType, VK_LValue, Loc);
11738     assert(!IterationVarRef.isInvalid() &&
11739            "Reference to invented variable cannot fail!");
11740     IterationVarRef = S.DefaultLvalueConversion(IterationVarRef.take());
11741     assert(!IterationVarRef.isInvalid() &&
11742            "Conversion of invented variable cannot fail!");
11743 
11744     // Subscript the array with this iteration variable.
11745     ExprResult Subscript = S.CreateBuiltinArraySubscriptExpr(
11746                              Ref, Loc, IterationVarRef.take(), Loc);
11747     if (Subscript.isInvalid()) {
11748       S.CleanupVarDeclMarking();
11749       S.DiscardCleanupsInEvaluationContext();
11750       return ExprError();
11751     }
11752 
11753     Ref = Subscript.take();
11754     BaseType = Array->getElementType();
11755   }
11756 
11757   // Construct the entity that we will be initializing. For an array, this
11758   // will be first element in the array, which may require several levels
11759   // of array-subscript entities.
11760   SmallVector<InitializedEntity, 4> Entities;
11761   Entities.reserve(1 + IndexVariables.size());
11762   Entities.push_back(
11763     InitializedEntity::InitializeLambdaCapture(Var->getIdentifier(),
11764         Field->getType(), Loc));
11765   for (unsigned I = 0, N = IndexVariables.size(); I != N; ++I)
11766     Entities.push_back(InitializedEntity::InitializeElement(S.Context,
11767                                                             0,
11768                                                             Entities.back()));
11769 
11770   InitializationKind InitKind
11771     = InitializationKind::CreateDirect(Loc, Loc, Loc);
11772   InitializationSequence Init(S, Entities.back(), InitKind, Ref);
11773   ExprResult Result(true);
11774   if (!Init.Diagnose(S, Entities.back(), InitKind, Ref))
11775     Result = Init.Perform(S, Entities.back(), InitKind, Ref);
11776 
11777   // If this initialization requires any cleanups (e.g., due to a
11778   // default argument to a copy constructor), note that for the
11779   // lambda.
11780   if (S.ExprNeedsCleanups)
11781     LSI->ExprNeedsCleanups = true;
11782 
11783   // Exit the expression evaluation context used for the capture.
11784   S.CleanupVarDeclMarking();
11785   S.DiscardCleanupsInEvaluationContext();
11786   return Result;
11787 }
11788 
11789 
11790 
11791 /// \brief Capture the given variable in the lambda.
11792 static bool captureInLambda(LambdaScopeInfo *LSI,
11793                             VarDecl *Var,
11794                             SourceLocation Loc,
11795                             const bool BuildAndDiagnose,
11796                             QualType &CaptureType,
11797                             QualType &DeclRefType,
11798                             const bool RefersToEnclosingLocal,
11799                             const Sema::TryCaptureKind Kind,
11800                             SourceLocation EllipsisLoc,
11801                             const bool IsTopScope,
11802                             Sema &S) {
11803 
11804   // Determine whether we are capturing by reference or by value.
11805   bool ByRef = false;
11806   if (IsTopScope && Kind != Sema::TryCapture_Implicit) {
11807     ByRef = (Kind == Sema::TryCapture_ExplicitByRef);
11808   } else {
11809     ByRef = (LSI->ImpCaptureStyle == LambdaScopeInfo::ImpCap_LambdaByref);
11810   }
11811 
11812   // Compute the type of the field that will capture this variable.
11813   if (ByRef) {
11814     // C++11 [expr.prim.lambda]p15:
11815     //   An entity is captured by reference if it is implicitly or
11816     //   explicitly captured but not captured by copy. It is
11817     //   unspecified whether additional unnamed non-static data
11818     //   members are declared in the closure type for entities
11819     //   captured by reference.
11820     //
11821     // FIXME: It is not clear whether we want to build an lvalue reference
11822     // to the DeclRefType or to CaptureType.getNonReferenceType(). GCC appears
11823     // to do the former, while EDG does the latter. Core issue 1249 will
11824     // clarify, but for now we follow GCC because it's a more permissive and
11825     // easily defensible position.
11826     CaptureType = S.Context.getLValueReferenceType(DeclRefType);
11827   } else {
11828     // C++11 [expr.prim.lambda]p14:
11829     //   For each entity captured by copy, an unnamed non-static
11830     //   data member is declared in the closure type. The
11831     //   declaration order of these members is unspecified. The type
11832     //   of such a data member is the type of the corresponding
11833     //   captured entity if the entity is not a reference to an
11834     //   object, or the referenced type otherwise. [Note: If the
11835     //   captured entity is a reference to a function, the
11836     //   corresponding data member is also a reference to a
11837     //   function. - end note ]
11838     if (const ReferenceType *RefType = CaptureType->getAs<ReferenceType>()){
11839       if (!RefType->getPointeeType()->isFunctionType())
11840         CaptureType = RefType->getPointeeType();
11841     }
11842 
11843     // Forbid the lambda copy-capture of autoreleasing variables.
11844     if (CaptureType.getObjCLifetime() == Qualifiers::OCL_Autoreleasing) {
11845       if (BuildAndDiagnose) {
11846         S.Diag(Loc, diag::err_arc_autoreleasing_capture) << /*lambda*/ 1;
11847         S.Diag(Var->getLocation(), diag::note_previous_decl)
11848           << Var->getDeclName();
11849       }
11850       return false;
11851     }
11852 
11853     if (S.RequireNonAbstractType(Loc, CaptureType,
11854                                  diag::err_capture_of_abstract_type))
11855       return false;
11856   }
11857 
11858   // Capture this variable in the lambda.
11859   Expr *CopyExpr = 0;
11860   if (BuildAndDiagnose) {
11861     ExprResult Result = addAsFieldToClosureType(S, LSI, Var,
11862                                         CaptureType, DeclRefType, Loc,
11863                                         RefersToEnclosingLocal);
11864     if (!Result.isInvalid())
11865       CopyExpr = Result.take();
11866   }
11867 
11868   // Compute the type of a reference to this captured variable.
11869   if (ByRef)
11870     DeclRefType = CaptureType.getNonReferenceType();
11871   else {
11872     // C++ [expr.prim.lambda]p5:
11873     //   The closure type for a lambda-expression has a public inline
11874     //   function call operator [...]. This function call operator is
11875     //   declared const (9.3.1) if and only if the lambda-expression’s
11876     //   parameter-declaration-clause is not followed by mutable.
11877     DeclRefType = CaptureType.getNonReferenceType();
11878     if (!LSI->Mutable && !CaptureType->isReferenceType())
11879       DeclRefType.addConst();
11880   }
11881 
11882   // Add the capture.
11883   if (BuildAndDiagnose)
11884     LSI->addCapture(Var, /*IsBlock=*/false, ByRef, RefersToEnclosingLocal,
11885                     Loc, EllipsisLoc, CaptureType, CopyExpr);
11886 
11887   return true;
11888 }
11889 
11890 
11891 bool Sema::tryCaptureVariable(VarDecl *Var, SourceLocation ExprLoc,
11892                               TryCaptureKind Kind, SourceLocation EllipsisLoc,
11893                               bool BuildAndDiagnose,
11894                               QualType &CaptureType,
11895                               QualType &DeclRefType,
11896 						                const unsigned *const FunctionScopeIndexToStopAt) {
11897   bool Nested = false;
11898 
11899   DeclContext *DC = CurContext;
11900   const unsigned MaxFunctionScopesIndex = FunctionScopeIndexToStopAt
11901       ? *FunctionScopeIndexToStopAt : FunctionScopes.size() - 1;
11902   // We need to sync up the Declaration Context with the
11903   // FunctionScopeIndexToStopAt
11904   if (FunctionScopeIndexToStopAt) {
11905     unsigned FSIndex = FunctionScopes.size() - 1;
11906     while (FSIndex != MaxFunctionScopesIndex) {
11907       DC = getLambdaAwareParentOfDeclContext(DC);
11908       --FSIndex;
11909     }
11910   }
11911 
11912 
11913   // If the variable is declared in the current context (and is not an
11914   // init-capture), there is no need to capture it.
11915   if (!Var->isInitCapture() && Var->getDeclContext() == DC) return true;
11916   if (!Var->hasLocalStorage()) return true;
11917 
11918   // Walk up the stack to determine whether we can capture the variable,
11919   // performing the "simple" checks that don't depend on type. We stop when
11920   // we've either hit the declared scope of the variable or find an existing
11921   // capture of that variable.  We start from the innermost capturing-entity
11922   // (the DC) and ensure that all intervening capturing-entities
11923   // (blocks/lambdas etc.) between the innermost capturer and the variable`s
11924   // declcontext can either capture the variable or have already captured
11925   // the variable.
11926   CaptureType = Var->getType();
11927   DeclRefType = CaptureType.getNonReferenceType();
11928   bool Explicit = (Kind != TryCapture_Implicit);
11929   unsigned FunctionScopesIndex = MaxFunctionScopesIndex;
11930   do {
11931     // Only block literals, captured statements, and lambda expressions can
11932     // capture; other scopes don't work.
11933     DeclContext *ParentDC = getParentOfCapturingContextOrNull(DC, Var,
11934                                                               ExprLoc,
11935                                                               BuildAndDiagnose,
11936                                                               *this);
11937     if (!ParentDC) return true;
11938 
11939     FunctionScopeInfo  *FSI = FunctionScopes[FunctionScopesIndex];
11940     CapturingScopeInfo *CSI = cast<CapturingScopeInfo>(FSI);
11941 
11942 
11943     // Check whether we've already captured it.
11944     if (isVariableAlreadyCapturedInScopeInfo(CSI, Var, Nested, CaptureType,
11945                                              DeclRefType))
11946       break;
11947     // If we are instantiating a generic lambda call operator body,
11948     // we do not want to capture new variables.  What was captured
11949     // during either a lambdas transformation or initial parsing
11950     // should be used.
11951     if (isGenericLambdaCallOperatorSpecialization(DC)) {
11952       if (BuildAndDiagnose) {
11953         LambdaScopeInfo *LSI = cast<LambdaScopeInfo>(CSI);
11954         if (LSI->ImpCaptureStyle == CapturingScopeInfo::ImpCap_None) {
11955           Diag(ExprLoc, diag::err_lambda_impcap) << Var->getDeclName();
11956           Diag(Var->getLocation(), diag::note_previous_decl)
11957              << Var->getDeclName();
11958           Diag(LSI->Lambda->getLocStart(), diag::note_lambda_decl);
11959         } else
11960           diagnoseUncapturableValueReference(*this, ExprLoc, Var, DC);
11961       }
11962       return true;
11963     }
11964     // Certain capturing entities (lambdas, blocks etc.) are not allowed to capture
11965     // certain types of variables (unnamed, variably modified types etc.)
11966     // so check for eligibility.
11967     if (!isVariableCapturable(CSI, Var, ExprLoc, BuildAndDiagnose, *this))
11968        return true;
11969 
11970     if (CSI->ImpCaptureStyle == CapturingScopeInfo::ImpCap_None && !Explicit) {
11971       // No capture-default, and this is not an explicit capture
11972       // so cannot capture this variable.
11973       if (BuildAndDiagnose) {
11974         Diag(ExprLoc, diag::err_lambda_impcap) << Var->getDeclName();
11975         Diag(Var->getLocation(), diag::note_previous_decl)
11976           << Var->getDeclName();
11977         Diag(cast<LambdaScopeInfo>(CSI)->Lambda->getLocStart(),
11978              diag::note_lambda_decl);
11979         // FIXME: If we error out because an outer lambda can not implicitly
11980         // capture a variable that an inner lambda explicitly captures, we
11981         // should have the inner lambda do the explicit capture - because
11982         // it makes for cleaner diagnostics later.  This would purely be done
11983         // so that the diagnostic does not misleadingly claim that a variable
11984         // can not be captured by a lambda implicitly even though it is captured
11985         // explicitly.  Suggestion:
11986         //  - create const bool VariableCaptureWasInitiallyExplicit = Explicit
11987         //    at the function head
11988         //  - cache the StartingDeclContext - this must be a lambda
11989         //  - captureInLambda in the innermost lambda the variable.
11990       }
11991       return true;
11992     }
11993 
11994     FunctionScopesIndex--;
11995     DC = ParentDC;
11996     Explicit = false;
11997   } while (!Var->getDeclContext()->Equals(DC));
11998 
11999   // Walk back down the scope stack, (e.g. from outer lambda to inner lambda)
12000   // computing the type of the capture at each step, checking type-specific
12001   // requirements, and adding captures if requested.
12002   // If the variable had already been captured previously, we start capturing
12003   // at the lambda nested within that one.
12004   for (unsigned I = ++FunctionScopesIndex, N = MaxFunctionScopesIndex + 1; I != N;
12005        ++I) {
12006     CapturingScopeInfo *CSI = cast<CapturingScopeInfo>(FunctionScopes[I]);
12007 
12008     if (BlockScopeInfo *BSI = dyn_cast<BlockScopeInfo>(CSI)) {
12009       if (!captureInBlock(BSI, Var, ExprLoc,
12010                           BuildAndDiagnose, CaptureType,
12011                           DeclRefType, Nested, *this))
12012         return true;
12013       Nested = true;
12014     } else if (CapturedRegionScopeInfo *RSI = dyn_cast<CapturedRegionScopeInfo>(CSI)) {
12015       if (!captureInCapturedRegion(RSI, Var, ExprLoc,
12016                                    BuildAndDiagnose, CaptureType,
12017                                    DeclRefType, Nested, *this))
12018         return true;
12019       Nested = true;
12020     } else {
12021       LambdaScopeInfo *LSI = cast<LambdaScopeInfo>(CSI);
12022       if (!captureInLambda(LSI, Var, ExprLoc,
12023                            BuildAndDiagnose, CaptureType,
12024                            DeclRefType, Nested, Kind, EllipsisLoc,
12025                             /*IsTopScope*/I == N - 1, *this))
12026         return true;
12027       Nested = true;
12028     }
12029   }
12030   return false;
12031 }
12032 
12033 bool Sema::tryCaptureVariable(VarDecl *Var, SourceLocation Loc,
12034                               TryCaptureKind Kind, SourceLocation EllipsisLoc) {
12035   QualType CaptureType;
12036   QualType DeclRefType;
12037   return tryCaptureVariable(Var, Loc, Kind, EllipsisLoc,
12038                             /*BuildAndDiagnose=*/true, CaptureType,
12039                             DeclRefType, 0);
12040 }
12041 
12042 QualType Sema::getCapturedDeclRefType(VarDecl *Var, SourceLocation Loc) {
12043   QualType CaptureType;
12044   QualType DeclRefType;
12045 
12046   // Determine whether we can capture this variable.
12047   if (tryCaptureVariable(Var, Loc, TryCapture_Implicit, SourceLocation(),
12048                          /*BuildAndDiagnose=*/false, CaptureType,
12049                          DeclRefType, 0))
12050     return QualType();
12051 
12052   return DeclRefType;
12053 }
12054 
12055 
12056 
12057 // If either the type of the variable or the initializer is dependent,
12058 // return false. Otherwise, determine whether the variable is a constant
12059 // expression. Use this if you need to know if a variable that might or
12060 // might not be dependent is truly a constant expression.
12061 static inline bool IsVariableNonDependentAndAConstantExpression(VarDecl *Var,
12062     ASTContext &Context) {
12063 
12064   if (Var->getType()->isDependentType())
12065     return false;
12066   const VarDecl *DefVD = 0;
12067   Var->getAnyInitializer(DefVD);
12068   if (!DefVD)
12069     return false;
12070   EvaluatedStmt *Eval = DefVD->ensureEvaluatedStmt();
12071   Expr *Init = cast<Expr>(Eval->Value);
12072   if (Init->isValueDependent())
12073     return false;
12074   return IsVariableAConstantExpression(Var, Context);
12075 }
12076 
12077 
12078 void Sema::UpdateMarkingForLValueToRValue(Expr *E) {
12079   // Per C++11 [basic.def.odr], a variable is odr-used "unless it is
12080   // an object that satisfies the requirements for appearing in a
12081   // constant expression (5.19) and the lvalue-to-rvalue conversion (4.1)
12082   // is immediately applied."  This function handles the lvalue-to-rvalue
12083   // conversion part.
12084   MaybeODRUseExprs.erase(E->IgnoreParens());
12085 
12086   // If we are in a lambda, check if this DeclRefExpr or MemberExpr refers
12087   // to a variable that is a constant expression, and if so, identify it as
12088   // a reference to a variable that does not involve an odr-use of that
12089   // variable.
12090   if (LambdaScopeInfo *LSI = getCurLambda()) {
12091     Expr *SansParensExpr = E->IgnoreParens();
12092     VarDecl *Var = 0;
12093     if (DeclRefExpr *DRE = dyn_cast<DeclRefExpr>(SansParensExpr))
12094       Var = dyn_cast<VarDecl>(DRE->getFoundDecl());
12095     else if (MemberExpr *ME = dyn_cast<MemberExpr>(SansParensExpr))
12096       Var = dyn_cast<VarDecl>(ME->getMemberDecl());
12097 
12098     if (Var && IsVariableNonDependentAndAConstantExpression(Var, Context))
12099       LSI->markVariableExprAsNonODRUsed(SansParensExpr);
12100   }
12101 }
12102 
12103 ExprResult Sema::ActOnConstantExpression(ExprResult Res) {
12104   if (!Res.isUsable())
12105     return Res;
12106 
12107   // If a constant-expression is a reference to a variable where we delay
12108   // deciding whether it is an odr-use, just assume we will apply the
12109   // lvalue-to-rvalue conversion.  In the one case where this doesn't happen
12110   // (a non-type template argument), we have special handling anyway.
12111   UpdateMarkingForLValueToRValue(Res.get());
12112   return Res;
12113 }
12114 
12115 void Sema::CleanupVarDeclMarking() {
12116   for (llvm::SmallPtrSetIterator<Expr*> i = MaybeODRUseExprs.begin(),
12117                                         e = MaybeODRUseExprs.end();
12118        i != e; ++i) {
12119     VarDecl *Var;
12120     SourceLocation Loc;
12121     if (DeclRefExpr *DRE = dyn_cast<DeclRefExpr>(*i)) {
12122       Var = cast<VarDecl>(DRE->getDecl());
12123       Loc = DRE->getLocation();
12124     } else if (MemberExpr *ME = dyn_cast<MemberExpr>(*i)) {
12125       Var = cast<VarDecl>(ME->getMemberDecl());
12126       Loc = ME->getMemberLoc();
12127     } else {
12128       llvm_unreachable("Unexpcted expression");
12129     }
12130 
12131     MarkVarDeclODRUsed(Var, Loc, *this, /*MaxFunctionScopeIndex Pointer*/ 0);
12132   }
12133 
12134   MaybeODRUseExprs.clear();
12135 }
12136 
12137 
12138 static void DoMarkVarDeclReferenced(Sema &SemaRef, SourceLocation Loc,
12139                                     VarDecl *Var, Expr *E) {
12140   assert((!E || isa<DeclRefExpr>(E) || isa<MemberExpr>(E)) &&
12141          "Invalid Expr argument to DoMarkVarDeclReferenced");
12142   Var->setReferenced();
12143 
12144   // If the context is not PotentiallyEvaluated and not Unevaluated
12145   // (i.e PotentiallyEvaluatedIfUsed) do not bother to consider variables
12146   // in this context for odr-use unless we are within a lambda.
12147   // If we don't know whether the context is potentially evaluated or not
12148   // (for e.g., if we're in a generic lambda), we want to add a potential
12149   // capture and eventually analyze for odr-use.
12150   // We should also be able to analyze certain constructs in a non-generic
12151   // lambda setting for potential odr-use and capture violation:
12152   // template<class T> void foo(T t) {
12153   //    auto L = [](int i) { return t; };
12154   // }
12155   //
12156   if (!IsPotentiallyEvaluatedContext(SemaRef)) {
12157 
12158     if (SemaRef.isUnevaluatedContext()) return;
12159 
12160     const bool refersToEnclosingScope =
12161       (SemaRef.CurContext != Var->getDeclContext() &&
12162            Var->getDeclContext()->isFunctionOrMethod());
12163     if (!refersToEnclosingScope) return;
12164 
12165     if (LambdaScopeInfo *const LSI = SemaRef.getCurLambda()) {
12166       // If a variable could potentially be odr-used, defer marking it so
12167       // until we finish analyzing the full expression for any lvalue-to-rvalue
12168       // or discarded value conversions that would obviate odr-use.
12169       // Add it to the list of potential captures that will be analyzed
12170       // later (ActOnFinishFullExpr) for eventual capture and odr-use marking
12171       // unless the variable is a reference that was initialized by a constant
12172       // expression (this will never need to be captured or odr-used).
12173       const bool IsConstantExpr = IsVariableNonDependentAndAConstantExpression(
12174           Var, SemaRef.Context);
12175       assert(E && "Capture variable should be used in an expression.");
12176       if (!IsConstantExpr || !Var->getType()->isReferenceType())
12177         LSI->addPotentialCapture(E->IgnoreParens());
12178     }
12179     return;
12180   }
12181 
12182   VarTemplateSpecializationDecl *VarSpec =
12183       dyn_cast<VarTemplateSpecializationDecl>(Var);
12184   assert(!isa<VarTemplatePartialSpecializationDecl>(Var) &&
12185          "Can't instantiate a partial template specialization.");
12186 
12187   // Implicit instantiation of static data members, static data member
12188   // templates of class templates, and variable template specializations.
12189   // Delay instantiations of variable templates, except for those
12190   // that could be used in a constant expression.
12191   TemplateSpecializationKind TSK = Var->getTemplateSpecializationKind();
12192   if (isTemplateInstantiation(TSK)) {
12193     bool TryInstantiating = TSK == TSK_ImplicitInstantiation;
12194 
12195     if (TryInstantiating && !isa<VarTemplateSpecializationDecl>(Var)) {
12196       if (Var->getPointOfInstantiation().isInvalid()) {
12197         // This is a modification of an existing AST node. Notify listeners.
12198         if (ASTMutationListener *L = SemaRef.getASTMutationListener())
12199           L->StaticDataMemberInstantiated(Var);
12200       } else if (!Var->isUsableInConstantExpressions(SemaRef.Context))
12201         // Don't bother trying to instantiate it again, unless we might need
12202         // its initializer before we get to the end of the TU.
12203         TryInstantiating = false;
12204     }
12205 
12206     if (Var->getPointOfInstantiation().isInvalid())
12207       Var->setTemplateSpecializationKind(TSK, Loc);
12208 
12209     if (TryInstantiating) {
12210       SourceLocation PointOfInstantiation = Var->getPointOfInstantiation();
12211       bool InstantiationDependent = false;
12212       bool IsNonDependent =
12213           VarSpec ? !TemplateSpecializationType::anyDependentTemplateArguments(
12214                         VarSpec->getTemplateArgsInfo(), InstantiationDependent)
12215                   : true;
12216 
12217       // Do not instantiate specializations that are still type-dependent.
12218       if (IsNonDependent) {
12219         if (Var->isUsableInConstantExpressions(SemaRef.Context)) {
12220           // Do not defer instantiations of variables which could be used in a
12221           // constant expression.
12222           SemaRef.InstantiateVariableDefinition(PointOfInstantiation, Var);
12223         } else {
12224           SemaRef.PendingInstantiations
12225               .push_back(std::make_pair(Var, PointOfInstantiation));
12226         }
12227       }
12228     }
12229   }
12230   // Per C++11 [basic.def.odr], a variable is odr-used "unless it satisfies
12231   // the requirements for appearing in a constant expression (5.19) and, if
12232   // it is an object, the lvalue-to-rvalue conversion (4.1)
12233   // is immediately applied."  We check the first part here, and
12234   // Sema::UpdateMarkingForLValueToRValue deals with the second part.
12235   // Note that we use the C++11 definition everywhere because nothing in
12236   // C++03 depends on whether we get the C++03 version correct. The second
12237   // part does not apply to references, since they are not objects.
12238   if (E && IsVariableAConstantExpression(Var, SemaRef.Context)) {
12239     // A reference initialized by a constant expression can never be
12240     // odr-used, so simply ignore it.
12241     // But a non-reference might get odr-used if it doesn't undergo
12242     // an lvalue-to-rvalue or is discarded, so track it.
12243     if (!Var->getType()->isReferenceType())
12244       SemaRef.MaybeODRUseExprs.insert(E);
12245   }
12246   else
12247     MarkVarDeclODRUsed(Var, Loc, SemaRef, /*MaxFunctionScopeIndex ptr*/0);
12248 }
12249 
12250 /// \brief Mark a variable referenced, and check whether it is odr-used
12251 /// (C++ [basic.def.odr]p2, C99 6.9p3).  Note that this should not be
12252 /// used directly for normal expressions referring to VarDecl.
12253 void Sema::MarkVariableReferenced(SourceLocation Loc, VarDecl *Var) {
12254   DoMarkVarDeclReferenced(*this, Loc, Var, 0);
12255 }
12256 
12257 static void MarkExprReferenced(Sema &SemaRef, SourceLocation Loc,
12258                                Decl *D, Expr *E, bool OdrUse) {
12259   if (VarDecl *Var = dyn_cast<VarDecl>(D)) {
12260     DoMarkVarDeclReferenced(SemaRef, Loc, Var, E);
12261     return;
12262   }
12263 
12264   SemaRef.MarkAnyDeclReferenced(Loc, D, OdrUse);
12265 
12266   // If this is a call to a method via a cast, also mark the method in the
12267   // derived class used in case codegen can devirtualize the call.
12268   const MemberExpr *ME = dyn_cast<MemberExpr>(E);
12269   if (!ME)
12270     return;
12271   CXXMethodDecl *MD = dyn_cast<CXXMethodDecl>(ME->getMemberDecl());
12272   if (!MD)
12273     return;
12274   const Expr *Base = ME->getBase();
12275   const CXXRecordDecl *MostDerivedClassDecl = Base->getBestDynamicClassType();
12276   if (!MostDerivedClassDecl)
12277     return;
12278   CXXMethodDecl *DM = MD->getCorrespondingMethodInClass(MostDerivedClassDecl);
12279   if (!DM || DM->isPure())
12280     return;
12281   SemaRef.MarkAnyDeclReferenced(Loc, DM, OdrUse);
12282 }
12283 
12284 /// \brief Perform reference-marking and odr-use handling for a DeclRefExpr.
12285 void Sema::MarkDeclRefReferenced(DeclRefExpr *E) {
12286   // TODO: update this with DR# once a defect report is filed.
12287   // C++11 defect. The address of a pure member should not be an ODR use, even
12288   // if it's a qualified reference.
12289   bool OdrUse = true;
12290   if (CXXMethodDecl *Method = dyn_cast<CXXMethodDecl>(E->getDecl()))
12291     if (Method->isVirtual())
12292       OdrUse = false;
12293   MarkExprReferenced(*this, E->getLocation(), E->getDecl(), E, OdrUse);
12294 }
12295 
12296 /// \brief Perform reference-marking and odr-use handling for a MemberExpr.
12297 void Sema::MarkMemberReferenced(MemberExpr *E) {
12298   // C++11 [basic.def.odr]p2:
12299   //   A non-overloaded function whose name appears as a potentially-evaluated
12300   //   expression or a member of a set of candidate functions, if selected by
12301   //   overload resolution when referred to from a potentially-evaluated
12302   //   expression, is odr-used, unless it is a pure virtual function and its
12303   //   name is not explicitly qualified.
12304   bool OdrUse = true;
12305   if (!E->hasQualifier()) {
12306     if (CXXMethodDecl *Method = dyn_cast<CXXMethodDecl>(E->getMemberDecl()))
12307       if (Method->isPure())
12308         OdrUse = false;
12309   }
12310   SourceLocation Loc = E->getMemberLoc().isValid() ?
12311                             E->getMemberLoc() : E->getLocStart();
12312   MarkExprReferenced(*this, Loc, E->getMemberDecl(), E, OdrUse);
12313 }
12314 
12315 /// \brief Perform marking for a reference to an arbitrary declaration.  It
12316 /// marks the declaration referenced, and performs odr-use checking for functions
12317 /// and variables. This method should not be used when building an normal
12318 /// expression which refers to a variable.
12319 void Sema::MarkAnyDeclReferenced(SourceLocation Loc, Decl *D, bool OdrUse) {
12320   if (OdrUse) {
12321     if (VarDecl *VD = dyn_cast<VarDecl>(D)) {
12322       MarkVariableReferenced(Loc, VD);
12323       return;
12324     }
12325     if (FunctionDecl *FD = dyn_cast<FunctionDecl>(D)) {
12326       MarkFunctionReferenced(Loc, FD);
12327       return;
12328     }
12329   }
12330   D->setReferenced();
12331 }
12332 
12333 namespace {
12334   // Mark all of the declarations referenced
12335   // FIXME: Not fully implemented yet! We need to have a better understanding
12336   // of when we're entering
12337   class MarkReferencedDecls : public RecursiveASTVisitor<MarkReferencedDecls> {
12338     Sema &S;
12339     SourceLocation Loc;
12340 
12341   public:
12342     typedef RecursiveASTVisitor<MarkReferencedDecls> Inherited;
12343 
12344     MarkReferencedDecls(Sema &S, SourceLocation Loc) : S(S), Loc(Loc) { }
12345 
12346     bool TraverseTemplateArgument(const TemplateArgument &Arg);
12347     bool TraverseRecordType(RecordType *T);
12348   };
12349 }
12350 
12351 bool MarkReferencedDecls::TraverseTemplateArgument(
12352   const TemplateArgument &Arg) {
12353   if (Arg.getKind() == TemplateArgument::Declaration) {
12354     if (Decl *D = Arg.getAsDecl())
12355       S.MarkAnyDeclReferenced(Loc, D, true);
12356   }
12357 
12358   return Inherited::TraverseTemplateArgument(Arg);
12359 }
12360 
12361 bool MarkReferencedDecls::TraverseRecordType(RecordType *T) {
12362   if (ClassTemplateSpecializationDecl *Spec
12363                   = dyn_cast<ClassTemplateSpecializationDecl>(T->getDecl())) {
12364     const TemplateArgumentList &Args = Spec->getTemplateArgs();
12365     return TraverseTemplateArguments(Args.data(), Args.size());
12366   }
12367 
12368   return true;
12369 }
12370 
12371 void Sema::MarkDeclarationsReferencedInType(SourceLocation Loc, QualType T) {
12372   MarkReferencedDecls Marker(*this, Loc);
12373   Marker.TraverseType(Context.getCanonicalType(T));
12374 }
12375 
12376 namespace {
12377   /// \brief Helper class that marks all of the declarations referenced by
12378   /// potentially-evaluated subexpressions as "referenced".
12379   class EvaluatedExprMarker : public EvaluatedExprVisitor<EvaluatedExprMarker> {
12380     Sema &S;
12381     bool SkipLocalVariables;
12382 
12383   public:
12384     typedef EvaluatedExprVisitor<EvaluatedExprMarker> Inherited;
12385 
12386     EvaluatedExprMarker(Sema &S, bool SkipLocalVariables)
12387       : Inherited(S.Context), S(S), SkipLocalVariables(SkipLocalVariables) { }
12388 
12389     void VisitDeclRefExpr(DeclRefExpr *E) {
12390       // If we were asked not to visit local variables, don't.
12391       if (SkipLocalVariables) {
12392         if (VarDecl *VD = dyn_cast<VarDecl>(E->getDecl()))
12393           if (VD->hasLocalStorage())
12394             return;
12395       }
12396 
12397       S.MarkDeclRefReferenced(E);
12398     }
12399 
12400     void VisitMemberExpr(MemberExpr *E) {
12401       S.MarkMemberReferenced(E);
12402       Inherited::VisitMemberExpr(E);
12403     }
12404 
12405     void VisitCXXBindTemporaryExpr(CXXBindTemporaryExpr *E) {
12406       S.MarkFunctionReferenced(E->getLocStart(),
12407             const_cast<CXXDestructorDecl*>(E->getTemporary()->getDestructor()));
12408       Visit(E->getSubExpr());
12409     }
12410 
12411     void VisitCXXNewExpr(CXXNewExpr *E) {
12412       if (E->getOperatorNew())
12413         S.MarkFunctionReferenced(E->getLocStart(), E->getOperatorNew());
12414       if (E->getOperatorDelete())
12415         S.MarkFunctionReferenced(E->getLocStart(), E->getOperatorDelete());
12416       Inherited::VisitCXXNewExpr(E);
12417     }
12418 
12419     void VisitCXXDeleteExpr(CXXDeleteExpr *E) {
12420       if (E->getOperatorDelete())
12421         S.MarkFunctionReferenced(E->getLocStart(), E->getOperatorDelete());
12422       QualType Destroyed = S.Context.getBaseElementType(E->getDestroyedType());
12423       if (const RecordType *DestroyedRec = Destroyed->getAs<RecordType>()) {
12424         CXXRecordDecl *Record = cast<CXXRecordDecl>(DestroyedRec->getDecl());
12425         S.MarkFunctionReferenced(E->getLocStart(),
12426                                     S.LookupDestructor(Record));
12427       }
12428 
12429       Inherited::VisitCXXDeleteExpr(E);
12430     }
12431 
12432     void VisitCXXConstructExpr(CXXConstructExpr *E) {
12433       S.MarkFunctionReferenced(E->getLocStart(), E->getConstructor());
12434       Inherited::VisitCXXConstructExpr(E);
12435     }
12436 
12437     void VisitCXXDefaultArgExpr(CXXDefaultArgExpr *E) {
12438       Visit(E->getExpr());
12439     }
12440 
12441     void VisitImplicitCastExpr(ImplicitCastExpr *E) {
12442       Inherited::VisitImplicitCastExpr(E);
12443 
12444       if (E->getCastKind() == CK_LValueToRValue)
12445         S.UpdateMarkingForLValueToRValue(E->getSubExpr());
12446     }
12447   };
12448 }
12449 
12450 /// \brief Mark any declarations that appear within this expression or any
12451 /// potentially-evaluated subexpressions as "referenced".
12452 ///
12453 /// \param SkipLocalVariables If true, don't mark local variables as
12454 /// 'referenced'.
12455 void Sema::MarkDeclarationsReferencedInExpr(Expr *E,
12456                                             bool SkipLocalVariables) {
12457   EvaluatedExprMarker(*this, SkipLocalVariables).Visit(E);
12458 }
12459 
12460 /// \brief Emit a diagnostic that describes an effect on the run-time behavior
12461 /// of the program being compiled.
12462 ///
12463 /// This routine emits the given diagnostic when the code currently being
12464 /// type-checked is "potentially evaluated", meaning that there is a
12465 /// possibility that the code will actually be executable. Code in sizeof()
12466 /// expressions, code used only during overload resolution, etc., are not
12467 /// potentially evaluated. This routine will suppress such diagnostics or,
12468 /// in the absolutely nutty case of potentially potentially evaluated
12469 /// expressions (C++ typeid), queue the diagnostic to potentially emit it
12470 /// later.
12471 ///
12472 /// This routine should be used for all diagnostics that describe the run-time
12473 /// behavior of a program, such as passing a non-POD value through an ellipsis.
12474 /// Failure to do so will likely result in spurious diagnostics or failures
12475 /// during overload resolution or within sizeof/alignof/typeof/typeid.
12476 bool Sema::DiagRuntimeBehavior(SourceLocation Loc, const Stmt *Statement,
12477                                const PartialDiagnostic &PD) {
12478   switch (ExprEvalContexts.back().Context) {
12479   case Unevaluated:
12480   case UnevaluatedAbstract:
12481     // The argument will never be evaluated, so don't complain.
12482     break;
12483 
12484   case ConstantEvaluated:
12485     // Relevant diagnostics should be produced by constant evaluation.
12486     break;
12487 
12488   case PotentiallyEvaluated:
12489   case PotentiallyEvaluatedIfUsed:
12490     if (Statement && getCurFunctionOrMethodDecl()) {
12491       FunctionScopes.back()->PossiblyUnreachableDiags.
12492         push_back(sema::PossiblyUnreachableDiag(PD, Loc, Statement));
12493     }
12494     else
12495       Diag(Loc, PD);
12496 
12497     return true;
12498   }
12499 
12500   return false;
12501 }
12502 
12503 bool Sema::CheckCallReturnType(QualType ReturnType, SourceLocation Loc,
12504                                CallExpr *CE, FunctionDecl *FD) {
12505   if (ReturnType->isVoidType() || !ReturnType->isIncompleteType())
12506     return false;
12507 
12508   // If we're inside a decltype's expression, don't check for a valid return
12509   // type or construct temporaries until we know whether this is the last call.
12510   if (ExprEvalContexts.back().IsDecltype) {
12511     ExprEvalContexts.back().DelayedDecltypeCalls.push_back(CE);
12512     return false;
12513   }
12514 
12515   class CallReturnIncompleteDiagnoser : public TypeDiagnoser {
12516     FunctionDecl *FD;
12517     CallExpr *CE;
12518 
12519   public:
12520     CallReturnIncompleteDiagnoser(FunctionDecl *FD, CallExpr *CE)
12521       : FD(FD), CE(CE) { }
12522 
12523     virtual void diagnose(Sema &S, SourceLocation Loc, QualType T) {
12524       if (!FD) {
12525         S.Diag(Loc, diag::err_call_incomplete_return)
12526           << T << CE->getSourceRange();
12527         return;
12528       }
12529 
12530       S.Diag(Loc, diag::err_call_function_incomplete_return)
12531         << CE->getSourceRange() << FD->getDeclName() << T;
12532       S.Diag(FD->getLocation(),
12533              diag::note_function_with_incomplete_return_type_declared_here)
12534         << FD->getDeclName();
12535     }
12536   } Diagnoser(FD, CE);
12537 
12538   if (RequireCompleteType(Loc, ReturnType, Diagnoser))
12539     return true;
12540 
12541   return false;
12542 }
12543 
12544 // Diagnose the s/=/==/ and s/\|=/!=/ typos. Note that adding parentheses
12545 // will prevent this condition from triggering, which is what we want.
12546 void Sema::DiagnoseAssignmentAsCondition(Expr *E) {
12547   SourceLocation Loc;
12548 
12549   unsigned diagnostic = diag::warn_condition_is_assignment;
12550   bool IsOrAssign = false;
12551 
12552   if (BinaryOperator *Op = dyn_cast<BinaryOperator>(E)) {
12553     if (Op->getOpcode() != BO_Assign && Op->getOpcode() != BO_OrAssign)
12554       return;
12555 
12556     IsOrAssign = Op->getOpcode() == BO_OrAssign;
12557 
12558     // Greylist some idioms by putting them into a warning subcategory.
12559     if (ObjCMessageExpr *ME
12560           = dyn_cast<ObjCMessageExpr>(Op->getRHS()->IgnoreParenCasts())) {
12561       Selector Sel = ME->getSelector();
12562 
12563       // self = [<foo> init...]
12564       if (isSelfExpr(Op->getLHS()) && ME->getMethodFamily() == OMF_init)
12565         diagnostic = diag::warn_condition_is_idiomatic_assignment;
12566 
12567       // <foo> = [<bar> nextObject]
12568       else if (Sel.isUnarySelector() && Sel.getNameForSlot(0) == "nextObject")
12569         diagnostic = diag::warn_condition_is_idiomatic_assignment;
12570     }
12571 
12572     Loc = Op->getOperatorLoc();
12573   } else if (CXXOperatorCallExpr *Op = dyn_cast<CXXOperatorCallExpr>(E)) {
12574     if (Op->getOperator() != OO_Equal && Op->getOperator() != OO_PipeEqual)
12575       return;
12576 
12577     IsOrAssign = Op->getOperator() == OO_PipeEqual;
12578     Loc = Op->getOperatorLoc();
12579   } else if (PseudoObjectExpr *POE = dyn_cast<PseudoObjectExpr>(E))
12580     return DiagnoseAssignmentAsCondition(POE->getSyntacticForm());
12581   else {
12582     // Not an assignment.
12583     return;
12584   }
12585 
12586   Diag(Loc, diagnostic) << E->getSourceRange();
12587 
12588   SourceLocation Open = E->getLocStart();
12589   SourceLocation Close = PP.getLocForEndOfToken(E->getSourceRange().getEnd());
12590   Diag(Loc, diag::note_condition_assign_silence)
12591         << FixItHint::CreateInsertion(Open, "(")
12592         << FixItHint::CreateInsertion(Close, ")");
12593 
12594   if (IsOrAssign)
12595     Diag(Loc, diag::note_condition_or_assign_to_comparison)
12596       << FixItHint::CreateReplacement(Loc, "!=");
12597   else
12598     Diag(Loc, diag::note_condition_assign_to_comparison)
12599       << FixItHint::CreateReplacement(Loc, "==");
12600 }
12601 
12602 /// \brief Redundant parentheses over an equality comparison can indicate
12603 /// that the user intended an assignment used as condition.
12604 void Sema::DiagnoseEqualityWithExtraParens(ParenExpr *ParenE) {
12605   // Don't warn if the parens came from a macro.
12606   SourceLocation parenLoc = ParenE->getLocStart();
12607   if (parenLoc.isInvalid() || parenLoc.isMacroID())
12608     return;
12609   // Don't warn for dependent expressions.
12610   if (ParenE->isTypeDependent())
12611     return;
12612 
12613   Expr *E = ParenE->IgnoreParens();
12614 
12615   if (BinaryOperator *opE = dyn_cast<BinaryOperator>(E))
12616     if (opE->getOpcode() == BO_EQ &&
12617         opE->getLHS()->IgnoreParenImpCasts()->isModifiableLvalue(Context)
12618                                                            == Expr::MLV_Valid) {
12619       SourceLocation Loc = opE->getOperatorLoc();
12620 
12621       Diag(Loc, diag::warn_equality_with_extra_parens) << E->getSourceRange();
12622       SourceRange ParenERange = ParenE->getSourceRange();
12623       Diag(Loc, diag::note_equality_comparison_silence)
12624         << FixItHint::CreateRemoval(ParenERange.getBegin())
12625         << FixItHint::CreateRemoval(ParenERange.getEnd());
12626       Diag(Loc, diag::note_equality_comparison_to_assign)
12627         << FixItHint::CreateReplacement(Loc, "=");
12628     }
12629 }
12630 
12631 ExprResult Sema::CheckBooleanCondition(Expr *E, SourceLocation Loc) {
12632   DiagnoseAssignmentAsCondition(E);
12633   if (ParenExpr *parenE = dyn_cast<ParenExpr>(E))
12634     DiagnoseEqualityWithExtraParens(parenE);
12635 
12636   ExprResult result = CheckPlaceholderExpr(E);
12637   if (result.isInvalid()) return ExprError();
12638   E = result.take();
12639 
12640   if (!E->isTypeDependent()) {
12641     if (getLangOpts().CPlusPlus)
12642       return CheckCXXBooleanCondition(E); // C++ 6.4p4
12643 
12644     ExprResult ERes = DefaultFunctionArrayLvalueConversion(E);
12645     if (ERes.isInvalid())
12646       return ExprError();
12647     E = ERes.take();
12648 
12649     QualType T = E->getType();
12650     if (!T->isScalarType()) { // C99 6.8.4.1p1
12651       Diag(Loc, diag::err_typecheck_statement_requires_scalar)
12652         << T << E->getSourceRange();
12653       return ExprError();
12654     }
12655   }
12656 
12657   return Owned(E);
12658 }
12659 
12660 ExprResult Sema::ActOnBooleanCondition(Scope *S, SourceLocation Loc,
12661                                        Expr *SubExpr) {
12662   if (!SubExpr)
12663     return ExprError();
12664 
12665   return CheckBooleanCondition(SubExpr, Loc);
12666 }
12667 
12668 namespace {
12669   /// A visitor for rebuilding a call to an __unknown_any expression
12670   /// to have an appropriate type.
12671   struct RebuildUnknownAnyFunction
12672     : StmtVisitor<RebuildUnknownAnyFunction, ExprResult> {
12673 
12674     Sema &S;
12675 
12676     RebuildUnknownAnyFunction(Sema &S) : S(S) {}
12677 
12678     ExprResult VisitStmt(Stmt *S) {
12679       llvm_unreachable("unexpected statement!");
12680     }
12681 
12682     ExprResult VisitExpr(Expr *E) {
12683       S.Diag(E->getExprLoc(), diag::err_unsupported_unknown_any_call)
12684         << E->getSourceRange();
12685       return ExprError();
12686     }
12687 
12688     /// Rebuild an expression which simply semantically wraps another
12689     /// expression which it shares the type and value kind of.
12690     template <class T> ExprResult rebuildSugarExpr(T *E) {
12691       ExprResult SubResult = Visit(E->getSubExpr());
12692       if (SubResult.isInvalid()) return ExprError();
12693 
12694       Expr *SubExpr = SubResult.take();
12695       E->setSubExpr(SubExpr);
12696       E->setType(SubExpr->getType());
12697       E->setValueKind(SubExpr->getValueKind());
12698       assert(E->getObjectKind() == OK_Ordinary);
12699       return E;
12700     }
12701 
12702     ExprResult VisitParenExpr(ParenExpr *E) {
12703       return rebuildSugarExpr(E);
12704     }
12705 
12706     ExprResult VisitUnaryExtension(UnaryOperator *E) {
12707       return rebuildSugarExpr(E);
12708     }
12709 
12710     ExprResult VisitUnaryAddrOf(UnaryOperator *E) {
12711       ExprResult SubResult = Visit(E->getSubExpr());
12712       if (SubResult.isInvalid()) return ExprError();
12713 
12714       Expr *SubExpr = SubResult.take();
12715       E->setSubExpr(SubExpr);
12716       E->setType(S.Context.getPointerType(SubExpr->getType()));
12717       assert(E->getValueKind() == VK_RValue);
12718       assert(E->getObjectKind() == OK_Ordinary);
12719       return E;
12720     }
12721 
12722     ExprResult resolveDecl(Expr *E, ValueDecl *VD) {
12723       if (!isa<FunctionDecl>(VD)) return VisitExpr(E);
12724 
12725       E->setType(VD->getType());
12726 
12727       assert(E->getValueKind() == VK_RValue);
12728       if (S.getLangOpts().CPlusPlus &&
12729           !(isa<CXXMethodDecl>(VD) &&
12730             cast<CXXMethodDecl>(VD)->isInstance()))
12731         E->setValueKind(VK_LValue);
12732 
12733       return E;
12734     }
12735 
12736     ExprResult VisitMemberExpr(MemberExpr *E) {
12737       return resolveDecl(E, E->getMemberDecl());
12738     }
12739 
12740     ExprResult VisitDeclRefExpr(DeclRefExpr *E) {
12741       return resolveDecl(E, E->getDecl());
12742     }
12743   };
12744 }
12745 
12746 /// Given a function expression of unknown-any type, try to rebuild it
12747 /// to have a function type.
12748 static ExprResult rebuildUnknownAnyFunction(Sema &S, Expr *FunctionExpr) {
12749   ExprResult Result = RebuildUnknownAnyFunction(S).Visit(FunctionExpr);
12750   if (Result.isInvalid()) return ExprError();
12751   return S.DefaultFunctionArrayConversion(Result.take());
12752 }
12753 
12754 namespace {
12755   /// A visitor for rebuilding an expression of type __unknown_anytype
12756   /// into one which resolves the type directly on the referring
12757   /// expression.  Strict preservation of the original source
12758   /// structure is not a goal.
12759   struct RebuildUnknownAnyExpr
12760     : StmtVisitor<RebuildUnknownAnyExpr, ExprResult> {
12761 
12762     Sema &S;
12763 
12764     /// The current destination type.
12765     QualType DestType;
12766 
12767     RebuildUnknownAnyExpr(Sema &S, QualType CastType)
12768       : S(S), DestType(CastType) {}
12769 
12770     ExprResult VisitStmt(Stmt *S) {
12771       llvm_unreachable("unexpected statement!");
12772     }
12773 
12774     ExprResult VisitExpr(Expr *E) {
12775       S.Diag(E->getExprLoc(), diag::err_unsupported_unknown_any_expr)
12776         << E->getSourceRange();
12777       return ExprError();
12778     }
12779 
12780     ExprResult VisitCallExpr(CallExpr *E);
12781     ExprResult VisitObjCMessageExpr(ObjCMessageExpr *E);
12782 
12783     /// Rebuild an expression which simply semantically wraps another
12784     /// expression which it shares the type and value kind of.
12785     template <class T> ExprResult rebuildSugarExpr(T *E) {
12786       ExprResult SubResult = Visit(E->getSubExpr());
12787       if (SubResult.isInvalid()) return ExprError();
12788       Expr *SubExpr = SubResult.take();
12789       E->setSubExpr(SubExpr);
12790       E->setType(SubExpr->getType());
12791       E->setValueKind(SubExpr->getValueKind());
12792       assert(E->getObjectKind() == OK_Ordinary);
12793       return E;
12794     }
12795 
12796     ExprResult VisitParenExpr(ParenExpr *E) {
12797       return rebuildSugarExpr(E);
12798     }
12799 
12800     ExprResult VisitUnaryExtension(UnaryOperator *E) {
12801       return rebuildSugarExpr(E);
12802     }
12803 
12804     ExprResult VisitUnaryAddrOf(UnaryOperator *E) {
12805       const PointerType *Ptr = DestType->getAs<PointerType>();
12806       if (!Ptr) {
12807         S.Diag(E->getOperatorLoc(), diag::err_unknown_any_addrof)
12808           << E->getSourceRange();
12809         return ExprError();
12810       }
12811       assert(E->getValueKind() == VK_RValue);
12812       assert(E->getObjectKind() == OK_Ordinary);
12813       E->setType(DestType);
12814 
12815       // Build the sub-expression as if it were an object of the pointee type.
12816       DestType = Ptr->getPointeeType();
12817       ExprResult SubResult = Visit(E->getSubExpr());
12818       if (SubResult.isInvalid()) return ExprError();
12819       E->setSubExpr(SubResult.take());
12820       return E;
12821     }
12822 
12823     ExprResult VisitImplicitCastExpr(ImplicitCastExpr *E);
12824 
12825     ExprResult resolveDecl(Expr *E, ValueDecl *VD);
12826 
12827     ExprResult VisitMemberExpr(MemberExpr *E) {
12828       return resolveDecl(E, E->getMemberDecl());
12829     }
12830 
12831     ExprResult VisitDeclRefExpr(DeclRefExpr *E) {
12832       return resolveDecl(E, E->getDecl());
12833     }
12834   };
12835 }
12836 
12837 /// Rebuilds a call expression which yielded __unknown_anytype.
12838 ExprResult RebuildUnknownAnyExpr::VisitCallExpr(CallExpr *E) {
12839   Expr *CalleeExpr = E->getCallee();
12840 
12841   enum FnKind {
12842     FK_MemberFunction,
12843     FK_FunctionPointer,
12844     FK_BlockPointer
12845   };
12846 
12847   FnKind Kind;
12848   QualType CalleeType = CalleeExpr->getType();
12849   if (CalleeType == S.Context.BoundMemberTy) {
12850     assert(isa<CXXMemberCallExpr>(E) || isa<CXXOperatorCallExpr>(E));
12851     Kind = FK_MemberFunction;
12852     CalleeType = Expr::findBoundMemberType(CalleeExpr);
12853   } else if (const PointerType *Ptr = CalleeType->getAs<PointerType>()) {
12854     CalleeType = Ptr->getPointeeType();
12855     Kind = FK_FunctionPointer;
12856   } else {
12857     CalleeType = CalleeType->castAs<BlockPointerType>()->getPointeeType();
12858     Kind = FK_BlockPointer;
12859   }
12860   const FunctionType *FnType = CalleeType->castAs<FunctionType>();
12861 
12862   // Verify that this is a legal result type of a function.
12863   if (DestType->isArrayType() || DestType->isFunctionType()) {
12864     unsigned diagID = diag::err_func_returning_array_function;
12865     if (Kind == FK_BlockPointer)
12866       diagID = diag::err_block_returning_array_function;
12867 
12868     S.Diag(E->getExprLoc(), diagID)
12869       << DestType->isFunctionType() << DestType;
12870     return ExprError();
12871   }
12872 
12873   // Otherwise, go ahead and set DestType as the call's result.
12874   E->setType(DestType.getNonLValueExprType(S.Context));
12875   E->setValueKind(Expr::getValueKindForType(DestType));
12876   assert(E->getObjectKind() == OK_Ordinary);
12877 
12878   // Rebuild the function type, replacing the result type with DestType.
12879   const FunctionProtoType *Proto = dyn_cast<FunctionProtoType>(FnType);
12880   if (Proto) {
12881     // __unknown_anytype(...) is a special case used by the debugger when
12882     // it has no idea what a function's signature is.
12883     //
12884     // We want to build this call essentially under the K&R
12885     // unprototyped rules, but making a FunctionNoProtoType in C++
12886     // would foul up all sorts of assumptions.  However, we cannot
12887     // simply pass all arguments as variadic arguments, nor can we
12888     // portably just call the function under a non-variadic type; see
12889     // the comment on IR-gen's TargetInfo::isNoProtoCallVariadic.
12890     // However, it turns out that in practice it is generally safe to
12891     // call a function declared as "A foo(B,C,D);" under the prototype
12892     // "A foo(B,C,D,...);".  The only known exception is with the
12893     // Windows ABI, where any variadic function is implicitly cdecl
12894     // regardless of its normal CC.  Therefore we change the parameter
12895     // types to match the types of the arguments.
12896     //
12897     // This is a hack, but it is far superior to moving the
12898     // corresponding target-specific code from IR-gen to Sema/AST.
12899 
12900     ArrayRef<QualType> ParamTypes = Proto->getArgTypes();
12901     SmallVector<QualType, 8> ArgTypes;
12902     if (ParamTypes.empty() && Proto->isVariadic()) { // the special case
12903       ArgTypes.reserve(E->getNumArgs());
12904       for (unsigned i = 0, e = E->getNumArgs(); i != e; ++i) {
12905         Expr *Arg = E->getArg(i);
12906         QualType ArgType = Arg->getType();
12907         if (E->isLValue()) {
12908           ArgType = S.Context.getLValueReferenceType(ArgType);
12909         } else if (E->isXValue()) {
12910           ArgType = S.Context.getRValueReferenceType(ArgType);
12911         }
12912         ArgTypes.push_back(ArgType);
12913       }
12914       ParamTypes = ArgTypes;
12915     }
12916     DestType = S.Context.getFunctionType(DestType, ParamTypes,
12917                                          Proto->getExtProtoInfo());
12918   } else {
12919     DestType = S.Context.getFunctionNoProtoType(DestType,
12920                                                 FnType->getExtInfo());
12921   }
12922 
12923   // Rebuild the appropriate pointer-to-function type.
12924   switch (Kind) {
12925   case FK_MemberFunction:
12926     // Nothing to do.
12927     break;
12928 
12929   case FK_FunctionPointer:
12930     DestType = S.Context.getPointerType(DestType);
12931     break;
12932 
12933   case FK_BlockPointer:
12934     DestType = S.Context.getBlockPointerType(DestType);
12935     break;
12936   }
12937 
12938   // Finally, we can recurse.
12939   ExprResult CalleeResult = Visit(CalleeExpr);
12940   if (!CalleeResult.isUsable()) return ExprError();
12941   E->setCallee(CalleeResult.take());
12942 
12943   // Bind a temporary if necessary.
12944   return S.MaybeBindToTemporary(E);
12945 }
12946 
12947 ExprResult RebuildUnknownAnyExpr::VisitObjCMessageExpr(ObjCMessageExpr *E) {
12948   // Verify that this is a legal result type of a call.
12949   if (DestType->isArrayType() || DestType->isFunctionType()) {
12950     S.Diag(E->getExprLoc(), diag::err_func_returning_array_function)
12951       << DestType->isFunctionType() << DestType;
12952     return ExprError();
12953   }
12954 
12955   // Rewrite the method result type if available.
12956   if (ObjCMethodDecl *Method = E->getMethodDecl()) {
12957     assert(Method->getResultType() == S.Context.UnknownAnyTy);
12958     Method->setResultType(DestType);
12959   }
12960 
12961   // Change the type of the message.
12962   E->setType(DestType.getNonReferenceType());
12963   E->setValueKind(Expr::getValueKindForType(DestType));
12964 
12965   return S.MaybeBindToTemporary(E);
12966 }
12967 
12968 ExprResult RebuildUnknownAnyExpr::VisitImplicitCastExpr(ImplicitCastExpr *E) {
12969   // The only case we should ever see here is a function-to-pointer decay.
12970   if (E->getCastKind() == CK_FunctionToPointerDecay) {
12971     assert(E->getValueKind() == VK_RValue);
12972     assert(E->getObjectKind() == OK_Ordinary);
12973 
12974     E->setType(DestType);
12975 
12976     // Rebuild the sub-expression as the pointee (function) type.
12977     DestType = DestType->castAs<PointerType>()->getPointeeType();
12978 
12979     ExprResult Result = Visit(E->getSubExpr());
12980     if (!Result.isUsable()) return ExprError();
12981 
12982     E->setSubExpr(Result.take());
12983     return S.Owned(E);
12984   } else if (E->getCastKind() == CK_LValueToRValue) {
12985     assert(E->getValueKind() == VK_RValue);
12986     assert(E->getObjectKind() == OK_Ordinary);
12987 
12988     assert(isa<BlockPointerType>(E->getType()));
12989 
12990     E->setType(DestType);
12991 
12992     // The sub-expression has to be a lvalue reference, so rebuild it as such.
12993     DestType = S.Context.getLValueReferenceType(DestType);
12994 
12995     ExprResult Result = Visit(E->getSubExpr());
12996     if (!Result.isUsable()) return ExprError();
12997 
12998     E->setSubExpr(Result.take());
12999     return S.Owned(E);
13000   } else {
13001     llvm_unreachable("Unhandled cast type!");
13002   }
13003 }
13004 
13005 ExprResult RebuildUnknownAnyExpr::resolveDecl(Expr *E, ValueDecl *VD) {
13006   ExprValueKind ValueKind = VK_LValue;
13007   QualType Type = DestType;
13008 
13009   // We know how to make this work for certain kinds of decls:
13010 
13011   //  - functions
13012   if (FunctionDecl *FD = dyn_cast<FunctionDecl>(VD)) {
13013     if (const PointerType *Ptr = Type->getAs<PointerType>()) {
13014       DestType = Ptr->getPointeeType();
13015       ExprResult Result = resolveDecl(E, VD);
13016       if (Result.isInvalid()) return ExprError();
13017       return S.ImpCastExprToType(Result.take(), Type,
13018                                  CK_FunctionToPointerDecay, VK_RValue);
13019     }
13020 
13021     if (!Type->isFunctionType()) {
13022       S.Diag(E->getExprLoc(), diag::err_unknown_any_function)
13023         << VD << E->getSourceRange();
13024       return ExprError();
13025     }
13026 
13027     if (CXXMethodDecl *MD = dyn_cast<CXXMethodDecl>(FD))
13028       if (MD->isInstance()) {
13029         ValueKind = VK_RValue;
13030         Type = S.Context.BoundMemberTy;
13031       }
13032 
13033     // Function references aren't l-values in C.
13034     if (!S.getLangOpts().CPlusPlus)
13035       ValueKind = VK_RValue;
13036 
13037   //  - variables
13038   } else if (isa<VarDecl>(VD)) {
13039     if (const ReferenceType *RefTy = Type->getAs<ReferenceType>()) {
13040       Type = RefTy->getPointeeType();
13041     } else if (Type->isFunctionType()) {
13042       S.Diag(E->getExprLoc(), diag::err_unknown_any_var_function_type)
13043         << VD << E->getSourceRange();
13044       return ExprError();
13045     }
13046 
13047   //  - nothing else
13048   } else {
13049     S.Diag(E->getExprLoc(), diag::err_unsupported_unknown_any_decl)
13050       << VD << E->getSourceRange();
13051     return ExprError();
13052   }
13053 
13054   // Modifying the declaration like this is friendly to IR-gen but
13055   // also really dangerous.
13056   VD->setType(DestType);
13057   E->setType(Type);
13058   E->setValueKind(ValueKind);
13059   return S.Owned(E);
13060 }
13061 
13062 /// Check a cast of an unknown-any type.  We intentionally only
13063 /// trigger this for C-style casts.
13064 ExprResult Sema::checkUnknownAnyCast(SourceRange TypeRange, QualType CastType,
13065                                      Expr *CastExpr, CastKind &CastKind,
13066                                      ExprValueKind &VK, CXXCastPath &Path) {
13067   // Rewrite the casted expression from scratch.
13068   ExprResult result = RebuildUnknownAnyExpr(*this, CastType).Visit(CastExpr);
13069   if (!result.isUsable()) return ExprError();
13070 
13071   CastExpr = result.take();
13072   VK = CastExpr->getValueKind();
13073   CastKind = CK_NoOp;
13074 
13075   return CastExpr;
13076 }
13077 
13078 ExprResult Sema::forceUnknownAnyToType(Expr *E, QualType ToType) {
13079   return RebuildUnknownAnyExpr(*this, ToType).Visit(E);
13080 }
13081 
13082 ExprResult Sema::checkUnknownAnyArg(SourceLocation callLoc,
13083                                     Expr *arg, QualType &paramType) {
13084   // If the syntactic form of the argument is not an explicit cast of
13085   // any sort, just do default argument promotion.
13086   ExplicitCastExpr *castArg = dyn_cast<ExplicitCastExpr>(arg->IgnoreParens());
13087   if (!castArg) {
13088     ExprResult result = DefaultArgumentPromotion(arg);
13089     if (result.isInvalid()) return ExprError();
13090     paramType = result.get()->getType();
13091     return result;
13092   }
13093 
13094   // Otherwise, use the type that was written in the explicit cast.
13095   assert(!arg->hasPlaceholderType());
13096   paramType = castArg->getTypeAsWritten();
13097 
13098   // Copy-initialize a parameter of that type.
13099   InitializedEntity entity =
13100     InitializedEntity::InitializeParameter(Context, paramType,
13101                                            /*consumed*/ false);
13102   return PerformCopyInitialization(entity, callLoc, Owned(arg));
13103 }
13104 
13105 static ExprResult diagnoseUnknownAnyExpr(Sema &S, Expr *E) {
13106   Expr *orig = E;
13107   unsigned diagID = diag::err_uncasted_use_of_unknown_any;
13108   while (true) {
13109     E = E->IgnoreParenImpCasts();
13110     if (CallExpr *call = dyn_cast<CallExpr>(E)) {
13111       E = call->getCallee();
13112       diagID = diag::err_uncasted_call_of_unknown_any;
13113     } else {
13114       break;
13115     }
13116   }
13117 
13118   SourceLocation loc;
13119   NamedDecl *d;
13120   if (DeclRefExpr *ref = dyn_cast<DeclRefExpr>(E)) {
13121     loc = ref->getLocation();
13122     d = ref->getDecl();
13123   } else if (MemberExpr *mem = dyn_cast<MemberExpr>(E)) {
13124     loc = mem->getMemberLoc();
13125     d = mem->getMemberDecl();
13126   } else if (ObjCMessageExpr *msg = dyn_cast<ObjCMessageExpr>(E)) {
13127     diagID = diag::err_uncasted_call_of_unknown_any;
13128     loc = msg->getSelectorStartLoc();
13129     d = msg->getMethodDecl();
13130     if (!d) {
13131       S.Diag(loc, diag::err_uncasted_send_to_unknown_any_method)
13132         << static_cast<unsigned>(msg->isClassMessage()) << msg->getSelector()
13133         << orig->getSourceRange();
13134       return ExprError();
13135     }
13136   } else {
13137     S.Diag(E->getExprLoc(), diag::err_unsupported_unknown_any_expr)
13138       << E->getSourceRange();
13139     return ExprError();
13140   }
13141 
13142   S.Diag(loc, diagID) << d << orig->getSourceRange();
13143 
13144   // Never recoverable.
13145   return ExprError();
13146 }
13147 
13148 /// Check for operands with placeholder types and complain if found.
13149 /// Returns true if there was an error and no recovery was possible.
13150 ExprResult Sema::CheckPlaceholderExpr(Expr *E) {
13151   const BuiltinType *placeholderType = E->getType()->getAsPlaceholderType();
13152   if (!placeholderType) return Owned(E);
13153 
13154   switch (placeholderType->getKind()) {
13155 
13156   // Overloaded expressions.
13157   case BuiltinType::Overload: {
13158     // Try to resolve a single function template specialization.
13159     // This is obligatory.
13160     ExprResult result = Owned(E);
13161     if (ResolveAndFixSingleFunctionTemplateSpecialization(result, false)) {
13162       return result;
13163 
13164     // If that failed, try to recover with a call.
13165     } else {
13166       tryToRecoverWithCall(result, PDiag(diag::err_ovl_unresolvable),
13167                            /*complain*/ true);
13168       return result;
13169     }
13170   }
13171 
13172   // Bound member functions.
13173   case BuiltinType::BoundMember: {
13174     ExprResult result = Owned(E);
13175     tryToRecoverWithCall(result, PDiag(diag::err_bound_member_function),
13176                          /*complain*/ true);
13177     return result;
13178   }
13179 
13180   // ARC unbridged casts.
13181   case BuiltinType::ARCUnbridgedCast: {
13182     Expr *realCast = stripARCUnbridgedCast(E);
13183     diagnoseARCUnbridgedCast(realCast);
13184     return Owned(realCast);
13185   }
13186 
13187   // Expressions of unknown type.
13188   case BuiltinType::UnknownAny:
13189     return diagnoseUnknownAnyExpr(*this, E);
13190 
13191   // Pseudo-objects.
13192   case BuiltinType::PseudoObject:
13193     return checkPseudoObjectRValue(E);
13194 
13195   case BuiltinType::BuiltinFn:
13196     Diag(E->getLocStart(), diag::err_builtin_fn_use);
13197     return ExprError();
13198 
13199   // Everything else should be impossible.
13200 #define BUILTIN_TYPE(Id, SingletonId) \
13201   case BuiltinType::Id:
13202 #define PLACEHOLDER_TYPE(Id, SingletonId)
13203 #include "clang/AST/BuiltinTypes.def"
13204     break;
13205   }
13206 
13207   llvm_unreachable("invalid placeholder type!");
13208 }
13209 
13210 bool Sema::CheckCaseExpression(Expr *E) {
13211   if (E->isTypeDependent())
13212     return true;
13213   if (E->isValueDependent() || E->isIntegerConstantExpr(Context))
13214     return E->getType()->isIntegralOrEnumerationType();
13215   return false;
13216 }
13217 
13218 /// ActOnObjCBoolLiteral - Parse {__objc_yes,__objc_no} literals.
13219 ExprResult
13220 Sema::ActOnObjCBoolLiteral(SourceLocation OpLoc, tok::TokenKind Kind) {
13221   assert((Kind == tok::kw___objc_yes || Kind == tok::kw___objc_no) &&
13222          "Unknown Objective-C Boolean value!");
13223   QualType BoolT = Context.ObjCBuiltinBoolTy;
13224   if (!Context.getBOOLDecl()) {
13225     LookupResult Result(*this, &Context.Idents.get("BOOL"), OpLoc,
13226                         Sema::LookupOrdinaryName);
13227     if (LookupName(Result, getCurScope()) && Result.isSingleResult()) {
13228       NamedDecl *ND = Result.getFoundDecl();
13229       if (TypedefDecl *TD = dyn_cast<TypedefDecl>(ND))
13230         Context.setBOOLDecl(TD);
13231     }
13232   }
13233   if (Context.getBOOLDecl())
13234     BoolT = Context.getBOOLType();
13235   return Owned(new (Context) ObjCBoolLiteralExpr(Kind == tok::kw___objc_yes,
13236                                         BoolT, OpLoc));
13237 }
13238