| OLD | NEW |
| 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 Loading... |
| 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 |
| OLD | NEW |