commit: 911c97c324ef64d77a6d8530144eb9835264d3da Author: Joonas Niilola <juippis <AT> gentoo <DOT> org> AuthorDate: Wed Nov 16 09:31:00 2022 +0000 Commit: Joonas Niilola <juippis <AT> gentoo <DOT> org> CommitDate: Wed Nov 16 09:31:52 2022 +0000 URL: https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=911c97c3
mail-client/thunderbird: add 102.5.0 - depend on newly created virtual/rust:0/llvm-* in order to try and avoid mixing these sensitive rust-llvm-lld mismatches - sm will follow, - update LLVM compatibility to 15. Signed-off-by: Joonas Niilola <juippis <AT> gentoo.org> mail-client/thunderbird/Manifest | 65 ++ mail-client/thunderbird/thunderbird-102.5.0.ebuild | 1170 ++++++++++++++++++++ 2 files changed, 1235 insertions(+) diff --git a/mail-client/thunderbird/Manifest b/mail-client/thunderbird/Manifest index 4a05d0f6354c..23dc7d89b9b9 100644 --- a/mail-client/thunderbird/Manifest +++ b/mail-client/thunderbird/Manifest @@ -130,3 +130,68 @@ DIST thunderbird-102.4.2-vi.xpi 724848 BLAKE2B d63dda61aece0d1e229ee0bca54f4cc7c DIST thunderbird-102.4.2-zh-CN.xpi 722698 BLAKE2B d8a466c7c3cfa4d7a710be4429a5b1d9342b298fcd4848baf6601df1f122085c0ed6c921bd25c352cbd0441e07e8b2bf2a220cc73a0e3cae3b7760ddd65150e7 SHA512 a5ae3a7aa426bfaf44d13230f14589f56d92bc0b75b4fd24b8c746e7f758492ff21f2bdfd426a578434c35dbc7367bd5eada1961a809a3b303453dd99796777b DIST thunderbird-102.4.2-zh-TW.xpi 725969 BLAKE2B 15b0798c234180778c17cb1363218d5d190f7c63b7d3ddc06a13f77d9fd40a1ce664a17890c849bae502ddd0cf82f7eaaea8f003042310de80f2fadff1617d49 SHA512 6ddc7bd5aa084658253d228388af2cab035d611131ea2e4e84a6fea5f48c5402e463851d15faa979da1fc7b96535a1ee0aff6de4ebfa91f0f6dc4915da695adf DIST thunderbird-102.4.2.source.tar.xz 500913544 BLAKE2B d20177ac0191ee85d972fd11705a5a1a86fcd8265e3bb9c24c1413a0175a76094d9b775ea97217e2b5f7413ab3e3766ac5d167c8ed2622c786a0d5aa1d13211f SHA512 d74045e3ded718b9dffbf9f076f61f05be63d1914cca672c5145f86e94677df35c0c86958e31aee4f6388052c766b9588b942ab8578bc214addd49edfaa04a4f +DIST thunderbird-102.5.0-af.xpi 551372 BLAKE2B 825b30af561774079ad4ba5729e8fa573430e7442be3df494d972650856764a91b38c3e69e7f08a62607167d92295ac2dc962c67d92447daaecf8eefafd3e0d0 SHA512 87f88bcfcf80796e045048d30f1642eb617113984cba2ee99f097cb6a21bcefc3d33111600aa90af6a1037d0a588f017710398be07628cfcae05afeecfec0331 +DIST thunderbird-102.5.0-ar.xpi 656150 BLAKE2B 22c476028d8ed1164eab9b3954fd830c55d35db77b4159e05bfa29bf0d0e87498328ee30a0d3f9fa2a625faf28994c43957e824474470b67195fdf3404938a5d SHA512 9c8216f3fadbee50fa717b3decde8ced664f198f079a4e833de354203d78524467216522db8e93051c5ef8687691b3718936b59dd0e5a0b16d35599cfde52771 +DIST thunderbird-102.5.0-ast.xpi 564286 BLAKE2B 313fa27e3d7be871cc30b738991973491d9401b42ef81052f4c7fbe72631439cf3e657aab35f7b41fd32e56a09d9c1104dbf446d2ca7a6e69797917cb60d17b8 SHA512 6339a03f717e1bda4b37834095aebadbf7db8ba00980508b48c54907db56bb3f925583c564e131353df2aa84e3d0cdf09858b78883e000df7124964fa0baf518 +DIST thunderbird-102.5.0-be.xpi 686679 BLAKE2B cbcfc10ca7b087daddd1701bbb8f7c38211afc1acb9db6299468b577670aad7a4f8dcd3da3dfedd2213de413d0ddef68b969f4fca55e524813cad5caad9e2f7c SHA512 4c4176c8036d11d07fbb566a98e5fdce1aaf5806c6bd88d393e74be65d465ea0d0123a5fc0318c2e7486b6631387e849ab9c963142aad078bd57ecf8f8d17e3d +DIST thunderbird-102.5.0-bg.xpi 682267 BLAKE2B 4b25580bd068a4c4d8433922ab67ad2380121b04b5e02b493ff4c5f59dd99fcd57a37adb1c2daec2d2523596b70d62ff578a965538a3ecafab84ea4a20fa6a71 SHA512 5d0812f274a8d37ce3cd1cc9360c6b0e34e8038dc02bde2cc51ed38754f6728ab2d9e5f0c2475abc90b490948a02a2fe0507c09a883c5420ebdb098afa5c75bd +DIST thunderbird-102.5.0-br.xpi 615115 BLAKE2B 05ddfdc4ab289452d8228d826298fb0336f3ecf054df3f4b13df0a6c229626cc387131b7bc8ab869f8c85e7f505cbb0e683fa1c6d3fd16e5b2db68d2a78968e3 SHA512 5a897c11185175138773e9ed2e2a657363f0232a9c10b23f7d2ddd5da45225bd88aa3c6bc1f3d028d82cb3e671f58c39061cc484a4343482c20ddfead235b7bf +DIST thunderbird-102.5.0-ca.xpi 636174 BLAKE2B e6bec45bc39cff0ed596fd7112098a17e8ee72afa46e2c9a174add319075dff256ee70bef8e27b1d9fe6405156e2a7c9da81d0fe3699c17968ba6dfcfa555d0c SHA512 7a697a373bee328b1bc430f80a15be32e9e54cade138adb166f3aa1df281872921108f3603fdd7e4a2b25603c6be331f363062857fb037b3baf0118fcd26bca3 +DIST thunderbird-102.5.0-cak.xpi 641842 BLAKE2B 7e01d8d1937e32162220e6ee937a55d157b9cf7a18d5af35de544748539ed8865b6551dcd98c4c941e44f3a56b06f516995b8a10581526b4a99170aed6b5ab0e SHA512 e08db5fc96487108ff40cedc79dbc52d60c06a85f9692980efa7fa4e147f1476b5be15850faff2c40650804926fee1202ae33d904aca8b9d3f58b1e095c40664 +DIST thunderbird-102.5.0-cs.xpi 706337 BLAKE2B f17ccd8a41defac92c7e4320a3d3ffd45e468718c00da53c498895a9e8dd4446548e1eaa284ffacf013fa22a0f162b5df99ec140ee9546d206baeb93ee55f5fa SHA512 831bda7bc15553452ce6302fba74c71dfa89e47c70e553aeff5fa1f39175022c015e97d30f63f3f4d17ab845e9418f214e8a56a6526273669adaf5c50edf3550 +DIST thunderbird-102.5.0-cy.xpi 684716 BLAKE2B 6cd51123aa4901d8eab113f58839593d81878a1500976a2d9f025b8cc77b5bad49064d81c056df5f820b4b70416877fb93b21cdd4970f823953e3f4e5174a6d8 SHA512 e792e0112d32b84456ce57a738bbd0ba1fd20237400387e4627d05c60f572b55ee28485e3490961671673c18c683619a4e96d02da43987945c97fc160fa654ef +DIST thunderbird-102.5.0-da.xpi 670578 BLAKE2B e22dd96523b05bba607eb8c80ca196e7de645abf8b256475d07d8e7bbf00c18afb259ecd7d12676ac332e3d916d9e27ee1e8a33950ef9837c8a31a7998288cf5 SHA512 a0403c8197a3bcdabe046263d5a68ac6cc0ea555dc3d1f5d462447f653da7bcf3ea7fa2f20a47533db6d25d0493a45ee2d954a84499ceca99e87cc6addac5a30 +DIST thunderbird-102.5.0-de.xpi 703559 BLAKE2B 363993cda0c67cafa51a4676851ae05fcdfdbae46502c90819b73b266db7eb5f6af38d222b54298f457eea1dc76cde3b52c781dc8397efd84f736f7a416e7d31 SHA512 7077776a6b89c0efd49f1b53c628412a374b2feffad4e8d475ad82bc9d879f40f38cde8ed8b92f1d2543b69b3ab88776fd1070191717f30da6f7a80a7cc9a6bc +DIST thunderbird-102.5.0-dsb.xpi 718470 BLAKE2B 9d3864582ea95665b2371f40303471464bba778bdb773556f2031e4fdc0498997fe16d5333a191bd55df9738c96c840f3e7d805b225aec768afc8c28d4f0691f SHA512 a3aa103726f8e516bb80cdda5b98847b466ef8381093d6ca6e8f600b2c56ab36099799c67c20cf1746898da0a48e63d032c1dd51352ea5401c49ad11d68d956c +DIST thunderbird-102.5.0-el.xpi 816315 BLAKE2B cc8735308e9ce3cf0021e7a45ef5c4b993bd839be4da025c3a71f17e61f7a8a8260a9e080731220e0876480530d7bc36392c3f4c28b55348941bc79a3f0652e4 SHA512 5b2cb3771907fd96e8f39aea9a2839f457ce66a179849e2de38ca6737081f3099e9423845e784933e931ba0c9c1465d2563d4ad20ca794643d8bac8ba3988b1f +DIST thunderbird-102.5.0-en-CA.xpi 644397 BLAKE2B 3a324d2cc753078affc146ca1e1ff6289966f438bdfe411e8f6de45b27fe3908d2c581f07e442d900971290ccd750d14640fc0d841ff09a5b162f6d2228f84da SHA512 51100025b8890af9415bfbc11afc1be522d374ca9f6ecc421d9a47e4012ad690f2c22089fa9b4f0a941d8bb854762ecb917105fa6b17fbe694fb1c631ce198b5 +DIST thunderbird-102.5.0-en-GB.xpi 645398 BLAKE2B 9985e6392eff8c8088dd4f78854b187565c03cf6b5f1e0f241781f6f9053ae34cae496c2143b7147b4da4bc938be7fd8312544210a044ec1c6e33c6a0b6d5a73 SHA512 8b4f4e6973fa1369abb5910c5e534a7fd592d18575fd780fca1f667ea1da2ab86aea78d74f5b97c62c8feb07187d2c86bc731058d4746a0df375a302f450d93e +DIST thunderbird-102.5.0-es-AR.xpi 695963 BLAKE2B b9a517f72e9071fb78ec09fc85f157cbbe0297225a4e7800d88e4ddd37c9da14ddb6aedcf2f7ae61abe94ccb23c1efe40dd605ef5a0ed78c4c6dcd140934c98c SHA512 4512768c6168d75bee3a16a38a57157a227d67129d2e8b8b53f7ba1c3cc66367247b87d94e60979da5cbac35c12ccb825bfb89cfded20532ccbacf4d1fb28e9f +DIST thunderbird-102.5.0-es-ES.xpi 652045 BLAKE2B 18dec7f62d14f332ba1c288b02699845a8026882771f9c374fcb5fe8e449da32b8fb0bcaac99ddba048e49f88b9c09b38844be7e9832dcd230be73a7d8db75ab SHA512 2b8a903bbdbc4c6547168660cdbc47890dd05e810f02676586c6427f202b8ecf9b76399357dab9d8268581ae98cb9b2e36c560006d1fcca973c21b9a3a9eac26 +DIST thunderbird-102.5.0-es-MX.xpi 698653 BLAKE2B c8998bf378308a1869545a18a5d910c73849c6af16e88d3319e2c3d3bd7ca575d10d84bf7c04c45ebfc6a1244ab371d44ceae5991748fdf1efd659d55c9d51ee SHA512 70b28e30a673ad791b723f05513f5671e0aa30b190ba1aca64dc5b314a2926fb6e063eeaa52e1801927a47eb8cf5cfbda6af5c6a42ee779bcf66a04ddb285810 +DIST thunderbird-102.5.0-et.xpi 666813 BLAKE2B d2d0172136de202c78efdb87f785ebbe45136ae777b132481db0fbc83e8e9dd7ab09b434c20e853f839eb5595d6e8bd5f744798a1b50e6d86c811f2745731ca0 SHA512 80f334627caa22ed98483ced66fe328bbdb90123d0d0c85f2301de060398cae46f09afdd948975df9231aee86d21c80e6ae78342614785f3fed355c51df24023 +DIST thunderbird-102.5.0-eu.xpi 680211 BLAKE2B 60f4392588b861f8aac9b6cd684a20248078a1696c975e606af79e92fb0f98a6180f898c61c6aa939963560f7b61523235d12fdbdc37c3f2880a8f3f949078a0 SHA512 cf273461a4dcf53c5025dc82eebac548ca2495d6dd109be5cf7d9fb71df886ba520a3e067d3d49c6c788a1794feba694f6a98a5ba59117046f209e035d9dfed2 +DIST thunderbird-102.5.0-fi.xpi 673902 BLAKE2B faa916d8d7f7a3fca0a9874edf9458ae0d7510b635b036ca526354285e19c9e88e4f7a7539b10b01a7fecc5f8b94e293b7fcddb2a434b2a2b283e7f946d78f0d SHA512 02d46716afa2229ab8032d88b6ac63a40e445ba7841e322a29353f437f5ab5d6692008382cae9df1816850582cc6b917275a7ed1a9560224bfc42eee79babec8 +DIST thunderbird-102.5.0-fr.xpi 708767 BLAKE2B d0e8b29a153358f272de17206680dce3fa13575293b7eed3dea223cd55759a05c43946a70aa7a3019bee6aeb3fbf69fa1ef0bcdc8f17ab199b39fef8249ab232 SHA512 cea496737f46785e4bec8b6b12455b8595af1aa356453e6f34376c8288b886a7e80527557396f0f0a99439886f4cc31815724e6d4b4ac9ed13d1fd356d41433a +DIST thunderbird-102.5.0-fy-NL.xpi 690681 BLAKE2B 81b85f7092de2cbba0f0de9400fbe52bebec13e7cceff556553ff085123859736b7a1af3e75480596fd21d72548b07721144458f7dec392f0efadf684c273c0b SHA512 180f0959b46a5a4ce4ecea0c8e5bb374e6f4f64f1091b835211f6eb3d8b977a0546127d3759890b184687570d36ed80748e9fdd49b66a8a588654d3e369757cd +DIST thunderbird-102.5.0-ga-IE.xpi 603098 BLAKE2B ae139feaca04cbf651616ccf62abe3f5a3ba8d27b051b2d0a7d3a5cabc3136fab672e23c228e5a61f5487a7ddd19005243c27001a1108043de98561da70608fd SHA512 ae6dce5b45a6fcddf9f9c04bc23ab7fc9d104d9249e1ca03f3640751d324926687504ad2b75817b498adb9d3db8ac131f942cfe751f7bd530e9334895a043f62 +DIST thunderbird-102.5.0-gd.xpi 632445 BLAKE2B a55383a30b9afd1553cc9d2dff106e5a4cd404cc3c7cc233a6a77b39c0eb4779efe8d61e0da38af6dc858d11c46ebd2065a90e340d79b1254e82e539439cbaf2 SHA512 6aee6f876e8156634c3234d5cfba2e085570403af11d9f2cb2c7a2d864b734e2563b5723d9bd37101a48a832ab06d2c0706cc1cc802b8e49930c693245900e1b +DIST thunderbird-102.5.0-gl.xpi 663209 BLAKE2B 5d623f3e6d44b0ac583f78ac2910070b27965a9f0aac4b593e3198492a5677ba0c7c8b0112f15af05de7accd46b42e88eda5578830089b481576da83dc52b235 SHA512 a021603f92e8e4ee47083f27742d46acabca340a5f566b20b30545e43260ae7523bcb431de6e99081f013bd8f34d687273ce3ed788e5e51d6ac93e7d9cde61de +DIST thunderbird-102.5.0-he.xpi 662890 BLAKE2B 7392abf96aa117ace66353b6044f7edbc216257a9291218a43a9af79f50bd4f7a3fd6aafbf0b6bbe28d75b1c65845ca7f410565abdac0476c9c82fbda1eb7786 SHA512 eea501f01b733b32478059de21dba17f7cc619aad4c2ccb719688b8979ba083297f4538aacfd5a9cf56be82500fd52ab883c06098654fcf2b10283ff66af1222 +DIST thunderbird-102.5.0-hr.xpi 661112 BLAKE2B e09982d13328968e5e6c619421c00ffff2a082e84ba5b096d75d9ca1923166c21ef231cd6d7100b78e23b3551a9eb3a4390f2074ccc33a33b7aa2a082225f6f9 SHA512 e3ecf8adee761c0824d2929802bf4341a859cd565abc786bc2b5654040c449bb6d426383e79ace3afd286316b8022134c6f90b22fcd16e69c3cab66a9b2e7507 +DIST thunderbird-102.5.0-hsb.xpi 715754 BLAKE2B f29c273ea44ef4ba2984e2502b7e86bc17c7f4ec9228663f8052934806ffc62b34ca0ad531099995111835753259aa64cd00d846689a29f3e9c69b95b138fec4 SHA512 95d2333a7c11bd57b08cf1f63e67444f6df5ffc65555bd22ce6e3f8446ab1362bf434e95a2ee50c9faf3539613d32532e5332133ddcb804860b214fea9178bcb +DIST thunderbird-102.5.0-hu.xpi 718785 BLAKE2B 9161d358d82b22e5c013316b5b4cba52fd8c86ab7f4bf4cccef8fd1ac7ccb74e8c7b80e069a22c110e612080816b46cd629cb6a549141bbd1a8ec87e9f8bce3d SHA512 a27d93e84806efcaaf0ebd631194d632093cdf2c8eaaaeba01953b4a5356c2fde3fc0e76e33189a5fb444c5d36d93a9e2f2a4de4e923e4cc9ea599697e25ab5e +DIST thunderbird-102.5.0-id.xpi 639542 BLAKE2B c302c31046bb4b40e61e63ca29ac52521ed28ae4056bbcc3d372fd60bf632b1505ed77287b902cf4a4468bad91454c12b4a9116a8f467b0ef00dba35befec673 SHA512 ca28ec8accb06fd580165ac2979bb49af0ac426981a8c3062f8ec2251f42e84f045f5b74758433c5b91ef1ae2b986498d0d8a8a6f8e226bbc040a76f6e980302 +DIST thunderbird-102.5.0-is.xpi 685617 BLAKE2B 3e9ea7c3fae76f6579b6e51c7230fea74d1c653e8f9cfe0c4bb64459ec9845373be39b0e6bd731044451b3f937fa19552035ba4e9371d527ef97f02f6516139c SHA512 dae88b95f700d3ec85bf840b8f5dca58cc4040ce4fff90437090a2d38e01e00de6fe44ecf26add241b29287a8ca1ee34f89f50ddb5ce2cc493720ba8ebe27ce1 +DIST thunderbird-102.5.0-it.xpi 617780 BLAKE2B 74ced8df05e7127ae5b93b4b7deefdb4a2150e2e5a09a0731a66dcf903284254fb5b8fdbdd6cd7ed6739b84753c0e2c68780d17dd3f2ac9cec7472249f24b49e SHA512 92dcd540f9ac0f10870ec9561bbcfc2100bc07f8680c8d97416300099cbb10764f597756e321cad432f7c1babe8dad184332a03881fc50625a8c7616b2df60d3 +DIST thunderbird-102.5.0-ja.xpi 755145 BLAKE2B 870f4e67a7c6cacaeb224a5a89d2c6f2bade222846c8265d19c2cb9c7ed8a9dc318ff620aa921468690e558e238adbd2f0936e70ae1163114ddeea088ba9afe6 SHA512 c4e1fb28cff27b5c6731d889dde46d755fb5b5de0d300778ab44509b7bcc12fcd708e8067c8c71ae6c18de49307100b7993e8edad93db47cc389d7e6ffac537b +DIST thunderbird-102.5.0-ka.xpi 752977 BLAKE2B f9ded31e90cc2dec3c3ec021e318fe28c4101e99f64acfc72928acc7105ee5a18626711d07a0331a596cd21ee23679c3cac3278af37203032a48d9b8b1a174cb SHA512 ab07aea6bc1a88fc54d9212388dec76d200211426cae09148661316bda137fa564417e9699bf5c49f12a9165bbfedeb3464d288a9e6234d4cc94da090e1ddf2d +DIST thunderbird-102.5.0-kab.xpi 688572 BLAKE2B 02ccaae86f798415b96eb9e283086694a71a1e0a043fdc0246d170eaeb4cfb03109da23f5d416dc89418adc16a69b5df3e01acdc1db23d4981125cf752cc1ce5 SHA512 6123abf6b28ea3e062eb0d12b63571222186bd412b6175a077787675221f54eedaf16857d10c801d7f1fe0bb0dcf69b202de126e5b910a3c37867e6acb9acebf +DIST thunderbird-102.5.0-kk.xpi 731942 BLAKE2B 5c07b77ebbcba113266c1a6a2556f75872b7e1018b0855a86059411a698ccc6507daf6fed9c3c89ab5aa8ae923506f4da761cb025468ff97499eae083188cb55 SHA512 cd7d777386a6e6bd3a63a0426b1d10ca7fdb1e8914b4833e19098d7023309bc45a560e2ac4fc5632efd71ff8015ba35b76987988a39a163eb16543fd32b6ba0c +DIST thunderbird-102.5.0-ko.xpi 692942 BLAKE2B 82d2f8c564cc898ee9b864427cb5d1894ecef7f14f14ea1fa76fea1df11deee234119281a08ff1045d63323d860cb0d2c37b5302af61b23a70c1d9112c9b1228 SHA512 ede612e93cb013bef06642a729382863fdd9e25fe4fb21d06b91d36d4ed3145897b9b3346f6710060da1d7fcfde5eb89d9081931f53fd85bc2d75774c420dcf1 +DIST thunderbird-102.5.0-lt.xpi 680720 BLAKE2B d6ab74cb9d46281d8edd9d0c9881a61e113aee5c974e89b865a73326018b969c1b3851411c62f6b67398cceeb84ca4ce53eb43ec2179c890115c76948b41c831 SHA512 73310a4d6b49a069af7dddb31f15157dcb7b44e3eb4cf5dedff5948660ce1ef74e53e9d4e12a097dbef74dc1e5f66d53463f83b114edd3c09661be4d9607983d +DIST thunderbird-102.5.0-lv.xpi 608590 BLAKE2B 112e346d783a3e926051dff22c0866c265f31cce6ba0455dabc8427996a968da00fcced6243559b270acdd28a0a5a9b6a2a3d52f44bdcc35c581fc93fbaf4778 SHA512 fe67606f64f7fe91fc83f68ee1509a2564f6a05c54aee41d30c79d4756d5e0eeb2f77e9d5822e4c317462a56100f0874c01f86dc0b8cfc04c06f562c1387f863 +DIST thunderbird-102.5.0-ms.xpi 568426 BLAKE2B 594f2a51c56634734d31c313cf4168901fd933dfc770e47b6ab183216deceb6940437af7e84822bf4be74e07032838018525baa5ce89a0946f132a4a445bca68 SHA512 c72b9779ad6ef5d5784b197fdcf3ff117931ea6d66da396c013b2a41850c9d20a4a6dc6f7859462a6879d275971f0e2d044aae3d40788d5f35180f80c17ed340 +DIST thunderbird-102.5.0-nb-NO.xpi 648584 BLAKE2B 1a3bd5d8e4e5e69e44d2dfeefbb348646dd2e3803cb106c1bbf77e2ecd0d2f41d9cf1f8b9fd45693205c39ed836f59a6d54420bfe34b3dac869dfe7274a2d6f2 SHA512 060ef488fb38c947a2be6fa71178538ca1a4100b7fa9b566ef0c5063f4ed4d08d894529042b611760505211b15d498b4cd21d01f168b7fb32264a6f81685a0f1 +DIST thunderbird-102.5.0-nl.xpi 682267 BLAKE2B 64ce650a53812de39c8b57b798d9056c89fb3109b7962bf896eb001200e4948270bfa3b50fc768a349b073d5d5f03390d97fe69c8e6eb5dfe73b13957f436201 SHA512 c3a56572ef569c09fe4f0a8cddc73110f25b5fc31b304cfb8ac21188dd7466637607d11fcf4bdea5678f10e7d94f860ba1ddf1d66c36dd08882cfd8880eca1f6 +DIST thunderbird-102.5.0-nn-NO.xpi 656907 BLAKE2B c03d54e951d501030cce9492dee8b7a30f839ff01078bb474391bd72b3e75e19da2cb3fd9d2808bbf960baa9e6218b0131f70bb31997dc394ed3e954514fa55d SHA512 c11179ffc17faf43ad7a0fd60ea6848832fcc1f7ef1b7c4bd27d60c462732486ae2abd38c13a20d77f3f63b98f1980a61f327747d51ed4e7a910424e3599d5fe +DIST thunderbird-102.5.0-pa-IN.xpi 653543 BLAKE2B 5e005cc184e5098f6d315a9516efffcb79ade394b3947bb46967f4de94ab4544a1a4db7bfe4f5c482d8a5b3bdb5eb127d948840d785faca452ed8eb30efa888e SHA512 ecd45904664fe6e7e14ff3eedc01317af0a3c309e7bb0ed637a454e2debf6e2937c82c31fe7a13824ceb7a4330020f370117b571e7111810573f14c39cd960b1 +DIST thunderbird-102.5.0-pl.xpi 695417 BLAKE2B ce213b91277dbad211c722b633baa9ae6dee5e0e0d6bad24cd20bbf64ab304851235332ddc0430769d03e9bf119f175bb8e3930da5259cccaee976ec4eb10250 SHA512 172f0a5ab3f1dd5c794d07925b25416db9afd36a547a4690c09d3f7466f5930f1d685622896d350fbebbafb818307bcf0db1201f7c48abd709a08632a2cfa396 +DIST thunderbird-102.5.0-pt-BR.xpi 690288 BLAKE2B 6f891b987f7f8ec2bd2b680a83a3c908c8157966a49d6745538a0e1a71481cb77443cd6486eae544466e371ab92b7c68108bd546d3721feb1dd965f61c5f0a83 SHA512 ec490f04f30d5cacdf9bb9d58bf0d04084c91bc4c5022eee80ac0936ddb5334770adea7dd5a6ed9e5782d72827c2fd75d57235964b23e14332a3e6dc51f122ff +DIST thunderbird-102.5.0-pt-PT.xpi 666879 BLAKE2B 97b383492d8961236d578ca589f858885cd3ebb2edca3bd628e31a95ec74b8cdba7b0fd0eaf817a899259c1dabc3bd0f1debe267738b5a07938e4960bfa17a77 SHA512 78fdb6c5bdf0919ad49605f53f35b31dc8b1dd5aa1b91d5adbd1b2494c2daea5ab0eee1e00cf60e7de0bd50591ffe73a0ccc4c3c75d97b726c23a863482c9af1 +DIST thunderbird-102.5.0-rm.xpi 686110 BLAKE2B 7dc85b92231b6e6745ed9782e3e19ed0af6b978d1de1af13ceb3314d729d427d48bddb4dbf46a49d9119b19a31c0be837a0946c41550085a679e20ac21d99cbc SHA512 4d56bb4a412548c5e61c11c5c17c3a9f78ee387c20d0845353c93893a2215d72fa7b6eb86b3b26c73b26a4b2298fea5ca7c3a9dbd4a19ec0c96796e80b1e4445 +DIST thunderbird-102.5.0-ro.xpi 651335 BLAKE2B 5838c609016144de1fef33b95b93c90ff5cb0b0354be5bf3f3a442319a3c66da5fbecfc5b663bc74ba6cdc1036ce66d627e687fbe107588e612c3d3593ac4f51 SHA512 a473f95bac0f05dcdec5f14a14168355376bcfa36c10b05101119ef032a3edd2aeda6ef4c138348e20d061087b5d0fb643d5f3e0d764ae3c241b50d92ddd8c3c +DIST thunderbird-102.5.0-ru.xpi 801784 BLAKE2B d1c74cfd59448ac3ac2ea2e43742a3c013ed85a9e2000d72a4066dac361bccfb9dc89edd028f9627083f296da158981716ed5d5cce9c646ff2e3c1ff7481c51e SHA512 b06f419d9ffdae93ce9eed53af2320714a8d030149c674e5ee31ee029f904f95cf9eb3700f1aea0477cec1ee8d8748b2c187e9dd326a335dad7b2eeb6bb98d1c +DIST thunderbird-102.5.0-sk.xpi 718356 BLAKE2B 88972ad0c55db486ca68b33501a56ce03cdb508b119779031bf05192ecd14b46e88cfa468f5954d1e775b373f32157f101899ada657bdd8160ecce6c591321d5 SHA512 6061ebdd3323e80775927bfec4c31da09caa1ba446538a729f5d411f8b2897912d5184fe58e0f409dcebfb62f127eb381bd617c548f08ace00a1edc12fbf8b7e +DIST thunderbird-102.5.0-sl.xpi 683784 BLAKE2B 72e336a55d5e19f70a23beda0a389d14ec96f4ad19d2f1a720c47ca50cb0e91a3f2444bf8f31850ec472109313b32283e064f953f2fbc1e81b7309a098e73946 SHA512 cc8e01d12792478e5a4d944a9c636def45b6c129f8297ee292a3cb0537cffd87588daa9fe0dcbcbaf1f35ebf70b60408e219328faa642a65f8a0d17d62be23ea +DIST thunderbird-102.5.0-sq.xpi 690224 BLAKE2B 32e5f70898bea3ec98557e9f0885c8ff2904cfa6fe0966b74847e146a8667cddc16431616bbde806956e4c20c7993999ec7f94eaf1ce26c0b44b17cbc3f4beec SHA512 ccd89b79c7ed148b0c3cf17ec426c6f17c31cecab47a7542413dc0de93c771c79b18c9bb15b56161511f0ff08fa79aaa8426a691f8d340b63d4efbd55c5ebafd +DIST thunderbird-102.5.0-sr.xpi 705270 BLAKE2B 5a57b5368c2b267fd851ad62e0471c7d4e148000330c0fa64c1feea36c4a13b407e57a0f4eccd8bd789996902a673eb83d73ddd60613c46c79ec7fb748926483 SHA512 61374f38ff7e3d1a8c5d65de4f95ffcbb437e2ba0e5160945ddac2bab2a23779e78f3d4f2c265558a122e5a744d681118458c6a939c3bcca547b7c90de998dd5 +DIST thunderbird-102.5.0-sv-SE.xpi 685685 BLAKE2B e3a6d1569889a713319dedccbf31dcc3a1dcaa2074e781df8d9418eca41de907672e77fe9f797a16b13a7bd56afe0d5b20ad650452c259004ad1c16f8634fbdc SHA512 333e6d8fe81a4a4bead28e767d50de91eb4ad6e699489f5707de33abecb7a0dfb737843e822f487eb2a5e814b23de1fa3f8c2ea99c47a2652f230d0417ddfadd +DIST thunderbird-102.5.0-th.xpi 734540 BLAKE2B 354a2fa484df6237fc0c2ac1a6062ae5917fd65ec81b1ceccce7ad1619d510bfa7adf52d970e3fed870f48b6e9c348571f81c4f046ce7738da5dc8f33751ea5d SHA512 00637837eadf37d41db11999373ba01a8169a8084cdfedf824aa8ddc9af39f3c77e70cae1e53079497d3501a7887a66f5ce8862c8b08c794bb3ec7e9197c9021 +DIST thunderbird-102.5.0-tr.xpi 697057 BLAKE2B 3e7ec8a07f9915437167c8975e69158feb02726dc6ddf1caa22fd7c30f26c3fe6c1100fec45c4379d1376b9163600abc91bb055dc3a86f6f8dca85da2ef92703 SHA512 9d0e99063cee5beea0de06ed9a9fe13bf408ea12447d89ed20f35f3907dc945ff0136bda7544925d90b94d7f1f540645d1a2d90abc7ad953d9033dbad8d04e78 +DIST thunderbird-102.5.0-uk.xpi 794406 BLAKE2B 7bc74fbefbdb6d227c60cdd0666d29892d96de7ec01dc0df7d4014da2457b5b42cb5f39ed54299641dcfc891862db457c3d22d64de429cc6844c3ac67c29d085 SHA512 8a89937877dc1510ed762589b40770138d6675acb3008e9d504f23a277de0d7fba0e24ac90a1033912cd9e9830ded2c638a313d8dad862b1726d1111e1a04583 +DIST thunderbird-102.5.0-uz.xpi 584807 BLAKE2B 645493e677ef4ad188f04ed3b9873b37fb96d1a49c90b41fa2093a743fd5095324d56393e87abd5035a34ae32ac65a4b09811b7402e8fec3d23a152cbbc70cc7 SHA512 891d0c88db54378306862e644ab2b46c0f95d0ab98c69167d4b736c5f39b87e01352c487230b9496fe0126eae151390a05c12b1aa3327d86407d84cf46fa7f38 +DIST thunderbird-102.5.0-vi.xpi 724849 BLAKE2B 1a912cff7418cd2d1139bbfc2c060e6e5fa871d6196b899aa1de2514be7921d0a978fc31ee4f3ef4b71d9b830e8c419e50f9607f64d7d711c15b48d97e6d917e SHA512 85dec4b8086625cba7d120c24f95794959ba6babf943dfe184e12cca704bd78983f59173a06f25e54c56c76706f3bd1d03061a925d1dad619e9aa77672c3692d +DIST thunderbird-102.5.0-zh-CN.xpi 722696 BLAKE2B 8a04aeaf37d8d3580c1b2ef79bc2c288b9be36f7a01e582acd7c2f017ce3dd572d7af52e0327347024e422f07c1b8fe64f4fb8c63452a453e70417904945f6cc SHA512 73c23709d2d994877da5676abafda891c78f830649f908d4f90f5e9033b2b30b6542a7b5e2ca1592874e112c270e73a8b4c783288b953b19abdfdbe73c6949f2 +DIST thunderbird-102.5.0-zh-TW.xpi 725969 BLAKE2B 863f00e7b37197d42c3400ab28d0561a90d64b61ac110a5709c2c117e43d57da9752cc1240a199bf82fce291b8e5169d68e017280bcd303ac8ff9244106dc1ad SHA512 c7027c8dec0659662e357468657ec2befe1e4bc50a38acc99849157b5e0a227d574a6238f14335348f9d41fa419859f34f572f2072f01d25d4348c9cef755bfe +DIST thunderbird-102.5.0.source.tar.xz 506950192 BLAKE2B 7374644b6601358b9ac10694faf15bcfee20a92b00905b6d8321964996682512bbd3b57ab44ebcdeeb5f10ff297d14ce56f8c28482ab9fefa2ccf67df0adbc08 SHA512 b6f2828b23616db5620e0364a1ebb02a8676e184d5e361c0aa87f36b64eb6b7f4b1bc3c42675b3ae3092953fbda6b01c18c068b167d40469481b1e18af1dcaa1 diff --git a/mail-client/thunderbird/thunderbird-102.5.0.ebuild b/mail-client/thunderbird/thunderbird-102.5.0.ebuild new file mode 100644 index 000000000000..549059c920e4 --- /dev/null +++ b/mail-client/thunderbird/thunderbird-102.5.0.ebuild @@ -0,0 +1,1170 @@ +# Copyright 1999-2022 Gentoo Authors +# Distributed under the terms of the GNU General Public License v2 + +EAPI=8 + +FIREFOX_PATCHSET="firefox-102esr-patches-05j.tar.xz" + +LLVM_MAX_SLOT=15 + +PYTHON_COMPAT=( python3_{8..11} ) +PYTHON_REQ_USE="ncurses,sqlite,ssl" + +WANT_AUTOCONF="2.1" + +VIRTUALX_REQUIRED="pgo" + +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 \ + 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,whissi,slashbeast}/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" + +# Thunderbird-only USE flags. +IUSE+=" +system-librnp" + +REQUIRED_USE="debug? ( !system-av1 ) + pgo? ( lto ) + wayland? ( dbus ) + wifi? ( dbus )" + +# Thunderbird-only dependencies. +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:15 + sys-devel/llvm:15 + clang? ( + sys-devel/lld:15 + pgo? ( =sys-libs/compiler-rt-sanitizers-15*[profile] ) + ) + ) + ( + sys-devel/clang:14 + sys-devel/llvm:14 + clang? ( + sys-devel/lld:14 + pgo? ( =sys-libs/compiler-rt-sanitizers-14*[profile] ) + ) + ) + ) + || ( + virtual/rust:0/llvm-15 + virtual/rust:0/llvm-14 + ) + app-arch/unzip + app-arch/zip + >=dev-util/cbindgen-0.24.3 + net-libs/nodejs + virtual/pkgconfig + amd64? ( >=dev-lang/nasm-2.14 ) + x86? ( >=dev-lang/nasm-2.14 )" + +COMMON_DEPEND="${TB_ONLY_DEPEND} + dev-libs/atk + dev-libs/expat + dev-libs/glib:2 + dev-libs/libffi:= + >=dev-libs/nss-3.79 + >=dev-libs/nspr-4.34 + media-libs/alsa-lib + media-libs/fontconfig + media-libs/freetype + media-libs/mesa + media-video/ffmpeg + sys-libs/zlib + virtual/freedesktop-icon-theme + virtual/opengl + x11-libs/cairo[X] + x11-libs/gdk-pixbuf + 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/libXtst + x11-libs/libxcb:= + x11-libs/libxkbcommon[X] + x11-libs/pango + x11-libs/pixman + dbus? ( + dev-libs/dbus-glib + sys-apps/dbus + ) + jack? ( virtual/jack ) + libproxy? ( net-libs/libproxy ) + 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-71.1:= ) + system-jpeg? ( >=media-libs/libjpeg-turbo-1.2.1 ) + system-libevent? ( >=dev-libs/libevent-2.0: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? ( + x11-libs/gtk+:3[wayland] + x11-libs/libdrm + x11-libs/libxkbcommon[wayland] + ) + wifi? ( + kernel_linux? ( + dev-libs/dbus-glib + net-misc/networkmanager + sys-apps/dbus + ) + )" + +RDEPEND="${COMMON_DEPEND} + jack? ( virtual/jack ) + openh264? ( media-libs/openh264:*[plugin] ) + pulseaudio? ( + || ( + media-sound/pulseaudio + >=media-sound/apulse-0.1.12-r4 + ) + )" + +DEPEND="${COMMON_DEPEND} + x11-libs/libICE + x11-libs/libSM + pulseaudio? ( + || ( + media-sound/pulseaudio + >=media-sound/apulse-0.1.12-r4[sdk] + ) + )" + +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 ; 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}*" ; then + einfo "=sys-libs/compiler-rt-sanitizers-${LLVM_SLOT}* 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}" +} + +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 ; 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 + # 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 + + 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)" + + # 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 + + # 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 ..." + if tc-is-gcc; then + have_switched_compiler=yes + fi + AR=llvm-ar + CC=${CHOST}-clang + CXX=${CHOST}-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 + 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 + + # Set Gentoo defaults + export MOZILLA_OFFICIAL=1 + + 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-updater \ + --enable-js-shell \ + --enable-negotiateauth \ + --enable-new-pass-manager \ + --enable-official-branding \ + --enable-release \ + --enable-system-ffi \ + --enable-system-pixman \ + --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. + if use ppc64; then + mozconfig_add_options_ac '' --disable-sandbox + else + mozconfig_add_options_ac '' --enable-sandbox + fi + + 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 + 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 wayland ; then + mozconfig_add_options_ac '+x11+wayland' --enable-default-toolkit=cairo-gtk3-x11-wayland + else + mozconfig_add_options_ac '+x11' --enable-default-toolkit=cairo-gtk3 + fi + + if use lto ; then + if use clang ; then + # Upstream only supports lld when using clang + mozconfig_add_options_ac "forcing ld=lld due to USE=clang and USE=lto" --enable-linker=lld + + mozconfig_add_options_ac '+lto' --enable-lto=cross + + else + # ThinLTO is currently broken, see bmo#1644409 + 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 + # This is upstream's default + mozconfig_add_options_ac "forcing ld=lld due to USE=clang" --enable-linker=lld + else + mozconfig_add_options_ac "linker is set to bfd" --enable-linker=bfd + fi + fi + + # LTO flag was handled via configure + filter-flags '-flto*' + + mozconfig_use_enable debug + if use debug ; then + mozconfig_add_options_ac '+debug' --disable-optimize + else + 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 + elif tc-is-gcc ; then + if ver_test $(gcc-fullversion) -ge 10 ; then + einfo "Forcing -fno-tree-loop-vectorize to workaround GCC bug, see bug 758446 ..." + append-cxxflags -fno-tree-loop-vectorize + fi + 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 use pgo ; then + virtx_cmd=virtx + + # Reset and cleanup environment variables used by GNOME/XDG + gnome2_environment_reset + + addpredict /root + fi + + local -x GDK_BACKEND=x11 + + ${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 runtime features:" + optfeature "encrypted chat support" net-libs/libotr +}