This file is indexed.

/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