зеркало из https://github.com/microsoft/clang-1.git
Reject typedef redefinitions when the underlying types are not identical,
even if in a system header etc. rdar://6079937 git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@54038 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Родитель
806c3b9478
Коммит
99cb9976ef
|
@ -739,6 +739,8 @@ DIAG(err_non_static_static, ERROR,
|
||||||
"non-static declaration of '%0' follows static declaration")
|
"non-static declaration of '%0' follows static declaration")
|
||||||
DIAG(err_redefinition_different_kind, ERROR,
|
DIAG(err_redefinition_different_kind, ERROR,
|
||||||
"redefinition of '%0' as different kind of symbol")
|
"redefinition of '%0' as different kind of symbol")
|
||||||
|
DIAG(err_redefinition_different_typedef, ERROR,
|
||||||
|
"typedef redefinition with different types ('%0' vs '%1')")
|
||||||
DIAG(err_conflicting_types, ERROR,
|
DIAG(err_conflicting_types, ERROR,
|
||||||
"conflicting types for '%0'")
|
"conflicting types for '%0'")
|
||||||
DIAG(err_nested_redefinition, ERROR,
|
DIAG(err_nested_redefinition, ERROR,
|
||||||
|
|
|
@ -248,6 +248,18 @@ TypedefDecl *Sema::MergeTypeDefDecl(TypedefDecl *New, Decl *OldD) {
|
||||||
return New;
|
return New;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// If the typedef types are not identical, reject them in all languages and
|
||||||
|
// with any extensions enabled.
|
||||||
|
if (Old->getUnderlyingType() != New->getUnderlyingType() &&
|
||||||
|
Context.getCanonicalType(Old->getUnderlyingType()) !=
|
||||||
|
Context.getCanonicalType(New->getUnderlyingType())) {
|
||||||
|
Diag(New->getLocation(), diag::err_redefinition_different_typedef,
|
||||||
|
New->getUnderlyingType().getAsString(),
|
||||||
|
Old->getUnderlyingType().getAsString());
|
||||||
|
Diag(Old->getLocation(), diag::err_previous_definition);
|
||||||
|
return Old;
|
||||||
|
}
|
||||||
|
|
||||||
// Allow multiple definitions for ObjC built-in typedefs.
|
// Allow multiple definitions for ObjC built-in typedefs.
|
||||||
// FIXME: Verify the underlying types are equivalent!
|
// FIXME: Verify the underlying types are equivalent!
|
||||||
if (getLangOptions().ObjC1 && isBuiltinObjCType(New))
|
if (getLangOptions().ObjC1 && isBuiltinObjCType(New))
|
||||||
|
|
|
@ -1,4 +1,13 @@
|
||||||
// RUN: clang < %s -fsyntax-only -verify
|
// RUN: clang < %s -fsyntax-only -verify
|
||||||
|
|
||||||
|
// size_t coming from a system header.
|
||||||
#include <stddef.h>
|
#include <stddef.h>
|
||||||
typedef unsigned long size_t;
|
typedef __SIZE_TYPE__ size_t;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
typedef const int x; // expected-error {{previous definition is here}}
|
||||||
|
extern x a;
|
||||||
|
typedef int x; // expected-error {{typedef redefinition with different types}}
|
||||||
|
extern x a;
|
||||||
|
|
||||||
|
|
Загрузка…
Ссылка в новой задаче