|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| ... |  | 
| | 
| 
| 
| | llvm-svn: 82435 | 
| | 
| 
| 
| 
| 
| 
| 
| | HandleTopLevelDecl -- this is already being done inside the reader.
This is something of a hack, since whether the reader actually did this depends on the "isConsumerInterestedIn" predicate. I think we need to rework how this works, but I need to discuss with Doug.
llvm-svn: 82111 | 
| | 
| 
| 
| | llvm-svn: 81346 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | order because it was doing so while iterating over a densemap.
There are still similar problems in other places, for example 
WeakUndeclaredIdentifiers is still written to the PCH file in a nondeterminstic
order, and we emit warnings about #pragma weak in nondeterminstic order.
llvm-svn: 81236 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | directly in the AST.  The current thinking is to create these
only in C++ mode for efficiency.  But for now, they're not being
created at all; patch to follow.
This will let us do things like verify that tags match during
template instantation, as well as signal that an elaborated type
specifier was used for clients that actually care.
Optimally, the TypeLoc hierarchy should be adjusted to carry tag
location information as well.
llvm-svn: 81057 | 
| | 
| 
| 
| | llvm-svn: 80916 | 
| | 
| 
| 
| 
| 
| | - Patch by David Chisnall, with PCH and Darwin support mixed in.
llvm-svn: 80883 | 
| | 
| 
| 
| 
| 
| | - Primarily to discourage clients form making decisions based on the string.
llvm-svn: 79901 | 
| | 
| 
| 
| | llvm-svn: 79782 | 
| | 
| 
| 
| 
| 
| 
| | types that are preloaded by the PCH file. Fixes PCH breakage
introduced in r79248.
llvm-svn: 79583 | 
| | 
| 
| 
| 
| 
| | tighten up the static type system.
llvm-svn: 78164 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Type::getAsReferenceType() -> Type::getAs<ReferenceType>()
  Type::getAsRecordType() -> Type::getAs<RecordType>()
  Type::getAsPointerType() -> Type::getAs<PointerType>()
  Type::getAsBlockPointerType() -> Type::getAs<BlockPointerType>()
  Type::getAsLValueReferenceType() -> Type::getAs<LValueReferenceType>()
  Type::getAsRValueReferenceType() -> Type::getAs<RValueReferenceType>()
  Type::getAsMemberPointerType() -> Type::getAs<MemberPointerType>()
  Type::getAsReferenceType() -> Type::getAs<ReferenceType>()
  Type::getAsTagType() -> Type::getAs<TagType>()
  
And remove Type::getAsReferenceType(), etc.
This change is similar to one I made a couple weeks ago, but that was partly
reverted pending some additional design discussion. With Doug's pending smart
pointer changes for Types, it seemed natural to take this approach.
llvm-svn: 77510 | 
| | 
| 
| 
| | llvm-svn: 77291 | 
| | 
| 
| 
| 
| 
| | Use ObjCInterfaceDecl::getCategoryClassMethod() and ObjCInterfaceDecl::getCategoryInstanceMethod() for the same functionality.
llvm-svn: 76510 | 
| | 
| 
| 
| | llvm-svn: 76321 | 
| | 
| 
| 
| | llvm-svn: 76303 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | until Doug Gregor's Type smart pointer code lands (or more discussion occurs).
These methods just call the new Type::getAs<XXX> methods, so we still have
reduced implementation redundancy. Having explicit getAsXXXType() methods makes
it easier to set breakpoints in the debugger.
llvm-svn: 76193 | 
| | 
| 
| 
| 
| 
| | Type::getAsMemberPointerType(), Type::getAsTagType(), and Type::getAsRecordType() with their Type::getAs<XXX> equivalents.
llvm-svn: 76139 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | pseudo built-in types, since Sema still injects a typedef for recognition (i.e. they aren't truly built-ins from a parser perspective).
This removes the static data/methods on ObjCObjectPointerType while preserving the nice API (no need to fiddle with ASTContext:-).
This patch also adds Type::isObjCBuiltinType().
This should be the last fairly large patch related to recrafting the ObjC type system. The follow-on patches should be fairly small.
llvm-svn: 75808 | 
| | 
| 
| 
| 
| 
| | an incremental patch
llvm-svn: 75622 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | The idea is to segregate Objective-C "object" pointers from general C pointers (utilizing the recently added ObjCObjectPointerType). The fun starts in Sema::GetTypeForDeclarator(), where "SomeInterface *" is now represented by a single AST node (rather than a PointerType whose Pointee is an ObjCInterfaceType). Since a significant amount of code assumed ObjC object pointers where based on C pointers/structs, this patch is very tedious. It should also explain why it is hard to accomplish this in smaller, self-contained patches.
This patch does most of the "heavy lifting" related to moving from PointerType->ObjCObjectPointerType. It doesn't include all potential "cleanups". The good news is additional cleanups can be done later (some are noted in the code). This patch is so large that I didn't want to include any changes that are purely aesthetic.
By making the ObjC types truly built-in, they are much easier to work with (and require fewer "hacks"). For example, there is no need for ASTContext::isObjCIdStructType() or ASTContext::isObjCClassStructType()! We believe this change (and the follow-up cleanups) will pay dividends over time. 
Given the amount of code change, I do expect some fallout from this change (though it does pass all of the clang tests). If you notice any problems, please let us know asap! Thanks.
llvm-svn: 75314 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | FILE type, rather than using name lookup to find FILE within the
translation unit. Within precompiled headers, FILE is treated as yet
another "special type" (like __builtin_va_list).
This change should provide a performance improvement (not verified),
since the lookup into the translation unit declaration 
forces the (otherwise unneeded) construction of a large hash table.
More importantly, with precompiled headers, the construction
of that table requires deserializing most of the top-level
declarations from the precompiled header, which are then unused.
Fixes PR 4509.
llvm-svn: 74911 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | with a particular system root directory and can be used with a different
system root directory when the headers it depends on have been installed.
Relocatable precompiled headers rewrite the file names of the headers used
when generating the PCH file into the corresponding file names of the 
headers available when using the PCH file.
Addresses <rdar://problem/7001604>.
llvm-svn: 74885 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | of a top-level declaration loads another top-level declaration of the
same name whose type depends on the first declaration having been
completed. This commit breaks the circular dependency by delaying
loads of top-level declarations triggered by loading a name until we
are no longer recursively loading types or declarations.
llvm-svn: 74847 | 
| | 
| 
| 
| 
| 
| | from Enea Zaffanella!
llvm-svn: 74831 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | declaration in the AST. 
The new ASTContext::getCommentForDecl function searches for a comment
that is attached to the given declaration, and returns that comment, 
which may be composed of several comment blocks.
Comments are always available in an AST. However, to avoid harming
performance, we don't actually parse the comments. Rather, we keep the
source ranges of all of the comments within a large, sorted vector,
then lazily extract comments via a binary search in that vector only
when needed (which never occurs in a "normal" compile).
Comments are written to a precompiled header/AST file as a blob of
source ranges. That blob is only lazily loaded when one requests a
comment for a declaration (this never occurs in a "normal" compile). 
The indexer testbed now supports comment extraction. When the
-point-at location points to a declaration with a Doxygen-style
comment, the indexer testbed prints the associated comment
block(s). See test/Index/comments.c for an example.
Some notes:
  - We don't actually attempt to parse the comment blocks themselves,
  beyond identifying them as Doxygen comment blocks to associate them
  with a declaration.
  - We won't find comment blocks that aren't adjacent to the
  declaration, because we start our search based on the location of
  the declaration.
  - We don't go through the necessary hops to find, for example,
  whether some redeclaration of a declaration has comments when our
  current declaration does not. Similarly, we don't attempt to
  associate a \param Foo marker in a function body comment with the
  parameter named Foo (although that is certainly possible).
  - Verification of my "no performance impact" claims is still "to be
  done".
llvm-svn: 74704 | 
| | 
| 
| 
| | llvm-svn: 74221 | 
| | 
| 
| 
| | llvm-svn: 74220 | 
| | 
| 
| 
| | llvm-svn: 74099 | 
| | 
| 
| 
| 
| 
| | initialized to 0.
llvm-svn: 73762 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | pre-initialized Preprocessor.
-Introduce 'PCHReaderListener' which is an abstract interface for getting various information from the PCHReader.
-If PCHReader is constructed without a Preprocessor, it can still load the file and invoke the callbacks of PCHReaderListener.
-If PCHReader is constructed with an initialized Preprocessor, PCHValidator is used as a PCHReaderListener to validate the contents of the PCH file against the given Preprocessor.
llvm-svn: 73741 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | representation.
Add a type (ObjCObjectPointerType) and remove a type (ObjCQualifiedIdType).
This large/tedious patch is just a first step. Next step is to remove ObjCQualifiedInterfaceType. After that, I will remove the magic TypedefType for 'id' (installed by Sema). This work will enable various simplifications throughout clang (when dealing with ObjC types). 
No functionality change.
llvm-svn: 73649 | 
| | 
| 
| 
| 
| 
| 
| 
| | like:
fatal error: could not find file '1.h' referenced by PCH file
instead of aborting with an assertion failure, PR4219
llvm-svn: 73371 | 
| | 
| 
| 
| | llvm-svn: 72928 | 
| | 
| 
| 
| 
| 
| | keep the spec out of the canonical type this time. Net effect is currently nothing, because the spec isn't checked anywhere.
llvm-svn: 72498 | 
| | 
| 
| 
| 
| 
| 
| | llvm::SmallVector, using data() instead of &[0]. The PCH testsuite now
runs cleanly (again).
llvm-svn: 72292 | 
| | 
| 
| 
| | llvm-svn: 72210 | 
| | 
| 
| 
| 
| 
| | -faccess-control option. When we have better support for it, we can enable it by default again.
llvm-svn: 71706 | 
| | 
| 
| 
| 
| 
| 
| | (with -E), we turn the PCH include into an implicit include of the
file from which the PCH file was generated.
llvm-svn: 71534 | 
| | 
| 
| 
| | llvm-svn: 71405 | 
| | 
| 
| 
| 
| 
| | until we've had a lot more discussion.
llvm-svn: 71125 | 
| | 
| 
| 
| | llvm-svn: 70506 | 
| | 
| 
| 
| 
| 
| 
| 
| | compatible with VC++ and GCC.  The codegen/mangling angle hasn't
been fully ironed out yet.  Note that we accept int128_t even in
32-bit mode, unlike gcc.
llvm-svn: 70464 | 
| | 
| 
| 
| 
| 
| 
| | compilation if the user requested a PCH file but no such PCH file
exists.
llvm-svn: 70332 | 
| | 
| 
| 
| | llvm-svn: 70330 | 
| | 
| 
| 
| 
| 
| | now gotten back about 180k of the 500k we lost.
llvm-svn: 70326 | 
| | 
| 
| 
| 
| 
| 
| 
| | which eliminates the storage for IdentifierInfo in the "uninteresting
identifier" cases. Sadly, this only brought back 7k of the 500k we
lost :(
llvm-svn: 70325 | 
| | 
| 
| 
| | llvm-svn: 70322 | 
| | 
| 
| 
| 
| 
| 
| 
| | line when using a PCH that were not provided when building the PCH
file. If those names were used as identifiers somewhere in the PCH
file, reject the PCH file.
llvm-svn: 70321 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | for identifiers to separate "interesting" from "uninteresting"
identifiers. However, to cope with compiler invocations where the
predefines buffers mismatch, we need to be able to search the complete
identifier table. Cocoa.h.pch is now about 500k larger that it used to
be :(
llvm-svn: 70320 |