|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| ... |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | - References to ObjC bit-field ivars are bit-field lvalues;
    fixes rdar://13794269, which got me started down this.
  - Introduce Expr::refersToBitField, switch a couple users to
    it where semantically important, and comment the difference
    between this and the existing API.
  - Discourage Expr::getBitField by making it a bit longer and
    less general-sounding.
  - Lock down on const_casts of bit-field gl-values until we
    hear back from the committee as to whether they're allowed.
llvm-svn: 181252 | 
| | 
| 
| 
| 
| 
| 
| 
| | InitializationSequence::Diagnose()
Patch by Robert Wilhelm.
llvm-svn: 181022 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | The suggestion was already in the text of the note; this just adds the
actual fixit and the appropriate test cases.
Patch by Alexander Zinenko!
llvm-svn: 178274 | 
| | 
| 
| 
| 
| 
| 
| | declarations at any point. Patch by Alexander Zinenko, and
report by Richard Smith.
llvm-svn: 178098 | 
| | 
| 
| 
| 
| 
| 
| 
| | hierarchy-related at a possibly nonzero offset.
Patch by Alexander Zinenko!
llvm-svn: 177698 | 
| | 
| 
| 
| 
| 
| 
| | c++'s named cast need be replaced for bridge casting.
// rdar://12788838
llvm-svn: 175923 | 
| | 
| 
| 
| 
| 
| | Patch by Joey Gouly!
llvm-svn: 174928 | 
| | 
| 
| 
| 
| 
| 
| 
| | operations (as opposed to storage only half/fp16).
Also add some semantic checks for OpenCL half types.
llvm-svn: 173254 | 
| | 
| 
| 
| | llvm-svn: 171367 | 
| | 
| 
| 
| 
| 
| | to (SEL). Fixes // rdar://12859590
llvm-svn: 170058 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | 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 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | This implementation doesn't warn on anything that GCC doesn't warn on with the
exception of templates specializations (GCC doesn't warn, Clang does). The
specific skipped cases (boolean, constant expressions, enums) are open for
debate/adjustment if anyone wants to demonstrate that GCC is being overly
conservative here. The only really obvious false positive I found was in the
Clang regression suite's MPI test - apparently MPI uses specific flag values in
pointer constants. (eg: #define FOO (void*)~0)
llvm-svn: 166039 | 
| | 
| 
| 
| 
| 
| 
| 
| | MutableArrayRef.
This required changing all get() calls to data() and using the simpler constructors.
llvm-svn: 162501 | 
| | 
| 
| 
| 
| 
| 
| | These were nops for quite a while and only lead to confusion. ASTMultiPtr
now behaves like a proper dumb array reference.
llvm-svn: 162475 | 
| | 
| 
| 
| 
| 
| 
| | on unsafe cast of a c-function call. This is
a C-only option.
llvm-svn: 162109 | 
| | 
| 
| 
| 
| 
| 
| | expressions except to void, void * and their
qualified versions. // rdar://12107381
llvm-svn: 162036 | 
| | 
| 
| 
| 
| 
| | CXXFunctionalCastExprs.
llvm-svn: 160252 | 
| | 
| 
| 
| 
| 
| 
| 
| | semantics when promotions are involved.
(As far as I can tell, this only affects some edge cases.)
llvm-svn: 158591 | 
| | 
| 
| 
| 
| 
| | function-style cast.  Fixed PR12658.
llvm-svn: 156271 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | off PartialDiagnostic. PartialDiagnostic is rather heavyweight for
something that is in the critical path and is rarely used. So, switch
over to an abstract-class-based callback mechanism that delays most of
the work until a diagnostic is actually produced. Good for ~11k code
size reduction in the compiler and 1% speedup in -fsyntax-only on the
code in <rdar://problem/11004361>.
llvm-svn: 156176 | 
| | 
| 
| 
| 
| 
| | type. But a glvalue can be reinterpret_cast to either flavor of reference.
llvm-svn: 155789 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | (Lex to AST).
The member variable is always "LangOpts" and the member function is always "getLangOpts".
Reviewed by Chris Lattner
llvm-svn: 152536 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | NSNumber, and boolean literals.  This includes both Sema and Codegen support.
Included is also support for new Objective-C container subscripting.
My apologies for the large patch.  It was very difficult to break apart.
The patch introduces changes to the driver as well to cause clang to link
in additional runtime support when needed to support the new language features.
Docs are forthcoming to document the implementation and behavior of these features.
llvm-svn: 152137 | 
| | 
| 
| 
| | llvm-svn: 151447 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | is general goodness because representations of member pointers are
not always equivalent across member pointer types on all ABIs
(even though this isn't really standard-endorsed).
Take advantage of the new information to teach IR-generation how
to do these reinterprets in constant initializers.  Make sure this
works when intermingled with hierarchy conversions (although
this is not part of our motivating use case).  Doing this in the
constant-evaluator would probably have been better, but that would
require a *lot* of extra structure in the representation of
constant member pointers:  you'd really have to track an arbitrary
chain of hierarchy conversions and reinterpretations in order to
get this right.  Ultimately, this seems less complex.  I also
wasn't quite sure how to extend the constant evaluator to handle
foldings that we don't actually want to treat as extended
constant expressions.
llvm-svn: 150551 | 
| | 
| 
| 
| 
| 
| | functional cast code path. It sometimes does the wrong thing, produces horrible error messages, and is just unnecessary.
llvm-svn: 150408 | 
| | 
| 
| 
| 
| 
| | expressions. Array new still missing.
llvm-svn: 150346 | 
| | 
| 
| 
| 
| 
| | distinguish between list and parens form. This allows us to correctly diagnose the last test cases from litb.
llvm-svn: 150343 | 
| | 
| 
| 
| 
| 
| 
| 
| | a cast to the same type is allowed so long as it does not cast away constness.
Fix for PR11747. Patch by Aaron Ballman. Reviewed by Eli.
llvm-svn: 149664 | 
| | 
| 
| 
| 
| 
| | appropriate or when GCC requires it)
llvm-svn: 148292 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | - Add atomic-to/from-nonatomic cast types
- Emit atomic operations for arithmetic on atomic types
- Emit non-atomic stores for initialisation of atomic types, but atomic stores and loads for every other store / load
- Add a __atomic_init() intrinsic which does a non-atomic store to an _Atomic() type.  This is needed for the corresponding C11 stdatomic.h function.
- Enables the relevant __has_feature() checks.  The feature isn't 100% complete yet, but it's done enough that we want people testing it.
Still to do:
- Make the arithmetic operations on atomic types (e.g. Atomic(int) foo = 1; foo++;) use the correct LLVM intrinsic if one exists, not a loop with a cmpxchg.
- Add a signal fence builtin
- Properly set the fenv state in atomic operations on floating point values
- Correctly handle things like _Atomic(_Complex double) which are too large for an atomic cmpxchg on some platforms (this requires working out what 'correctly' means in this context)
- Fix the many remaining corner cases
llvm-svn: 148242 | 
| | 
| 
| 
| | llvm-svn: 147984 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | for some cast expressions.
Original commit message:
Removed useless ImplicitCast nodes in explicit cstyle and static casts
llvm-svn: 145447 | 
| | 
| 
| 
| | llvm-svn: 145244 | 
| | 
| 
| 
| | llvm-svn: 144637 | 
| | 
| 
| 
| | llvm-svn: 143364 | 
| | 
| 
| 
| | llvm-svn: 142419 | 
| | 
| 
| 
| 
| 
| 
| | passing/receiving CF objects at +0 to/from Objective-C methods
or audited C functions.
llvm-svn: 142219 | 
| | 
| 
| 
| 
| 
| | has placeholder type.
llvm-svn: 142203 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | and DefaultFunctionArrayLvalueConversion.  To prevent
significant regression for should-this-be-a-call fixits,
and to repair some such regression from the introduction of
bound member placeholders, make those placeholder checks
try to build calls appropriately.  Harden the build-a-call
logic while we're at it.
llvm-svn: 141738 | 
|  | llvm-svn: 141686 |