FontPlatformData.h [plain text]
#ifndef FontPlatformData_h
#define FontPlatformData_h
#include "StringImpl.h"
#ifdef __OBJC__
@class NSFont;
#else
class NSFont;
#endif
#import <GraphicsServices/GraphicsServices.h>
typedef struct CGFont* CGFontRef;
#ifndef BUILDING_ON_TIGER
typedef const struct __CTFont* CTFontRef;
#endif
#include <CoreFoundation/CFBase.h>
#include <objc/objc-auto.h>
#include <wtf/RetainPtr.h>
typedef UInt32 ATSUFontID;
namespace WebCore {
class String;
struct FontPlatformData {
FontPlatformData(float size, bool syntheticBold, bool syntheticOblique)
: m_syntheticBold(syntheticBold)
, m_syntheticOblique(syntheticOblique)
, m_atsuFontID(0)
, m_isEmoji(false)
, m_size(size)
, m_font(0)
#ifdef BUILDING_ON_TIGER
, m_cgFont(0)
#endif
, m_isColorBitmapFont(false)
{
}
FontPlatformData(GSFontRef, bool syntheticBold = false, bool syntheticOblique = false);
FontPlatformData(CGFontRef cgFont, ATSUFontID fontID, float size, bool syntheticBold, bool syntheticOblique)
: m_syntheticBold(syntheticBold)
, m_syntheticOblique(syntheticOblique)
, m_atsuFontID(fontID)
, m_isEmoji(false)
, m_size(size)
, m_font(0)
, m_cgFont(cgFont)
, m_isColorBitmapFont(false)
{
}
FontPlatformData(const FontPlatformData&);
~FontPlatformData();
FontPlatformData(WTF::HashTableDeletedValueType) : m_font(hashTableDeletedFontValue()) { }
bool isHashTableDeletedValue() const { return m_font == hashTableDeletedFontValue(); }
float size() const { return m_size; }
bool syntheticBold() const { return m_syntheticBold; }
bool syntheticOblique() const { return m_syntheticOblique; }
bool m_syntheticBold;
bool m_syntheticOblique;
ATSUFontID m_atsuFontID;
bool m_isEmoji;
float m_size;
unsigned hash() const
{
ASSERT(m_font != 0 || m_cgFont == 0 || m_isEmoji != 0);
uintptr_t hashCodes[2] = { (uintptr_t)m_font, m_isEmoji << 2 | m_syntheticBold << 1 | m_syntheticOblique };
return StringImpl::computeHash(reinterpret_cast<UChar*>(hashCodes), sizeof(hashCodes) / sizeof(UChar));
}
const FontPlatformData& operator=(const FontPlatformData& f);
bool operator==(const FontPlatformData& other) const
{
return m_font == other.m_font && m_syntheticBold == other.m_syntheticBold && m_syntheticOblique == other.m_syntheticOblique &&
m_cgFont == other.m_cgFont && m_size == other.m_size && m_atsuFontID == other.m_atsuFontID
&& m_isEmoji == other.m_isEmoji
;
}
GSFontRef font() const { return m_font; }
void setFont(GSFontRef font);
#if USE(CORE_TEXT)
CTFontRef ctFont() const;
#endif
bool roundsGlyphAdvances() const { return false; }
bool allowsLigatures() const;
bool isColorBitmapFont() const { return m_isColorBitmapFont; }
#ifndef BUILDING_ON_TIGER
CGFontRef cgFont() const { return m_cgFont.get(); }
#else
CGFontRef cgFont() const { return m_cgFont; }
#endif
#ifndef NDEBUG
String description() const;
#endif
private:
static GSFontRef hashTableDeletedFontValue() { return reinterpret_cast<GSFontRef>(-1); }
GSFontRef m_font;
#ifndef BUILDING_ON_TIGER
RetainPtr<CGFontRef> m_cgFont;
#else
CGFontRef m_cgFont; #endif
#if USE(CORE_TEXT)
mutable RetainPtr<CTFontRef> m_CTFont;
#endif
bool m_isColorBitmapFont;
};
}
#endif