Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(77)

Side by Side Diff: Source/bindings/v8/V8GCController.cpp

Issue 26792002: Reland: Reland: Implement new Blink IDL attribute [SetReference] (Closed) Base URL: svn://svn.chromium.org/blink/trunk
Patch Set: Created 7 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 /* 1 /*
2 * Copyright (C) 2009 Google Inc. All rights reserved. 2 * Copyright (C) 2009 Google Inc. All rights reserved.
3 * 3 *
4 * Redistribution and use in source and binary forms, with or without 4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions are 5 * modification, are permitted provided that the following conditions are
6 * met: 6 * met:
7 * 7 *
8 * * Redistributions of source code must retain the above copyright 8 * * Redistributions of source code must retain the above copyright
9 * notice, this list of conditions and the following disclaimer. 9 * notice, this list of conditions and the following disclaimer.
10 * * Redistributions in binary form must reproduce the above 10 * * Redistributions in binary form must reproduce the above
(...skipping 221 matching lines...) Expand 10 before | Expand all | Expand 10 after
232 virtual void VisitPersistentHandle(v8::Persistent<v8::Value>* value, uint16_ t classId) OVERRIDE 232 virtual void VisitPersistentHandle(v8::Persistent<v8::Value>* value, uint16_ t classId) OVERRIDE
233 { 233 {
234 // Casting to a Handle is safe here, since the Persistent cannot get GCd 234 // Casting to a Handle is safe here, since the Persistent cannot get GCd
235 // during the GC prologue. 235 // during the GC prologue.
236 ASSERT((*reinterpret_cast<v8::Handle<v8::Value>*>(value))->IsObject()); 236 ASSERT((*reinterpret_cast<v8::Handle<v8::Value>*>(value))->IsObject());
237 237
238 if (classId != v8DOMNodeClassId && classId != v8DOMObjectClassId) 238 if (classId != v8DOMNodeClassId && classId != v8DOMObjectClassId)
239 return; 239 return;
240 240
241 v8::Handle<v8::Object>* wrapper = reinterpret_cast<v8::Handle<v8::Object >*>(value); 241 v8::Handle<v8::Object>* wrapper = reinterpret_cast<v8::Handle<v8::Object >*>(value);
242 v8::Persistent<v8::Object>* wrapperpers = reinterpret_cast<v8::Persisten t<v8::Object>*>(value);
haraken 2013/10/10 06:08:32 You can write this just before you use |wrapperper
242 243
243 ASSERT(V8DOMWrapper::maybeDOMWrapper(*wrapper)); 244 ASSERT(V8DOMWrapper::maybeDOMWrapper(*wrapper));
244 245
245 if (value->IsIndependent()) 246 if (value->IsIndependent())
246 return; 247 return;
247 248
248 WrapperTypeInfo* type = toWrapperTypeInfo(*wrapper); 249 WrapperTypeInfo* type = toWrapperTypeInfo(*wrapper);
249 void* object = toNative(*wrapper); 250 void* object = toNative(*wrapper);
250 251
251 if (V8MessagePort::info.equals(type)) { 252 if (V8MessagePort::info.equals(type)) {
(...skipping 25 matching lines...) Expand all
277 Node* node = static_cast<Node*>(object); 278 Node* node = static_cast<Node*>(object);
278 279
279 if (node->hasEventListeners()) 280 if (node->hasEventListeners())
280 addReferencesForNodeWithEventListeners(m_isolate, node, v8::Pers istent<v8::Object>::Cast(*value)); 281 addReferencesForNodeWithEventListeners(m_isolate, node, v8::Pers istent<v8::Object>::Cast(*value));
281 Node* root = V8GCController::opaqueRootForGC(node, m_isolate); 282 Node* root = V8GCController::opaqueRootForGC(node, m_isolate);
282 m_isolate->SetObjectGroupId(*value, v8::UniqueId(reinterpret_cast<in tptr_t>(root))); 283 m_isolate->SetObjectGroupId(*value, v8::UniqueId(reinterpret_cast<in tptr_t>(root)));
283 if (m_constructRetainedObjectInfos) 284 if (m_constructRetainedObjectInfos)
284 m_groupsWhichNeedRetainerInfo.append(root); 285 m_groupsWhichNeedRetainerInfo.append(root);
285 } else if (classId == v8DOMObjectClassId) { 286 } else if (classId == v8DOMObjectClassId) {
286 ASSERT(!value->IsIndependent()); 287 ASSERT(!value->IsIndependent());
287 void* root = type->opaqueRootForGC(object, m_isolate); 288 void* root = type->resolveWrapperReachability(object, *wrapperpers, m_isolate);
288 m_isolate->SetObjectGroupId(*value, v8::UniqueId(reinterpret_cast<in tptr_t>(root))); 289 m_isolate->SetObjectGroupId(*value, v8::UniqueId(reinterpret_cast<in tptr_t>(root)));
haraken 2013/10/10 06:08:32 This is a bit confusing. resolveWrapperReachabilit
289 } else { 290 } else {
290 ASSERT_NOT_REACHED(); 291 ASSERT_NOT_REACHED();
291 } 292 }
292 } 293 }
293 294
294 void notifyFinished() 295 void notifyFinished()
295 { 296 {
296 if (!m_constructRetainedObjectInfos) 297 if (!m_constructRetainedObjectInfos)
297 return; 298 return;
298 std::sort(m_groupsWhichNeedRetainerInfo.begin(), m_groupsWhichNeedRetain erInfo.end()); 299 std::sort(m_groupsWhichNeedRetainerInfo.begin(), m_groupsWhichNeedRetain erInfo.end());
(...skipping 115 matching lines...) Expand 10 before | Expand all | Expand 10 after
414 { 415 {
415 v8::HandleScope handleScope(isolate); 416 v8::HandleScope handleScope(isolate);
416 v8::Local<v8::Context> context = v8::Context::New(isolate); 417 v8::Local<v8::Context> context = v8::Context::New(isolate);
417 if (context.IsEmpty()) 418 if (context.IsEmpty())
418 return; 419 return;
419 v8::Context::Scope contextScope(context); 420 v8::Context::Scope contextScope(context);
420 V8ScriptRunner::compileAndRunInternalScript(v8String("if (gc) gc();", isolat e), isolate); 421 V8ScriptRunner::compileAndRunInternalScript(v8String("if (gc) gc();", isolat e), isolate);
421 } 422 }
422 423
423 } // namespace WebCore 424 } // namespace WebCore
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698