|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| ... |  | 
| | 
| 
| 
| | llvm-svn: 78536 | 
| | 
| 
| 
| | llvm-svn: 78515 | 
| | 
| 
| 
| | llvm-svn: 78489 | 
| | 
| 
| 
| 
| 
| 
| | copying non-virtual base classes which have non-trivial
constructor. Work in progress.
llvm-svn: 78436 | 
| | 
| 
| 
| | llvm-svn: 78402 | 
| | 
| 
| 
| 
| 
| | Work in progress.
llvm-svn: 78355 | 
| | 
| 
| 
| | llvm-svn: 77722 | 
| | 
| 
| 
| 
| 
| | been declared as needed.
llvm-svn: 77641 | 
| | 
| 
| 
| | llvm-svn: 77638 | 
| | 
| 
| 
| | llvm-svn: 77608 | 
| | 
| 
| 
| | llvm-svn: 77514 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | 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: 77012 | 
| | 
| 
| 
| | llvm-svn: 76862 | 
| | 
| 
| 
| | llvm-svn: 76498 | 
| | 
| 
| 
| | llvm-svn: 76493 | 
| | 
| 
| 
| | llvm-svn: 76473 | 
| | 
| 
| 
| | llvm-svn: 76365 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | - Emit variable declarations as "simple", we want to avoid forcing the creation
   of a dummy basic block, but still need to make the variable available for
   later use.
 - With that, we can now skip IRgen for other unreachable statements (which
   don't define a label).
 - Anders, I added two fixmes on calls to EmitVLASize, can you check them?
llvm-svn: 76361 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | 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 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | This method is intended to eventually replace the individual
Type::getAsXXXType<> methods.
The motivation behind this change is twofold:
1) Reduce redundant implementations of Type::getAsXXXType() methods. Most of
them are basically copy-and-paste.
2) By centralizing the implementation of the getAs<Type> logic we can more
smoothly move over to Doug Gregor's proposed canonical type smart pointer
scheme.
Along with this patch:
a) Removed 'Type::getAsPointerType()'; now clients use getAs<PointerType>.
b) Removed 'Type::getAsBlockPointerTypE()'; now clients use getAs<BlockPointerType>.
llvm-svn: 76098 | 
| | 
| 
| 
| | llvm-svn: 75705 | 
| | 
| 
| 
| | llvm-svn: 75446 | 
| | 
| 
| 
| | llvm-svn: 75041 | 
| | 
| 
| 
| 
| 
| 
| 
| | subclasses.
Timings showed no significant difference before and after the commit.
llvm-svn: 74504 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | The implementations of these methods can Use Decl::getASTContext() to get the ASTContext.
This commit touches a lot of files since call sites for these methods are everywhere.
I used pre-tokenized "carbon.h" and "cocoa.h" headers to do some timings, and there was no real time difference between before the commit and after it.
llvm-svn: 74501 | 
| | 
| 
| 
| | llvm-svn: 73702 | 
| | 
| 
| 
| 
| 
| | instructions to the current block.
llvm-svn: 72654 | 
| | 
| 
| 
| 
| 
| | actually necessary in some obscure cases.
llvm-svn: 72585 | 
| | 
| 
| 
| 
| 
| | tried other things that might trip, but they all worked.
llvm-svn: 72584 | 
| | 
| 
| 
| | llvm-svn: 72578 | 
| | 
| 
| 
| | llvm-svn: 71937 | 
| | 
| 
| 
| 
| 
| | can't track down.
llvm-svn: 70155 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | the type assigned by sema (and is visible with sizeof(__func__) for
example) has nothing to do with what codegen ends up producing.
We should eventually add a method on PredefinedExpr to handle this.
In the meantime, just set up some framework and add some fixme's.
llvm-svn: 69872 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | in cases like this:
typedef struct {
  short instance;
  char name[0];
} ATTR_LIST_ENTRY2;
void test() {
  ATTR_LIST_ENTRY2 X = (ATTR_LIST_ENTRY2) { .instance = 7, };
}  
While it is safe to emit them, it is pretty silly.
llvm-svn: 69687 | 
| | 
| 
| 
| 
| 
| 
| 
| | lazy PCH deserialization. Propagate that argument wherever it needs to
be. No functionality change, except that I've tightened up a few PCH
tests in preparation.
llvm-svn: 69406 | 
| | 
| 
| 
| | llvm-svn: 69134 | 
| | 
| 
| 
| 
| 
| | - No functionality change.
llvm-svn: 68987 | 
| | 
| 
| 
| | llvm-svn: 68755 | 
| | 
| 
| 
| | llvm-svn: 68425 | 
| | 
| 
| 
| | llvm-svn: 68151 | 
| | 
| 
| 
| 
| 
| | types don't get generated when blocks aren't used.
llvm-svn: 67898 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | in release-assert builds.  For automatic variables, explicitly set
a name with setName that does not make a temporary std::string.
This speeds up -emit-llvm-only -disable-free on PR3810 by 4.6%
llvm-svn: 67459 | 
| | 
| 
| 
| | llvm-svn: 67075 | 
| | 
| 
| 
| | llvm-svn: 66319 | 
| | 
| 
| 
| | llvm-svn: 66231 | 
| | 
| 
| 
| 
| 
| | necessary.
llvm-svn: 66117 | 
| | 
| 
| 
| 
| 
| | functionality change.
llvm-svn: 66048 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | giving them rough classifications (normal types, never-canonical
types, always-dependent types, abstract type representations) and
making it far easier to make sure that we've hit all of the cases when
decoding types. 
Switched some switch() statements on the type class over to using this
mechanism, and filtering out those things we don't care about. For
example, CodeGen should never see always-dependent or non-canonical
types, while debug info generation should never see always-dependent
types. More switch() statements on the type class need to be moved 
over to using this approach, so that we'll get warnings when we add a
new type then fail to account for it somewhere in the compiler.
As part of this, some types have been renamed:
  TypeOfExpr -> TypeOfExprType
  FunctionTypeProto -> FunctionProtoType
  FunctionTypeNoProto -> FunctionNoProtoType
There shouldn't be any functionality change...
llvm-svn: 65591 |