|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| | llvm-svn: 140367 | 
| | 
| 
| 
| 
| 
| 
| 
| | that this flag must be used only for Microsoft extensions and not emulation; to avoid confusion with the new LangOptions::MicrosoftMode flag.
Many of the code now under LangOptions::MicrosoftExt will eventually be moved under the LangOptions::MicrosoftMode flag.
llvm-svn: 139987 | 
| | 
| 
| 
| | llvm-svn: 132878 | 
| | 
| 
| 
| | llvm-svn: 131950 | 
| | 
| 
| 
| | llvm-svn: 131722 | 
| | 
| 
| 
| 
| 
| | for destructors until the class is complete and destructors have been adjusted.
llvm-svn: 131632 | 
| | 
| 
| 
| 
| 
| | warnings I introduced lately.
llvm-svn: 129986 | 
| | 
| 
| 
| 
| 
| 
| 
| | MSVC doesn't do any validation on exception specifications.
This remove 1 error when parsing MSVC stl lib with clang.
llvm-svn: 127961 | 
| | 
| 
| 
| | llvm-svn: 127692 | 
| | 
| 
| 
| 
| 
| | operator new in C++0x.
llvm-svn: 127688 | 
| | 
| 
| 
| 
| 
| | noexcept specifiers, unique FunctionProtoTypes with a ContextualFoldingSet, as suggested by John McCall.
llvm-svn: 127568 | 
| | 
| 
| 
| 
| 
| 
| 
| | Change the interface to expose the new information and deal with the enormous fallout.
Introduce the new ExceptionSpecificationType value EST_DynamicNone to more easily deal with empty throw specifications.
Update the tests for noexcept and fix the various bugs uncovered, such as lack of tentative parsing support.
llvm-svn: 127537 | 
| | 
| 
| 
| | llvm-svn: 127536 | 
| | 
| 
| 
| 
| 
| | ExtProtoInfo.", this time with the missing header.
llvm-svn: 127118 | 
| | 
| 
| 
| 
| 
| 
| 
| | ExtProtoInfo."
It seems missing "clang/Basic/ExceptionSpecificationType.h".
llvm-svn: 127115 | 
| | 
| 
| 
| | llvm-svn: 127112 | 
| | 
| 
| 
| 
| 
| | whether C++ exceptions are enabled, not exceptions in general.  PR9358.
llvm-svn: 126820 | 
| | 
| 
| 
| | llvm-svn: 121795 | 
| | 
| 
| 
| | llvm-svn: 121763 | 
| | 
| 
| 
| | llvm-svn: 121759 | 
| | 
| 
| 
| 
| 
| 
| | class to be passed around.  The line between argument and return types and
everything else is kindof vague, but I think it's justifiable.
llvm-svn: 121752 | 
| | 
| 
| 
| | llvm-svn: 121488 | 
| | 
| 
| 
| 
| 
| | specifications, from Martin Vejnar!
llvm-svn: 112482 | 
| | 
| 
| 
| 
| 
| 
| | Clients of Sema don't need to know (for example) the list of diagnostics we
support.
llvm-svn: 112093 | 
| | 
| 
| 
| | llvm-svn: 110945 | 
| | 
| 
| 
| 
| 
| | Fixes PR7243.
llvm-svn: 104942 | 
| | 
| 
| 
| 
| 
| 
| | CXXBasePaths::isAmbiguous(), rather than just asserting that we have a
canonical type. Fixes PR7176.
llvm-svn: 104374 | 
| | 
| 
| 
| 
| 
| | the C-only "optimization".
llvm-svn: 100022 | 
| | 
| 
| 
| | llvm-svn: 100018 | 
| | 
| 
| 
| 
| 
| 
| | term "fix-it" everywhere and even *I* get tired of long names
sometimes. No functionality change.
llvm-svn: 100008 | 
| | 
| 
| 
| 
| 
| 
| 
| | This introduces FunctionType::ExtInfo to hold the calling convention and the
noreturn attribute. The next patch will extend it to include the regparm
attribute and fix the bug.
llvm-svn: 99920 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | cache of PartialDiagnostic::Storage objects into an allocator within
the ASTContext. This eliminates a significant amount of malloc
traffic, for a 10% performance improvement in -fsyntax-only wall-clock
time with 403.gcc's combine.c.
Also, eliminate the RequireNonAbstractType hack I put in earlier,
which was but a symptom of this larger problem.
Fixes <rdar://problem/7806091>.
llvm-svn: 99849 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | that was present in a prior declaration, emit a warning rather than a
hard error (which we did before, and still do with mismatched
exception specifications). Moreover, provide a fix-it hint with the
throw() clause that should be added, e.g.,
t.C:10:7: warning: 'operator new' is missing exception specification
      'throw(std::bad_alloc)'
void *operator new(unsigned long sz)
      ^
                                     throw(std::bad_alloc)
As part of this, disable the warning when we're missing an exception
specification on operator new, operator new[], operator delete, or
operator delete[] when exceptions are turned off (-fno-exceptions).
Fixes PR5957.
llvm-svn: 99388 | 
| | 
| 
| 
| 
| 
| | required when emitting a destructor definition.
llvm-svn: 98609 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | headers, where malloc (and many other libc functions) are declared
with empty throw specifications, e.g.,  
  extern void *malloc (__SIZE_TYPE__ __size) throw () __attribute__
  ((__malloc__)) ;
The C++ standard doesn't seem to allow this, and redeclaring malloc as
the standard permits (as follows) resulted in Clang (rightfully!)
complaining about mis-matched exception specifications.
  void *malloc(size_t size);
We work around this by silently propagating an empty throw
specification "throw()" from a function with C linkage declared in a
system header to a redeclaration that has no throw specifier.
Ick.
llvm-svn: 95969 | 
| | 
| 
| 
| 
| 
| 
| | conversions.  Fix an access-control bug where privileges were not considered
at intermediate points along the inheritance path.  Prepare for friends.
llvm-svn: 95775 | 
| | 
| 
| 
| 
| 
| | a type currently being defined, from Nicola Gigante!
llvm-svn: 91052 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | sugared types. The basic problem is that our qualifier accessors
(getQualifiers, getCVRQualifiers, isConstQualified, etc.) only look at
the current QualType and not at any qualifiers that come from sugared
types, meaning that we won't see these qualifiers through, e.g.,
typedefs:
  typedef const int CInt;
  typedef CInt Self;
Self.isConstQualified() currently returns false!
Various bugs (e.g., PR5383) have cropped up all over the front end due
to such problems. I'm addressing this problem by splitting each
qualifier accessor into two versions: 
  - the "local" version only returns qualifiers on this particular
    QualType instance
  - the "normal" version that will eventually combine qualifiers from this
    QualType instance with the qualifiers on the canonical type to
    produce the full set of qualifiers.
This commit adds the local versions and switches a few callers from
the "normal" version (e.g., isConstQualified) over to the "local"
version (e.g., isLocalConstQualified) when that is the right thing to
do, e.g., because we're printing or serializing the qualifiers. Also,
switch a bunch of
  
  Context.getCanonicalType(T1).getUnqualifiedType() == Context.getCanonicalType(T2).getQualifiedType()
expressions over to 
  Context.hasSameUnqualifiedType(T1, T2)
llvm-svn: 88969 | 
| | 
| 
| 
| 
| 
| | to merge two diagnostics.
llvm-svn: 84105 | 
| | 
| 
| 
| | llvm-svn: 84101 | 
| | 
| 
| 
| 
| 
| | things, this means we get a note on the declaration of the incomplete type when it is used in an exception specification.
llvm-svn: 84099 | 
| | 
| 
| 
| | llvm-svn: 84098 | 
| | 
| 
| 
| | llvm-svn: 83766 | 
|  | Along the way, use RequireCompleteType when testing exception spec types.
Separate all the ugly spec stuff into its own file.
llvm-svn: 83764 |