diff options
Diffstat (limited to 'clang/lib/AST/ASTContext.cpp')
| -rw-r--r-- | clang/lib/AST/ASTContext.cpp | 9 | 
1 files changed, 3 insertions, 6 deletions
| diff --git a/clang/lib/AST/ASTContext.cpp b/clang/lib/AST/ASTContext.cpp index 3fd58ce9fdf..f9cc06987b6 100644 --- a/clang/lib/AST/ASTContext.cpp +++ b/clang/lib/AST/ASTContext.cpp @@ -1913,7 +1913,7 @@ ASTContext::getFunctionType(QualType ResultTy,      return QualType(FTP, 0);    // Determine whether the type being created is already canonical or not. -  bool isCanonical = !EPI.HasExceptionSpec && ResultTy.isCanonical(); +  bool isCanonical= EPI.ExceptionSpecType == EST_None && ResultTy.isCanonical();    for (unsigned i = 0; i != NumArgs && isCanonical; ++i)      if (!ArgArray[i].isCanonicalAsParam())        isCanonical = false; @@ -1932,11 +1932,8 @@ ASTContext::getFunctionType(QualType ResultTy,        CanonicalArgs.push_back(getCanonicalParamType(ArgArray[i]));      FunctionProtoType::ExtProtoInfo CanonicalEPI = EPI; -    if (CanonicalEPI.HasExceptionSpec) { -      CanonicalEPI.HasExceptionSpec = false; -      CanonicalEPI.HasAnyExceptionSpec = false; -      CanonicalEPI.NumExceptions = 0; -    } +    CanonicalEPI.ExceptionSpecType = EST_None; +    CanonicalEPI.NumExceptions = 0;      CanonicalEPI.ExtInfo        = CanonicalEPI.ExtInfo.withCallingConv(getCanonicalCallConv(CallConv)); | 

