OLD | NEW |
---|---|
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 The Chromium 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 "config.h" | 5 #include "config.h" |
6 #include "web/OpenedFrameTracker.h" | 6 #include "web/OpenedFrameTracker.h" |
7 | 7 |
8 #include "platform/heap/Handle.h" | 8 #include "platform/heap/Handle.h" |
9 #include "public/web/WebFrame.h" | 9 #include "public/web/WebFrame.h" |
10 | 10 |
11 namespace blink { | 11 namespace blink { |
12 | 12 |
13 OpenedFrameTracker::OpenedFrameTracker() | 13 OpenedFrameTracker::OpenedFrameTracker() |
14 { | 14 { |
15 } | 15 } |
16 | 16 |
17 OpenedFrameTracker::~OpenedFrameTracker() | 17 OpenedFrameTracker::~OpenedFrameTracker() |
18 { | 18 { |
19 #if !ENABLE(OILPAN) | 19 #if !ENABLE(OILPAN) |
20 // Oilpan takes care of clearing weak m_opener fields during GC. | 20 // Oilpan takes care of clearing weak m_opener fields during GC. |
21 updateOpener(0); | 21 transferTo(nullptr); |
22 #endif | 22 #endif |
23 } | 23 } |
24 | 24 |
25 bool OpenedFrameTracker::isEmpty() const | 25 bool OpenedFrameTracker::isEmpty() const |
26 { | 26 { |
27 return m_openedFrames.isEmpty(); | 27 return m_openedFrames.isEmpty(); |
28 } | 28 } |
29 | 29 |
30 void OpenedFrameTracker::add(WebFrame* frame) | 30 void OpenedFrameTracker::add(WebFrame* frame) |
31 { | 31 { |
32 m_openedFrames.add(frame); | 32 m_openedFrames.add(frame); |
33 } | 33 } |
34 | 34 |
35 void OpenedFrameTracker::remove(WebFrame* frame) | 35 void OpenedFrameTracker::remove(WebFrame* frame) |
36 { | 36 { |
37 m_openedFrames.remove(frame); | 37 m_openedFrames.remove(frame); |
38 } | 38 } |
39 | 39 |
40 void OpenedFrameTracker::updateOpener(WebFrame* frame) | 40 void OpenedFrameTracker::transferTo(WebFrame* opener) |
41 { | 41 { |
42 HashSet<WebFrame*>::iterator end = m_openedFrames.end(); | 42 HashSet<WebFrame*> frames(m_openedFrames); |
alexmos
2015/10/27 19:09:51
nit: is it worth adding a comment about why the co
dcheng
2015/10/27 19:11:16
Yeah, probably worth commenting. I'll add it and C
| |
43 for (HashSet<WebFrame*>::iterator it = m_openedFrames.begin(); it != end; ++ it) | 43 for (WebFrame* frame : frames) |
44 (*it)->m_opener = frame; | 44 frame->setOpener(opener); |
45 } | 45 } |
46 | 46 |
47 template <typename VisitorDispatcher> | 47 template <typename VisitorDispatcher> |
48 ALWAYS_INLINE void OpenedFrameTracker::traceFramesImpl(VisitorDispatcher visitor ) | 48 ALWAYS_INLINE void OpenedFrameTracker::traceFramesImpl(VisitorDispatcher visitor ) |
49 { | 49 { |
50 #if ENABLE(OILPAN) | 50 #if ENABLE(OILPAN) |
51 HashSet<WebFrame*>::iterator end = m_openedFrames.end(); | 51 HashSet<WebFrame*>::iterator end = m_openedFrames.end(); |
52 for (HashSet<WebFrame*>::iterator it = m_openedFrames.begin(); it != end; ++ it) | 52 for (HashSet<WebFrame*>::iterator it = m_openedFrames.begin(); it != end; ++ it) |
53 WebFrame::traceFrame(visitor, *it); | 53 WebFrame::traceFrame(visitor, *it); |
54 #endif | 54 #endif |
55 } | 55 } |
56 | 56 |
57 void OpenedFrameTracker::traceFrames(Visitor* visitor) { traceFramesImpl(visitor ); } | 57 void OpenedFrameTracker::traceFrames(Visitor* visitor) { traceFramesImpl(visitor ); } |
58 void OpenedFrameTracker::traceFrames(InlinedGlobalMarkingVisitor visitor) { trac eFramesImpl(visitor); } | 58 void OpenedFrameTracker::traceFrames(InlinedGlobalMarkingVisitor visitor) { trac eFramesImpl(visitor); } |
59 | 59 |
60 } // namespace blink | 60 } // namespace blink |
OLD | NEW |