diff options
author | Joonas Niilola <juippis@gentoo.org> | 2024-11-20 18:59:38 +0200 |
---|---|---|
committer | Joonas Niilola <juippis@gentoo.org> | 2024-11-20 18:59:38 +0200 |
commit | 504777e8788e84cf025a36888491e759e58da647 (patch) | |
tree | 1132b1a6e65acb3ba2b431f8c4fc40c4c715fb76 | |
parent | profiles/base: globally package.use.mask xemacs[dnd] (diff) | |
download | gentoo-504777e8788e84cf025a36888491e759e58da647.tar.gz gentoo-504777e8788e84cf025a36888491e759e58da647.tar.bz2 gentoo-504777e8788e84cf025a36888491e759e58da647.zip |
mail-client/thunderbird: add 128.4.4
Signed-off-by: Joonas Niilola <juippis@gentoo.org>
-rw-r--r-- | mail-client/thunderbird/Manifest | 65 | ||||
-rw-r--r-- | mail-client/thunderbird/thunderbird-128.4.4.ebuild | 1156 |
2 files changed, 1221 insertions, 0 deletions
diff --git a/mail-client/thunderbird/Manifest b/mail-client/thunderbird/Manifest index 9bd86c4105c8..5914c2c8bad6 100644 --- a/mail-client/thunderbird/Manifest +++ b/mail-client/thunderbird/Manifest @@ -129,3 +129,68 @@ DIST thunderbird-128.4.3esr-vi.xpi 790928 BLAKE2B 9b3e0774be4c6577993edb4600a1ac DIST thunderbird-128.4.3esr-zh-CN.xpi 790744 BLAKE2B eec55be6a969b1993ba973ab90a1215772cb6cc9a22272cb70e33a15de847e3ef3c0c76eadd8cdea83732a08078a2c705adaeb819cce0e10b4b3cfca99d339d1 SHA512 4965e4fc8cbf8ec42e940d178c7eedf25ace3104cc33b90b7b1e1cb9b3818334fb3ddf5be058ee18b805e65122ec5c22b4f6045c841485e6940bbf3e6397d47d DIST thunderbird-128.4.3esr-zh-TW.xpi 794099 BLAKE2B a5c3218a692bde7d220eb8cfbdab7126347312b911910d57a168fcdf8709f2c2840ba31ce54ff33ead9f0627a450e94106e7b9a91399a4a449d1f1f68925ba62 SHA512 aa789247b4e853e95687072f5f5e93cf835b799b5d037558ad49230ee64b9494fde0328c1a792aac52f36ec050b0efda193f0ad7495f5f7c30c0f3ea9555ae75 DIST thunderbird-128.4.3esr.source.tar.xz 673965268 BLAKE2B 31954caf84b382149a8bef7f2c46dd86e93adeda8eb4553e7dc5831ac8e4108609c55f2c027397de9969dd9e651971a63ef4c719dc55a4987cb1bff0d5e6b8d0 SHA512 18691722f6376f3dc0658c01164fcdbf6008fc31eff8c1bd403d34f188db0e7850883315a96fc07289d207c9977d732628d3945736aa191fefd0a01735e3037d +DIST thunderbird-128.4.4esr-af.xpi 530349 BLAKE2B 68e19704fb7d4019fd29f083790c9b318141e9794e78f826ea0a24eb82033788079ed57dab278158781bc94029d2efe2b0593430ad739bc2366eeb75255686f6 SHA512 0d921a5b3e31df6fcdc71e56d0c436f9061635df5a947b65a380a650263836d29f7cce4d5b7c3bab18a4933b6f996454828744a2725d8836adbda5cf75ae1657 +DIST thunderbird-128.4.4esr-ar.xpi 686479 BLAKE2B 597760162f95be07802fd970368071a1be9357e0c578fb4dc49b54121df6f72ccc99efe4ee672eace422b0bb7a56e68ee8a1e8c207ccd413c2aa40628451a9b4 SHA512 841649ce1354f7334a7dcedba212cd64636c8b3c8ab1e2118ee14c3ae14decf9cc91690f40b836a2affa04f38cb584490f3a06a3420920fc89b9904996baee40 +DIST thunderbird-128.4.4esr-ast.xpi 561054 BLAKE2B fe33c10d50dc07300c8e5a4df10289b470ce0b4657b6c509fc97f361e3234e5901c27dc36e2b48fa8b0129dff46080d0c92e2a4dfc261da527ef25c8d29b09cd SHA512 d1bb988fbc33f95394e1b84fa45dab3e2ea8a3768af95c46571a1b5176af0e441743ed7264343f10e9b8b4939266a7867a298ac6c83230a379abc5acfc384d64 +DIST thunderbird-128.4.4esr-be.xpi 769119 BLAKE2B 4e90e132831e06f487f16ba964c08d597cb777fb34050b5b644906cc0c2c264a2916da6701e7ca27687f6dc300e079557e9ecc5d23e05759bc27e252aef80f40 SHA512 1a580678a17353db1f1df5b2dc5f5dd84e41a5eebe41af32196ff1a06dbf16c73f9429398fd8d52023338d86ae8a9622e9b400ed55e1de6c674680e5fb00990e +DIST thunderbird-128.4.4esr-bg.xpi 811600 BLAKE2B 67edadd6e29f23713e829404784d4f1d52139492832611e9c88a8ec7d003a691db93f4b73655416b67bf98a8aa7f5101e7694f70b2eb3b16bcb00ac62bc73779 SHA512 cf1809bda13805ddca66083183de63d1c35f2c66d7576f75fe7926399ed9e067b04eaede707be674b9ecc7a35476266accd4c5ea2f18563dd9ec281db33f9482 +DIST thunderbird-128.4.4esr-br.xpi 654631 BLAKE2B 88162381c80c81d833d0b8876652e94bf66dc154c7a31494075a5ddfe46057ce2ba82dd60b6ae78fba4845a62032f0dd8c23c9c4e278fb6172f7a75f52a060f7 SHA512 e764bbe29571d276be1b700d74ed4180de2ac02e87f6f025f6153aceffdb69497f7fca16c689a5ed71667f74c12ede948b8933acb1a71d1b78766cefcca067b3 +DIST thunderbird-128.4.4esr-ca.xpi 709854 BLAKE2B c8ae414f253a863b7beefb807ef0f20126834e31c5882cfbda9fd574c3a04eb3cec37da20cd87733cf55b7d579fc86208c9fab8d15653755e24876730c8d0354 SHA512 4884021301e7eead3d65992282de1a5614e62ca34178d4801ae369a367c80fcf0799ca0532644d70e405059788ba96c07c3c4442f9be843765322727d12914c0 +DIST thunderbird-128.4.4esr-cak.xpi 671703 BLAKE2B 4b8c716f2bf6f633f9b7d01ba4004eb6c8fc9dc83ea4e759c1448587ca3ab6bc411a14c4cf314f0d02d469a541ca3ba6ca5138591620ec183464b3081c649542 SHA512 476b8ac27f5f3568d49014c23caad54bcd29dda8ae4b8f79be328616c993ac9942a7de4ebf97dda13fe2cb33dd08bbe249872c50a788cd765e48936e6ee2366d +DIST thunderbird-128.4.4esr-cs.xpi 788816 BLAKE2B 27ca17bb2d3a631c125fcced58cc8e7e4b7b9571deb777f6d0852717bdbb966bcf41ef734c01a248143643d658255ea1feae15c7f9db8a58ffc116cb72059a4e SHA512 7eaab3dbb9c2e80859c9e7c4ba727117268a62fa2a49e31279718538c6d5e4d2886673c47951718b026012cd5428477e763e4313602d55991a21d87aa11cc82d +DIST thunderbird-128.4.4esr-cy.xpi 753452 BLAKE2B 11ef77ceb682661805f6310e61d6d051eaab78dfb8d8edfa2beb09b0a0b87a7d0004ea87e7b611a48833331917477ad7b77fe42fdaae9a57f70763dca9dd84ec SHA512 2f99bec0e89543250d08bb2d5c008dad5c64ce2d0ab4e569179251182f4683ad21ca6e4d79a74ad93a73c8986bfec1585f5dfef42ef8951ca6beb6b5f2756fbf +DIST thunderbird-128.4.4esr-da.xpi 737120 BLAKE2B 0ef97bb9c2dccd6bb6c00ab304dd2cb4ebdd6410145d2a397cc4b312c87b2dc750204a526f86773bd5ec5b5623f83ead74afb2b954aba58e12f9cb14b4a23ca0 SHA512 e598d4460aedcf5c853c6c728e00cb710fff791bd918900a383a45dceb08918368da76341d78194719112269eb20ba346513b3edbeacbfc4ae66e0a4cdaf28ee +DIST thunderbird-128.4.4esr-de.xpi 771021 BLAKE2B 6aa65be90f3eb5811df850270f89d83a46bc0176a2fa2a2a9c2653f047563189b470ba53498d8baa7ded1c05e1aaec8aa5195146587c89bc36a30017c8040558 SHA512 9a28e6f55d1c98956d55ab3d54f66b51e714b5619cfebdb66849f6c80683ada06c3fbb79b5fa1eb8a40d67d0c205db82858457c64d7898c503d51f22def06715 +DIST thunderbird-128.4.4esr-dsb.xpi 787772 BLAKE2B 97ee88d787c3cb72f12df184075641db2fccd0d6efe1fdec4d666da4ef88e4ccb55978b8c9b9309d9e318f5eb0850a1b11eb30c45cad0865a5f12de0088d05a1 SHA512 37abd46027d6e355aae158f0f05deb8ebf8c30f8a29b29b49798f0c957c700d49af7bc8641431694d5cce232298ca81a9fd6abe5b70fad556faa69b0f736682b +DIST thunderbird-128.4.4esr-el.xpi 894340 BLAKE2B da68f1b41321a72766e4a7b79d062497c8c9175fe762f6eeb83477d6f83770d6ab950bd43542cc0ef14455a5f170b6d20d8dd9829686f8335817ea0fbae6f67e SHA512 ccc3f0941cab1f5012b17e255484285adc3daea6cf717d37b4c0dd8fc2ac3ddeca2043a5c57b54034a1b3899f2717d9ec038c427f56d69207331c8671df426a3 +DIST thunderbird-128.4.4esr-en-CA.xpi 704736 BLAKE2B 64dcd0121bf0ad6b90e4719ebbb974fa38eab65af52a7ca96feb17f3a8ee07f9b27073fddf3934806a1a54ce16ff4f06072b45d7a7f6f76ac1a0d110a9e412b3 SHA512 3174dbbacf2b7da1fab3a1e9ba8571690103641b5aa57db92eba243c680fcbf7b41bd769a63515f76c181d41738de90a127d637fcaf5e906369ea03a3ad64129 +DIST thunderbird-128.4.4esr-en-GB.xpi 706803 BLAKE2B c607948911ab83bc883a10d8f084bb508c75fc34fb82381633ed01d47b8d594ef8c70f770b2b592eeb7e4924fdaf3c68502f1193eab8b4119ed7003ae0f34fd9 SHA512 837c18d26cd113ddb576cc04119b2389507a7f85735b2f544b313319d4dc6029f92e64e8c3c71ababf02dc30e597c35453be37600cd2dc89cfceeec986690e2c +DIST thunderbird-128.4.4esr-es-AR.xpi 762698 BLAKE2B 91e62f75d0fa124a66c882032a4ebafabaf68c3a505c16d1355e09a1e82999dd1e03e6ff2d6e50f5ed3c7875074e81a7b9bc5477110283de8a77b38962a304a2 SHA512 ca617ae57b0528907cdcaaab370653ff8846b8087cd276d8fa5b5122560e8de9ee7764b19bd0b63a82227bb618394d2ce6c895b59419e9c089f8f607a0e74f91 +DIST thunderbird-128.4.4esr-es-ES.xpi 729373 BLAKE2B f963e13473971b52e72d9933fc22287606de51c3232d45ca8d510933c45ccff067c1aa8b41bd9c812434e42e6cda09d4cb5c9e20f8836853c4354b089b0ed224 SHA512 a54b3784b8d3d85d8db5c4c5f0a5d30a186cfe614b2101bb181daaf4fff067b24d0b76c1b3529741f69a16e84e187062deb4d04841edb237fdc08be1b1ad38f4 +DIST thunderbird-128.4.4esr-es-MX.xpi 748409 BLAKE2B 9d9a937fb22acf29972c3e8c51f37ed806a6041a915c39abcb01038437db6295065bdc6813262c66aab31f6d4a773c59b68623ec6e49990b4ce7dc55061e41f7 SHA512 fef07803171194189b325a85acd557a9d33567fd83afae192a46a1e568c2f7656e6b0c2bc7b1e5c03a7285a3601fa2dd79f68a9b5397decd0a684a3621bec3f7 +DIST thunderbird-128.4.4esr-et.xpi 696281 BLAKE2B 03fc02f993a7e0759e3e19204839cda19f998720f61637749db8b5e073782c5585a070328b1d7805eea2017f48694319b01db7d5b56771a701b51a1b891944d1 SHA512 5af67957a924756a064244d745e24ff7efb33cf8edd1a6059b00a85d9e861519be268eac7162caf5ea9acb92e5705c3bbd87629a01cd5def20d7ad7e05e14fad +DIST thunderbird-128.4.4esr-eu.xpi 734389 BLAKE2B fbd27718a01b3a55fb92ae4b83368f62571f69330b92576870952c34fe10e3712e2106d0d3d70d396956d3a74a986a339905abf8d3fab07050d7edd06d4f2287 SHA512 4ef6e401f4ffd29decd05a3bc10e4515a0d65a81ae0831f154fd60361e45a1949df2952f71796527ed4cc6a479b3a4d606091ecb79ab893498c1d9efdeadbb4d +DIST thunderbird-128.4.4esr-fi.xpi 738610 BLAKE2B 6dc4b37e8bf8b9fe5f44218c430a6194ec8cab726ec449734eda7e51ff3a75b3392f6231005bc168bf226fc9ff1b1594cd25da4954483a6f5ef853f3d614625e SHA512 17192431de7cf5495963d83eb2b1bd370a3a8f0a8e0b912462a8a56867cbcd84a41f9b2b8bbf7bfc635de66f480e32e1f67bf23f491506b56869405702250b79 +DIST thunderbird-128.4.4esr-fr.xpi 775788 BLAKE2B 95109a9b332aa350c556e9d7e2024fe587ecf521c40da0228db12b871e563fe0591ce0aed826c37cccc9c56f96fe444acb723ec9353e7dae0f5d7f4e57d6c5a9 SHA512 e91229a65f7f6d8d49c4360c94a6a416aac80cf61b821a3f1973a476a7b3b44140e3322350aaca0eeba381200165eff91b35b3658b7166b6c18ad5ceb7b6d310 +DIST thunderbird-128.4.4esr-fy-NL.xpi 755944 BLAKE2B 3ad4c74a94499450fed862eff35680895181feed975041088e95ca55d1f28d887a7799015f6a70aeb785d4eb5afeddb8222f4aece5558bea2591cf6ff4c3ab6f SHA512 059504b3f1d2f084fe04462ddf7cbe909f0e2982844fb14d78ddcc34c340af41a17eddf0983fa0f5fdea138bc7903b80f5b618d01a144e8d49ad7c8b82ffa9e9 +DIST thunderbird-128.4.4esr-ga-IE.xpi 615879 BLAKE2B df319c78feb62944f09fcb901ac7fdd6dce01c82cf1c2efbe00ec415386390c875c2ba75856912fba74d65ac7f9f21a1ca5b4b1a4282e0f0f133632a625a7492 SHA512 423c8964e2dc68ff6eb9224a9ac1f4a93c110df9cabc28d82a73708bca2462654b7552799d376a0ae8c66b2e9a2994913fd18af317f6eb4cc858a8b385d21e68 +DIST thunderbird-128.4.4esr-gd.xpi 728645 BLAKE2B f44306b1438a451740360bdfce3f516bf6e07c1c5e164ce0372e4ce38fb6b1e6e2ba14dc69d4f6560e7b28459c5a08fd504cfab90495ed296241199bf35c8cb0 SHA512 ff1d218f35c437905adb6844cd6a7a45eacf0bc7d89cf2ee55fe78c7e39d04dbee8d23da48af1bc0f2136f8672ceed5beaaca1003695cefee87d0b3192ec44d4 +DIST thunderbird-128.4.4esr-gl.xpi 741682 BLAKE2B 23e9a2c453af966f64da7bffaab1c40b78467fc02a0097f27f7a19070dc47d6ee4957de50964a9ab557040650c01e18c7edb1e6f51ce6b27d281ad9b7efd30f7 SHA512 84839f342c3d1eab23aea2ade1172f1a8dc36de07c9f88273dcc6fc7ae1fda3e31514ff0d7bc7b5ca1d677b4562a275c4c9ae34f8c2eceae299d2d99ef04c788 +DIST thunderbird-128.4.4esr-he.xpi 700947 BLAKE2B 4f3ebc8b6d46a660cc2ff7a384bf33e86fea508ecadc7deeaa9065641e2a7535ad91d8af83e9e606ff8e7911e172c5162df31e72ddf7de66e6cfe4c3eed878dd SHA512 bd648910a7ba14b2831942e8b459b29af5af1859d168843e3be47fd0f541775871327b5b5a94be7a5214a27f0995e7b7ee0037fc46f1993129be2874157e1a04 +DIST thunderbird-128.4.4esr-hr.xpi 719846 BLAKE2B 2514efd8a5858fcdca3f5c50c6e3fec5a0e86fd414b0ad044ae45b3957664866c2b434bbe7e7380a5c72149eca1314a08492b4f7b9343e232447e4b9eab9a345 SHA512 8e388e6fd548eef5b2b10a0ccbac34e3940002fceb5be595c7e710b4a9e352bb0afad75ed200e40f84ec8001242de5a22531ef80fea5f431e13be80f1e7f4a96 +DIST thunderbird-128.4.4esr-hsb.xpi 785170 BLAKE2B 7ea2d858b34fdac9f35a6ee3a01215e13d58b13fa27000b40abebd13253d1cb87405259dec8ee8c791374ef1a489aaaf66d658e6da5df17c5cbb58f5a02874a7 SHA512 2b24f598a2fd1fc9360cb4bc51a7cd6412d2a85b09c5ec40606d2c2f4192ea7c0552ddbe4ecfb4514894c6d3c6e5713a1f0ede7e49d60a71bd58587ed0fb3eee +DIST thunderbird-128.4.4esr-hu.xpi 787990 BLAKE2B 20a9a6c532126074a34702304fb276655c46c72b41ff741fc1690ed850160a0f9d49d161c3f943877cf43ef7906c741f319b8aff5cd89de3458f27ddcfccdfae SHA512 5ab2fbddc39f9712c3691a159ffec7b6364525dd2a710e1860a7baa53ce5688c0d0f402eb7d45b472feeb2bf9b2ec1fd04675c66d623e4b274ecc5855293920b +DIST thunderbird-128.4.4esr-id.xpi 666012 BLAKE2B 0599945f8ff277340409c1f229361f173210ba79db4e46318e6f37ba92c6644fc0433b4b006710f2dae59be41bf931c227eb6a4b3bffe33bb29597c100a86647 SHA512 f7934cf045a94f46e31f58a5c91c087fc411cf72357643ada7e2751a54cf73e3d00bf728264d67edd7603c933f44ccb4d084e6852082f2bce6616e24c4cf6d40 +DIST thunderbird-128.4.4esr-is.xpi 747036 BLAKE2B b93a96fe0baa4132405ac1dca581125e1a3ad604aefe4df8a7d9aa676876df5694c5157d7bdb825ff98a2328da8df4a9fe1e6a0ee43e4655b18d738ec77317f0 SHA512 26363744fabe2a23cf8f701ad192a5f39ce34c252f20676035b96cc8ec81c504804b9c9c991d92d0b62730171d4dbd0ecd3a9f7d5e8469888778e1d498df7c7f +DIST thunderbird-128.4.4esr-it.xpi 694514 BLAKE2B d8dc27dfd7e72fe58b04431dc607df4b06327e55b9ab1944336554c73413a285124d8503b1d54ce6f659ac7c96306fdcaf86a74316d310d0da656fdeb6b5cfe6 SHA512 09fd2653c9fae89ce5270f92ab0b4d86fb89d0983891867396d9a10e2d0b3ae1393766306148bbe2ab3008a9a29bfb5f11e984c2feae14e7379501aff463acee +DIST thunderbird-128.4.4esr-ja.xpi 824169 BLAKE2B c82457defbab58ae29655b537f9341dd8f21371a1a45f6c7da1f4b438253410aaf9198045e5643b31b7ca52b6e59fc9b9ef958de1907459485c3809b34421785 SHA512 ab2cf3b8dac98690305c8cea57a69cc06984ffb52d4ef25939a8943e640a1b0b5382453eab376597c1decede7a438aa80156a67c36cb7e816d5941c3a67b451e +DIST thunderbird-128.4.4esr-ka.xpi 796222 BLAKE2B 203368a688f5f72fe5991360857dd21f6cd1e720b718da63a202f386cb2597abba4daa8c3d629870fae6d27116f32b0a5c31733f9c83fe113e54f367fb517a7b SHA512 6434dbf300d4db892a9f78ead0845fea4184250a68f45ead47fdc1f300cd473b5d60a4d1d6f73d04df9ee2a7048461ecb054395c28ee1d9536e34092ebfc84f6 +DIST thunderbird-128.4.4esr-kab.xpi 733902 BLAKE2B 50a9f0abc30933c891bd0236a2d112b19a86445e3751301c172a7d36bb9091ff1c64433826989822c4108c9f145fc1631b89ff8f96d867ae372ace00db919a59 SHA512 0b3c34f653cf5c2a19814549fefa04c572216e65db05bf400a0a52e5a5021c5473ebd30e4a34093d4e693807a9072e93c87a21cbc5add962f371c78f6b817914 +DIST thunderbird-128.4.4esr-kk.xpi 860676 BLAKE2B 31faa057852dbc6bfb90099b91b21c09769788161d41cbc1c5b35d09434a000125609f25c637fb950c35d311bb0120e7af1f9ad5385d0a9efa9c85bc3ebe17b8 SHA512 b21305f7435d72f47baae49cba7a423e6e3d6692325c953c096fa583e675e4d48c097bd0ea7e4442d83f079de56ccd1fe0790dd01a7cd2f432d1c3b6329d025e +DIST thunderbird-128.4.4esr-ko.xpi 756768 BLAKE2B e96f7d4bc1881c90dae99d7e005a0e4985218c61aeffda9eed21c0dba96ab7f272a68250b8c13281283192345f08fddd7152c56f46e7a1ef96a8746351cb57b8 SHA512 88a1bad45000d8998054582d06003efe7bf8faec7bd5fa9ade8f8f35956a6dff94c87e212aeed732998aef78f30395c4a1c46d5649aa2bf45b5471fdaac94b7b +DIST thunderbird-128.4.4esr-lt.xpi 700919 BLAKE2B 2c0651f16739191e24806feae83d2ce11d13728bf47116de72fbbff4ad8bd6bc096812d841ed9ec41629bbf863589adb48fddedb393890d4555e06ad2f6406e9 SHA512 218e4c8dcb14db210ff688c549eefdd859bbd0a955386fe3ae1cf7d42f93aa659af471b7bae3df6baa2ab4a5449de0d52451aba57a27f44c73428cf477c71944 +DIST thunderbird-128.4.4esr-lv.xpi 625981 BLAKE2B a0991a79cf50854349c404e2e24b52fdc3b265e7a702c6d2895034bc8a07f7d5687c7407ab09411f01e410235b75a1cc02b397363098276467984053d38a047e SHA512 c0bc929e169ee882a5409dfe17032fae4f06fd2b26f6108028f42838c8c4c1bc9395d993548e1c571b38505fd76e7a622efdc1eca35d1631310fd4474df32016 +DIST thunderbird-128.4.4esr-ms.xpi 581084 BLAKE2B 786f1f371362fa870fb48ffcde86fb32b9828c297d4d0bbc9e8adc75edf5d7d55f3b16bb67c7f3c1ca3cc08360164a75c821fd1da485c7c7460859436f44cbb9 SHA512 97866fbda474893c023116f9bafe3429bae8cdb7f2f5b7b3d03a17556876b1442ebcf04f026a038ee8b87beb0da7d6445f9c724bbcd31db55b19d789a55d53a4 +DIST thunderbird-128.4.4esr-nb-NO.xpi 706104 BLAKE2B 05877b8aebcbf445c584e09fd75a74e52123709bec94771a4da9068be2044eb6672c64a89fb045916f21dda9d7186cae8b82570b048519ed8a1ae7c0661f4038 SHA512 07913b4541f8fbaa0e1d43b17f72fcd43b367cee9a1781d22c3642eb2d1ce76f4666e657fe61cc133d79f7289cdc27315c9390ad13a16af9ba8c312cdf389521 +DIST thunderbird-128.4.4esr-nl.xpi 748484 BLAKE2B 17dc4e149ffefd2f47bc7e4bb330daa656953feac057dc19f3fd15f0b1673075541376ff94ab7f64063a87ef00ed769f3e7d1c4e101df3d02b70f84b9992104e SHA512 b81b56dee44284503c41635f458dad46391f1ab27faa91769fdf64d42ce4a8174b05abbb33b2ec794a366c7b7967fb25ab1439a4661c3f86f789773b0a378323 +DIST thunderbird-128.4.4esr-nn-NO.xpi 726987 BLAKE2B d2ccaea17f2a09152ed1c57a58d5b6663ea1b26fda53c71367bf48a77b9ff6759ce0551ce23ef64b14dd97199f3fbedd6ffc86e6283eb521ec64d1bfa7871048 SHA512 fdb2742bf498d3196d4ce30b44b3fc7a282ae1fd12e59de8b6bf4eaa2e31a346918d27e7218278ff5269385e3ca0f0949acac7e5b11ce3223d280f361d278ec3 +DIST thunderbird-128.4.4esr-pa-IN.xpi 685675 BLAKE2B 126524b39f7c4dd197540be08849c54ff4fc3a7bf33bf13987cad84bda81438a1f81a814245cddf69360d44da6520166bded1cd82434ced9bd2b7e7a7782f7f2 SHA512 7006cb3929b96856ccfba11bc1dc3931188c53f7f108b8a341a6feaf7138bd0e6e32102f6a597c30a89033c32d567bb176c850db020731534cf0934a4263de6d +DIST thunderbird-128.4.4esr-pl.xpi 767304 BLAKE2B dbdaf77fcfa5d463e09552727714b0e84c397b8148b3c65ee8db8768a90fd90b453b9b11444957b47a9ef415296b17c22b7ea9e6d06bdd5b06d04a1ece44a4ab SHA512 e19a5a41801081ee2f5f000af0a01b6a2a25bee97881fae4fc5f78a33294c06fe87fee4af7599d5c5eea54c9a27e78c00b63f6dad9b23857a64981161aececb6 +DIST thunderbird-128.4.4esr-pt-BR.xpi 755727 BLAKE2B 6075976be7b2421cd8e6b98b21e299563f25bf5525a7e108b51218a622208c3294c3b4c0a7b4c0a28759420306a0467c50e96865fc0d839420badada6bcf0262 SHA512 be25a575b60752018845ebe7483d99c9f1ab5ec5b3f50e67d6626182260cd13bafadc59e9120dd080d4bbeb69455f09cf3454789e6ad1248f89e031b34538679 +DIST thunderbird-128.4.4esr-pt-PT.xpi 750495 BLAKE2B dbb4fe7c7ce7ece69a37eeea11b31ca0e4e29b6960dd154960af7b0447cad3522e4353d6939857f5460020796ed5a04af835ed6e7eff2eec299635a6fe112e73 SHA512 a9c6a39eb60098caa8155b6b387063656161f2838ada540375624aa78bdd82008d57900f3100033742e282264e73cc81a7a00a72a4c6eb97d0046a1e26613913 +DIST thunderbird-128.4.4esr-rm.xpi 751458 BLAKE2B 967de42110a750d88c9f875eb03c8721bfb70a72cfd0fa425a78c677295af8cf0e1dbace91413377a9d851e1e1660df1770faac4da54272e8e73f027d5f3a285 SHA512 6badc345ab73e4db3c64d5492ce7cf7f8226c6c80b6160f555fa42f00900cb166429da5caa8a828a1a3cea8b7516ba330825a20cafb454a6cf985565957f1602 +DIST thunderbird-128.4.4esr-ro.xpi 669743 BLAKE2B 99792248f5c00b2faf129f1c1144a627b5f74a2604383479a658dbe63513f3e7b165e9d0a837dd0c8ecc704d69bdc49b3c687d7ee84323580b81c91fe05e2714 SHA512 026fd78dfb4548060b76d589d58a29db18f7751c1dcc2fc7ce19cdd743d492edf8f810e2edf610afbabfefac26b1941356c28c807f2792929c46cd93f6b46338 +DIST thunderbird-128.4.4esr-ru.xpi 877214 BLAKE2B 8393c8cd0ff01be01418512ab3adbdb51255d79f76cc345c03c7bfcaf691ca6a10586bce34392e9aa2e5ac36ecaca63c31442dfbca992b5f8f4fbb16892dd84e SHA512 9ef501c67f9c5686096ee0f946e5b778928bd2edf027965493cbb3deaa4abe508c93f7ca6450b3ad52bed52ab74f7106fb260b0e73f0824cf3a44e10b0da0910 +DIST thunderbird-128.4.4esr-sk.xpi 788763 BLAKE2B ccb3fc8ba85f049813b2a3e3b494d5088e58b44684e70a28de1e10f735c26eb63a9187c670a7a66906e35b36685e7182ef31d103bbd1b2341c271cc8c4fe9671 SHA512 411619eced8cbb5a0e7712d1a6ef20bba777491e3c3c8c3d139a9ed21eeac3529445bdacce3e57631dd3d047b6f9d36cd16beb07f83443a688fe4b2ea662f03f +DIST thunderbird-128.4.4esr-sl.xpi 749577 BLAKE2B 9b8109eb656558f4b3e8ec3f015098c6f37bafe5ac8b2857c6f0dc978fe500897fab586fb00115b72bde2bb129ff2cb3123784fea5785bd580e199d931457021 SHA512 eb6297918da31118003aee23da2cfca35913e63c4ff10a6763cfcdedf0d3e91ca6bf5aa2bef21c4f2a454236516b82ce9f682815754e38816ab9c0c75b1b860a +DIST thunderbird-128.4.4esr-sq.xpi 771528 BLAKE2B 6fc2326408d16f9b5dbad311bbd8096a51c652a7524fa31756d074db70e1fe2784dba91203382a788fca1c002af79acb7817d4ed59a9088030d1d6262921983a SHA512 3d98e394b4e0ea975d6a2ef9108ac8a81752e28fb5dc6f221b54873fcbabaa2cb8d32552f3ee8b6bafa60c59dc18cde28926c5d1a25412d43671da638e2dbda3 +DIST thunderbird-128.4.4esr-sr.xpi 771225 BLAKE2B ffe274e307dc371b95bb23fe12980ffc1a1fc69c11841642350883f4ecd869cb61a259d8bbb71885ef831cfbabd099eff2ccceff8e3505227ed4a18f99280033 SHA512 b6fa3f1831fedb4e98c496b35991f25cdb8e06c04085c7e8eb2c0d0a6c986bcab6764712527ad31e8fa234356fce8700fc63fdcc0023f71fcadd2b914149bb5b +DIST thunderbird-128.4.4esr-sv-SE.xpi 751824 BLAKE2B 3cb200e3cf66247035e7557fa976d6476e09207d68de5123096acb9161579dec1709b5d9f35cc4b28c8ff5f892f5fe24d1d15c201a244114e431d696d368d47f SHA512 a21f01ba0627129bab06c62d80188a0e5caf07bef30491a2a91b2019e50c3cc85c58b0d55688267173854338c0224d78e5e41078d42bf536fb4f7c3313762df7 +DIST thunderbird-128.4.4esr-th.xpi 815950 BLAKE2B 65d6724441aac7a242998b85aed68ab79944e216d6c0a2d84072db7f2f0f88c43d17af9bd2ddde9966d1419a02755bc1611145b533c983f9c64769f908bd5b3f SHA512 a2ed2042867f31deb437e5c0216e3bc7b793b69ccd2f57642d3d42d5c73b7c062448912d3b486d25be37d8f1b7a3d5f4d0550e492cfa5b31ad630b0221382cd7 +DIST thunderbird-128.4.4esr-tr.xpi 761635 BLAKE2B d2a50602405c28d910af99949b8b9c9a4da5694387720bde3d87ebcad11645650c35b7e05a4150790f4a722fda05b7a5a353c5b733de6eefc5e97a90188f9497 SHA512 fb96c118e444b0d8588d8155f348ceab941a4940b9b8ca80c4d82ed6149bf027fb9703ce8a0d70f54e9aeddd097248876b0cb814f00767a91b6b308df518d69e +DIST thunderbird-128.4.4esr-uk.xpi 867539 BLAKE2B 35ebf051d085e581f8aa013904b5fb629392ebedbbb3f3987bf901fe5e8aba07cd9f6c3fc700ee9f0758f28249a52d9b6b79ae3deb9047831a293d87a081ed5c SHA512 35704c3e0e7697f8bb50e3e8dba94d4124fc663d13d8eed86de4b04b01f1361a6b98065a748b2e7091bcd3f2dc201bf804b0ced471423ec7bbdc2e8f7588b42d +DIST thunderbird-128.4.4esr-uz.xpi 592134 BLAKE2B 428385b973c75b047eca627a01f1f0f59200cb53a4f0ff17e4fa22e2992829e9c02145654b5c2b8af2bf49715faf4544f75e3a9c37f3a60193a00dce5e5bc1ec SHA512 b53733ca5361b45d3ae82982634941decdc7f7dc2615708bd758d1cc9fb0254255c4ed3f375df0ecb70cf0cffce0a2c1e8b25cea0530666ae6556a617be95c9c +DIST thunderbird-128.4.4esr-vi.xpi 790930 BLAKE2B 4dfe68aec8a41ffb4baa48cbc27aaf379e9946a41324aa85e5e524aa09aaae0c3618b1f20cd10a2434f8745331079effe68c42091848ed13b6dac3560a8f9d06 SHA512 f3de9253eb9c5761cf18e2d1c4247d971e3ab577a1eaeb83b9ec059910970adbcfcfcfb66c61866fb83f4eb978506d638a9601b3acb2e3c4b7cc32be21866cb3 +DIST thunderbird-128.4.4esr-zh-CN.xpi 790746 BLAKE2B a9190edb5c4be0afbba068791559bb9b1b3699f29dc770120c7e9e7b8672bacd7595c53790af7a7b4c042df01f84ee58996a4c50ae8e434eeb6b152329a8edde SHA512 ccdfc3016201d3bd89f6970e22003ff9253ceda879be068d42bf43322148fabc125ffa1c9368715f0405c9c06a7259fc81029b21551547e6d5e804babcb86a0c +DIST thunderbird-128.4.4esr-zh-TW.xpi 794100 BLAKE2B 9266ac41e404554f1268887a00b146c6df1e1d9715913c0f25b1ab4761ed57517871bb71f8a14d4dbf8489844cee01300afbd59af6c0f0326087b41431415aa2 SHA512 310a77fd1ef840fbd995821cb615194bc0776505d5aa53f9a691481a85ef32d6cc4498aab4c1a9b70f0229376a64699bc2f6dec873985156465d64298b0248ea +DIST thunderbird-128.4.4esr.source.tar.xz 677533120 BLAKE2B 73a54041068d2e2e824f64a34754345c2c020e63ea2c2767049d119580cdd0c3d587c7e841e2845f4220a7a4721158e51a67cd679d020a10bb2313d5249607fb SHA512 1affd4049fd014116a5a3f5693f38245a21adef498213d72c1d0d98ec9ead152448f5ec089b2a5e91d19c41a90857f8c134ae30a62a44dd68c680a1ddc6b111a diff --git a/mail-client/thunderbird/thunderbird-128.4.4.ebuild b/mail-client/thunderbird/thunderbird-128.4.4.ebuild new file mode 100644 index 000000000000..0ec3fb734152 --- /dev/null +++ b/mail-client/thunderbird/thunderbird-128.4.4.ebuild @@ -0,0 +1,1156 @@ +# Copyright 1999-2024 Gentoo Authors +# Distributed under the terms of the GNU General Public License v2 + +EAPI=8 + +FIREFOX_PATCHSET="firefox-128esr-patches-05.tar.xz" + +LLVM_COMPAT=( 17 18 19 ) + +PYTHON_COMPAT=( python3_{10..12} ) +PYTHON_REQ_USE="ncurses,sqlite,ssl" + +RUST_MIN_VER="1.77.1" +RUST_NEEDS_LLVM=1 + +WANT_AUTOCONF="2.1" + +VIRTUALX_REQUIRED="manual" + +# Thunderbird will have separate release and esr channels, matching Firefox's rapid and esr. +MOZ_ESR=yes + +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-r1 multiprocessing \ + optfeature pax-utils python-any-r1 rust toolchain-funcs virtualx xdg + +DESCRIPTION="Thunderbird Mail Client" +HOMEPAGE="https://www.thunderbird.net/" + +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[@]}" +S="${WORKDIR}/${PN}-${PV%_*}" + +LICENSE="MPL-2.0 GPL-2 LGPL-2.1" +SLOT="0" +KEYWORDS="~amd64 ~arm64 ~ppc64 ~x86" + +IUSE="clang +dbus debug eme-free hardened hwaccel jack libproxy lto pgo pulseaudio sndio selinux" +IUSE+=" +system-av1 +system-harfbuzz +system-icu +system-jpeg +system-libevent +system-libvpx" +IUSE+=" system-png +system-webp wayland wifi +X" + +# Thunderbird-only USE flags. +IUSE+=" +rust-extensions +system-librnp" + +REQUIRED_USE="|| ( X wayland ) + debug? ( !system-av1 ) + pgo? ( lto ) + rust-extensions? ( dbus ) + wayland? ( dbus ) + wifi? ( dbus )" + +TB_ONLY_DEPEND="selinux? ( sec-policy/selinux-thunderbird ) + !system-librnp? ( dev-libs/jsoncpp ) + system-librnp? ( >=dev-util/librnp-0.17.1 )" +BDEPEND="${PYTHON_DEPS} + $(llvm_gen_dep ' + sys-devel/clang:${LLVM_SLOT} + sys-devel/llvm:${LLVM_SLOT} + clang? ( + sys-devel/lld:${LLVM_SLOT} + pgo? ( sys-libs/compiler-rt-sanitizers:${LLVM_SLOT}[profile] ) + ) + ') + app-alternatives/awk + app-arch/unzip + app-arch/zip + >=dev-util/cbindgen-0.26.0 + net-libs/nodejs + virtual/pkgconfig + 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 + ) + !X? ( + || ( + gui-wm/tinywl + <gui-libs/wlroots-0.17.3[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.101 + >=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:2 + x11-libs/pango + x11-libs/pixman + dbus? ( 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] + ) + wifi? ( + kernel_linux? ( + || ( + net-misc/networkmanager + net-misc/connman[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/libXrandr + x11-libs/libxcb:= + )" +RDEPEND="${COMMON_DEPEND} + jack? ( virtual/jack )" +DEPEND="${COMMON_DEPEND} + X? ( + x11-base/xorg-proto + x11-libs/libICE + x11-libs/libSM + )" + +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 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!" >&2 + einfo "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}" +} + +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' + + 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-r1_pkg_setup + rust_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 + + # Clear tons of conditions, since PGO is hardware-dependant. + addpredict /dev + 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 + + # Workaround for bgo#917599 + if has_version ">=dev-libs/icu-74.1" && use system-icu ; then + eapply "${WORKDIR}"/firefox-patches/*-bmo-1862601-system-icu-74.patch + fi + rm -v "${WORKDIR}"/firefox-patches/*-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 "Failed sedding multiprocessing.cpu_count" + + # Make ICU respect MAKEOPTS + sed -i -e "s/multiprocessing.cpu_count()/$(makeopts_jobs)/" \ + "${S}"/intl/icu_sources_data.py || die "Failed sedding multiprocessing.cpu_count" + + # Respect MAKEOPTS all around (maybe some find+sed is better) + sed -i -e "s/multiprocessing.cpu_count()/$(makeopts_jobs)/" \ + "${S}"/python/mozbuild/mozbuild/base.py || die "Failed sedding multiprocessing.cpu_count" + + sed -i -e "s/multiprocessing.cpu_count()/$(makeopts_jobs)/" \ + "${S}"/third_party/libwebrtc/build/toolchain/get_cpu_count.py || die "Failed sedding multiprocessing.cpu_count" + + sed -i -e "s/multiprocessing.cpu_count()/$(makeopts_jobs)/" \ + "${S}"/third_party/libwebrtc/build/toolchain/get_concurrent_links.py || + die "Failed sedding multiprocessing.cpu_count" + + sed -i -e "s/multiprocessing.cpu_count()/$(makeopts_jobs)/" \ + "${S}"/third_party/python/gyp/pylib/gyp/input.py || die "Failed sedding multiprocessing.cpu_count" + + sed -i -e "s/multiprocessing.cpu_count()/$(makeopts_jobs)/" \ + "${S}"/python/mozbuild/mozbuild/code_analysis/mach_commands.py || die "Failed sedding multiprocessing.cpu_count" + + # 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 checksums from cargo crates we've manually patched. + # moz_clear_vendor_checksums xyz + + # 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" + + # Configuration tests expect llvm-readelf output, bug 913130 + READELF="llvm-readelf" + + tc-export CC CXX LD AR AS NM OBJDUMP RANLIB READELF 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-disk-remnant-avoidance \ + --disable-geckodriver \ + --disable-gpsd \ + --disable-install-strip \ + --disable-legacy-profile-creation \ + --disable-parental-controls \ + --disable-strip \ + --disable-tests \ + --disable-updater \ + --disable-valgrind \ + --disable-wmf \ + --enable-js-shell \ + --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 ; 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_enable rust-extensions thunderbird-rust + + 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" + + # Increase the FORTIFY_SOURCE value, #910071. + sed -i -e '/-D_FORTIFY_SOURCE=/s:2:3:' "${S}"/build/moz.configure/toolchain.configure || die + 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-x11-only + fi + + # LTO is handled via configure. + # -Werror=lto-type-mismatch -Werror=odr are going to fail with GCC, + # bmo#1516758, bgo#942288 + filter-lto + filter-flags -Werror=lto-type-mismatch -Werror=odr + + if use lto ; then + if use clang ; then + # Upstream only supports lld or mold when using clang. + if tc-ld-is-mold ; then + # mold expects the -flto line from *FLAGS configuration, bgo#923119 + append-ldflags "-flto=thin" + 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 + + mozconfig_use_enable debug + if use debug ; then + mozconfig_add_options_ac '+debug' --disable-optimize + mozconfig_add_options_ac '+debug' --enable-jemalloc + 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*' + + # elf-hack + # Filter "-z,pack-relative-relocs" and let the build system handle it instead. + if use amd64 || use x86 ; then + filter-flags "-z,pack-relative-relocs" + + if tc-ld-is-mold ; then + # relr-elf-hack is currently broken with mold, bgo#916259 + mozconfig_add_options_ac 'disable elf-hack with mold linker' --disable-elf-hack + else + mozconfig_add_options_ac 'relr elf-hack' --enable-elf-hack=relr + fi + elif use ppc64 || use riscv ; then + # '--disable-elf-hack' is not recognized on ppc64/riscv, + # see bgo #917049, #930046 + :; + else + mozconfig_add_options_ac 'disable elf-hack on non-supported arches' --disable-elf-hack + fi + + if ! use elibc_glibc; then + mozconfig_add_options_ac '!elibc_glibc' --disable-jemalloc + fi + + # System-av1 fix + use system-av1 && append-ldflags "-Wl,--undefined-version" + + # 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 + + export MACH_BUILD_PYTHON_NATIVE_PACKAGE_SOURCE="none" + + # 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-r1.js gentoo-prefs.js + + local GENTOO_PREFS="${ED}${PREFS_DIR}/gentoo-prefs.js" + + # 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 + + # 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 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:@DEFAULT_WAYLAND@:${use_wayland}:" \ + "${ED}/usr/bin/${PN}" || die +} + +pkg_postinst() { + xdg_pkg_postinst + + 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 +} |