|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| 
| 
| 
| 
| | variables in C, in the cases where we can constant-fold it to a value
regardless (such as floating-point division by zero and signed integer
overflow). Strictly enforcing this rule breaks too much code.
llvm-svn: 254992 | 
| | 
| 
| 
| 
| 
| 
| 
| | not integer constant expressions. In passing, fix the 'folding is an extension'
diagnostic to not claim we're accepting the code, since that's not true in
-pedantic-errors mode, and add this diagnostic to -Wgnu.
llvm-svn: 148209 | 
| | 
| 
| 
| 
| 
| | type. Fixes PR8089 in a slightly different way than had been suggested.
llvm-svn: 113711 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | for incomplete enum types.  An incomplete enum can't really be treated as
an "integral or enumeration" type, and the incorrect treatment leads to
bad behavior for many callers.
This makes isIntegralOrEnumerationType equivalent to isIntegerType; I think
we should globally replace the latter with the former; thoughts?
llvm-svn: 111512 | 
| | 
| 
| 
| 
| 
| | C++). Fixes PR7466.
llvm-svn: 108231 | 
| | 
| 
| 
| 
| 
| | enum as a GNU extension.
llvm-svn: 106540 | 
| | 
| 
| 
| 
| 
| | type. Fixes PR7051.
llvm-svn: 104475 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | lvalue-to-rvalue conversion adjusts lvalues of qualified, non-class
type to rvalue expressions of the unqualified variant of that
type. For example, given:
  const int i;
  (void)(i + 17);
the lvalue-to-rvalue conversion for the subexpression "i" will turn it
from an lvalue expression (a DeclRefExpr) with type 'const int' into
an rvalue expression with type 'int'. Both C and C++ mandate this
conversion, and somehow we've slid through without implementing it. 
We now have both DefaultFunctionArrayConversion and
DefaultFunctionArrayLvalueConversion, and which gets used depends on
whether we do the lvalue-to-rvalue conversion or not. Generally, we do
the lvalue-to-rvalue conversion, but there are a few notable
exceptions:
  - the left-hand side of a '.' operator
  - the left-hand side of an assignment
  - a C++ throw expression
  - a subscript expression that's subscripting a vector
Making this change exposed two issues with blocks:
  - we were deducing const-qualified return types of non-class type
  from a block return, which doesn't fit well
  - we weren't always setting the known return type of a block when it
  was provided with the ^return-type syntax
Fixes the current Clang-on-Clang compile failure and PR6076.
llvm-svn: 95167 | 
| | 
| 
| 
| 
| 
| 
| | ForRedeclaration flag so that we don't look into base classes. 
Fixes PR6061.
llvm-svn: 93862 | 
| | 
| 
| 
| | llvm-svn: 91566 | 
| | 
| 
| 
| | llvm-svn: 91563 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | - This is designed to make it obvious that %clang_cc1 is a "test variable"
   which is substituted. It is '%clang_cc1' instead of '%clang -cc1' because it
   can be useful to redefine what gets run as 'clang -cc1' (for example, to set
   a default target).
llvm-svn: 91446 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | "integer promotion" type associated with an enum decl, and use this type to
determine which type to promote to.  This type obeys C++ [conv.prom]p2 and
is therefore generally signed unless the range of the enumerators forces
it to be unsigned.
Kills off a lot of false positives from -Wsign-compare in C++, addressing
rdar://7455616
llvm-svn: 90965 | 
| | 
| 
| 
| 
| 
| | create the enum type in the same scope as you would a record type.
llvm-svn: 90500 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | This will improve error messages. For
struct B;
B f();
void g() {
f();
}
We now get
t.cpp:6:3: error: calling 'f' with incomplete return type 'struct B'
  f();
  ^~~
t.cpp:3:3: note: 'f' declared here
B f();
  ^
t.cpp:1:8: note: forward declaration of 'struct B'
struct B;
       ^
llvm-svn: 83692 | 
| | 
| 
| 
| | llvm-svn: 81346 | 
| | 
| 
| 
| 
| 
| | Tests and drivers updated, still need to shuffle dirs.
llvm-svn: 67602 | 
| | 
| 
| 
| | llvm-svn: 67485 | 
| | 
| 
| 
| 
| 
| | struct N::M::foo
llvm-svn: 67284 | 
| | 
| 
| 
| 
| 
| | C and C++. Fixes PR3688.
llvm-svn: 66282 | 
| | 
| 
| 
| 
| 
| | with reference type (it should be an lvalue with non-reference type).
llvm-svn: 62345 | 
|  | llvm-svn: 60940 |