Index: src/objects.cc |
diff --git a/src/objects.cc b/src/objects.cc |
index ca780dbe0ea44bbf81cf337e7494afcd507fd933..cac68294dd66942d355dc948662105a4c1150b0b 100644 |
--- a/src/objects.cc |
+++ b/src/objects.cc |
@@ -2233,6 +2233,44 @@ MUST_USE_RESULT MaybeObject* JSProxy::SetPropertyWithHandler( |
} |
+MUST_USE_RESULT MaybeObject* JSProxy::DeletePropertyWithHandler( |
+ String* name_raw, DeleteMode mode) { |
+ Isolate* isolate = GetIsolate(); |
+ HandleScope scope; |
Mads Ager (chromium)
2011/07/14 16:17:22
You should pass in the isolate to the HandleScope
rossberg
2011/07/15 08:47:40
Done, here and in a number of other places.
|
+ Handle<Object> receiver(this); |
+ Handle<Object> name(name_raw); |
+ Handle<Object> handler(this->handler()); |
+ |
+ // Extract trap function. |
+ Handle<String> trap_name = isolate->factory()->LookupAsciiSymbol("delete"); |
+ Handle<Object> trap(v8::internal::GetProperty(handler, trap_name)); |
+ if (trap->IsUndefined()) { |
+ Handle<Object> args[] = { handler, trap_name }; |
+ Handle<Object> error = isolate->factory()->NewTypeError( |
+ "handler_trap_missing", HandleVector(args, ARRAY_SIZE(args))); |
+ isolate->Throw(*error); |
+ return Failure::Exception(); |
+ } |
+ |
+ // Call trap function. |
+ Object** args[] = { name.location() }; |
+ bool has_exception; |
+ Handle<Object> result = |
+ Execution::Call(trap, handler, ARRAY_SIZE(args), args, &has_exception); |
+ if (has_exception) return Failure::Exception(); |
+ |
+ Object* bool_result = result->ToBoolean(); |
+ if (mode != NORMAL_DELETION && bool_result == GetHeap()->false_value()) { |
Mads Ager (chromium)
2011/07/14 16:17:22
Do we want this behavior for FORCE_DELETION as wel
rossberg
2011/07/15 08:47:40
Done.
|
+ Handle<Object> args[] = { handler, trap_name }; |
+ Handle<Object> error = isolate->factory()->NewTypeError( |
+ "handler_failed", HandleVector(args, ARRAY_SIZE(args))); |
+ isolate->Throw(*error); |
+ return Failure::Exception(); |
+ } |
+ return bool_result; |
+} |
+ |
+ |
MUST_USE_RESULT PropertyAttributes JSProxy::GetPropertyAttributeWithHandler( |
JSReceiver* receiver_raw, |
String* name_raw, |
@@ -3179,6 +3217,15 @@ MaybeObject* JSObject::DeleteElement(uint32_t index, DeleteMode mode) { |
} |
+MaybeObject* JSReceiver::DeleteProperty(String* name, DeleteMode mode) { |
+ if (IsJSProxy()) { |
+ return JSProxy::cast(this)->DeletePropertyWithHandler(name, mode); |
+ } else { |
+ return JSObject::cast(this)->DeleteProperty(name, mode); |
+ } |
+} |
+ |
+ |
MaybeObject* JSObject::DeleteProperty(String* name, DeleteMode mode) { |
Isolate* isolate = GetIsolate(); |
// ECMA-262, 3rd, 8.6.2.5 |
@@ -11053,11 +11100,11 @@ void NumberDictionary::RemoveNumberEntries(uint32_t from, uint32_t to) { |
template<typename Shape, typename Key> |
Object* Dictionary<Shape, Key>::DeleteProperty(int entry, |
- JSObject::DeleteMode mode) { |
+ JSReceiver::DeleteMode mode) { |
Heap* heap = Dictionary<Shape, Key>::GetHeap(); |
PropertyDetails details = DetailsAt(entry); |
// Ignore attributes if forcing a deletion. |
- if (details.IsDontDelete() && mode != JSObject::FORCE_DELETION) { |
+ if (details.IsDontDelete() && mode != JSReceiver::FORCE_DELETION) { |
return heap->false_value(); |
} |
SetEntry(entry, heap->null_value(), heap->null_value()); |