|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | of the file.
This would run past the end of the buffer. Sadly I don't have a great way to
test it, the only way to trigger the bug is having a removal fix it at the end
of the file, which none of our current warnings can generate.
llvm-svn: 217766 | 
| | 
| 
| 
| 
| 
| | with auto-boxing syntax for literals. rdar://18080352
llvm-svn: 216405 | 
| | 
| 
| 
| | llvm-svn: 212919 | 
| | 
| 
| 
| | llvm-svn: 208392 | 
| | 
| 
| 
| 
| 
| | rdar://16223810
llvm-svn: 207391 | 
| | 
| 
| 
| 
| 
| | Harmless in this case but potentially dangerous if it gets extended some day.
llvm-svn: 205107 | 
| | 
| 
| 
| | llvm-svn: 202238 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | introduce CLANG_TABLEGEN_TARGETS.
This does;
  - clang_tablegen() adds each tblgen'd target to global property CLANG_TABLEGEN_TARGETS as list.
  - List of targets is added to LLVM_COMMON_DEPENDS.
  - all clang libraries and targets depend on generated headers.
You might wonder this would be regression, but in fact, this is little loss.
  - Almost all of clang libraries depend on tblgen'd files and clang-tblgen.
  - clang-tblgen may cause short stall-out but doesn't cause unconditional rebuild.
  - Each library's dependencies to tblgen'd files might vary along headers' structure.
    It made hard to track and update *really optimal* dependencies.
Each dependency to intrinsics_gen and ClangSACheckers is left as DEPENDS.
llvm-svn: 201842 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | With the introduction of explicit address space casts into LLVM, there's
a need to provide a new cast kind the front-end can create for C/OpenCL/CUDA
and code to produce address space casts from those kinds when appropriate.
Patch by Michele Scandale!
llvm-svn: 197036 | 
| | 
| 
| 
| 
| 
| 
| 
| | target_link_libraries() and LLVM_LINK_COMPONENTS.
I will prune redundant dependencies later.
llvm-svn: 196800 | 
| | 
| 
| 
| 
| 
| 
| 
| | migration of headers which have become system headers by user having put
the .system_framework in the sdk directory.
// rdar://15066802
llvm-svn: 191796 | 
| | 
| 
| 
| 
| 
| 
| | declaration when converting to NS_ENUM. This required
some code refactoring.
llvm-svn: 186619 | 
| | 
| 
| 
| 
| 
| | - wip.
llvm-svn: 186604 | 
| | 
| 
| 
| 
| 
| 
| | declaration to include list of protocols class
conforms to. 
llvm-svn: 186443 | 
| | 
| 
| 
| 
| 
| | declaration (not yet used). wip.
llvm-svn: 186369 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | migrate to 'copy attribute if Object
class implements NSCopying otherwise 
assume implied 'strong'. Remove 
lifetime qualifier on property as it has
moved to property's attribute. Added TODO
comment for future work by poking into
setter implementation.
llvm-svn: 186037 | 
| | 
| 
| 
| 
| 
| 
| | attributes in migration. Specialli use of
'copy' attribute for retainable object types.
llvm-svn: 185985 | 
| | 
| 
| 
| 
| 
| | their equivalent property declaration. wip.
llvm-svn: 185873 | 
| | 
| 
| 
| 
| 
| | use of objc's properties.
llvm-svn: 185724 | 
| | 
| 
| 
| 
| 
| | rdar://13181413
llvm-svn: 178942 | 
| | 
| 
| 
| 
| 
| | Post-commit CR feedback from Jordan Rose regarding r175594.
llvm-svn: 175679 | 
| | 
| 
| 
| | llvm-svn: 175160 | 
| | 
| 
| 
| 
| 
| 
| | Nearly all of these changes are one-to-one replacements; the few that
aren't have to do with custom identifier validation.
llvm-svn: 174768 | 
| | 
| 
| 
| 
| 
| | OpenCL restrictions (OpenCL 1.2 spec 6.9)
llvm-svn: 172973 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | dictionary literal
if we can see the elements of the arrays.
for example:
 NSDictionary *dict = [NSDictionary dictionaryWithObjects:[NSArray arrayWithObjects:@"1", @"2", nil] forKeys:[NSArray arrayWithObjects:@"A", @"B", nil]];
-->
 NSDictionary *dict = @{ @"A" : @"1", @"B" : @"2" };
rdar://12428166
llvm-svn: 172679 | 
| | 
| 
| 
| 
| 
| | brought into 'clang' namespace by clang/Basic/LLVM.h
llvm-svn: 172323 | 
| | 
| 
| 
| | llvm-svn: 170817 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | to also remove a trailing space if possible.
For example, removing '__bridge' from:
i = (__bridge I*)p;
should result in:
i = (I*)p;
not:
i = ( I*)p;
rdar://11314821
llvm-svn: 170764 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | uncovered.
This required manually correcting all of the incorrect main-module
headers I could find, and running the new llvm/utils/sort_includes.py
script over the files.
I also manually added quite a few missing headers that were uncovered by
shuffling the order or moving headers up to be main-module-headers.
llvm-svn: 169237 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | PreprocessingRecord and into its own class, PPConditionalDirectiveRecord.
Decoupling allows a client to use the functionality of PPConditionalDirectiveRecord
without needing a PreprocessingRecord.
llvm-svn: 169229 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | (__builtin_* etc.) so that it isn't possible to take their address.
Specifically, introduce a new type to represent a reference to a builtin
function, and a new cast kind to convert it to a function pointer in the
operand of a call.  Fixes PR13195.
llvm-svn: 162962 | 
| | 
| 
| 
| | llvm-svn: 160851 | 
| | 
| 
| 
| | llvm-svn: 160850 | 
| | 
| 
| 
| 
| 
| | unbreak the VS build.
llvm-svn: 160309 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | that the migrator handles) but return their instances as 'id', resulting
in the compiler resolving 'objectForKey:' as the method from NSDictionary.
When checking if we can convert to subscripting syntax, check whether
the receiver is a result of a class method from a hardcoded list of
such classes. In such a case return the specific class as the interface
of the receiver.
llvm-svn: 159788 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | (apart from NSDictionary/NSArray) that implement objectForKey:/objectAtIndex/etc.
and the subscripting methods as well.
Part of rdar://11734969
llvm-svn: 159783 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | This required moving the ctors for IntegerLiteral and FloatingLiteral out of
line which shouldn't change anything as they are usually called through Create
methods that are already out of line.
ASTContext::Deallocate has been a nop for a long time, drop it from ASTVector
and make it independent from ASTContext.h
Pass the StorageAllocator directly to AccessedEntity so it doesn't need to
have a definition of ASTContext around.
llvm-svn: 159718 | 
| | 
| 
| 
| 
| 
| 
| | Commit::canReplaceText would not initialize its out 'Len' parameter before
returning true and it would be used uninitialized in Commit::replaceText.
llvm-svn: 159306 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | express library-level dependencies within Clang.
This is no more verbose really, and plays nicer with the rest of the
CMake facilities. It should also have no change in functionality.
llvm-svn: 158888 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | [NSNumber numberWithDouble:cppb];
warning: converting to boxing syntax requires a cast
to something like:
[NSNumber numberWithDouble:cppb];
warning: converting to boxing syntax requires casting 'bool' to 'double'
This is way better to fully understand the warning.
rdar://11705106
llvm-svn: 158783 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | ObjCInterfaceDec::lookupInstanceMethod to make sure we check categories as well
and update related tests.
rdar://11695288
llvm-svn: 158697 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | literals,
since the change from +1 to +0 will be handled fine by ARC.
rdar://11606358
llvm-svn: 158114 | 
| | 
| 
| 
| 
| 
| 
| 
| | been declared on NSArray/NSDictionary.
rdar://11581975
llvm-svn: 157951 | 
| | 
| 
| 
| 
| 
| 
| 
| | because it requires a cast.
rdar://11525138
llvm-svn: 157395 | 
| | 
| 
| 
| 
| 
| | rdar://11501256
llvm-svn: 157227 | 
| | 
| 
| 
| 
| 
| | Part of rdar://11438360
llvm-svn: 156880 | 
| | 
| 
| 
| 
| 
| 
| 
| | more liberal in rewriting when the parameter is an enum constant.
Part of rdar://11438360
llvm-svn: 156873 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | to use the @() boxing syntax.
It will also rewrite uses of stringWithCString:encoding: where the encoding that is
used is NSASCIIStringEncoding or NSUTF8StringEncoding.
rdar://11438360
llvm-svn: 156868 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | There are some caveats:
-If an implicit cast (e.g. int -> float for numberWithFloat:) was required, the message
 will not get rewritten
-If the message was with numberWithInteger:/numberWithUnsignedInteger:, which are very
 commonly used, be more liberal and allow the boxing syntax if the underlying type has
 same signedness and will not lose precision.
Part of rdar://11438360
llvm-svn: 156844 | 
| | 
| 
| 
| 
| 
| 
| 
| | the receiver in parentheses when necessary.
Part of rdar://11438360
llvm-svn: 156789 |