2007-03-22 10:30:00 -07:00
|
|
|
/* -*- Mode: C++; tab-width: 20; indent-tabs-mode: nil; c-basic-offset: 4 -*-
|
|
|
|
* ***** BEGIN LICENSE BLOCK *****
|
|
|
|
* Version: MPL 1.1/GPL 2.0/LGPL 2.1
|
|
|
|
*
|
|
|
|
* The contents of this file are subject to the Mozilla Public License Version
|
|
|
|
* 1.1 (the "License"); you may not use this file except in compliance with
|
|
|
|
* the License. You may obtain a copy of the License at
|
|
|
|
* http://www.mozilla.org/MPL/
|
|
|
|
*
|
|
|
|
* Software distributed under the License is distributed on an "AS IS" basis,
|
|
|
|
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
|
|
|
|
* for the specific language governing rights and limitations under the
|
|
|
|
* License.
|
|
|
|
*
|
|
|
|
* The Original Code is Mozilla Foundation code.
|
|
|
|
*
|
|
|
|
* The Initial Developer of the Original Code is Mozilla Foundation.
|
|
|
|
* Portions created by the Initial Developer are Copyright (C) 2005
|
|
|
|
* the Initial Developer. All Rights Reserved.
|
|
|
|
*
|
|
|
|
* Contributor(s):
|
|
|
|
* Vladimir Vukicevic <vladimir@mozilla.com>
|
|
|
|
* Masayuki Nakano <masayuki@d-toybox.com>
|
|
|
|
*
|
|
|
|
* Alternatively, the contents of this file may be used under the terms of
|
|
|
|
* either the GNU General Public License Version 2 or later (the "GPL"), or
|
|
|
|
* the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
|
|
|
|
* in which case the provisions of the GPL or the LGPL are applicable instead
|
|
|
|
* of those above. If you wish to allow use of your version of this file only
|
|
|
|
* under the terms of either the GPL or the LGPL, and not to allow others to
|
|
|
|
* use your version of this file under the terms of the MPL, indicate your
|
|
|
|
* decision by deleting the provisions above and replace them with the notice
|
|
|
|
* and other provisions required by the GPL or the LGPL. If you do not delete
|
|
|
|
* the provisions above, a recipient may use your version of this file under
|
|
|
|
* the terms of any one of the MPL, the GPL or the LGPL.
|
|
|
|
*
|
|
|
|
* ***** END LICENSE BLOCK ***** */
|
|
|
|
|
|
|
|
#ifndef GFX_PANGOFONTS_H
|
|
|
|
#define GFX_PANGOFONTS_H
|
|
|
|
|
|
|
|
#include "cairo.h"
|
|
|
|
#include "gfxTypes.h"
|
|
|
|
#include "gfxFont.h"
|
|
|
|
|
2008-11-06 18:21:34 -08:00
|
|
|
#include "nsAutoRef.h"
|
2009-01-18 12:14:14 -08:00
|
|
|
#include "nsTArray.h"
|
2008-11-06 18:21:34 -08:00
|
|
|
|
2007-03-22 10:30:00 -07:00
|
|
|
#include <pango/pango.h>
|
|
|
|
|
2007-10-06 00:26:13 -07:00
|
|
|
// Control when we bypass Pango
|
|
|
|
// Enable this to use FreeType to glyph-convert 8bit-only textruns, but use Pango
|
2007-03-22 10:30:00 -07:00
|
|
|
// to shape any textruns with non-8bit characters
|
2007-10-06 00:26:13 -07:00
|
|
|
// XXX
|
|
|
|
#define ENABLE_FAST_PATH_8BIT
|
|
|
|
// Enable this to bypass Pango shaping for all textruns. Don't expect
|
|
|
|
// anything other than simple Latin work though!
|
|
|
|
//#define ENABLE_FAST_PATH_ALWAYS
|
2007-03-22 10:30:00 -07:00
|
|
|
|
2008-11-06 18:21:34 -08:00
|
|
|
class gfxFcPangoFontSet;
|
2008-12-05 15:19:27 -08:00
|
|
|
class gfxProxyFontEntry;
|
|
|
|
typedef struct _FcPattern FcPattern;
|
|
|
|
typedef struct FT_FaceRec_* FT_Face;
|
2008-08-05 21:34:06 -07:00
|
|
|
|
2007-03-22 10:30:00 -07:00
|
|
|
class THEBES_API gfxPangoFontGroup : public gfxFontGroup {
|
|
|
|
public:
|
|
|
|
gfxPangoFontGroup (const nsAString& families,
|
2008-09-30 20:01:53 -07:00
|
|
|
const gfxFontStyle *aStyle,
|
|
|
|
gfxUserFontSet *aUserFontSet);
|
2007-03-22 10:30:00 -07:00
|
|
|
virtual ~gfxPangoFontGroup ();
|
|
|
|
|
|
|
|
virtual gfxFontGroup *Copy(const gfxFontStyle *aStyle);
|
|
|
|
|
2007-10-06 00:26:13 -07:00
|
|
|
// Create and initialize a textrun using Pango
|
2007-03-22 10:30:00 -07:00
|
|
|
virtual gfxTextRun *MakeTextRun(const PRUnichar *aString, PRUint32 aLength,
|
2007-05-08 15:46:14 -07:00
|
|
|
const Parameters *aParams, PRUint32 aFlags);
|
2007-03-22 10:30:00 -07:00
|
|
|
virtual gfxTextRun *MakeTextRun(const PRUint8 *aString, PRUint32 aLength,
|
2007-05-08 15:46:14 -07:00
|
|
|
const Parameters *aParams, PRUint32 aFlags);
|
2007-03-22 10:30:00 -07:00
|
|
|
|
2008-09-26 17:21:55 -07:00
|
|
|
virtual gfxFont *GetFontAt(PRInt32 i);
|
|
|
|
|
2008-12-05 15:19:27 -08:00
|
|
|
virtual void UpdateFontList();
|
|
|
|
|
2008-09-26 17:21:55 -07:00
|
|
|
static void Shutdown();
|
2007-03-22 10:30:00 -07:00
|
|
|
|
2009-01-02 19:21:49 -08:00
|
|
|
// Used for @font-face { src: local(); }
|
|
|
|
static gfxFontEntry *NewFontEntry(const gfxProxyFontEntry &aProxyEntry,
|
|
|
|
const nsAString &aFullname);
|
2008-12-05 15:19:27 -08:00
|
|
|
// Used for @font-face { src: url(); }
|
|
|
|
static gfxFontEntry *NewFontEntry(const gfxProxyFontEntry &aProxyEntry,
|
|
|
|
const PRUint8 *aFontData,
|
|
|
|
PRUint32 aLength);
|
|
|
|
|
2008-11-06 18:21:34 -08:00
|
|
|
// Interfaces used internally
|
|
|
|
// (but public so that they can be accessed from non-member functions):
|
|
|
|
|
|
|
|
// The FontGroup holds the reference to the PangoFont (through the FontSet).
|
|
|
|
PangoFont *GetBasePangoFont();
|
|
|
|
|
|
|
|
// A language guessed from the gfxFontStyle
|
|
|
|
PangoLanguage *GetPangoLanguage() { return mPangoLanguage; }
|
|
|
|
|
|
|
|
// @param aLang [in] language to use for pref fonts and system default font
|
|
|
|
// selection, or NULL for the language guessed from the gfxFontStyle.
|
|
|
|
// The FontGroup holds a reference to this set.
|
|
|
|
gfxFcPangoFontSet *GetFontSet(PangoLanguage *aLang = NULL);
|
|
|
|
|
2007-03-22 10:30:00 -07:00
|
|
|
protected:
|
2008-11-06 18:21:34 -08:00
|
|
|
class FontSetByLangEntry {
|
|
|
|
public:
|
|
|
|
FontSetByLangEntry(PangoLanguage *aLang, gfxFcPangoFontSet *aFontSet);
|
|
|
|
PangoLanguage *mLang;
|
|
|
|
nsRefPtr<gfxFcPangoFontSet> mFontSet;
|
|
|
|
};
|
|
|
|
// There is only one of entry in this array unless characters from scripts
|
|
|
|
// of other languages are measured.
|
|
|
|
nsAutoTArray<FontSetByLangEntry,1> mFontSets;
|
|
|
|
|
|
|
|
gfxFloat mSizeAdjustFactor;
|
|
|
|
PangoLanguage *mPangoLanguage;
|
2008-09-26 17:21:55 -07:00
|
|
|
|
2007-03-22 10:30:00 -07:00
|
|
|
// ****** Textrun glyph conversion helpers ******
|
|
|
|
|
2007-07-16 15:49:10 -07:00
|
|
|
/**
|
|
|
|
* Fill in the glyph-runs for the textrun.
|
|
|
|
* @param aTake8BitPath the text contains only characters below 0x100
|
|
|
|
* (TEXT_IS_8BIT can return false when the characters are all below 0x100
|
|
|
|
* but stored in UTF16 format)
|
|
|
|
*/
|
2007-03-22 10:30:00 -07:00
|
|
|
void InitTextRun(gfxTextRun *aTextRun, const gchar *aUTF8Text,
|
2007-11-11 11:40:34 -08:00
|
|
|
PRUint32 aUTF8Length, PRUint32 aUTF8HeaderLength,
|
|
|
|
PRBool aTake8BitPath);
|
2007-10-06 00:26:13 -07:00
|
|
|
|
2007-03-22 10:30:00 -07:00
|
|
|
// Returns NS_ERROR_FAILURE if there's a missing glyph
|
2008-09-15 21:19:46 -07:00
|
|
|
nsresult SetGlyphs(gfxTextRun *aTextRun,
|
2007-05-08 08:33:52 -07:00
|
|
|
const gchar *aUTF8, PRUint32 aUTF8Length,
|
2007-03-22 10:30:00 -07:00
|
|
|
PRUint32 *aUTF16Offset, PangoGlyphString *aGlyphs,
|
|
|
|
PangoGlyphUnit aOverrideSpaceWidth,
|
|
|
|
PRBool aAbortOnMissingGlyph);
|
2007-05-08 08:33:52 -07:00
|
|
|
nsresult SetMissingGlyphs(gfxTextRun *aTextRun,
|
|
|
|
const gchar *aUTF8, PRUint32 aUTF8Length,
|
|
|
|
PRUint32 *aUTF16Offset);
|
2007-03-22 10:30:00 -07:00
|
|
|
void CreateGlyphRunsItemizing(gfxTextRun *aTextRun,
|
2007-11-11 11:40:34 -08:00
|
|
|
const gchar *aUTF8, PRUint32 aUTF8Length,
|
|
|
|
PRUint32 aUTF8HeaderLength);
|
2007-10-06 00:26:13 -07:00
|
|
|
#if defined(ENABLE_FAST_PATH_8BIT) || defined(ENABLE_FAST_PATH_ALWAYS)
|
|
|
|
PRBool CanTakeFastPath(PRUint32 aFlags);
|
2007-10-11 18:05:16 -07:00
|
|
|
nsresult CreateGlyphRunsFast(gfxTextRun *aTextRun,
|
|
|
|
const gchar *aUTF8, PRUint32 aUTF8Length);
|
2007-03-22 10:30:00 -07:00
|
|
|
#endif
|
|
|
|
|
2008-12-05 15:19:27 -08:00
|
|
|
void GetFcFamilies(nsTArray<nsString> *aFcFamilyList,
|
2010-02-24 09:57:57 -08:00
|
|
|
nsIAtom *aLanguage);
|
2007-05-08 08:33:52 -07:00
|
|
|
|
2008-11-06 18:21:34 -08:00
|
|
|
// @param aLang [in] language to use for pref fonts and system font
|
|
|
|
// resolution, or NULL to guess a language from the gfxFontStyle.
|
|
|
|
// @param aMatchPattern [out] if non-NULL, will return the pattern used.
|
|
|
|
already_AddRefed<gfxFcPangoFontSet>
|
|
|
|
MakeFontSet(PangoLanguage *aLang, gfxFloat aSizeAdjustFactor,
|
|
|
|
nsAutoRef<FcPattern> *aMatchPattern = NULL);
|
2008-01-27 02:27:08 -08:00
|
|
|
|
2008-11-06 18:21:34 -08:00
|
|
|
gfxFcPangoFontSet *GetBaseFontSet();
|
2008-01-27 02:27:08 -08:00
|
|
|
|
2008-11-06 18:21:34 -08:00
|
|
|
gfxFloat GetSizeAdjustFactor()
|
|
|
|
{
|
|
|
|
if (mFontSets.Length() == 0)
|
|
|
|
GetBaseFontSet();
|
|
|
|
return mSizeAdjustFactor;
|
2008-01-27 02:27:08 -08:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2007-03-22 10:30:00 -07:00
|
|
|
#endif /* GFX_PANGOFONTS_H */
|