OLD | NEW |
1 // Copyright 2014 the V8 project authors. All rights reserved. | 1 // Copyright 2014 the V8 project authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "src/runtime/runtime-utils.h" | 5 #include "src/runtime/runtime-utils.h" |
6 | 6 |
7 #include "src/arguments.h" | 7 #include "src/arguments.h" |
8 #include "src/bootstrapper.h" | 8 #include "src/bootstrapper.h" |
9 #include "src/debug/debug.h" | 9 #include "src/debug/debug.h" |
10 #include "src/isolate-inl.h" | 10 #include "src/isolate-inl.h" |
(...skipping 139 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
150 | 150 |
151 return Object::SetProperty(&it, value, language_mode, | 151 return Object::SetProperty(&it, value, language_mode, |
152 Object::MAY_BE_STORE_FROM_KEYED); | 152 Object::MAY_BE_STORE_FROM_KEYED); |
153 } | 153 } |
154 | 154 |
155 | 155 |
156 RUNTIME_FUNCTION(Runtime_GetPrototype) { | 156 RUNTIME_FUNCTION(Runtime_GetPrototype) { |
157 HandleScope scope(isolate); | 157 HandleScope scope(isolate); |
158 DCHECK(args.length() == 1); | 158 DCHECK(args.length() == 1); |
159 CONVERT_ARG_HANDLE_CHECKED(Object, obj, 0); | 159 CONVERT_ARG_HANDLE_CHECKED(Object, obj, 0); |
160 // We don't expect access checks to be needed on JSProxy objects. | 160 return *Object::GetPrototype(isolate, obj); |
161 DCHECK(!obj->IsAccessCheckNeeded() || obj->IsJSObject()); | |
162 PrototypeIterator iter(isolate, obj, PrototypeIterator::START_AT_RECEIVER); | |
163 Handle<Context> context(isolate->context()); | |
164 do { | |
165 if (PrototypeIterator::GetCurrent(iter)->IsAccessCheckNeeded() && | |
166 !isolate->MayAccess(context, | |
167 PrototypeIterator::GetCurrent<JSObject>(iter))) { | |
168 return isolate->heap()->null_value(); | |
169 } | |
170 iter.AdvanceIgnoringProxies(); | |
171 if (PrototypeIterator::GetCurrent(iter)->IsJSProxy()) { | |
172 return *PrototypeIterator::GetCurrent(iter); | |
173 } | |
174 } while (!iter.IsAtEnd(PrototypeIterator::END_AT_NON_HIDDEN)); | |
175 return *PrototypeIterator::GetCurrent(iter); | |
176 } | 161 } |
177 | 162 |
178 | 163 |
179 RUNTIME_FUNCTION(Runtime_InternalSetPrototype) { | 164 RUNTIME_FUNCTION(Runtime_InternalSetPrototype) { |
180 HandleScope scope(isolate); | 165 HandleScope scope(isolate); |
181 DCHECK(args.length() == 2); | 166 DCHECK(args.length() == 2); |
182 CONVERT_ARG_HANDLE_CHECKED(JSObject, obj, 0); | 167 CONVERT_ARG_HANDLE_CHECKED(JSObject, obj, 0); |
183 CONVERT_ARG_HANDLE_CHECKED(Object, prototype, 1); | 168 CONVERT_ARG_HANDLE_CHECKED(Object, prototype, 1); |
184 DCHECK(!obj->IsAccessCheckNeeded()); | 169 DCHECK(!obj->IsAccessCheckNeeded()); |
185 DCHECK(!obj->map()->is_observed()); | 170 DCHECK(!obj->map()->is_observed()); |
186 Handle<Object> result; | 171 Handle<Object> result; |
187 ASSIGN_RETURN_FAILURE_ON_EXCEPTION( | 172 ASSIGN_RETURN_FAILURE_ON_EXCEPTION( |
188 isolate, result, JSObject::SetPrototype(obj, prototype, false)); | 173 isolate, result, JSObject::SetPrototype(obj, prototype, false)); |
189 return *result; | 174 return *result; |
190 } | 175 } |
191 | 176 |
192 | 177 |
193 RUNTIME_FUNCTION(Runtime_SetPrototype) { | 178 RUNTIME_FUNCTION(Runtime_SetPrototype) { |
194 HandleScope scope(isolate); | 179 HandleScope scope(isolate); |
195 DCHECK(args.length() == 2); | 180 DCHECK(args.length() == 2); |
196 CONVERT_ARG_HANDLE_CHECKED(JSObject, obj, 0); | 181 CONVERT_ARG_HANDLE_CHECKED(JSObject, obj, 0); |
197 CONVERT_ARG_HANDLE_CHECKED(Object, prototype, 1); | 182 CONVERT_ARG_HANDLE_CHECKED(Object, prototype, 1); |
198 if (obj->IsAccessCheckNeeded() && | 183 if (obj->IsAccessCheckNeeded() && |
199 !isolate->MayAccess(handle(isolate->context()), obj)) { | 184 !isolate->MayAccess(handle(isolate->context()), obj)) { |
200 isolate->ReportFailedAccessCheck(obj); | 185 isolate->ReportFailedAccessCheck(obj); |
201 RETURN_FAILURE_IF_SCHEDULED_EXCEPTION(isolate); | 186 RETURN_FAILURE_IF_SCHEDULED_EXCEPTION(isolate); |
202 return isolate->heap()->undefined_value(); | 187 return isolate->heap()->undefined_value(); |
203 } | 188 } |
204 if (obj->map()->is_observed()) { | 189 if (obj->map()->is_observed()) { |
205 Handle<Object> old_value = | 190 Handle<Object> old_value = Object::GetPrototypeWithAccess(isolate, obj); |
206 Object::GetPrototypeSkipHiddenPrototypes(isolate, obj); | |
207 Handle<Object> result; | 191 Handle<Object> result; |
208 ASSIGN_RETURN_FAILURE_ON_EXCEPTION( | 192 ASSIGN_RETURN_FAILURE_ON_EXCEPTION( |
209 isolate, result, JSObject::SetPrototype(obj, prototype, true)); | 193 isolate, result, JSObject::SetPrototype(obj, prototype, true)); |
210 | 194 |
211 Handle<Object> new_value = | 195 Handle<Object> new_value = Object::GetPrototypeWithAccess(isolate, obj); |
212 Object::GetPrototypeSkipHiddenPrototypes(isolate, obj); | |
213 if (!new_value->SameValue(*old_value)) { | 196 if (!new_value->SameValue(*old_value)) { |
214 RETURN_FAILURE_ON_EXCEPTION( | 197 RETURN_FAILURE_ON_EXCEPTION( |
215 isolate, JSObject::EnqueueChangeRecord( | 198 isolate, JSObject::EnqueueChangeRecord( |
216 obj, "setPrototype", isolate->factory()->proto_string(), | 199 obj, "setPrototype", isolate->factory()->proto_string(), |
217 old_value)); | 200 old_value)); |
218 } | 201 } |
219 return *result; | 202 return *result; |
220 } | 203 } |
221 Handle<Object> result; | 204 Handle<Object> result; |
222 ASSIGN_RETURN_FAILURE_ON_EXCEPTION( | 205 ASSIGN_RETURN_FAILURE_ON_EXCEPTION( |
(...skipping 1399 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1622 RUNTIME_FUNCTION(Runtime_IsAccessCheckNeeded) { | 1605 RUNTIME_FUNCTION(Runtime_IsAccessCheckNeeded) { |
1623 SealHandleScope shs(isolate); | 1606 SealHandleScope shs(isolate); |
1624 DCHECK_EQ(1, args.length()); | 1607 DCHECK_EQ(1, args.length()); |
1625 CONVERT_ARG_CHECKED(Object, object, 0); | 1608 CONVERT_ARG_CHECKED(Object, object, 0); |
1626 return isolate->heap()->ToBoolean(object->IsAccessCheckNeeded()); | 1609 return isolate->heap()->ToBoolean(object->IsAccessCheckNeeded()); |
1627 } | 1610 } |
1628 | 1611 |
1629 | 1612 |
1630 } // namespace internal | 1613 } // namespace internal |
1631 } // namespace v8 | 1614 } // namespace v8 |
OLD | NEW |