dart-sdk/runtime/bin/crashpad.cc
Zach Anderson f407419d0a [vm] Reland: Prefix HOST_OS_* and TARGET_OS_* with DART_
This relands https://dart-review.googlesource.com/c/sdk/+/205633
but without renaming TARGET_OS_IPHONE to DART_TARGET_OS_IPHONE.
It also changes uses of TARGET_OS_IOS to
DART_TARGET_OS_MACOS_IOS to be consistent with the rest of the
VM.

TargetConditionals.h for XCode 13 defines several
TARGET_OS_* preprocessor symbols that confuse the
Dart build. There is probably a more targeted fix
for this, but renaming the symbols that Dart uses
will also prevent this problem if more symbols
are added to the platform headers in the future.

See: https://github.com/dart-lang/sdk/issues/46499

TEST=It builds.

Change-Id: Ie775c19dd23cfdf5f65e5ebc6ee4ec3a561676fa
Reviewed-on: https://dart-review.googlesource.com/c/sdk/+/205860
Commit-Queue: Zach Anderson <zra@google.com>
Reviewed-by: Alexander Aprelev <aam@google.com>
2021-07-02 19:06:45 +00:00

81 lines
2.7 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 "bin/crashpad.h"
#if defined(DART_USE_CRASHPAD)
#include <map>
#include <string>
#include <vector>
#include "crashpad/client/crashpad_client.h"
#include "crashpad/client/crashpad_info.h"
#endif
#include "bin/error_exit.h"
#include "bin/platform.h"
#include "platform/syslog.h"
namespace dart {
namespace bin {
#if defined(DART_USE_CRASHPAD)
#if !defined(DART_HOST_OS_WINDOWS)
#error "Currently we only support Crashpad on Windows"
#endif
void InitializeCrashpadClient() {
// DART_CRASHPAD_HANDLER and DART_CRASHPAD_CRASHES_DIR are set by the
// testing framework.
wchar_t* handler = _wgetenv(L"DART_CRASHPAD_HANDLER");
wchar_t* crashes_dir = _wgetenv(L"DART_CRASHPAD_CRASHES_DIR");
if (handler == nullptr || crashes_dir == nullptr || wcslen(handler) == 0 ||
wcslen(crashes_dir) == 0) {
return;
}
// Crashpad uses STL so we use it here too even though in general we
// avoid it.
const base::FilePath handler_path{std::wstring(handler)};
const base::FilePath crashes_dir_path{std::wstring(crashes_dir)};
const std::string url("");
std::map<std::string, std::string> annotations;
char* test_name = getenv("DART_TEST_NAME");
if (test_name != nullptr) {
annotations["dart_test_name"] = test_name;
}
std::vector<std::string> arguments;
crashpad::CrashpadClient client;
// Prevent crashpad_handler from inheriting our standard output and error
// handles. Otherwise we would not be able to close them ourselves making
// tests that rely on that fail.
HANDLE original_stdout = GetStdHandle(STD_OUTPUT_HANDLE);
HANDLE original_stderr = GetStdHandle(STD_ERROR_HANDLE);
SetStdHandle(STD_OUTPUT_HANDLE, INVALID_HANDLE_VALUE);
SetStdHandle(STD_ERROR_HANDLE, INVALID_HANDLE_VALUE);
const bool success =
client.StartHandler(handler_path, crashes_dir_path, crashes_dir_path, url,
annotations, arguments,
/*restartable=*/true,
/*asynchronous_start=*/false);
SetStdHandle(STD_OUTPUT_HANDLE, original_stdout);
SetStdHandle(STD_ERROR_HANDLE, original_stderr);
if (!success) {
Syslog::PrintErr("Failed to start the crash handler!\n");
Platform::Exit(kErrorExitCode);
}
crashpad::CrashpadInfo::GetCrashpadInfo()
->set_gather_indirectly_referenced_memory(crashpad::TriState::kEnabled,
/*limit=*/500 * MB);
}
#else
void InitializeCrashpadClient() {}
#endif // DART_USE_CRASHPAD
} // namespace bin
} // namespace dart