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

Unified Diff: sky/engine/platform/fonts/FontPlatformData.h

Issue 722723003: Re-land 714393002 after fixing android build. (Closed) Base URL: git@github.com:domokit/mojo.git@master
Patch Set: 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « sky/engine/platform/exported/WebCursorInfo.cpp ('k') | sky/engine/platform/fonts/GlyphPage.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: sky/engine/platform/fonts/FontPlatformData.h
diff --git a/sky/engine/platform/fonts/FontPlatformData.h b/sky/engine/platform/fonts/FontPlatformData.h
index a589f27a6f64887703cbd3a35c28b6de8402bbfb..0f65e88253c21321d2c0d30c39b927bdc6246c96 100644
--- a/sky/engine/platform/fonts/FontPlatformData.h
+++ b/sky/engine/platform/fonts/FontPlatformData.h
@@ -23,153 +23,4 @@
*/
// FIXME: This is temporary until mac switch to using FontPlatformDataHarfBuzz.h and we merge it with this file.
-#if !OS(MACOSX)
#include "platform/fonts/harfbuzz/FontPlatformDataHarfBuzz.h"
-
-#else
-
-#ifndef FontPlatformData_h
-#define FontPlatformData_h
-
-#include "platform/PlatformExport.h"
-#include "platform/fonts/FontOrientation.h"
-#include "platform/fonts/FontWidthVariant.h"
-
-OBJC_CLASS NSFont;
-
-typedef struct CGFont* CGFontRef;
-typedef const struct __CTFont* CTFontRef;
-
-#include <CoreFoundation/CFBase.h>
-#include <objc/objc-auto.h>
-
-#include "wtf/Forward.h"
-#include "wtf/HashTableDeletedValueType.h"
-#include "wtf/PassRefPtr.h"
-#include "wtf/RefCounted.h"
-#include "wtf/RetainPtr.h"
-#include "wtf/text/StringImpl.h"
-
-#include "platform/fonts/mac/MemoryActivatedFont.h"
-#include "third_party/skia/include/core/SkTypeface.h"
-
-typedef struct CGFont* CGFontRef;
-typedef const struct __CTFont* CTFontRef;
-typedef UInt32 FMFont;
-typedef FMFont ATSUFontID;
-typedef UInt32 ATSFontRef;
-
-namespace blink {
-
-class HarfBuzzFace;
-
-inline CTFontRef toCTFontRef(NSFont *nsFont) { return reinterpret_cast<CTFontRef>(nsFont); }
-
-class PLATFORM_EXPORT FontPlatformData {
-public:
- FontPlatformData(WTF::HashTableDeletedValueType);
- FontPlatformData();
- FontPlatformData(const FontPlatformData&);
- FontPlatformData(float size, bool syntheticBold, bool syntheticOblique, FontOrientation = Horizontal, FontWidthVariant = RegularWidth);
- FontPlatformData(NSFont*, float size, bool syntheticBold = false, bool syntheticOblique = false,
- FontOrientation = Horizontal, FontWidthVariant = RegularWidth);
- FontPlatformData(CGFontRef, float size, bool syntheticBold, bool syntheticOblique, FontOrientation, FontWidthVariant);
-
- ~FontPlatformData();
-
- NSFont* font() const { return m_font; }
- void setFont(NSFont*);
-
- CGFontRef cgFont() const { return m_cgFont.get(); }
- CTFontRef ctFont() const;
- SkTypeface* typeface() const;
-
- bool roundsGlyphAdvances() const;
- bool allowsLigatures() const;
-
- String fontFamilyName() const;
- bool isFixedPitch() const;
- float size() const { return m_size; }
- void setSize(float size) { m_size = size; }
- bool syntheticBold() const { return m_syntheticBold; }
- bool syntheticOblique() const { return m_syntheticOblique; }
- bool isColorBitmapFont() const { return m_isColorBitmapFont; }
- bool isCompositeFontReference() const { return m_isCompositeFontReference; }
-
- FontOrientation orientation() const { return m_orientation; }
- FontWidthVariant widthVariant() const { return m_widthVariant; }
-
- void setOrientation(FontOrientation orientation) { m_orientation = orientation; }
-
- HarfBuzzFace* harfBuzzFace();
-
- unsigned hash() const
- {
- ASSERT(m_font || !m_cgFont);
- uintptr_t hashCodes[3] = { (uintptr_t)m_font, m_widthVariant, static_cast<uintptr_t>(m_orientation << 2 | m_syntheticBold << 1 | m_syntheticOblique) };
- return StringHasher::hashMemory<sizeof(hashCodes)>(hashCodes);
- }
-
- const FontPlatformData& operator=(const FontPlatformData&);
-
- bool operator==(const FontPlatformData& other) const
- {
- return platformIsEqual(other)
- && m_size == other.m_size
- && m_syntheticBold == other.m_syntheticBold
- && m_syntheticOblique == other.m_syntheticOblique
- && m_isColorBitmapFont == other.m_isColorBitmapFont
- && m_isCompositeFontReference == other.m_isCompositeFontReference
- && m_orientation == other.m_orientation
- && m_widthVariant == other.m_widthVariant;
- }
-
- bool isHashTableDeletedValue() const
- {
- return m_font == hashTableDeletedFontValue();
- }
-
-#ifndef NDEBUG
- String description() const;
-#endif
-
-private:
- bool platformIsEqual(const FontPlatformData&) const;
- void platformDataInit(const FontPlatformData&);
- const FontPlatformData& platformDataAssign(const FontPlatformData&);
-#if OS(MACOSX)
- // Load various data about the font specified by |nsFont| with the size fontSize into the following output paramters:
- // Note: Callers should always take into account that for the Chromium port, |outNSFont| isn't necessarily the same
- // font as |nsFont|. This because the sandbox may block loading of the original font.
- // * outNSFont - The font that was actually loaded, for the Chromium port this may be different than nsFont.
- // The caller is responsible for calling CFRelease() on this parameter when done with it.
- // * cgFont - CGFontRef representing the input font at the specified point size.
- void loadFont(NSFont*, float fontSize, NSFont*& outNSFont, CGFontRef&);
- static NSFont* hashTableDeletedFontValue() { return reinterpret_cast<NSFont *>(-1); }
-#endif
-
-public:
- bool m_syntheticBold;
- bool m_syntheticOblique;
- FontOrientation m_orientation;
- float m_size;
- FontWidthVariant m_widthVariant;
-
-private:
- NSFont* m_font;
- RetainPtr<CGFontRef> m_cgFont;
- mutable RetainPtr<CTFontRef> m_CTFont;
-
- RefPtr<MemoryActivatedFont> m_inMemoryFont;
- RefPtr<HarfBuzzFace> m_harfBuzzFace;
- mutable RefPtr<SkTypeface> m_typeface;
-
- bool m_isColorBitmapFont;
- bool m_isCompositeFontReference;
-};
-
-} // namespace blink
-
-#endif // FontPlatformData_h
-
-#endif
« no previous file with comments | « sky/engine/platform/exported/WebCursorInfo.cpp ('k') | sky/engine/platform/fonts/GlyphPage.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698