| 1 | // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file |
| 2 | // for details. All rights reserved. Use of this source code is governed by a |
| 3 | // BSD-style license that can be found in the LICENSE file. |
| 4 | |
| 5 | #include "platform/assert.h" |
| 6 | |
| 7 | #include "include/dart_api.h" |
| 8 | #include "platform/globals.h" |
| 9 | #include "platform/syslog.h" |
| 10 | |
| 11 | namespace dart { |
| 12 | |
| 13 | bool Expect::failed_ = false; |
| 14 | |
| 15 | void DynamicAssertionHelper::Print(const char* format, va_list arguments) { |
| 16 | // Take only the last 1KB of the file name if it is longer. |
| 17 | const intptr_t file_len = strlen(file_); |
| 18 | const intptr_t file_offset = (file_len > (1 * KB)) ? file_len - (1 * KB) : 0; |
| 19 | const char* file = file_ + file_offset; |
| 20 | |
| 21 | // Print the file and line number into the buffer. |
| 22 | char buffer[4 * KB]; |
| 23 | MSAN_UNPOISON(buffer, sizeof(buffer)); |
| 24 | intptr_t file_and_line_length = |
| 25 | snprintf(buffer, sizeof(buffer), "%s: %d: error: " , file, line_); |
| 26 | |
| 27 | // Print the error message into the buffer. |
| 28 | vsnprintf(buffer + file_and_line_length, |
| 29 | sizeof(buffer) - file_and_line_length, format, arguments); |
| 30 | |
| 31 | // Print the buffer on stderr and/or syslog. |
| 32 | Syslog::PrintErr("%s\n" , buffer); |
| 33 | } |
| 34 | |
| 35 | void Assert::Fail(const char* format, ...) { |
| 36 | va_list arguments; |
| 37 | va_start(arguments, format); |
| 38 | Print(format, arguments); |
| 39 | va_end(arguments); |
| 40 | |
| 41 | // Abort right away. |
| 42 | Dart_DumpNativeStackTrace(NULL); |
| 43 | Dart_PrepareToAbort(); |
| 44 | abort(); |
| 45 | } |
| 46 | |
| 47 | void Expect::Fail(const char* format, ...) { |
| 48 | va_list arguments; |
| 49 | va_start(arguments, format); |
| 50 | Print(format, arguments); |
| 51 | va_end(arguments); |
| 52 | |
| 53 | // Wait until the program is exiting before producing a non-zero exit |
| 54 | // code through abort. |
| 55 | failed_ = true; |
| 56 | } |
| 57 | |
| 58 | } // namespace dart |
| 59 | |