summaryrefslogtreecommitdiffstats
path: root/clang
Commit message (Collapse)AuthorAgeFilesLines
...
* libclang: introduce cxstring::createNull()Dmitri Gribenko2013-02-016-26/+36
| | | | llvm-svn: 174173
* Re-design the convenience interfaces on MatchFinder.Manuel Klimek2013-02-013-54/+112
| | | | | | | | | | | | First, this implements a match() method on MatchFinder; this allows us to get rid of the findAll implementation, as findAll is really a special case of recursive matchers on match. Instead of findAll, provide a convenience function match() that lets users iterate easily over the results instead of needing to implement callbacks. llvm-svn: 174172
* Use const visitors in ASTDumper.Alexander Kornienko2013-02-014-235/+276
| | | | | | | http://llvm-reviews.chandlerc.com/D355 Patch by Philip Craig! llvm-svn: 174171
* Hopefully fix windows build due to non-standard pair implementation.Daniel Jasper2013-02-011-1/+1
| | | | llvm-svn: 174169
* Revamp of the basic layouting algorithm in clang-format.Daniel Jasper2013-02-011-117/+122
| | | | | | | | | | | | | | | | | | | | In order to end up with good solutions, clang-format needs to try "all" combinations of line breaks, evaluate them and select the best one. Before, we have done this using a DFS with memoization and cut-off conditions. However, this approach is very limited as shown by the huge static initializer in the attachment of llvm.org/PR14959. Instead, this new implementation uses a variant of Dijkstra's algorithm to do a prioritized BFS over the solution space. Some numbers: lib/Format/TokenAnnotator.cpp: 1.5s -> 0.15s Attachment of PR14959: 10min+ (didn't finish) -> 10s No functional changes intended. llvm-svn: 174166
* Fix diagnostic for bad alignas use: it can't be applied to functions.Richard Smith2013-02-014-6/+11
| | | | llvm-svn: 174160
* Add a new -Wundefined-inline warning for inline functions which are used but notNick Lewycky2013-02-0114-66/+169
| | | | | | defined. Fixes PR14993! llvm-svn: 174158
* Implement [dcl.align]p5 and C11 6.7.5/4: alignas cannot underalign.Richard Smith2013-02-019-42/+181
| | | | | | Also support alignas(0), which C++11 and C11 require us to ignore. llvm-svn: 174157
* Add PPC A2Q core and BG/Q preprocessor definitionsHal Finkel2013-02-014-2/+42
| | | | | | The a2q core is the variant of the a2 core used on the BG/Q supercomputers. llvm-svn: 174151
* Destroy arrays and ARC fields when throwing out of ctors.John McCall2013-02-015-32/+127
| | | | | | | | Previously we were only handling non-array fields of class type. Testcases derived from a patch by WenHan Gu. llvm-svn: 174146
* Don't do delayed exception-specification checking on an invalidDouglas Gregor2013-02-012-0/+19
| | | | | | class. Fixes <rdar://problem/13017229>. llvm-svn: 174145
* Enable -fno-altivec, -mno-altivec for PowerPC.Bill Schmidt2013-02-014-0/+51
| | | | | | | | | | | Introduces these negation forms explicitly and uses them to control a new "altivec" target feature for PowerPC. This allows avoiding generating Altivec instructions on processors that support Altivec. The new test case verifies that the Altivec "lvx" instruction is not used when -fno-altivec is present on the command line. llvm-svn: 174140
* [Sema][Attr]Fix alignment attribute printing.Michael Han2013-02-018-44/+96
| | | | | | | | | Remove "IsMSDeclspec" argument from Align attribute since the arguments in Attr.td should only model those appear in source code. Introduce attribute Accessor, and teach TableGen to generate syntax kind accessors for Align attribute, and use those accessors to decide if an alignment attribute is a declspec attribute. llvm-svn: 174133
* Consistently format sample diagnostics on this page.Richard Smith2013-02-011-48/+47
| | | | llvm-svn: 174126
* clang/test/Index/headerfile-comment-to-html.m: Try to unbreak libxml2-less ↵NAKAMURA Takumi2013-02-011-5/+5
| | | | | | hosts to eliminate "CommentXMLValid". llvm-svn: 174124
* Comment parsing: add more comments to CommentCommands.tdDmitri Gribenko2013-01-311-3/+33
| | | | | | | I hope the ASCII art delimiters are OK, since they group *groups* of commands -- that is really helpful. llvm-svn: 174114
* Escape backslash in the comment.Dmitri Gribenko2013-01-311-2/+2
| | | | llvm-svn: 174112
* Update the tests.Bill Wendling2013-01-3130-130/+130
| | | | | | | This update coincides with r174110. That change ordered the attributes alphabetically. llvm-svn: 174111
* [Comment parsing] Add support for recognizingFariborz Jahanian2013-01-319-4/+180
| | | | | | | | \headerfile command and representing it in an xml document. Patch reviewed by Dmitri Gribenko. // rdar://12397511 llvm-svn: 174109
* [analyzer]RetainCount: Fix an autorelease related false positive.Anna Zaks2013-01-312-1/+9
| | | | | | | The Cnt variable is adjusted (incremented) for simplification of checking logic. The increment should not be stored in the state. llvm-svn: 174104
* [analyzer] Don't track autorelease pools created by +new.Jordan Rose2013-01-312-2722/+3991
| | | | | | | | | | | | | This matches our behavior for autorelease pools created by +alloc. Some people like to create autorelease pools in one method and release them somewhere else. If you want safe autorelease pool semantics, use the new ARC-compatible syntax: @autoreleasepool { ... } <rdar://problem/13121353> llvm-svn: 174096
* Lexer: Don't warn about Unicode in preprocessor directives.Jordan Rose2013-01-313-2/+19
| | | | | | | | | This allows people to use Unicode in their #pragma mark and in macros that exist only to be string-ized. <rdar://problem/13107323&13121362> llvm-svn: 174081
* Preprocessor: initialize member introduced in r173881.Jordan Rose2013-01-311-0/+1
| | | | | | | Compilation always sets this explicitly, but creating a preprocessor manually should still put the 'IsPreprocessedOutput' flag in a valid state. llvm-svn: 174077
* Reverted unintendedly-committed file.Alexander Kornienko2013-01-311-1/+1
| | | | llvm-svn: 174076
* Micro-change: moved a brace for better readabilityAlexander Kornienko2013-01-312-3/+3
| | | | llvm-svn: 174075
* Revert "[analyzer] Model trivial copy/move ctors with an aggregate bind."Jordan Rose2013-01-315-183/+17
| | | | | | | | | It's causing hangs on our internal analyzer buildbot. Will restore after investigating. This reverts r173951 / baa7ca1142990e1ad6d4e9d2c73adb749ff50789. llvm-svn: 174069
* clang/test/Index/skip-parsed-bodies/compile_commands.json: Mark it as ↵NAKAMURA Takumi2013-01-311-1/+1
| | | | | | XFAIL:mingw32, for now. llvm-svn: 174064
* Never break inside something that was a preprocessor directive.Manuel Klimek2013-01-312-3/+5
| | | | | | Just put it in one unwrapped line and let the formatter handle it. llvm-svn: 174063
* Several improvements to the formatting of static initializers.Daniel Jasper2013-01-313-16/+71
| | | | | | | | | | | | | 1. Never avoid bin packing in static initializers as this can lead to terrible results. 2. If an element has to be broken over multiple lines, break after the following comma. This should be a step forward, but there are still many cases especially with nested static initializers that we handle badly. More patches will follow. llvm-svn: 174061
* Attempt to fix Windows build breakage.Evgeniy Stepanov2013-01-311-1/+2
| | | | llvm-svn: 174060
* Move commonly useful code for AST testing into MatchVerfier.h.Manuel Klimek2013-01-312-165/+196
| | | | llvm-svn: 174057
* Add support for AArch64 target.Tim Northover2013-01-3119-6/+1467
| | | | | | | | | | | | | In cooperation with the LLVM patch, this should implement all scalar front-end parts of the C and C++ ABIs for AArch64. This patch excludes the NEON support also reviewed due to an outbreak of batshit insanity in our legal department. That will be committed soon bringing the changes to precisely what has been approved. Further reviews would be gratefully received. llvm-svn: 174055
* Revert r174043 and tweak the comment wording so I'm (hopefully) not confused ↵Richard Smith2013-01-311-0/+8
| | | | | | by it again! llvm-svn: 174053
* Added outer template parameter lists to friend type AST nodes.Enea Zaffanella2013-01-316-28/+84
| | | | llvm-svn: 174050
* [msan] Run more optimizations after MemorySanitizer pass.Evgeniy Stepanov2013-01-311-0/+12
| | | | | | | | | | | | MSan instrumentation is driven by the original code. We take every incoming instruction and emit another instruction (or ten) next to it, operating on the shadow values (but sometimes on the real values, too). Two programs in one, essentially. There can be any kinds of redundancies in the second one, so we just run whatever is normally run at -O2, and then exclude some passes that do not help much with benchmarks. llvm-svn: 174049
* Remove incorrect warning signs from QualType::getUnqualifiedType(). TheseRichard Smith2013-01-311-8/+0
| | | | | | statements were only true for 65 CLs after they were introduced two years ago. llvm-svn: 174043
* When we're emitting a constructor or destructor call from a delegatingDouglas Gregor2013-01-315-21/+73
| | | | | | | constructor, retrieve our VTT parameter directly. Fixes PR14588 / <rdar://problem/12867962>. llvm-svn: 174042
* Improve 'failed template argument deduction' diagnostic for the case where weRichard Smith2013-01-3111-53/+91
| | | | | | | | have a direct mismatch between some component of the template and some component of the argument. The diagnostic now says what the mismatch was, but doesn't yet say which part of the template doesn't match. llvm-svn: 174039
* When code completing in a statement, parenthesized expression, orDouglas Gregor2013-01-314-12/+29
| | | | | | | | Objective-C message receiver, the user is as likely to want to write a type name as any other declaration, so give types the same priority as other declarations. Fixes <rdar://problem/12480600>. llvm-svn: 174038
* Allow the computation of the base priority for a declaration code completion ↵Douglas Gregor2013-01-315-54/+71
| | | | | | result to consider the completion context llvm-svn: 174037
* Replace "failed template argument deduction" diagnostic with something usefulRichard Smith2013-01-316-8/+54
| | | | | | in the one case where we've already factored out a reason code. llvm-svn: 174036
* Remove elements from Sema.UndefinedInternals as functions are defined. AlsoNick Lewycky2013-01-319-38/+74
| | | | | | | filter the elements before emitting them into a PCH. No user-visible functionality change, except that PCH files may be smaller? llvm-svn: 174034
* Fix grammar in comment.Nick Lewycky2013-01-311-1/+1
| | | | llvm-svn: 174033
* Clarify the diagnostic for -Wnested-anon-types.Richard Smith2013-01-314-10/+11
| | | | llvm-svn: 174032
* [analyzer] If a lazy binding is undefined, pretend that it's unknown instead.Jordan Rose2013-01-312-4/+83
| | | | | | | | | | | | | | | | | | | | | | | | This is a hack to work around the fact that we don't track extents for our default bindings: CGPoint p; p.x = 0.0; p.y = 0.0; rectParam.origin = p; use(rectParam.size); // warning: uninitialized value in rectParam.size.width In this case, the default binding for 'p' gets copied into 'rectParam', because the 'origin' field is at offset 0 within CGRect. From then on, rectParam's old default binding (in this case a symbol) is lost. This patch silences the warning by pretending that lazy bindings are never made from uninitialized memory, but not only is that not true, the original default binding is still getting overwritten (see FIXME test cases). The long-term solution is tracked in <rdar://problem/12701038> PR14765 and <rdar://problem/12875012> llvm-svn: 174031
* When comparing two template template arguments in the template differ, considerRichard Trieu2013-01-312-5/+22
| | | | | | | | | | | them the same if they are actually the same; having the same name isn't enough. Similar to r174013, template template arguments were also mistakenly considered the same when they had the same name but were in different namespaces. In addition, when printing template template arguments, use the qualified name if the regular name is the same. llvm-svn: 174029
* Fix -Wcovered-switch-default and -Wunused-private-field warnings.Richard Smith2013-01-311-19/+17
| | | | llvm-svn: 174025
* Add indents to AST dumping and removed parenthesis from AST nodes.Richard Trieu2013-01-3111-143/+412
| | | | | | | | | | | | | | | | | | | | | Indents were given the color blue when outputting with color. AST dumping now looks like this: Node |-Node | `-Node `-Node `-Node Compared to the previous: (Node (Node (Node)) (Node (Node))) llvm-svn: 174022
* Fix ODR-use of a MemberExpr to check before marking a pure function used. RemoveNick Lewycky2013-01-313-3/+26
| | | | | | a workaround for this bug from the -Wundefined-internals warning. llvm-svn: 174020
* [analyzer] Fix a bug in region store that lead to undefined value falseAnna Zaks2013-01-312-17/+21
| | | | | | | | | | positives. The includeSuffix was only set on the first iteration through the function, resulting in invalid regions being produced by getLazyBinding (ex: zoomRegion.y). llvm-svn: 174016
OpenPOWER on IntegriCloud