mirror of
https://github.com/dart-lang/sdk
synced 2024-09-19 20:41:45 +00:00
07f43510a2
Assert against Exceptions::PropagateError skipping over LongJumpScopes and LongJumpScope::Jump skipping over exit frames. Bug: https://github.com/dart-lang/sdk/issues/35224 Change-Id: I67004a73265882191cb1945cb5a049559b747e89 Reviewed-on: https://dart-review.googlesource.com/c/85411 Commit-Queue: Ryan Macnak <rmacnak@google.com> Reviewed-by: Martin Kustermann <kustermann@google.com>
48 lines
1.3 KiB
C++
48 lines
1.3 KiB
C++
// Copyright (c) 2011, 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 "vm/longjump.h"
|
|
|
|
#include "include/dart_api.h"
|
|
|
|
#include "vm/dart_api_impl.h"
|
|
#include "vm/isolate.h"
|
|
#include "vm/object.h"
|
|
#include "vm/os.h"
|
|
|
|
namespace dart {
|
|
|
|
jmp_buf* LongJumpScope::Set() {
|
|
ASSERT(top_ == NULL);
|
|
top_ = Thread::Current()->top_resource();
|
|
return &environment_;
|
|
}
|
|
|
|
void LongJumpScope::Jump(int value, const Error& error) {
|
|
// A zero is the default return value from setting up a LongJumpScope
|
|
// using Set.
|
|
ASSERT(value != 0);
|
|
ASSERT(!error.IsNull());
|
|
|
|
Thread* thread = Thread::Current();
|
|
DEBUG_ASSERT(thread->TopErrorHandlerIsSetJump());
|
|
|
|
#if defined(DEBUG)
|
|
#define CHECK_REUSABLE_HANDLE(name) \
|
|
ASSERT(!thread->reusable_##name##_handle_scope_active());
|
|
REUSABLE_HANDLE_LIST(CHECK_REUSABLE_HANDLE)
|
|
#undef CHECK_REUSABLE_HANDLE
|
|
#endif // defined(DEBUG)
|
|
|
|
// Remember the error in the sticky error of this isolate.
|
|
thread->set_sticky_error(error);
|
|
|
|
// Destruct all the active StackResource objects.
|
|
StackResource::UnwindAbove(thread, top_);
|
|
longjmp(environment_, value);
|
|
UNREACHABLE();
|
|
}
|
|
|
|
} // namespace dart
|