[cfe-commits] [libcxxabi] r148752 - /libcxxabi/trunk/src/abort_message.cpp
Ted Kremenek
kremenek at apple.com
Mon Jan 23 16:33:01 PST 2012
Indeed. It should be removed.
On Jan 23, 2012, at 4:29 PM, Jean-Daniel Dupas wrote:
> Not guarded enough though.
> __APPLE__ is unconditionally defined by clang and GCC when compiling on OS X and iOS, and the second condition is true on Lion which actually does not include this header.
>
> Le 24 janv. 2012 à 01:18, Howard Hinnant a écrit :
>
>> Right, its inclusion is guarded:
>>
>>> +#if __APPLE__
>>> + #include <Availability.h>
>>> + #if __MAC_OS_X_VERSION_MIN_REQUIRED >= 1070
>>> + #include <CrashReporterClient.h>
>>
>> Howard
>>
>> On Jan 23, 2012, at 7:15 PM, Jean-Daniel Dupas wrote:
>>
>>> I know this part is not done yet, but I want just to be sure that you know CrashReporterClient.h is a private header and is not available outside of Apple (unless it is part of the latest Xcode beta that I don't have).
>>>
>>> Le 24 janv. 2012 à 00:58, Howard Hinnant a écrit :
>>>
>>>> Author: hhinnant
>>>> Date: Mon Jan 23 17:58:26 2012
>>>> New Revision: 148752
>>>>
>>>> URL: http://llvm.org/viewvc/llvm-project?rev=148752&view=rev
>>>> Log:
>>>> I renamed abort_message to be a C++ file to simplify my simplistic build script which I'm still working on. I also added a struct for the crash reporter on __APPLE__.
>>>>
>>>> Added:
>>>> libcxxabi/trunk/src/abort_message.cpp
>>>>
>>>> Added: libcxxabi/trunk/src/abort_message.cpp
>>>> URL: http://llvm.org/viewvc/llvm-project/libcxxabi/trunk/src/abort_message.cpp?rev=148752&view=auto
>>>> ==============================================================================
>>>> --- libcxxabi/trunk/src/abort_message.cpp (added)
>>>> +++ libcxxabi/trunk/src/abort_message.cpp Mon Jan 23 17:58:26 2012
>>>> @@ -0,0 +1,58 @@
>>>> +//===-------------------------- abort_message.c ---------------------------===//
>>>> +//
>>>> +// The LLVM Compiler Infrastructure
>>>> +//
>>>> +// This file is dual licensed under the MIT and the University of Illinois Open
>>>> +// Source Licenses. See LICENSE.TXT for details.
>>>> +//
>>>> +//===----------------------------------------------------------------------===//
>>>> +
>>>> +#include <stdlib.h>
>>>> +#include <stdio.h>
>>>> +#include <stdarg.h>
>>>> +
>>>> +#if __APPLE__
>>>> + #include <Availability.h>
>>>> + #if __MAC_OS_X_VERSION_MIN_REQUIRED >= 1070
>>>> + #include <CrashReporterClient.h>
>>>> +
>>>> + // If any clients of llvm try to link to libCrashReporterClient.a themselves,
>>>> + // only one crash info struct will be used.
>>>> + extern "C" {
>>>> + CRASH_REPORTER_CLIENT_HIDDEN
>>>> + struct crashreporter_annotations_t gCRAnnotations
>>>> + __attribute__((section("__DATA," CRASHREPORTER_ANNOTATIONS_SECTION)))
>>>> + = { CRASHREPORTER_ANNOTATIONS_VERSION, 0, 0, 0, 0, 0, 0 };
>>>> + }
>>>> +
>>>> + #endif
>>>> +#endif
>>>> +
>>>> +#include "abort_message.h"
>>>> +
>>>> +__attribute__((visibility("hidden")))
>>>> +void abort_message(const char* format, ...)
>>>> +{
>>>> + // write message to stderr
>>>> +#if __APPLE__
>>>> + fprintf(stderr, "libc++abi.dylib: ");
>>>> +#endif
>>>> + va_list list;
>>>> + va_start(list, format);
>>>> + vfprintf(stderr, format, list);
>>>> + va_end(list);
>>>> + fprintf(stderr, "\n");
>>>> +
>>>> +#if __APPLE__ && (__MAC_OS_X_VERSION_MIN_REQUIRED >= 1070)
>>>> + // record message in crash report
>>>> + char* buffer;
>>>> + va_list list2;
>>>> + va_start(list2, format);
>>>> + vasprintf(&buffer, format, list2);
>>>> + va_end(list2);
>>>> + CRSetCrashLogMessage(buffer);
>>>> +#endif
>>>> +
>>>> + abort();
>>>> +}
>>>
>>>
>>> -- Jean-Daniel
>>>
>>>
>>>
>>>
>>
>
> -- Jean-Daniel
>
>
>
>
>
> _______________________________________________
> cfe-commits mailing list
> cfe-commits at cs.uiuc.edu
> http://lists.cs.uiuc.edu/mailman/listinfo/cfe-commits
More information about the cfe-commits
mailing list