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

Side by Side Diff: Source/core/page/FrameView.cpp

Issue 16695002: Uptake WebKit Changeset r149185. (Closed) Base URL: svn://svn.chromium.org/blink/trunk
Patch Set: Refetch render view and null check AXObjectCache Created 7 years, 6 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
« no previous file with comments | « Source/core/dom/Document.cpp ('k') | Source/core/rendering/RenderArena.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 /* 1 /*
2 * Copyright (C) 1998, 1999 Torben Weis <weis@kde.org> 2 * Copyright (C) 1998, 1999 Torben Weis <weis@kde.org>
3 * 1999 Lars Knoll <knoll@kde.org> 3 * 1999 Lars Knoll <knoll@kde.org>
4 * 1999 Antti Koivisto <koivisto@kde.org> 4 * 1999 Antti Koivisto <koivisto@kde.org>
5 * 2000 Dirk Mueller <mueller@kde.org> 5 * 2000 Dirk Mueller <mueller@kde.org>
6 * Copyright (C) 2004, 2005, 2006, 2007, 2008 Apple Inc. All rights reserved. 6 * Copyright (C) 2004, 2005, 2006, 2007, 2008 Apple Inc. All rights reserved.
7 * (C) 2006 Graham Dennis (graham.dennis@gmail.com) 7 * (C) 2006 Graham Dennis (graham.dennis@gmail.com)
8 * (C) 2006 Alexey Proskuryakov (ap@nypop.com) 8 * (C) 2006 Alexey Proskuryakov (ap@nypop.com)
9 * Copyright (C) 2009 Google Inc. All rights reserved. 9 * Copyright (C) 2009 Google Inc. All rights reserved.
10 * 10 *
(...skipping 2169 matching lines...) Expand 10 before | Expand all | Expand 10 after
2180 2180
2181 bool FrameView::updateWidgets() 2181 bool FrameView::updateWidgets()
2182 { 2182 {
2183 if (m_nestedLayoutCount > 1 || !m_widgetUpdateSet || m_widgetUpdateSet->isEm pty()) 2183 if (m_nestedLayoutCount > 1 || !m_widgetUpdateSet || m_widgetUpdateSet->isEm pty())
2184 return true; 2184 return true;
2185 2185
2186 size_t size = m_widgetUpdateSet->size(); 2186 size_t size = m_widgetUpdateSet->size();
2187 2187
2188 Vector<RenderObject*> objects; 2188 Vector<RenderObject*> objects;
2189 objects.reserveInitialCapacity(size); 2189 objects.reserveInitialCapacity(size);
2190 // Protect RendereArena from getting wiped out, when Document is detached du ring updateWidget().
2191 RefPtr<RenderArena> protectedArena = m_frame->document()->renderArena();
2190 2192
2191 RenderObjectSet::const_iterator end = m_widgetUpdateSet->end(); 2193 RenderObjectSet::const_iterator end = m_widgetUpdateSet->end();
2192 for (RenderObjectSet::const_iterator it = m_widgetUpdateSet->begin(); it != end; ++it) { 2194 for (RenderObjectSet::const_iterator it = m_widgetUpdateSet->begin(); it != end; ++it) {
2193 RenderObject* object = *it; 2195 RenderObject* object = *it;
2194 objects.uncheckedAppend(object); 2196 objects.uncheckedAppend(object);
2195 if (object->isEmbeddedObject()) { 2197 if (object->isEmbeddedObject()) {
2196 RenderEmbeddedObject* embeddedObject = static_cast<RenderEmbeddedObj ect*>(object); 2198 RenderEmbeddedObject* embeddedObject = static_cast<RenderEmbeddedObj ect*>(object);
2197 embeddedObject->ref(); 2199 embeddedObject->ref();
2198 } 2200 }
2199 } 2201 }
2200 2202
2201 for (size_t i = 0; i < size; ++i) { 2203 for (size_t i = 0; i < size; ++i) {
2202 RenderObject* object = objects[i]; 2204 RenderObject* object = objects[i];
2203 updateWidget(object); 2205 updateWidget(object);
2204 m_widgetUpdateSet->remove(object); 2206 m_widgetUpdateSet->remove(object);
2205 } 2207 }
2206 2208
2207 RenderArena* arena = m_frame->document()->renderArena();
2208 for (size_t i = 0; i < size; ++i) { 2209 for (size_t i = 0; i < size; ++i) {
2209 RenderObject* object = objects[i]; 2210 RenderObject* object = objects[i];
2210 if (object->isEmbeddedObject()) { 2211 if (object->isEmbeddedObject()) {
2211 RenderEmbeddedObject* embeddedObject = static_cast<RenderEmbeddedObj ect*>(object); 2212 RenderEmbeddedObject* embeddedObject = static_cast<RenderEmbeddedObj ect*>(object);
2212 embeddedObject->deref(arena); 2213 embeddedObject->deref(protectedArena.get());
2213 } 2214 }
2214 } 2215 }
2215 2216
2216 return m_widgetUpdateSet->isEmpty(); 2217 return m_widgetUpdateSet->isEmpty();
2217 } 2218 }
2218 2219
2219 void FrameView::flushAnyPendingPostLayoutTasks() 2220 void FrameView::flushAnyPendingPostLayoutTasks()
2220 { 2221 {
2221 if (!m_postLayoutTasksTimer.isActive()) 2222 if (!m_postLayoutTasksTimer.isActive())
2222 return; 2223 return;
(...skipping 62 matching lines...) Expand 10 before | Expand all | Expand 10 after
2285 scrollToAnchor(); 2286 scrollToAnchor();
2286 2287
2287 m_actionScheduler->resume(); 2288 m_actionScheduler->resume();
2288 2289
2289 // Viewport-dependent media queries may cause us to need completely differen t style information. 2290 // Viewport-dependent media queries may cause us to need completely differen t style information.
2290 if (m_frame->document()->styleResolver()->affectedByViewportChange()) { 2291 if (m_frame->document()->styleResolver()->affectedByViewportChange()) {
2291 m_frame->document()->styleResolverChanged(DeferRecalcStyle); 2292 m_frame->document()->styleResolverChanged(DeferRecalcStyle);
2292 InspectorInstrumentation::mediaQueryResultChanged(m_frame->document()); 2293 InspectorInstrumentation::mediaQueryResultChanged(m_frame->document());
2293 } 2294 }
2294 2295
2296 // Refetch render view since it can be destroyed by updateWidget() call abov e.
2297 renderView = this->renderView();
2295 if (renderView && !renderView->printing()) { 2298 if (renderView && !renderView->printing()) {
2296 IntSize currentSize; 2299 IntSize currentSize;
2297 currentSize = visibleContentRect(IncludeScrollbars).size(); 2300 currentSize = visibleContentRect(IncludeScrollbars).size();
2298 float currentZoomFactor = renderView->style()->zoom(); 2301 float currentZoomFactor = renderView->style()->zoom();
2299 bool resized = !m_firstLayout && (currentSize != m_lastViewportSize || c urrentZoomFactor != m_lastZoomFactor); 2302 bool resized = !m_firstLayout && (currentSize != m_lastViewportSize || c urrentZoomFactor != m_lastZoomFactor);
2300 m_lastViewportSize = currentSize; 2303 m_lastViewportSize = currentSize;
2301 m_lastZoomFactor = currentZoomFactor; 2304 m_lastZoomFactor = currentZoomFactor;
2302 if (resized) { 2305 if (resized) {
2303 m_frame->eventHandler()->sendResizeEvent(); 2306 m_frame->eventHandler()->sendResizeEvent();
2304 if (page && page->mainFrame() == m_frame) 2307 if (page && page->mainFrame() == m_frame)
(...skipping 1102 matching lines...) Expand 10 before | Expand all | Expand 10 after
3407 } 3410 }
3408 3411
3409 AXObjectCache* FrameView::axObjectCache() const 3412 AXObjectCache* FrameView::axObjectCache() const
3410 { 3413 {
3411 if (frame() && frame()->document()) 3414 if (frame() && frame()->document())
3412 return frame()->document()->existingAXObjectCache(); 3415 return frame()->document()->existingAXObjectCache();
3413 return 0; 3416 return 0;
3414 } 3417 }
3415 3418
3416 } // namespace WebCore 3419 } // namespace WebCore
OLDNEW
« no previous file with comments | « Source/core/dom/Document.cpp ('k') | Source/core/rendering/RenderArena.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698