Index: runtime/lib/object.cc |
diff --git a/runtime/lib/object.cc b/runtime/lib/object.cc |
index 09e4808ba15c1ff9fe06776d455ef08186363190..b450038b0f5a832117a6b8c458eee5da46f28e3d 100644 |
--- a/runtime/lib/object.cc |
+++ b/runtime/lib/object.cc |
@@ -138,10 +138,11 @@ DEFINE_NATIVE_ENTRY(Object_instanceOf, 4) { |
const char* result_str = is_instance_of ? "true" : "false"; |
OS::Print("Native Object.instanceOf: result %s\n", result_str); |
const AbstractType& instance_type = |
- AbstractType::Handle(instance.GetType()); |
+ AbstractType::Handle(zone, instance.GetType()); |
OS::Print(" instance type: %s\n", |
- String::Handle(instance_type.Name()).ToCString()); |
- OS::Print(" test type: %s\n", String::Handle(type.Name()).ToCString()); |
+ String::Handle(zone, instance_type.Name()).ToCString()); |
+ OS::Print(" test type: %s\n", |
+ String::Handle(zone, type.Name()).ToCString()); |
if (!bound_error.IsNull()) { |
OS::Print(" bound error: %s\n", bound_error.ToErrorCString()); |
} |
@@ -155,7 +156,7 @@ DEFINE_NATIVE_ENTRY(Object_instanceOf, 4) { |
String& bound_error_message = String::Handle( |
zone, String::New(bound_error.ToErrorCString())); |
Exceptions::CreateAndThrowTypeError( |
- location, Symbols::Empty(), Symbols::Empty(), |
+ location, AbstractType::Handle(zone), AbstractType::Handle(zone), |
Symbols::Empty(), bound_error_message); |
UNREACHABLE(); |
} |
@@ -224,15 +225,16 @@ DEFINE_NATIVE_ENTRY(Object_instanceOfString, 2) { |
DEFINE_NATIVE_ENTRY(Object_as, 3) { |
- const Instance& instance = Instance::CheckedHandle(arguments->NativeArgAt(0)); |
+ const Instance& instance = |
+ Instance::CheckedHandle(zone, arguments->NativeArgAt(0)); |
const TypeArguments& instantiator_type_arguments = |
- TypeArguments::CheckedHandle(arguments->NativeArgAt(1)); |
- const AbstractType& type = |
- AbstractType::CheckedHandle(arguments->NativeArgAt(2)); |
+ TypeArguments::CheckedHandle(zone, arguments->NativeArgAt(1)); |
+ AbstractType& type = |
+ AbstractType::CheckedHandle(zone, arguments->NativeArgAt(2)); |
ASSERT(type.IsFinalized()); |
ASSERT(!type.IsMalformed()); |
ASSERT(!type.IsMalbounded()); |
- Error& bound_error = Error::Handle(); |
+ Error& bound_error = Error::Handle(zone); |
if (instance.IsNull()) { |
return instance.raw(); |
} |
@@ -243,10 +245,11 @@ DEFINE_NATIVE_ENTRY(Object_as, 3) { |
const char* result_str = is_instance_of ? "true" : "false"; |
OS::Print("Object.as: result %s\n", result_str); |
const AbstractType& instance_type = |
- AbstractType::Handle(instance.GetType()); |
+ AbstractType::Handle(zone, instance.GetType()); |
OS::Print(" instance type: %s\n", |
- String::Handle(instance_type.Name()).ToCString()); |
- OS::Print(" cast type: %s\n", String::Handle(type.Name()).ToCString()); |
+ String::Handle(zone, instance_type.Name()).ToCString()); |
+ OS::Print(" cast type: %s\n", |
+ String::Handle(zone, type.Name()).ToCString()); |
if (!bound_error.IsNull()) { |
OS::Print(" bound error: %s\n", bound_error.ToErrorCString()); |
} |
@@ -257,33 +260,23 @@ DEFINE_NATIVE_ENTRY(Object_as, 3) { |
ASSERT(caller_frame != NULL); |
const TokenPosition location = caller_frame->GetTokenPos(); |
const AbstractType& instance_type = |
- AbstractType::Handle(instance.GetType()); |
- const String& instance_type_name = |
- String::Handle(instance_type.UserVisibleName()); |
- String& type_name = String::Handle(); |
+ AbstractType::Handle(zone, instance.GetType()); |
if (!type.IsInstantiated()) { |
// Instantiate type before reporting the error. |
- const AbstractType& instantiated_type = AbstractType::Handle( |
- type.InstantiateFrom(instantiator_type_arguments, NULL, |
- NULL, NULL, Heap::kNew)); |
- // Note that instantiated_type may be malformed. |
- type_name = instantiated_type.UserVisibleName(); |
- } else { |
- type_name = type.UserVisibleName(); |
+ type = type.InstantiateFrom(instantiator_type_arguments, NULL, |
+ NULL, NULL, Heap::kNew); |
+ // Note that the instantiated type may be malformed. |
} |
- String& bound_error_message = String::Handle(); |
if (bound_error.IsNull()) { |
- const String& dst_name = String::ZoneHandle( |
- Symbols::New(Exceptions::kCastErrorDstName)); |
- |
Exceptions::CreateAndThrowTypeError( |
- location, instance_type_name, type_name, |
- dst_name, Object::null_string()); |
+ location, instance_type, type, |
+ Symbols::InTypeCast(), Object::null_string()); |
} else { |
ASSERT(isolate->type_checks()); |
- bound_error_message = String::New(bound_error.ToErrorCString()); |
+ const String& bound_error_message = |
+ String::Handle(zone, String::New(bound_error.ToErrorCString())); |
Exceptions::CreateAndThrowTypeError( |
- location, instance_type_name, Symbols::Empty(), |
+ location, instance_type, AbstractType::Handle(zone), |
Symbols::Empty(), bound_error_message); |
} |
UNREACHABLE(); |
@@ -294,14 +287,14 @@ DEFINE_NATIVE_ENTRY(Object_as, 3) { |
DEFINE_NATIVE_ENTRY(AbstractType_toString, 1) { |
const AbstractType& type = |
- AbstractType::CheckedHandle(arguments->NativeArgAt(0)); |
+ AbstractType::CheckedHandle(zone, arguments->NativeArgAt(0)); |
return type.UserVisibleName(); |
} |
DEFINE_NATIVE_ENTRY(LibraryPrefix_invalidateDependentCode, 1) { |
const LibraryPrefix& prefix = |
- LibraryPrefix::CheckedHandle(arguments->NativeArgAt(0)); |
+ LibraryPrefix::CheckedHandle(zone, arguments->NativeArgAt(0)); |
prefix.InvalidateDependentCode(); |
return Bool::Get(true).raw(); |
} |
@@ -309,7 +302,7 @@ DEFINE_NATIVE_ENTRY(LibraryPrefix_invalidateDependentCode, 1) { |
DEFINE_NATIVE_ENTRY(LibraryPrefix_load, 1) { |
const LibraryPrefix& prefix = |
- LibraryPrefix::CheckedHandle(arguments->NativeArgAt(0)); |
+ LibraryPrefix::CheckedHandle(zone, arguments->NativeArgAt(0)); |
bool hasCompleted = prefix.LoadLibrary(); |
return Bool::Get(hasCompleted).raw(); |
} |
@@ -317,19 +310,19 @@ DEFINE_NATIVE_ENTRY(LibraryPrefix_load, 1) { |
DEFINE_NATIVE_ENTRY(LibraryPrefix_loadError, 1) { |
const LibraryPrefix& prefix = |
- LibraryPrefix::CheckedHandle(arguments->NativeArgAt(0)); |
+ LibraryPrefix::CheckedHandle(zone, arguments->NativeArgAt(0)); |
// Currently all errors are Dart instances, e.g. I/O errors |
// created by deferred loading code. LanguageErrors from |
// failed loading or finalization attempts are propagated and result |
// in the isolate's death. |
- const Instance& error = Instance::Handle(prefix.LoadError()); |
+ const Instance& error = Instance::Handle(zone, prefix.LoadError()); |
return error.raw(); |
} |
DEFINE_NATIVE_ENTRY(LibraryPrefix_isLoaded, 1) { |
const LibraryPrefix& prefix = |
- LibraryPrefix::CheckedHandle(arguments->NativeArgAt(0)); |
+ LibraryPrefix::CheckedHandle(zone, arguments->NativeArgAt(0)); |
return Bool::Get(prefix.is_loaded()).raw(); |
} |