|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| | llvm-svn: 65613 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | - For types whose native representation is a pointer.
 - Use to replace ExprConstant.cpp:HasPointerEvalType,
   CodeGenFunction::isObjCPointerType.
llvm-svn: 65569 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | pretty sure we want to keep constant expression verification outside of 
Evaluate. Because of that, the short-circuit evaluation doesn't 
generally make sense, and the comma warning doesn't make sense in its 
current form.
llvm-svn: 65525 | 
| | 
| 
| 
| 
| 
| 
| | The big difference here is that (like string literal) @encode has 
array type, not pointer type.
llvm-svn: 65391 | 
| | 
| 
| 
| 
| 
| | Remove support for "Class<P>". Will be making this an error.
llvm-svn: 65332 | 
| | 
| 
| 
| | llvm-svn: 65305 | 
| | 
| 
| 
| 
| 
| | someone would reasonably expect Evaluate to handle for C/ObjC.
llvm-svn: 65284 | 
| | 
| 
| 
| 
| 
| 
| 
| | I know, these follow the exact same rules as pointers, so I just made 
them use the same codepath.  Someone more familiar with ObjC should 
double-check this, though.
llvm-svn: 65261 | 
| | 
| 
| 
| 
| 
| | partially done in r65258.)
llvm-svn: 65260 | 
| | 
| 
| 
| 
| 
| 
| | expr; hilarity ensued.
 - PR3640.
llvm-svn: 65234 | 
| | 
| 
| 
| 
| 
| | - PR3463 (again).
llvm-svn: 65133 | 
| | 
| 
| 
| | llvm-svn: 65105 | 
| | 
| 
| 
| 
| 
| | from the testsuite.
llvm-svn: 65098 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | - PR3463, PR3398, <rdar://problem/6553401> crash on relocatable
   symbol addresses as constants in static locals.
 - There are many more scenarious we could handle (like arithmetic on
   such an int) but this is the main use case.
llvm-svn: 65074 | 
| | 
| 
| 
| | llvm-svn: 65073 | 
| | 
| 
| 
| 
| 
| 
| | appear to be constant.  I'll probably redo this and throw it all away
later once we have codegen for BlockDeclRefExprs.
llvm-svn: 65070 | 
| | 
| 
| 
| 
| 
| | - Prep for handling lvalues, no intended functionality change.
llvm-svn: 65063 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | manual setting of the Result.
 - Idiom now enforces that result will always have correct width and
   type; this exposed three new bugs:
    o Enum constant decl value can have different width than type
      (PR3173).
    o EvaluateInteger should not run an IntExprEvaluator over
      non-integral expressions.
    o FloatExprEvaluate was not handling casts correctly (it was
      evaluating the cast in the IntExprEvaluator!).
llvm-svn: 65053 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | - Handles assignment to Result with appropriate type.
 - Simplifies & encapsulates most direct handling of the Result value;
   prep for allowing IntExprEvaluator to deal with LValue APValues.
 - No intended functionality change.
llvm-svn: 65038 | 
| | 
| 
| 
| 
| 
| | expressions as well.
llvm-svn: 65013 | 
| | 
| 
| 
| 
| 
| | The size calculation is improved.
llvm-svn: 64994 | 
| | 
| 
| 
| | llvm-svn: 64951 | 
| | 
| 
| 
| 
| 
| | with Expr::Evaluate().
llvm-svn: 64850 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | - Renamed to getDeclAlignInBytes since most other query functions
   work in bits.
 - Fun to track down as isIntegerConstantExpr was getting it right,
   but Evaluate() was getting it wrong. Maybe we should assert they
   compute the same thing when they succeed?
llvm-svn: 64828 | 
| | 
| 
| 
| 
| 
| 
| | general use; as for, objc2's gc type attributes. No
change in functionality.
llvm-svn: 64778 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | about, whether they are builtins or not. Use this to add the
appropriate "format" attribute to NSLog, NSLogv, asprintf, and
vasprintf, and to translate builtin attributes (from Builtins.def)
into actual attributes on the function declaration.
Use the "printf" format attribute on function declarations to
determine whether we should do format string checking, rather than
looking at an ad hoc list of builtins and "known" function names.
Be a bit more careful about when we consider a function a "builtin" in
C++.
llvm-svn: 64561 | 
| | 
| 
| 
| | llvm-svn: 64086 | 
| | 
| 
| 
| | llvm-svn: 63280 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | - Lift (int,float) -> (int,float) conversion into separate routines.
 - Fix handling of, e.g., char -> _Complex int, which was producing a
   _Complex char value instead.
llvm-svn: 63278 | 
| | 
| 
| 
| 
| 
| | redundant #includes.  Patch by Anders Johnsen!
llvm-svn: 63271 | 
| | 
| 
| 
| 
| 
| 
| 
| | evaluation (alternate part of real/imag init was being set to 3 not 0
because the wrong APFloat constructor was being called).
 - Test cases coming once some more support is in.
llvm-svn: 63264 | 
| | 
| 
| 
| 
| 
| 
| | - Merged into single ComplexEvaluator, these share too much logic to
   be worth splitting for float/int (IMHO). Will split on request.
llvm-svn: 63248 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | .def file for each library.  This means that adding a diagnostic
to sema doesn't require all the other libraries to be rebuilt.
Patch by Anders Johnsen!
llvm-svn: 63111 | 
| | 
| 
| 
| 
| 
| 
| | __builtin___CFStringMakeConstantString.  (We get into trouble in 
GenerateStaticBlockVarDecl if the constant folder isn't accurate.)
llvm-svn: 62949 | 
| | 
| 
| 
| 
| 
| | constant.
llvm-svn: 62948 | 
| | 
| 
| 
| 
| 
| | sizeof expressions.
llvm-svn: 62941 | 
| | 
| 
| 
| 
| 
| 
| | not the type" semantics.  This can definitely be improved, but is better than
what we had.
llvm-svn: 62939 | 
| | 
| 
| 
| | llvm-svn: 62932 | 
| | 
| 
| 
| 
| 
| 
| | mismatched semantics).
 - Enforce this in APValue.
llvm-svn: 62924 | 
| | 
| 
| 
| | llvm-svn: 62455 | 
| | 
| 
| 
| | llvm-svn: 62292 | 
| | 
| 
| 
| 
| 
| | and uninitialized use options.
llvm-svn: 62270 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Make C++ classes track the POD property (C++ [class]p4)
Track the existence of a copy assignment operator.
Implicitly declare the copy assignment operator if none is provided.
Implement most of the parsing job for the G++ type traits extension.
Fully implement the low-hanging fruit of the type traits:
__is_pod: Whether a type is a POD.
__is_class: Whether a type is a (non-union) class.
__is_union: Whether a type is a union.
__is_enum: Whether a type is an enum.
__is_polymorphic: Whether a type is polymorphic (C++ [class.virtual]p1).
llvm-svn: 61746 | 
| | 
| 
| 
| | llvm-svn: 61314 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | which can refer to static data members, enumerators, and member
functions as well as to non-static data members.
Implement correct lvalue computation for member references in C++. 
Compute the result type of non-static data members of reference type properly.
llvm-svn: 61294 | 
| | 
| 
| 
| | llvm-svn: 61260 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | and separates lexical name lookup from qualified name lookup. In
particular:
  * Make DeclContext the central data structure for storing and
    looking up declarations within existing declarations, e.g., members
    of structs/unions/classes, enumerators in C++0x enums, members of
    C++ namespaces, and (later) members of Objective-C
    interfaces/implementations. DeclContext uses a lazily-constructed
    data structure optimized for fast lookup (array for small contexts,
    hash table for larger contexts). 
  * Implement C++ qualified name lookup in terms of lookup into
    DeclContext.
  * Implement C++ unqualified name lookup in terms of
    qualified+unqualified name lookup (since unqualified lookup is not
    purely lexical in C++!)
  * Limit the use of the chains of declarations stored in
    IdentifierInfo to those names declared lexically.
  * Eliminate CXXFieldDecl, collapsing its behavior into
    FieldDecl. (FieldDecl is now a ScopedDecl).
  * Make RecordDecl into a DeclContext and eliminates its
    Members/NumMembers fields (since one can just iterate through the
    DeclContext to get the fields).
llvm-svn: 60878 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | code were working correctly, it would be a no-op, but it's not really a 
proper fix.  That said, I don't really want to touch the enum code at 
the moment because I don't understand it very well, and this seems to 
be a relatively visible regression.
llvm-svn: 60680 | 
| | 
| 
| 
| | llvm-svn: 60582 | 
| | 
| 
| 
| | llvm-svn: 60581 |