From: Fariborz Jahanian Date: Wed, 11 Feb 2009 23:59:18 +0000 (+0000) Subject: Last @encode'ing fix for objc2's nonfragile abi. X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=c657eba43f0159bd81227fa0812b92a0b03f00d0;p=clang Last @encode'ing fix for objc2's nonfragile abi. All relevant dejagnu enocding tests pass in this mode. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@64341 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/AST/ASTContext.cpp b/lib/AST/ASTContext.cpp index 1184710041..46b88df153 100644 --- a/lib/AST/ASTContext.cpp +++ b/lib/AST/ASTContext.cpp @@ -1915,15 +1915,18 @@ void ASTContext::getObjCEncodingForPropertyDecl(const ObjCPropertyDecl *PD, /// getLegacyIntegralTypeEncoding - /// Another legacy compatibility encoding: 32-bit longs are encoded as -/// 'l' or 'L', but not always. For typedefs, we need to use +/// 'l' or 'L' , but not always. For typedefs, we need to use /// 'i' or 'I' instead if encoding a struct field, or a pointer! /// void ASTContext::getLegacyIntegralTypeEncoding (QualType &PointeeTy) const { if (dyn_cast(PointeeTy.getTypePtr())) { if (const BuiltinType *BT = PointeeTy->getAsBuiltinType()) { - if (BT->getKind() == BuiltinType::ULong) + if (BT->getKind() == BuiltinType::ULong && + ((const_cast(this))->getIntWidth(PointeeTy) == 32)) PointeeTy = UnsignedIntTy; - else if (BT->getKind() == BuiltinType::Long) + else + if (BT->getKind() == BuiltinType::Long && + ((const_cast(this))->getIntWidth(PointeeTy) == 32)) PointeeTy = IntTy; } }