 Chromium Code Reviews
 Chromium Code Reviews Issue 7670023:
  Fix GC unsafe place in JSProxy::DeletePropertyWithHandler.  (Closed) 
  Base URL: http://v8.googlecode.com/svn/branches/bleeding_edge/
    
  
    Issue 7670023:
  Fix GC unsafe place in JSProxy::DeletePropertyWithHandler.  (Closed) 
  Base URL: http://v8.googlecode.com/svn/branches/bleeding_edge/| OLD | NEW | 
|---|---|
| 1 // Copyright 2011 the V8 project authors. All rights reserved. | 1 // Copyright 2011 the V8 project authors. All rights reserved. | 
| 2 // Redistribution and use in source and binary forms, with or without | 2 // Redistribution and use in source and binary forms, with or without | 
| 3 // modification, are permitted provided that the following conditions are | 3 // modification, are permitted provided that the following conditions are | 
| 4 // met: | 4 // met: | 
| 5 // | 5 // | 
| 6 // * Redistributions of source code must retain the above copyright | 6 // * Redistributions of source code must retain the above copyright | 
| 7 // notice, this list of conditions and the following disclaimer. | 7 // notice, this list of conditions and the following disclaimer. | 
| 8 // * Redistributions in binary form must reproduce the above | 8 // * Redistributions in binary form must reproduce the above | 
| 9 // copyright notice, this list of conditions and the following | 9 // copyright notice, this list of conditions and the following | 
| 10 // disclaimer in the documentation and/or other materials provided | 10 // disclaimer in the documentation and/or other materials provided | 
| (...skipping 2300 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 2311 } | 2311 } | 
| 2312 | 2312 | 
| 2313 // Call trap function. | 2313 // Call trap function. | 
| 2314 Object** args[] = { name.location() }; | 2314 Object** args[] = { name.location() }; | 
| 2315 bool has_exception; | 2315 bool has_exception; | 
| 2316 Handle<Object> result = | 2316 Handle<Object> result = | 
| 2317 Execution::Call(trap, handler, ARRAY_SIZE(args), args, &has_exception); | 2317 Execution::Call(trap, handler, ARRAY_SIZE(args), args, &has_exception); | 
| 2318 if (has_exception) return Failure::Exception(); | 2318 if (has_exception) return Failure::Exception(); | 
| 2319 | 2319 | 
| 2320 Object* bool_result = result->ToBoolean(); | 2320 Object* bool_result = result->ToBoolean(); | 
| 2321 if (mode == STRICT_DELETION && bool_result == GetHeap()->false_value()) { | 2321 if (mode == STRICT_DELETION && | 
| 2322 bool_result == isolate->heap()->false_value()) { | |
| 
Vitaly Repeshko
2011/08/17 12:27:39
Whoa, nice catch!
 | |
| 2322 Handle<Object> args[] = { handler, trap_name }; | 2323 Handle<Object> args[] = { handler, trap_name }; | 
| 2323 Handle<Object> error = isolate->factory()->NewTypeError( | 2324 Handle<Object> error = isolate->factory()->NewTypeError( | 
| 2324 "handler_failed", HandleVector(args, ARRAY_SIZE(args))); | 2325 "handler_failed", HandleVector(args, ARRAY_SIZE(args))); | 
| 2325 isolate->Throw(*error); | 2326 isolate->Throw(*error); | 
| 2326 return Failure::Exception(); | 2327 return Failure::Exception(); | 
| 2327 } | 2328 } | 
| 2328 return bool_result; | 2329 return bool_result; | 
| 2329 } | 2330 } | 
| 2330 | 2331 | 
| 2331 | 2332 | 
| (...skipping 9268 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 11600 if (break_point_objects()->IsUndefined()) return 0; | 11601 if (break_point_objects()->IsUndefined()) return 0; | 
| 11601 // Single break point. | 11602 // Single break point. | 
| 11602 if (!break_point_objects()->IsFixedArray()) return 1; | 11603 if (!break_point_objects()->IsFixedArray()) return 1; | 
| 11603 // Multiple break points. | 11604 // Multiple break points. | 
| 11604 return FixedArray::cast(break_point_objects())->length(); | 11605 return FixedArray::cast(break_point_objects())->length(); | 
| 11605 } | 11606 } | 
| 11606 #endif | 11607 #endif | 
| 11607 | 11608 | 
| 11608 | 11609 | 
| 11609 } } // namespace v8::internal | 11610 } } // namespace v8::internal | 
| OLD | NEW |