Always treat 'main' as an extern "C" function, so that we detect

redeclarations of main appropriately rather than allowing it to be
overloaded. Also, disallowing declaring main as a template.

Fixes GCC DejaGNU g++.old-deja/g++.other/main1.C.


git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@117029 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Douglas Gregor 2010-10-21 16:57:46 +00:00
Родитель 9ee5ee84f0
Коммит 0bab54cf82
5 изменённых файлов: 13 добавлений и 2 удалений

Просмотреть файл

@ -229,6 +229,7 @@ def warn_unusual_main_decl : Warning<"'main' should not be declared "
"%select{static|inline|static or inline}0">;
def err_unusual_main_decl : Error<"'main' is not allowed to be declared "
"%select{static|inline|static or inline}0">;
def err_main_template_decl : Error<"'main' cannot be a template">;
def err_main_returns_nonint : Error<"'main' must return 'int'">;
def err_main_surplus_args : Error<"too many parameters (%0) for 'main': "
"must be 0, 2, or 3">;

Просмотреть файл

@ -964,7 +964,7 @@ public:
Ovl_NonFunction
};
OverloadKind CheckOverload(Scope *S,
FunctionDecl *New,
FunctionDecl *New,
const LookupResult &OldDecls,
NamedDecl *&OldDecl,
bool IsForUsingDecl);

Просмотреть файл

@ -1001,7 +1001,7 @@ bool FunctionDecl::isExternC() const {
break;
}
return false;
return isMain();
}
bool FunctionDecl::isGlobal() const {

Просмотреть файл

@ -4182,6 +4182,11 @@ void Sema::CheckMain(FunctionDecl* FD) {
if (nparams == 1 && !FD->isInvalidDecl()) {
Diag(FD->getLocation(), diag::warn_main_one_arg);
}
if (!FD->isInvalidDecl() && FD->getDescribedFunctionTemplate()) {
Diag(FD->getLocation(), diag::err_main_template_decl);
FD->setInvalidDecl();
}
}
bool Sema::CheckForConstantInitializer(Expr *Init, QualType DclT) {

Просмотреть файл

@ -0,0 +1,5 @@
// RUN: %clang_cc1 -fsyntax-only -verify %s
template<typename T>
int main() { } // expected-error{{'main' cannot be a template}}