OLD | NEW |
---|---|
(Empty) | |
1 // Copyright 2015 The Chromium Authors. All rights reserved. | |
2 // Use of this source code is governed by a BSD-style license that can be | |
3 // found in the LICENSE file. | |
4 | |
5 #ifndef WebFrameImplBase_h | |
6 #define WebFrameImplBase_h | |
7 | |
8 #include "platform/heap/Handle.h" | |
9 #include "wtf/text/AtomicString.h" | |
10 | |
11 namespace blink { | |
12 | |
13 class Frame; | |
14 class FrameHost; | |
15 class FrameOwner; | |
16 | |
17 // WebFrameImplBase exists to avoid the diamond inheritance problem: | |
18 // - The public interfaces WebLocalFrame/WebRemoteFrame extend WebFrame. | |
19 // - WebLocalFrameImpl implements WebLocalFrame and WebRemoteFrameImpl | |
20 // implements WebRemoteFrame. | |
21 // - The private implementations should share some functionality, but cannot | |
22 // inherit from a common base class inheriting WebFrame. This would result in | |
23 // WebFrame beind inherited from two different base classes. | |
24 // | |
25 // To get around this, only the private implementations have WebFrameImplBase as | |
26 // a base class. WebFrame exposes a virtual accessor to retrieve the underlying | |
27 // implementation as an instance of the base class, but has no inheritance | |
28 // relationship with it. The cost is a virtual indirection, but this is nicer | |
29 // than the previous manual dispatch emulating real virtual dispatch. | |
30 class WebFrameImplBase : public RefCountedWillBeGarbageCollectedFinalized<WebFra meImplBase> { | |
31 public: | |
32 virtual ~WebFrameImplBase(); | |
33 | |
34 virtual void initializeCoreFrame(FrameHost*, FrameOwner*, const AtomicString & name, const AtomicString& fallbackName) = 0; | |
35 // TODO(dcheng): Rename this to coreFrame()? This probably also shouldn't be const... | |
36 virtual Frame* frame() const = 0; | |
37 | |
38 #if ENABLE(OILPAN) | |
haraken
2015/11/24 02:30:53
I guess ENABLE(OILPAN) won't be needed.
dcheng
2015/11/24 06:55:07
Hmm, is ENABLE(OILPAN) universally enabled? Right
haraken
2015/11/24 07:00:33
We normally don't add #if ENABLE(OILPAN) to a trac
dcheng
2015/11/24 07:50:24
Makes sense. Done.
| |
39 DECLARE_VIRTUAL_TRACE(); | |
40 #endif | |
41 }; | |
42 | |
43 } // namespace blink | |
44 | |
45 #endif // WebFrameImplBase_h | |
OLD | NEW |