Chromium Code Reviews| Index: cc/TreeSynchronizer.cpp |
| diff --git a/cc/TreeSynchronizer.cpp b/cc/TreeSynchronizer.cpp |
| index e12d32d2ccead4952f6857a1fbb1e27de4a7ef6a..b7e76bbe9ab16d6843bfb26937329c17e35b6233 100644 |
| --- a/cc/TreeSynchronizer.cpp |
| +++ b/cc/TreeSynchronizer.cpp |
| @@ -14,55 +14,53 @@ |
| namespace cc { |
| -PassOwnPtr<CCLayerImpl> TreeSynchronizer::synchronizeTrees(LayerChromium* layerChromiumRoot, PassOwnPtr<CCLayerImpl> oldCCLayerImplRoot, CCLayerTreeHostImpl* hostImpl) |
| +scoped_ptr<CCLayerImpl> TreeSynchronizer::synchronizeTrees(LayerChromium* layerChromiumRoot, scoped_ptr<CCLayerImpl> oldCCLayerImplRoot, CCLayerTreeHostImpl* hostImpl) |
| { |
| - OwnPtrCCLayerImplMap oldLayers; |
| + ScopedPtrCCLayerImplMap oldLayers; |
| RawPtrCCLayerImplMap newLayers; |
| - collectExistingCCLayerImplRecursive(oldLayers, oldCCLayerImplRoot); |
| + collectExistingCCLayerImplRecursive(oldLayers, oldCCLayerImplRoot.Pass()); |
| - OwnPtr<CCLayerImpl> newTree = synchronizeTreeRecursive(newLayers, oldLayers, layerChromiumRoot, hostImpl); |
| + scoped_ptr<CCLayerImpl> newTree = synchronizeTreeRecursive(newLayers, oldLayers, layerChromiumRoot, hostImpl); |
| updateScrollbarLayerPointersRecursive(newLayers, layerChromiumRoot); |
| - return newTree.release(); |
| + return newTree.Pass(); |
| } |
| -void TreeSynchronizer::collectExistingCCLayerImplRecursive(OwnPtrCCLayerImplMap& oldLayers, PassOwnPtr<CCLayerImpl> popCCLayerImpl) |
| +void TreeSynchronizer::collectExistingCCLayerImplRecursive(ScopedPtrCCLayerImplMap& oldLayers, scoped_ptr<CCLayerImpl> ccLayerImpl) |
| { |
| - OwnPtr<CCLayerImpl> ccLayerImpl = popCCLayerImpl; |
| - |
| if (!ccLayerImpl) |
| return; |
| - OwnPtrVector<CCLayerImpl>& children = ccLayerImpl->m_children; |
| + ScopedPtrVector<CCLayerImpl>& children = ccLayerImpl->m_children; |
| for (size_t i = 0; i < children.size(); ++i) |
| collectExistingCCLayerImplRecursive(oldLayers, children.take(i)); |
| - collectExistingCCLayerImplRecursive(oldLayers, ccLayerImpl->m_maskLayer.release()); |
| - collectExistingCCLayerImplRecursive(oldLayers, ccLayerImpl->m_replicaLayer.release()); |
| + collectExistingCCLayerImplRecursive(oldLayers, ccLayerImpl->m_maskLayer.Pass()); |
| + collectExistingCCLayerImplRecursive(oldLayers, ccLayerImpl->m_replicaLayer.Pass()); |
| int id = ccLayerImpl->id(); |
| - oldLayers.set(id, ccLayerImpl.release()); |
| + oldLayers.set(id, ccLayerImpl.Pass()); |
| } |
| -PassOwnPtr<CCLayerImpl> TreeSynchronizer::reuseOrCreateCCLayerImpl(RawPtrCCLayerImplMap& newLayers, OwnPtrCCLayerImplMap& oldLayers, LayerChromium* layer) |
| +scoped_ptr<CCLayerImpl> TreeSynchronizer::reuseOrCreateCCLayerImpl(RawPtrCCLayerImplMap& newLayers, ScopedPtrCCLayerImplMap& oldLayers, LayerChromium* layer) |
| { |
| - OwnPtr<CCLayerImpl> ccLayerImpl = oldLayers.take(layer->id()); |
| + scoped_ptr<CCLayerImpl> ccLayerImpl = oldLayers.take(layer->id()); |
| if (!ccLayerImpl) |
| ccLayerImpl = layer->createCCLayerImpl(); |
| - newLayers.set(layer->id(), ccLayerImpl.get()); |
| - return ccLayerImpl.release(); |
| + newLayers[layer->id()] = ccLayerImpl.get(); |
| + return ccLayerImpl.Pass(); |
| } |
| -PassOwnPtr<CCLayerImpl> TreeSynchronizer::synchronizeTreeRecursive(RawPtrCCLayerImplMap& newLayers, OwnPtrCCLayerImplMap& oldLayers, LayerChromium* layer, CCLayerTreeHostImpl* hostImpl) |
| +scoped_ptr<CCLayerImpl> TreeSynchronizer::synchronizeTreeRecursive(RawPtrCCLayerImplMap& newLayers, ScopedPtrCCLayerImplMap& oldLayers, LayerChromium* layer, CCLayerTreeHostImpl* hostImpl) |
| { |
| if (!layer) |
| - return nullptr; |
| + return scoped_ptr<CCLayerImpl>(); |
| - OwnPtr<CCLayerImpl> ccLayerImpl = reuseOrCreateCCLayerImpl(newLayers, oldLayers, layer); |
| + scoped_ptr<CCLayerImpl> ccLayerImpl = reuseOrCreateCCLayerImpl(newLayers, oldLayers, layer); |
| ccLayerImpl->clearChildList(); |
| const std::vector<scoped_refptr<LayerChromium> >& children = layer->children(); |
| @@ -81,7 +79,7 @@ PassOwnPtr<CCLayerImpl> TreeSynchronizer::synchronizeTreeRecursive(RawPtrCCLayer |
| scrollbarController->setVerticalScrollbarLayer(0); |
| } |
| - return ccLayerImpl.release(); |
| + return ccLayerImpl.Pass(); |
| } |
| void TreeSynchronizer::updateScrollbarLayerPointersRecursive(const RawPtrCCLayerImplMap& newLayers, LayerChromium* layer) |
| @@ -97,9 +95,12 @@ void TreeSynchronizer::updateScrollbarLayerPointersRecursive(const RawPtrCCLayer |
| if (!scrollbarLayer) |
| return; |
| - CCScrollbarLayerImpl* ccScrollbarLayerImpl = static_cast<CCScrollbarLayerImpl*>(newLayers.get(scrollbarLayer->id())); |
| + RawPtrCCLayerImplMap::const_iterator iter = newLayers.find(scrollbarLayer->id()); |
| + CCScrollbarLayerImpl* ccScrollbarLayerImpl = iter != newLayers.end() ? static_cast<CCScrollbarLayerImpl*>(iter->second) : NULL; |
|
jamesr
2012/10/07 22:27:19
do we really need the iterator? what about just do
enne (OOO)
2012/10/07 22:44:57
Done. I think it's just personal style to never u
enne (OOO)
2012/10/07 23:40:23
Ok, I lied. You can't operator[] on a const hash_
|
| + iter = newLayers.find(scrollbarLayer->scrollLayerId()); |
| + CCLayerImpl* ccScrollLayerImpl = iter != newLayers.end() ? iter->second : NULL; |
|
jamesr
2012/10/07 22:27:19
same here
enne (OOO)
2012/10/07 22:44:57
Done.
|
| + |
| ASSERT(ccScrollbarLayerImpl); |
| - CCLayerImpl* ccScrollLayerImpl = newLayers.get(scrollbarLayer->scrollLayerId()); |
| ASSERT(ccScrollLayerImpl); |
| if (ccScrollbarLayerImpl->orientation() == WebKit::WebScrollbar::Horizontal) |