summaryrefslogtreecommitdiff
path: root/mail-client/thunderbird
diff options
context:
space:
mode:
authorV3n3RiX <venerix@koprulu.sector>2024-02-21 17:40:23 +0000
committerV3n3RiX <venerix@koprulu.sector>2024-02-21 17:40:23 +0000
commitf2d1966a40070fb5ba3279db49b8435c7c143802 (patch)
treec22ee074b9798b0ad569fb20e1658ddb9de8aee3 /mail-client/thunderbird
parenteb3b53b5fd521edc0e4a7d611e76898732a63a81 (diff)
gentoo auto-resync : 21:02:2024 - 17:40:23
Diffstat (limited to 'mail-client/thunderbird')
-rw-r--r--mail-client/thunderbird/Manifest67
-rw-r--r--mail-client/thunderbird/thunderbird-115.8.0.ebuild1353
2 files changed, 1420 insertions, 0 deletions
diff --git a/mail-client/thunderbird/Manifest b/mail-client/thunderbird/Manifest
index 823cdbb65676..a449be6b7f27 100644
--- a/mail-client/thunderbird/Manifest
+++ b/mail-client/thunderbird/Manifest
@@ -5,6 +5,7 @@ AUX gentoo-hwaccel-prefs.js 162 BLAKE2B c5f2dfb727081e2d538c262f12c0cfdda31cbda5
AUX icon/thunderbird-r2.desktop 882 BLAKE2B eb9c2e381b67319d9cd53f26e9b406f55de86b716b28a3df6470594a612e07acda4c7dcdb48b6d55930972592f7f01afbbf14f09ccc4b20265d3c18554a01a2c SHA512 689c9fa5c37a1e6ee80a3dfaebec2a185d91508537c35ce2fb35d13d89b16ae0cf3c640c3115a52c0e4b7a7624aee6a8f8c52679a0073c94dea25cc779ce624b
AUX thunderbird-r1.sh 2896 BLAKE2B 140047417b24e959fe6388c4913457f8e3e786158b7394abf7442b0d2e83de21238e58983845a23b855e1aab60c9289e1a12af430eac9a8b2d9929da97de2852 SHA512 f9b989152a8a3ac274033722c77ec19374085654ad6c85ea4db6f8af8f4b2066d6d9f82b610be2db341c8ac867547f54f806ca6571258ed98dd9e2527d21b357
DIST firefox-115esr-patches-08.tar.xz 15912 BLAKE2B 3f94deb17920672ad2184e813bd38e390ecaa50bfc6e00973db717bc56a5adb4f096224cc366da525db25aaa3d198d57716bcb765ddc906783532864e23dd8d4 SHA512 4474fbed14b2c4fac03d82f4b37849a69dbdd61fc15f01cefa373eb8a64a692f5a584247acdf7c349ab6965225c3cd47be3fc4523f93db5299680e2a22e94d94
+DIST firefox-115esr-patches-09.tar.xz 16660 BLAKE2B 1dcdf62f35013b82dd70bf00c0505394b9277affcd1b1cbde92421778f4fcc146f536a546c2db8d6a70f92d40e4b1c96927fedec54383e6bb80bd9806d9b4461 SHA512 e003d0a2a5304dcdd0851b57ceb11993333326c8221d5d99555cd0c64090d5eda1bdb2a2a52e605f6094a3214ffa2238e43d57ff64eb7d424ff54b8125c16f5c
DIST thunderbird-115.7.0-af.xpi 549700 BLAKE2B 3bc2ea371ffa3666ef46e34220e9352b84b317d7c2fa7145cb129b60d9b0f5e110f88953512a773c94accfc78e9eaedf11c0200c2e2aee7f3196f62a22766035 SHA512 74176f279b90e65115244334f20f7a387d8087706d9dd20c550cdf2be9b87485c53a2baab7383a7623c2a46c951270fea5ad7bec0d0725985ead3c70a7eb47dc
DIST thunderbird-115.7.0-ar.xpi 666361 BLAKE2B e44585a1fdebe17dba69ef883310855427eaa656c82de9a53e090dac67f27cd1e0e37f5d22a1884e458a18584b4e589809d0f117855d1096f9b4fa74cd7a99a7 SHA512 a944a0e4b9eb14a2eb1b85987e801fb553707c33d4dcfd97a2c9306563c78a003070bfb9f00c09f4e972a7682a4dfbefd8f6b3fc580b8c0aee06bbf337e6e806
DIST thunderbird-115.7.0-ast.xpi 568311 BLAKE2B 9156bba9c66d142aff5541db33d8ce761c50e4a3e92e6becb3f3cc1adabdd930053f77c031b40d160f41147489942543adc6ff4ffc1f80ff446220b4a8cd418c SHA512 ddd37a559414c29c14919491aca2483a5fdf5f2e0ed6ab7e7392ce2d3d23c9367bdff75b822727fe791e7db5b6d9b4facb457bf7d9407990f1641b92c09decfa
@@ -70,5 +71,71 @@ DIST thunderbird-115.7.0-vi.xpi 764154 BLAKE2B 23fbc672b39ac6f6e30ea06b131c1d22e
DIST thunderbird-115.7.0-zh-CN.xpi 761572 BLAKE2B 8d099904ac891386f5936b8151a38384be9ad5c816b5adc01a689e9b017a578f2af22f59b7f74d3eee8fa244c6e56ee85b54b22dd5c6af0777b8fe8f585b0216 SHA512 f4288c6b5429b71e8bf6e6aae3c096911302c9ab3554314eaaac776fc8779cc032d3e3523c60bf2f845c48f1b87468a8700ab92ee2c3bf663b23adf427a81d67
DIST thunderbird-115.7.0-zh-TW.xpi 766124 BLAKE2B d1c08e311dec02e7f024a25b1adca6987d4714679861a1e0a8dd028336b858fe42e55368894110560f6e08354b69b0b0f17d6e1de6ab97a07b6c19dc8c8f9498 SHA512 0000b9141ee84900a2a299e7adbbb7df576fd20981f488d8595ca7e8a042132ae15221db66beac710159da07a9feb82c304529a4b9ec40a1f3bc2d0fd4130192
DIST thunderbird-115.7.0.source.tar.xz 532459912 BLAKE2B 2d936b07c3c78963d9a68c2be4e18c06b27e6f4f61a60bd2d7f49e2ca39e5c6c5f6ff2c0d9fed90cf88c5517ea0a52a711c78164c4ab568589d57962a9aca177 SHA512 de9edb81cf5da494101bf927a5b963ccdec0cc9bff87ebd72d896c6e25102c1113b326f67302a81abd237048aa1e6150c4a97fe4b1892bc80030cbab9099e2d8
+DIST thunderbird-115.8.0-af.xpi 549703 BLAKE2B c39c6e984888f0b9b5cc19253ca2ed3c7ea62a63252fcdb95dc637e781e5a21a1fa0d78fc0a3f756144732b38ae0707b2650a1b31397157448a1e65fbfd8d3b7 SHA512 31399a14da85308c7fbbfa9d3af26612fde0a9e186250d1d78b27717c1b6637cc4d61aa5f24df3a6cb54bbd643350413cced0079c54bfd2030c0dbb1e4d445a1
+DIST thunderbird-115.8.0-ar.xpi 666364 BLAKE2B a26384184f42e2560a1e26abfbb94a8d583d5f1a2877b93478744adee1c2f4be17d20f5928179c031c9a190aed2ea6ecb546cccfa404b1294e9132a193b547bd SHA512 84a5d5e25ebfa14d1db6a5425ae7023f85b4dbd7a95fd7d3b85435dba827efa257aea81b747cdea365ce1c29f9d3d1c574d738f76527d6a3e93db96a4de22801
+DIST thunderbird-115.8.0-ast.xpi 568313 BLAKE2B f5fc09afe7f2c24abd7bf2a3c2b69b18134f84db9edfa921b025d5ffdb3538ab88adf63b1e653066900dfbab8aed48e0bbb659f3cf5ffb9d2d1f996c2d4dfad8 SHA512 bfba963b373e284625730fb334daa48c7159a8a79c471f4122d5db0538777272d1cbfbf511482403d2462ed9248cb7ecf0c4fd7ed7946be5daa463fd05298e98
+DIST thunderbird-115.8.0-be.xpi 717165 BLAKE2B 1e76f7dc330484e326d1cfce6868dde79b8c71d3f8c18cbc087ab8ad55e18a95421983a91da2902be01ff61fe3a5e49331f57b5d422124f1470f07b54db2d5f8 SHA512 d97a150ee5940ecf1d391fe5fc5237c5931a64ae1ad541ab13a2a52c0db4c8bdfe5b64373324b731fe03e55569a07cc30f04f703aea4cf5ab656625e87f43f8f
+DIST thunderbird-115.8.0-bg.xpi 778864 BLAKE2B 3b52ed49a997be5c5fb571eaad8ae2b9a8b9a8e776151d28b6a19e4554e7374cc3014e83afbe7ec591fcc6814069d0d39ed0d67f1869b50f2dc13cfe23b3ff47 SHA512 228a18bb3da8228609d284db0bac62da762bb9db26430377235da6802450954c144d634fa6c96d9cd0da3296597528806ed6320c50c2a336cd7c4033e79f6264
+DIST thunderbird-115.8.0-br.xpi 642274 BLAKE2B f22760af6a74e4a777dc68f32b18613cb87024f6d78f7280dd9d9194815ba6370251600e019608df6a5abeddcae86b42cc975db68cfb93262032ec6744329b17 SHA512 f3994b11ec547fab11ce0c2eb68128e82e9a1e3a34897ad46cd34129aba535cf8c58358962a4d8ba1c7a2785976335af3e7f0ccda0066a1f428253f73e512fd4
+DIST thunderbird-115.8.0-ca.xpi 685489 BLAKE2B 8e34f7f8ab4f40382588adc81b7fbbac36cf40dee4531da9a47b87b6c4f26b9d7411b18ddc57d8d9a381b5dcec5f8731f9092171d9bcdd00b06723a1097df41d SHA512 165590c8c41443df513870cfde93e8486a3b90e3254a8703c82a07b18c8b4f6bd328d58d06e6e1fd4f1d8797cf4e023f7ba3ee4be73be9596c23efc996a3a7a2
+DIST thunderbird-115.8.0-cak.xpi 667770 BLAKE2B 4b0572c7dd2918947c89674736c387deb98021152122c68c6e4708ea6d3295f56ac9b8dafd2d7bd919a91ca7c5c2385db997f0dd104de1ef61bdc2cb484ce144 SHA512 8429ab492dfeabe8b021dbb74619a664168a7afe55b290ef1420a0e0e9be9fadd8a6acdda03e3f20721d82e5e9b052d4e28dfaf8721087a9edbf56a321b24299
+DIST thunderbird-115.8.0-cs.xpi 759535 BLAKE2B 66e591a6d0f1e5e8bafcda81115b564ef5c5a6330dc0a5f9d185c10e872d4a4bd8d911a7bb26138a3b9568a7075563fbc737d7ae95aee42e7ccd3924c33b02a8 SHA512 79c7c22216cf30695f1504c85157eece54a6c142832ad77e84b1ebaf589a8932d61d351d294374fbdd3d965182a53cd4a3b1140220ddd3e6bbb008be2ecafd0d
+DIST thunderbird-115.8.0-cy.xpi 725349 BLAKE2B 860c704bdc057d25aa5feedea3e1bce35e3cd10703f01dbc91fcd397f7f78389a3ce0a5a89fa79571bb1bd230c1dccc31db06522d0d550a80e5829ea93112733 SHA512 fb888c779c8675f4ba17feeee98b29f2ce4d27a6475a0529be1bcec5621539d755d47ba3b37c369d049735895419574244b7ae10bf651922f7930de853b80561
+DIST thunderbird-115.8.0-da.xpi 710497 BLAKE2B 05a578f84eaf4a7cac058227f86c453036666d108e4a72d6e77c5253baeccc393cb452f792c4c02632c296fd46c04f78e32354920f72bee363a2c12a7146198c SHA512 a25899f22c88cf3c176e3c88ff380202010690aa83409d1f82bde94ea0cc91b0993f7aa4847b10d7765631a5ce233e1ca07fca90c08af54b0406d0129648138b
+DIST thunderbird-115.8.0-de.xpi 741447 BLAKE2B 5e84b5c3b57f73d32b460baeb647c6dd90d3b66005d88c77de8ddc69d9c22fe0fe60dbd18101b2068af05e1d793f0635398124eb5a973605c3bb08b4b2fae087 SHA512 057009e7df508cb64c035a5c7f40a2ba6885d2ade51763adfbaa6811413aae91787d3b80faff63b6fbda7c75a68213954fe2eba4f0505c88ca1ffee981b90f11
+DIST thunderbird-115.8.0-dsb.xpi 759682 BLAKE2B ca0e43ca1195e01dfc1d25047fed6bc1387e66083732fceaafa24110e6fd686f1ae36153d139e90357975f12bb4b3a9c4074bc30bdf78f85272d89bf59bf61ae SHA512 d7ac8f28b16755c260999a1894a8bb0d319432f7fad3fe9c8a079cada7d91648a2eada8281c4f0fff0012dd423bd4c3ffe9efc7725ecae9376a31cc7abfd648a
+DIST thunderbird-115.8.0-el.xpi 862802 BLAKE2B e7d2dddc77b0a9a5412d27da7d040c0d2d52c06d0e9c65798d3c5660972b6e3d6dc6fab0e6dd58c2e5d59a4b6daa69ff7f22544ef3b6d6998c34b45f49e0f191 SHA512 30b98b717d05dfcce3bc680d92e6a7dcfc26c869da7eb6ef3ec49e595f84d7df7a6c47dd44df3eaf152e68a7f6a09667588038eecace5f59d5f74a392bf78d6e
+DIST thunderbird-115.8.0-en-CA.xpi 671010 BLAKE2B e4d186ca33d40185c96e1c8a674cb2dd4fc1bdb5f85280fbe3c7c3cd384fac29e2e13f1a5149f71d09228387ba8d874f4ba97f0d07a15f3103d4b63ca458b274 SHA512 4412cc489f5dedcb6ef397e73998691ef2f44208c00f59bf764f1673d91c3e16852eeabe7d5e03ca19d22dbaafe4ecc697148944e3497a28c36d161c9d76c3e3
+DIST thunderbird-115.8.0-en-GB.xpi 681893 BLAKE2B 0327c830169edf1b9d383455e4cd8be7f7e7993b46c509b6aa7ee717163e213570f6274cbd216aef69a053a61ab3bcb7fdc05059a1cf33942e376a52de4335ee SHA512 cc2606d8e8269159f4d74a44b63787f2d9771ce7b9eb25026a075338c548fdcb6fa4ce1a5b6077d509266dfba19a7ded2c5f3ff0d73ea8dae6d7227db8fb7af6
+DIST thunderbird-115.8.0-es-AR.xpi 735671 BLAKE2B 5805d38cfbc90e89ba41c85b53d26edacb84b65178902b0038da5bf09410a3901d952a8eb606f2a6a03eafdc51b09e78102b7179737383d1fb06fd5cfc3f48e7 SHA512 8f434608927f81434cf12360aad27fa108f04987c0c59e384bd6d324562ce227b7854a6e00457db97e8f77158969f48734157ffbc76c6fe76835fb6ea7e9ec0c
+DIST thunderbird-115.8.0-es-ES.xpi 697506 BLAKE2B 5c060a45575fe19290d7e3a31fec56e8e9109649b859fa220e48aafadbd8fd20e34199952c5d85065d7f30d972e28a4f6542c0aaa20fc6da811911cac98f49ef SHA512 855db59ade8c1d796bacc84a58a0761189b2e642f7b10f7813054280c5c8607bada5d3e3f2a22e3ef8a0d3ba1efaeef898f311e97129e1e15dac62249d0ddd3f
+DIST thunderbird-115.8.0-es-MX.xpi 719673 BLAKE2B 20bebf20ce901c93f464aedc8d18a2ecba21d3c1bda3bfcc1800f1a770385fc54a14a5792537cabce9d0f7293b595eb2ae12c3b1073f2a84cf2a47549f221711 SHA512 00fc5378005c74d5b4c0c40a8ac7e5176e1e7e563388a63c0f646480f4974d24655e2023b824c7a5beb2ee9424f4172021270f61ac980cbf55d315c2e5f9ab05
+DIST thunderbird-115.8.0-et.xpi 679916 BLAKE2B 7e052a12e8acecb0ffdb199421b6f363c3d171b5559959da8449d4b99f497ce1f911044b83d89a402fa97c823508570a23ffe5232d8cc83716b2a4ac329c8784 SHA512 4e20877676e5d4401489a8bf9172056fefdb6ee4243666dc99413cb94f7edec73d2c19218013d660b4470fc9b83b4e611a3c347870ad6817949bd5c720808500
+DIST thunderbird-115.8.0-eu.xpi 708428 BLAKE2B 6dbd9d5fd00477a28aaa9d2b411ccb639e33feba92f2039f816050df95a715e59acdd73b8a9c85a36a1687b88c92804df596155a8d7d319ff344096cc9679eed SHA512 e9f2301a08f068d725236e20bc8e3c516bb8c31d427c61da504b1adce3b7f121c795c02e0b440c0d7aae7ec37f2d266fb82d848d2a87189869f8b20321cefbe2
+DIST thunderbird-115.8.0-fi.xpi 713341 BLAKE2B c804a9c4e5b6e698e2763806a4d83590f1d281f1521e8de9cc7cd709f74d9a3b851c6e704e9523008afd1be7686858d813d4fca115ede4f8e1635293d36b552b SHA512 7e4318a4eaba1cb89353dcf8b1e064e373709a743151ee7104e712bf0f463eabc727be65bec56befc89e66a543637c7b7433f44b816e8489e174835124627235
+DIST thunderbird-115.8.0-fr.xpi 746570 BLAKE2B 7bc7581b7c638a823ba6a3a32197a5aa6eb8ca5f40d8f87d0b31d5db8d56ea60bcfd3dfd6ec1b0904f9a366f4aee1546fc8330d750387786602fd4dd148a2b60 SHA512 91b69267060018cdf08394506c686b74952e192d04898253525a1c43b1e4a30d0fc4f637812dd4376810d086098d09c980baec21eab9dbd60e6acf77a7dab32e
+DIST thunderbird-115.8.0-fy-NL.xpi 729277 BLAKE2B 9acabf28f2c7c6364fe8cd4e8d18a0d3e8fdb1a14b79f86162a08e8846b3e3150a583741cf1dda9b46806b855066b22189527788434f219f3c1ee219ab5ad884 SHA512 53c17184a7bffa10c01af6c07ac7b8f610fb2dfbeba5206017da99a691be09c6e501962c0adea8f7439c87d26c3f6b442f2c166997172e124bf93de2a9205d96
+DIST thunderbird-115.8.0-ga-IE.xpi 609799 BLAKE2B 37791190ea78c4260dc4f3c79ecef2e4be67e0ba50f96f4bf08d1ff5a415c65fb52126a3bd241d4c946e22c9bfc65d86c4df8173cc96353635c0e39da9514ed5 SHA512 9418237c47dcccea496ce75d7b52d794678affb96870b0bcba7c770c24fafc4026c55b6a2dc179dc52db51a8b935d88e8614f743ca05da386bda550b72c73114
+DIST thunderbird-115.8.0-gd.xpi 712354 BLAKE2B e67d4357eee311753535b7001b28bf862e8c3961178f16035c9cfdc15a826b87009f5f7ec837b6628f4404bcd68fdc506502ef86e3f0c3d61e61afb820bdf2f9 SHA512 45cd7c362551cca06b1d6aff940406d55ba17953d1c62b9417e3682626d33e1ede84430dcb42472b7ecd7c68ba10563673b3af2c1e72bb15f4fc53f704fe7dd8
+DIST thunderbird-115.8.0-gl.xpi 719542 BLAKE2B 40c0ebf096e22fe816f96c977cc46fdb93f1992fd44ceee28c7adb0727e2d110ff60ecbc8f35c0dde6da8651202078152972870869b5b0c6a63b763857131c61 SHA512 eb9042849142c928490dd0aa16339f6771f8ecc852e64593f8ed13c8f7188c627d3aa6781fbf81db9206f0993cd7c7f6312244730a89a89b1f5d264f93241872
+DIST thunderbird-115.8.0-he.xpi 686345 BLAKE2B 3c87b06ad791aa8c1a4c6b74ed6fe21d30d8c2a634e0cd5fc891c7a8e1e42082a297538ea3e075fcf7c5ab5d21fd75b14cf9cc3a70345f80ec21ee4b4646f6a3 SHA512 44ad4374e058b8e0841272e6e7d407be22cb46c606a293f36e5f4fdd1f3261ccfeb76b8f1dec75e1a6ace23f6727cab5722d3c0d79756c69062f45cb864041dd
+DIST thunderbird-115.8.0-hr.xpi 687078 BLAKE2B 9d3149361415ba5b46574acf3be604d838c755bfcbd9e32bf5b7340b775b653ee316814b45fa4c262c05876ff4dfb6f4c317b40c336a11b2a1b64988256941f5 SHA512 3733cc42127cc7612423fa8b3cd4af137115d0cb8b7df46293ce9565788e1a090ef9477710b1fdde66c339e3820d7d5d666d2c1f1fc1c08690053754b5d684ff
+DIST thunderbird-115.8.0-hsb.xpi 756722 BLAKE2B 5f86246c688ad6690576193717a3ec95bdbf88022ec17f351c52638d78ec209c94b8e51e1cb67253910902f4ca0a99d3dbde5a9e6110bb0727ba00bbd05bb6cf SHA512 f230b4824d32a944afcf817c4b2c6de6d021d6c44dfe62be80c096de6e20c66d87bb95cf7b4fec7520c835e98085c531ec0160164b70b3972bb0d6163f50db1a
+DIST thunderbird-115.8.0-hu.xpi 758284 BLAKE2B a0a3f50d3ccb16190307d604d15504987f3e5eca38b2ae7ca1de664d23fabceae1b951b3fdbe224dafca915bee6cdf24a8de55e118d9fd50ed8ff1fc95028c34 SHA512 bcc26e2ceb539c9547fdcd7b2f874a73b3e60a4f0b75c23dc20829150ca5b998001821de2087fd7ae88e9ebcb355a9b05c8bdc6ac882ee77b8057449bf0b06e5
+DIST thunderbird-115.8.0-id.xpi 651343 BLAKE2B 8dc14e249b534f64784cdbe174f4701156ec74d2857905a78e5ae13da0726b3d267b3f9e419b152b36bab5f0d7b9b31c250d7cf94b08e7ba5dbe189afef16058 SHA512 38a8e5479d0cfeac98ca64d2627940c44a861354e643fd9e611a66e2cfec6ba6eceefa07dd4e0ade34966c828fe78f2f16c4eacba629a6d288e7f93a84454df0
+DIST thunderbird-115.8.0-is.xpi 719342 BLAKE2B 1edd577cba535e05cc4635bddfdc5f469b003327e2fef689e7e53f588da1fcb17249074e5b0f1d966356bd92363f16c2eee09ea74ed6f2e59c237712db956cee SHA512 ae1869b780c42b9c811877cb15367761bdf4d474098a0a2e47f30b0db3bade02e4415744975d10604b0a1ac897b7604c800665ca8ce19264e66f604c6c271a3b
+DIST thunderbird-115.8.0-it.xpi 668020 BLAKE2B dc9514d045b99c956d309a2147bf778603c094d290842820e82edce818f9ae69d725b9b374406a6a2e59a00ff888384f5aa8e4c0892506322f35001b2a5e5bb0 SHA512 0436ec36a016f990b1c1df4e5b48ba5629e656548cb07c774bfab90d3c1c86929265ee3521ffe68b4b7c3c6f470702d2ae9d1087cc4651c65cb89683f4960048
+DIST thunderbird-115.8.0-ja.xpi 795399 BLAKE2B 2cb457e2d401608d10126ea43739aff35b7b8998e81a14998373511f2d631487070cf981aa744f072582b667cf193ec5db96e43ce8f667a7b1e8393ca7ea5639 SHA512 e0d16d6cf997a511cea95b2cebb4228eab3c7d345522335420bc3522e735fdd831b3904a0fc15db1f88329a61f53620c21fb61aa7f86cce685f11ccff2689048
+DIST thunderbird-115.8.0-ka.xpi 783168 BLAKE2B 6c77148d0c1dfcd6524cd99d8675c2aeb888c41725e0c24df8ac588b7adde55008aff45789fe2d0b10d197aac76df550d0a455dd3719e4ce8763b2f61675c771 SHA512 7ba1883f259892449114fc5929be2d0b8bc491a00b765975e90b6bbcec6c0f0863b4009cd799798dfa2e531a10ecfba7de95727dc13a78b2db26d113576314cb
+DIST thunderbird-115.8.0-kab.xpi 711124 BLAKE2B 22b98839daf67d1b370f3250b0ff8c423323499d3403f70a93e2af883993706fd2251fc3e80d14f018b9ddf3e749f78a73e57b91c39a97e55c8f6f2f8c13c7ab SHA512 28b1ac62e33d645487ae55c1b6d7a34b46f6a4504fe5a51605a1decb047e3a4268c7a514c500a7185a7b74f8c27dbd600ed946fac10b9f2e282dc89229c40e42
+DIST thunderbird-115.8.0-kk.xpi 832553 BLAKE2B 80da8571ca3f3456f64019a9143f761364a63578fe7f7b79546e222d05ab3298f9b175c070872792cd6950303bbcff6d4f9638085b9097e39fc36e8f0e38a248 SHA512 f8c2c14a5ac5e05020eced2e01d001588edbcd6f5286156cb441a677813297e6fab072f78b5c14fbf7d0351566f4133cff2a75d43fc3af5fb291cca9d2ae138b
+DIST thunderbird-115.8.0-ko.xpi 737246 BLAKE2B b36647726da2425c2817471cd0d6fd9eb865a159b1da4d31e5a5fe123d5e9dd197375d3280132cfcc8f88e02aa4bdadcd600d7f43b80e3846c7bb50315bef471 SHA512 bcb0a09a889baf65c08e4bc90cb27063c6ee840e0387c013eb6da3445591e4ddcb773e403ced5ba74dbcc378a213ff113bb7a1dc9e6059f7899ea11ecbbb9ca2
+DIST thunderbird-115.8.0-lt.xpi 688631 BLAKE2B eb4b89cf8a803a3a4bfc563555705944b33c3c725be792f2af1be73a56044bf0c184cb95b2356a01233096dc888acf846ca118a22b88c160bc376d12ffe9667d SHA512 13100e9b69b0b93afba34e89e77a152eb96519eed033b1ef4c26dc68fff9452ea391fc4089d2e53edeb5e9df256857ed9f0a3dfcc7f386dc3aefb753ecf88f76
+DIST thunderbird-115.8.0-lv.xpi 613042 BLAKE2B 6f7c62fd0a99de0823b6ef830364f5aea59acc6946c76c2e84a7fa3b0abdb8da1920a30899773c9984f558a462c1a8d075ec61332d745e2506f2e27be813ab1c SHA512 20abd44e735fc50ae318f259e839ce06ec5bd0ea39c3e07ae824a4a76e31e5f2c5d9c9efebd61267a67fa432e8f0f011e96e92589c603e1087bccc477c1b243b
+DIST thunderbird-115.8.0-ms.xpi 573633 BLAKE2B a6f61a7ab41f32c3cb4f601e7f5b6e8ff355eb15afd1fede94563dd5ffa99eecdea6cb581d430fd55590d0ddbd24ef3112b577b3efde13744d40d15aa826cb88 SHA512 36f9be69bba62161ae18015b0dfa5fb9c1bc877d9177da01796349d4599caf808d87eadb8d4859901b4eb267e18ea79c254a2ce6a5746841b8138439cb26f4d5
+DIST thunderbird-115.8.0-nb-NO.xpi 674710 BLAKE2B 0d6f05324a72c3be83790e7d7db73b29f0f5486e2e328e8d6519f49bdbb36cb3f98beaa81b259a0b1c1c1dbc61111e59b25a4fe3075002acc783946be23ad40c SHA512 5f2f816879b5395c04044e4f2c9ba093815077a1c1931de785c7e7c7b3a7a6bba6360aabd175ec8c1318712f9c96f106b7cb11da90f85f694c8047f27e5ffcdb
+DIST thunderbird-115.8.0-nl.xpi 720591 BLAKE2B b5981b08a1f8e6784039535d765bc5e25c9e928b4c7573df8df8ca35eb1f7ab5a55d7efcabe69cc93b3bb36bb831aa45d94398ab336d0c2aeb27d3365a5f283b SHA512 1f0f285ac63526aa7f986bee041dd8fafef0f8467f3b3b102566e39451242c6a0681a1204fa00bcd3fb6be827fdba3b623e414ec8c247ec9790575ff44df3227
+DIST thunderbird-115.8.0-nn-NO.xpi 690678 BLAKE2B eb53264338a12ea56af05969ec2b124a0ad9b062cf8e8cfbf0bf66d5edcbbdf85d9462ff000aeebaefba65bb8d3789c2bcd89520b6aead30ad336a13b54cde98 SHA512 fe7b75b7c684d5bb3fa5cb6a605d6bb97077d5e42ee9c4bd8cf1c7a558e1c8e91258f62e460e9b773e01a7854f6d42f0527f6ceda8db0cea881520728ee2e1cd
+DIST thunderbird-115.8.0-pa-IN.xpi 678306 BLAKE2B 4055e3cff50ce8e62213481f330549c5e8e68420be58bb641104b3a1629fda65775906a792b3d153600546ab8bb2d036f51dbf59c133e7829f9688418ee2add7 SHA512 3fdd63cee079e83874a9f4e240f7280058bf804460d8b52ecabb08682ae913e55bfc7d65af79504577ded6e1b4ea884582156214a9454dcbe03acc044d634bec
+DIST thunderbird-115.8.0-pl.xpi 739287 BLAKE2B 40af551f3cf01775e50f8190d78113f5dcda86c81262a00e83c894966ab5d377a04fd719a2bcdb4a24da24d415d5b8275e6622bf00940f787ab34815f6b7e4e0 SHA512 9ba5ecc7de93b8d27a88e11459518ee3e56483de60225ca0a78d4729e8c9c61ac77a30f4c75553bf124ce93949fe2cfea9ea79f088a1275268c903508326b776
+DIST thunderbird-115.8.0-pt-BR.xpi 728574 BLAKE2B ffb01d25209467c0aa9783f816f8e81da190827597c711dc8fcba936025c49ecf4466e8560fe2f120c8fa8692a67e5e7466f2978cca2f56718a05b0abcd9015c SHA512 67a7a6f5d2cd3337bc5be0b63e656b35504c83b1300d5c208ee47bfd8b6bf4699deedfcb83239aa64abd35ceb9a3ca4d85c954bd0205058100ffa4c262fb5631
+DIST thunderbird-115.8.0-pt-PT.xpi 704334 BLAKE2B 7a2a115ac77eb63a8ded25beef9c43b3940f8db6c65719b4afb6644ed141f7f1abf8085494a08d4bb8a68a5bb8aae8ba0127c1b8ad6537c6efa748274218d6bb SHA512 1d8893c35a8ccd487ab9bc6464cc44c02da2588a3696e30c84f1bc6093fc16b64042528dc32714805373a8e3317929f65798d91a105a23aa5b2716125e8421d2
+DIST thunderbird-115.8.0-rm.xpi 724360 BLAKE2B 0c0ebb8e22935829805bd88503324b2d5dbbc84233b092588e2f08964d07199bd9bbebc077bb40604026c28913bac298e3417ce9f8038004f80b00e3695509c3 SHA512 54d188148f1ad1ca4d99905889c5ac2ba75b98403ff230fba9b178e3619f2ea4635dd4947bb86d106de00762bce35bb625e42bab451ba06aa6626fdb6ec4d6f6
+DIST thunderbird-115.8.0-ro.xpi 659830 BLAKE2B 7f480c3eec452270099ebf945483f83cc544bdca5f0c662b2db670586fd6bd01ca8322b55a3a1446ab12908c670e3fe9e33dfdbd1b0706c1aaa2b0ba4db28af1 SHA512 859dda57e240fbed49420dfb9da022fdd69b49d7936ccf6912f0c0c8945ab033ff3e9cadb3d6d022a4aef2e2f1349efe0c1e66ac25d7d7a676aad668c9eb9f4c
+DIST thunderbird-115.8.0-ru.xpi 846508 BLAKE2B 9cbe16d5db3b747b7db678952da027efc4c57c9637e747d6f4fd482558c98260b3b42758c4fc9993c7389e5ce0987d820c900dab60532831f9c0ad152fe60558 SHA512 29db50060784e8cf7b418862de8711da32f6536bb16c20487d08fe17e6fdb7092a11ad9455839b6bdb61f571d80698f8d099a7fc1924159215cb2b4dc9cfcf5e
+DIST thunderbird-115.8.0-sk.xpi 758460 BLAKE2B 310a7cfb2e93ffc652c2aa2c6d7a4a234e860de7a291bccbd30941d8deaddd938723c1c6a1633aec34fe7fd76c4aa80488cfcec929a71b28ee6130326024e320 SHA512 3761551e0601ba967388567898b03a0910ae22772c5c3f2128ea5117149f4b01277d5d0f96cf5d911f425cf960f1d64647785dbf4124c52912967c111cb45639
+DIST thunderbird-115.8.0-sl.xpi 721617 BLAKE2B 0925d78cbe27a3b9d20d54f4da778e1f770684934f7719c97872077a32bdb7f321c23b88e9b51c93e43cc771021937776bd24727a8b3290db703bd709ae434be SHA512 9d4498b445f39163df400b758361c63146f5a73ad99681c9b1b3935fa1c36a9a0756fc502270d690d9fcfa89670eb8734725b9ccf5715c5a90d2dd46d7d62e8a
+DIST thunderbird-115.8.0-sq.xpi 742870 BLAKE2B b49681905db0d11419243a15b07db4a7b80e977b0c351e8a4bab4d70ca74e5aa072180a1ba691e9226d0b8d296cf7cb3a0026759a9eff428407ada127e999cc2 SHA512 816ccd6f8ace8d49e5f257b77c3469bd0c6702226caef2743ed9bfdf0fe6596971bfdfce8d5ea0eb17b5e9daee7dbf1e0ad8fd01babb7a76e9de3ce09bec5686
+DIST thunderbird-115.8.0-sr.xpi 755183 BLAKE2B 05884b15a74cb0815854da2fcb42756b65f0093bdfa3bee5e1b460595a2ed72efca06c6564b0a7911b793d90f41b0a314776da70722d2e6fa8dcb5b7a3606879 SHA512 a653646f038f469e93e129a3afbda0e51e98412ef765fd05a049bcd4ac19f1817222431b504196d3186b8220e39b5c60e6525c8ab410801e06336540547d358f
+DIST thunderbird-115.8.0-sv-SE.xpi 724751 BLAKE2B 478752f563026720a16bee72e13e70017ff93bde9712b067367252b45892c63f86e198d2f8ea4d1b9205fd59a886fdd63d2e3785c628f85f039768837c28cf70 SHA512 bb8c4f370ab48cb2205bbc9c18997f718511e40c4b4e49848bb57f7ad8693838210da0fa520bdb66907b95e783ce046241dcff232991b45185e19faf2a245bb4
+DIST thunderbird-115.8.0-th.xpi 788244 BLAKE2B 4e5a3c16a122b9a1bf24a7eb7eadfc0005153e9d2bab7a744094a75c9b881f056b42f9c7329e8b46a7ba40610538474ed309d4468a088c2e9f785f9ee412ee26 SHA512 25e48256520d0f3b2558458d4e4a832c6f2bcb42a4552308847fc04410bf2a3375bfd3caa409ca18d1bdb31a939188323b459ab2d4bafea28f52a4751a3dffb3
+DIST thunderbird-115.8.0-tr.xpi 736599 BLAKE2B 7ffe6e1e5d670215fb8c793727b0699eafde9fe04c2de3fe11b5d6d2f065b9ad5f3193facf095960c3043850421811c10a0035b9f7e3b67f90ea62d36e935cf9 SHA512 ba9428833e9fbb4e6de6881ccafd0c55a33abd8b7d8ecf2ea06b1c58904a6ce6095f7ae7a4017c2038163653e3166ef42744f2a448cc670dcd53ac4dee60fb26
+DIST thunderbird-115.8.0-uk.xpi 839051 BLAKE2B c164dd767bb82f40be3ec95ccbf733a70a05ce872ebaabbdac95545c238389dd222b445e54aeea779292543d44fd9b6083c25f78ea7a31c7d45c8b349b6140cf SHA512 aec1641f5185111d7b5c814334548e587429a40d463c7d800f7d66f80c5202a846c469049620bd3519b4d0467dd29de8a15c651ab4c5556a22df4afb3ecacc7b
+DIST thunderbird-115.8.0-uz.xpi 587159 BLAKE2B 7b61b93680d038df7795540f507eb596c9101a53f12f1f75e56abb61f6b8af93bc1d18d4b2f9cd3e5ce13257c4d013710b13bd7799d201ef39080c71478cfb64 SHA512 844c777f798a86517f295eda6f92b377adbbeffc9541779571ab2502284718eb40fc666192d8c895512e25643e4b9649070d5d300d49420b10683cef9467883a
+DIST thunderbird-115.8.0-vi.xpi 764702 BLAKE2B fa24b9009a2fcb2a8da2dbccad74a5416b4f3a319adb199d053f5cae5141c7bdbd1998d89bc9ff4bea77c8fbc1e1566e074f249b701c92ea425d47e63e656583 SHA512 244f9e5a04027337ddef0bcc583eca6c6d40d412a9b96163d2f30339f1bcde7d27ef0fea210d3d9dc91e2481b399a536938e3808fa3f9d5b5c3128473e8b8d70
+DIST thunderbird-115.8.0-zh-CN.xpi 761851 BLAKE2B 00ccc2d1626f90c873e4297fb9e61e6883ebaa3b43bc9f7a7473da64e8552b5475cdc9660fae5851f8d72ef16bb53b78f8ddd22dd5155b65ab0837b7e501113d SHA512 bf6c7d9f917edffbed95d1087f97b5d65f6fd108b56ab9c0343c8fe97d10bfcd0fa8d783cffaab2be695714bc62a4417451857aa732c80d6549e6df917e9204f
+DIST thunderbird-115.8.0-zh-TW.xpi 766758 BLAKE2B 074db005f906118ba0bf6d69768c554c6da0f2e07d502738093aec58ccd4da58769100b401fa429ab51049552432c860a04c850f34510724171512a54eae69d3 SHA512 150ce952c2330d18f9c3e596432d11e1ed792f82700aef3ef299fe9dc9479c6b458ea74ff4aa74f0a5117facfde113c958712cb8afa77e52082cf06398796d7e
+DIST thunderbird-115.8.0.source.tar.xz 540914844 BLAKE2B 21dcb4772466e6496aa1deb6e2aadbb1917f69846d50e60b9ab884c982241e75da4b26c5ea512dc32228d6c8858bd6e91064e0ce3ee5df1cd434234c2b7ff5d9 SHA512 a0bdd34bebda4973f714422293f10a5a96c2b12f097c68d76fa37c48943fdbfb32dd2e504faa0b88fd699118b1903e18c3bb54cb32cd5e2ff60c09966b23e79c
EBUILD thunderbird-115.7.0.ebuild 38950 BLAKE2B 07e3ce53064c606744da91e258669838eb46476e2317b176def533a4f6baedbc26df51146ca7fae284fa8272f19a6d5082bf438d12e9cf2da1775dc09128e03f SHA512 aac4b4afa0e5d8f54dee5b37167fcb7efd5c641f891ed66244cac90ab4876420d5e287025cefd4571024002ad0582fac46f172ef8d6563f05dbe503b3910a7c1
+EBUILD thunderbird-115.8.0.ebuild 39501 BLAKE2B 99f2d29e48b38aca367a035e1a0b7c1554104c7e8c5fb68809eb12618deb3c9fddd501e8d826be4682cb6571fda7baeaea06ed3acdffd92a07b537719495c4bc SHA512 b815e1b91fc1dd5d2c977e39f21d6936697afbd0b89809a300f31d233774caa0900e2d20c21f7e1f6c81671d603d425a7b04bf3278ce191f93baa272ca5ec53a
MISC metadata.xml 2387 BLAKE2B 3602296d8cca60f79ea66089332dbce63b9da3625e476659e0a663966e65bc060e67b263c8fdcdbf8fa5545adf7b8f958cc36f9011459c715ee31bb494e7ce5e SHA512 e51ee84ed715cba36beb240db27265ac37b8df684c0e98f3b81ccf7785c1f465f1bbe3729c1c01717445e787129b449c009815f62a7455ea3fc4db8d1d9e82c3
diff --git a/mail-client/thunderbird/thunderbird-115.8.0.ebuild b/mail-client/thunderbird/thunderbird-115.8.0.ebuild
new file mode 100644
index 000000000000..1b865bde1892
--- /dev/null
+++ b/mail-client/thunderbird/thunderbird-115.8.0.ebuild
@@ -0,0 +1,1353 @@
+# Copyright 1999-2024 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=8
+
+FIREFOX_PATCHSET="firefox-115esr-patches-09.tar.xz"
+
+LLVM_MAX_SLOT=17
+
+PYTHON_COMPAT=( python3_{10..11} )
+PYTHON_REQ_USE="ncurses,sqlite,ssl"
+
+WANT_AUTOCONF="2.1"
+
+VIRTUALX_REQUIRED="manual"
+
+MOZ_ESR=
+
+MOZ_PV=${PV}
+MOZ_PV_SUFFIX=
+if [[ ${PV} =~ (_(alpha|beta|rc).*)$ ]] ; then
+ MOZ_PV_SUFFIX=${BASH_REMATCH[1]}
+
+ # Convert the ebuild version to the upstream Mozilla version
+ MOZ_PV="${MOZ_PV/_alpha/a}" # Handle alpha for SRC_URI
+ MOZ_PV="${MOZ_PV/_beta/b}" # Handle beta for SRC_URI
+ MOZ_PV="${MOZ_PV%%_rc*}" # Handle rc for SRC_URI
+fi
+
+if [[ -n ${MOZ_ESR} ]] ; then
+ # ESR releases have slightly different version numbers
+ MOZ_PV="${MOZ_PV}esr"
+fi
+
+MOZ_PN="${PN%-bin}"
+MOZ_P="${MOZ_PN}-${MOZ_PV}"
+MOZ_PV_DISTFILES="${MOZ_PV}${MOZ_PV_SUFFIX}"
+MOZ_P_DISTFILES="${MOZ_PN}-${MOZ_PV_DISTFILES}"
+
+inherit autotools check-reqs desktop flag-o-matic gnome2-utils linux-info \
+ llvm multiprocessing optfeature pax-utils python-any-r1 toolchain-funcs \
+ virtualx xdg
+
+MOZ_SRC_BASE_URI="https://archive.mozilla.org/pub/${MOZ_PN}/releases/${MOZ_PV}"
+
+if [[ ${PV} == *_rc* ]] ; then
+ MOZ_SRC_BASE_URI="https://archive.mozilla.org/pub/${MOZ_PN}/candidates/${MOZ_PV}-candidates/build${PV##*_rc}"
+fi
+
+PATCH_URIS=(
+ https://dev.gentoo.org/~juippis/mozilla/patchsets/${FIREFOX_PATCHSET}
+)
+
+SRC_URI="${MOZ_SRC_BASE_URI}/source/${MOZ_P}.source.tar.xz -> ${MOZ_P_DISTFILES}.source.tar.xz
+ ${PATCH_URIS[@]}"
+
+DESCRIPTION="Thunderbird Mail Client"
+HOMEPAGE="https://www.thunderbird.net/"
+
+KEYWORDS="~amd64 ~arm64 ~ppc64 ~x86"
+
+SLOT="0"
+LICENSE="MPL-2.0 GPL-2 LGPL-2.1"
+
+IUSE="+clang cpu_flags_arm_neon dbus debug eme-free hardened hwaccel"
+IUSE+=" jack libproxy lto +openh264 pgo pulseaudio sndio selinux"
+IUSE+=" +system-av1 +system-harfbuzz +system-icu +system-jpeg +system-libevent +system-libvpx system-png system-python-libs +system-webp"
+IUSE+=" wayland wifi +X"
+
+# Thunderbird-only USE flags.
+IUSE+=" +system-librnp"
+
+REQUIRED_USE="|| ( X wayland )
+ debug? ( !system-av1 )
+ pgo? ( lto )
+ wifi? ( dbus )"
+
+TB_ONLY_DEPEND="!<x11-plugins/enigmail-2.2
+ selinux? ( sec-policy/selinux-thunderbird )
+ !system-librnp? ( dev-libs/jsoncpp )
+ system-librnp? ( dev-util/librnp )"
+BDEPEND="${PYTHON_DEPS}
+ || (
+ (
+ sys-devel/clang:17
+ sys-devel/llvm:17
+ clang? (
+ sys-devel/lld:17
+ virtual/rust:0/llvm-17
+ pgo? ( =sys-libs/compiler-rt-sanitizers-17*[profile] )
+ )
+ )
+ (
+ sys-devel/clang:16
+ sys-devel/llvm:16
+ clang? (
+ sys-devel/lld:16
+ virtual/rust:0/llvm-16
+ pgo? ( =sys-libs/compiler-rt-sanitizers-16*[profile] )
+ )
+ )
+ (
+ sys-devel/clang:15
+ sys-devel/llvm:15
+ clang? (
+ sys-devel/lld:15
+ virtual/rust:0/llvm-15
+ pgo? ( =sys-libs/compiler-rt-sanitizers-15*[profile] )
+ )
+ )
+ )
+ app-alternatives/awk
+ app-arch/unzip
+ app-arch/zip
+ >=dev-util/cbindgen-0.24.3
+ net-libs/nodejs
+ virtual/pkgconfig
+ !clang? ( >=virtual/rust-1.65 )
+ !elibc_glibc? (
+ || (
+ dev-lang/rust
+ <dev-lang/rust-bin-1.73
+ )
+ )
+ amd64? ( >=dev-lang/nasm-2.14 )
+ x86? ( >=dev-lang/nasm-2.14 )
+ pgo? (
+ X? (
+ sys-devel/gettext
+ x11-base/xorg-server[xvfb]
+ x11-apps/xhost
+ )
+ wayland? (
+ >=gui-libs/wlroots-0.15.1-r1[tinywl]
+ x11-misc/xkeyboard-config
+ )
+ )"
+COMMON_DEPEND="${TB_ONLY_DEPEND}
+ >=app-accessibility/at-spi2-core-2.46.0:2
+ dev-libs/expat
+ dev-libs/glib:2
+ dev-libs/libffi:=
+ >=dev-libs/nss-3.90
+ >=dev-libs/nspr-4.35
+ media-libs/alsa-lib
+ media-libs/fontconfig
+ media-libs/freetype
+ media-libs/mesa
+ media-video/ffmpeg
+ sys-libs/zlib
+ virtual/freedesktop-icon-theme
+ x11-libs/cairo
+ x11-libs/gdk-pixbuf
+ x11-libs/pango
+ x11-libs/pixman
+ dbus? (
+ dev-libs/dbus-glib
+ sys-apps/dbus
+ )
+ jack? ( virtual/jack )
+ pulseaudio? (
+ || (
+ media-libs/libpulse
+ >=media-sound/apulse-0.1.12-r4[sdk]
+ )
+ )
+ libproxy? ( net-libs/libproxy )
+ selinux? ( sec-policy/selinux-mozilla )
+ sndio? ( >=media-sound/sndio-1.8.0-r1 )
+ system-av1? (
+ >=media-libs/dav1d-1.0.0:=
+ >=media-libs/libaom-1.0.0:=
+ )
+ system-harfbuzz? (
+ >=media-gfx/graphite2-1.3.13
+ >=media-libs/harfbuzz-2.8.1:0=
+ )
+ system-icu? ( >=dev-libs/icu-74.1:= )
+ system-jpeg? ( >=media-libs/libjpeg-turbo-1.2.1 )
+ system-libevent? ( >=dev-libs/libevent-2.1.12:0=[threads(+)] )
+ system-libvpx? ( >=media-libs/libvpx-1.8.2:0=[postproc] )
+ system-png? ( >=media-libs/libpng-1.6.35:0=[apng] )
+ system-webp? ( >=media-libs/libwebp-1.1.0:0= )
+ wayland? (
+ >=media-libs/libepoxy-1.5.10-r1
+ x11-libs/gtk+:3[wayland]
+ x11-libs/libxkbcommon[wayland]
+ )
+ wifi? (
+ kernel_linux? (
+ dev-libs/dbus-glib
+ net-misc/networkmanager
+ sys-apps/dbus
+ )
+ )
+ X? (
+ virtual/opengl
+ x11-libs/cairo[X]
+ x11-libs/gtk+:3[X]
+ x11-libs/libX11
+ x11-libs/libXcomposite
+ x11-libs/libXdamage
+ x11-libs/libXext
+ x11-libs/libXfixes
+ x11-libs/libxkbcommon[X]
+ x11-libs/libXrandr
+ x11-libs/libXtst
+ x11-libs/libxcb:=
+ )"
+RDEPEND="${COMMON_DEPEND}
+ jack? ( virtual/jack )
+ openh264? ( media-libs/openh264:*[plugin] )"
+DEPEND="${COMMON_DEPEND}
+ X? (
+ x11-base/xorg-proto
+ x11-libs/libICE
+ x11-libs/libSM
+ )"
+
+S="${WORKDIR}/${PN}-${PV%_*}"
+
+llvm_check_deps() {
+ if ! has_version -b "sys-devel/clang:${LLVM_SLOT}" ; then
+ einfo "sys-devel/clang:${LLVM_SLOT} is missing! Cannot use LLVM slot ${LLVM_SLOT} ..." >&2
+ return 1
+ fi
+
+ if use clang && ! tc-ld-is-mold ; then
+ if ! has_version -b "sys-devel/lld:${LLVM_SLOT}" ; then
+ einfo "sys-devel/lld:${LLVM_SLOT} is missing! Cannot use LLVM slot ${LLVM_SLOT} ..." >&2
+ return 1
+ fi
+
+ if ! has_version -b "virtual/rust:0/llvm-${LLVM_SLOT}" ; then
+ einfo "virtual/rust:0/llvm-${LLVM_SLOT} is missing! Cannot use LLVM slot ${LLVM_SLOT} ..." >&2
+ return 1
+ fi
+
+ if use pgo ; then
+ if ! has_version -b "=sys-libs/compiler-rt-sanitizers-${LLVM_SLOT}*[profile]" ; then
+ einfo "=sys-libs/compiler-rt-sanitizers-${LLVM_SLOT}*[profile] is missing! Cannot use LLVM slot ${LLVM_SLOT} ..." >&2
+ return 1
+ fi
+ fi
+ fi
+
+ einfo "Using LLVM slot ${LLVM_SLOT} to build" >&2
+}
+
+MOZ_LANGS=(
+ af ar ast be bg br ca cak cs cy da de dsb
+ el en-CA en-GB en-US es-AR es-ES es-MX et eu
+ fi fr fy-NL ga-IE gd gl he hr hsb hu
+ id is it ja ka kab kk ko lt lv ms nb-NO nl nn-NO
+ pa-IN pl pt-BR pt-PT rm ro ru
+ sk sl sq sr sv-SE th tr uk uz vi zh-CN zh-TW
+)
+
+mozilla_set_globals() {
+ # https://bugs.gentoo.org/587334
+ local MOZ_TOO_REGIONALIZED_FOR_L10N=(
+ fy-NL ga-IE gu-IN hi-IN hy-AM nb-NO ne-NP nn-NO pa-IN sv-SE
+ )
+
+ local lang xflag
+ for lang in "${MOZ_LANGS[@]}" ; do
+ # en and en_US are handled internally
+ if [[ ${lang} == en ]] || [[ ${lang} == en-US ]] ; then
+ continue
+ fi
+
+ # strip region subtag if $lang is in the list
+ if has ${lang} "${MOZ_TOO_REGIONALIZED_FOR_L10N[@]}" ; then
+ xflag=${lang%%-*}
+ else
+ xflag=${lang}
+ fi
+
+ SRC_URI+=" l10n_${xflag/[_@]/-}? ("
+ SRC_URI+=" ${MOZ_SRC_BASE_URI}/linux-x86_64/xpi/${lang}.xpi -> ${MOZ_P_DISTFILES}-${lang}.xpi"
+ SRC_URI+=" )"
+ IUSE+=" l10n_${xflag/[_@]/-}"
+ done
+}
+mozilla_set_globals
+
+moz_clear_vendor_checksums() {
+ debug-print-function ${FUNCNAME} "$@"
+
+ if [[ ${#} -ne 1 ]] ; then
+ die "${FUNCNAME} requires exact one argument"
+ fi
+
+ einfo "Clearing cargo checksums for ${1} ..."
+
+ sed -i \
+ -e 's/\("files":{\)[^}]*/\1/' \
+ "${S}"/third_party/rust/${1}/.cargo-checksum.json \
+ || die
+}
+
+moz_install_xpi() {
+ debug-print-function ${FUNCNAME} "$@"
+
+ if [[ ${#} -lt 2 ]] ; then
+ die "${FUNCNAME} requires at least two arguments"
+ fi
+
+ local DESTDIR=${1}
+ shift
+
+ insinto "${DESTDIR}"
+
+ local emid xpi_file xpi_tmp_dir
+ for xpi_file in "${@}" ; do
+ emid=
+ xpi_tmp_dir=$(mktemp -d --tmpdir="${T}")
+
+ # Unpack XPI
+ unzip -qq "${xpi_file}" -d "${xpi_tmp_dir}" || die
+
+ # Determine extension ID
+ if [[ -f "${xpi_tmp_dir}/install.rdf" ]] ; then
+ emid=$(sed -n -e '/install-manifest/,$ { /em:id/!d; s/.*[\">]\([^\"<>]*\)[\"<].*/\1/; p; q }' "${xpi_tmp_dir}/install.rdf")
+ [[ -z "${emid}" ]] && die "failed to determine extension id from install.rdf"
+ elif [[ -f "${xpi_tmp_dir}/manifest.json" ]] ; then
+ emid=$(sed -n -e 's/.*"id": "\([^"]*\)".*/\1/p' "${xpi_tmp_dir}/manifest.json")
+ [[ -z "${emid}" ]] && die "failed to determine extension id from manifest.json"
+ else
+ die "failed to determine extension id"
+ fi
+
+ einfo "Installing ${emid}.xpi into ${ED}${DESTDIR} ..."
+ newins "${xpi_file}" "${emid}.xpi"
+ done
+}
+
+mozconfig_add_options_ac() {
+ debug-print-function ${FUNCNAME} "$@"
+
+ if [[ ${#} -lt 2 ]] ; then
+ die "${FUNCNAME} requires at least two arguments"
+ fi
+
+ local reason=${1}
+ shift
+
+ local option
+ for option in ${@} ; do
+ echo "ac_add_options ${option} # ${reason}" >>${MOZCONFIG}
+ done
+}
+
+mozconfig_add_options_mk() {
+ debug-print-function ${FUNCNAME} "$@"
+
+ if [[ ${#} -lt 2 ]] ; then
+ die "${FUNCNAME} requires at least two arguments"
+ fi
+
+ local reason=${1}
+ shift
+
+ local option
+ for option in ${@} ; do
+ echo "mk_add_options ${option} # ${reason}" >>${MOZCONFIG}
+ done
+}
+
+mozconfig_use_enable() {
+ debug-print-function ${FUNCNAME} "$@"
+
+ if [[ ${#} -lt 1 ]] ; then
+ die "${FUNCNAME} requires at least one arguments"
+ fi
+
+ local flag=$(use_enable "${@}")
+ mozconfig_add_options_ac "$(use ${1} && echo +${1} || echo -${1})" "${flag}"
+}
+
+mozconfig_use_with() {
+ debug-print-function ${FUNCNAME} "$@"
+
+ if [[ ${#} -lt 1 ]] ; then
+ die "${FUNCNAME} requires at least one arguments"
+ fi
+
+ local flag=$(use_with "${@}")
+ mozconfig_add_options_ac "$(use ${1} && echo +${1} || echo -${1})" "${flag}"
+}
+
+# This is a straight copypaste from toolchain-funcs.eclass's 'tc-ld-is-lld', and is temporarily
+# placed here until toolchain-funcs.eclass gets an official support for mold linker.
+# Please see:
+# https://github.com/gentoo/gentoo/pull/28366 ||
+# https://github.com/gentoo/gentoo/pull/28355
+tc-ld-is-mold() {
+ local out
+
+ # Ensure ld output is in English.
+ local -x LC_ALL=C
+
+ # First check the linker directly.
+ out=$($(tc-getLD "$@") --version 2>&1)
+ if [[ ${out} == *"mold"* ]] ; then
+ return 0
+ fi
+
+ # Then see if they're selecting mold via compiler flags.
+ # Note: We're assuming they're using LDFLAGS to hold the
+ # options and not CFLAGS/CXXFLAGS.
+ local base="${T}/test-tc-linker"
+ cat <<-EOF > "${base}.c"
+ int main() { return 0; }
+ EOF
+ out=$($(tc-getCC "$@") ${CFLAGS} ${CPPFLAGS} ${LDFLAGS} -Wl,--version "${base}.c" -o "${base}" 2>&1)
+ rm -f "${base}"*
+ if [[ ${out} == *"mold"* ]] ; then
+ return 0
+ fi
+
+ # No mold here!
+ return 1
+}
+
+virtwl() {
+ debug-print-function ${FUNCNAME} "$@"
+
+ [[ $# -lt 1 ]] && die "${FUNCNAME} needs at least one argument"
+ [[ -n $XDG_RUNTIME_DIR ]] || die "${FUNCNAME} needs XDG_RUNTIME_DIR to be set; try xdg_environment_reset"
+ tinywl -h >/dev/null || die 'tinywl -h failed'
+
+ # TODO: don't run addpredict in utility function. WLR_RENDERER=pixman doesn't work
+ addpredict /dev/dri
+ local VIRTWL VIRTWL_PID
+ coproc VIRTWL { WLR_BACKENDS=headless exec tinywl -s 'echo $WAYLAND_DISPLAY; read _; kill $PPID'; }
+ local -x WAYLAND_DISPLAY
+ read WAYLAND_DISPLAY <&${VIRTWL[0]}
+
+ debug-print "${FUNCNAME}: $@"
+ "$@"
+ local r=$?
+
+ [[ -n $VIRTWL_PID ]] || die "tinywl exited unexpectedly"
+ exec {VIRTWL[0]}<&- {VIRTWL[1]}>&-
+ return $r
+}
+
+pkg_pretend() {
+ if [[ ${MERGE_TYPE} != binary ]] ; then
+ if use pgo ; then
+ if ! has usersandbox $FEATURES ; then
+ die "You must enable usersandbox as X server can not run as root!"
+ fi
+ fi
+
+ # Ensure we have enough disk space to compile
+ if use pgo || use lto || use debug ; then
+ CHECKREQS_DISK_BUILD="13500M"
+ else
+ CHECKREQS_DISK_BUILD="6600M"
+ fi
+
+ check-reqs_pkg_pretend
+ fi
+}
+
+pkg_setup() {
+ if [[ ${MERGE_TYPE} != binary ]] ; then
+ if use pgo ; then
+ if ! has userpriv ${FEATURES} ; then
+ eerror "Building ${PN} with USE=pgo and FEATURES=-userpriv is not supported!"
+ fi
+ fi
+
+ # Ensure we have enough disk space to compile
+ if use pgo || use lto || use debug ; then
+ CHECKREQS_DISK_BUILD="13500M"
+ else
+ CHECKREQS_DISK_BUILD="6400M"
+ fi
+
+ check-reqs_pkg_setup
+
+ llvm_pkg_setup
+
+ if use clang && use lto && tc-ld-is-lld ; then
+ local version_lld=$(ld.lld --version 2>/dev/null | awk '{ print $2 }')
+ [[ -n ${version_lld} ]] && version_lld=$(ver_cut 1 "${version_lld}")
+ [[ -z ${version_lld} ]] && die "Failed to read ld.lld version!"
+
+ local version_llvm_rust=$(rustc -Vv 2>/dev/null | grep -F -- 'LLVM version:' | awk '{ print $3 }')
+ [[ -n ${version_llvm_rust} ]] && version_llvm_rust=$(ver_cut 1 "${version_llvm_rust}")
+ [[ -z ${version_llvm_rust} ]] && die "Failed to read used LLVM version from rustc!"
+
+ if ver_test "${version_lld}" -ne "${version_llvm_rust}" ; then
+ eerror "Rust is using LLVM version ${version_llvm_rust} but ld.lld version belongs to LLVM version ${version_lld}."
+ eerror "You will be unable to link ${CATEGORY}/${PN}. To proceed you have the following options:"
+ eerror " - Manually switch rust version using 'eselect rust' to match used LLVM version"
+ eerror " - Switch to dev-lang/rust[system-llvm] which will guarantee matching version"
+ eerror " - Build ${CATEGORY}/${PN} without USE=lto"
+ eerror " - Rebuild lld with llvm that was used to build rust (may need to rebuild the whole "
+ eerror " llvm/clang/lld/rust chain depending on your @world updates)"
+ die "LLVM version used by Rust (${version_llvm_rust}) does not match with ld.lld version (${version_lld})!"
+ fi
+ fi
+
+ python-any-r1_pkg_setup
+
+ # Avoid PGO profiling problems due to enviroment leakage
+ # These should *always* be cleaned up anyway
+ unset \
+ DBUS_SESSION_BUS_ADDRESS \
+ DISPLAY \
+ ORBIT_SOCKETDIR \
+ SESSION_MANAGER \
+ XAUTHORITY \
+ XDG_CACHE_HOME \
+ XDG_SESSION_COOKIE
+
+ # Build system is using /proc/self/oom_score_adj, bug #604394
+ addpredict /proc/self/oom_score_adj
+
+ if use pgo ; then
+ # Update 105.0: "/proc/self/oom_score_adj" isn't enough anymore with pgo, but not sure
+ # whether that's due to better OOM handling by Firefox (bmo#1771712), or portage
+ # (PORTAGE_SCHEDULING_POLICY) update...
+ addpredict /proc
+
+ # May need a wider addpredict when using wayland+pgo.
+ addpredict /dev/dri
+
+ # Allow access to GPU during PGO run
+ local ati_cards mesa_cards nvidia_cards render_cards
+ shopt -s nullglob
+
+ ati_cards=$(echo -n /dev/ati/card* | sed 's/ /:/g')
+ if [[ -n "${ati_cards}" ]] ; then
+ addpredict "${ati_cards}"
+ fi
+
+ mesa_cards=$(echo -n /dev/dri/card* | sed 's/ /:/g')
+ if [[ -n "${mesa_cards}" ]] ; then
+ addpredict "${mesa_cards}"
+ fi
+
+ nvidia_cards=$(echo -n /dev/nvidia* | sed 's/ /:/g')
+ if [[ -n "${nvidia_cards}" ]] ; then
+ addpredict "${nvidia_cards}"
+ fi
+
+ render_cards=$(echo -n /dev/dri/renderD128* | sed 's/ /:/g')
+ if [[ -n "${render_cards}" ]] ; then
+ addpredict "${render_cards}"
+ fi
+
+ shopt -u nullglob
+ fi
+
+ if ! mountpoint -q /dev/shm ; then
+ # If /dev/shm is not available, configure is known to fail with
+ # a traceback report referencing /usr/lib/pythonN.N/multiprocessing/synchronize.py
+ ewarn "/dev/shm is not mounted -- expect build failures!"
+ fi
+
+ # Google API keys (see http://www.chromium.org/developers/how-tos/api-keys)
+ # Note: These are for Gentoo Linux use ONLY. For your own distribution, please
+ # get your own set of keys.
+ if [[ -z "${MOZ_API_KEY_GOOGLE+set}" ]] ; then
+ MOZ_API_KEY_GOOGLE="AIzaSyDEAOvatFogGaPi0eTgsV_ZlEzx0ObmepsMzfAc"
+ fi
+
+ if [[ -z "${MOZ_API_KEY_LOCATION+set}" ]] ; then
+ MOZ_API_KEY_LOCATION="AIzaSyB2h2OuRgGaPicUgy5N-5hsZqiPW6sH3n_rptiQ"
+ fi
+
+ # Mozilla API keys (see https://location.services.mozilla.com/api)
+ # Note: These are for Gentoo Linux use ONLY. For your own distribution, please
+ # get your own set of keys.
+ if [[ -z "${MOZ_API_KEY_MOZILLA+set}" ]] ; then
+ MOZ_API_KEY_MOZILLA="edb3d487-3a84-46m0ap1e3-9dfd-92b5efaaa005"
+ fi
+
+ # Ensure we use C locale when building, bug #746215
+ export LC_ALL=C
+ fi
+}
+
+src_unpack() {
+ local _lp_dir="${WORKDIR}/language_packs"
+ local _src_file
+
+ if [[ ! -d "${_lp_dir}" ]] ; then
+ mkdir "${_lp_dir}" || die
+ fi
+
+ for _src_file in ${A} ; do
+ if [[ ${_src_file} == *.xpi ]]; then
+ cp "${DISTDIR}/${_src_file}" "${_lp_dir}" || die "Failed to copy '${_src_file}' to '${_lp_dir}'!"
+ else
+ unpack ${_src_file}
+ fi
+ done
+}
+
+src_prepare() {
+ if use lto; then
+ rm -v "${WORKDIR}"/firefox-patches/*-LTO-Only-enable-LTO-*.patch || die
+ fi
+
+ if ! use ppc64; then
+ rm -v "${WORKDIR}"/firefox-patches/*ppc64*.patch || die
+ fi
+
+ if use x86 && use elibc_glibc ; then
+ rm -v "${WORKDIR}"/firefox-patches/*-musl-non-lfs64-api-on-audio_thread_priority-crate.patch || die
+ fi
+
+ # Workaround for bgo#917599
+ if has_version ">=dev-libs/icu-74.1" && use system-icu ; then
+ eapply "${WORKDIR}"/firefox-patches/0029-bmo-1862601-system-icu-74.patch
+ fi
+ rm -v "${WORKDIR}"/firefox-patches/0029-bmo-1862601-system-icu-74.patch || die
+
+ # Workaround for bgo#915651 on musl
+ if use elibc_glibc ; then
+ rm -v "${WORKDIR}"/firefox-patches/*bgo-748849-RUST_TARGET_override.patch || die
+ fi
+
+ eapply "${WORKDIR}/firefox-patches"
+
+ # Allow user to apply any additional patches without modifing ebuild
+ eapply_user
+
+ # Make cargo respect MAKEOPTS
+ export CARGO_BUILD_JOBS="$(makeopts_jobs)"
+
+ # Workaround for bgo#915651
+ if ! use elibc_glibc ; then
+ if use amd64 ; then
+ export RUST_TARGET="x86_64-unknown-linux-musl"
+ elif use x86 ; then
+ export RUST_TARGET="i686-unknown-linux-musl"
+ else
+ die "Unknown musl chost, please post your rustc -vV along with emerge --info on Gentoo's bug #915651"
+ fi
+ fi
+
+ # Make LTO respect MAKEOPTS
+ sed -i \
+ -e "s/multiprocessing.cpu_count()/$(makeopts_jobs)/" \
+ "${S}"/build/moz.configure/lto-pgo.configure \
+ || die "sed failed to set num_cores"
+
+ # Make ICU respect MAKEOPTS
+ sed -i \
+ -e "s/multiprocessing.cpu_count()/$(makeopts_jobs)/" \
+ "${S}"/intl/icu_sources_data.py \
+ || die "sed failed to set num_cores"
+
+ # sed-in toolchain prefix
+ sed -i \
+ -e "s/objdump/${CHOST}-objdump/" \
+ "${S}"/python/mozbuild/mozbuild/configure/check_debug_ranges.py \
+ || die "sed failed to set toolchain prefix"
+
+ sed -i \
+ -e 's/ccache_stats = None/return None/' \
+ "${S}"/python/mozbuild/mozbuild/controller/building.py \
+ || die "sed failed to disable ccache stats call"
+
+ einfo "Removing pre-built binaries ..."
+
+ find "${S}"/third_party -type f \( -name '*.so' -o -name '*.o' \) -print -delete || die
+
+ # Clear cargo checksums from crates we have patched
+ # moz_clear_vendor_checksums crate
+ moz_clear_vendor_checksums audio_thread_priority
+
+ # Create build dir
+ BUILD_DIR="${WORKDIR}/${PN}_build"
+ mkdir -p "${BUILD_DIR}" || die
+
+ # Write API keys to disk
+ echo -n "${MOZ_API_KEY_GOOGLE//gGaPi/}" > "${S}"/api-google.key || die
+ echo -n "${MOZ_API_KEY_LOCATION//gGaPi/}" > "${S}"/api-location.key || die
+ echo -n "${MOZ_API_KEY_MOZILLA//m0ap1/}" > "${S}"/api-mozilla.key || die
+
+ xdg_environment_reset
+}
+
+src_configure() {
+ # Show flags set at the beginning
+ einfo "Current BINDGEN_CFLAGS:\t${BINDGEN_CFLAGS:-no value set}"
+ einfo "Current CFLAGS:\t\t${CFLAGS:-no value set}"
+ einfo "Current CXXFLAGS:\t\t${CXXFLAGS:-no value set}"
+ einfo "Current LDFLAGS:\t\t${LDFLAGS:-no value set}"
+ einfo "Current RUSTFLAGS:\t\t${RUSTFLAGS:-no value set}"
+
+ local have_switched_compiler=
+ if use clang; then
+ # Force clang
+ einfo "Enforcing the use of clang due to USE=clang ..."
+
+ local version_clang=$(clang --version 2>/dev/null | grep -F -- 'clang version' | awk '{ print $3 }')
+ [[ -n ${version_clang} ]] && version_clang=$(ver_cut 1 "${version_clang}")
+ [[ -z ${version_clang} ]] && die "Failed to read clang version!"
+
+ if tc-is-gcc; then
+ have_switched_compiler=yes
+ fi
+ AR=llvm-ar
+ CC=${CHOST}-clang-${version_clang}
+ CXX=${CHOST}-clang++-${version_clang}
+ NM=llvm-nm
+ RANLIB=llvm-ranlib
+ elif ! use clang && ! tc-is-gcc ; then
+ # Force gcc
+ have_switched_compiler=yes
+ einfo "Enforcing the use of gcc due to USE=-clang ..."
+ AR=gcc-ar
+ CC=${CHOST}-gcc
+ CXX=${CHOST}-g++
+ NM=gcc-nm
+ RANLIB=gcc-ranlib
+ fi
+
+ if [[ -n "${have_switched_compiler}" ]] ; then
+ # Because we switched active compiler we have to ensure
+ # that no unsupported flags are set
+ strip-unsupported-flags
+ fi
+
+ # Ensure we use correct toolchain,
+ # AS is used in a non-standard way by upstream, #bmo1654031
+ export HOST_CC="$(tc-getBUILD_CC)"
+ export HOST_CXX="$(tc-getBUILD_CXX)"
+ export AS="$(tc-getCC) -c"
+ tc-export CC CXX LD AR AS NM OBJDUMP RANLIB PKG_CONFIG
+
+ # Pass the correct toolchain paths through cbindgen
+ if tc-is-cross-compiler ; then
+ export BINDGEN_CFLAGS="${SYSROOT:+--sysroot=${ESYSROOT}} --target=${CHOST} ${BINDGEN_CFLAGS-}"
+ fi
+
+ # Set MOZILLA_FIVE_HOME
+ export MOZILLA_FIVE_HOME="/usr/$(get_libdir)/${PN}"
+
+ # python/mach/mach/mixin/process.py fails to detect SHELL
+ export SHELL="${EPREFIX}/bin/bash"
+
+ # Set state path
+ export MOZBUILD_STATE_PATH="${BUILD_DIR}"
+
+ # Set MOZCONFIG
+ export MOZCONFIG="${S}/.mozconfig"
+
+ # Initialize MOZCONFIG
+ mozconfig_add_options_ac '' --enable-application=comm/mail
+ mozconfig_add_options_ac '' --enable-project=comm/mail
+
+ # Set Gentoo defaults
+ mozconfig_add_options_ac 'Gentoo default' \
+ --allow-addon-sideload \
+ --disable-cargo-incremental \
+ --disable-crashreporter \
+ --disable-gpsd \
+ --disable-install-strip \
+ --disable-parental-controls \
+ --disable-strip \
+ --disable-tests \
+ --disable-updater \
+ --disable-wmf \
+ --enable-js-shell \
+ --enable-legacy-profile-creation \
+ --enable-negotiateauth \
+ --enable-new-pass-manager \
+ --enable-official-branding \
+ --enable-release \
+ --enable-system-ffi \
+ --enable-system-pixman \
+ --enable-system-policies \
+ --host="${CBUILD:-${CHOST}}" \
+ --libdir="${EPREFIX}/usr/$(get_libdir)" \
+ --prefix="${EPREFIX}/usr" \
+ --target="${CHOST}" \
+ --without-ccache \
+ --without-wasm-sandboxed-libraries \
+ --with-intl-api \
+ --with-libclang-path="$(llvm-config --libdir)" \
+ --with-system-nspr \
+ --with-system-nss \
+ --with-system-zlib \
+ --with-toolchain-prefix="${CHOST}-" \
+ --with-unsigned-addon-scopes=app,system \
+ --x-includes="${ESYSROOT}/usr/include" \
+ --x-libraries="${ESYSROOT}/usr/$(get_libdir)"
+
+ # Set update channel
+ local update_channel=release
+ [[ -n ${MOZ_ESR} ]] && update_channel=esr
+ mozconfig_add_options_ac '' --update-channel=${update_channel}
+
+ if ! use x86 && [[ ${CHOST} != armv*h* ]] ; then
+ mozconfig_add_options_ac '' --enable-rust-simd
+ fi
+
+ # For future keywording: This is currently (97.0) only supported on:
+ # amd64, arm, arm64 & x86.
+ # Might want to flip the logic around if Firefox is to support more arches.
+ # bug 833001, bug 903411#c8
+ if use ppc64 || use riscv; then
+ mozconfig_add_options_ac '' --disable-sandbox
+ else
+ mozconfig_add_options_ac '' --enable-sandbox
+ fi
+
+ # Enable JIT on riscv64 explicitly
+ # Can be removed once upstream enable it by default in the future.
+ use riscv && mozconfig_add_options_ac 'Enable JIT for RISC-V 64' --enable-jit
+
+ if [[ -s "${S}/api-google.key" ]] ; then
+ local key_origin="Gentoo default"
+ if [[ $(cat "${S}/api-google.key" | md5sum | awk '{ print $1 }') != 709560c02f94b41f9ad2c49207be6c54 ]] ; then
+ key_origin="User value"
+ fi
+
+ mozconfig_add_options_ac "${key_origin}" \
+ --with-google-safebrowsing-api-keyfile="${S}/api-google.key"
+ else
+ einfo "Building without Google API key ..."
+ fi
+
+ if [[ -s "${S}/api-location.key" ]] ; then
+ local key_origin="Gentoo default"
+ if [[ $(cat "${S}/api-location.key" | md5sum | awk '{ print $1 }') != ffb7895e35dedf832eb1c5d420ac7420 ]] ; then
+ key_origin="User value"
+ fi
+
+ mozconfig_add_options_ac "${key_origin}" \
+ --with-google-location-service-api-keyfile="${S}/api-location.key"
+ else
+ einfo "Building without Location API key ..."
+ fi
+
+ if [[ -s "${S}/api-mozilla.key" ]] ; then
+ local key_origin="Gentoo default"
+ if [[ $(cat "${S}/api-mozilla.key" | md5sum | awk '{ print $1 }') != 3927726e9442a8e8fa0e46ccc39caa27 ]] ; then
+ key_origin="User value"
+ fi
+
+ mozconfig_add_options_ac "${key_origin}" \
+ --with-mozilla-api-keyfile="${S}/api-mozilla.key"
+ else
+ einfo "Building without Mozilla API key ..."
+ fi
+
+ mozconfig_use_with system-av1
+ mozconfig_use_with system-harfbuzz
+ mozconfig_use_with system-harfbuzz system-graphite2
+ mozconfig_use_with system-icu
+ mozconfig_use_with system-jpeg
+ mozconfig_use_with system-libevent
+ mozconfig_use_with system-libvpx
+ mozconfig_use_with system-png
+ mozconfig_use_with system-webp
+
+ if use system-librnp; then
+ mozconfig_add_options_ac "+system-librnp" --enable-compile-environment
+ mozconfig_use_with system-librnp
+ else
+ # This controls the backend of the bundled librnp. Choices are "botan" and "openssl".
+ # RNP Upstream recommends to use botan. In Gentoo it's preferred to use system-librnp.
+ mozconfig_add_options_ac "+bundled librnp backend = botan" --with-librnp-backend="botan"
+ fi
+
+ mozconfig_use_enable dbus
+ mozconfig_use_enable libproxy
+
+ use eme-free && mozconfig_add_options_ac '+eme-free' --disable-eme
+
+ if use hardened ; then
+ mozconfig_add_options_ac "+hardened" --enable-hardening
+ append-ldflags "-Wl,-z,relro -Wl,-z,now"
+ fi
+
+ local myaudiobackends=""
+ use jack && myaudiobackends+="jack,"
+ use sndio && myaudiobackends+="sndio,"
+ use pulseaudio && myaudiobackends+="pulseaudio,"
+ ! use pulseaudio && myaudiobackends+="alsa,"
+
+ mozconfig_add_options_ac '--enable-audio-backends' --enable-audio-backends="${myaudiobackends::-1}"
+
+ mozconfig_use_enable wifi necko-wifi
+
+ if use X && use wayland ; then
+ mozconfig_add_options_ac '+x11+wayland' --enable-default-toolkit=cairo-gtk3-x11-wayland
+ elif ! use X && use wayland ; then
+ mozconfig_add_options_ac '+wayland' --enable-default-toolkit=cairo-gtk3-wayland-only
+ else
+ mozconfig_add_options_ac '+x11' --enable-default-toolkit=cairo-gtk3
+ fi
+
+ if use lto ; then
+ if use clang ; then
+ # Upstream only supports lld or mold when using clang.
+ if tc-ld-is-mold ; then
+ mozconfig_add_options_ac "using ld=mold due to system selection" --enable-linker=mold
+ else
+ mozconfig_add_options_ac "forcing ld=lld due to USE=clang and USE=lto" --enable-linker=lld
+ fi
+
+ mozconfig_add_options_ac '+lto' --enable-lto=cross
+
+ else
+ # ThinLTO is currently broken, see bmo#1644409.
+ # mold does not support gcc+lto combination.
+ mozconfig_add_options_ac '+lto' --enable-lto=full
+ mozconfig_add_options_ac "linker is set to bfd" --enable-linker=bfd
+ fi
+
+ if use pgo ; then
+ mozconfig_add_options_ac '+pgo' MOZ_PGO=1
+
+ if use clang ; then
+ # Used in build/pgo/profileserver.py
+ export LLVM_PROFDATA="llvm-profdata"
+ fi
+ fi
+ else
+ # Avoid auto-magic on linker
+ if use clang ; then
+ # lld is upstream's default
+ if tc-ld-is-mold ; then
+ mozconfig_add_options_ac "using ld=mold due to system selection" --enable-linker=mold
+ else
+ mozconfig_add_options_ac "forcing ld=lld due to USE=clang" --enable-linker=lld
+ fi
+
+ else
+ if tc-ld-is-mold ; then
+ mozconfig_add_options_ac "using ld=mold due to system selection" --enable-linker=mold
+ else
+ mozconfig_add_options_ac "linker is set to bfd due to USE=-clang" --enable-linker=bfd
+ fi
+ fi
+ fi
+
+ # LTO flag was handled via configure
+ filter-lto
+
+ mozconfig_use_enable debug
+ if use debug ; then
+ mozconfig_add_options_ac '+debug' --disable-optimize
+ mozconfig_add_options_ac '+debug' --enable-real-time-tracing
+ else
+ mozconfig_add_options_ac 'Gentoo defaults' --disable-real-time-tracing
+
+ if is-flag '-g*' ; then
+ if use clang ; then
+ mozconfig_add_options_ac 'from CFLAGS' --enable-debug-symbols=$(get-flag '-g*')
+ else
+ mozconfig_add_options_ac 'from CFLAGS' --enable-debug-symbols
+ fi
+ else
+ mozconfig_add_options_ac 'Gentoo default' --disable-debug-symbols
+ fi
+
+ if is-flag '-O0' ; then
+ mozconfig_add_options_ac "from CFLAGS" --enable-optimize=-O0
+ elif is-flag '-O4' ; then
+ mozconfig_add_options_ac "from CFLAGS" --enable-optimize=-O4
+ elif is-flag '-O3' ; then
+ mozconfig_add_options_ac "from CFLAGS" --enable-optimize=-O3
+ elif is-flag '-O1' ; then
+ mozconfig_add_options_ac "from CFLAGS" --enable-optimize=-O1
+ elif is-flag '-Os' ; then
+ mozconfig_add_options_ac "from CFLAGS" --enable-optimize=-Os
+ else
+ mozconfig_add_options_ac "Gentoo default" --enable-optimize=-O2
+ fi
+ fi
+
+ # Debug flag was handled via configure
+ filter-flags '-g*'
+
+ # Optimization flag was handled via configure
+ filter-flags '-O*'
+
+ # Modifications to better support ARM, bug #553364
+ if use cpu_flags_arm_neon ; then
+ mozconfig_add_options_ac '+cpu_flags_arm_neon' --with-fpu=neon
+
+ if ! tc-is-clang ; then
+ # thumb options aren't supported when using clang, bug 666966
+ mozconfig_add_options_ac '+cpu_flags_arm_neon' \
+ --with-thumb=yes \
+ --with-thumb-interwork=no
+ fi
+ fi
+
+ if [[ ${CHOST} == armv*h* ]] ; then
+ mozconfig_add_options_ac 'CHOST=armv*h*' --with-float-abi=hard
+
+ if ! use system-libvpx ; then
+ sed -i \
+ -e "s|softfp|hard|" \
+ "${S}"/media/libvpx/moz.build \
+ || die
+ fi
+ fi
+
+ if use clang ; then
+ # https://bugzilla.mozilla.org/show_bug.cgi?id=1482204
+ # https://bugzilla.mozilla.org/show_bug.cgi?id=1483822
+ # toolkit/moz.configure Elfhack section: target.cpu in ('arm', 'x86', 'x86_64')
+ local disable_elf_hack=
+ if use amd64 ; then
+ disable_elf_hack=yes
+ elif use x86 ; then
+ disable_elf_hack=yes
+ elif use arm ; then
+ disable_elf_hack=yes
+ fi
+
+ if [[ -n ${disable_elf_hack} ]] ; then
+ mozconfig_add_options_ac 'elf-hack is broken when using Clang' --disable-elf-hack
+ fi
+ fi
+
+ if use elibc_musl && use arm64 ; then
+ mozconfig_add_options_ac 'elf-hack is broken when using musl/arm64' --disable-elf-hack
+ fi
+
+ # Additional ARCH support
+ case "${ARCH}" in
+ arm)
+ # Reduce the memory requirements for linking
+ if use clang ; then
+ # Nothing to do
+ :;
+ elif use lto ; then
+ append-ldflags -Wl,--no-keep-memory
+ else
+ append-ldflags -Wl,--no-keep-memory -Wl,--reduce-memory-overheads
+ fi
+ ;;
+ esac
+
+ if ! use elibc_glibc; then
+ mozconfig_add_options_ac '!elibc_glibc' --disable-jemalloc
+ fi
+
+ # Allow elfhack to work in combination with unstripped binaries
+ # when they would normally be larger than 2GiB.
+ append-ldflags "-Wl,--compress-debug-sections=zlib"
+
+ # Make revdep-rebuild.sh happy; Also required for musl
+ append-ldflags -Wl,-rpath="${MOZILLA_FIVE_HOME}",--enable-new-dtags
+
+ # Pass $MAKEOPTS to build system
+ export MOZ_MAKE_FLAGS="${MAKEOPTS}"
+
+ # Use system's Python environment
+ export PIP_NETWORK_INSTALL_RESTRICTED_VIRTUALENVS=mach
+
+ if use system-python-libs; then
+ export MACH_BUILD_PYTHON_NATIVE_PACKAGE_SOURCE="system"
+ else
+ export MACH_BUILD_PYTHON_NATIVE_PACKAGE_SOURCE="none"
+ fi
+
+ # Disable notification when build system has finished
+ export MOZ_NOSPAM=1
+
+ # Portage sets XARGS environment variable to "xargs -r" by default which
+ # breaks build system's check_prog() function which doesn't support arguments
+ mozconfig_add_options_ac 'Gentoo default' "XARGS=${EPREFIX}/usr/bin/xargs"
+
+ # Set build dir
+ mozconfig_add_options_mk 'Gentoo default' "MOZ_OBJDIR=${BUILD_DIR}"
+
+ # Show flags we will use
+ einfo "Build BINDGEN_CFLAGS:\t${BINDGEN_CFLAGS:-no value set}"
+ einfo "Build CFLAGS:\t\t${CFLAGS:-no value set}"
+ einfo "Build CXXFLAGS:\t\t${CXXFLAGS:-no value set}"
+ einfo "Build LDFLAGS:\t\t${LDFLAGS:-no value set}"
+ einfo "Build RUSTFLAGS:\t\t${RUSTFLAGS:-no value set}"
+
+ # Handle EXTRA_CONF and show summary
+ local ac opt hash reason
+
+ # Apply EXTRA_ECONF entries to $MOZCONFIG
+ if [[ -n ${EXTRA_ECONF} ]] ; then
+ IFS=\! read -a ac <<<${EXTRA_ECONF// --/\!}
+ for opt in "${ac[@]}"; do
+ mozconfig_add_options_ac "EXTRA_ECONF" --${opt#--}
+ done
+ fi
+
+ echo
+ echo "=========================================================="
+ echo "Building ${PF} with the following configuration"
+ grep ^ac_add_options "${MOZCONFIG}" | while read ac opt hash reason; do
+ [[ -z ${hash} || ${hash} == \# ]] \
+ || die "error reading mozconfig: ${ac} ${opt} ${hash} ${reason}"
+ printf " %-30s %s\n" "${opt}" "${reason:-mozilla.org default}"
+ done
+ echo "=========================================================="
+ echo
+
+ ./mach configure || die
+}
+
+src_compile() {
+ local virtx_cmd=
+
+ if tc-ld-is-mold && use lto; then
+ # increase ulimit with mold+lto, bugs #892641, #907485
+ if ! ulimit -n 16384 1>/dev/null 2>&1 ; then
+ ewarn "Unable to modify ulimits - building with mold+lto might fail due to low ulimit -n resources."
+ ewarn "Please see bugs #892641 & #907485."
+ else
+ ulimit -n 16384
+ fi
+ fi
+
+ if use pgo; then
+ # Reset and cleanup environment variables used by GNOME/XDG
+ gnome2_environment_reset
+
+ addpredict /root
+
+ if ! use X; then
+ virtx_cmd=virtwl
+ else
+ virtx_cmd=virtx
+ fi
+ fi
+
+ if ! use X; then
+ local -x GDK_BACKEND=wayland
+ else
+ local -x GDK_BACKEND=x11
+ fi
+
+ ${virtx_cmd} ./mach build --verbose || die
+}
+
+src_install() {
+ # xpcshell is getting called during install
+ pax-mark m \
+ "${BUILD_DIR}"/dist/bin/xpcshell \
+ "${BUILD_DIR}"/dist/bin/${PN} \
+ "${BUILD_DIR}"/dist/bin/plugin-container
+
+ DESTDIR="${D}" ./mach install || die
+
+ # Upstream cannot ship symlink but we can (bmo#658850)
+ rm "${ED}${MOZILLA_FIVE_HOME}/${PN}-bin" || die
+ dosym ${PN} ${MOZILLA_FIVE_HOME}/${PN}-bin
+
+ # Don't install llvm-symbolizer from sys-devel/llvm package
+ if [[ -f "${ED}${MOZILLA_FIVE_HOME}/llvm-symbolizer" ]] ; then
+ rm -v "${ED}${MOZILLA_FIVE_HOME}/llvm-symbolizer" || die
+ fi
+
+ # Install policy (currently only used to disable application updates)
+ insinto "${MOZILLA_FIVE_HOME}/distribution"
+ newins "${FILESDIR}"/distribution.ini distribution.ini
+ newins "${FILESDIR}"/disable-auto-update.policy.json policies.json
+
+ # Install system-wide preferences
+ local PREFS_DIR="${MOZILLA_FIVE_HOME}/defaults/pref"
+ insinto "${PREFS_DIR}"
+ newins "${FILESDIR}"/gentoo-default-prefs.js gentoo-prefs.js
+
+ local GENTOO_PREFS="${ED}${PREFS_DIR}/gentoo-prefs.js"
+
+ # Set dictionary path to use system hunspell
+ cat >>"${GENTOO_PREFS}" <<-EOF || die "failed to set spellchecker.dictionary_path pref"
+ pref("spellchecker.dictionary_path", "${EPREFIX}/usr/share/myspell");
+ EOF
+
+ # Force hwaccel prefs if USE=hwaccel is enabled
+ if use hwaccel ; then
+ cat "${FILESDIR}"/gentoo-hwaccel-prefs.js \
+ >>"${GENTOO_PREFS}" \
+ || die "failed to add prefs to force hardware-accelerated rendering to all-gentoo.js"
+
+ if use wayland; then
+ cat >>"${GENTOO_PREFS}" <<-EOF || die "failed to set hwaccel wayland prefs"
+ pref("gfx.x11-egl.force-enabled", false);
+ EOF
+ else
+ cat >>"${GENTOO_PREFS}" <<-EOF || die "failed to set hwaccel x11 prefs"
+ pref("gfx.x11-egl.force-enabled", true);
+ EOF
+ fi
+ fi
+
+ # Force the graphite pref if USE=system-harfbuzz is enabled, since the pref cannot disable it
+ if use system-harfbuzz ; then
+ cat >>"${GENTOO_PREFS}" <<-EOF || die "failed to set gfx.font_rendering.graphite.enabled pref"
+ sticky_pref("gfx.font_rendering.graphite.enabled", true);
+ EOF
+ fi
+
+ # Install language packs
+ local langpacks=( $(find "${WORKDIR}/language_packs" -type f -name '*.xpi') )
+ if [[ -n "${langpacks}" ]] ; then
+ moz_install_xpi "${MOZILLA_FIVE_HOME}/distribution/extensions" "${langpacks[@]}"
+ fi
+
+ # Install icons
+ local icon_srcdir="${S}/comm/mail/branding/thunderbird"
+ local icon_symbolic_file="${icon_srcdir}/TB-symbolic.svg"
+
+ insinto /usr/share/icons/hicolor/symbolic/apps
+ newins "${icon_symbolic_file}" ${PN}-symbolic.svg
+
+ local icon size
+ for icon in "${icon_srcdir}"/default*.png ; do
+ size=${icon%.png}
+ size=${size##*/default}
+
+ if [[ ${size} -eq 48 ]] ; then
+ newicon "${icon}" ${PN}.png
+ fi
+
+ newicon -s ${size} "${icon}" ${PN}.png
+ done
+
+ # Install menu
+ local app_name="Mozilla ${MOZ_PN^}"
+ local desktop_file="${FILESDIR}/icon/${PN}-r2.desktop"
+ local desktop_filename="${PN}.desktop"
+ local exec_command="${PN}"
+ local icon="${PN}"
+ local use_wayland="false"
+
+ if use wayland ; then
+ use_wayland="true"
+ fi
+
+ cp "${desktop_file}" "${WORKDIR}/${PN}.desktop-template" || die
+
+ sed -i \
+ -e "s:@NAME@:${app_name}:" \
+ -e "s:@EXEC@:${exec_command}:" \
+ -e "s:@ICON@:${icon}:" \
+ "${WORKDIR}/${PN}.desktop-template" \
+ || die
+
+ newmenu "${WORKDIR}/${PN}.desktop-template" "${desktop_filename}"
+
+ rm "${WORKDIR}/${PN}.desktop-template" || die
+
+ # Install wrapper script
+ [[ -f "${ED}/usr/bin/${PN}" ]] && rm "${ED}/usr/bin/${PN}"
+ newbin "${FILESDIR}/${PN}-r1.sh" ${PN}
+
+ # Update wrapper
+ sed -i \
+ -e "s:@PREFIX@:${EPREFIX}/usr:" \
+ -e "s:@MOZ_FIVE_HOME@:${MOZILLA_FIVE_HOME}:" \
+ -e "s:@APULSELIB_DIR@:${apulselib}:" \
+ -e "s:@DEFAULT_WAYLAND@:${use_wayland}:" \
+ "${ED}/usr/bin/${PN}" \
+ || die
+}
+
+pkg_preinst() {
+ xdg_pkg_preinst
+
+ # If the apulse libs are available in MOZILLA_FIVE_HOME then apulse
+ # does not need to be forced into the LD_LIBRARY_PATH
+ if use pulseaudio && has_version ">=media-sound/apulse-0.1.12-r4" ; then
+ einfo "APULSE found; Generating library symlinks for sound support ..."
+ local lib
+ pushd "${ED}${MOZILLA_FIVE_HOME}" &>/dev/null || die
+ for lib in ../apulse/libpulse{.so{,.0},-simple.so{,.0}} ; do
+ # A quickpkg rolled by hand will grab symlinks as part of the package,
+ # so we need to avoid creating them if they already exist.
+ if [[ ! -L ${lib##*/} ]] ; then
+ ln -s "${lib}" ${lib##*/} || die
+ fi
+ done
+ popd &>/dev/null || die
+ fi
+}
+
+pkg_postinst() {
+ xdg_pkg_postinst
+
+ if use pulseaudio && has_version ">=media-sound/apulse-0.1.12-r4" ; then
+ elog "Apulse was detected at merge time on this system and so it will always be"
+ elog "used for sound. If you wish to use pulseaudio instead please unmerge"
+ elog "media-sound/apulse."
+ elog
+ fi
+
+ local show_doh_information
+ local show_shortcut_information
+
+ if [[ -z "${REPLACING_VERSIONS}" ]] ; then
+ # New install; Tell user that DoH is disabled by default
+ show_doh_information=yes
+ show_shortcut_information=no
+ else
+ local replacing_version
+ for replacing_version in ${REPLACING_VERSIONS} ; do
+ if ver_test "${replacing_version}" -lt 91.0 ; then
+ # Tell user that we no longer install a shortcut
+ # per supported display protocol
+ show_shortcut_information=yes
+ fi
+ done
+ fi
+
+ if [[ -n "${show_doh_information}" ]] ; then
+ elog
+ elog "Note regarding Trusted Recursive Resolver aka DNS-over-HTTPS (DoH):"
+ elog "Due to privacy concerns (encrypting DNS might be a good thing, sending all"
+ elog "DNS traffic to Cloudflare by default is not a good idea and applications"
+ elog "should respect OS configured settings), \"network.trr.mode\" was set to 5"
+ elog "(\"Off by choice\") by default."
+ elog "You can enable DNS-over-HTTPS in ${PN^}'s preferences."
+ fi
+
+ if [[ -n "${show_shortcut_information}" ]] ; then
+ elog
+ elog "Since ${PN}-91.0 we no longer install multiple shortcuts for"
+ elog "each supported display protocol. Instead we will only install"
+ elog "one generic Mozilla ${PN^} shortcut."
+ elog "If you still want to be able to select between running Mozilla ${PN^}"
+ elog "on X11 or Wayland, you have to re-create these shortcuts on your own."
+ fi
+
+ # bug 835078
+ if use hwaccel && has_version "x11-drivers/xf86-video-nouveau"; then
+ ewarn "You have nouveau drivers installed in your system and 'hwaccel' "
+ ewarn "enabled for Firefox. Nouveau / your GPU might not support the "
+ ewarn "required EGL, so either disable 'hwaccel' or try the workaround "
+ ewarn "explained in https://bugs.gentoo.org/835078#c5 if Firefox crashes."
+ fi
+
+ optfeature_header "Optional programs for extra features:"
+ optfeature "desktop notifications" x11-libs/libnotify
+ optfeature "encrypted chat support" net-libs/libotr
+ optfeature "fallback mouse cursor theme e.g. on WMs" gnome-base/gsettings-desktop-schemas
+}