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

Side by Side Diff: Source/core/css/CSSSegmentedFontFace.h

Issue 18375005: [oilpan] Move CSSFontFace and CSSSegmentedFontFace to the managed heap (Closed) Base URL: svn://svn.chromium.org/blink/branches/oilpan
Patch Set: Created 7 years, 5 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/css/CSSFontSelector.cpp ('k') | Source/core/css/CSSSegmentedFontFace.cpp » ('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) 2008 Apple Inc. All rights reserved. 2 * Copyright (C) 2008 Apple 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 APPLE COMPUTER, INC. ``AS IS'' AND ANY 13 * THIS SOFTWARE IS PROVIDED BY APPLE COMPUTER, 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 COMPUTER, INC. OR 16 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE COMPUTER, 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 CSSSegmentedFontFace_h 26 #ifndef CSSSegmentedFontFace_h
27 #define CSSSegmentedFontFace_h 27 #define CSSSegmentedFontFace_h
28 28
29 #include "heap/Handle.h"
29 #include <wtf/HashMap.h> 30 #include <wtf/HashMap.h>
30 #include <wtf/PassRefPtr.h> 31 #include <wtf/PassRefPtr.h>
31 #include <wtf/RefCounted.h>
32 #include <wtf/Vector.h> 32 #include <wtf/Vector.h>
33 #include <wtf/unicode/Unicode.h> 33 #include <wtf/unicode/Unicode.h>
34 34
35 namespace WebCore { 35 namespace WebCore {
36 36
37 class CSSFontFace; 37 class CSSFontFace;
38 class CSSFontSelector; 38 class CSSFontSelector;
39 class FontData; 39 class FontData;
40 class FontDescription; 40 class FontDescription;
41 class SegmentedFontData; 41 class SegmentedFontData;
42 42
43 class CSSSegmentedFontFace : public RefCounted<CSSSegmentedFontFace> { 43 class CSSSegmentedFontFace : public HeapAllocatedFinalized<CSSSegmentedFontFace> {
44 DECLARE_GC_TYPE_MARKER
44 public: 45 public:
45 static PassRefPtr<CSSSegmentedFontFace> create(CSSFontSelector* selector) { return adoptRef(new CSSSegmentedFontFace(selector)); } 46 static Result<CSSSegmentedFontFace> create(CSSFontSelector* selector) { retu rn adopt(new CSSSegmentedFontFace(selector)); }
46 ~CSSSegmentedFontFace(); 47 ~CSSSegmentedFontFace();
47 48
48 CSSFontSelector* fontSelector() const { return m_fontSelector; } 49 CSSFontSelector* fontSelector() const { return m_fontSelector.get(); }
49 50
50 void fontLoaded(CSSFontFace*); 51 void fontLoaded(Handle<CSSFontFace>);
51 52
52 void appendFontFace(PassRefPtr<CSSFontFace>); 53 void appendFontFace(Handle<CSSFontFace>);
53 54
54 PassRefPtr<FontData> getFontData(const FontDescription&); 55 PassRefPtr<FontData> getFontData(const FontDescription&);
55 56
56 class LoadFontCallback : public RefCounted<LoadFontCallback> { 57 class LoadFontCallback : public HeapAllocatedFinalized<LoadFontCallback> {
58 DECLARE_GC_TYPE_MARKER
57 public: 59 public:
58 virtual ~LoadFontCallback() { } 60 virtual ~LoadFontCallback() { }
59 virtual void notifyLoaded(CSSSegmentedFontFace*) = 0; 61 virtual void notifyLoaded(Handle<CSSSegmentedFontFace>) = 0;
60 virtual void notifyError(CSSSegmentedFontFace*) = 0; 62 virtual void notifyError(Handle<CSSSegmentedFontFace>) = 0;
63 virtual void accept(Visitor*) const = 0;
61 }; 64 };
62 65
63 bool checkFont() const; 66 bool checkFont() const;
64 void loadFont(const FontDescription&, PassRefPtr<LoadFontCallback> loadCallb ack); 67 void loadFont(const FontDescription&, Handle<LoadFontCallback> loadCallback) ;
68
69 void accept(Visitor*) const;
65 70
66 private: 71 private:
67 CSSSegmentedFontFace(CSSFontSelector*); 72 CSSSegmentedFontFace(CSSFontSelector*);
68 73
69 void pruneTable(); 74 void pruneTable();
70 bool isValid() const; 75 bool isValid() const;
71 bool isLoading() const; 76 bool isLoading() const;
72 77
73 CSSFontSelector* m_fontSelector; 78 RefPtr<CSSFontSelector> m_fontSelector;
haraken 2013/07/04 08:03:44 Adding this RefPtr fixed the heap corruption in SV
74 HashMap<unsigned, RefPtr<SegmentedFontData> > m_fontDataTable; 79 HashMap<unsigned, RefPtr<SegmentedFontData> > m_fontDataTable;
75 Vector<RefPtr<CSSFontFace>, 1> m_fontFaces; 80 Vector<Member<CSSFontFace>, 1> m_fontFaces;
76 Vector<RefPtr<LoadFontCallback> > m_callbacks; 81 Vector<Member<LoadFontCallback> > m_callbacks;
77 }; 82 };
78 83
79 } // namespace WebCore 84 } // namespace WebCore
80 85
81 #endif // CSSSegmentedFontFace_h 86 #endif // CSSSegmentedFontFace_h
OLDNEW
« no previous file with comments | « Source/core/css/CSSFontSelector.cpp ('k') | Source/core/css/CSSSegmentedFontFace.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698