Patch for PR 7409 - only error on definition of invalid typedefs. Suppress errors for additional uses of this invalid typedef.

llvm-svn: 131043
This commit is contained in:
Richard Trieu 2011-05-07 01:36:37 +00:00
parent 63697e5025
commit de756fbbd7
2 changed files with 38 additions and 3 deletions

View File

@ -2568,9 +2568,13 @@ TreeTransform<Derived>::TransformNestedNameSpecifierLoc(
Q.getLocalEndLoc());
break;
}
SemaRef.Diag(TL.getBeginLoc(), diag::err_nested_name_spec_non_tag)
<< TL.getType() << SS.getRange();
// If the nested-name-specifier is an invalid type def, don't emit an
// error because a previous error should have already been emitted.
TypedefTypeLoc* TTL = dyn_cast<TypedefTypeLoc>(&TL);
if (!TTL || !TTL->getTypedefNameDecl()->isInvalidDecl()) {
SemaRef.Diag(TL.getBeginLoc(), diag::err_nested_name_spec_non_tag)
<< TL.getType() << SS.getRange();
}
return NestedNameSpecifierLoc();
}
}

View File

@ -71,3 +71,34 @@ struct C {
::Y<A>::type ip7 = &i;
::Y<B>::type ip8 = &i; // expected-note{{in instantiation of template class 'Y<B>' requested here}}
::Y<C>::type ip9 = &i; // expected-note{{in instantiation of template class 'Y<C>' requested here}}
template<typename T> struct D {
typedef typename T::foo foo; // expected-error {{type 'long' cannot be used prior to '::' because it has no members}}
typedef typename foo::bar bar;
};
D<long> struct_D; // expected-note {{in instantiation of template class 'D<long>' requested here}}
template<typename T> struct E {
typedef typename T::foo foo;
typedef typename foo::bar bar; // expected-error {{type 'foo' (aka 'double') cannot be used prior to '::' because it has no members}}
};
struct F {
typedef double foo;
};
E<F> struct_E; // expected-note {{in instantiation of template class 'E<F>' requested here}}
template<typename T> struct G {
typedef typename T::foo foo;
typedef typename foo::bar bar;
};
struct H {
struct foo {
typedef double bar;
};
};
G<H> struct_G;