| Index: runtime/lib/error.cc
|
| ===================================================================
|
| --- runtime/lib/error.cc (revision 25781)
|
| +++ runtime/lib/error.cc (working copy)
|
| @@ -1,130 +0,0 @@
|
| -// 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 "lib/error.h"
|
| -
|
| -#include "vm/bootstrap_natives.h"
|
| -#include "vm/exceptions.h"
|
| -#include "vm/object_store.h"
|
| -#include "vm/runtime_entry.h"
|
| -#include "vm/stack_frame.h"
|
| -
|
| -namespace dart {
|
| -
|
| -DEFINE_FLAG(bool, trace_type_checks, false, "Trace runtime type checks.");
|
| -
|
| -// Allocate and throw a new AssertionError.
|
| -// Arg0: index of the first token of the failed assertion.
|
| -// Arg1: index of the first token after the failed assertion.
|
| -// Return value: none, throws an exception.
|
| -DEFINE_NATIVE_ENTRY(AssertionError_throwNew, 2) {
|
| - // No need to type check the arguments. This function can only be called
|
| - // internally from the VM.
|
| - intptr_t assertion_start =
|
| - Smi::CheckedHandle(arguments->NativeArgAt(0)).Value();
|
| - intptr_t assertion_end =
|
| - Smi::CheckedHandle(arguments->NativeArgAt(1)).Value();
|
| -
|
| - const Array& args = Array::Handle(Array::New(4));
|
| -
|
| - DartFrameIterator iterator;
|
| - iterator.NextFrame(); // Skip native call.
|
| - const Script& script = Script::Handle(Exceptions::GetCallerScript(&iterator));
|
| -
|
| - // Initialize argument 'failed_assertion' with source snippet.
|
| - intptr_t from_line, from_column;
|
| - script.GetTokenLocation(assertion_start, &from_line, &from_column);
|
| - intptr_t to_line, to_column;
|
| - script.GetTokenLocation(assertion_end, &to_line, &to_column);
|
| - args.SetAt(0, String::Handle(
|
| - script.GetSnippet(from_line, from_column, to_line, to_column)));
|
| -
|
| - // Initialize location arguments starting at position 1.
|
| - args.SetAt(1, String::Handle(script.url()));
|
| - args.SetAt(2, Smi::Handle(Smi::New(from_line)));
|
| - args.SetAt(3, Smi::Handle(Smi::New(from_column)));
|
| -
|
| - Exceptions::ThrowByType(Exceptions::kAssertion, args);
|
| - UNREACHABLE();
|
| - return Object::null();
|
| -}
|
| -
|
| -
|
| -// Allocate and throw a new TypeError.
|
| -// Arg0: index of the token of the failed type check.
|
| -// Arg1: src value.
|
| -// Arg2: dst type name.
|
| -// Arg3: dst name.
|
| -// Arg4: type error message.
|
| -// Return value: none, throws an exception.
|
| -DEFINE_NATIVE_ENTRY(TypeError_throwNew, 5) {
|
| - // No need to type check the arguments. This function can only be called
|
| - // internally from the VM.
|
| - intptr_t location = Smi::CheckedHandle(arguments->NativeArgAt(0)).Value();
|
| - const Instance& src_value =
|
| - Instance::CheckedHandle(arguments->NativeArgAt(1));
|
| - const String& dst_type_name =
|
| - String::CheckedHandle(arguments->NativeArgAt(2));
|
| - const String& dst_name = String::CheckedHandle(arguments->NativeArgAt(3));
|
| - const String& type_error = String::CheckedHandle(arguments->NativeArgAt(4));
|
| - const String& src_type_name =
|
| - String::Handle(Type::Handle(src_value.GetType()).UserVisibleName());
|
| - Exceptions::CreateAndThrowTypeError(location, src_type_name,
|
| - dst_type_name, dst_name, type_error);
|
| - UNREACHABLE();
|
| - return Object::null();
|
| -}
|
| -
|
| -
|
| -// Allocate and throw a new FallThroughError.
|
| -// Arg0: index of the case clause token into which we fall through.
|
| -// Return value: none, throws an exception.
|
| -DEFINE_NATIVE_ENTRY(FallThroughError_throwNew, 1) {
|
| - GET_NON_NULL_NATIVE_ARGUMENT(Smi, smi_pos, arguments->NativeArgAt(0));
|
| - intptr_t fallthrough_pos = smi_pos.Value();
|
| -
|
| - const Array& args = Array::Handle(Array::New(2));
|
| -
|
| - // Initialize 'url' and 'line' arguments.
|
| - DartFrameIterator iterator;
|
| - iterator.NextFrame(); // Skip native call.
|
| - const Script& script = Script::Handle(Exceptions::GetCallerScript(&iterator));
|
| - args.SetAt(0, String::Handle(script.url()));
|
| - intptr_t line, column;
|
| - script.GetTokenLocation(fallthrough_pos, &line, &column);
|
| - args.SetAt(1, Smi::Handle(Smi::New(line)));
|
| -
|
| - Exceptions::ThrowByType(Exceptions::kFallThrough, args);
|
| - UNREACHABLE();
|
| - return Object::null();
|
| -}
|
| -
|
| -
|
| -// Allocate and throw a new AbstractClassInstantiationError.
|
| -// Arg0: Token position of allocation statement.
|
| -// Arg1: class name of the abstract class that cannot be instantiated.
|
| -// Return value: none, throws an exception.
|
| -DEFINE_NATIVE_ENTRY(AbstractClassInstantiationError_throwNew, 2) {
|
| - GET_NON_NULL_NATIVE_ARGUMENT(Smi, smi_pos, arguments->NativeArgAt(0));
|
| - GET_NON_NULL_NATIVE_ARGUMENT(String, class_name, arguments->NativeArgAt(1));
|
| - intptr_t error_pos = smi_pos.Value();
|
| -
|
| - const Array& args = Array::Handle(Array::New(3));
|
| -
|
| - // Initialize 'className', 'url' and 'line' arguments.
|
| - DartFrameIterator iterator;
|
| - iterator.NextFrame(); // Skip native call.
|
| - const Script& script = Script::Handle(Exceptions::GetCallerScript(&iterator));
|
| - args.SetAt(0, class_name);
|
| - args.SetAt(1, String::Handle(script.url()));
|
| - intptr_t line, column;
|
| - script.GetTokenLocation(error_pos, &line, &column);
|
| - args.SetAt(2, Smi::Handle(Smi::New(line)));
|
| -
|
| - Exceptions::ThrowByType(Exceptions::kAbstractClassInstantiation, args);
|
| - UNREACHABLE();
|
| - return Object::null();
|
| -}
|
| -
|
| -} // namespace dart
|
|
|