summaryrefslogtreecommitdiffstats
path: root/clang/lib
Commit message (Collapse)AuthorAgeFilesLines
* objc_exception_rethrow does not take an exception argument.John McCall2010-10-161-23/+9
| | | | | | rdar://problem/8535238 llvm-svn: 116663
* Reformatting.John McCall2010-10-162-4/+4
| | | | llvm-svn: 116662
* White-listing templated-scope friend decls is a good idea, but doing itJohn McCall2010-10-166-26/+36
| | | | | | | | by marking the decl invalid isn't. Make some steps towards supporting these and then hastily shut them down at the last second by marking them as unsupported. llvm-svn: 116661
* Revert r116656, "IRgen/Obj-C/NeXT: Fix the IR signature forDaniel Dunbar2010-10-161-1/+1
| | | | | | | | objc_exception_rethrow, so we don't...", since something is actually trying to call this with the wrong signature (!). Unfortunately I don't understand the new EH infrastructure well enough to fix it immediately. llvm-svn: 116660
* IRgen/Obj-C/NeXT: Fix the IR signature for objc_exception_rethrow, so we don'tDaniel Dunbar2010-10-161-1/+1
| | | | | | generate unnecessary %al clear on x86_64. llvm-svn: 116656
* Fix a rewriting bug of rewriting properties declared inFariborz Jahanian2010-10-161-24/+25
| | | | | | protocols. // rdar: //8558702 llvm-svn: 116652
* Allow list-initialization of a local variable of class type with aDouglas Gregor2010-10-151-3/+13
| | | | | | | | flexible array member, so long as the flexibility array member is either not initialized or is initialized with an empty initializer list. Fixes <rdar://problem/8540437>. llvm-svn: 116647
* Tweak retain/release checker diagnostics to specify a leak occurs because an ↵Ted Kremenek2010-10-151-2/+2
| | | | | | | | object is not referenced later in the path, not that it isn't referenced later in the code. Fixes <rdar://problem/8527839>. llvm-svn: 116636
* Check for ivar being a C++ object before attempting toFariborz Jahanian2010-10-151-2/+4
| | | | | | | | | find a copy constructor/assignment operator used in getter/setter synthesis. This removes an unintended diagnostics and makes objc++ consistant with objective-c. // rdar: //8550657. llvm-svn: 116631
* Driver: Error on -fno-for-scope, which we have no intention of supporting.Daniel Dunbar2010-10-151-1/+7
| | | | llvm-svn: 116627
* Report the location of the syntax error inside a macro. Fixes PR7944.Nick Lewycky2010-10-151-1/+1
| | | | llvm-svn: 116624
* Mention the paragraphs in the standards which sanction TBAA.Dan Gohman2010-10-151-1/+5
| | | | llvm-svn: 116617
* Use a different name for pointer types in tbaa, to be a littleDan Gohman2010-10-151-2/+3
| | | | | | more consistent with other names, and to look less like a magic name. llvm-svn: 116616
* Add a comment.Dan Gohman2010-10-151-1/+3
| | | | llvm-svn: 116615
* Fix a typo in a comment Frits van Bommel spotted.Dan Gohman2010-10-151-1/+1
| | | | llvm-svn: 116614
* Experimental TBAA support for enum types.Dan Gohman2010-10-153-7/+38
| | | | llvm-svn: 116613
* Revert r116605, a lot more were committed by mistake.Argyrios Kyrtzidis2010-10-151-10/+0
| | | | llvm-svn: 116606
* Add '-include-pch' option to the driver, so it can get passed to the cc1 driver.Argyrios Kyrtzidis2010-10-151-0/+10
| | | | llvm-svn: 116605
* Eradicate IsSuper field from ObjCImplicitSetterGetterRefExprClassFariborz Jahanian2010-10-152-2/+0
| | | | | | AST node. (finishing off radar 8525788). llvm-svn: 116603
* Read/write to/from PCH DeclarationNameLocs, DeclarationNameInfos and ↵Argyrios Kyrtzidis2010-10-156-36/+166
| | | | | | QualifierInfos (rdar://8513756). llvm-svn: 116598
* Don't leak the TBAA object.Dan Gohman2010-10-151-0/+1
| | | | llvm-svn: 116595
* Add a comment about odd "signed char" incompatibility between C++ and C.Dan Gohman2010-10-151-1/+5
| | | | llvm-svn: 116593
* When performing typo correction, keep track of whether the last lookupDouglas Gregor2010-10-151-1/+37
| | | | | | | | | we did was an acceptable lookup. If it is, then we can re-use that lookup result. If it isn't, we have to perform the lookup again. This is almost surely the cause behind the mysterious typo.m failures on some builders; we were getting the wrong lookup results returned. llvm-svn: 116586
* When we're in the context of an Objective-C message send's receiver,Douglas Gregor2010-10-151-1/+13
| | | | | | | typo correction prefers "super" over other, equivalent completions. I believe this will fix the regression on the buildbot. llvm-svn: 116574
* Diagnose C++ [class.mem]p13-14, where a class member has the same nameDouglas Gregor2010-10-152-1/+50
| | | | | | as the class itself. Fixes PR7082. llvm-svn: 116573
* fix http://llvm.org/PR8371 in the straightforward way, also adding a commentGabor Greif2010-10-151-0/+1
| | | | llvm-svn: 116570
* Treat __extension__ like ParenExpr.Abramo Bagnara2010-10-151-14/+48
| | | | llvm-svn: 116569
* Death to blocks, or at least the word "block" in one particular obnoxiouslyJohn McCall2010-10-1513-57/+55
| | | | | | ambiguous context. llvm-svn: 116567
* Don't complain about a variable within a linkage-specification that isDouglas Gregor2010-10-151-1/+1
| | | | | | initialized. Fixes PR7076. llvm-svn: 116553
* When we are missing the ',' or '>' to terminate a template parameterDouglas Gregor2010-10-151-1/+1
| | | | | | list, complain about it! Fixes PR7053. llvm-svn: 116551
* Add builtin conditional operator candidates for scoped enumerationDouglas Gregor2010-10-151-3/+12
| | | | | | types, from Alp Toker! Fixes PR8344. llvm-svn: 116549
* Update CMake.Daniel Dunbar2010-10-151-0/+1
| | | | llvm-svn: 116548
* Add a TBAA type for pointer types.Dan Gohman2010-10-151-0/+4
| | | | llvm-svn: 116544
* Unsigned types are TBAA-compatible with their signed counterparts.Dan Gohman2010-10-141-4/+18
| | | | | | Also, handle unknown types conservatively. llvm-svn: 116541
* Rewrite bug fix rewriting a property assignment whenFariborz Jahanian2010-10-141-0/+6
| | | | | | its RHS is an ivar. Fixes //rdar: //8541517. llvm-svn: 116539
* Experimental TBAA support.Dan Gohman2010-10-147-10/+191
| | | | | | | This enables metadata generation by default, however the TBAA pass in the optimizer is still disabled for now. llvm-svn: 116536
* Use root non-virtual primary base class, not just immediate primary base ↵Devang Patel2010-10-141-1/+11
| | | | | | | | class, for AT_containing_type. This is tested by virtfunc.exp in gdb testsuite. llvm-svn: 116535
* Wire up the -fstrict-aliasing and -fno-strict-aliasing optionsDan Gohman2010-10-142-0/+5
| | | | | | to CodeGenOption flags. llvm-svn: 116530
* template-ids are looked up differently in friend declarations.John McCall2010-10-141-1/+6
| | | | llvm-svn: 116529
* When performing typo correction, look through the set of knownDouglas Gregor2010-10-144-10/+116
| | | | | | | | | | | | | | | | | | | | identifiers to determine good typo-correction candidates. Once we've identified those candidates, we perform name lookup on each of them and the consider the results. This optimization makes typo correction > 2x faster on a benchmark example using a single typo (NSstring) in a tiny file that includes Cocoa.h from a precompiled header, since we are deserializing far less information now during typo correction. There is a semantic change here, which is interesting. The presence of a similarly-named entity that is not visible can now affect typo correction. This is both good (you won't get weird corrections if the thing you wanted isn't in scope) and bad (you won't get good corrections if there is a similarly-named-but-completely-unrelated thing). Time will tell whether it was a good choice or not. llvm-svn: 116528
* Make sure that we diagnose invalid qualifiers on friend functions.Douglas Gregor2010-10-141-6/+9
| | | | llvm-svn: 116527
* At Fariborz's request, a somewhat cleaner bit-combining hack.John McCall2010-10-142-16/+16
| | | | llvm-svn: 116524
* Put line number on the diagnostic. //rdar: //8550657.Fariborz Jahanian2010-10-141-1/+1
| | | | llvm-svn: 116519
* Tweak the typo-correction implementation to determine correctionsDouglas Gregor2010-10-141-147/+109
| | | | | | | | | | | | | | | | | | | | | solely based on the names it sees, rather than actual declarations it gets. In essence, we determine the set of names that are "close enough" to the typo'd name. Then, we perform name lookup for each of those names, filtering out those that aren't actually visible, and typo-correct from the remaining results. Overall, there isn't much of a change in the behavior of typo correction here. The only test-suite change comes from the fact that we make good on our promise to require that the user type 3 characters for each 1 character corrected. The real intent behind this change is to set the stage for an optimization to typo correction (so that we don't need to deserialize all declarations in a translation unit) and future work in finding missing qualification ("'vector' isn't in scope; did you mean 'std::vector'?). Plus, the code is cleaner this way. llvm-svn: 116511
* Store in PCH the key function of C++ class to avoid deserializing the ↵Argyrios Kyrtzidis2010-10-143-3/+14
| | | | | | | | complete declaration context in order to compute it. Progress for rdar://7260160. llvm-svn: 116508
* Allow deserialization of just the fields of a record, when we want to ↵Argyrios Kyrtzidis2010-10-144-29/+81
| | | | | | | | | | | | | iterate over them, instead of deserializing the complete declaration context of the record. Iterating over the fields of a record is very common (e.g to determine the layout), unfortunately we needlessly deserialize every declaration that the declaration context of the record contains; this can be bad for large C++ classes that contain a lot of methods. Fix this by allow deserialization of just the fields when we want to iterate over them. Progress for rdar://7260160. llvm-svn: 116507
* Give a default implementation for ASTDeserializationListener's methods, no ↵Argyrios Kyrtzidis2010-10-142-14/+4
| | | | | | functionality change. llvm-svn: 116506
* Introduce command line option -error-on-deserialized-decl that is ↵Argyrios Kyrtzidis2010-10-142-0/+45
| | | | | | | | | | accompanied by a name and emits an error if a declaration with this name is deserialized from PCH. This is for testing, to make sure that we don't deserialize stuff needlessly. llvm-svn: 116505
* Don't add the injected class name to the redeclarations chain; the chain ↵Argyrios Kyrtzidis2010-10-141-1/+3
| | | | | | | | should contain actual redeclarations, not implicits. As a bonus, now we don't deserialize it unless we need it. llvm-svn: 116504
* Introduce command line option -dump-deserialized-decls which is used to ↵Argyrios Kyrtzidis2010-10-142-2/+38
| | | | | | print the PCH decls that got deserialized, for testing purposes. llvm-svn: 116503
OpenPOWER on IntegriCloud