summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAron Griffis <agriffis@gentoo.org>2004-11-15 20:34:40 +0000
committerAron Griffis <agriffis@gentoo.org>2004-11-15 20:34:40 +0000
commit343bb8d7ca74c6628f46863aafbec032a0922f97 (patch)
treea285a063c644a9978a495de3e5717c2718667e3d /net-www
parentStable on ppc64; bug #69447 (diff)
downloadhistorical-343bb8d7ca74c6628f46863aafbec032a0922f97.tar.gz
historical-343bb8d7ca74c6628f46863aafbec032a0922f97.tar.bz2
historical-343bb8d7ca74c6628f46863aafbec032a0922f97.zip
Add patch for freetype-2.1.8+ binary compatibility #59849
Diffstat (limited to 'net-www')
-rw-r--r--net-www/mozilla-firefox/ChangeLog8
-rw-r--r--net-www/mozilla-firefox/Manifest25
-rw-r--r--net-www/mozilla-firefox/files/digest-mozilla-firefox-1.0-r31
-rw-r--r--net-www/mozilla-firefox/files/mozilla-firefox-1.0-4ft2.patch654
-rw-r--r--net-www/mozilla-firefox/mozilla-firefox-1.0-r3.ebuild188
5 files changed, 864 insertions, 12 deletions
diff --git a/net-www/mozilla-firefox/ChangeLog b/net-www/mozilla-firefox/ChangeLog
index cd7cb13c3447..ec78fd3367be 100644
--- a/net-www/mozilla-firefox/ChangeLog
+++ b/net-www/mozilla-firefox/ChangeLog
@@ -1,6 +1,12 @@
# ChangeLog for net-www/mozilla-firefox
# Copyright 2000-2004 Gentoo Foundation; Distributed under the GPL v2
-# $Header: /var/cvsroot/gentoo-x86/net-www/mozilla-firefox/ChangeLog,v 1.79 2004/11/15 02:18:17 agriffis Exp $
+# $Header: /var/cvsroot/gentoo-x86/net-www/mozilla-firefox/ChangeLog,v 1.80 2004/11/15 20:34:40 agriffis Exp $
+
+*mozilla-firefox-1.0-r3 (15 Nov 2004)
+
+ 15 Nov 2004; Aron Griffis <agriffis@gentoo.org>
+ +files/mozilla-firefox-1.0-4ft2.patch, +mozilla-firefox-1.0-r3.ebuild:
+ Add patch for freetype-2.1.8+ binary compatibility #59849
14 Nov 2004; Aron Griffis <agriffis@gentoo.org>
mozilla-firefox-1.0-r2.ebuild:
diff --git a/net-www/mozilla-firefox/Manifest b/net-www/mozilla-firefox/Manifest
index f59df81b68e4..c36b48e76cef 100644
--- a/net-www/mozilla-firefox/Manifest
+++ b/net-www/mozilla-firefox/Manifest
@@ -1,24 +1,27 @@
-MD5 81a211e2f3776102b06790945a67e56b ChangeLog 12959
+MD5 db19f9dacddff33483bb7305e45fe7f2 ChangeLog 13182
MD5 ce23390351fe8020387d93ee29e09a3d metadata.xml 160
-MD5 809453352ef124b51ec8e4c96fd23e69 mozilla-firefox-1.0_rc1.ebuild 5147
-MD5 6c89295fc5264c6798ee06f9e2f5c936 mozilla-firefox-1.0_rc2.ebuild 5066
-MD5 1886b4b2093f8116f5f8639402dc8df1 mozilla-firefox-1.0.ebuild 5060
MD5 c543ce361b2035afbb9db4010f9f776e mozilla-firefox-0.9.3.ebuild 8425
-MD5 faaa52e819364f34c1b174f0c47a6d86 mozilla-firefox-1.0_pre-r2.ebuild 5073
MD5 490be87316abb05ed47da6a4d9a4ed1a mozilla-firefox-1.0-r2.ebuild 5595
+MD5 1886b4b2093f8116f5f8639402dc8df1 mozilla-firefox-1.0.ebuild 5060
+MD5 faaa52e819364f34c1b174f0c47a6d86 mozilla-firefox-1.0_pre-r2.ebuild 5073
+MD5 809453352ef124b51ec8e4c96fd23e69 mozilla-firefox-1.0_rc1.ebuild 5147
+MD5 6c89295fc5264c6798ee06f9e2f5c936 mozilla-firefox-1.0_rc2.ebuild 5066
+MD5 bd9e6d7ea4332291dd0e3fd7a11a9e83 mozilla-firefox-1.0-r3.ebuild 5827
MD5 606e82226379fd5ae6cd1d0d1faff7ff files/10MozillaFirefox 31
+MD5 0c7804fd13815f9a0e7a1ef0eab6a871 files/digest-mozilla-firefox-0.9.3 75
+MD5 47c899122e30bc898b5a899ed0e10129 files/digest-mozilla-firefox-1.0 73
+MD5 47c899122e30bc898b5a899ed0e10129 files/digest-mozilla-firefox-1.0-r2 73
+MD5 bef773177860190ef5d6cce7ec70c613 files/digest-mozilla-firefox-1.0_pre-r2 77
MD5 fa885b490a3c76594784843a1c06ee3a files/digest-mozilla-firefox-1.0_rc1 76
MD5 e5cc0a5838a73f3fdaf38f4e3c368c26 files/digest-mozilla-firefox-1.0_rc2 76
-MD5 47c899122e30bc898b5a899ed0e10129 files/digest-mozilla-firefox-1.0 73
MD5 bd50631b47d20becbb5af21b605dfb5d files/firefox 4218
MD5 3ad7410bd680964096c84eee3fa21abf files/firefox-0.8-gcc-3.4.patch 460
+MD5 48baf2f328e6478812c24e59037ff99c files/firefox-0.9-init.tar.bz2 3322
+MD5 c6308c086c87ed2e1e4f3d136efdd770 files/firefox-0.9-nsFormHistory-crash-fix.patch 1755
MD5 23d1fbd03cc6dd346a4e4ce8f2d88ebf files/mozilla-1.3-alpha-stubs.patch 4646
MD5 f0e9adeb0454377ce019e8969e644efb files/mozilla-firebird-amd64.patch 35052
MD5 88371b8f812caf799a1ede2b1b07c079 files/mozilla-firefox-mousebuttons.patch 17099
-MD5 47c899122e30bc898b5a899ed0e10129 files/digest-mozilla-firefox-1.0-r2 73
-MD5 48baf2f328e6478812c24e59037ff99c files/firefox-0.9-init.tar.bz2 3322
-MD5 c6308c086c87ed2e1e4f3d136efdd770 files/firefox-0.9-nsFormHistory-crash-fix.patch 1755
-MD5 0c7804fd13815f9a0e7a1ef0eab6a871 files/digest-mozilla-firefox-0.9.3 75
-MD5 bef773177860190ef5d6cce7ec70c613 files/digest-mozilla-firefox-1.0_pre-r2 77
+MD5 b16efe0e4066720b718d67348aeee757 files/mozilla-firefox-1.0-4ft2.patch 22294
+MD5 47c899122e30bc898b5a899ed0e10129 files/digest-mozilla-firefox-1.0-r3 73
MD5 bff260036c5dcca45da3218517fb33d8 files/icon/firefox-icon.png 3979
MD5 2cdd03eb2752bc01ba07ad837e926f39 files/icon/mozillafirefox.desktop 168
diff --git a/net-www/mozilla-firefox/files/digest-mozilla-firefox-1.0-r3 b/net-www/mozilla-firefox/files/digest-mozilla-firefox-1.0-r3
new file mode 100644
index 000000000000..e6d2584b2eac
--- /dev/null
+++ b/net-www/mozilla-firefox/files/digest-mozilla-firefox-1.0-r3
@@ -0,0 +1 @@
+MD5 49c16a71f4de014ea471be81e46b1da8 firefox-1.0-source.tar.bz2 32686249
diff --git a/net-www/mozilla-firefox/files/mozilla-firefox-1.0-4ft2.patch b/net-www/mozilla-firefox/files/mozilla-firefox-1.0-4ft2.patch
new file mode 100644
index 000000000000..11028aba71cc
--- /dev/null
+++ b/net-www/mozilla-firefox/files/mozilla-firefox-1.0-4ft2.patch
@@ -0,0 +1,654 @@
+This patch is from
+https://bugzilla.mozilla.org/show_bug.cgi?id=234035#c65 to enable
+linking against freetype-2.1.8+. It disables the experimental
+freetype caching. I modified this patch slightly to apply to 1.0;
+some things had moved around in the files since the original patch.
+
+15 Nov 2004 agriffis
+
+--- gfx/idl/nsIFreeType2.idl.agriffis 2004-04-15 21:09:33.000000000 -0400
++++ gfx/idl/nsIFreeType2.idl 2004-11-15 13:29:05.120343408 -0500
+@@ -98,8 +98,6 @@
+ {
+
+ readonly attribute FT_Library library;
+- readonly attribute FTC_Manager FTCacheManager;
+- readonly attribute FTC_Image_Cache ImageCache;
+
+ void doneFace(in FT_Face face);
+ void doneFreeType(in FT_Library lib);
+@@ -114,17 +112,8 @@
+ in FT_Long face_num, out FT_Face face);
+ void outlineDecompose(in FT_Outline_p outline,
+ in const_FT_Outline_Funcs_p funcs, in voidPtr p);
++ void setPixelSizes(in FT_Face face, in FT_UInt width, in FT_UInt height);
+ void setCharmap(in FT_Face face, in FT_CharMap charmap);
+- void imageCacheLookup(in FTC_Image_Cache cache, in FTC_Image_Desc_p desc,
+- in FT_UInt gindex, out FT_Glyph glyph);
+- void managerLookupSize(in FTC_Manager manager, in FTC_Font font,
+- out FT_Face face, out FT_Size size);
+- void managerDone(in FTC_Manager manager);
+- void managerNew(in FT_Library lib, in FT_UInt max_faces,
+- in FT_UInt max_sizes, in FT_ULong max_bytes,
+- in FTC_Face_Requester requester, in FT_Pointer req_data,
+- out FTC_Manager manager);
+- void imageCacheNew(in FTC_Manager manager, out FTC_Image_Cache cache);
+ /* #ifdef MOZ_SVG */
+ void glyphTransform(in FT_Glyph glyph, in FT_Matrix_p matrix,
+ in FT_Vector_p delta);
+--- gfx/src/ps/nsFontMetricsPS.h.agriffis 2003-04-22 12:25:09.000000000 -0400
++++ gfx/src/ps/nsFontMetricsPS.h 2004-11-15 13:37:58.431267824 -0500
+@@ -320,7 +320,8 @@
+ nsCOMPtr<nsITrueTypeFontCatalogEntry> mFaceID;
+ nsCOMPtr<nsIFreeType2> mFt2;
+ PRUint16 mPixelSize;
+- FTC_Image_Desc mImageDesc;
++ FT_Face mFace;
++ FT_Library mFreeTypeLibrary;
+
+
+ static PRBool AddUserPref(nsIAtom *aLang, const nsFont& aFont,
+@@ -363,7 +364,8 @@
+ protected:
+ nsCOMPtr<nsITrueTypeFontCatalogEntry> mEntry;
+ nsCOMPtr<nsIFreeType2> mFt2;
+- FTC_Image_Desc mImageDesc;
++ FT_Face mFace;
++ FT_Library mFreeTypeLibrary;
+ };
+ #endif
+
+--- gfx/src/ps/nsFontMetricsPS.cpp.agriffis 2004-02-04 20:57:05.000000000 -0500
++++ gfx/src/ps/nsFontMetricsPS.cpp 2004-11-15 13:29:05.123342952 -0500
+@@ -1141,21 +1141,26 @@
+
+ mPixelSize = NSToIntRound(app2dev * mFont->size);
+
+- mImageDesc.font.face_id = (void*)mEntry;
+- mImageDesc.font.pix_width = mPixelSize;
+- mImageDesc.font.pix_height = mPixelSize;
+- mImageDesc.image_type = 0;
+-
+ nsresult rv;
+ mFt2 = do_GetService(NS_FREETYPE2_CONTRACTID, &rv);
+ if (NS_FAILED(rv)) {
++ NS_ERROR("failed to get ft2 service");
++ return NS_ERROR_FAILURE;
++ }
++
++ if (NS_FAILED(mFt2->GetLibrary(&mFreeTypeLibrary))) {
++ NS_ERROR("failed to get ft2 library");
+ return NS_ERROR_FAILURE;
+ }
++
++ mFace = nsnull;
+ return NS_OK;
+ }
+
+ nsFontPSFreeType::~nsFontPSFreeType()
+ {
++ if (mFace)
++ mFt2->DoneFace(mFace);
+ mEntry = nsnull;
+ }
+
+@@ -1180,32 +1185,26 @@
+ nscoord
+ nsFontPSFreeType::GetWidth(const PRUnichar* aString, PRUint32 aLength)
+ {
+- FT_UInt glyph_index;
+- FT_Glyph glyph;
+- double origin_x = 0;
+-
+ // get the face/size from the FreeType cache
+ FT_Face face = getFTFace();
+ NS_ASSERTION(face, "failed to get face/size");
+ if (!face)
+ return 0;
+
+- FTC_Image_Cache iCache;
+- nsresult rv = mFt2->GetImageCache(&iCache);
+- if (NS_FAILED(rv)) {
+- NS_ERROR("Failed to get Image Cache");
+- return 0;
+- }
++ FT_UInt glyph_index;
++ FT_Glyph glyph;
++ double origin_x = 0;
+
++ // XXX : we might need some caching here
+ for (PRUint32 i=0; i<aLength; i++) {
+- mFt2->GetCharIndex((FT_Face)face, aString[i], &glyph_index);
+- nsresult rv = mFt2->ImageCacheLookup(iCache, &mImageDesc,
+- glyph_index, &glyph);
+- if (NS_FAILED(rv)) {
++ mFt2->GetCharIndex(face, aString[i], &glyph_index);
++ if (NS_FAILED(mFt2->LoadGlyph(face, glyph_index, FT_LOAD_DEFAULT)) ||
++ NS_FAILED(mFt2->GetGlyph(face->glyph, &glyph))) {
+ origin_x += FT_REG_TO_16_16(face->size->metrics.x_ppem/2 + 2);
+ continue;
+ }
+ origin_x += glyph->advance.x;
++ mFt2->DoneGlyph(glyph);
+ }
+
+ NS_ENSURE_TRUE(mFontMetrics, 0);
+@@ -1224,16 +1223,26 @@
+ FT_Face
+ nsFontPSFreeType::getFTFace()
+ {
+- FT_Face face = nsnull;
+-
+- FTC_Manager cManager;
+- mFt2->GetFTCacheManager(&cManager);
+- nsresult rv = mFt2->ManagerLookupSize(cManager, &mImageDesc.font,
+- &face, nsnull);
++ if (mFace) return mFace;
++
++ nsCAutoString fileName;
++ PRInt16 faceIndex;
++ mEntry->GetFileName(fileName);
++ mEntry->GetFaceIndex(&faceIndex);
++
++ nsresult rv =
++ mFt2->NewFace(mFreeTypeLibrary, fileName.get(), faceIndex, &mFace);
++
+ NS_ASSERTION(rv==0, "failed to get face/size");
+- if (rv)
+- return nsnull;
+- return face;
++ if (NS_FAILED(rv)) {
++ return nsnull;
++ }
++
++ if (NS_FAILED(mFt2->SetPixelSizes(mFace, mPixelSize, 0))) {
++ return nsnull;
++ }
++
++ return mFace;
+ }
+
+ nscoord
+@@ -1618,26 +1627,23 @@
+
+ void nsFT2Type8Generator::GeneratePSFont(FILE* aFile)
+ {
+- nsCAutoString fontName, styleName;
+- mEntry->GetFamilyName(fontName);
+- mEntry->GetStyleName(styleName);
+-
+- mImageDesc.font.face_id = (void*)mEntry;
+- // TT glyph has no relation to size
+- mImageDesc.font.pix_width = 16;
+- mImageDesc.font.pix_height = 16;
+- mImageDesc.image_type = 0;
+- FT_Face face = nsnull;
+- FTC_Manager cManager;
+- mFt2->GetFTCacheManager(&cManager);
+- nsresult rv = mFt2->ManagerLookupSize(cManager, &mImageDesc.font,
+- &face, nsnull);
+- if (NS_FAILED(rv))
+- return;
++ if (mFace == nsnull) {
++ nsCAutoString fileName;
++ PRInt16 faceIndex;
++
++ mEntry->GetFileName(fileName);
++ mEntry->GetFaceIndex(&faceIndex);
++ if (NS_FAILED(mFt2->
++ NewFace(mFreeTypeLibrary, fileName.get(), faceIndex, &mFace))) {
++ return;
++ }
++ NS_ASSERTION(mFace != nsnull, "mFace is null");
++ }
++
+
+ int wmode = 0;
+ if (!mSubset.IsEmpty())
+- FT2SubsetToType8(face, mSubset.get(), mSubset.Length(), wmode, aFile);
++ FT2SubsetToType8(mFace, mSubset.get(), mSubset.Length(), wmode, aFile);
+ }
+ #endif //MOZ_ENABLE_FREETYPE2
+
+--- gfx/src/x11shared/nsFontFreeType.cpp.agriffis 2003-12-25 03:24:52.000000000 -0500
++++ gfx/src/x11shared/nsFontFreeType.cpp 2004-11-15 13:29:05.125342648 -0500
+@@ -173,15 +173,22 @@
+ FT_Face
+ nsFreeTypeFont::getFTFace()
+ {
+- FT_Face face = nsnull;
+- FTC_Manager mgr;
++ if (mFace) return mFace;
++
++ nsCAutoString fileName;
++ PRInt16 faceIndex;
++ mFaceID->GetFileName(fileName);
++ mFaceID->GetFaceIndex(&faceIndex);
++
+ nsresult rv;
+- mFt2->GetFTCacheManager(&mgr);
+- rv = mFt2->ManagerLookupSize(mgr, &mImageDesc.font, &face, nsnull);
++ rv = mFt2->NewFace(mFreeTypeLibrary, fileName.get(), faceIndex, &mFace);
+ NS_ASSERTION(NS_SUCCEEDED(rv), "failed to get face/size");
+ if (NS_FAILED(rv))
+ return nsnull;
+- return face;
++ rv = mFt2->SetPixelSizes(mFace, mPixelSize, 0);
++ if (NS_FAILED(rv))
++ return nsnull;
++ return mFace;
+ }
+
+ nsFreeTypeFont::nsFreeTypeFont(nsITrueTypeFontCatalogEntry *aFaceID,
+@@ -191,21 +198,20 @@
+ PRBool embedded_bimap = PR_FALSE;
+ mFaceID = aFaceID;
+ mPixelSize = aPixelSize;
+- mImageDesc.font.face_id = (void*)mFaceID;
+- mImageDesc.font.pix_width = aPixelSize;
+- mImageDesc.font.pix_height = aPixelSize;
+- mImageDesc.image_type = 0;
++//mLoadFlag = FT_LOAD_RENDER;
++ mLoadFlag = 0;
++ mFace = nsnull;
+
+ if (aPixelSize < nsFreeType2::gAntiAliasMinimum) {
+- mImageDesc.image_type |= ftc_image_mono;
++ mLoadFlag |= FT_LOAD_MONOCHROME;
+ anti_alias = PR_FALSE;
+ }
+
+ if (nsFreeType2::gFreeType2Autohinted)
+- mImageDesc.image_type |= ftc_image_flag_autohinted;
++ mLoadFlag |= FT_LOAD_FORCE_AUTOHINT;
+
+ if (nsFreeType2::gFreeType2Unhinted)
+- mImageDesc.image_type |= ftc_image_flag_unhinted;
++ mLoadFlag |= FT_LOAD_NO_HINTING;
+
+ PRUint32 num_embedded_bitmaps, i;
+ PRInt32* embedded_bitmapheights;
+@@ -218,7 +224,7 @@
+ if (embedded_bitmapheights[i] == aPixelSize) {
+ embedded_bimap = PR_TRUE;
+ // unhinted must be set for embedded bitmaps to be used
+- mImageDesc.image_type |= ftc_image_flag_unhinted;
++ mLoadFlag |= FT_LOAD_NO_HINTING;
+ break;
+ }
+ }
+@@ -230,6 +236,11 @@
+ mFt2 = do_GetService(NS_FREETYPE2_CONTRACTID, &rv);
+ NS_ASSERTION(NS_SUCCEEDED(rv), "failed to find FreeType routines");
+
++ if (mFt2) {
++ rv = mFt2->GetLibrary(&mFreeTypeLibrary);
++ NS_ASSERTION(NS_SUCCEEDED(rv), "failed to find FreeType library");
++ }
++
+ FREETYPE_FONT_PRINTF(("anti_alias=%d, embedded_bitmap=%d, "
+ "AutoHinted=%d, gFreeType2Unhinted = %d, "
+ "size=%dpx, \"%s\"",
+@@ -288,8 +299,6 @@
+ PRInt32* aDescent,
+ PRInt32* aWidth)
+ {
+- nsresult rv;
+-
+ *aLeftBearing = 0;
+ *aRightBearing = 0;
+ *aAscent = 0;
+@@ -312,11 +321,6 @@
+ if (!face)
+ return NS_ERROR_FAILURE;
+
+- FTC_Image_Cache icache;
+- mFt2->GetImageCache(&icache);
+- if (!icache)
+- return NS_ERROR_FAILURE;
+-
+ // get the text size
+ PRUint32 i, extraSurrogateLength;
+ for (i=0; i<aLength; i+=1+extraSurrogateLength) {
+@@ -337,16 +341,17 @@
+ }
+ mFt2->GetCharIndex(face, code_point, &glyph_index);
+
+- //NS_ASSERTION(glyph_index,"failed to get glyph");
+- if (glyph_index) {
+- rv = mFt2->ImageCacheLookup(icache, &mImageDesc, glyph_index, &glyph);
+- NS_ASSERTION(NS_SUCCEEDED(rv),"error loading glyph");
+- }
+- if ((glyph_index) && (NS_SUCCEEDED(rv))) {
++ // XXX : we need some caching here
++ if (glyph_index &&
++ NS_SUCCEEDED(mFt2->LoadGlyph(face, glyph_index, mLoadFlag)) &&
++// NS_SUCCEEDED(mFt2->LoadGlyph(face, glyph_index, FT_LOAD_DEFAULT)) &&
++ NS_SUCCEEDED(mFt2->GetGlyph(face->glyph, &glyph))) {
+ mFt2->GlyphGetCBox(glyph, ft_glyph_bbox_pixels, &glyph_bbox);
+ advance = FT_16_16_TO_REG(glyph->advance.x);
++ mFt2->DoneGlyph(glyph);
+ }
+ else {
++ NS_ERROR("failed to get or load glyph");
+ // allocate space to draw an empty box in
+ GetFallbackGlyphMetrics(&glyph_bbox, face);
+ advance = glyph_bbox.xMax + 1;
+@@ -401,11 +406,6 @@
+ if (!face)
+ return 0;
+
+- FTC_Image_Cache icache;
+- mFt2->GetImageCache(&icache);
+- if (!icache)
+- return 0;
+-
+ PRUint32 i, extraSurrogateLength;
+ for (i=0; i<aLength; i+=1+extraSurrogateLength) {
+ extraSurrogateLength=0;
+@@ -418,15 +418,18 @@
+ // skip aString[i+1], it is already used as low surrogate
+ extraSurrogateLength = 1;
+ }
++
++ // XXX : we need some caching here
+ mFt2->GetCharIndex((FT_Face)face, code_point, &glyph_index);
+- nsresult rv;
+- rv = mFt2->ImageCacheLookup(icache, &mImageDesc, glyph_index, &glyph);
+- NS_ASSERTION(NS_SUCCEEDED(rv),"error loading glyph");
+- if (NS_FAILED(rv)) {
++ if (NS_FAILED(mFt2->LoadGlyph(face, glyph_index, mLoadFlag)) ||
++// if (NS_FAILED(mFt2->LoadGlyph(face, glyph_index, FT_LOAD_DEFAULT)) ||
++ NS_FAILED(mFt2->GetGlyph(face->glyph, &glyph))) {
++ NS_ERROR("error loading glyph");
+ origin_x += face->size->metrics.x_ppem/2 + 2;
+ continue;
+ }
+ origin_x += FT_16_16_TO_REG(glyph->advance.x);
++ mFt2->DoneGlyph(glyph);
+ }
+
+ return origin_x;
+@@ -723,11 +726,6 @@
+ if (y%4==0) (*blendPixelFunc)(sub_image, y, ascent-1, black, 255/2);
+ #endif
+
+- FTC_Image_Cache icache;
+- mFt2->GetImageCache(&icache);
+- if (!icache)
+- return 0;
+-
+ //
+ // Get aa glyphs and blend with background
+ //
+@@ -736,7 +734,6 @@
+ for (i=0; i<aLength; i+=1+extraSurrogateLength) {
+ FT_UInt glyph_index;
+ FT_Glyph glyph;
+- nsresult rv;
+ FT_BBox glyph_bbox;
+ FT_ULong code_point = aString[i];
+ extraSurrogateLength = 0;
+@@ -750,11 +747,12 @@
+ extraSurrogateLength = 1;
+ }
+
++ // XXX : we need some caching here
+ mFt2->GetCharIndex(face, code_point, &glyph_index);
+- if (glyph_index) {
+- rv = mFt2->ImageCacheLookup(icache, &mImageDesc, glyph_index, &glyph);
+- }
+- if ((glyph_index) && (NS_SUCCEEDED(rv))) {
++ if (glyph_index &&
++ NS_SUCCEEDED(mFt2->LoadGlyph(face, glyph_index, mLoadFlag)) &&
++// NS_SUCCEEDED(mFt2->LoadGlyph(face, glyph_index, FT_LOAD_DEFAULT)) &&
++ NS_SUCCEEDED(mFt2->GetGlyph(face->glyph, &glyph))) {
+ mFt2->GlyphGetCBox(glyph, ft_glyph_bbox_pixels, &glyph_bbox);
+ }
+ else {
+@@ -775,13 +773,26 @@
+ continue;
+ }
+
+- FT_BitmapGlyph slot = (FT_BitmapGlyph)glyph;
++ FT_BitmapGlyph slot;
++
++ if (glyph->format != FT_GLYPH_FORMAT_BITMAP)
++ {
++ if (mFt2->GlyphToBitmap(&glyph, FT_RENDER_MODE_NORMAL, 0, 1)) {
++ NS_ERROR("failed to convert outline to bitmap ");
++ XDestroyImage(sub_image);
++ mFt2->DoneGlyph(glyph);
++ return 0;
++ }
++ }
++
++ slot = (FT_BitmapGlyph)glyph;
+ nsAntiAliasedGlyph aaglyph(glyph_bbox.xMax-glyph_bbox.xMin,
+ glyph_bbox.yMax-glyph_bbox.yMin, 0);
+ PRUint8 buf[IMAGE_BUFFER_SIZE]; // try to use the stack for data
+ if (!aaglyph.WrapFreeType(&glyph_bbox, slot, buf, IMAGE_BUFFER_SIZE)) {
+ NS_ERROR("failed to wrap freetype image");
+ XDestroyImage(sub_image);
++ mFt2->DoneGlyph(glyph);
+ return 0;
+ }
+
+@@ -815,6 +826,7 @@
+ x_pos + aaglyph.GetLBearing(), ascent-glyph_bbox.yMax);
+
+ x_pos += aaglyph.GetAdvance();
++ mFt2->DoneGlyph(glyph);
+ }
+
+ //
+--- gfx/src/x11shared/nsFontFreeType.h.agriffis 2003-04-22 12:25:13.000000000 -0400
++++ gfx/src/x11shared/nsFontFreeType.h 2004-11-15 13:29:05.125342648 -0500
+@@ -110,8 +110,10 @@
+ XImage *GetXImage(PRUint32 width, PRUint32 height);
+ nsITrueTypeFontCatalogEntry *mFaceID;
+ PRUint16 mPixelSize;
+- FTC_Image_Desc mImageDesc;
+ nsCOMPtr<nsIFreeType2> mFt2;
++ FT_Face mFace;
++ FT_Int32 mLoadFlag;
++ FT_Library mFreeTypeLibrary;
+ };
+
+ void WeightTableInitCorrection(PRUint8*, PRUint8, double);
+--- gfx/src/freetype/nsFreeType.cpp.agriffis 2004-02-07 10:22:30.000000000 -0500
++++ gfx/src/freetype/nsFreeType.cpp 2004-11-15 13:29:05.121343256 -0500
+@@ -109,12 +109,8 @@
+ {"FT_Load_Glyph", NS_FT2_OFFSET(nsFT_Load_Glyph), PR_TRUE},
+ {"FT_New_Face", NS_FT2_OFFSET(nsFT_New_Face), PR_TRUE},
+ {"FT_Outline_Decompose", NS_FT2_OFFSET(nsFT_Outline_Decompose), PR_TRUE},
++ {"FT_Set_Pixel_Sizes", NS_FT2_OFFSET(nsFT_Set_Pixel_Sizes), PR_TRUE},
+ {"FT_Set_Charmap", NS_FT2_OFFSET(nsFT_Set_Charmap), PR_TRUE},
+- {"FTC_Image_Cache_Lookup", NS_FT2_OFFSET(nsFTC_Image_Cache_Lookup), PR_TRUE},
+- {"FTC_Manager_Lookup_Size", NS_FT2_OFFSET(nsFTC_Manager_Lookup_Size), PR_TRUE},
+- {"FTC_Manager_Done", NS_FT2_OFFSET(nsFTC_Manager_Done), PR_TRUE},
+- {"FTC_Manager_New", NS_FT2_OFFSET(nsFTC_Manager_New), PR_TRUE},
+- {"FTC_Image_Cache_New", NS_FT2_OFFSET(nsFTC_Image_Cache_New), PR_TRUE},
+ // #ifdef MOZ_SVG
+ {"FT_Glyph_Transform", NS_FT2_OFFSET(nsFT_Glyph_Transform), PR_TRUE},
+ {"FT_Get_Kerning", NS_FT2_OFFSET(nsFT_Get_Kerning), PR_TRUE},
+@@ -274,59 +270,21 @@
+ }
+
+ NS_IMETHODIMP
+-nsFreeType2::SetCharmap(FT_Face face, FT_CharMap charmap)
+-{
+- // call the FreeType2 function via the function pointer
+- FT_Error error = nsFT_Set_Charmap(face, charmap);
+- return error ? NS_ERROR_FAILURE : NS_OK;
+-}
+-
+-NS_IMETHODIMP
+-nsFreeType2::ImageCacheLookup(FTC_Image_Cache cache, FTC_Image_Desc *desc,
+- FT_UInt glyphID, FT_Glyph *glyph)
+-{
+- // call the FreeType2 function via the function pointer
+- FT_Error error = nsFTC_Image_Cache_Lookup(cache, desc, glyphID, glyph);
+- return error ? NS_ERROR_FAILURE : NS_OK;
+-}
+-
+-NS_IMETHODIMP
+-nsFreeType2::ManagerLookupSize(FTC_Manager manager, FTC_Font font,
+- FT_Face *face, FT_Size *size)
++nsFreeType2::SetPixelSizes(FT_Face face, FT_UInt width, FT_UInt height)
+ {
+ // call the FreeType2 function via the function pointer
+- FT_Error error = nsFTC_Manager_Lookup_Size(manager, font, face, size);
++ FT_Error error = nsFT_Set_Pixel_Sizes(face, width, height);
+ return error ? NS_ERROR_FAILURE : NS_OK;
+ }
+-
+-NS_IMETHODIMP
+-nsFreeType2::ManagerDone(FTC_Manager manager)
+-{
+- // call the FreeType2 function via the function pointer
+- nsFTC_Manager_Done(manager);
+- return NS_OK;
+-}
+-
++
+ NS_IMETHODIMP
+-nsFreeType2::ManagerNew(FT_Library library, FT_UInt max_faces,
+- FT_UInt max_sizes, FT_ULong max_bytes,
+- FTC_Face_Requester requester, FT_Pointer req_data,
+- FTC_Manager *manager)
++nsFreeType2::SetCharmap(FT_Face face, FT_CharMap charmap)
+ {
+ // call the FreeType2 function via the function pointer
+- FT_Error error = nsFTC_Manager_New(library, max_faces, max_sizes, max_bytes,
+- requester, req_data, manager);
++ FT_Error error = nsFT_Set_Charmap(face, charmap);
+ return error ? NS_ERROR_FAILURE : NS_OK;
+ }
+
+-NS_IMETHODIMP
+-nsFreeType2::ImageCacheNew(FTC_Manager manager, FTC_Image_Cache *cache)
+-{
+- // call the FreeType2 function via the function pointer
+- FT_Error error = nsFTC_Image_Cache_New(manager, cache);
+- return error ? NS_ERROR_FAILURE : NS_OK;
+-}
+-
+ // #ifdef MOZ_SVG
+ NS_IMETHODIMP
+ nsFreeType2::GlyphTransform(FT_Glyph glyph, FT_Matrix * matrix, FT_Vector * delta)
+@@ -389,20 +347,6 @@
+ }
+
+ NS_IMETHODIMP
+-nsFreeType2::GetImageCache(FTC_Image_Cache *aCache)
+-{
+- *aCache = mImageCache;
+- return NS_OK;
+-}
+-
+-NS_IMETHODIMP
+-nsFreeType2::GetFTCacheManager(FTC_Manager *aManager)
+-{
+- *aManager = mFTCacheManager;
+- return NS_OK;
+-}
+-
+-NS_IMETHODIMP
+ nsFreeType2::GetLibrary(FT_Library *aLibrary)
+ {
+ *aLibrary = mFreeTypeLibrary;
+@@ -425,8 +369,6 @@
+ {
+ mSharedLib = nsnull;
+ mFreeTypeLibrary = nsnull;
+- mFTCacheManager = nsnull;
+- mImageCache = nsnull;
+ }
+
+ // I would like to make this a static member function but the compilier
+@@ -456,12 +398,6 @@
+ delete gFreeTypeFaces;
+ gFreeTypeFaces = nsnull;
+ }
+- // mImageCache released by cache manager
+- if (mFTCacheManager) {
+- // use "this->" to make sure it is obivious we are calling the member func
+- this->ManagerDone(mFTCacheManager);
+- mFTCacheManager = nsnull;
+- }
+ if (mFreeTypeLibrary) {
+ // use "this->" to make sure it is obivious we are calling the member func
+ this->DoneFreeType(mFreeTypeLibrary);
+@@ -658,17 +594,6 @@
+ mFreeTypeLibrary = nsnull;
+ goto cleanup_and_return;
+ }
+- // use "this->" to make sure it is obivious we are calling the member func
+- rv = this->ManagerNew(mFreeTypeLibrary, 0, 0, 0, nsFreeTypeFaceRequester,
+- this, &mFTCacheManager);
+- NS_ASSERTION(NS_SUCCEEDED(rv), "failed to create FreeType Cache manager");
+- if (NS_FAILED(rv))
+- goto cleanup_and_return;
+- // use "this->" to make sure it is obivious we are calling the member func
+- rv = this->ImageCacheNew(mFTCacheManager, &mImageCache);
+- NS_ASSERTION(NS_SUCCEEDED(rv), "failed to create FreeType image cache");
+- if (NS_FAILED(rv))
+- goto cleanup_and_return;
+ return PR_TRUE;
+
+ cleanup_and_return:
+--- gfx/src/freetype/nsFreeType.h.agriffis 2004-04-16 17:31:42.000000000 -0400
++++ gfx/src/freetype/nsFreeType.h 2004-11-15 13:29:05.122343104 -0500
+@@ -102,15 +102,8 @@
+ typedef FT_Error (*FT_Outline_Decompose_t)
+ (FT_Outline*, const FT_Outline_Funcs*, void*);
+ typedef FT_Error (*FT_New_Face_t)(FT_Library, const char*, FT_Long, FT_Face*);
++typedef FT_Error (*FT_Set_Pixel_Sizes_t)(FT_Face face, FT_UInt, FT_UInt);
+ typedef FT_Error (*FT_Set_Charmap_t)(FT_Face face, FT_CharMap charmap);
+-typedef FT_Error (*FTC_Image_Cache_Lookup_t)
+- (FTC_Image_Cache, FTC_Image_Desc*, FT_UInt, FT_Glyph*);
+-typedef FT_Error (*FTC_Manager_Lookup_Size_t)
+- (FTC_Manager, FTC_Font, FT_Face*, FT_Size*);
+-typedef FT_Error (*FTC_Manager_Done_t)(FTC_Manager);
+-typedef FT_Error (*FTC_Manager_New_t)(FT_Library, FT_UInt, FT_UInt, FT_ULong,
+- FTC_Face_Requester, FT_Pointer, FTC_Manager*);
+-typedef FT_Error (*FTC_Image_Cache_New_t)(FTC_Manager, FTC_Image_Cache*);
+ // #ifdef MOZ_SVG
+ typedef FT_Error (*FT_Glyph_Transform_t)(FT_Glyph, FT_Matrix*, FT_Vector*);
+ typedef FT_Error (*FT_Get_Kerning_t)
+@@ -163,12 +156,8 @@
+ FT_Load_Glyph_t nsFT_Load_Glyph;
+ FT_New_Face_t nsFT_New_Face;
+ FT_Outline_Decompose_t nsFT_Outline_Decompose;
++ FT_Set_Pixel_Sizes_t nsFT_Set_Pixel_Sizes;
+ FT_Set_Charmap_t nsFT_Set_Charmap;
+- FTC_Image_Cache_Lookup_t nsFTC_Image_Cache_Lookup;
+- FTC_Manager_Lookup_Size_t nsFTC_Manager_Lookup_Size;
+- FTC_Manager_Done_t nsFTC_Manager_Done;
+- FTC_Manager_New_t nsFTC_Manager_New;
+- FTC_Image_Cache_New_t nsFTC_Image_Cache_New;
+ // #ifdef MOZ_SVG
+ FT_Glyph_Transform_t nsFT_Glyph_Transform;
+ FT_Get_Kerning_t nsFT_Get_Kerning;
+@@ -181,9 +170,9 @@
+ // this array needs to be big enough to hold all the function pointers
+ // plus one extra for the null at the end
+ // #ifdef MOZ_SVG
+- static FtFuncList FtFuncs[24];
++ static FtFuncList FtFuncs[20];
+ // #else
+-// static FtFuncList FtFuncs[20];
++// static FtFuncList FtFuncs[17];
+ // #endif
+
+ protected:
+@@ -212,8 +201,6 @@
+
+ PRLibrary *mSharedLib;
+ FT_Library mFreeTypeLibrary;
+- FTC_Manager mFTCacheManager;
+- FTC_Image_Cache mImageCache;
+
+ static nsHashtable *sFontFamilies;
+ static nsHashtable *sRange1CharSetNames;
diff --git a/net-www/mozilla-firefox/mozilla-firefox-1.0-r3.ebuild b/net-www/mozilla-firefox/mozilla-firefox-1.0-r3.ebuild
new file mode 100644
index 000000000000..34c305c70036
--- /dev/null
+++ b/net-www/mozilla-firefox/mozilla-firefox-1.0-r3.ebuild
@@ -0,0 +1,188 @@
+# Copyright 1999-2004 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Header: /var/cvsroot/gentoo-x86/net-www/mozilla-firefox/mozilla-firefox-1.0-r3.ebuild,v 1.1 2004/11/15 20:34:40 agriffis Exp $
+
+inherit makeedit flag-o-matic gcc nsplugins eutils mozconfig mozilla-launcher
+
+S=${WORKDIR}/mozilla
+
+DESCRIPTION="The Mozilla Firefox Web Browser"
+HOMEPAGE="http://www.mozilla.org/projects/firefox/"
+MY_PV=${PV/_rc/rc}
+SRC_URI="http://ftp.mozilla.org/pub/mozilla.org/firefox/releases/${MY_PV}/source/firefox-${MY_PV}-source.tar.bz2"
+
+LICENSE="MPL-1.1 NPL-1.1"
+SLOT="0"
+KEYWORDS="~alpha ~amd64 ~arm ~ia64 ~ppc ~sparc ~x86"
+IUSE="java gtk2 ipv6 moznoxft truetype xinerama"
+
+RDEPEND="virtual/x11
+ !moznoxft? ( virtual/xft )
+ >=sys-libs/zlib-1.1.4
+ >=media-libs/jpeg-6b
+ >=media-libs/libmng-1.0.0
+ >=media-libs/libpng-1.2.1
+ >=sys-apps/portage-2.0.36
+ dev-libs/expat
+ app-arch/zip
+ app-arch/unzip
+ gtk2? ( >=x11-libs/gtk+-2.1.1 >=dev-libs/libIDL-0.8.0 )
+ !gtk2? ( =x11-libs/gtk+-1.2* =gnome-base/orbit-0* )
+ java? ( virtual/jre )
+ >=net-www/mozilla-launcher-1.20"
+
+DEPEND="${RDEPEND}
+ virtual/libc
+ dev-util/pkgconfig
+ java? ( >=dev-java/java-config-0.2.0 )"
+
+# Needed by src_compile() and src_install().
+# Would do in pkg_setup but that loses the export attribute, they
+# become pure shell variables.
+export MOZ_PHOENIX=1
+
+src_unpack() {
+ unpack firefox-${MY_PV}-source.tar.bz2 || die "unpack failed"
+ cd ${S} || die "cd failed"
+
+ # alpha stubs patch from lfs project.
+ # <taviso@gentoo.org> (26 Jun 2003)
+ use alpha && epatch ${FILESDIR}/mozilla-1.3-alpha-stubs.patch
+
+ # patch out ft caching code since the API changed between releases of
+ # freetype; this enables freetype-2.1.8+ compat.
+ # https://bugzilla.mozilla.org/show_bug.cgi?id=234035#c65
+ epatch ${FILESDIR}/mozilla-firefox-1.0-4ft2.patch
+}
+
+src_compile() {
+ ####################################
+ #
+ # mozconfig, CFLAGS and CXXFLAGS setup
+ #
+ ####################################
+
+ mozconfig_init
+
+ # Bug 60668: Galeon doesn't build without oji enabled, so enable it
+ # regardless of java setting.
+ mozconfig_annotate '' --enable-oji --enable-mathml
+
+ # Other ff-specific settings
+ mozconfig_use_enable mozdevelop jsd
+ mozconfig_use_enable mozdevelop xpctools
+ mozconfig_use_extension mozdevelop venkman
+ mozconfig_use_enable gnome gnomevfs
+ mozconfig_use_extension gnome gnomevfs
+ mozconfig_annotate '' --with-default-mozilla-five-home=/usr/lib/MozillaFirefox
+
+ # Finalize and report settings
+ mozconfig_final
+
+ # hardened GCC uses -fstack-protector-all by default, and this breaks
+ # firefox.
+ has_hardened && append-flags -fno-stack-protector-all
+ replace-flags -fstack-protector-all -fstack-protector
+
+ ####################################
+ #
+ # Configure and build Firefox
+ #
+ ####################################
+
+ # ./configure picks up the mozconfig stuff
+ econf
+
+ # This removes extraneous CFLAGS from the Makefiles to reduce RAM
+ # requirements while compiling
+ edit_makefiles
+
+ emake MOZ_PHOENIX=1 || die
+}
+
+src_install() {
+ # Plugin path creation
+ PLUGIN_DIR="/usr/lib/nsbrowser/plugins"
+ dodir ${PLUGIN_DIR}
+
+ dodir /usr/lib
+ dodir /usr/lib/MozillaFirefox
+ cp -RL --no-preserve=links ${S}/dist/bin/* ${D}/usr/lib/MozillaFirefox
+
+ #fix permissions
+ chown -R root:root ${D}/usr/lib/MozillaFirefox
+
+ # Plugin path setup (rescuing the existent plugins)
+ src_mv_plugins /usr/lib/MozillaFirefox/plugins
+
+ dodir /usr/bin
+ dosym /usr/libexec/mozilla-launcher /usr/bin/firefox
+ insinto /etc/env.d
+ doins ${FILESDIR}/10MozillaFirefox
+
+ # Fix icons to look the same everywhere
+ insinto /usr/lib/MozillaFirefox/icons
+ doins ${S}/build/package/rpm/SOURCES/mozicon16.xpm
+ doins ${S}/build/package/rpm/SOURCES/mozicon50.xpm
+
+ # Install icon and .desktop for menu entry
+ insinto /usr/share/pixmaps
+ doins ${FILESDIR}/icon/firefox-icon.png
+ # Fix bug 54179: Install .desktop file into /usr/share/applications
+ # instead of /usr/share/gnome/apps/Internet (18 Jun 2004 agriffis)
+ insinto /usr/share/applications
+ doins ${FILESDIR}/icon/mozillafirefox.desktop
+
+ # Normally firefox-0.9 must be run as root once before it can be
+ # run as a normal user. Drop in some initialized files to avoid
+ # this.
+ einfo "Extracting firefox-${PV} initialization files"
+ tar xjpf ${FILESDIR}/firefox-0.9-init.tar.bz2 -C ${D}/usr/lib/MozillaFirefox
+}
+
+pkg_preinst() {
+ export MOZILLA_FIVE_HOME=${ROOT}/usr/lib/MozillaFirefox
+
+ # Remove the old plugins dir
+ pkg_mv_plugins /usr/lib/MozillaFirefox/plugins
+
+ # Remove entire installed instance to prevent all kinds of
+ # problems... see bug 44772 for example
+ rm -rf "${MOZILLA_FIVE_HOME}"
+}
+
+pkg_postinst() {
+ export MOZILLA_FIVE_HOME="${ROOT}/usr/lib/MozillaFirefox"
+
+ # Needed to update the run time bindings for REGXPCOM
+ # (do not remove next line!)
+ env-update
+
+ # Register Components and Chrome
+ #
+ # Bug 67031: Set HOME=~root in case this is being emerged via sudo.
+ # Otherwise the following commands will create ~/.mozilla owned by root
+ # and 700 perms, which makes subsequent execution of firefox by user
+ # impossible.
+ einfo "Registering Components and Chrome..."
+ HOME=~root LD_LIBRARY_PATH=/usr/lib/MozillaFirefox ${MOZILLA_FIVE_HOME}/regxpcom
+ HOME=~root LD_LIBRARY_PATH=/usr/lib/MozillaFirefox ${MOZILLA_FIVE_HOME}/regchrome
+
+ # Fix permissions of component registry
+ chmod 0644 ${MOZILLA_FIVE_HOME}/components/compreg.dat
+
+ # Fix directory permissions
+ find ${MOZILLA_FIVE_HOME}/ -type d -perm 0700 -exec chmod 0755 {} \; || :
+
+ # Fix permissions on chrome files
+ find ${MOZILLA_FIVE_HOME}/chrome/ -name '*.rdf' -exec chmod 0644 {} \; || :
+
+ # This should be called in the postinst and postrm of all the
+ # mozilla, mozilla-bin, firefox, firefox-bin, thunderbird and
+ # thunderbird-bin ebuilds.
+ update_mozilla_launcher_symlinks
+}
+
+pkg_postrm() {
+ update_mozilla_launcher_symlinks
+}