mirror of
https://github.com/dart-lang/sdk
synced 2024-09-05 16:41:07 +00:00
e0e14c370a
TEST=build Change-Id: I1a01702451f1be91f14c3a860fa3f84b0c686409 Reviewed-on: https://dart-review.googlesource.com/c/sdk/+/292062 Reviewed-by: Alexander Aprelev <aam@google.com> Commit-Queue: Ryan Macnak <rmacnak@google.com>
70 lines
2.1 KiB
C++
70 lines
2.1 KiB
C++
// Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file
|
|
// for details. All rights reserved. Use of this source code is governed by a
|
|
// BSD-style license that can be found in the LICENSE file.
|
|
|
|
#include "platform/assert.h"
|
|
|
|
#include "include/dart_api.h"
|
|
#include "platform/globals.h"
|
|
#include "platform/syslog.h"
|
|
|
|
#if defined(DART_HOST_OS_ANDROID)
|
|
extern "C" __attribute__((weak)) void android_set_abort_message(const char*);
|
|
#endif // defined(DART_HOST_OS_ANDROID)
|
|
|
|
namespace dart {
|
|
|
|
bool Expect::failed_ = false;
|
|
|
|
void DynamicAssertionHelper::Print(const char* format,
|
|
va_list arguments,
|
|
bool will_abort /* = false */) const {
|
|
// Take only the last 1KB of the file name if it is longer.
|
|
const intptr_t file_len = strlen(file_);
|
|
const intptr_t file_offset = (file_len > (1 * KB)) ? file_len - (1 * KB) : 0;
|
|
const char* file = file_ + file_offset;
|
|
|
|
// Print the file and line number into the buffer.
|
|
char buffer[4 * KB];
|
|
MSAN_UNPOISON(buffer, sizeof(buffer));
|
|
intptr_t file_and_line_length =
|
|
snprintf(buffer, sizeof(buffer), "%s: %d: error: ", file, line_);
|
|
|
|
// Print the error message into the buffer.
|
|
vsnprintf(buffer + file_and_line_length,
|
|
sizeof(buffer) - file_and_line_length, format, arguments);
|
|
|
|
// Print the buffer on stderr and/or syslog.
|
|
Syslog::PrintErr("%s\n", buffer);
|
|
#if defined(DART_HOST_OS_ANDROID)
|
|
if (will_abort && (&android_set_abort_message != nullptr)) {
|
|
android_set_abort_message(buffer);
|
|
}
|
|
#endif // defined(DART_HOST_OS_ANDROID)
|
|
}
|
|
|
|
void Assert::Fail(const char* format, ...) const {
|
|
va_list arguments;
|
|
va_start(arguments, format);
|
|
Print(format, arguments, /*will_abort=*/true);
|
|
va_end(arguments);
|
|
|
|
// Abort right away.
|
|
Dart_DumpNativeStackTrace(nullptr);
|
|
Dart_PrepareToAbort();
|
|
abort();
|
|
}
|
|
|
|
void Expect::Fail(const char* format, ...) const {
|
|
va_list arguments;
|
|
va_start(arguments, format);
|
|
Print(format, arguments);
|
|
va_end(arguments);
|
|
|
|
// Wait until the program is exiting before producing a non-zero exit
|
|
// code through abort.
|
|
failed_ = true;
|
|
}
|
|
|
|
} // namespace dart
|