aboutsummaryrefslogtreecommitdiff
path: root/lib/Sema/SemaOverload.cpp
diff options
context:
space:
mode:
authorAnders Carlsson <andersca@mac.com>2009-08-27 16:01:18 +0000
committerAnders Carlsson <andersca@mac.com>2009-08-27 16:01:18 +0000
commit19377389530101d583955537729e8889d487d59e (patch)
treef0f683908f04e8c4e311d84742e1517d1343605e /lib/Sema/SemaOverload.cpp
parent1d8bdd34101651e5ffca93486f9f4034eb0a564f (diff)
Add a OverloadResolutionFlags and start converting some of the overload methods over to using it instead of bools arguments.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@80248 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Sema/SemaOverload.cpp')
-rw-r--r--lib/Sema/SemaOverload.cpp18
1 files changed, 11 insertions, 7 deletions
diff --git a/lib/Sema/SemaOverload.cpp b/lib/Sema/SemaOverload.cpp
index dde5c28723..2c8c731797 100644
--- a/lib/Sema/SemaOverload.cpp
+++ b/lib/Sema/SemaOverload.cpp
@@ -408,10 +408,11 @@ Sema::IsOverload(FunctionDecl *New, Decl* OldD,
/// If @p ForceRValue, then overloading is performed as if From was an rvalue,
/// no matter its actual lvalueness.
ImplicitConversionSequence
-Sema::TryImplicitConversion(Expr* From, QualType ToType,
- bool SuppressUserConversions,
- bool AllowExplicit, bool ForceRValue)
-{
+Sema::TryImplicitConversion(Expr* From, QualType ToType, unsigned Flags) {
+ bool SuppressUserConversions = Flags & ORF_SuppressUserConversions;
+ bool AllowExplicit = Flags & ORF_AllowExplicit;
+ bool ForceRValue = Flags & ORF_ForceRValue;
+
ImplicitConversionSequence ICS;
if (IsStandardConversion(From, ToType, ICS.Standard))
ICS.ConversionKind = ImplicitConversionSequence::StandardConversion;
@@ -1929,8 +1930,11 @@ Sema::TryCopyInitialization(Expr *From, QualType ToType,
/*AllowExplicit=*/false, ForceRValue);
return ICS;
} else {
- return TryImplicitConversion(From, ToType, SuppressUserConversions,
- ForceRValue);
+ unsigned Flags = ORF_None;
+ if (SuppressUserConversions) Flags |= ORF_SuppressUserConversions;
+ if (ForceRValue) Flags |= ORF_ForceRValue;
+
+ return TryImplicitConversion(From, ToType, Flags);
}
}
@@ -2064,7 +2068,7 @@ Sema::PerformObjectArgumentInitialization(Expr *&From, CXXMethodDecl *Method) {
/// TryContextuallyConvertToBool - Attempt to contextually convert the
/// expression From to bool (C++0x [conv]p3).
ImplicitConversionSequence Sema::TryContextuallyConvertToBool(Expr *From) {
- return TryImplicitConversion(From, Context.BoolTy, false, true);
+ return TryImplicitConversion(From, Context.BoolTy, ORF_AllowExplicit);
}
/// PerformContextuallyConvertToBool - Perform a contextual conversion