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

Side by Side Diff: Source/platform/fonts/mac/FontCustomPlatformDataMac.cpp

Issue 691733004: Do not use SkCreateTypefaceFromCTFont for custom fonts (Closed) Base URL: svn://svn.chromium.org/blink/trunk
Patch Set: removed lion-specific test expectations Created 6 years, 1 month 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/platform/fonts/FontPlatformData.cpp ('k') | no next file » | 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) 2007, 2008, 2010 Apple Inc. All rights reserved. 2 * Copyright (C) 2007, 2008, 2010 Apple Inc. All rights reserved.
3 * 3 *
4 * This library is free software; you can redistribute it and/or 4 * This library is free software; you can redistribute it and/or
5 * modify it under the terms of the GNU Library General Public 5 * modify it under the terms of the GNU Library General Public
6 * License as published by the Free Software Foundation; either 6 * License as published by the Free Software Foundation; either
7 * version 2 of the License, or (at your option) any later version. 7 * version 2 of the License, or (at your option) any later version.
8 * 8 *
9 * This library is distributed in the hope that it will be useful, 9 * This library is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of 10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
(...skipping 26 matching lines...) Expand all
37 , m_typeface(typeface) 37 , m_typeface(typeface)
38 { 38 {
39 } 39 }
40 40
41 FontCustomPlatformData::~FontCustomPlatformData() 41 FontCustomPlatformData::~FontCustomPlatformData()
42 { 42 {
43 } 43 }
44 44
45 FontPlatformData FontCustomPlatformData::fontPlatformData(float size, bool bold, bool italic, FontOrientation orientation, FontWidthVariant widthVariant) 45 FontPlatformData FontCustomPlatformData::fontPlatformData(float size, bool bold, bool italic, FontOrientation orientation, FontWidthVariant widthVariant)
46 { 46 {
47 return FontPlatformData(m_cgFont.get(), size, bold, italic, orientation, wid thVariant); 47 return FontPlatformData(m_cgFont.get(), m_typeface, size, bold, italic, orie ntation, widthVariant);
48 } 48 }
49 49
50 PassOwnPtr<FontCustomPlatformData> FontCustomPlatformData::create(SharedBuffer* buffer) 50 PassOwnPtr<FontCustomPlatformData> FontCustomPlatformData::create(SharedBuffer* buffer)
51 { 51 {
52 ASSERT_ARG(buffer, buffer); 52 ASSERT_ARG(buffer, buffer);
53 53
54 OpenTypeSanitizer sanitizer(buffer); 54 OpenTypeSanitizer sanitizer(buffer);
55 RefPtr<SharedBuffer> transcodeBuffer = sanitizer.sanitize(); 55 RefPtr<SharedBuffer> transcodeBuffer = sanitizer.sanitize();
56 if (!transcodeBuffer) 56 if (!transcodeBuffer)
57 return nullptr; // validation failed. 57 return nullptr; // validation failed.
58 buffer = transcodeBuffer.get(); 58 buffer = transcodeBuffer.get();
59 59
60 RetainPtr<CFDataRef> bufferData(AdoptCF, CFDataCreate(0, reinterpret_cast<co nst UInt8*>(buffer->data()), buffer->size())); 60 RetainPtr<CFDataRef> bufferData(AdoptCF, CFDataCreate(0, reinterpret_cast<co nst UInt8*>(buffer->data()), buffer->size()));
61 RetainPtr<CGDataProviderRef> dataProvider(AdoptCF, CGDataProviderCreateWithC FData(bufferData.get())); 61 RetainPtr<CGDataProviderRef> dataProvider(AdoptCF, CGDataProviderCreateWithC FData(bufferData.get()));
62 RetainPtr<CGFontRef> cgFontRef(AdoptCF, CGFontCreateWithDataProvider(dataPro vider.get())); 62 RetainPtr<CGFontRef> cgFontRef(AdoptCF, CGFontCreateWithDataProvider(dataPro vider.get()));
63 if (!cgFontRef) 63 if (!cgFontRef)
64 return nullptr; 64 return nullptr;
65 65
66 // It's unclear whether this is used. It seems like it has the effect of pri ming the cache.
67 // Since we store this anyways, it might be worthwhile just plumbing this to FontMac.cpp in
68 // a more obvious way.
69 // FIXME: Remove this, add an explicit use, or add a comment explaining why this exists.
70 RefPtr<SkMemoryStream> stream = adoptRef(new SkMemoryStream(buffer->getAsSkD ata().get())); 66 RefPtr<SkMemoryStream> stream = adoptRef(new SkMemoryStream(buffer->getAsSkD ata().get()));
71 RefPtr<SkTypeface> typeface = adoptRef(SkTypeface::CreateFromStream(stream.g et())); 67 RefPtr<SkTypeface> typeface = adoptRef(SkTypeface::CreateFromStream(stream.g et()));
72 if (!typeface) 68 if (!typeface)
73 return nullptr; 69 return nullptr;
74 70
75 return adoptPtr(new FontCustomPlatformData(cgFontRef.leakRef(), typeface.rel ease())); 71 return adoptPtr(new FontCustomPlatformData(cgFontRef.leakRef(), typeface.rel ease()));
76 } 72 }
77 73
78 bool FontCustomPlatformData::supportsFormat(const String& format) 74 bool FontCustomPlatformData::supportsFormat(const String& format)
79 { 75 {
80 return equalIgnoringCase(format, "truetype") || equalIgnoringCase(format, "o pentype") || OpenTypeSanitizer::supportsFormat(format); 76 return equalIgnoringCase(format, "truetype") || equalIgnoringCase(format, "o pentype") || OpenTypeSanitizer::supportsFormat(format);
81 } 77 }
82 78
83 } // namespace blink 79 } // namespace blink
OLDNEW
« no previous file with comments | « Source/platform/fonts/FontPlatformData.cpp ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698