/usr/include/graphite/FileFont.h is in libgraphite-dev 1:2.3.1-0.2build1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 | /*--------------------------------------------------------------------*//*:Ignore this sentence.
Copyright (C) 1999, 2001, 2005 SIL International. All rights reserved.
Distributable under the terms of either the Common Public License or the
GNU Lesser General Public License, as specified in the LICENSING.txt file.
File: XftFont.h
Responsibility: Keith Stribley
Last reviewed: Not yet.
Description:
A Font is an object that represents a font-family + bold + italic setting, that contains
Graphite tables.
----------------------------------------------------------------------------------------------*/
#ifndef FILEFONT_INCLUDED
#define FILEFONT_INCLUDED
#include "Font.h"
//:End Ignore
namespace gr
{
class FontTableCache;
class GrEngine;
/*-----------------------------------------------------------------------------
Stock implementation of an Xft font class.
------------------------------------------------------------------------------*/
/**
* An implementation of the Graphite gr::Font class for Xft fonts for use on
* systems using X. Freetype is used to retrieve font information.
* If you are using Freetype directly, without Xft, you can pass in a FT_Face
* directly.
*/
class FileFont : public Font
{
public:
/**
* The main user constructor. Constructs the font from the supplied FILE pointer.
* @param file the FILE pointer to initialise from (must not be null)
*/
FileFont(FILE * file, float pointSize, unsigned int DPIx, unsigned int DPIy = 0);
/**
* Alternative user constructor. Constructs the font from the supplied filename.
* @param filename character array
*/
FileFont(char * filename, float pointSize, unsigned int DPIx, unsigned int DPIy = 0);
/**
* Alternative user constructor. Constructs the font from the supplied filename.
* @param filename as a string
*/
FileFont(std::string filename, float pointSize,
unsigned int DPIx, unsigned int DPIy = 0);
/**
* Destructor - cleans up the tables that it has allocated if all other copies
* of this font have been deleted.
*/
virtual ~FileFont();
/**
* Returns a copy of the recipient. Specifically needed to store the Font
* in a segment.
* @internal
*/
virtual Font * copyThis();
/**
* Copy constructor - note the tables are shared between the copy and the
* original font for efficiency reasons.
* The last copy to be deleted will delete the tables.
* @param font the XftGrFont object to copy from.
* @internal
*/
FileFont(const FileFont & font, float pointSize = 0, unsigned int DPIx = 0, unsigned int DPIy = 0);
//virtual FontErrorCode isValidForGraphite(int * pnVersion = NULL, int * pnSubVersion = NULL);
/**
* Returns a pointer to the start of a table in the font. The ftblid32 type
* is a 32-bit unsigned integer.
* If the Font class cannot easily determine the length of the table, it may
* set 0 as the length (while returning a non-NULL pointer to the table). This
* means that certain kinds of error checking cannot be done by the Graphite
* engine.
* Throws an exception if there is some other error in reading the table, or if
* the table asked for is not one of the expected ones (cmap, head, name, Sile,
* Silf, Feat, Gloc, Glat). [If we want to be able to read “non-standard”
* tables, then the caller needs to be responsible for freeing the memory.]
*/
virtual const void * getTable(fontTableId32 tableID, size_t * pcbSize);
/**
* Returns the basic metrics of the font. It corresponds to the current
* GrGraphics::get_FontAscent, get_FontDescent and GetFontEmSquare methods.
* @param pAscent pointer to hold font ascent
* @param pDescent pointer to hold font descent
* @param pEmSquare pointer to hold font EM square
*/
virtual void getFontMetrics(float * pAscent, float * pDescent = NULL,
float * pEmSquare = NULL);
/**
* Returns true if the given arguments specify a font that contains Graphite
* tables—specfically a “Silf” table.
* @param xftFont XftFont pointer
* @return true if this font has the silf table
*/
bool fontHasGraphiteTables();
/**
* Returns true if the given arguments specify a font that contains Graphite
* tables—specfically a “Silf” table.
* @param xftFont XftFont pointer
* @return true if this font has the silf table
*/
static bool FontHasGraphiteTables(FILE * file);
/**
* Returns true if the given arguments specify a font that contains Graphite
* tables—specfically a “Silf” table.
* @param face FT_Face handle
* @return true if this font has the silf table
*/
static bool FontHasGraphiteTables(char * filename);
// Temporary, until interface gets thoroughly reworked:
GrEngine * GraphiteEngine();
/**
* Returns the font ascent in pixels. Using floating point allows us to
* avoid rounding errors.
* Value is the same as that returned by getFontMetrics()
* @return the font ascent
*/
virtual float ascent()
{
float pixAscent;
getFontMetrics(&pixAscent);
return pixAscent;
}
/**
* Returns the font descent in pixels with a positive sign.
* Value is the same as that returned by getFontMetrics()
* @return the font descent in pixels.
*/
virtual float descent()
{
float pixDescent;
getFontMetrics(NULL, &pixDescent);
return pixDescent;
}
/**
* Returns the total height of the font.
* Equivalent to ascent() + descent().
* @return font height
*/
virtual float height()
{
float pixAscent;
float pixDescent;
getFontMetrics(&pixAscent, &pixDescent);
return (pixAscent + pixDescent);
}
/**
* @return true if the font is a bold styled one.
*/
virtual bool bold()
{
return m_fBold;
}
/**
* @return true if the font is italic
*/
virtual bool italic()
{
return m_fItalic;
}
/** @return the DPI for the x-axis.
*/
virtual unsigned int getDPIx()
{
return m_dpiX;
}
/** @return Returns the DPI for the y-axis.
*/
virtual unsigned int getDPIy()
{
return m_dpiY;
}
// Specific to XftGrFont:
/** @return set the DPI for the x-axis.
*/
virtual void setDPIx(unsigned int dpi)
{
m_dpiX = dpi;
m_xScale = scaleFromDpi(dpi);
}
/** @return set the DPI for the y-axis.
*/
virtual void setDPIy(unsigned int dpi)
{
m_dpiY = dpi;
m_yScale = scaleFromDpi(dpi);
}
bool isValid() { return m_fIsValid; };
protected:
/** Default constructor is not used */
FileFont();
/**
* Common initialisation between the XftFont and FT_Face constructors.
*/
void initializeFromFace(void);
// this uses an int to avoid having to include TtfUtil.h in the include
// directory
byte * readTable(int /*TableId*/ tableId, size_t & size);
// pixels-per-em = dpi * point-size / 72
// pixel-coord = design-coord * pixels-per-em / font-em-square
float scaleFromDpi(int dpi)
{
return (dpi * m_pointSize) / (72.0f * m_mEmSquare);
}
// Member variables:
FILE * m_pfile;
unsigned long m_clrFore;
unsigned long m_clrBack;
bool m_fBold;
bool m_fItalic;
// font table caches:
FontTableCache * m_pTableCache;
// KRS: I think these should be cached otherwise Segment::LineContextSegment doesn't work
float m_mAscent;
float m_mDescent;
float m_mEmSquare;
float m_pointSize;
int m_dpiX;
int m_dpiY;
bool m_fIsValid;
std::wstring m_stuFaceName;
byte * m_pHeader;
byte * m_pTableDir;
float m_xScale;
float m_yScale;
};
} // namespace gr
#endif
|