<div dir="ltr">On Wed, Nov 20, 2013 at 1:41 PM, Aaron Ballman <span dir="ltr"><<a href="mailto:aaron@aaronballman.com" target="_blank">aaron@aaronballman.com</a>></span> wrote:<br><div class="gmail_extra"><div class="gmail_quote">
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Author: aaronballman<br>
Date: Wed Nov 20 15:41:42 2013<br>
New Revision: 195275<br>
<br>
URL: <a href="http://llvm.org/viewvc/llvm-project?rev=195275&view=rev" target="_blank">http://llvm.org/viewvc/llvm-project?rev=195275&view=rev</a><br>
Log:<br>
Removed a duplicate diagnostic related to attribute subjects for thread safety annotations, and replaced it with the more general attribute diagnostic. Updated the test case in the one instance where wording changed. No functional change intended.<br>
</blockquote><div><br></div><div>This introduces a functional change: the warning flag to suppress this warning has changed.</div><div><br></div><div>Delesley: Does that matter? We'd ideally like to be able to factor out the subject checking from the handlers for individual attributes, and this is a step on that path.</div>
<div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
Modified:<br>
cfe/trunk/include/clang/Basic/DiagnosticSemaKinds.td<br>
cfe/trunk/lib/Sema/SemaDeclAttr.cpp<br>
cfe/trunk/test/SemaCXX/warn-thread-safety-parsing.cpp<br>
<br>
Modified: cfe/trunk/include/clang/Basic/DiagnosticSemaKinds.td<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/cfe/trunk/include/clang/Basic/DiagnosticSemaKinds.td?rev=195275&r1=195274&r2=195275&view=diff" target="_blank">http://llvm.org/viewvc/llvm-project/cfe/trunk/include/clang/Basic/DiagnosticSemaKinds.td?rev=195275&r1=195274&r2=195275&view=diff</a><br>
==============================================================================<br>
--- cfe/trunk/include/clang/Basic/DiagnosticSemaKinds.td (original)<br>
+++ cfe/trunk/include/clang/Basic/DiagnosticSemaKinds.td Wed Nov 20 15:41:42 2013<br>
@@ -2136,11 +2136,6 @@ def warn_thread_attribute_decl_not_locka<br>
def warn_thread_attribute_decl_not_pointer : Warning<<br>
"'%0' only applies to pointer types; type here is %1">,<br>
InGroup<ThreadSafetyAttributes>, DefaultIgnore;<br>
-def warn_thread_attribute_wrong_decl_type : Warning<<br>
- "%0 attribute only applies to %select{"<br>
- "fields and global variables|functions and methods|"<br>
- "classes and structs}1">,<br>
- InGroup<ThreadSafetyAttributes>, DefaultIgnore;<br>
def err_attribute_argument_out_of_range : Error<<br>
"%0 attribute parameter %1 is out of bounds: "<br>
"%plural{0:no parameters to index into|"<br>
<br>
Modified: cfe/trunk/lib/Sema/SemaDeclAttr.cpp<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Sema/SemaDeclAttr.cpp?rev=195275&r1=195274&r2=195275&view=diff" target="_blank">http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Sema/SemaDeclAttr.cpp?rev=195275&r1=195274&r2=195275&view=diff</a><br>
==============================================================================<br>
--- cfe/trunk/lib/Sema/SemaDeclAttr.cpp (original)<br>
+++ cfe/trunk/lib/Sema/SemaDeclAttr.cpp Wed Nov 20 15:41:42 2013<br>
@@ -535,18 +535,12 @@ static void checkAttrArgsAreLockableObjs<br>
// least add some helper functions to check most argument patterns (#<br>
// and types of args).<br>
<br>
-enum ThreadAttributeDeclKind {<br>
- ThreadExpectedFieldOrGlobalVar,<br>
- ThreadExpectedFunctionOrMethod,<br>
- ThreadExpectedClassOrStruct<br>
-};<br>
-<br>
static bool checkGuardedVarAttrCommon(Sema &S, Decl *D,<br>
const AttributeList &Attr) {<br>
// D must be either a member field or global (potentially shared) variable.<br>
if (!mayBeSharedVariable(D)) {<br>
- S.Diag(Attr.getLoc(), diag::warn_thread_attribute_wrong_decl_type)<br>
- << Attr.getName() << ThreadExpectedFieldOrGlobalVar;<br>
+ S.Diag(Attr.getLoc(), diag::warn_attribute_wrong_decl_type)<br>
+ << Attr.getName() << ExpectedFieldOrGlobalVar;<br>
return false;<br>
}<br>
<br>
@@ -580,8 +574,8 @@ static bool checkGuardedByAttrCommon(Sem<br>
Expr* &Arg) {<br>
// D must be either a member field or global (potentially shared) variable.<br>
if (!mayBeSharedVariable(D)) {<br>
- S.Diag(Attr.getLoc(), diag::warn_thread_attribute_wrong_decl_type)<br>
- << Attr.getName() << ThreadExpectedFieldOrGlobalVar;<br>
+ S.Diag(Attr.getLoc(), diag::warn_attribute_wrong_decl_type)<br>
+ << Attr.getName() << ExpectedFieldOrGlobalVar;<br>
return false;<br>
}<br>
<br>
@@ -622,8 +616,8 @@ static bool checkLockableAttrCommon(Sema<br>
const AttributeList &Attr) {<br>
// FIXME: Lockable structs for C code.<br>
if (!isa<RecordDecl>(D)) {<br>
- S.Diag(Attr.getLoc(), diag::warn_thread_attribute_wrong_decl_type)<br>
- << Attr.getName() << ThreadExpectedClassOrStruct;<br>
+ S.Diag(Attr.getLoc(), diag::warn_attribute_wrong_decl_type)<br>
+ << Attr.getName() << ExpectedStructOrUnionOrClass;<br>
return false;<br>
}<br>
<br>
@@ -650,8 +644,8 @@ static void handleScopedLockableAttr(Sem<br>
static void handleNoThreadSafetyAnalysis(Sema &S, Decl *D,<br>
const AttributeList &Attr) {<br>
if (!isa<FunctionDecl>(D) && !isa<FunctionTemplateDecl>(D)) {<br>
- S.Diag(Attr.getLoc(), diag::warn_thread_attribute_wrong_decl_type)<br>
- << Attr.getName() << ThreadExpectedFunctionOrMethod;<br>
+ S.Diag(Attr.getLoc(), diag::warn_attribute_wrong_decl_type)<br>
+ << Attr.getName() << ExpectedFunctionOrMethod;<br>
return;<br>
}<br>
<br>
@@ -705,8 +699,8 @@ static bool checkAcquireOrderAttrCommon(<br>
// D must be either a member field or global (potentially shared) variable.<br>
ValueDecl *VD = dyn_cast<ValueDecl>(D);<br>
if (!VD || !mayBeSharedVariable(D)) {<br>
- S.Diag(Attr.getLoc(), diag::warn_thread_attribute_wrong_decl_type)<br>
- << Attr.getName() << ThreadExpectedFieldOrGlobalVar;<br>
+ S.Diag(Attr.getLoc(), diag::warn_attribute_wrong_decl_type)<br>
+ << Attr.getName() << ExpectedFieldOrGlobalVar;<br>
return false;<br>
}<br>
<br>
@@ -762,8 +756,8 @@ static bool checkLockFunAttrCommon(Sema<br>
<br>
// check that the attribute is applied to a function<br>
if (!isa<FunctionDecl>(D) && !isa<FunctionTemplateDecl>(D)) {<br>
- S.Diag(Attr.getLoc(), diag::warn_thread_attribute_wrong_decl_type)<br>
- << Attr.getName() << ThreadExpectedFunctionOrMethod;<br>
+ S.Diag(Attr.getLoc(), diag::warn_attribute_wrong_decl_type)<br>
+ << Attr.getName() << ExpectedFunctionOrMethod;<br>
return false;<br>
}<br>
<br>
@@ -835,8 +829,8 @@ static bool checkTryLockFunAttrCommon(Se<br>
return false;<br>
<br>
if (!isa<FunctionDecl>(D) && !isa<FunctionTemplateDecl>(D)) {<br>
- S.Diag(Attr.getLoc(), diag::warn_thread_attribute_wrong_decl_type)<br>
- << Attr.getName() << ThreadExpectedFunctionOrMethod;<br>
+ S.Diag(Attr.getLoc(), diag::warn_attribute_wrong_decl_type)<br>
+ << Attr.getName() << ExpectedFunctionOrMethod;<br>
return false;<br>
}<br>
<br>
@@ -885,8 +879,8 @@ static bool checkLocksRequiredCommon(Sem<br>
return false;<br>
<br>
if (!isa<FunctionDecl>(D) && !isa<FunctionTemplateDecl>(D)) {<br>
- S.Diag(Attr.getLoc(), diag::warn_thread_attribute_wrong_decl_type)<br>
- << Attr.getName() << ThreadExpectedFunctionOrMethod;<br>
+ S.Diag(Attr.getLoc(), diag::warn_attribute_wrong_decl_type)<br>
+ << Attr.getName() << ExpectedFunctionOrMethod;<br>
return false;<br>
}<br>
<br>
@@ -929,8 +923,8 @@ static void handleUnlockFunAttr(Sema &S,<br>
// zero or more arguments ok<br>
<br>
if (!isa<FunctionDecl>(D) && !isa<FunctionTemplateDecl>(D)) {<br>
- S.Diag(Attr.getLoc(), diag::warn_thread_attribute_wrong_decl_type)<br>
- << Attr.getName() << ThreadExpectedFunctionOrMethod;<br>
+ S.Diag(Attr.getLoc(), diag::warn_attribute_wrong_decl_type)<br>
+ << Attr.getName() << ExpectedFunctionOrMethod;<br>
return;<br>
}<br>
<br>
@@ -948,8 +942,8 @@ static void handleUnlockFunAttr(Sema &S,<br>
static void handleLockReturnedAttr(Sema &S, Decl *D,<br>
const AttributeList &Attr) {<br>
if (!isa<FunctionDecl>(D) && !isa<FunctionTemplateDecl>(D)) {<br>
- S.Diag(Attr.getLoc(), diag::warn_thread_attribute_wrong_decl_type)<br>
- << Attr.getName() << ThreadExpectedFunctionOrMethod;<br>
+ S.Diag(Attr.getLoc(), diag::warn_attribute_wrong_decl_type)<br>
+ << Attr.getName() << ExpectedFunctionOrMethod;<br>
return;<br>
}<br>
<br>
@@ -971,8 +965,8 @@ static void handleLocksExcludedAttr(Sema<br>
return;<br>
<br>
if (!isa<FunctionDecl>(D) && !isa<FunctionTemplateDecl>(D)) {<br>
- S.Diag(Attr.getLoc(), diag::warn_thread_attribute_wrong_decl_type)<br>
- << Attr.getName() << ThreadExpectedFunctionOrMethod;<br>
+ S.Diag(Attr.getLoc(), diag::warn_attribute_wrong_decl_type)<br>
+ << Attr.getName() << ExpectedFunctionOrMethod;<br>
return;<br>
}<br>
<br>
<br>
Modified: cfe/trunk/test/SemaCXX/warn-thread-safety-parsing.cpp<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/cfe/trunk/test/SemaCXX/warn-thread-safety-parsing.cpp?rev=195275&r1=195274&r2=195275&view=diff" target="_blank">http://llvm.org/viewvc/llvm-project/cfe/trunk/test/SemaCXX/warn-thread-safety-parsing.cpp?rev=195275&r1=195274&r2=195275&view=diff</a><br>
==============================================================================<br>
--- cfe/trunk/test/SemaCXX/warn-thread-safety-parsing.cpp (original)<br>
+++ cfe/trunk/test/SemaCXX/warn-thread-safety-parsing.cpp Wed Nov 20 15:41:42 2013<br>
@@ -229,28 +229,28 @@ class __attribute__((lockable (1))) LTes<br>
};<br>
<br>
void l_test_function() LOCKABLE; // \<br>
- // expected-warning {{'lockable' attribute only applies to classes}}<br>
+ // expected-warning {{'lockable' attribute only applies to struct, union or class}}<br>
<br>
int l_testfn(int y) {<br>
int x LOCKABLE = y; // \<br>
- // expected-warning {{'lockable' attribute only applies to classes}}<br>
+ // expected-warning {{'lockable' attribute only applies to struct, union or class}}<br>
return x;<br>
}<br>
<br>
int l_test_var LOCKABLE; // \<br>
- // expected-warning {{'lockable' attribute only applies to classes}}<br>
+ // expected-warning {{'lockable' attribute only applies to struct, union or class}}<br>
<br>
class LFoo {<br>
private:<br>
int test_field LOCKABLE; // \<br>
- // expected-warning {{'lockable' attribute only applies to classes}}<br>
+ // expected-warning {{'lockable' attribute only applies to struct, union or class}}<br>
void test_method() LOCKABLE; // \<br>
- // expected-warning {{'lockable' attribute only applies to classes}}<br>
+ // expected-warning {{'lockable' attribute only applies to struct, union or class}}<br>
};<br>
<br>
<br>
void l_function_params(int lvar LOCKABLE); // \<br>
- // expected-warning {{'lockable' attribute only applies to classes}}<br>
+ // expected-warning {{'lockable' attribute only applies to struct, union or class}}<br>
<br>
<br>
//-----------------------------------------//<br>
@@ -269,28 +269,28 @@ class __attribute__((scoped_lockable (1)<br>
};<br>
<br>
void sl_test_function() SCOPED_LOCKABLE; // \<br>
- // expected-warning {{'scoped_lockable' attribute only applies to classes}}<br>
+ // expected-warning {{'scoped_lockable' attribute only applies to struct, union or class}}<br>
<br>
int sl_testfn(int y) {<br>
int x SCOPED_LOCKABLE = y; // \<br>
- // expected-warning {{'scoped_lockable' attribute only applies to classes}}<br>
+ // expected-warning {{'scoped_lockable' attribute only applies to struct, union or class}}<br>
return x;<br>
}<br>
<br>
int sl_test_var SCOPED_LOCKABLE; // \<br>
- // expected-warning {{'scoped_lockable' attribute only applies to classes}}<br>
+ // expected-warning {{'scoped_lockable' attribute only applies to struct, union or class}}<br>
<br>
class SLFoo {<br>
private:<br>
int test_field SCOPED_LOCKABLE; // \<br>
- // expected-warning {{'scoped_lockable' attribute only applies to classes}}<br>
+ // expected-warning {{'scoped_lockable' attribute only applies to struct, union or class}}<br>
void test_method() SCOPED_LOCKABLE; // \<br>
- // expected-warning {{'scoped_lockable' attribute only applies to classes}}<br>
+ // expected-warning {{'scoped_lockable' attribute only applies to struct, union or class}}<br>
};<br>
<br>
<br>
void sl_function_params(int lvar SCOPED_LOCKABLE); // \<br>
- // expected-warning {{'scoped_lockable' attribute only applies to classes}}<br>
+ // expected-warning {{'scoped_lockable' attribute only applies to struct, union or class}}<br>
<br>
<br>
//-----------------------------------------//<br>
<br>
<br>
_______________________________________________<br>
cfe-commits mailing list<br>
<a href="mailto:cfe-commits@cs.uiuc.edu">cfe-commits@cs.uiuc.edu</a><br>
<a href="http://lists.cs.uiuc.edu/mailman/listinfo/cfe-commits" target="_blank">http://lists.cs.uiuc.edu/mailman/listinfo/cfe-commits</a><br>
</blockquote></div><br></div></div>