|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| 
| 
| 
| 
| | http://reviews.llvm.org/D12855#246073.
NFC.
llvm-svn: 247678 | 
| | 
| 
| 
| 
| 
| 
| 
| | Patch by Pedro Ferreira.
Reviewers: pekka.jaaskelainen
Differential Revision: http://reviews.llvm.org/D12855
llvm-svn: 247676 | 
| | 
| 
| 
| 
| 
| 
| 
| | Adds parsing/sema analysis/serialization/deserialization for array sections in OpenMP constructs (introduced in OpenMP 4.0).
Currently it is allowed to use array sections only in OpenMP clauses that accepts list of expressions.
Differential Revision: http://reviews.llvm.org/D10732
llvm-svn: 245937 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Produce type parameter declarations for Objective-C type parameters,
and attach lists of type parameters to Objective-C classes,
categories, forward declarations, and extensions as
appropriate. Perform semantic analysis of type bounds for type
parameters, both in isolation and across classes/categories/extensions
to ensure consistency.
Also handle (de-)serialization of Objective-C type parameter lists,
along with sundry other things one must do to add a new declaration to
Clang.
Note that Objective-C type parameters are typedef name declarations,
like typedefs and C++11 type aliases, in support of type erasure.
Part of rdar://problem/6294649.
llvm-svn: 241541 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | of extern "C" declarations. This is simpler and vastly more efficient for
modules builds (we no longer need to load *all* extern "C" declarations to
determine if we have a redeclaration).
No functionality change intended.
llvm-svn: 231538 | 
| | 
| 
| 
| 
| 
| 
| | context as anonymous for merging purposes. They can't be found by their names,
so we merge them based on their position within the surrounding context.
llvm-svn: 228485 | 
| | 
| 
| 
| 
| 
| 
| | merging of namespace aliases across modules and improves source fidelity.
Incidentally also fixes PR20816.
llvm-svn: 217103 | 
| | 
| 
| 
| 
| 
| | contexts, so that we can merge them when we merge the surrounding context.
llvm-svn: 216639 | 
| | 
| 
| 
| | llvm-svn: 209392 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | modules.
With this fixed, I no longer see any test regressions in the libc++ test suite
when enabling a single-module module.map for libc++ (other than issues with my
system headers).
llvm-svn: 193219 | 
| | 
| 
| 
| 
| 
| | fully supported, up to some limitations documented as FIXMEs or TODO. Static data member templates work very partially. Static data member templates of class templates need particular attention...
llvm-svn: 187762 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Add CapturedDecl to be the DeclContext for CapturedStmt, and perform semantic
analysis. Currently captures all variables by reference.
TODO: templates
Author: Ben Langmuir <ben.langmuir@intel.com>
Differential Revision: http://llvm-reviews.chandlerc.com/D433
llvm-svn: 179618 | 
| | 
| 
| 
| 
| 
| 
| 
| | references thereto.
Patch by Tong Shen!
llvm-svn: 179585 | 
| | 
| 
| 
| | llvm-svn: 177705 | 
| | 
| 
| 
| 
| 
| 
| 
| | Introduce a new AST Decl node "EmptyDecl" to model empty-declaration. Have attributes from attribute-declaration appertain
to the EmptyDecl node by creating the AST representations of these attributes and attach them to the EmptyDecl node so these
attributes can be sema checked just as attributes attached to "normal" declarations.
llvm-svn: 175900 | 
| | 
| 
| 
| 
| 
| | restrictions.
llvm-svn: 174601 | 
| | 
| 
| 
| 
| 
| 
| | would expect, and clean up the return/break inconsistencies. Thanks,
Sebastian!
llvm-svn: 173171 | 
| | 
| 
| 
| 
| 
| 
| | kind indicates that it can never be redeclared. Good for a 1% speedup,
and redeclaration searching drops off the profile.
llvm-svn: 173054 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | DeclContext. When the DeclContext is of a kind that can only be
defined once and never updated, we limit the search to the module file
that conatins the lookup table. Provides a 15% speedup in one
modules-heavy source file.
llvm-svn: 173050 | 
| | 
| 
| 
| 
| 
| | OpenCL restrictions (OpenCL 1.2 spec 6.9)
llvm-svn: 172973 | 
| | 
| 
| 
| 
| 
| | Add OpenCL images as clang builtin types.
llvm-svn: 170432 | 
| | 
| 
| 
| 
| 
| | these files to Windows style.
llvm-svn: 170431 | 
| | 
| 
| 
| | llvm-svn: 170428 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | 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 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | (__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 | 
| | 
| 
| 
| 
| 
| | GCC compiler workaround.
llvm-svn: 142931 | 
| | 
| 
| 
| 
| 
| | r142914: "Introduce a placeholder type for "pseudo object""
r142915: "Pull the pseudo-object stuff into its own file."
llvm-svn: 142921 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | expressions: expressions which refer to a logical rather
than a physical l-value, where the logical object is
actually accessed via custom getter/setter code.
A subsequent patch will generalize the AST for these
so that arbitrary "implementing" sub-expressions can
be provided.
Right now the only client is ObjC properties, but
this should be generalizable to similar language
features, e.g. Managed C++'s __property methods.
llvm-svn: 142914 | 
| | 
| 
| 
| 
| 
| 
| 
| | casts in ARC.
No semantic analysis yet.
llvm-svn: 142208 | 
| | 
| 
| 
| 
| 
| | Lack of half FP was a regression compared to llvm-gcc.
llvm-svn: 142016 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | bound
member function, i.e. something of the form 'x.f' where 'f' is a non-static
member function.  Diagnose this in the general case.  Some of the new diagnostics
are probably worse than the old ones, but we now get this right much more
universally, and there's certainly room for improvement in the diagnostics.
llvm-svn: 130239 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | The idea is that you can create a VarDecl with an unknown type, or a
FunctionDecl with an unknown return type, and it will still be valid to
access that object as long as you explicitly cast it at every use.  I'm
still going back and forth about how I want to test this effectively, but
I wanted to go ahead and provide a skeletal implementation for the LLDB
folks' benefit and because it also improves some diagnostic goodness for
placeholder expressions.
llvm-svn: 129065 | 
| | 
| 
| 
| 
| 
| | This fixes PR 8738, 9060 and 9132.
llvm-svn: 126069 | 
| | 
| 
| 
| 
| 
| 
| | 16-bits in size.  Implement this by splitting WChar into two enums, like we have
for char.  This fixes a miscompmilation of XULRunner, PR8856.
llvm-svn: 122558 | 
| | 
| 
| 
| 
| 
| | functionality change.
llvm-svn: 116506 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | more generic
MakeTypeID template function which accepts a type and a function object that returns a TypeIdx.
MakeTypeID is in PCHCommon.h so that it can be used by ASTReader too.
llvm-svn: 111634 | 
|  | copies in PCHReader and PCHWriter.
No functionality change.
llvm-svn: 111629 |