}
if (ImplicitCastExpr *ImpCast = dyn_cast<ImplicitCastExpr>(Expr)) {
- ImpCast->setType(Ty);
- ImpCast->setLvalueCast(isLvalue);
- } else
- Expr = new (Context) ImplicitCastExpr(Ty, Kind, Expr, isLvalue);
+ if (ImpCast->getCastKind() == Kind) {
+ ImpCast->setType(Ty);
+ ImpCast->setLvalueCast(isLvalue);
+ return;
+ }
+ }
+
+ Expr = new (Context) ImplicitCastExpr(Ty, Kind, Expr, isLvalue);
}
void Sema::DeleteExpr(ExprTy *E) {
if (CastArg.isInvalid())
return true;
- From = new (Context) ImplicitCastExpr(ToType.getNonReferenceType(),
- CastKind, CastArg.takeAs<Expr>(),
- ToType->isLValueReferenceType());
+ QualType CastArgType = ((Expr *)CastArg.get())->getType();
+ From =
+ new (Context) ImplicitCastExpr(CastArgType, CastKind,
+ CastArg.takeAs<Expr>(),
+ CastArgType->isLValueReferenceType());
+ if (PerformImplicitConversion(From, ToType.getNonReferenceType(),
+ ICS.UserDefined.After, "converting"))
+ return true;
+
return false;
}