mirror of
https://github.com/flatcar/scripts.git
synced 2025-08-15 08:56:58 +02:00
dev-lang/python: Sync with Gentoo
It's from Gentoo commit 4ff0f9bdbf50fa1b729a3d5335f9cae63ff66a7f.
This commit is contained in:
parent
b333307dca
commit
e6613dff2e
@ -1,21 +1,18 @@
|
|||||||
DIST Python-2.7.18.tar.xz 12854736 BLAKE2B 060a621c91dd8e3d321aec99d44c17aa67381998256a1a002d316b38288349884d5960de35c49352d03129ed0bae599e641ec2225898158ebce50a7a2fd74d2c SHA512 a7bb62b51f48ff0b6df0b18f5b0312a523e3110f49c3237936bfe56ed0e26838c0274ff5401bda6fc21bf24337477ccac49e8026c5d651e4b4cafb5eb5086f6c
|
DIST Python-2.7.18.tar.xz 12854736 BLAKE2B 060a621c91dd8e3d321aec99d44c17aa67381998256a1a002d316b38288349884d5960de35c49352d03129ed0bae599e641ec2225898158ebce50a7a2fd74d2c SHA512 a7bb62b51f48ff0b6df0b18f5b0312a523e3110f49c3237936bfe56ed0e26838c0274ff5401bda6fc21bf24337477ccac49e8026c5d651e4b4cafb5eb5086f6c
|
||||||
DIST Python-2.7.18.tar.xz.asc 833 BLAKE2B 1d98770e46171971fb99994508d238c01d2755281d2f94353314014d9e83e0ec5f0b3e3950ea1fdf5fce9ba6b8f55312355845c2a3fc4291c27ee56fe6215448 SHA512 c2a5f5a52f47dec52460ad3275758d4e5de6e7075c3def4353c988d74d563a39b42cae2d5eb24e2a23a6247cef69100f91620b11a49c2359fbf99b203c9cbda8
|
DIST Python-2.7.18.tar.xz.asc 833 BLAKE2B 1d98770e46171971fb99994508d238c01d2755281d2f94353314014d9e83e0ec5f0b3e3950ea1fdf5fce9ba6b8f55312355845c2a3fc4291c27ee56fe6215448 SHA512 c2a5f5a52f47dec52460ad3275758d4e5de6e7075c3def4353c988d74d563a39b42cae2d5eb24e2a23a6247cef69100f91620b11a49c2359fbf99b203c9cbda8
|
||||||
DIST Python-3.10.8.tar.xz 19619508 BLAKE2B 8bbfbae34fbc517c4a746e5e4c360efc57aca175c50fe46a378aa9d6d023a3d90c7df816149e4cca0c9b64ca0142267d8df552e8f8dc53a04b5251e8848dce74 SHA512 40e3e77d79618c81d6fc57c5d119b99c2959dcf932f40aad6b26f2ec39c5e713e6ff298f7597b4fad2ab94680db3732483b5ca0a45e6ae58c14580b3ea44cb0f
|
DIST Python-3.10.9.tar.xz 19612112 BLAKE2B ef2d063a9fbaf234aa4a47149cb184a0379dc403515df10249104a5092750cdaf22ad47916d34e17dd68fff1c30338c0375f4e4e3cc9bde33e0896c1c3ba655b SHA512 d66ea8adeb6dc4951e612175f8838b3092967ff275b7a3470f2d86f470036aa2221e722c3144d90bcd230b88efd53dde204213f72f703e524e4b833e2ccc68e2
|
||||||
DIST Python-3.10.8.tar.xz.asc 833 BLAKE2B 1e94822a57d055f5db1a5d2915df24be9d6fd9e6b301d148919a7643285a93ca1c8a16db7d74e0adabe7d2a21678b5126e3df7fffb253b35f8db6f74284a0aba SHA512 0c2ef09d898257ba5e9ec7c5bb224a7e50e5ebca96843b4d9e25be6cdd2f17144772aafc92280af20c21491e3c8cedc697414688ece613c93b28ff7ecddcf93f
|
DIST Python-3.10.9.tar.xz.asc 833 BLAKE2B 8895c6cb5031b2463cc6ba3e0dc56bee40c2e99117c062f9c72f2b7adb0d5a49782b968abfc764117e8513bd12816915245677c25b1710e3dae3c9e26937c2b9 SHA512 525e166ede6836086de814c26fc880f41eaf1ed4bff6118f00342e42f7ab1c47148447ced1b565e146d3125fa06b5cd6b394a256bc61096766b26e07f18bbf10
|
||||||
DIST Python-3.11.0.tar.xz 19819768 BLAKE2B 3a9852b8973e0e6ce414742f08f17f2c239d20a4e437e95656a325e151d04f4751f07fce955e55f2818af6810b767f2438b3d14e9f2313fe607bab31c47a2fca SHA512 314eef88ae0d68760f34d7a32f238fd2ecb27c50963baa7357c42ad8159026ec50229a0b31d83c39710a472904a06422afc082f9658a90a1dc83ccb74c08039d
|
DIST Python-3.11.1.tar.xz 19856648 BLAKE2B 2a8942e7a145cfcc5b6932865ff9a1afd300bf2e6c4c915e88d0e849441196a3a4cacf94f3db87eaa7538872059085cf7eeff91c436f424448f85d4b180a6f24 SHA512 5edd70c881e083c96199c60471f18f9ebc4c97a2d45dc66f89e16d7c3638d8a5d2cbf2e84b1be3d7f1178ce9f7fa4197884385c1ee3618ff66a538f872f318ed
|
||||||
DIST Python-3.11.0.tar.xz.asc 833 BLAKE2B 7133f390ff8e7d856466c8d310903ef694196f5d945d6b753dcd7bf3e5416d69ef0e2320252ecce419ecce07ac5e2a37ad1657e2ded393d0c38a6521a65cebc2 SHA512 d20fb152c5b16cfef1f59af588f7576eb45c903d9e15fd4ad0e15fd32bef7ffd951b99a062d2944234ecffcf29eb9266544e92d2f6584710cbb20ba38f8ac224
|
DIST Python-3.11.1.tar.xz.asc 833 BLAKE2B 27c6101b2022cb7bea3e6082f1554b31cceb8cabe720e4b19391f550e870588c4defd1552c580a7e063638b80e8b8f415e54a11cf40ae3b0f449500c2e9babc6 SHA512 81ed05c2adf38552bdc5ac761704f2720a646d56681a919a6bfa51f1a4b42cd14edb9c84d58664dbc8e7b561cd78d82ae6b10dda423e1fae543bc7fa4bf3f78e
|
||||||
DIST Python-3.12.0a1.tar.xz 19776600 BLAKE2B 035e75c5713f9ff139f6df50329d9b74ade3b255f5413311d7012b2298dd3cb6d71ed11f5855d01e79d6bac334f80bd6a3340591fc3654d9723fd1c5f80eb750 SHA512 fa69dddf36dfe89b869d4de71cb8e878ef1e8be2b96ddfe2d58286710dd09b64db67c130d0438e3cea6679f6e9cd6bb83633691c8b7d6f346b730668866a28f7
|
DIST Python-3.12.0a3.tar.xz 19695444 BLAKE2B c869e68612b7b32a3a9cdb5accd1fec3453abbea68ca6993e7ce6d5f8deead50902ee6026c3bf2a3faf92e5a571b6b71fbcfc85d49fa03b4ac12ab5dba3f486a SHA512 82d88adda53a1e5c16fc7165ac0d55f3828bae9249d361fbf7237d8826bd5acd941befb9b2c74f815a251b216d377f416831fbd233f1bfef31c2cab73b6554d1
|
||||||
DIST Python-3.12.0a1.tar.xz.asc 963 BLAKE2B 5027ce705b80ad2d186f45c27d00542df1090dcaa30e9d97e483d7debdaeb35b5bf94c9f0cd000715a8ccf6dc5f752e0129bb42e48bfd6b308754bd73ee26090 SHA512 4db7946d27505da9c9b358a3b0fc2f47bb79b10bbcdb8f3ce2f918d1b74665e41a51600de3b94d50b126b66c72f191f8532f4030af184698c32430c35ef8d821
|
DIST Python-3.12.0a3.tar.xz.asc 963 BLAKE2B ff0a4eb7a3e27281494450dca7f23f4e1816e18d0487e09b6a9f58d441b766f32e8653b7e01753c8353bb34a235b8296cbe975ee7a917ae4a24e5b8875b4ff5f SHA512 e25a42982f3cab6e38ef7a4f5bfd71ad25811f52dffeffbb827ee9f48bf45003edad14ffdd3289bfda113a34b7ef818d04a413d0da7e8ca52d0c47f9b4475dbb
|
||||||
DIST Python-3.12.0a2.tar.xz 19633668 BLAKE2B 03c5b5637d43bd324f3dce2d16d8d12a585b2bbed82e165c1491e798f9a321547ab035372fe775b28098c6b8f65fc115f77d9ef677ec34da65cbf882689d6181 SHA512 0f830fdb514078c5403727b31fd81912382eca4decb52ae9bfb0f00b8a007be9f8e29bad349034ec97e2229f60fe0baae417227413350485d747d31f4567d5c1
|
DIST Python-3.8.16.tar.xz 19046724 BLAKE2B cbdeec7961d39cb9ab4960760b5d4c7ae71675c174156aa9f6fca55ee92a93a937ef39defe86e423237a25e0e24703233ce4b91dc97005b6ffc1f342ddd9e22c SHA512 d206e80806409410c00ef8acd8c3d90e3cc9553f996d0a57faa63802f2415e9d7591542b2e84b5e8e79245f40f6478790b5ba2acf1da98ebbc9495999183f7fd
|
||||||
DIST Python-3.12.0a2.tar.xz.asc 963 BLAKE2B a5508457e61db805cbadcef66ebb92d6e62a797704827483cca616d6441a60f99ec7a826ad3ebdaa7c92865a9aa2e5b41fde248467d5b9e1c57fb4295f7910b4 SHA512 f0c22e071c68d648c8cf2823647f0c807db41b81b94b8100b50d2049a47f19475a4323c5ac488eb5a3798f942978054f358090c1e460804232bb46093fb3fd55
|
DIST Python-3.8.16.tar.xz.asc 833 BLAKE2B 678dabc558d013b104bf9e65d4319076c4730a67093a66fefc073b429c640d4facb31a0d6b7238deb08b265586a0cfb2c345051fe4df7bf5001d7317e6c06c9b SHA512 e93c394c0c5afcaaab625a3bd540dcc8e0ab946803d212343b8d1d6d5e6b89b09b6a20607bab0d858b30389a03305d57e14548605a65277d053c7817f32f4546
|
||||||
DIST Python-3.8.15.tar.xz 19038408 BLAKE2B 4ce84171b2f7ca8c9cf1d130adf70f16a0899766cea98965c3e7afcb84b73c482bcb400b59b91736d20e31c57be79edc178f6eeecd775a1f8920a8fbfdd90c24 SHA512 4fb3827b13c2452faa75e5ed18dddf381e80b4fffcfde046e289b4629cff0bb87fba1d09916b9b8a6f8039dc422c952293ebdb381c49f8ca7e7893ae4be6c28d
|
DIST Python-3.9.16.tar.xz 19738796 BLAKE2B 70dedeb70d9d8f27e4f6db5106623e087c61d451c7a04639cf8d3503ad02d4d43f1b36d0cdf1131aefc9bf6e677e561227dd4baef2c2c3d2dbf6d3e7dc36bd94 SHA512 b5fd0afe131c82bbce6ddf887c59eef6945910d6a9a2bc87c0927f4e4a096bf9ca4d25bcb729c40f6ebb8a65fbe8bf7b0b97a7c4a8c9e551240eb4f34b878653
|
||||||
DIST Python-3.8.15.tar.xz.asc 833 BLAKE2B bff055e28f4a2e59bb9e6d131ed39f954b729ac791279a6ac618521b545ace16e4eba3aaab629ca1c155d973c0c255b3d184b38fd82ee943d59a328d0603b1b6 SHA512 8ed69db7773a111e7b356848e18fc35b8835426e8d2cb8f311644d511682960c97740232c32c92196391adaecebc0ff842c2f918aad07e5dd46b168e8277ac04
|
DIST Python-3.9.16.tar.xz.asc 833 BLAKE2B 416b4a4be06e101c5971c12a6f21229c425bcabaea58487e0d1b24d6dea318c58806ee43892fc704df8252670451bd6a4a2610c25672d3983ddb081fed34b92d SHA512 468959c36a3ec6136f57a39475fff4745a25be0cb5d3d58cf3e5faf0b9ce2d2a8b89f1f9fea1479c4c6ad12ac49e97c1cfd4291c978bb3d30df5a582ec315210
|
||||||
DIST Python-3.9.15.tar.xz 19712208 BLAKE2B a8490c998c89ed4e3e87ef48e3b5d622e5d06ebd7b8b79db564d668cd1f0c7fe89e0ef37ec4481ff82b30778e2be1a96c1b16199b9dce1f82de32f73b4343ddd SHA512 9310d263bc7a7925f73a6f66fd254ae61f377f43011a6bc5c58e57c8b170c2da4f197a646927ab9d05f8912ed8be4369c09576063931a3f93c3b0228ccb33a39
|
|
||||||
DIST Python-3.9.15.tar.xz.asc 833 BLAKE2B c325fb52fae254153456c24c1039b07c9ccf8734df3665640215d35219ccacb705f99d94c9f8b644d15d4ea4612f5ac0da599814f68f7d3b6fc1fdc175db9002 SHA512 722625091731536757b9db447590c31620665133d45076367a3281f2ee3add23a781b10ce5cea582d65caabb18814583c1a347689d2b396214e36a6771182f38
|
|
||||||
DIST python-gentoo-patches-2.7.18_p16.tar.xz 35448 BLAKE2B 0139c0944f62f9cdd236f6a8557e0ed19704c7d72869af1cb7d8bd3e646a746cd4a0201e1b44232a5e78ef49f254db20b0d0271bf744fbfd4fe0f1e99b8f3e6c SHA512 810be590d0e06fab4b2165e6852ca49662f09dcd7e20b47a29f613ad7653252c8dfac3f0eb228d77c8a914efa7c08788b2fbd552a4b47504f5fd0ec17450c48f
|
DIST python-gentoo-patches-2.7.18_p16.tar.xz 35448 BLAKE2B 0139c0944f62f9cdd236f6a8557e0ed19704c7d72869af1cb7d8bd3e646a746cd4a0201e1b44232a5e78ef49f254db20b0d0271bf744fbfd4fe0f1e99b8f3e6c SHA512 810be590d0e06fab4b2165e6852ca49662f09dcd7e20b47a29f613ad7653252c8dfac3f0eb228d77c8a914efa7c08788b2fbd552a4b47504f5fd0ec17450c48f
|
||||||
DIST python-gentoo-patches-3.10.8_p3-r1.tar.xz 16468 BLAKE2B be00739bdfc78623781139b8218d5173f13f252d3394482c38aeda8efd9b6bb4988a8dbec1b521a028448a0a92c7dce8b979eb2c38fdd6749bd9be682847d719 SHA512 094a058d2b956dfe017ae8b1da4c8da0a6aad82b70eebe9cdeb8d86bfe8b625aba57526186c97a805392c6baa62e5daaf005b54864e096f946f40ef3ce703bda
|
DIST python-gentoo-patches-3.10.9.tar.xz 12216 BLAKE2B ced4f951089c51ddaab6c62ade9d2c84f69e7e1baf2acf5247559534c7d0fb0e88dca1222f5bd2209b4e61f5aca17279b8054f269535dbc10de0786c2c5779f5 SHA512 2d01f0f3831beeba004517bb82f7d616f25f08e5c755409ecff79cd68e0a619b5bf6802fffd0e5f7f39f1d9d93e65b018b91cdeb337a5e47f1651f36bea0e96e
|
||||||
DIST python-gentoo-patches-3.11.0_p2-r1.tar.xz 9140 BLAKE2B 3fa95d054c2702ec04f92493c1a721064a5119bfe555dc413f54977d2349d513c00586ec379ee3719e8c5a213c1c43b8702e945d1f6b746ba71dc53d70d98d9c SHA512 2372b40f5e5d391193c8560430c21d6b1d8d9aaefd8ea77aff68decc08addaea17c34ae3b3f754b6069bbab797f06361438585411276d680da2a18d6361be1fd
|
DIST python-gentoo-patches-3.11.1.tar.xz 7076 BLAKE2B 3ec45f7529d34eabc9d9ba7fa7f8dd51d8754d9758a605b61857a9fd80386a0357837c925263ad7b0e207ff916944b94cc0e03c0f59921f839d5e51d92f0e47e SHA512 4253dbfa057a91db584b92550e2d39d87986f33041233bc400dd0254cbd95415b33fc47b0fe997bb84192c755bc16d3d31941bba4c216ee4d65facf0b48c7862
|
||||||
DIST python-gentoo-patches-3.12.0a1_p2-r1.tar.xz 9168 BLAKE2B c2f1018c7890518c66051a3470bb4bec45342c0656a143e0a25ea5b2ec5c27a1285345f8f6fbc7eaea5e216ae1bd2462ecd6ad251851368921cb3fe816652d43 SHA512 7c5436768e3e4de8bafe16f0709115901c90892b127e6f81c06a6da4a3a35c973cb38542180c714d0f2848972db18a0f70e33f0a4dce9b037ea0d15ace045f5a
|
DIST python-gentoo-patches-3.12.0a3.tar.xz 6152 BLAKE2B 6c8c88100d184440cf27a4b9baf4f192310f62960b2061adca8dd423745836048f3f8489c434c51ab7572320356bc889498d68f3635f174194d6009e1b9277e4 SHA512 7b0dbcbefeafbdb2a822bb06950844ff21336ba1685a2af6bf2bd32b1ecde7c17591d01b2a018105b8c094149a9804d709c3ca17af67378644ad40fd5e02c012
|
||||||
DIST python-gentoo-patches-3.12.0a2.tar.xz 6164 BLAKE2B 734068ed87dae1bb30b61f42436664936f27c2507e89fde6da0ce10f791d444b54e8298810717e461b60b7fe572a8fbf2cc9c787e59f01aa0eb5fd1360b212bd SHA512 96e060dc6f2cf412cb1a1be251a6cdd2c30cd2706bfc669dfb920815bcc768b712ed53cc43ee6a1606504a19fdcd9492e7d88bf7e334e1dde2769aa7f1e6ed2d
|
DIST python-gentoo-patches-3.8.16.tar.xz 28716 BLAKE2B 28ccad9d77a89f80f72dd12eb89d657825e80061eaa069d4c491736bffd87b235f483b9d079b9f383377ea4bc6c19471bb6a4869a37fc0401abe28e2444fd9d2 SHA512 fe94ee2851af5c87c64ea3af5c1a744a53dcb03743f824a7726803daf454f38511894e24fe68be9de4ab59d1798161a3c320748309d04afd1e77906df353a246
|
||||||
DIST python-gentoo-patches-3.8.15_p3-r1.tar.xz 30604 BLAKE2B 68ddeff291a70dfe22e8a0276b30db5a37d7e53dfc5d52c311573136f6fc322cddc65478684ed6339cd8156170588fe8ea3a454a5ec18e0bb91a898dc7c99f1e SHA512 ce9c73cd2b53c5c7f8bb27c65d5ea02bb7c38bfc1b25c972203fcea52bd1ffe4afcb65eedc8556b026a2faf0fc402f566c38b91ee54d6580bc958c0322e90e0a
|
DIST python-gentoo-patches-3.9.16.tar.xz 23348 BLAKE2B 26b66e57530d167776d2aee60fd4620fc8e6c229f371616fdaa74aa2f03fd5a50b61653a5f34e0f2659901ba167af7c2aadbb0d2db773ab08bac8b3125c84b77 SHA512 8260369d96a6328ad8498359ecc56f48cb02015547065cdaec28a6bb2293bef420cb12764fae9fdd13f4a6faa60c4c402e804a22cbed7dca031ac1679032f9f6
|
||||||
DIST python-gentoo-patches-3.9.15_p3-r1.tar.xz 26400 BLAKE2B 27198acf3e9087b96ef15328b9da6d80837a459c62b21c9785fde77dc6f4a5c8c4ccbc3cb48e5af684a253a978c5562fb1a342e6a554d2247aa968fd5890d6f5 SHA512 d658dc89ca29070de2a39d643cc9585ae7f66232dececfd7007cb57a6c6ededd30ae030dbe9226686b8517c48fdb5ed7e681decb64b207e41173a0993f461aea
|
|
||||||
|
@ -10,7 +10,7 @@ inherit python-utils-r1 toolchain-funcs verify-sig
|
|||||||
MY_PV=${PV/_rc/rc}
|
MY_PV=${PV/_rc/rc}
|
||||||
MY_P="Python-${MY_PV%_p*}"
|
MY_P="Python-${MY_PV%_p*}"
|
||||||
PYVER=$(ver_cut 1-2)
|
PYVER=$(ver_cut 1-2)
|
||||||
PATCHSET="python-gentoo-patches-${MY_PV}-r1"
|
PATCHSET="python-gentoo-patches-${MY_PV}"
|
||||||
|
|
||||||
DESCRIPTION="An interpreted, interactive, object-oriented programming language"
|
DESCRIPTION="An interpreted, interactive, object-oriented programming language"
|
||||||
HOMEPAGE="
|
HOMEPAGE="
|
||||||
@ -230,6 +230,9 @@ src_configure() {
|
|||||||
local -x OPT=
|
local -x OPT=
|
||||||
|
|
||||||
if tc-is-cross-compiler ; then
|
if tc-is-cross-compiler ; then
|
||||||
|
# Hack to workaround get_libdir not being able to handle CBUILD, bug #794181
|
||||||
|
local cbuild_libdir=$(unset PKG_CONFIG_PATH ; $(tc-getBUILD_PKG_CONFIG) --keep-system-libs --libs-only-L libffi)
|
||||||
|
|
||||||
# pass system CFLAGS & LDFLAGS as _NODIST, otherwise they'll get
|
# pass system CFLAGS & LDFLAGS as _NODIST, otherwise they'll get
|
||||||
# propagated to sysconfig for built extensions
|
# propagated to sysconfig for built extensions
|
||||||
local -x CFLAGS_NODIST=${CFLAGS_FOR_BUILD}
|
local -x CFLAGS_NODIST=${CFLAGS_FOR_BUILD}
|
||||||
@ -241,6 +244,8 @@ src_configure() {
|
|||||||
local myeconfargs_cbuild=(
|
local myeconfargs_cbuild=(
|
||||||
"${myeconfargs[@]}"
|
"${myeconfargs[@]}"
|
||||||
|
|
||||||
|
--libdir="${cbuild_libdir:2}"
|
||||||
|
|
||||||
# As minimal as possible for the mini CBUILD Python
|
# As minimal as possible for the mini CBUILD Python
|
||||||
# we build just for cross.
|
# we build just for cross.
|
||||||
--without-lto
|
--without-lto
|
||||||
@ -253,7 +258,10 @@ src_configure() {
|
|||||||
|
|
||||||
mkdir "${WORKDIR}"/${P}-${CBUILD} || die
|
mkdir "${WORKDIR}"/${P}-${CBUILD} || die
|
||||||
pushd "${WORKDIR}"/${P}-${CBUILD} &> /dev/null || die
|
pushd "${WORKDIR}"/${P}-${CBUILD} &> /dev/null || die
|
||||||
ECONF_SOURCE="${S}" econf_build "${myeconfargs_cbuild[@]}"
|
# We disable _ctypes and _crypt for CBUILD because Python's setup.py can't handle locating
|
||||||
|
# libdir correctly for cross.
|
||||||
|
PYTHON_DISABLE_MODULES="${PYTHON_DISABLE_MODULES} _ctypes _crypt" \
|
||||||
|
ECONF_SOURCE="${S}" econf_build "${myeconfargs_cbuild[@]}"
|
||||||
|
|
||||||
# Avoid as many dependencies as possible for the cross build.
|
# Avoid as many dependencies as possible for the cross build.
|
||||||
cat >> Makefile <<-EOF || die
|
cat >> Makefile <<-EOF || die
|
||||||
@ -276,7 +284,7 @@ src_configure() {
|
|||||||
# not in src_compile, because CHOST configure for Python
|
# not in src_compile, because CHOST configure for Python
|
||||||
# will check the existence of the Python it was pointed to
|
# will check the existence of the Python it was pointed to
|
||||||
# immediately.
|
# immediately.
|
||||||
emake
|
PYTHON_DISABLE_MODULES="${PYTHON_DISABLE_MODULES} _ctypes _crypt" emake
|
||||||
popd &> /dev/null || die
|
popd &> /dev/null || die
|
||||||
fi
|
fi
|
||||||
|
|
@ -10,7 +10,7 @@ inherit python-utils-r1 toolchain-funcs verify-sig
|
|||||||
MY_PV=${PV/_rc/rc}
|
MY_PV=${PV/_rc/rc}
|
||||||
MY_P="Python-${MY_PV%_p*}"
|
MY_P="Python-${MY_PV%_p*}"
|
||||||
PYVER=$(ver_cut 1-2)
|
PYVER=$(ver_cut 1-2)
|
||||||
PATCHSET="python-gentoo-patches-${MY_PV}-r1"
|
PATCHSET="python-gentoo-patches-${MY_PV}"
|
||||||
|
|
||||||
DESCRIPTION="An interpreted, interactive, object-oriented programming language"
|
DESCRIPTION="An interpreted, interactive, object-oriented programming language"
|
||||||
HOMEPAGE="
|
HOMEPAGE="
|
||||||
@ -219,6 +219,9 @@ src_configure() {
|
|||||||
local -x OPT=
|
local -x OPT=
|
||||||
|
|
||||||
if tc-is-cross-compiler ; then
|
if tc-is-cross-compiler ; then
|
||||||
|
# Hack to workaround get_libdir not being able to handle CBUILD, bug #794181
|
||||||
|
local cbuild_libdir=$(unset PKG_CONFIG_PATH ; $(tc-getBUILD_PKG_CONFIG) --keep-system-libs --libs-only-L libffi)
|
||||||
|
|
||||||
# pass system CFLAGS & LDFLAGS as _NODIST, otherwise they'll get
|
# pass system CFLAGS & LDFLAGS as _NODIST, otherwise they'll get
|
||||||
# propagated to sysconfig for built extensions
|
# propagated to sysconfig for built extensions
|
||||||
local -x CFLAGS_NODIST=${CFLAGS_FOR_BUILD}
|
local -x CFLAGS_NODIST=${CFLAGS_FOR_BUILD}
|
||||||
@ -230,6 +233,8 @@ src_configure() {
|
|||||||
local myeconfargs_cbuild=(
|
local myeconfargs_cbuild=(
|
||||||
"${myeconfargs[@]}"
|
"${myeconfargs[@]}"
|
||||||
|
|
||||||
|
--libdir="${cbuild_libdir:2}"
|
||||||
|
|
||||||
# As minimal as possible for the mini CBUILD Python
|
# As minimal as possible for the mini CBUILD Python
|
||||||
# we build just for cross to satisfy --with-build-python.
|
# we build just for cross to satisfy --with-build-python.
|
||||||
--without-lto
|
--without-lto
|
||||||
@ -245,7 +250,10 @@ src_configure() {
|
|||||||
|
|
||||||
mkdir "${WORKDIR}"/${P}-${CBUILD} || die
|
mkdir "${WORKDIR}"/${P}-${CBUILD} || die
|
||||||
pushd "${WORKDIR}"/${P}-${CBUILD} &> /dev/null || die
|
pushd "${WORKDIR}"/${P}-${CBUILD} &> /dev/null || die
|
||||||
ECONF_SOURCE="${S}" econf_build "${myeconfargs_cbuild[@]}"
|
# We disable _ctypes and _crypt for CBUILD because Python's setup.py can't handle locating
|
||||||
|
# libdir correctly for cross.
|
||||||
|
PYTHON_DISABLE_MODULES="${PYTHON_DISABLE_MODULES} _ctypes _crypt" \
|
||||||
|
ECONF_SOURCE="${S}" econf_build "${myeconfargs_cbuild[@]}"
|
||||||
|
|
||||||
# Avoid as many dependencies as possible for the cross build.
|
# Avoid as many dependencies as possible for the cross build.
|
||||||
cat >> Makefile <<-EOF || die
|
cat >> Makefile <<-EOF || die
|
||||||
@ -268,7 +276,7 @@ src_configure() {
|
|||||||
# not in src_compile, because CHOST configure for Python
|
# not in src_compile, because CHOST configure for Python
|
||||||
# will check the existence of the --with-build-python value
|
# will check the existence of the --with-build-python value
|
||||||
# immediately.
|
# immediately.
|
||||||
emake
|
PYTHON_DISABLE_MODULES="${PYTHON_DISABLE_MODULES} _ctypes _crypt" emake
|
||||||
popd &> /dev/null || die
|
popd &> /dev/null || die
|
||||||
fi
|
fi
|
||||||
|
|
@ -1,494 +0,0 @@
|
|||||||
# Copyright 1999-2022 Gentoo Authors
|
|
||||||
# Distributed under the terms of the GNU General Public License v2
|
|
||||||
|
|
||||||
EAPI="7"
|
|
||||||
WANT_LIBTOOL="none"
|
|
||||||
|
|
||||||
inherit autotools check-reqs flag-o-matic multiprocessing pax-utils
|
|
||||||
inherit python-utils-r1 toolchain-funcs verify-sig
|
|
||||||
|
|
||||||
MY_PV=${PV/_alpha/a}
|
|
||||||
MY_P="Python-${MY_PV%_p*}"
|
|
||||||
PYVER=$(ver_cut 1-2)
|
|
||||||
PATCHSET="python-gentoo-patches-${MY_PV}-r1"
|
|
||||||
|
|
||||||
DESCRIPTION="An interpreted, interactive, object-oriented programming language"
|
|
||||||
HOMEPAGE="
|
|
||||||
https://www.python.org/
|
|
||||||
https://github.com/python/cpython/
|
|
||||||
"
|
|
||||||
SRC_URI="
|
|
||||||
https://www.python.org/ftp/python/${PV%%_*}/${MY_P}.tar.xz
|
|
||||||
https://dev.gentoo.org/~mgorny/dist/python/${PATCHSET}.tar.xz
|
|
||||||
verify-sig? (
|
|
||||||
https://www.python.org/ftp/python/${PV%%_*}/${MY_P}.tar.xz.asc
|
|
||||||
)
|
|
||||||
"
|
|
||||||
S="${WORKDIR}/${MY_P}"
|
|
||||||
|
|
||||||
LICENSE="PSF-2"
|
|
||||||
SLOT="${PYVER}"
|
|
||||||
KEYWORDS="~alpha ~amd64 ~arm ~arm64 ~hppa ~ia64 ~loong ~m68k ~mips ~ppc ~ppc64 ~riscv ~s390 ~sparc ~x86"
|
|
||||||
IUSE="
|
|
||||||
bluetooth build +ensurepip examples gdbm hardened libedit lto
|
|
||||||
+ncurses pgo +readline +sqlite +ssl test tk
|
|
||||||
"
|
|
||||||
RESTRICT="!test? ( test )"
|
|
||||||
|
|
||||||
# Do not add a dependency on dev-lang/python to this ebuild.
|
|
||||||
# If you need to apply a patch which requires python for bootstrapping, please
|
|
||||||
# run the bootstrap code on your dev box and include the results in the
|
|
||||||
# patchset. See bug 447752.
|
|
||||||
|
|
||||||
RDEPEND="
|
|
||||||
app-arch/bzip2:=
|
|
||||||
app-arch/xz-utils:=
|
|
||||||
app-crypt/libb2
|
|
||||||
>=dev-libs/expat-2.1:=
|
|
||||||
dev-libs/libffi:=
|
|
||||||
sys-apps/util-linux:=
|
|
||||||
>=sys-libs/zlib-1.1.3:=
|
|
||||||
virtual/libcrypt:=
|
|
||||||
virtual/libintl
|
|
||||||
ensurepip? ( dev-python/ensurepip-wheels )
|
|
||||||
gdbm? ( sys-libs/gdbm:=[berkdb] )
|
|
||||||
ncurses? ( >=sys-libs/ncurses-5.2:= )
|
|
||||||
readline? (
|
|
||||||
!libedit? ( >=sys-libs/readline-4.1:= )
|
|
||||||
libedit? ( dev-libs/libedit:= )
|
|
||||||
)
|
|
||||||
sqlite? ( >=dev-db/sqlite-3.3.8:3= )
|
|
||||||
ssl? ( >=dev-libs/openssl-1.1.1:= )
|
|
||||||
tk? (
|
|
||||||
>=dev-lang/tcl-8.0:=
|
|
||||||
>=dev-lang/tk-8.0:=
|
|
||||||
dev-tcltk/blt:=
|
|
||||||
dev-tcltk/tix
|
|
||||||
)
|
|
||||||
!!<sys-apps/sandbox-2.21
|
|
||||||
"
|
|
||||||
# bluetooth requires headers from bluez
|
|
||||||
DEPEND="
|
|
||||||
${RDEPEND}
|
|
||||||
bluetooth? ( net-wireless/bluez )
|
|
||||||
test? ( app-arch/xz-utils[extra-filters(+)] )
|
|
||||||
"
|
|
||||||
# autoconf-archive needed to eautoreconf
|
|
||||||
BDEPEND="
|
|
||||||
sys-devel/autoconf-archive
|
|
||||||
app-alternatives/awk
|
|
||||||
virtual/pkgconfig
|
|
||||||
verify-sig? ( >=sec-keys/openpgp-keys-python-20221025 )
|
|
||||||
"
|
|
||||||
RDEPEND+="
|
|
||||||
!build? ( app-misc/mime-types )
|
|
||||||
"
|
|
||||||
if [[ ${PV} != *_alpha* ]]; then
|
|
||||||
RDEPEND+="
|
|
||||||
dev-lang/python-exec[python_targets_python${PYVER/./_}(-)]
|
|
||||||
"
|
|
||||||
fi
|
|
||||||
|
|
||||||
VERIFY_SIG_OPENPGP_KEY_PATH=${BROOT}/usr/share/openpgp-keys/python.org.asc
|
|
||||||
|
|
||||||
# large file tests involve a 2.5G file being copied (duplicated)
|
|
||||||
CHECKREQS_DISK_BUILD=5500M
|
|
||||||
|
|
||||||
QA_PKGCONFIG_VERSION=${PYVER}
|
|
||||||
|
|
||||||
pkg_pretend() {
|
|
||||||
use test && check-reqs_pkg_pretend
|
|
||||||
}
|
|
||||||
|
|
||||||
pkg_setup() {
|
|
||||||
use test && check-reqs_pkg_setup
|
|
||||||
}
|
|
||||||
|
|
||||||
src_unpack() {
|
|
||||||
if use verify-sig; then
|
|
||||||
verify-sig_verify_detached "${DISTDIR}"/${MY_P}.tar.xz{,.asc}
|
|
||||||
fi
|
|
||||||
default
|
|
||||||
}
|
|
||||||
|
|
||||||
src_prepare() {
|
|
||||||
# Ensure that internal copies of expat and libffi are not used.
|
|
||||||
# TODO: Makefile has annoying deps on expat headers
|
|
||||||
#rm -r Modules/expat || die
|
|
||||||
rm -r Modules/_ctypes/libffi* || die
|
|
||||||
|
|
||||||
local PATCHES=(
|
|
||||||
"${WORKDIR}/${PATCHSET}"
|
|
||||||
)
|
|
||||||
|
|
||||||
default
|
|
||||||
|
|
||||||
# force the correct number of jobs
|
|
||||||
# https://bugs.gentoo.org/737660
|
|
||||||
sed -i -e "s:-j0:-j$(makeopts_jobs):" Makefile.pre.in || die
|
|
||||||
|
|
||||||
eautoreconf
|
|
||||||
}
|
|
||||||
|
|
||||||
src_configure() {
|
|
||||||
local disable
|
|
||||||
# disable automagic bluetooth headers detection
|
|
||||||
if ! use bluetooth; then
|
|
||||||
local -x ac_cv_header_bluetooth_bluetooth_h=no
|
|
||||||
fi
|
|
||||||
|
|
||||||
append-flags -fwrapv
|
|
||||||
filter-flags -malign-double
|
|
||||||
|
|
||||||
# https://bugs.gentoo.org/700012
|
|
||||||
if is-flagq -flto || is-flagq '-flto=*'; then
|
|
||||||
append-cflags $(test-flags-CC -ffat-lto-objects)
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Export CXX so it ends up in /usr/lib/python3.X/config/Makefile.
|
|
||||||
# PKG_CONFIG needed for cross.
|
|
||||||
tc-export CXX PKG_CONFIG
|
|
||||||
|
|
||||||
local dbmliborder=
|
|
||||||
if use gdbm; then
|
|
||||||
dbmliborder+="${dbmliborder:+:}gdbm"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if use pgo; then
|
|
||||||
local profile_task_flags=(
|
|
||||||
-m test
|
|
||||||
"-j$(makeopts_jobs)"
|
|
||||||
--pgo-extended
|
|
||||||
-x test_gdb
|
|
||||||
-u-network
|
|
||||||
|
|
||||||
# All of these seem to occasionally hang for PGO inconsistently
|
|
||||||
# They'll even hang here but be fine in src_test sometimes.
|
|
||||||
# bug #828535 (and related: bug #788022)
|
|
||||||
-x test_asyncio
|
|
||||||
-x test_httpservers
|
|
||||||
-x test_logging
|
|
||||||
-x test_multiprocessing_fork
|
|
||||||
-x test_socket
|
|
||||||
-x test_xmlrpc
|
|
||||||
)
|
|
||||||
|
|
||||||
if has_version "app-arch/rpm" ; then
|
|
||||||
# Avoid sandbox failure (attempts to write to /var/lib/rpm)
|
|
||||||
profile_task_flags+=(
|
|
||||||
-x test_distutils
|
|
||||||
)
|
|
||||||
fi
|
|
||||||
local -x PROFILE_TASK="${profile_task_flags[*]}"
|
|
||||||
fi
|
|
||||||
|
|
||||||
local myeconfargs=(
|
|
||||||
# glibc-2.30 removes it; since we can't cleanly force-rebuild
|
|
||||||
# Python on glibc upgrade, remove it proactively to give
|
|
||||||
# a chance for users rebuilding python before glibc
|
|
||||||
ac_cv_header_stropts_h=no
|
|
||||||
|
|
||||||
--enable-shared
|
|
||||||
--without-static-libpython
|
|
||||||
--enable-ipv6
|
|
||||||
--infodir='${prefix}/share/info'
|
|
||||||
--mandir='${prefix}/share/man'
|
|
||||||
--with-computed-gotos
|
|
||||||
--with-dbmliborder="${dbmliborder}"
|
|
||||||
--with-libc=
|
|
||||||
--enable-loadable-sqlite-extensions
|
|
||||||
--without-ensurepip
|
|
||||||
--with-system-expat
|
|
||||||
--with-system-ffi
|
|
||||||
--with-platlibdir=lib
|
|
||||||
--with-pkg-config=yes
|
|
||||||
--with-wheel-pkg-dir="${EPREFIX}"/usr/lib/python/ensurepip
|
|
||||||
|
|
||||||
$(use_with lto)
|
|
||||||
$(use_enable pgo optimizations)
|
|
||||||
$(use_with readline readline "$(usex libedit editline readline)")
|
|
||||||
)
|
|
||||||
|
|
||||||
# disable implicit optimization/debugging flags
|
|
||||||
local -x OPT=
|
|
||||||
|
|
||||||
if tc-is-cross-compiler ; then
|
|
||||||
# pass system CFLAGS & LDFLAGS as _NODIST, otherwise they'll get
|
|
||||||
# propagated to sysconfig for built extensions
|
|
||||||
local -x CFLAGS_NODIST=${CFLAGS_FOR_BUILD}
|
|
||||||
local -x LDFLAGS_NODIST=${LDFLAGS_FOR_BUILD}
|
|
||||||
local -x CFLAGS= LDFLAGS=
|
|
||||||
|
|
||||||
# We need to build our own Python on CBUILD first, and feed it in.
|
|
||||||
# bug #847910
|
|
||||||
local myeconfargs_cbuild=(
|
|
||||||
"${myeconfargs[@]}"
|
|
||||||
|
|
||||||
# As minimal as possible for the mini CBUILD Python
|
|
||||||
# we build just for cross to satisfy --with-build-python.
|
|
||||||
--without-lto
|
|
||||||
--without-readline
|
|
||||||
--disable-optimizations
|
|
||||||
)
|
|
||||||
|
|
||||||
myeconfargs+=(
|
|
||||||
# Point the imminent CHOST build to the Python we just
|
|
||||||
# built for CBUILD.
|
|
||||||
--with-build-python="${WORKDIR}"/${P}-${CBUILD}/python
|
|
||||||
)
|
|
||||||
|
|
||||||
mkdir "${WORKDIR}"/${P}-${CBUILD} || die
|
|
||||||
pushd "${WORKDIR}"/${P}-${CBUILD} &> /dev/null || die
|
|
||||||
ECONF_SOURCE="${S}" econf_build "${myeconfargs_cbuild[@]}"
|
|
||||||
|
|
||||||
# Avoid as many dependencies as possible for the cross build.
|
|
||||||
cat >> Makefile <<-EOF || die
|
|
||||||
MODULE_NIS_STATE=disabled
|
|
||||||
MODULE__DBM_STATE=disabled
|
|
||||||
MODULE__GDBM_STATE=disabled
|
|
||||||
MODULE__DBM_STATE=disabled
|
|
||||||
MODULE__SQLITE3_STATE=disabled
|
|
||||||
MODULE__HASHLIB_STATE=disabled
|
|
||||||
MODULE__SSL_STATE=disabled
|
|
||||||
MODULE__CURSES_STATE=disabled
|
|
||||||
MODULE__CURSES_PANEL_STATE=disabled
|
|
||||||
MODULE_READLINE_STATE=disabled
|
|
||||||
MODULE__TKINTER_STATE=disabled
|
|
||||||
MODULE_PYEXPAT_STATE=disabled
|
|
||||||
MODULE_ZLIB_STATE=disabled
|
|
||||||
EOF
|
|
||||||
|
|
||||||
# Unfortunately, we do have to build this immediately, and
|
|
||||||
# not in src_compile, because CHOST configure for Python
|
|
||||||
# will check the existence of the --with-build-python value
|
|
||||||
# immediately.
|
|
||||||
emake
|
|
||||||
popd &> /dev/null || die
|
|
||||||
fi
|
|
||||||
|
|
||||||
# pass system CFLAGS & LDFLAGS as _NODIST, otherwise they'll get
|
|
||||||
# propagated to sysconfig for built extensions
|
|
||||||
local -x CFLAGS_NODIST=${CFLAGS}
|
|
||||||
local -x LDFLAGS_NODIST=${LDFLAGS}
|
|
||||||
local -x CFLAGS= LDFLAGS=
|
|
||||||
|
|
||||||
# Fix implicit declarations on cross and prefix builds. Bug #674070.
|
|
||||||
if use ncurses; then
|
|
||||||
append-cppflags -I"${ESYSROOT}"/usr/include/ncursesw
|
|
||||||
fi
|
|
||||||
|
|
||||||
econf "${myeconfargs[@]}"
|
|
||||||
|
|
||||||
if grep -q "#define POSIX_SEMAPHORES_NOT_ENABLED 1" pyconfig.h; then
|
|
||||||
eerror "configure has detected that the sem_open function is broken."
|
|
||||||
eerror "Please ensure that /dev/shm is mounted as a tmpfs with mode 1777."
|
|
||||||
die "Broken sem_open function (bug 496328)"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# force-disable modules we don't want built
|
|
||||||
local disable_modules=( NIS )
|
|
||||||
use gdbm || disable_modules+=( _GDBM _DBM )
|
|
||||||
use sqlite || disable_modules+=( _SQLITE3 )
|
|
||||||
use ssl || disable_modules+=( _HASHLIB _SSL )
|
|
||||||
use ncurses || disable_modules+=( _CURSES _CURSES_PANEL )
|
|
||||||
use readline || disable_modules+=( READLINE )
|
|
||||||
use tk || disable_modules+=( _TKINTER )
|
|
||||||
|
|
||||||
local mod
|
|
||||||
for mod in "${disable_modules[@]}"; do
|
|
||||||
echo "MODULE_${mod}_STATE=disabled"
|
|
||||||
done >> Makefile || die
|
|
||||||
|
|
||||||
# install epython.py as part of stdlib
|
|
||||||
echo "EPYTHON='python${PYVER}'" > Lib/epython.py || die
|
|
||||||
}
|
|
||||||
|
|
||||||
src_compile() {
|
|
||||||
# Ensure sed works as expected
|
|
||||||
# https://bugs.gentoo.org/594768
|
|
||||||
local -x LC_ALL=C
|
|
||||||
# Prevent using distutils bundled by setuptools.
|
|
||||||
# https://bugs.gentoo.org/823728
|
|
||||||
export SETUPTOOLS_USE_DISTUTILS=stdlib
|
|
||||||
export PYTHONSTRICTEXTENSIONBUILD=1
|
|
||||||
|
|
||||||
# Save PYTHONDONTWRITEBYTECODE so that 'has_version' doesn't
|
|
||||||
# end up writing bytecode & violating sandbox.
|
|
||||||
# bug #831897
|
|
||||||
local -x _PYTHONDONTWRITEBYTECODE=${PYTHONDONTWRITEBYTECODE}
|
|
||||||
|
|
||||||
if use pgo ; then
|
|
||||||
# bug 660358
|
|
||||||
local -x COLUMNS=80
|
|
||||||
local -x PYTHONDONTWRITEBYTECODE=
|
|
||||||
|
|
||||||
addpredict "/usr/lib/python${PYVER}/site-packages"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# also need to clear the flags explicitly here or they end up
|
|
||||||
# in _sysconfigdata*
|
|
||||||
emake CPPFLAGS= CFLAGS= LDFLAGS=
|
|
||||||
|
|
||||||
# Restore saved value from above.
|
|
||||||
local -x PYTHONDONTWRITEBYTECODE=${_PYTHONDONTWRITEBYTECODE}
|
|
||||||
|
|
||||||
# Work around bug 329499. See also bug 413751 and 457194.
|
|
||||||
if has_version dev-libs/libffi[pax-kernel]; then
|
|
||||||
pax-mark E python
|
|
||||||
else
|
|
||||||
pax-mark m python
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
src_test() {
|
|
||||||
# Tests will not work when cross compiling.
|
|
||||||
if tc-is-cross-compiler; then
|
|
||||||
elog "Disabling tests due to crosscompiling."
|
|
||||||
return
|
|
||||||
fi
|
|
||||||
|
|
||||||
# this just happens to skip test_support.test_freeze that is broken
|
|
||||||
# without bundled expat
|
|
||||||
# TODO: get a proper skip for it upstream
|
|
||||||
local -x LOGNAME=buildbot
|
|
||||||
|
|
||||||
local test_opts=(
|
|
||||||
-u-network
|
|
||||||
-j "$(makeopts_jobs)"
|
|
||||||
|
|
||||||
# fails
|
|
||||||
-x test_gdb
|
|
||||||
)
|
|
||||||
|
|
||||||
if use sparc ; then
|
|
||||||
# bug #788022
|
|
||||||
test_opts+=(
|
|
||||||
-x test_multiprocessing_fork
|
|
||||||
-x test_multiprocessing_forkserver
|
|
||||||
)
|
|
||||||
fi
|
|
||||||
|
|
||||||
# workaround docutils breaking tests
|
|
||||||
cat > Lib/docutils.py <<-EOF || die
|
|
||||||
raise ImportError("Thou shalt not import!")
|
|
||||||
EOF
|
|
||||||
|
|
||||||
# bug 660358
|
|
||||||
local -x COLUMNS=80
|
|
||||||
local -x PYTHONDONTWRITEBYTECODE=
|
|
||||||
# workaround https://bugs.gentoo.org/775416
|
|
||||||
addwrite "/usr/lib/python${PYVER}/site-packages"
|
|
||||||
|
|
||||||
nonfatal emake test EXTRATESTOPTS="${test_opts[*]}" \
|
|
||||||
CPPFLAGS= CFLAGS= LDFLAGS= < /dev/tty
|
|
||||||
local ret=${?}
|
|
||||||
|
|
||||||
rm Lib/docutils.py || die
|
|
||||||
|
|
||||||
[[ ${ret} -eq 0 ]] || die "emake test failed"
|
|
||||||
}
|
|
||||||
|
|
||||||
src_install() {
|
|
||||||
local libdir=${ED}/usr/lib/python${PYVER}
|
|
||||||
|
|
||||||
# -j1 hack for now for bug #843458
|
|
||||||
emake -j1 DESTDIR="${D}" altinstall
|
|
||||||
|
|
||||||
# Fix collisions between different slots of Python.
|
|
||||||
rm "${ED}/usr/$(get_libdir)/libpython3.so" || die
|
|
||||||
|
|
||||||
# Cheap hack to get version with ABIFLAGS
|
|
||||||
local abiver=$(cd "${ED}/usr/include"; echo python*)
|
|
||||||
if [[ ${abiver} != python${PYVER} ]]; then
|
|
||||||
# Replace python3.X with a symlink to python3.Xm
|
|
||||||
rm "${ED}/usr/bin/python${PYVER}" || die
|
|
||||||
dosym "${abiver}" "/usr/bin/python${PYVER}"
|
|
||||||
# Create python3.X-config symlink
|
|
||||||
dosym "${abiver}-config" "/usr/bin/python${PYVER}-config"
|
|
||||||
# Create python-3.5m.pc symlink
|
|
||||||
dosym "python-${PYVER}.pc" "/usr/$(get_libdir)/pkgconfig/${abiver/${PYVER}/-${PYVER}}.pc"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# python seems to get rebuilt in src_install (bug 569908)
|
|
||||||
# Work around it for now.
|
|
||||||
if has_version dev-libs/libffi[pax-kernel]; then
|
|
||||||
pax-mark E "${ED}/usr/bin/${abiver}"
|
|
||||||
else
|
|
||||||
pax-mark m "${ED}/usr/bin/${abiver}"
|
|
||||||
fi
|
|
||||||
|
|
||||||
rm -r "${libdir}"/ensurepip/_bundled || die
|
|
||||||
if ! use ensurepip; then
|
|
||||||
rm -r "${libdir}"/ensurepip || die
|
|
||||||
fi
|
|
||||||
if ! use sqlite; then
|
|
||||||
rm -r "${libdir}/"sqlite3 || die
|
|
||||||
fi
|
|
||||||
if ! use tk; then
|
|
||||||
rm -r "${ED}/usr/bin/idle${PYVER}" || die
|
|
||||||
rm -r "${libdir}/"{idlelib,tkinter,test/test_tk*} || die
|
|
||||||
fi
|
|
||||||
|
|
||||||
dodoc Misc/{ACKS,HISTORY,NEWS}
|
|
||||||
|
|
||||||
if use examples; then
|
|
||||||
docinto examples
|
|
||||||
find Tools -name __pycache__ -exec rm -fr {} + || die
|
|
||||||
dodoc -r Tools
|
|
||||||
fi
|
|
||||||
insinto /usr/share/gdb/auto-load/usr/$(get_libdir) #443510
|
|
||||||
local libname=$(
|
|
||||||
printf 'e:\n\t@echo $(INSTSONAME)\ninclude Makefile\n' |
|
|
||||||
emake --no-print-directory -s -f - 2>/dev/null
|
|
||||||
)
|
|
||||||
newins Tools/gdb/libpython.py "${libname}"-gdb.py
|
|
||||||
|
|
||||||
newconfd "${FILESDIR}/pydoc.conf" pydoc-${PYVER}
|
|
||||||
newinitd "${FILESDIR}/pydoc.init" pydoc-${PYVER}
|
|
||||||
sed \
|
|
||||||
-e "s:@PYDOC_PORT_VARIABLE@:PYDOC${PYVER/./_}_PORT:" \
|
|
||||||
-e "s:@PYDOC@:pydoc${PYVER}:" \
|
|
||||||
-i "${ED}/etc/conf.d/pydoc-${PYVER}" \
|
|
||||||
"${ED}/etc/init.d/pydoc-${PYVER}" || die "sed failed"
|
|
||||||
|
|
||||||
# python-exec wrapping support
|
|
||||||
local pymajor=${PYVER%.*}
|
|
||||||
local EPYTHON=python${PYVER}
|
|
||||||
local scriptdir=${D}$(python_get_scriptdir)
|
|
||||||
mkdir -p "${scriptdir}" || die
|
|
||||||
# python and pythonX
|
|
||||||
ln -s "../../../bin/${abiver}" "${scriptdir}/python${pymajor}" || die
|
|
||||||
ln -s "python${pymajor}" "${scriptdir}/python" || die
|
|
||||||
# python-config and pythonX-config
|
|
||||||
# note: we need to create a wrapper rather than symlinking it due
|
|
||||||
# to some random dirname(argv[0]) magic performed by python-config
|
|
||||||
cat > "${scriptdir}/python${pymajor}-config" <<-EOF || die
|
|
||||||
#!/bin/sh
|
|
||||||
exec "${abiver}-config" "\${@}"
|
|
||||||
EOF
|
|
||||||
chmod +x "${scriptdir}/python${pymajor}-config" || die
|
|
||||||
ln -s "python${pymajor}-config" "${scriptdir}/python-config" || die
|
|
||||||
# 2to3, pydoc
|
|
||||||
ln -s "../../../bin/2to3-${PYVER}" "${scriptdir}/2to3" || die
|
|
||||||
ln -s "../../../bin/pydoc${PYVER}" "${scriptdir}/pydoc" || die
|
|
||||||
# idle
|
|
||||||
if use tk; then
|
|
||||||
ln -s "../../../bin/idle${PYVER}" "${scriptdir}/idle" || die
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
pkg_postinst() {
|
|
||||||
local v
|
|
||||||
for v in ${REPLACING_VERSIONS}; do
|
|
||||||
if ver_test "${v}" -lt 3.11.0_beta4-r2; then
|
|
||||||
ewarn "Python 3.11.0b4 has changed its module ABI. The .pyc files"
|
|
||||||
ewarn "installed previously are no longer valid and will be regenerated"
|
|
||||||
ewarn "(or ignored) on the next import. This may cause sandbox failures"
|
|
||||||
ewarn "when installing some packages and checksum mismatches when removing"
|
|
||||||
ewarn "old versions. To actively prevent this, rebuild all packages"
|
|
||||||
ewarn "installing Python 3.11 modules, e.g. using:"
|
|
||||||
ewarn
|
|
||||||
ewarn " emerge -1v /usr/lib/python3.11/site-packages"
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
}
|
|
@ -215,6 +215,9 @@ src_configure() {
|
|||||||
local -x OPT=
|
local -x OPT=
|
||||||
|
|
||||||
if tc-is-cross-compiler ; then
|
if tc-is-cross-compiler ; then
|
||||||
|
# Hack to workaround get_libdir not being able to handle CBUILD, bug #794181
|
||||||
|
local cbuild_libdir=$(unset PKG_CONFIG_PATH ; $(tc-getBUILD_PKG_CONFIG) --keep-system-libs --libs-only-L libffi)
|
||||||
|
|
||||||
# pass system CFLAGS & LDFLAGS as _NODIST, otherwise they'll get
|
# pass system CFLAGS & LDFLAGS as _NODIST, otherwise they'll get
|
||||||
# propagated to sysconfig for built extensions
|
# propagated to sysconfig for built extensions
|
||||||
local -x CFLAGS_NODIST=${CFLAGS_FOR_BUILD}
|
local -x CFLAGS_NODIST=${CFLAGS_FOR_BUILD}
|
||||||
@ -226,6 +229,8 @@ src_configure() {
|
|||||||
local myeconfargs_cbuild=(
|
local myeconfargs_cbuild=(
|
||||||
"${myeconfargs[@]}"
|
"${myeconfargs[@]}"
|
||||||
|
|
||||||
|
--libdir="${cbuild_libdir:2}"
|
||||||
|
|
||||||
# As minimal as possible for the mini CBUILD Python
|
# As minimal as possible for the mini CBUILD Python
|
||||||
# we build just for cross to satisfy --with-build-python.
|
# we build just for cross to satisfy --with-build-python.
|
||||||
--without-lto
|
--without-lto
|
||||||
@ -241,7 +246,10 @@ src_configure() {
|
|||||||
|
|
||||||
mkdir "${WORKDIR}"/${P}-${CBUILD} || die
|
mkdir "${WORKDIR}"/${P}-${CBUILD} || die
|
||||||
pushd "${WORKDIR}"/${P}-${CBUILD} &> /dev/null || die
|
pushd "${WORKDIR}"/${P}-${CBUILD} &> /dev/null || die
|
||||||
ECONF_SOURCE="${S}" econf_build "${myeconfargs_cbuild[@]}"
|
# We disable _ctypes and _crypt for CBUILD because Python's setup.py can't handle locating
|
||||||
|
# libdir correctly for cross.
|
||||||
|
PYTHON_DISABLE_MODULES="${PYTHON_DISABLE_MODULES} _ctypes _crypt" \
|
||||||
|
ECONF_SOURCE="${S}" econf_build "${myeconfargs_cbuild[@]}"
|
||||||
|
|
||||||
# Avoid as many dependencies as possible for the cross build.
|
# Avoid as many dependencies as possible for the cross build.
|
||||||
cat >> Makefile <<-EOF || die
|
cat >> Makefile <<-EOF || die
|
||||||
@ -264,7 +272,7 @@ src_configure() {
|
|||||||
# not in src_compile, because CHOST configure for Python
|
# not in src_compile, because CHOST configure for Python
|
||||||
# will check the existence of the --with-build-python value
|
# will check the existence of the --with-build-python value
|
||||||
# immediately.
|
# immediately.
|
||||||
emake
|
PYTHON_DISABLE_MODULES="${PYTHON_DISABLE_MODULES} _ctypes _crypt" emake
|
||||||
popd &> /dev/null || die
|
popd &> /dev/null || die
|
||||||
fi
|
fi
|
||||||
|
|
@ -10,7 +10,7 @@ inherit python-utils-r1 toolchain-funcs verify-sig
|
|||||||
MY_PV=${PV/_rc/rc}
|
MY_PV=${PV/_rc/rc}
|
||||||
MY_P="Python-${MY_PV%_p*}"
|
MY_P="Python-${MY_PV%_p*}"
|
||||||
PYVER=$(ver_cut 1-2)
|
PYVER=$(ver_cut 1-2)
|
||||||
PATCHSET="python-gentoo-patches-${MY_PV}-r1"
|
PATCHSET="python-gentoo-patches-${MY_PV}"
|
||||||
|
|
||||||
DESCRIPTION="An interpreted, interactive, object-oriented programming language"
|
DESCRIPTION="An interpreted, interactive, object-oriented programming language"
|
||||||
HOMEPAGE="
|
HOMEPAGE="
|
||||||
@ -184,6 +184,9 @@ src_configure() {
|
|||||||
local -x OPT=
|
local -x OPT=
|
||||||
|
|
||||||
if tc-is-cross-compiler ; then
|
if tc-is-cross-compiler ; then
|
||||||
|
# Hack to workaround get_libdir not being able to handle CBUILD, bug #794181
|
||||||
|
local cbuild_libdir=$(unset PKG_CONFIG_PATH ; $(tc-getBUILD_PKG_CONFIG) --keep-system-libs --libs-only-L libffi)
|
||||||
|
|
||||||
# pass system CFLAGS & LDFLAGS as _NODIST, otherwise they'll get
|
# pass system CFLAGS & LDFLAGS as _NODIST, otherwise they'll get
|
||||||
# propagated to sysconfig for built extensions
|
# propagated to sysconfig for built extensions
|
||||||
local -x CFLAGS_NODIST=${CFLAGS_FOR_BUILD}
|
local -x CFLAGS_NODIST=${CFLAGS_FOR_BUILD}
|
||||||
@ -195,6 +198,8 @@ src_configure() {
|
|||||||
local myeconfargs_cbuild=(
|
local myeconfargs_cbuild=(
|
||||||
"${myeconfargs[@]}"
|
"${myeconfargs[@]}"
|
||||||
|
|
||||||
|
--libdir="${cbuild_libdir:2}"
|
||||||
|
|
||||||
# As minimal as possible for the mini CBUILD Python
|
# As minimal as possible for the mini CBUILD Python
|
||||||
# we build just for cross.
|
# we build just for cross.
|
||||||
--without-lto
|
--without-lto
|
||||||
@ -207,7 +212,10 @@ src_configure() {
|
|||||||
|
|
||||||
mkdir "${WORKDIR}"/${P}-${CBUILD} || die
|
mkdir "${WORKDIR}"/${P}-${CBUILD} || die
|
||||||
pushd "${WORKDIR}"/${P}-${CBUILD} &> /dev/null || die
|
pushd "${WORKDIR}"/${P}-${CBUILD} &> /dev/null || die
|
||||||
ECONF_SOURCE="${S}" econf_build "${myeconfargs_cbuild[@]}"
|
# We disable _ctypes and _crypt for CBUILD because Python's setup.py can't handle locating
|
||||||
|
# libdir correctly for cross.
|
||||||
|
PYTHON_DISABLE_MODULES="${PYTHON_DISABLE_MODULES} _ctypes _crypt" \
|
||||||
|
ECONF_SOURCE="${S}" econf_build "${myeconfargs_cbuild[@]}"
|
||||||
|
|
||||||
# Avoid as many dependencies as possible for the cross build.
|
# Avoid as many dependencies as possible for the cross build.
|
||||||
cat >> Makefile <<-EOF || die
|
cat >> Makefile <<-EOF || die
|
||||||
@ -230,7 +238,7 @@ src_configure() {
|
|||||||
# not in src_compile, because CHOST configure for Python
|
# not in src_compile, because CHOST configure for Python
|
||||||
# will check the existence of the Python it was pointed to
|
# will check the existence of the Python it was pointed to
|
||||||
# immediately.
|
# immediately.
|
||||||
emake
|
PYTHON_DISABLE_MODULES="${PYTHON_DISABLE_MODULES} _ctypes _crypt" emake
|
||||||
popd &> /dev/null || die
|
popd &> /dev/null || die
|
||||||
fi
|
fi
|
||||||
|
|
@ -10,7 +10,7 @@ inherit python-utils-r1 toolchain-funcs verify-sig
|
|||||||
MY_PV=${PV/_rc/rc}
|
MY_PV=${PV/_rc/rc}
|
||||||
MY_P="Python-${MY_PV%_p*}"
|
MY_P="Python-${MY_PV%_p*}"
|
||||||
PYVER=$(ver_cut 1-2)
|
PYVER=$(ver_cut 1-2)
|
||||||
PATCHSET="python-gentoo-patches-${MY_PV}-r1"
|
PATCHSET="python-gentoo-patches-${MY_PV}"
|
||||||
|
|
||||||
DESCRIPTION="An interpreted, interactive, object-oriented programming language"
|
DESCRIPTION="An interpreted, interactive, object-oriented programming language"
|
||||||
HOMEPAGE="
|
HOMEPAGE="
|
||||||
@ -224,6 +224,9 @@ src_configure() {
|
|||||||
local -x OPT=
|
local -x OPT=
|
||||||
|
|
||||||
if tc-is-cross-compiler ; then
|
if tc-is-cross-compiler ; then
|
||||||
|
# Hack to workaround get_libdir not being able to handle CBUILD, bug #794181
|
||||||
|
local cbuild_libdir=$(unset PKG_CONFIG_PATH ; $(tc-getBUILD_PKG_CONFIG) --keep-system-libs --libs-only-L libffi)
|
||||||
|
|
||||||
# pass system CFLAGS & LDFLAGS as _NODIST, otherwise they'll get
|
# pass system CFLAGS & LDFLAGS as _NODIST, otherwise they'll get
|
||||||
# propagated to sysconfig for built extensions
|
# propagated to sysconfig for built extensions
|
||||||
local -x CFLAGS_NODIST=${CFLAGS_FOR_BUILD}
|
local -x CFLAGS_NODIST=${CFLAGS_FOR_BUILD}
|
||||||
@ -235,6 +238,8 @@ src_configure() {
|
|||||||
local myeconfargs_cbuild=(
|
local myeconfargs_cbuild=(
|
||||||
"${myeconfargs[@]}"
|
"${myeconfargs[@]}"
|
||||||
|
|
||||||
|
--libdir="${cbuild_libdir:2}"
|
||||||
|
|
||||||
# As minimal as possible for the mini CBUILD Python
|
# As minimal as possible for the mini CBUILD Python
|
||||||
# we build just for cross.
|
# we build just for cross.
|
||||||
--without-lto
|
--without-lto
|
||||||
@ -247,7 +252,10 @@ src_configure() {
|
|||||||
|
|
||||||
mkdir "${WORKDIR}"/${P}-${CBUILD} || die
|
mkdir "${WORKDIR}"/${P}-${CBUILD} || die
|
||||||
pushd "${WORKDIR}"/${P}-${CBUILD} &> /dev/null || die
|
pushd "${WORKDIR}"/${P}-${CBUILD} &> /dev/null || die
|
||||||
ECONF_SOURCE="${S}" econf_build "${myeconfargs_cbuild[@]}"
|
# We disable _ctypes and _crypt for CBUILD because Python's setup.py can't handle locating
|
||||||
|
# libdir correctly for cross.
|
||||||
|
PYTHON_DISABLE_MODULES="${PYTHON_DISABLE_MODULES} _ctypes _crypt" \
|
||||||
|
ECONF_SOURCE="${S}" econf_build "${myeconfargs_cbuild[@]}"
|
||||||
|
|
||||||
# Avoid as many dependencies as possible for the cross build.
|
# Avoid as many dependencies as possible for the cross build.
|
||||||
cat >> Makefile <<-EOF || die
|
cat >> Makefile <<-EOF || die
|
||||||
@ -270,7 +278,7 @@ src_configure() {
|
|||||||
# not in src_compile, because CHOST configure for Python
|
# not in src_compile, because CHOST configure for Python
|
||||||
# will check the existence of the Python it was pointed to
|
# will check the existence of the Python it was pointed to
|
||||||
# immediately.
|
# immediately.
|
||||||
emake
|
PYTHON_DISABLE_MODULES="${PYTHON_DISABLE_MODULES} _ctypes _crypt" emake
|
||||||
popd &> /dev/null || die
|
popd &> /dev/null || die
|
||||||
fi
|
fi
|
||||||
|
|
Loading…
Reference in New Issue
Block a user