|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| ... |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | The conventional form is '<action> to silence this warning'.
Also call the diagnostic an 'issue' rather than a 'message' because the latter
term is more widely used with reference to message expressions.
llvm-svn: 209052 | 
| | 
| 
| 
| | llvm-svn: 207896 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Summary:
Previously, we would generate a single name for all reference
temporaries and allow LLVM to rename them for us.  Instead, number the
reference temporaries as we build them in Sema.
Reviewers: rsmith
Subscribers: cfe-commits
Differential Revision: http://reviews.llvm.org/D3554
llvm-svn: 207776 | 
| | 
| 
| 
| 
| 
| | symbols in non-imported modules.
llvm-svn: 206977 | 
| | 
| 
| 
| 
| 
| 
| | when building the candidate set, rather than trying to contort name lookup into
handling this.
llvm-svn: 206436 | 
| | 
| 
| 
| 
| 
| | iterator_range bases(). Updating all of the usages of the iterators with range-based for loops.
llvm-svn: 203803 | 
| | 
| 
| 
| 
| 
| | class.
llvm-svn: 203640 | 
| | 
| 
| 
| 
| 
| 
| 
| | instead, per post-commit review feedback.
Replacing llvm::copy changes with SmallVector range-based construction which is a considerably cleaner approach.
llvm-svn: 203461 | 
| | 
| 
| 
| 
| 
| | iterator_range fields(). Updating all of the usages of the iterators with range-based for loops.
llvm-svn: 203355 | 
| | 
| 
| 
| 
| 
| | Differential Revision: http://llvm-reviews.chandlerc.com/D2711
llvm-svn: 201926 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | A return type is the declared or deduced part of the function type specified in
the declaration.
A result type is the (potentially adjusted) type of the value of an expression
that calls the function.
Rule of thumb:
  * Declarations have return types and parameters.
  * Expressions have result types and arguments.
llvm-svn: 200082 | 
| | 
| 
| 
| | llvm-svn: 198420 | 
| | 
| 
| 
| 
| 
| | Finishes the work started in r194224, and fixes <rdar://problem/15494681>.
llvm-svn: 197609 | 
| | 
| 
| 
| 
| 
| 
| 
| | cstring, converted to NSString, produce the
matching AST for it. This also required some
refactoring of the previous code. // rdar://14106083
llvm-svn: 197605 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | of objc_bridge_related attribute; eliminate
unnecessary diagnostics which is issued elsewhere,
fixit now produces a valid AST tree per convention.
This results in some simplification in handling of
this attribute as well. // rdar://15499111
llvm-svn: 197436 | 
| | 
| 
| 
| 
| 
| 
| | attributed CF to ObjC type conversions.
// rdar://15499111
llvm-svn: 196935 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | attribute in sema and issuing a variety of diagnostics lazily 
for misuse of this attribute (and what to do) when converting 
from CF types to ObjectiveC types (and vice versa).
// rdar://15499111
llvm-svn: 196629 | 
| | 
| 
| 
| 
| 
| 
| | This patch tries to avoid unrelated changes other than fixing a few
hyphen-related ambiguities in nearby lines.
llvm-svn: 196466 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | For an init capture, process the initialization expression
right away.  For lambda init-captures such as the following:
const int x = 10;
 auto L = [i = x+1](int a) {
   return [j = x+2,
          &k = x](char b) { };
 };
keep in mind that each lambda init-capture has to have:
 - its initialization expression executed in the context
   of the enclosing/parent decl-context.
 - but the variable itself has to be 'injected' into the
   decl-context of its lambda's call-operator (which has
   not yet been created).
Each init-expression is a full-expression that has to get
Sema-analyzed (for capturing etc.) before its lambda's
call-operator's decl-context, scope & scopeinfo are pushed on their
respective stacks.  Thus if any variable is odr-used in the init-capture
it will correctly get captured in the enclosing lambda, if one exists.
The init-variables above are created later once the lambdascope and
call-operators decl-context is pushed onto its respective stack.
Since the lambda init-capture's initializer expression occurs in the
context of the enclosing function or lambda, therefore we can not wait
till a lambda scope has been pushed on before deciding whether the
variable needs to be captured.  We also need to process all
lvalue-to-rvalue conversions and discarded-value conversions,
so that we can avoid capturing certain constant variables.
For e.g.,
 void test() {
  const int x = 10;
  auto L = [&z = x](char a) { <-- don't capture by the current lambda
    return [y = x](int i) { <-- don't capture by enclosing lambda
         return y;
    }
  };
If x was not const, the second use would require 'L' to capture, and
that would be an error.
Make sure TranformLambdaExpr is also aware of this.
Patch approved by Richard (Thanks!!) 
http://llvm-reviews.chandlerc.com/D2092
llvm-svn: 196454 | 
| | 
| 
| 
| | llvm-svn: 195384 | 
| | 
| 
| 
| | llvm-svn: 195095 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | substitution failure, allow a flag to be set on the Diagnostic object,
to mark it as 'causes substitution failure'.
Refactor Diagnostic.td and the tablegen to use an enum for SFINAE behavior
rather than a bunch of flags.
llvm-svn: 194444 | 
| | 
| 
| 
| | llvm-svn: 194242 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | We now emit warnings when doing so and code generation is consistent
with GCC. Note that the C99 spec is unclear as to the precise
behavior.
See also ...
Bug:
  http://llvm.org/bugs/show_bug.cgi?id=16644 and
cfe-dev discussion:
  http://lists.cs.uiuc.edu/pipermail/cfe-dev/2013-September/031918.html
llvm-svn: 191890 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | an additional conversion (other than a qualification conversion) would be
required after the explicit conversion.
Conversely, do allow explicit conversion functions to be used when initializing
a temporary for a reference binding in direct-list-initialization.
llvm-svn: 191150 | 
| | 
| 
| 
| | llvm-svn: 191147 | 
| | 
| 
| 
| 
| 
| 
| 
| | rather than a post-processing action, so we can support inserting these checks
at stages other than the end of the initialization. No functionality change
intended.
llvm-svn: 191146 | 
| | 
| 
| 
| 
| 
| 
| | so the Index in/out parameters are pointless (always passed in as 0, always
ignored by the caller).
llvm-svn: 191103 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | AssignConvertType::IncompatibleVectors means the two types are in fact
compatible. :)
No testcase; I don't think the extra init list has any actual visible effect
other than making the resulting AST dump look a bit strange.
llvm-svn: 190845 | 
| | 
| 
| 
| | llvm-svn: 190249 | 
| | 
| 
| 
| 
| 
| 
| 
| | For clarity, renamed (get/set)ParenRange as (get/set)ParenOrBraceRange
in CXXConstructExpr nodes.
Added testcase.
llvm-svn: 190239 | 
| | 
| 
| 
| 
| 
| | Fixes PR16931.
llvm-svn: 188718 | 
| | 
| 
| 
| 
| 
| 
| | preparation for teaching this function how to diagnose a correction that
includes importing a module.
llvm-svn: 188602 | 
| | 
| 
| 
| 
| 
| 
| | retainable pointer is passed to an audited CF function
expecting CF type. // rdar://14569171
llvm-svn: 187543 | 
| | 
| 
| 
| 
| 
| 
| 
| | passing a retainable object arg to a CF audited function
expecting a CF object type. Issue a normal type mismatch
diagnostic. This is wip // rdar://14569171
llvm-svn: 187532 | 
| | 
| 
| 
| 
| 
| 
| 
| | for parameters passed to CF audited functions
to be used for better diagnostics. Current set but
unused. // rdar://14569171
llvm-svn: 187508 | 
| | 
| 
| 
| 
| 
| | No functionality change.
llvm-svn: 187047 | 
| | 
| 
| 
| 
| 
| 
| | certain familiy of methods have the wrong type.
// rdar://14408244
llvm-svn: 186111 | 
| | 
| 
| 
| 
| 
| 
| 
| | result type, a diagnostic being issued, issue a 'note' 
mentioning reason behind the unexpected warning.
// rdar://14121570.
llvm-svn: 186105 | 
| | 
| 
| 
| 
| 
| | avoid specifying the vector size unnecessarily.
llvm-svn: 185610 | 
| | 
| 
| 
| 
| 
| | InitListExpr.
llvm-svn: 185304 | 
| | 
| 
| 
| 
| 
| | initialized during aggregate initialization of the surrounding structure.
llvm-svn: 185117 | 
| | 
| 
| 
| | llvm-svn: 185058 | 
| | 
| 
| 
| 
| 
| | specifically states that the type is incomplete and points to the forward declaration of the incomplete type.
llvm-svn: 185056 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | return false;
in a function returning a pointer. 'false' was a null pointer constant in C++98
but is not in C++11. Punch a very small hole in the initialization rules in
C++11 mode to allow this specific case in system headers.
llvm-svn: 184395 | 
| | 
| 
| 
| | llvm-svn: 184154 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | the result of a cast-to-reference-type lifetime-extends the object to which the
reference inside the cast binds.
This requires us to look for subobject adjustments on both the inside and the
outside of the MaterializeTemporaryExpr when looking for a temporary to
lifetime-extend (which we also need for core issue 616, and possibly 1213).
llvm-svn: 184024 | 
| | 
| 
| 
| 
| 
| | explicit constructors.
llvm-svn: 183879 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Introduce CXXStdInitializerListExpr node, representing the implicit
construction of a std::initializer_list<T> object from its underlying array.
The AST representation of such an expression goes from an InitListExpr with a
flag set, to a CXXStdInitializerListExpr containing a MaterializeTemporaryExpr
containing an InitListExpr (possibly wrapped in a CXXBindTemporaryExpr).
This more detailed representation has several advantages, the most important of
which is that the new MaterializeTemporaryExpr allows us to directly model
lifetime extension of the underlying temporary array. Using that, this patch
*drastically* simplifies the IR generation of this construct, provides IR
generation support for nested global initializer_list objects, fixes several
bugs where the destructors for the underlying array would accidentally not get
invoked, and provides constant expression evaluation support for
std::initializer_list objects.
llvm-svn: 183872 | 
| | 
| 
| 
| 
| 
| 
| | CXXCtorInitializers to the point where we perform the questionable lifetime
extension. This exposed a selection of false negatives in the warning.
llvm-svn: 183869 |