forked from OSchip/llvm-project
Highlight the offending function parameter when the format argument refers to an invalid function parameter type.
llvm-svn: 214723
This commit is contained in:
parent
2f9e88b9f2
commit
dfe8cc51c2
|
@ -2545,23 +2545,24 @@ static void handleFormatAttr(Sema &S, Decl *D, const AttributeList &Attr) {
|
|||
if (Kind == CFStringFormat) {
|
||||
if (!isCFStringType(Ty, S.Context)) {
|
||||
S.Diag(Attr.getLoc(), diag::err_format_attribute_not)
|
||||
<< "a CFString" << IdxExpr->getSourceRange();
|
||||
<< "a CFString" << IdxExpr->getSourceRange()
|
||||
<< getFunctionOrMethodParamRange(D, ArgIdx);
|
||||
return;
|
||||
}
|
||||
} else if (Kind == NSStringFormat) {
|
||||
// FIXME: do we need to check if the type is NSString*? What are the
|
||||
// semantics?
|
||||
if (!isNSStringType(Ty, S.Context)) {
|
||||
// FIXME: Should highlight the actual expression that has the wrong type.
|
||||
S.Diag(Attr.getLoc(), diag::err_format_attribute_not)
|
||||
<< "an NSString" << IdxExpr->getSourceRange();
|
||||
<< "an NSString" << IdxExpr->getSourceRange()
|
||||
<< getFunctionOrMethodParamRange(D, ArgIdx);
|
||||
return;
|
||||
}
|
||||
} else if (!Ty->isPointerType() ||
|
||||
!Ty->getAs<PointerType>()->getPointeeType()->isCharType()) {
|
||||
// FIXME: Should highlight the actual expression that has the wrong type.
|
||||
S.Diag(Attr.getLoc(), diag::err_format_attribute_not)
|
||||
<< "a string type" << IdxExpr->getSourceRange();
|
||||
<< "a string type" << IdxExpr->getSourceRange()
|
||||
<< getFunctionOrMethodParamRange(D, ArgIdx);
|
||||
return;
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in New Issue