Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 /* | 1 /* |
| 2 * Copyright (C) 2011 Google, Inc. All Rights Reserved. | 2 * Copyright (C) 2011 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 | 5 * modification, are permitted provided that the following conditions |
| 6 * are met: | 6 * are met: |
| 7 * 1. Redistributions of source code must retain the above copyright | 7 * 1. Redistributions of source code must retain the above copyright |
| 8 * notice, this list of conditions and the following disclaimer. | 8 * notice, this list of conditions and the following disclaimer. |
| 9 * 2. Redistributions in binary form must reproduce the above copyright | 9 * 2. Redistributions in binary form must reproduce the above copyright |
| 10 * notice, this list of conditions and the following disclaimer in the | 10 * notice, this list of conditions and the following disclaimer in the |
| 11 * documentation and/or other materials provided with the distribution. | 11 * documentation and/or other materials provided with the distribution. |
| 12 * | 12 * |
| 13 * THIS SOFTWARE IS PROVIDED BY GOOGLE INC. ``AS IS'' AND ANY | 13 * THIS SOFTWARE IS PROVIDED BY GOOGLE INC. ``AS IS'' AND ANY |
| 14 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | 14 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE |
| 15 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR | 15 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR |
| 16 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR | 16 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR |
| 17 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, | 17 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, |
| 18 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, | 18 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, |
| 19 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR | 19 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR |
| 20 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY | 20 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY |
| 21 * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | 21 * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
| 22 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | 22 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
| 23 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | 23 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
| 24 */ | 24 */ |
| 25 | 25 |
| 26 #ifndef DOMWindowProperty_h | 26 #ifndef DOMWindowProperty_h |
| 27 #define DOMWindowProperty_h | 27 #define DOMWindowProperty_h |
| 28 | 28 |
| 29 #include "platform/heap/Handle.h" | |
| 30 | |
| 29 namespace blink { | 31 namespace blink { |
| 30 | 32 |
| 31 class LocalDOMWindow; | 33 class LocalDOMWindow; |
| 32 class LocalFrame; | 34 class LocalFrame; |
| 33 | 35 |
| 34 class DOMWindowProperty { | 36 class DOMWindowProperty : public WillBeGarbageCollectedMixin { |
| 35 public: | 37 public: |
| 36 explicit DOMWindowProperty(LocalFrame*); | 38 explicit DOMWindowProperty(LocalFrame*); |
| 37 | 39 |
| 38 virtual void willDestroyGlobalObjectInFrame(); | 40 virtual void willDestroyGlobalObjectInFrame(); |
| 39 virtual void willDetachGlobalObjectFromFrame(); | 41 virtual void willDetachGlobalObjectFromFrame(); |
| 40 | 42 |
| 41 LocalFrame* frame() const { return m_frame; } | 43 LocalFrame* frame() const { return m_frame; } |
| 42 | 44 |
| 45 virtual void trace(Visitor*); | |
| 46 | |
| 43 protected: | 47 protected: |
| 48 #if !ENABLE(OILPAN) | |
| 44 virtual ~DOMWindowProperty(); | 49 virtual ~DOMWindowProperty(); |
| 50 #endif | |
| 45 | 51 |
| 46 LocalFrame* m_frame; | 52 LocalFrame* m_frame; |
|
haraken
2014/09/10 02:49:36
How is it guaranteed that this m_frame does not be
sof
2014/09/10 05:49:40
It will be non-null if the LocalDOMWindow is someh
Mads Ager (chromium)
2014/09/10 06:34:13
My two cents: We should avoid using weakness if we
haraken
2014/09/10 07:46:53
Agreed. I prefer keeping the bi-directional strong
sof
2014/09/10 08:21:37
Yes, some tests (all resource leak related, i thin
haraken
2014/09/10 08:34:42
Thanks. What I want to understand is why the follo
| |
| 47 LocalDOMWindow* m_associatedDOMWindow; | 53 RawPtrWillBeMember<LocalDOMWindow> m_associatedDOMWindow; |
| 48 }; | 54 }; |
| 49 | 55 |
| 50 } | 56 } |
| 51 | 57 |
| 52 #endif | 58 #endif |
| OLD | NEW |