diff options
| author | Anton Korobeynikov <asl@math.spbu.ru> | 2008-12-23 22:24:07 +0000 |
|---|---|---|
| committer | Anton Korobeynikov <asl@math.spbu.ru> | 2008-12-23 22:24:07 +0000 |
| commit | 484f05e14d32e1b85740d38d9ede4bca4609d465 (patch) | |
| tree | 2669527c4563b0b971f0e118607d7650fda029d3 /clang/lib/Sema/SemaDeclAttr.cpp | |
| parent | 17eb26bc4e286ecd6cdb5c8f778baa258221e3cb (diff) | |
| download | bcm5719-llvm-484f05e14d32e1b85740d38d9ede4bca4609d465.tar.gz bcm5719-llvm-484f05e14d32e1b85740d38d9ede4bca4609d465.zip | |
Sema for fastcall/stdcall stuff. Tests will follow.
Patch by Ilya Okonsky!
llvm-svn: 61394
Diffstat (limited to 'clang/lib/Sema/SemaDeclAttr.cpp')
| -rw-r--r-- | clang/lib/Sema/SemaDeclAttr.cpp | 39 |
1 files changed, 33 insertions, 6 deletions
diff --git a/clang/lib/Sema/SemaDeclAttr.cpp b/clang/lib/Sema/SemaDeclAttr.cpp index 7275589c8cf..81283a85606 100644 --- a/clang/lib/Sema/SemaDeclAttr.cpp +++ b/clang/lib/Sema/SemaDeclAttr.cpp @@ -684,7 +684,7 @@ static void HandleDLLImportAttr(Decl *d, const AttributeList &Attr, Sema &S) { S.Diag(Attr.getLoc(), diag::err_attribute_wrong_number_arguments) << 0; return; } - + d->addAttr(new DLLImportAttr()); } @@ -694,27 +694,54 @@ static void HandleDLLExportAttr(Decl *d, const AttributeList &Attr, Sema &S) { S.Diag(Attr.getLoc(), diag::err_attribute_wrong_number_arguments) << 0; return; } - + d->addAttr(new DLLExportAttr()); } static void HandleStdCallAttr(Decl *d, const AttributeList &Attr, Sema &S) { - // check the attribute arguments. + // Attribute has no arguments. if (Attr.getNumArgs() != 0) { S.Diag(Attr.getLoc(), diag::err_attribute_wrong_number_arguments) << 0; return; } - + + // Attribute can be applied only to functions. + if (!isa<FunctionDecl>(d)) { + S.Diag(Attr.getLoc(), diag::warn_attribute_wrong_decl_type) + << "stdcall" << "function"; + return; + } + + // stdcall and fastcall attributes are mutually incompatible. + if (d->getAttr<FastCallAttr>()) { + S.Diag(Attr.getLoc(), diag::err_attributes_are_not_compatible) + << "stdcall" << "fastcall"; + return; + } + d->addAttr(new StdCallAttr()); } static void HandleFastCallAttr(Decl *d, const AttributeList &Attr, Sema &S) { - // check the attribute arguments. + // Attribute has no arguments. if (Attr.getNumArgs() != 0) { S.Diag(Attr.getLoc(), diag::err_attribute_wrong_number_arguments) << 0; return; } - + + if (!isa<FunctionDecl>(d)) { + S.Diag(Attr.getLoc(), diag::warn_attribute_wrong_decl_type) + << "fastcall" << "function"; + return; + } + + // stdcall and fastcall attributes are mutually incompatible. + if (d->getAttr<StdCallAttr>()) { + S.Diag(Attr.getLoc(), diag::err_attributes_are_not_compatible) + << "fastcall" << "stdcall"; + return; + } + d->addAttr(new FastCallAttr()); } |

