|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | There are a couple of interesting things here that we want to check over
(particularly the expecting asserts in StringRef) and get right for general use
in ADT so hold back on this one. For clang we have a workable templated
solution to use in the meanwhile.
This reverts commit r200187.
llvm-svn: 200194 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | (1) Add llvm_expect(), an asserting macro that can be evaluated as a constexpr
    expression as well as a runtime assert or compiler hint in release builds. This
    technique can be used to construct functions that are both unevaluated and
    compiled depending on usage.
(2) Update StringRef using llvm_expect() to preserve runtime assertions while
    extending the same checks to static asserts in C++11 builds that support the
    feature.
(3) Introduce ConstStringRef, a strong subclass of StringRef that references
    compile-time constant strings. It's convertible to, but not from, ordinary
    StringRef and thus can be used to add compile-time safety to various interfaces
    in LLVM and clang that only accept fixed inputs such as diagnostic format
    strings that tend to get misused.
llvm-svn: 200187 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | subsequent changes are easier to review. About to fix some layering
issues, and wanted to separate out the necessary churn.
Also comment and sink the include of "Windows.h" in three .inc files to
match the usage in Memory.inc.
llvm-svn: 198685 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | This change is incorrect. If you delete virtual destructor of both a base class
and a subclass, then the following code:
  Base *foo = new Child();
  delete foo;
will not cause the destructor for members of Child class. As a result, I observe
plently of memory leaks. Notable examples I investigated are:
ObjectBuffer and ObjectBufferStream, AttributeImpl and StringSAttributeImpl.
llvm-svn: 194997 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | This patch removes most of the trivial cases of weak vtables by pinning them to
a single object file.
Differential Revision: http://llvm-reviews.chandlerc.com/D2068
Reviewed by Andy
llvm-svn: 194865 | 
| | 
| 
| 
| 
| 
| 
| 
| | This is a stopgap fix for cast warnings introduced in r192864.
A proper fix should be investigated by the author when possible.
llvm-svn: 193160 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | I expose the API with some caveats:
- The C++ API involves a traditional void* opaque pointer for the fatal 
error callback.  The C API doesn’t do this.  I don’t think that the void* 
opaque pointer makes any sense since this is a global callback - there will 
only be one of them.  So if you need to pass some data to your callback, 
just put it in a global variable.
- The bindings will ignore the gen_crash_diag boolean.  I ignore it because 
(1) I don’t know what it does, (2) it’s not documented AFAIK, and (3) I 
couldn’t imagine any use for it.  I made the gut call that it probably 
wasn’t important enough to expose through the C API.
llvm-svn: 192864 | 
| | 
| 
| 
| | llvm-svn: 186413 | 
| | 
| 
| 
| 
| 
| 
| | if crash diagnostics should be generated.  By default this is enabled.
Part of rdar://13296693
llvm-svn: 178161 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Sooooo many of these had incorrect or strange main module includes.
I have manually inspected all of these, and fixed the main module
include to be the nearest plausible thing I could find. If you own or
care about any of these source files, I encourage you to take some time
and check that these edits were sensible. I can't have broken anything
(I strictly added headers, and reordered them, never removed), but they
may not be the headers you'd really like to identify as containing the
API being implemented.
Many forward declarations and missing includes were added to a header
files to allow them to parse cleanly when included first. The main
module rule does in fact have its merits. =]
llvm-svn: 169131 | 
| | 
| 
| 
| 
| 
| | command-line syntax errors.
llvm-svn: 167849 | 
| | 
| 
| 
| | llvm-svn: 167755 | 
| | 
| 
| 
| | llvm-svn: 130054 | 
| | 
| 
| 
| | llvm-svn: 120298 | 
| | 
| 
| 
| | llvm-svn: 118972 | 
| | 
| 
| 
| 
| 
| | with attribute warn_unused_result" here - suppress the warning harder.
llvm-svn: 114072 | 
| | 
| 
| 
| | llvm-svn: 111432 | 
| | 
| 
| 
| | llvm-svn: 111325 | 
| | 
| 
| 
| 
| 
| 
| | into report_fatal_error.  Just blast the string to stderr with write(2)
and hope for the best!  Part of rdar://8318441
llvm-svn: 111320 | 
| | 
| 
| 
| 
| 
| | ungracefully.
llvm-svn: 103334 | 
| | 
| 
| 
| 
| 
| | and friends.
llvm-svn: 100717 | 
| | 
| 
| 
| | llvm-svn: 100709 | 
| | 
| 
| 
| | llvm-svn: 99414 | 
| | 
| 
| 
| | llvm-svn: 92637 | 
| | 
| 
| 
| 
| 
| | the ErrorHandler callback.
llvm-svn: 79541 | 
| | 
| 
| 
| | llvm-svn: 78848 | 
| | 
| 
| 
| | llvm-svn: 78553 | 
| | 
| 
| 
| | llvm-svn: 76961 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | This adds location info for all llvm_unreachable calls (which is a macro now) in
!NDEBUG builds.
In NDEBUG builds location info and the message is off (it only prints
"UREACHABLE executed").
llvm-svn: 75640 | 
| | 
| 
| 
| 
| 
| 
| | Fix by making the LLVM_UNREACHABLE pass __FILE__ and __LINE__ to
llvm_unreachable.
llvm-svn: 75631 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | Make llvm_unreachable take an optional string, thus moving the cerr<< out of
line.
LLVM_UNREACHABLE is now a simple wrapper that makes the message go away for
NDEBUG builds.
llvm-svn: 75379 | 
| | 
| 
| 
| | llvm-svn: 74923 | 
|  | This will replace exit()/abort() style error handling with an API
that allows clients to register custom error handling hooks.
The default is to call exit(1) when no error handler is provided.
llvm-svn: 74922 |