python3-idle-3.6.15-150300.10.78.1<>,܉gM3p9| @׌zO\j1ۚޢ9iު֞yOpuѢs_t"5}+LFx+y"6!s)Dr9gQyg&S!*>G KjV0u$]e3<3:j/#<&@U"uZ FB\K}U آt@jIE ZF牬4́TXsS?x촾_:MM>A?d % V48DHa $ d$ $ $ $ $ $$$€¨$8    (78@9Ϥ:٪BpFpGp0$Hx$IP$Xt Y Z[\$]$^ybcĒdeflu0$vw$xP$yzCpython3-idle3.6.15150300.10.78.1An Integrated Development Environment for PythonIDLE is a Tkinter based integrated development environment for Python. It features a multi-window text editor with multiple undo, Python colorizing, and many other things, as well as a Python shell window and a debugger.gM3s390zp354>SUSE Linux Enterprise 15SUSE LLC Python-2.0https://www.suse.com/Unspecifiedhttps://www.python.org/linuxs390x * 8]J((Hx[MN  lf`}OIUj$%x!~((+&(>+V  %P>%PY  wOWw616..7v67v5,[60   ^g  1LL(p( 0g 0eJe:::545 ;2t;?  --.M( `(R R LQ>wL;3<99 L1&,&;747*** ? ? ?e4e];_$lMu Y(, "!4`J/l::8VJ,=#2R:"33+"+  **(("" ",p+,((O(_dadkk  k s F s66 d  a N a\\ee f5W)Wa.e+J.e: : 878k:7:Q)Q$$$ ` &B&&B<_6U<_V r ( r""6N-k 2i8"%tg;w! u dQ#xf R8 vH-P q%E$  g-UemB  3P%wH$ y :Np0NRdCxj \03fV:+' <(%x!: fA큤A큤A큤A큤큤A큤A큤큤A큤AAA큤AA큤AA큤A큤gMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMg5@g5@gMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMg5@g5@g5@g5@g5@g5@g5@g5@g5@gMgMgMgMg5@g5@g5@g5@g5@g5@g5@g5@g5@g5@gMg5@g5@gMg5@g5@g5@g5@gMg5@gMgMgMg5@gMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMgMg5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@g5@gMgM.a2a2a2a2a2gMgMgMgMgMgMgMgMgMgMgMgMe75df0b77ff61253be457af636d5eb7c55a3ff2b6a733beea844d2b294972ebfd22eea091d1f8f7b11a320cedb5acd822469c0c7ad3629d1f50f6fde6194593dc263472e71b9b557264dd066c5f06ea76d0935d25b19b92e9ac7bc49de82f15763485c7ce263c2c8e1076c52d6044dc008a75794aefd670dd259e75b1288c343251aa57bcef1bc9567a229154ee1370395c03cc241fb814555731338d2b695aac7a0cc61079c6e2df53457e63b413e0389f2c0061eb55e80229da932c8f8dbd61abddb32c2275993c297df1b56ce5d8b34eda35f823dfc27577c2b18c26efcf8531067a78ad392f25631aba1d885f40786cf5f47854577162c9f90ff1f33164c7c98d566a13fd599d1c11a375f387fef69b6c595c4f18c5d88c188a860be0e55bfe9c9b62bf4a4b1cb8419282f78bc98f4cde453a0d6bbfce8a7b76177a1af94ae74eb8119aa88532734a84dd782830f8f5cb4dff01cfa4372b1e4afa35653134ad97f34e64abd93e1e32aff017ff8914e3204a76044f1486bc9fbefa07bfdbb26999728e6eefa83b486188a3af6900a464741307e7e4fbe4c6bb030eb765042963d5f8d5d1259e9874a263a6621ca6dd1d57608faa5f28f7d61f349583e07814a404d5bcb1109a33329f0e099fa8c07a8b02401da4e531bbc6de733a90e45aa37484901eb40eefa846308e1da3ff6f240ea98f769a2afc3cf4fdba00327ecbef9b54f0a6c4a21daea6f41263e8df267367f5b491094bea56179a9c3b4ebd65afc11c3d934f8de7d3285f616d0a9129f8113b158157501829c2e452101d067a49a59e2abf1840156e9db8f85a38822fd56ab79a139eb95ec86f1fba1bb87326bfcea17dee8413652327d3d1f7565ac6b32b392a5e424947ede2088e27600346909878665b07bcb76fb3222ea1b4947a553ad0af76fc12b31651d1707980791dca932fd307c4bdc223ae39165f413b2a530b2dbf6323e8a272865da6627535ea3c7d72d323257e4c4c095b611381fd9f336d80fa7ae9104e7b03d14a7df2d9ae9c89a3b513501ebace8e428aea68dce39d0af9f29196e08fc9ea49c99605e79e72fc5037f367472c50ae104f86df35c0d5967968e352d7ea2b944f5909326076bf88e0fb30fa0ab5d0dc3030442ed92713f34170336c4dd2623723dc34829df893f8058df4fec56eb20ff67ff84c86fd3d9697e2384c5a290ed696f6d3187aa45f8f55514d26791588de02fe685af0ab129174b32ab93efa39faf6140b6795d9d92c1f9b4cc7ed6e240be197d197e40303786a69f533f0de3d0abca9178475632689c78481769686527d02a28a371379988681a08f4de44423d0445682715d86692c1f9b4cc7ed6e240be197d197e40303786a69f533f0de3d0abca91784756321308251d5bbe0e6ac6b882e355491b2b303c76f2f3519f2a100418d71354563fe0032bc96183ce2f67633eeaf6470d2cd1c1eca36c522cfe050c10b965dc76bf1308251d5bbe0e6ac6b882e355491b2b303c76f2f3519f2a100418d71354563f4738d02a72f99ce3803797eb3a35b2a0b50243a417bf8941c1d4c9b2f8561fc5ef87dd6916a0b800a7bc67e59cf9d04a7de3271b9cf799ffb0b9576f295b00fd4738d02a72f99ce3803797eb3a35b2a0b50243a417bf8941c1d4c9b2f8561fc5dd5199270a032e2744db31c5339ec2f65bcbec1ec0d80eb874b432aea25ef850cd98f68208af3da6bd7742391323252139f6c7689b6543740d41d7d3d6b0996bdd5199270a032e2744db31c5339ec2f65bcbec1ec0d80eb874b432aea25ef850d43eec127d89bb73fbaa67e37c76b5f4bfc16b7431e3438c6d188e79223531ef007b87464bf91621de904b7a8e7c7ebc9e60379cbd9745b6ff52f8802cf7f34ceb47fa1e67218f6ea69c8604b068c8957fa6f7b383838c39005bb2baa088f21d827be8a6e0b302ee2678629e1190f053965459e72f9bdfac789ee4ac65be7c501ecefc894e6436f788fd44fe6a1068b3315779eb22aa82fcfbd2a0cd0068872e827be8a6e0b302ee2678629e1190f053965459e72f9bdfac789ee4ac65be7c5026d70f715190299d6ecf84ac1b42d01c465a959d34984792cef67870ec59d4c2046172bab49b3c4575999132886e8344217cfafa0d6d770b5ecd7e8ee3dc1c5926d70f715190299d6ecf84ac1b42d01c465a959d34984792cef67870ec59d4c2a8476783ad776cbd2c303ff847c2a7ba1194babb619775d9e55fc0a42a277168f95f5c27d063506531b2238f708e2f98d18b00a739e19502b32ee1610cbae0c6a8476783ad776cbd2c303ff847c2a7ba1194babb619775d9e55fc0a42a277168b88ba95ee77879ee775bcd1f3d267a805e15dcf67b3b01655debf5131690af03026ec9cbe37b259441e1e217da4aa18777dc48440a945af76ee7f6cd840a36edb88ba95ee77879ee775bcd1f3d267a805e15dcf67b3b01655debf5131690af03ed6a495db6ef7e44d2bab869837c708ac1246af8e5247fccbbb203e5f281a3bc5f33adeef502f24f4549d678366cbeee95c278fc2645b60e26ee0632af256f43ac5c05db752e2230948ec2e2a12ecec6c29b5fab1b8148d6b229d8a9e5827183d9eb19f55821e99722ebbc2326761c476b4340a8cb3daa814b4c4ccfed219e5ba4e8f3ea4065b9f0ff2dee9655e932476091dda3e8acf7b1006dabba0f2f95a1d9eb19f55821e99722ebbc2326761c476b4340a8cb3daa814b4c4ccfed219e5bd86fe6cd298b12d2c18a254e0ab33a36471ecc1c2d8aed0f7bab6b53cac3abc4e6883aa04b16e7e827ca9dd33cb56cc8e0fecb20ce0f649eb1158e09b137ff6bd86fe6cd298b12d2c18a254e0ab33a36471ecc1c2d8aed0f7bab6b53cac3abc486ff9a0381d002702e542a39e247e6ace4e2e0629faf9bb6db676a2aae9b4be530d166b912d569e0e0d9d4b80e6ad5547617a365f1c9f59751f49d2e43666c5e86ff9a0381d002702e542a39e247e6ace4e2e0629faf9bb6db676a2aae9b4be5e2ac6def6cb5ad3b5ff3d5b406e8c766bb805828393e6cf3d4a50b076bfdc1228160fa737178b253d8d450e90a465bbd8ad83b93b1e08b56a310309dc0274af1e2ac6def6cb5ad3b5ff3d5b406e8c766bb805828393e6cf3d4a50b076bfdc1224900a548c6d5b66134cea8b21285e0e2f81203c5b0c4894f2b744bc6f82106534297f92e88a3cf2f0abea410b90fd53bcadc4b886aac47b3504e3da271d3d6384900a548c6d5b66134cea8b21285e0e2f81203c5b0c4894f2b744bc6f821065375cf6d2a1aed1b57e86b31252a16e47aa65be473c3dd45d6a720572afbc04b41b547a86013e4a02a13d7c6cc1c84d63bd936622cfd8fc80474a62d3e3626b14375ce7fb9580fe085e70e9e3da13bf6c819a18693c966d0a97987e18864a00d5ee2ff63bf96db25b64dafa4a70fb7d150c9bcc4d61ae050e81a74a51b66b28abfe2ff63bf96db25b64dafa4a70fb7d150c9bcc4d61ae050e81a74a51b66b28abfe2ff63bf96db25b64dafa4a70fb7d150c9bcc4d61ae050e81a74a51b66b28abf1074cc1d82f926cc97b45fb83b607beb356e8fa227f1262a81375ecc9c8432241074cc1d82f926cc97b45fb83b607beb356e8fa227f1262a81375ecc9c8432241074cc1d82f926cc97b45fb83b607beb356e8fa227f1262a81375ecc9c843224b917033d14ede9d9c9181e7e3abcde1927ab3032a330d347ab690c45e17ff614d8af70e89ca65575668c1824cca2fd5ecb6af8b5a00d36aa813d1a2104b3d8b5b917033d14ede9d9c9181e7e3abcde1927ab3032a330d347ab690c45e17ff614c748a5bb0a78fbeb4352b1922489cd594b0859471f0ebeecec7ae50181c8907f7c713aa86b2e17de95a249f48f2f09275056d01a7589912cef8b7a1c80e177f7c748a5bb0a78fbeb4352b1922489cd594b0859471f0ebeecec7ae50181c8907f89f3adf486fddd754a0a53766a6a27824ab66748167c48cb96b800b0a0d7b68b03bc254a64c2330c2b4ace86b18c11f78072d99ffb5d81b13a0f41619fca61d2b6adaa71ed3417e70747a4419cc82f0798beaa51051a82dd9c65fc6e9be2e0256a5a5e2af16a04977826db862ba05973e309f31c5b7265c3817f4d7f47b84ed7bbd1908557a9b7131c2850f5e90b2b9a7ffd7f5386a1364c6bf7d1d4e7cef48033e50127cfdb4d50e9628f446da53fd68af5db7646371ddb129d5d651bd46938e4e4168831efe2f9b0a355db4df7cfae7618f3b7e9a6bc76e01566b86a69d95b71e3a9896be9f5f0a6352a8b1f448a15675d51058a96cbba3738086d3a89b606e4e4168831efe2f9b0a355db4df7cfae7618f3b7e9a6bc76e01566b86a69d95bfdbfe138becb5589f14b1eaa532dea535374df5fe4269efd1635ee72bddef02f0f587244d524a7efab0fb70a01c6a3f3b34de9a95e3be3aa9aaf30d09aa79a0efdbfe138becb5589f14b1eaa532dea535374df5fe4269efd1635ee72bddef02fee65c8352da79e3cc7739f99bee841592fea9097c56326cc05fde559e0638cd8baff215bb614a9175d8de3eb7eb16d31284d8d2645d00db65d3955b84ae56e6dee65c8352da79e3cc7739f99bee841592fea9097c56326cc05fde559e0638cd8865890aab15c67c24542a733f75ede833231ea5e6250bd15680bd796b70ffc207c1fc68587a0be2d428811a4fe8801a0f7fd766e8feaecb85eb4f041e7347bfe865890aab15c67c24542a733f75ede833231ea5e6250bd15680bd796b70ffc20221f4ba3936c46bae6bd1678dd1bf2ad53f8c6c94a323fdff6107be097726708b3b8be9d0028434c9faf834c23e580c9125474bcdb7dc7dda8411f456d137c9c221f4ba3936c46bae6bd1678dd1bf2ad53f8c6c94a323fdff6107be097726708cb3e7cf96b2e11d5e1b302adf10aa6a097df895a24b87321779823f4e49d9492cb3e7cf96b2e11d5e1b302adf10aa6a097df895a24b87321779823f4e49d9492cb3e7cf96b2e11d5e1b302adf10aa6a097df895a24b87321779823f4e49d9492b665f86d9cbb4dded8a1eee57a4cdafb62f602bae516ef559fc42457e05fd29d23df78b919ed7bebad18f293589a983eae750dc305525a26c42f6c34221b04a8b665f86d9cbb4dded8a1eee57a4cdafb62f602bae516ef559fc42457e05fd29d78c1b8142e364df3d69cf36efbf484cbd7b3e2ba3902f9f8b256f3fd78b369cf2e2bed2629e199bdc1e9ff9a055c36f882f54c5bb49147701de2b059e5fdfd1678c1b8142e364df3d69cf36efbf484cbd7b3e2ba3902f9f8b256f3fd78b369cf65e2d0b19baadd2909c84dbbd619fc57fa559539e0a868b8f9a0e3f8c7e5206ec75113195310bb61e69606bb058cd3c5e478e59859c40c8873c8a4d724586a3e65e2d0b19baadd2909c84dbbd619fc57fa559539e0a868b8f9a0e3f8c7e5206ef2ad597e2a65a51b1a7d7c04efec36b637c3ece48f843c3fb55399aea5b1cf73573e72c0e14a171f42a5452b426c88a0983ec195a85902eb44028e13497ab0678602b19887aa82d4848793895b3a72532c31b89159e960f0b6a0eb6b976292e9c6c058766ed7920e5eed443a3a195b1ae4639f9917d506bc0edb1c80f331df7cabcac12be29a63e007091dffa5063db2711154d9b193d22e7fe1544a5d8d7f18c6c058766ed7920e5eed443a3a195b1ae4639f9917d506bc0edb1c80f331df7c5f58b9e4512daf230f01bc920301bc93d399a9aa4ed3ace1a00808bdcfa9e2998291888a9a8c014735a4a8cbc5dd8c8222ba818c1aaf3f94de287016ee68ca5b5f58b9e4512daf230f01bc920301bc93d399a9aa4ed3ace1a00808bdcfa9e299c1211b9086b71a343888e14d4903a41fe8e8eb627ccbf3b2c989c02d9cbdccc9d4d65e9e91a77001d1ae78a35c0040b6e0f72b1864b3ba730aa4e32cbabdbcb9c1211b9086b71a343888e14d4903a41fe8e8eb627ccbf3b2c989c02d9cbdccc998a411b8f1e292e8d8148b21a4d06e00972500c552d94cf437376b271cae81ba47a5bbcc4543b1666bca266a87cfa827a6b8378b50533de9e6e560b72e129a3498a411b8f1e292e8d8148b21a4d06e00972500c552d94cf437376b271cae81baecda7c3d2e2bd55f85dd2cd73f7627441e3b02095e153588686a686d15caa506ecda7c3d2e2bd55f85dd2cd73f7627441e3b02095e153588686a686d15caa506e80e1adc2906768be7bf14e6e52fff3c6a2ca115878c12952f85fa8fcf9737fa8c8ca773ab9add53869f4851f26caa0d4e2f7112117f866444ea04d92752c4687d33c9dadcc487a56b708886c82b921c170061f9e0d52164cef00041b991eebb6875c5798bfa43a9dfec49acfd1450c490283d696f32757e0d3a69b9acb1fc36b8aaf244c8649c61d72a82334ca62604e7af69c0464f95f2fa157d2a26c7b2145215d12f2982dfe9031b18efd34f0ff9012a8d6b820c8cafe39467f5cb63595a677b3e006423d80aea149b63efd32236e3d3ed2929596c84ccd4ed6c6abc8e1b460f799863ea80f7e55a04c55cfdf54d3ad9c476aa3688a831915555c2d9470ea8c2bdf02d6c74ad8f37d3f6d41400ec7c05865a8c833ab1ed57282e318780f5460f799863ea80f7e55a04c55cfdf54d3ad9c476aa3688a831915555c2d9470e5132bdb1eb1e9bfbfdcf6d5669dfc530b9e1204a817833c3a8d9e95c5934e6ec2e0a0b11b45cc57658bdf2bf0d4488b9f5d4a2ea661d948020b5e57bebfd712e5132bdb1eb1e9bfbfdcf6d5669dfc530b9e1204a817833c3a8d9e95c5934e6ec5bc149c2886d5445e71f2c9dd8a42719eeb9f224d0f728c4d05d771853893f32a729454fea7aa036e0428c1bd881ebd33878ca78aeba5ccbc0139c29025906f85bc149c2886d5445e71f2c9dd8a42719eeb9f224d0f728c4d05d771853893f329b5a56dcb45d63a5823ba5cf08d6a9f87a5d7ffcc7f851183875bc1e6142523ab18674817b7b42933155369026ecbce654d0f2845191572b84b9983cb1d00cad5188c33031c2aaf70be0e6fc0be286b195907341c6b9a0ee0dcb25370c3c69a03c5c6b93db0fa71a08e0c62d9080225f19150200878c6be8bc5eec962920906086e7c98994ae7041f2602ec64d86c6bae52bd1aab96eac02d822d2fcb1e456c13c5c6b93db0fa71a08e0c62d9080225f19150200878c6be8bc5eec96292090601aad64ba59162b3552686cabfc54e40cf94d79c80ee69abfe182e7bfd0fd986f6bb0c770e5539fe574131ebbd937048fea3f2095c517ca4e42093f5218ebea63cbea5348b695237e4c9bf99f00a927e959e7152b7d34ae08204c7b5bb4f0f9c6d302cd9fee0cba1dfda53de6b963728fb07f9e41174b80c1f00c3dd93ed2f116c1952a87c78d43f4384b4703894ae22ca61d1fa596ba4c39a8f72b7ff264ec26d302cd9fee0cba1dfda53de6b963728fb07f9e41174b80c1f00c3dd93ed2f116e0625176382d0ac353fdd9b211f03a36f99f33d662fad4166861080e73f23465e0625176382d0ac353fdd9b211f03a36f99f33d662fad4166861080e73f23465e0625176382d0ac353fdd9b211f03a36f99f33d662fad4166861080e73f23465e739031d86cdc0a04ea63579cfe49f40fa69778195f615c968525c0bbaf9b10c8012ab4f492d75ba9607b0030e33e3b434ee09f89aaed37904388024cb1adc72e739031d86cdc0a04ea63579cfe49f40fa69778195f615c968525c0bbaf9b10c78667aa93d2968e4eab94fce4fe4a3c0ed35aec070543b9d29e54b5c1ed43cefb8e146b9f6a6cacb9534ee7041bcca061bf5c99236feaa6383d93c7e2574983c78667aa93d2968e4eab94fce4fe4a3c0ed35aec070543b9d29e54b5c1ed43cef6355cd7c70680ecdf04b5caca6bdd15fb326dafc25ccc933df8b9b6fad5aca1f4b93fec6b35eeda280af846c7860501f189d1bf3597e31bd53c570d8d1cee8386355cd7c70680ecdf04b5caca6bdd15fb326dafc25ccc933df8b9b6fad5aca1f3884d3684b21b88335e591eb6a7fedbe9c9fba14b6c277633045ea68b2589d8308d0790a5bfc724635e49332fcfe1b45d1c74f6c74372c61e0052eaeb47967a91dc91c07cb11bcde41cfcdf54e26b8ee324bd8d095b491ca36b55599abd231e1deca1657339ef428ee2071934432b63dd5077aca025b5c3dd9992b4201b18c37deca1657339ef428ee2071934432b63dd5077aca025b5c3dd9992b4201b18c37deca1657339ef428ee2071934432b63dd5077aca025b5c3dd9992b4201b18c37fee8f8f73183e131c6045761aaa0847d2e9936a8a9f85f83d44fe007e0773507fee8f8f73183e131c6045761aaa0847d2e9936a8a9f85f83d44fe007e0773507fee8f8f73183e131c6045761aaa0847d2e9936a8a9f85f83d44fe007e0773507bc5cad802bb8e1f8acf92f7a40eac70805e6c8ecde014d5bbf9475e51835e18266bc6d35ee75a9adf82c90201e7b0b25051e148cf8930bf3ac79cf8b13fb439dbc5cad802bb8e1f8acf92f7a40eac70805e6c8ecde014d5bbf9475e51835e1829494882b07888d343dd401bec4348c7afca8968055cb317d9245b620e4a0a75194fe12e667a9dc8fa1f5e62075d1c56d077e454b58a5d6fe9a62930a8cf1ff149494882b07888d343dd401bec4348c7afca8968055cb317d9245b620e4a0a75143cacb3c23673755e3a8f4fbb9cea78eac53a6a66a61281741a302446bf7e26d2462f816c9cb09c5ba157675f8e3d4d8968628a0bd4d1a966a78e73cee52ba8c43cacb3c23673755e3a8f4fbb9cea78eac53a6a66a61281741a302446bf7e26d2775a7bd7ca3d8c89041ec4212f3844cd6490b34c615ac81a5af8ef40f63f3cc2775a7bd7ca3d8c89041ec4212f3844cd6490b34c615ac81a5af8ef40f63f3cc2775a7bd7ca3d8c89041ec4212f3844cd6490b34c615ac81a5af8ef40f63f3cc0e9565f4a3c9387d31f4c4472b3ec5e4f6cab77f49fcddd10ce66aef0303b51f0e9565f4a3c9387d31f4c4472b3ec5e4f6cab77f49fcddd10ce66aef0303b51f0e9565f4a3c9387d31f4c4472b3ec5e4f6cab77f49fcddd10ce66aef0303b51fac83e33afcaaeb11c215d373b3a33e27026eb3b8c99b7439e5e9cb1eb96a530c40597ce5a15f4f61ee3bf20070f6899577331ef63b9096ef41a660fbfb20975dac83e33afcaaeb11c215d373b3a33e27026eb3b8c99b7439e5e9cb1eb96a530c49a63b81a78986fde5893607014b8762d744600b4179c5b341e4680b2cbdb9711300a4a940ad1ec70f6f06e944f797c8f59450486b838eb6356cea27deab9e6d49a63b81a78986fde5893607014b8762d744600b4179c5b341e4680b2cbdb971e614f387dbdeb17760d9bb4cd50ae3091545f1285b9be0f5ad4b9a8c9eb930e96cabe6c0114a39fc378d91238279ed629b1a1ba65a3a9d792b4dc75b318c39137ffddac56236387d1143a42f07be881b625621be976faf3034b6f932fd79fe53c8eb28ef7addf5a664a7e3addfbfebe29040a8695e1db515828305aacba2ee4e28e8243b6a3f3fe92243ad474f808c12dffe608019627d48bc2e4d7b39185b455d580f5399568b375efe24fb7db6218d9264822dec25adec25c6d9640b854b65020cef86b5c31e96a3439d09252183f3eef21d4a103a4a909538bac3d0f1d4e4de42667bb690368459585dca6bffecaef498217ff74b9266cac74bb8af98e26730caf7524234fb85e08f01beb716e1a34aa233051fc0c3798a6b085aeac5b4663a7a35f40aa5d22c7fa74a889838f5c69631eaad0a9f4b70e6a439999d419630813aa76a1d93176dc33843b9e5bd4e6165886162d91b19e080e9c5adb30c05da1fb2a050c4e7c354b1434063e2a661edfe08852aa8a23a6f1621509832384856e9e38f992c807348eec7ddf175025ec6c149c20a7c2f597c99352caaa03e45577142ec668ee870cc3b09b7ced4a0592a9a2da5f7ccf8a314b1ed906fd7a30248db8add0abc885fc629c6746aca77cd40026b2dac8d7edb93f1fcf6ea9d28334f4e583b43fdf9bd4a731d70e074ee597aba03f3c8c36302bdc7e74650fb1fcc115c2cee869bed6e5169e410c4cebafab702449b8743c6614c0c90c85130b1ec7d1595e2034eaa93c2ca61854038e64197541906b3402c448b176e34a5af9b6b09b51f28a5d49a8a6775fad9bb944b47d65da733908b432b6cd0038ba99e7e3975ffecdbd3f9ba0d71c6e59984f8384817f0fe5b0ac69ba62e1e40a31faf596a6c26f690842feab34887e9863ee013180f93949b36cf3ac9643940968ddc1acb443ea7600c9cf97163c89799bff4dce3996f68fa6efccd4f66eb3867b754762f8cceb2fe1e3de8fad3c95d83407a829abcc028b8b02f85e4661c9c934129af1ea98ee037eff39bb5253b3bc2048ba149f43deec680fdb1f7dde421d9514ea3b32ba37b21cc6acb2a24ace550fc1a55852ed068fb2ecd13011ffa3ba5291b7346d0d8e97a030281647351ebbe56d9b72a581af69a9feeca7a8f5d09a9d3179963c0bd81f83b170583a900f3779f0cf8662ccd25479ffd2f063a6c4fde668a198ee015a3977f0d2c6a8e87db2ef7050ea10afb3a88b064bf5ef95439924e4246411433ffa2f718e123fd1c4e536bb4a471978515787ee9fbf7806a92073a787a733a26101d297127132c5e9634499f41ad00e125ea308343a20b278bee9e9225eb5cbfe6188362a0bc7db8b94c3dd313b97c83ad6d10b79451fd2a8a4bd773cd392b228f8efbf4c316bd701b09a72b084a08248e26a346c6a7636a142391a8b3e6742d87c2b1fd8c4d83f664b23fa46b15de926d3af0f45a2112775cfaf91b23dda2278a446e56c1704449a49a690b85d2d47db5e6f8cd7cfa0efc6181ee43332d122d87c2b1fd8c4d83f664b23fa46b15de926d3af0f45a2112775cfaf91b23dda22aea9b88ba6f1c7bfb168725f00018662f9a16977c938efd088bc46b490bcd8bf255dcc3af2f0a3c48ec3cbde80cf3d5826d869a02848e8282857a3739522fdb2aea9b88ba6f1c7bfb168725f00018662f9a16977c938efd088bc46b490bcd8b846cc037e0160c11384919235262b939c64d51d3c010a5af282e089bfe69fcc9d6bb9da3b19e2c161c09a847c2b4e953c31cb48f28472e5f1ac201707aba953f846cc037e0160c11384919235262b939c64d51d3c010a5af282e089bfe69fcc99ec0aa6dc88c611dedbb4d3b680b61b849b1fe1cbc24ccaaadd068d51653d0c19fcad080713c99214967373b01d26e14b87a8523f89c1dc7f09a09245bc163e29ec0aa6dc88c611dedbb4d3b680b61b849b1fe1cbc24ccaaadd068d51653d0c1e0dcdb89dc30cc4edd6e09505ae4ec64ffb16dcb7834d45860d6db479ce2cc9017877fc108bc395b799a0acb2a1f9c79317f1db9152711a13b012c85d3a4ca71e0dcdb89dc30cc4edd6e09505ae4ec64ffb16dcb7834d45860d6db479ce2cc90114a654895441d85b625245ce67f13a2bfd195f5c238242c78c1f97bab4606b47aae230504f9b387572f441d4a68cd9533b911d396f56fe3043e14fc54a18dae114a654895441d85b625245ce67f13a2bfd195f5c238242c78c1f97bab4606b4a0a93931633dccb4d741f78cfed87336700a7e4f553c0f21b2f20f2ee0de53831687668fce86d936bfedd21e9c1be696e066cf18a409f778f2b0fcbdfa9b0221a0a93931633dccb4d741f78cfed87336700a7e4f553c0f21b2f20f2ee0de5383205a7de8ba5a2c473f9bf902c9ce0747597f9b4d584c3a2a4eac6080eda34f6fad50f626f6e07bc939ed6a071dd7e9108589803f1a6e4b1ab0fff0bbf715af6e205a7de8ba5a2c473f9bf902c9ce0747597f9b4d584c3a2a4eac6080eda34f6f93f6ae22afef661f06aa172b3e6d90ebb52bc9d7198300dba691cdb759be77d6fb2d3f606f1e87e27381e7ac6540a4212bf917878d3f1fffa238cd17b71de1b593f6ae22afef661f06aa172b3e6d90ebb52bc9d7198300dba691cdb759be77d6a17f4156b16cc23c024441df3133afa760bf01320d721754129c135f05e95ca2c326eaec26edfa7adc45f2c1d455f3634261df1f600666b9872a17abc7d736b2f00058bf65ce2f6b014b908c2df9403520428fffbc72f7d85f378dac181c6c8cf1ad8c5784cbb01492c194dc09f70fe0a02533d1b5b1630a4a575c442c2cafb60aee4a79cd85b097bb0af110507f6fbe7f2f393c05b9432bd8ea39e7d8da5ec7f1ad8c5784cbb01492c194dc09f70fe0a02533d1b5b1630a4a575c442c2cafb63e82220649596f8d5b2c34eb57286d57f280f24dd63c43993d361ac4e4ba7da0467c9b3e9ea5c8e5cbfdaef9805fb371f8b9bf6f3d24a0a023c61144b6b7cf7d3e82220649596f8d5b2c34eb57286d57f280f24dd63c43993d361ac4e4ba7da07ca6632f62888a55ffce54e33ae14abfbe4f27200818db2e28a007caf4486c7c228314f6319b6d0d55cb859281f2ce1b735073bb247db7bcbfd579a9d3bb512f7ca6632f62888a55ffce54e33ae14abfbe4f27200818db2e28a007caf4486c7c67c6b60f7c9dcbe322093ff407d781730df678eb0107bc73289ecd048552623823d23fbe1570b44819642f7308e14567879bd740397ddcd7776062ebb3cc91c067c6b60f7c9dcbe322093ff407d781730df678eb0107bc73289ecd04855262383de6a0b4ed6d1d9850e70e409208ed6db8cab1e75af44f9c5c9eefe08eef6325ada46788def28f4658f3a642d62822ba45cab999362c84ac0ff1f7a13de3c5bf3de6a0b4ed6d1d9850e70e409208ed6db8cab1e75af44f9c5c9eefe08eef63256601f0f9a93d0b1092a79a0f2b90179f662c489f2f7f34ea697efdd0b1cf85c83deb3c192bf7e4e968f0e46ea832688298b33d4c2315b2e9fdebbc98874415456601f0f9a93d0b1092a79a0f2b90179f662c489f2f7f34ea697efdd0b1cf85c8ef3ad8a77ac310ed55d1d19b0a6c8ca7ba969f45c169feca8ccfc05385fdb4f87bc78ae235f96147789f9339f17898c5e93a40d85848c24eeaedbfa8069735b8ef3ad8a77ac310ed55d1d19b0a6c8ca7ba969f45c169feca8ccfc05385fdb4f82f0ae5e210b1c65c91b5b93d03b5e728a7f663ee22bf019b33f4f50cff37a065e91c2fd3977b7885ec44dfca8a221bc4927ab232d02d564ed01045f1512376d72f0ae5e210b1c65c91b5b93d03b5e728a7f663ee22bf019b33f4f50cff37a0653dfd2769ac89275e2f7606e57dfc1cacaf3a7084288fd848e1461c60e12cb2ee91117de46bec674fb14b66f20bb263c54cb695f7d978b9c3c860c89c5f801e903dfd2769ac89275e2f7606e57dfc1cacaf3a7084288fd848e1461c60e12cb2ee595dc6aab325c85c5a0f3546d54cb8ee2d4a481b3a4f0f2295686235e0325cf67152edce6039ff2d635bf91230f9efe6bd8e16f6b06e3f7f0adc044a5c97e8d4595dc6aab325c85c5a0f3546d54cb8ee2d4a481b3a4f0f2295686235e0325cf62f4dd40e0889a193cce7acfb52d55068a3b40a3ecb6c350e9ab2b5988f75760f335fa4f027eb7b45790d3ea7d82aba42b0cc41f5708d50cf1924447675497c902f4dd40e0889a193cce7acfb52d55068a3b40a3ecb6c350e9ab2b5988f75760f4fc546bb4ad8a4b7be3ce4e31cd0c1a6244cd1a772d688c5b8ba0f309642f2568b856a86a23a0ca85f9de101b84afa54782bf23d8c77b96b8fefe608ab1975294fc546bb4ad8a4b7be3ce4e31cd0c1a6244cd1a772d688c5b8ba0f309642f2562d539e9b98f300d5f5a577f8387ab53147f3b7a8091e8f29e9b2b1fcd12562788b9da2a545b9a1ce5cc7a537ae33b1f41d1003cf7c733aa137fa901ea9291f412d539e9b98f300d5f5a577f8387ab53147f3b7a8091e8f29e9b2b1fcd1256278205cca7895fde2797567b4cbf4de20abb4efe0481e1dc4f2a40164b85ef4884e1b97a35c370487a37370c5d4fb9fd823079045614025303ddd2d9d792e33cf1c205cca7895fde2797567b4cbf4de20abb4efe0481e1dc4f2a40164b85ef4884e8faf30e0c76cdf48c5e222a6cb1206fb885467b15435138ec2788bf8eb357545fd5c4395b40d78edd786e8920686dd118dfc3fcea6501fb300cf1220ea9313f98faf30e0c76cdf48c5e222a6cb1206fb885467b15435138ec2788bf8eb357545c21cf82ba32d8939ef287daa3ac49660a3892e5defef8dfc9e2172df696dccd4cbb5a1f1150bc77255cff58902d7babc9e107f2573f3a4ab0d866bb3b6b36099c21cf82ba32d8939ef287daa3ac49660a3892e5defef8dfc9e2172df696dccd43f0f7594c9f34c4aa5c1b2ef96c9bc9cc05328dcbd7cb8bd4db4530a32427ac9a374ac490b08d1374b652be2783378b726120119ea3ca099d9c9c58e6acde2b53f0f7594c9f34c4aa5c1b2ef96c9bc9cc05328dcbd7cb8bd4db4530a32427ac964ff8b3144e791bb990ed2ae1fccc67b1e1faff0c1ee7ea89819dc44534cac1458665fa6b83d9d0956727e7d4fed82ed88c747d343c00df8351c20e9e7079c1d64ff8b3144e791bb990ed2ae1fccc67b1e1faff0c1ee7ea89819dc44534cac146374fff8c4e8227d8e60c8ea2e07dde1df2959550160f0e6a2cd9ee2bfaa5ec9bf3d2380927e99a66055c5ca282965c19ae214b73849b51efd878a5a0781bd676374fff8c4e8227d8e60c8ea2e07dde1df2959550160f0e6a2cd9ee2bfaa5ec9257b883b8d94ab6d06502d52caf6729b60e44b9cedc1db5bd2eb054f9e1f0ee41e4175ff9e0c675da008b04b956a0d58cac0f7623e979d125cdb6bf635c674cc257b883b8d94ab6d06502d52caf6729b60e44b9cedc1db5bd2eb054f9e1f0ee432d3035c0366b33c23fea725054e13dc10396fea8a64bcd98adc144ac80241aba53f3f26f4f73c0005979e75a4f5f7e1a7aabaabd58f05842e5edfdf8f8b1e3792ce0479bdd3d160f24d3bd33bcabf38ef3d18c4ea3c435f9b615b1f270f79e654cd2c39a2231f2b2da976918a1f26c5686406a1d98cbcd24960ba6b2e5177505eefb5a05edac1160a93e582e39e24203b22478767b7f132f380197340ef999754cd2c39a2231f2b2da976918a1f26c5686406a1d98cbcd24960ba6b2e51775053116d56c23e7a615f1e32e460413632bf7678814690b1d87d608aedc8a0f84109dd4b59988a797267b2807f055a91bf72bb36f76eb43a2f621fb0f1d63ef70453116d56c23e7a615f1e32e460413632bf7678814690b1d87d608aedc8a0f8410c060afc44b4b32615ccf48c91e3ed5e228b954a3f1e50f8fc896d513c53c98c08e53f448a36dcb84e1bb04fd61e725f780c74bf0d8c22aa53336aeb71011e0b0c060afc44b4b32615ccf48c91e3ed5e228b954a3f1e50f8fc896d513c53c98c6a580fcb8f731bd345912649c8f24ecfdd79b9b238873ec331e1d4724ffd5b095fdc5df365905c6d85a1357ce93a3f9f892f0c0cf6ca07ee758dd8e559b110946a580fcb8f731bd345912649c8f24ecfdd79b9b238873ec331e1d4724ffd5b095bdf5953adbec1cae31eb61ab481812d7917c33036498a31e1dc6d19bc8e7a0db817948117cf491319f619f34ff8be030347572c8d7c42494ee790d854dfc1b45bdf5953adbec1cae31eb61ab481812d7917c33036498a31e1dc6d19bc8e7a0ddc0a867f7b708c502edb96fb4bc8feb71353262c5dba725b65131f0ed7a598df666638b381a5aa3325cb1f8c8df33e5fb428360b77e662683a5454be721250b3dc0a867f7b708c502edb96fb4bc8feb71353262c5dba725b65131f0ed7a598df0bda3e7065a8c94e0c36a68fa05db281df07d57b6f9e5742cd9fc3b4112eb166dcced6d126cfd325630f9fec9189cdf18fcd45d9e431f62e7246bca078cda3350bda3e7065a8c94e0c36a68fa05db281df07d57b6f9e5742cd9fc3b4112eb1661ebb2ab61f6609064989c7f605dd1325999e021b8957b7afdccf76aee6de7add788ae1b8eb1682539a3b9726aa506960c96a32d68f320d31c0d1749284b094e61ebb2ab61f6609064989c7f605dd1325999e021b8957b7afdccf76aee6de7add5780c92087f1933a12e145d3adaf5e960376bd429f30de110552c5e836594647dde2312e1818710889ce6c0fb62f5b3e3357ab03192ce71605b3bfec59c218295780c92087f1933a12e145d3adaf5e960376bd429f30de110552c5e836594647d730946ac22440de6ceaee9be3bdb38764573f5d340ef5e1dd490098920d3cd2de5e5108a02ed78921b9362d166e3df5ff8f353f84b98ba7a2e546e7c1ae4a81d730946ac22440de6ceaee9be3bdb38764573f5d340ef5e1dd490098920d3cd2275d1f61568e27305f7626146742211728d533d9ce7e9205df887dd06b0a5b5b7c9630eb407fb31901f3a9953c3a95da7d5c4828de450da00a837ce1a2a92192275d1f61568e27305f7626146742211728d533d9ce7e9205df887dd06b0a5b5bbd6b34b12fd0471c45d75b317688111a6d90331c9ade73c2a2a6546cc610b7cbd0ae1652a185f814d13002e67e61b5160f73faed98705fe55062aebd5dceab8fbd6b34b12fd0471c45d75b317688111a6d90331c9ade73c2a2a6546cc610b7cbfe0ef8a9a0ba42cd398cc0bb712c19ae67ad5ce9750406ac04136a1c759c88f590aa77d1cf22750e4a9e1a35e4f860f42b8f0b119e16d45aa7c46a1ef46caac1fe0ef8a9a0ba42cd398cc0bb712c19ae67ad5ce9750406ac04136a1c759c88f5972275d2ecff5a34eb30705d8f540dc5f50867a105e8526af2035a6a4dce1016c20e7f691990b321ba9c7552c29e77049b91d1676ff3b806972c2628261c44fc972275d2ecff5a34eb30705d8f540dc5f50867a105e8526af2035a6a4dce1016909a76be62014c67294eb09775df7194bdb122f5a04d55d9aa9d916472a9f762dbf73c813c33c25d8810b4b55d3e6ed7e5aaded8f95a77679e4727af4ae32495909a76be62014c67294eb09775df7194bdb122f5a04d55d9aa9d916472a9f762bc000c383a3ae3f1b2622a430e0bd3611db879c829f1b5f911a1ba38c797d48d2208468269d584dbb8c79db23cc1189de0b0fad8d394e6ad8833b8e50d843508bc000c383a3ae3f1b2622a430e0bd3611db879c829f1b5f911a1ba38c797d48dccb6f9ed4db763bd7fe562f4f3db3b8142852d60c91411556e47989fbbd337b7991671ff54a0f81978e11416a5758ace8203a9f9330dffc8e32262722249de34ccb6f9ed4db763bd7fe562f4f3db3b8142852d60c91411556e47989fbbd337b712e63045867398e6dd047ca80b5dc17d0fbffbfe088c046de0f40561ea1b0251654cea902f5043a3c8dd4803b384cfbe8783983e7bbc1ecb1f9d2662a76ee3cb12e63045867398e6dd047ca80b5dc17d0fbffbfe088c046de0f40561ea1b025110d4ecdf58fef7eafb0335d520aba8ac410b7dac32841c9f4d21e746ed446be6108dec90e09b306e98559f7e0c727012f3d4f7a849f03ff18025f239518dd0fc10d4ecdf58fef7eafb0335d520aba8ac410b7dac32841c9f4d21e746ed446be6520e51e9bc5eb01e81b8f7befad22a1094a2f11c33f9a46f936873ee7004eb2d050a1fd0d77bd79ffff12e87a843799029d701372c7c7cd5206a999c86cb8024520e51e9bc5eb01e81b8f7befad22a1094a2f11c33f9a46f936873ee7004eb2dc005c704ef36ad2527ffd420c9bb1a2ace2b8c616ee324c4a99ec8b193ab6281cc282376ec4d03a0b61dee7843f2d447b7d531c02cc01e067f84796d83b7c3b9c005c704ef36ad2527ffd420c9bb1a2ace2b8c616ee324c4a99ec8b193ab6281256b1044f1e1efe6a49ada50b5cec6bd0b46fa91a39e3b0ca2558f4eac720e94e2dbc91be44fae56579d5aa45f0717dcfaa1ab86c2078ca495c56085af4da726256b1044f1e1efe6a49ada50b5cec6bd0b46fa91a39e3b0ca2558f4eac720e94320e95a9154bb23d73b2e875794179f8ca5fcdab350b472741b2fa3035a6b32093b27288abf422d46e77a21d4ec3cd3c9d17aca0c82fae53cf00a52c49aeff40320e95a9154bb23d73b2e875794179f8ca5fcdab350b472741b2fa3035a6b32007a8c21c680721f8c4f34537f1e6c7faf05788392c438a1e2707b1f1d0749eb587ded2c02c2b6f5a8a07960b9d46f9b6a6ebb875e98d438623aee684165e323207a8c21c680721f8c4f34537f1e6c7faf05788392c438a1e2707b1f1d0749eb5a13b745c2b41a80ad423303bb84a2ae2af9e19169969d897c4f55a04ccd2b7d96086bcbd30e42ff7dd18e7162319a1abe7927d8b44c672b49fd108768d48414ca13b745c2b41a80ad423303bb84a2ae2af9e19169969d897c4f55a04ccd2b7d9ef0edc1bfd4338b7a15308bf93ebdfbd01f2f9f14a60253eefcc4f215f5513ebef0edc1bfd4338b7a15308bf93ebdfbd01f2f9f14a60253eefcc4f215f5513ebef0edc1bfd4338b7a15308bf93ebdfbd01f2f9f14a60253eefcc4f215f5513eb142836aafc06a6c86601794217ba830fe9c257f2fed211e047257b60b0535ca0dac7e100016b4aa0b9300ca61d750020ae4393a40f1584339ae50f2339c2e065142836aafc06a6c86601794217ba830fe9c257f2fed211e047257b60b0535ca036e8fceb6c875a333b9e7cf18f3c58ce18b7b9d4b5ca514fc835aab6e5e1571ae0a0183c1a51cba60e6018eca69c62a4b546cdb7fa4a50b1562d7d881378942536e8fceb6c875a333b9e7cf18f3c58ce18b7b9d4b5ca514fc835aab6e5e1571afe14e1af6004dd705b5c03f38c1ceca1fa2f223913d0ad4981e8b010c19e7686bc79b8b9f4db59dd5ba5a8e4b77224cc60a1c6142cca37db75c228e3d9e142d3fe14e1af6004dd705b5c03f38c1ceca1fa2f223913d0ad4981e8b010c19e76866da31204ff6a0ae5643686b7739d122ceb03d0e525055e3c59f12dd0f3006133de98942e634e5fa87491bc5e2aaf12a54535d69844c9c47039503da89fd06e246da31204ff6a0ae5643686b7739d122ceb03d0e525055e3c59f12dd0f300613385f6ddf1cb8421cacfd0af4c6a44f89e87ac5057cc641cf8fb89d94caa8ce837d495c566e9ffee11f3996a6dda9f13de1965296331501c17a2c7559a35a004e285f6ddf1cb8421cacfd0af4c6a44f89e87ac5057cc641cf8fb89d94caa8ce8376c9626928213003b3819ede11ab16488de0b6aeab7a87bb29ac5dd04d98832da87af5f553fe109977f01e43fe741bc350a15f3cad3fb5f2e09220744193d391f1e17e29c173171fcd763b2139b6629df2c0ce6792b057db2012edd3e0a49ea7743421286ad234a4240f8d4bc09f67bb58da0bf9d9b07bf93010989ef2c17f2f8cdae01f8da8411c2190dc4efae37e0496503a57445ea8b3d43a9e5fc50d74f7030ab335b5312af5ca57b26945c7297bec89f31e90d70e7c8cb0a2283599ab40f5d2d4ff90ab4bc9ef0903585d2fe7f4272263535af1dac98dd4a7a31b5f1759b78d40b3fbfcc67c431ad234b516d1825b17498a5dfc77ef1957d0fee36d311aa6df5742e1340743cc9932f3876bafe243e3053cd3a5f060935201708181666667462c048c689f82c3ae6b5782a18776762f88055b80ae77a92243b6c0606e004f00aea254728b67ce3b77880b3bff50b4fa66ba25ed71122d3453fa9319370783f4b14a1bc6adb09319e651fbd51cefbba97a2633e548c3c3a13c1a311377970e4e793bae777b06206a3e368053a2c94218cec72b03ff462aa22b09051c2dce20607730edb3911e3c72b8bcb0f11f27cd131cd54caa619c9afbb9f62a7f77c6dd3aa8c8a3bebaa05f55a03bbd904bda7adfdbc7b82443abd2b007e96c4fd35231881dcf94b0a44fe355f2acabfe25d8d67871402bbc19aaab37c6ff955575f1def57a0f52368c104b2a3b3551b3979751168b1ac42b7eafa1c8d5319bc95dc30e35a9f45b223d5c7e7f3bbfd8bc6495b1156c40b0ce3747ade0aed7b41aa23ac22d74368ba175175b9c14315f9d82fd7ddde60ae93d2e5572e9a647de7e869eb559d39df8c1ff38d177943f245b87f5379ee5ea93399fd6b5f7bfa882e6ed8caed3800137d48ffcf86ecb71afe5a24cd9ed381571f23036438ba8a97f502326a001464d2ef94de500cb053cd345164d696f7f84cf38fa522c77327ab04d32982d4cea5fdba68fb9e361541820d44eed003c317f4ef14bb9df3406b8d2c53ef7c73097d2c8187a17ae6a83ab6e2cf935a1309ada7dac041598e77bc618b0fa3e1e39288f4326136cadb4fab81fe31223187136bc3d9bdf65a9d67fd152e50a6e91d152088e94e1faa3df4b900cf2904458bbcc72045dd3d830c317fe2c9d9c1c66319fe7810ed91786b503de80701a291a4f9abe54c9e101c19c0917b709e62f3b8c48f3280ddc7156fd22f58360c617e25c8d145931a9aee74a2fa7c209779c2a2435bb75863215a3ecfdb268f52508ab001d6c52431ccb51595109ba013a4322ae5fde71364b4d201b1b691bfe21a91fe6c0257d6c1ca334b0f7898e8c69238c6a3d836f26771782f53685da5987a1bf57f41159e8a38352131656d07ae3dad883aff74861ca976307358c0ea3487fc783717abd5516059b9c5f88114141e684f24b52dbc02c8e59a971b1666cd0f41cf768c0837e8abe744a7f6a559ef9ede58e39e9bad047053a0dc5f27a31ff163452166c9db4ece043f7c77f985bbafa9e0ab7c528b32bc9b74d659dc4d5323e7b6d2d718d4eada7d0cc73efc350dff6da7d9c5085ff5c64232897f6ee0a09258a41a35f153f47ff0f3b8fa97ec67be9e133b134a46b23cf2c635be3116415fd388e3a1c1581bf1a77d7f7f0aff3a725bed01d8a3a88b85b65322b2256d3d90c746ee6194e0b46afd1b0c7a873ea24716a242e91b093b93210ab422d5c638d7a57feacbdd99357b3b0a90dbf5274570ce229553dd85ecb87d114bad1e615f4f9aa0c0cf01ebb5c2b116638eb78cbe4304517c1fe16da359e01f3cdfdf3f7aead4283e8b8e1107522b72f59d4c4f3ade4c5a90f03398bba5f1d3ebb705df137a81f0cc627dcea2cec72ee6d5610e734a231e2d997f442002389b3dadb47ed8134947c664a32ef637f43afdcbd1b5c1382339ae48e477969cee58822d528ae73bcb689154d92631f97b478006a7944600e510e8f647672359066df3ee2a8bf2fce14fa15037adc10d974719b9c3608cb1e44264a834dc230d397725f398d905d0746321d543c56644e5c89af59fe3fedb61a84ec601c8786daf0564e978c97c0e14095c23f9a08bb64950f9cb541b074b3ac0550b241c99a566f61929515ca97aedf99f73568df3dfe93078ed22cb54892b6c617c8e7122ae9b675af5389f5634b9b88643ad2752509f416aedfa2a81542bfcae1d871416a9bc216ad2ede3d418de48e8a8450f93de08256aa2388948ebc852eff97903ee737a4118785fa3f73759574d39d20591919577d9126cea7ba540483502cfbfce0ac87198cfd6d0ec7e5eec68834042ed949875730a35764c83ca0e9b262b9ad0046cbb0af1101a651fcb88cd1cba38e474b863abbb074b260a0296437194c674ad031297b060e590387062fa29455c2c7131ed9c7eaeb644db7bf504b395504eb46f2ab40b2587b84b971c4cdbb6001eacd1a452fef7db8d7c49ec7c2cfaecb92c5953ab48f1ac131615c7e9815671a743903aaabd4453a7d7f97d98e9ac69099676f38aba5a6cbc607f196bfd7b691554c4e3bbaea46b2c8fcdc5178b2dd77d794938fa52adce719d4948a92ba1a689068cec1fb6888d033e0ed1efc442b3fb93de89fb0988c73f8536fc5099afb761d2b69ec101c239c8c193336f2b6994f5aacca9689f32249db20a8dac36934314b7d5ba391d94169d63c66300aa47014a5c2dfc9bc0d6c3fb234dff4e4b60a6527d4cdfbb8c416f99df447acba7570e479457fec822f02dfbd78096641cbd6b6d997d18e82b8c31a01648a2be05a654a420c7b691d7a0ce7952c84b687d7387b271fcda7a8c956cbd0f58343f2bdbc30aed247a1aef9f2032e540101b46a674456967bf626b0d34a86f5f277f16699b17c3fd176c1b259959ed235bb9bb59d54731203c9c33c2e0e431729ea34280f0b51c476c951da31291f8f646630d56a7da6602a3365808a57c797bcaeb2076b6412093b234620aee37ce8be16100880af85ba6752e3652b2678b7ef122e13c385a135cbbbe8b1d87efeed43ddd3e0be9ddd8aa24b267b61fac42870d0bf5c92b0f2a5fe25ddf95729f6cba8a9ac48c7c0d1c2fdd7a7532586f2ea46be7d55a95c96f5bdffc7869acfea19c33c62a23ef9515d4f2f9e5b93b38b905b59664d1da4cfe90df4316370fd33e3a69f5b6371d1ade46bca444c14bab9284a21fcb75abf82243eb66fad0466b1d737cb51d6b957a8ec2acde3a01fbffc5a256f1b0189ee127902c0022ba8a8660b6b824801612ab1772a04800d886ea4361f9bd3a01148a0d6627692f4ef22f93361cd19e4e279510c45a522ef10ff6650daedef66d754b3202068593d714c7bfe09dcbf9e0525a59faa09b1a2b1de640cd57ac1182488554201e30bc180aa461a708bcdab3efcc019451b46351c61c2468ec9e4e0710e1441867b17a238159e89017ff6bc76b4d42d3e133d9e8809159423616094ef8df925afde07c0920da1882853184948c4a03aeb4dc99d50c363722fdf48c7c995feaf4c73b7b4c978d33747dcbdf14ae5654bfc807b15799c63fa694529bbf957aa2e3d3e66e624810c6ad7e81015f43eb4c41dd7ac5f2d77161f75c9163965d21b2df016c01202c56010e873a7353715e43429f763c89df40f8abd187ced93dc1209703237acc8e0413a9b1ef07775f45c18847d0a3d5987f13edc3287fa8beff020087d2614966840987f4a1e858d8b3051dc7a5afcb2a0f30edd1d05c1084a10bb4d2c563f089cc20fca49582f334d861cbbca4a01c94e81976926a667aa9936ec65cd80b2650d2f0f3434c2ee54f0be91939259add06ef7fd4488b992b184ebc4233ca856f1fcf817d4a0204dd34dc0833d46fa1839c862fafb8830eed0a417f1d8b60d047d8c958f624ea5649483077927067c93c23259048e90348fbdcca2b672271ee2a3759c5b73f34a0bc9b3764f83e3ab79f2182c1e277ef465907f0be250fe49a0897a708735972b6803cac22055ed760a861fce4036c6c8c30e4ae91de1da9ff290f44187d24df84aaca6995a3538fd8e6a126ae3096b743b854108908f25aedb8cd9c067cae60e41482d56af14cb8249cf8e5a96565c24986eb3e32bdd658c238b484e096fefe347488e1a22f9e99667cd0c288e6c9d2d33e969507af34a1634cec335e7c097c5421b441b9d84ae74c37c7da0d10aba5a048b59afe384585e0b38c5cd8d2a1b536c960f92f4724a628d48215c3881abddb32c2275993c297df1b56ce5d8b34eda35f823dfc27577c2b18c26efcf8c7d72d323257e4c4c095b611381fd9f336d80fa7ae9104e7b03d14a7df2d9ae92fc5037f367472c50ae104f86df35c0d5967968e352d7ea2b944f5909326076bf88e0fb30fa0ab5d0dc3030442ed92713f34170336c4dd2623723dc34829df89ffecdbd3f9ba0d71c6e59984f8384817f0fe5b0ac69ba62e1e40a31faf596a6c26999728e6eefa83b486188a3af6900a464741307e7e4fbe4c6bb030eb7650424a404d5bcb1109a33329f0e099fa8c07a8b02401da4e531bbc6de733a90e45aaf9b54f0a6c4a21daea6f41263e8df267367f5b491094bea56179a9c3b4ebd65a4fe845553b7ffbd7696ea3bf437851cbf73df723573d3b35ed7a699f9f4de8a2/etc/idle3.6/config-extensions.def/etc/idle3.6/config-highlight.def/etc/idle3.6/config-keys.def/etc/idle3.6/config-main.defrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootpython3-3.6.15-150300.10.78.1.src.rpmapplication()application(idle3.6.desktop)config(python3-idle)metainfo()metainfo(idle3.6.appdata.xml)mimehandler(text/x-python)python3-idlepython3-idlepython3-idle(s390-64)@@@     /usr/bin/python3/usr/bin/python3.6config(python3-idle)python(abi)python3python3-tkrpmlib(CompressedFileNames)rpmlib(FileDigests)rpmlib(PartialHardlinkSets)rpmlib(PayloadFilesHavePrefix)rpmlib(PayloadIsXz)3.6.15-150300.10.78.13.63.6.153.0.4-14.6.0-14.0.4-14.0-15.2-14.14.3g5@g4g6f5fff@fIf@fz@fuk@f:f*Ee؈e4@d@dVA@dRLd>@d@c>@ccv"@ck@c[@c$e@cbb@b@a@a*@a*@aaaayay?@af@a]aLl@aLl@aA@a'@aj@```t`[``@``/@``U_T__@_v@_0@_0@_@_G@___P_P_m_O@_N7_L@_?@_>e_>e_=@_@_______^^g@^>^>^8 @^0"@]f@]+]@]m]y@]v>]8H@]8H@]1]]@\\8\@\E@\C@["@[6@ZZԐ@Zx@Z@Z@Z Z Zz@Zhu@Z`@ZLZ"Z }YYX@Yo@Y@YY@Y@YI@XӸXƉXXqX@Xv@W@Wx@W_W@Vm@VhV*!@VCV }@U@U@U@UU[%UT@UCjU@TeT;mcepl@cepl.eumcepl@cepl.eumcepl@cepl.eumcepl@cepl.eumcepl@cepl.eumcepl@cepl.eumcepl@cepl.eumcepl@cepl.eumcepl@cepl.eumcepl@cepl.eumcepl@cepl.eumcepl@cepl.eumcepl@cepl.eumcepl@suse.commcepl@cepl.eudaniel.garcia@suse.commcepl@suse.commcepl@suse.comsteven.kowalik@suse.commcepl@suse.commcepl@suse.commcepl@suse.commcepl@suse.commcepl@suse.commcepl@suse.commcepl@suse.comsteven.kowalik@suse.commcepl@suse.commcepl@suse.comsteven.kowalik@suse.commcepl@suse.commcepl@suse.commcepl@suse.commcepl@suse.commcepl@suse.comdmueller@suse.comschwab@suse.demcepl@suse.comdimstar@opensuse.orgmcepl@suse.commcepl@suse.commcepl@suse.commcepl@suse.comschwab@suse.deqydwhotmail@gmail.commcepl@suse.commcepl@suse.commcepl@suse.comdmueller@suse.commcepl@suse.comcode@bnavigator.demcepl@suse.commcepl@suse.commcepl@suse.commcepl@suse.commcepl@suse.commeissner@suse.commcepl@suse.commcepl@suse.commcepl@suse.comsteven.kowalik@suse.commmachova@suse.commcepl@suse.commcepl@suse.commcalabkova@suse.comdimstar@opensuse.orgmcepl@suse.comdimstar@opensuse.orgmcepl@suse.commcepl@suse.comtchvatal@suse.comschwab@suse.demcalabkova@suse.commcalabkova@suse.commcalabkova@suse.commcepl@suse.commcalabkova@suse.comtchvatal@suse.comtchvatal@suse.comtchvatal@suse.comtchvatal@suse.comtchvatal@suse.comtchvatal@suse.commcepl@suse.commcepl@suse.commcepl@suse.commcepl@suse.comtchvatal@suse.commcepl@suse.commcepl@suse.commcepl@suse.commcepl@suse.commcepl@suse.commcepl@suse.commcepl@suse.commcepl@suse.commcepl@suse.commcepl@suse.commcepl@suse.commcepl@suse.commcepl@suse.commcepl@suse.commcepl@suse.commcepl@suse.commcepl@suse.commcepl@suse.commcepl@suse.comtchvatal@suse.comtchvatal@suse.commimi.vx@gmail.compsimons@suse.comadam@mizerski.plschwab@suse.debwiedemann@suse.comtchvatal@suse.comjmatejek@suse.comnormand@linux.vnet.ibm.comjmatejek@suse.comdimstar@opensuse.orgmimi.vx@gmail.comjmatejek@suse.comdmueller@suse.comvcizek@suse.comschwab@suse.dejmatejek@suse.comkukuk@suse.dejmatejek@suse.comasn@cryptomilk.orgjmatejek@suse.comjmatejek@suse.comjmatejek@suse.combwiedemann@suse.comjmatejek@suse.comjmatejek@suse.comhpj@urpla.nethpj@urpla.nethpj@urpla.netjmatejek@suse.comtoddrme2178@gmail.comtoddrme2178@gmail.comjmatejek@suse.comtoddrme2178@gmail.comjmatejek@suse.comdimstar@opensuse.orgjmatejek@suse.comfisiu@opensuse.orgmeissner@suse.comschwab@suse.dejmatejek@suse.commailaender@opensuse.orgrguenther@suse.comp.drouand@gmail.comjmatejek@suse.com- Remove -IVendor/ from python-config boo#1231795 - Fix CVE-2024-11168-validation-IPv6-addrs.patch - PGO run of build freezes with parallel processing, switch to -j1- Add CVE-2024-11168-validation-IPv6-addrs.patch fixing bsc#1233307 (CVE-2024-11168, gh#python/cpython#103848): Improper validation of IPv6 and IPvFuture addresses.- Add CVE-2024-9287-venv_path_unquoted.patch to properly quote path names provided when creating a virtual environment (bsc#1232241, CVE-2024-9287)- Drop .pyc files from docdir for reproducible builds (bsc#1230906).- Add CVE-2024-6232-ReDOS-backtrack-tarfile.patch prevent ReDos via excessive backtracking while parsing header values (bsc#1230227, CVE-2024-6232).- Add CVE-2024-5642-switch-off-NPN.patch switching off the NPN support eliminating bsc#1227233 (CVE-2024-5642).- Add CVE-2024-6923-email-hdr-inject.patch to prevent email header injection due to unquoted newlines (bsc#1228780, CVE-2024-6923). - Add CVE-2024-7592-quad-complex-cookies.patch fixing quadratic complexity in parsing cookies with backslashes (bsc#1229596, CVE-2024-7592) - %{profileopt} variable is set according to the variable %{do_profiling} (bsc#1227999)- Remove %suse_update_desktop_file macro as it is not useful any more.- Stop using %%defattr, it seems to be breaking proper executable attributes on /usr/bin/ scripts (bsc#1227378).- Add CVE-2024-4032-private-IP-addrs.patch to fix bsc#1226448 (CVE-2024-4032) rearranging definition of private v global IP addresses.- Add CVE-2024-0397-memrace_ssl.SSLContext_cert_store.patch fixing bsc#1226447 (CVE-2024-0397) by removing memory race condition in ssl.SSLContext certificate store methods.- Add bpo38361-syslog-no-slash-ident.patch (bsc#1222109, gh#python/cpython!16557) fixes syslog making default "ident" from sys.argv[0]. - Update CVE-2023-52425-libexpat-2.6.0-backport.patch so that it uses features sniffing, not just comparing version number (bsc#1220664, bsc#1219559, bsc#1221563, bsc#1222075). - Remove support-expat-CVE-2022-25236-patched.patch, which was the previous name of this patch. - Add CVE-2023-52425-remove-reparse_deferral-tests.patch skipping failing tests. - Refresh patches: - CVE-2023-27043-email-parsing-errors.patch - fix_configure_rst.patch - skip_if_buildbot-extend.patch- bsc#1221854 (CVE-2024-0450) Add CVE-2024-0450-zipfile-avoid-quoted-overlap-zipbomb.patch detecting the vulnerability of the "quoted-overlap" zipbomb (from gh#python/cpython!110016). - Add bh42369-thread-safety-zipfile-SharedFile.patch (from gh#python/cpython!26974) required by the previous patch. - Add expat-260-test_xml_etree-reparse-deferral.patch to make the interpreter work with patched libexpat in our distros. - Move all patches from locally sourced to the branch opensuse-3.6 branch at GitHub repo, and move all metadata to commits themselves (readable in the headers of each patch). - Add bpo-41675-modernize-siginterrupt.patch to make Python build cleanly even on more recent SPs of SLE-15 (gh#python/cpython#85841). - Remove patches: - bpo36263-Fix_hashlib_scrypt.patch - fix against bug in OpenSSL fixed in 1.1.1c (gh#openssl/openssl!8483), so this patch is redundant on all SUSE-supported distros - python-3.3.0b1-test-posix_fadvise.patch - protection against the kernel issues which has been fixed in gh#torvalds/linux@3d3727cdb07f, which has been included in all our kernels more recent than SLE-11. - python-3.3.3-skip-distutils-test_sysconfig_module.patch - skips a test, which should be relevant only for testing on Mac OS X systems with universal builds. I have no valid record, that this test would be ever problematic on Linux. - bpo-36576-skip_tests_for_OpenSSL-111.patch, which was included already in Python 3.5.- (bsc#1219666, CVE-2023-6597) Add CVE-2023-6597-TempDir-cleaning-symlink.patch (patch from gh#python/cpython!99930) fixing symlink bug in cleanup of tempfile.TemporaryDirectory. - Merge together bpo-36576-skip_tests_for_OpenSSL-111.patch into skip_SSL_tests.patch, and make them include all conditionals.- Refresh CVE-2023-27043-email-parsing-errors.patch to gh#python/cpython!111116, fixing bsc#1210638 (CVE-2023-27043).- Add CVE-2023-40217-avoid-ssl-pre-close.patch fixing gh#python/cpython#108310, backport from upstream patch gh#python/cpython#108315 (bsc#1214692, CVE-2023-40217)- Add 99366-patch.dict-can-decorate-async.patch fixing gh#python/cpython#98086 (backport from Python 3.10 patch in gh#python/cpython!99366), fixing bsc#1211158.- Add CVE-2007-4559-filter-tarfile_extractall.patch to fix CVE-2007-4559 (bsc#1203750) by adding the filter for tarfile.extractall (PEP 706).- Use python3 modules to build the documentation.- Add bpo-44434-libgcc_s-for-pthread_cancel.patch which eliminates unnecessary and dangerous calls to PyThread_exit_thread() (bsc#1203355).- Add CVE-2023-24329-blank-URL-bypass.patch (CVE-2023-24329, bsc#1208471) blocklists bypass via the urllib.parse component when supplying a URL that starts with blank characters- Add bpo27321-email-no-replace-header.patch to stop email.generator.py from replacing a non-existent header (bsc#1208443, gh#python/cpython#71508).- Add bsc1188607-pythreadstate_clear-decref.patch to fix crash in the garbage collection (bsc#1188607).- Add CVE-2022-45061-DoS-by-IDNA-decode.patch to avoid CVE-2022-45061 (bsc#1205244) allowing DoS by IDNA decoding extremely long domain names.- Add CVE-2022-37454-sha3-buffer-overflow.patch to fix bsc#1204577 (CVE-2022-37454, gh#python/cpython#98517) buffer overflow in hashlib.sha3_* implementations (originally from the XKCP library).- Add CVE-2020-10735-DoS-no-limit-int-size.patch to fix CVE-2020-10735 (bsc#1203125) to limit amount of digits converting text to int and vice vera (potential for DoS). Originally by Victor Stinner of Red Hat.- Add patch CVE-2021-28861-double-slash-path.patch: * http.server: Fix an open redirection vulnerability in the HTTP server when an URI path starts with //. (bsc#1202624, CVE-2021-28861)- Add CVE-2015-20107-mailcap-unsafe-filenames.patch to avoid CVE-2015-20107 (bsc#1198511, gh#python/cpython#68966), the command injection in the mailcap module. - Rename support-expat-245.patch to support-expat-CVE-2022-25236-patched.patch to unify the patch with other packages. - Add bpo-46623-skip-zlib-s390x.patch skipping two failing tests on s390x.- Update bundled pip wheel to the latest SLE version patched against bsc#1186819 (CVE-2021-3572).- Add patch support-expat-245.patch: * Support Expat >= 2.4.5- Rename 22198.patch into more descriptive remove-sphinx40-warning.patch.- Don't use appstream-glib on SLE-12. - Use Python 2-based Sphinx on SLE-12. - No documentation on SLE-12. - Add skip_SSL_tests.patch skipping tests because of patched OpenSSL (bpo#9425).- Don't use appstream-glib on SLE-12. - Use Python 2-based Sphinx on SLE-12. - No documentation on SLE-12. - Add skip_SSL_tests.patch skipping tests because of patched OpenSSL (bpo#9425).- Don't use OpenSSL 1.1 on platforms which don't have it.- Remove shebangs from from python-base libraries in _libdir (bsc#1193179, bsc#1192249). - Readjust patches: - bpo-31046_ensurepip_honours_prefix.patch - decimal.patch - python-3.3.0b1-fix_date_time_compiler.patch- build against openssl 1.1 as it is incompatible with openssl 3.0+ (bsc#1190566)- 0001-allow-for-reproducible-builds-of-python-packages.patch: ignore permission error when changing the mtime of the source file in presence of SOURCE_DATE_EPOCH- The previous construct works only on the current Factory, not in SLE.- BuildRequire rpm-build-python: The provider to inject python(abi) has been moved there. rpm-build pulls rpm-build-python automatically in when building anything against python3-base, but this implies that the initial build of python3-base does not trigger the automatic installation.- Due to conflicting demands of bsc#1183858 and platforms where Python 3.6 is only in interpreter+pip set we have to make complicated ugly construct about Sphinx BR.- Make python36 primary interpreter on SLE-15- Make build working even on older SLEs.- Update to 3.6.15: - bpo-43124: Made the internal putcmd function in smtplib sanitize input for presence of \r and \n characters to avoid (unlikely) command injection. Library - bpo-45001: Made email date parsing more robust against malformed input, namely a whitespace-only Date: header. Patch by Wouter Bolsterlee. Tests - bpo-38965: Fix test_faulthandler on GCC 10. Use the “volatile” keyword in faulthandler._stack_overflow() to prevent tail call optimization on any compiler, rather than relying on compiler specific pragma. - bpo-40791: Make compare_digest more constant-time (bsc#1214691, CVE-2022-48566). - Remove upstreamed patches: - faulthandler_stack_overflow_on_GCC10.patch- test_faulthandler is still problematic under qemu linux-user emulation, disable it there- Update to 3.6.14: * Security - bpo-44022 (bsc#1189241, CVE-2021-3737): mod:http.client now avoids infinitely reading potential HTTP headers after a 100 Continue status response from the server. - bpo-43882: The presence of newline or tab characters in parts of a URL could allow some forms of attacks. Following the controlling specification for URLs defined by WHATWG urllib.parse() now removes ASCII newlines and tabs from URLs, preventing such attacks. - bpo-42988 (CVE-2021-3426, bsc#1183374): Remove the getfile feature of the pydoc module which could be abused to read arbitrary files on the disk (directory traversal vulnerability). Moreover, even source code of Python modules can contain sensitive data like passwords. Vulnerability reported by David Schwörer. - bpo-43285: ftplib no longer trusts the IP address value returned from the server in response to the PASV command by default. This prevents a malicious FTP server from using the response to probe IPv4 address and port combinations on the client network. Code that requires the former vulnerable behavior may set a trust_server_pasv_ipv4_address attribute on their ftplib.FTP instances to True to re-enable it. - bpo-43075 (CVE-2021-3733, bsc#1189287): Fix Regular Expression Denial of Service (ReDoS) vulnerability in urllib.request.AbstractBasicAuthHandler. The ReDoS-vulnerable regex has quadratic worst-case complexity and it allows cause a denial of service when identifying crafted invalid RFCs. This ReDoS issue is on the client side and needs remote attackers to control the HTTP server. - Upstreamed patches were removed: - CVE-2021-3426-inf-disclosure-pydoc-getfile.patch - CVE-2021-3733-ReDoS-urllib-AbstractBasicAuthHandler.patch - Refreshed patches: - python3-sorted_tar.patch - riscv64-ctypes.patch- Rebuild to get new headers, avoid building in support for stropts.h (bsc#1187338).- Use versioned python-Sphinx to avoid dependency on other version of Python (bsc#1183858).- Modify Lib/ensurepip/__init__.py to contain the same version numbers as are in reality the ones in the bundled wheels (bsc#1187668).- add 22198.patch to build with Sphinx 4- Stop providing "python" symbol (bsc#1185588), which means python2 currently.- Make sure to close the import_failed.map file after the exception has been raised in order to avoid ResourceWarnings when the failing import is part of a try...except block.- Add CVE-2021-3426-inf-disclosure-pydoc-getfile.patch to remove getfile feature from pydoc, which is a security nightmare (among other things, CVE-2021-3426, allows disclosure of any file on the system; bsc#1183374, bpo#42988).Update to 3.6.13, final release of 3.6 branch: * Security - bpo#42967 (bsc#1182379, CVE-2021-23336): Fix web cache poisoning vulnerability by defaulting the query args separator to &, and allowing the user to choose a custom separator. - bpo#42938 (bsc#1181126, CVE-2021-3177): Avoid static buffers when computing the repr of ctypes.c_double and ctypes.c_longdouble values. - bpo#42103: Prevented potential DoS attack via CPU and RAM exhaustion when processing malformed Apple Property List files in binary format. - bpo#42051: The plistlib module no longer accepts entity declarations in XML plist files to avoid XML vulnerabilities. This should not affect users as entity declarations are not used in regular plist files. - bpo#40791: Add volatile to the accumulator variable in hmac.compare_digest, making constant-time-defeating optimizations less likely. * Core and Builtins - bpo#35560: Fix an assertion error in format() in debug build for floating point formatting with “n” format, zero padding and small width. Release build is not impacted. Patch by Karthikeyan Singaravelan. * Library - bpo#42103: InvalidFileException and RecursionError are now the only errors caused by loading malformed binary Plist file (previously ValueError and TypeError could be raised in some specific cases). * Tests - bpo#42794: Update test_nntplib to use offical group name of news.aioe.org for testing. Patch by Dong-hee Na. - bpo#41944: Tests for CJK codecs no longer call eval() on content received via HTTP. - Patches removed, because they were included in the upstream tarball: - CVE-2020-27619-no-eval-http-content.patch - CVE-2021-3177-buf_ovrfl_PyCArg_repr.patch- Add CVE-2021-3177-buf_ovrfl_PyCArg_repr.patch fixing bsc#1181126 (CVE-2021-3177) buffer overflow in PyCArg_repr in _ctypes/callproc.c, which may lead to remote code execution.- Provide the newest setuptools wheel (bsc#1176262, CVE-2019-20916) in their correct form (bsc#1180686).- (bsc#1180125) We really don't Require python-rpm-macros package. Unnecessary dependency.- readd --with-fpectl (bsc#1180377)- Adjust sphinx-update-removed-function.patch- (bsc#1179630) Update sphinx-update-removed-function.patch to work with all versions of Sphinx (not binding the Python documentation build to the latest verison of Sphinx). Updated version mentioned on gh#python/cpython#13236.- Add CVE-2020-27619-no-eval-http-content.patch fixing CVE-2020-27619 (bsc#1178009), where Lib/test/multibytecodec_support calls eval() on content retrieved via HTTP.- Add patch sphinx-update-removed-function.patch to no longer call a now removed function (gh#python/cpython#13236). As a consequence, no longer pin Sphinx version.- Pin Sphinx version to fix doc subpackage- Change setuptools and pip version numbers according to new wheels (bsc#1179756). - Add ignore_pip_deprec_warn.patch to switch of persistently failing test.- Replace bundled wheels for pip and setuptools with the updated ones (bsc#1176262 CVE-2019-20916).- Handful of changes to make python36 compatible with SLE15 and SLE12 (jsc#ECO-2799, jsc#SLE-13738) - Rebase bpo23395-PyErr_SetInterrupt-signal.patch- Fix build with RPM 4.16: error: bare words are no longer supported, please use "...": x86 == ppc.- Fix installing .desktop file- Buildrequire timezone only for general flavor. It's used in this flavor for the test suite.- Add faulthandler_stack_overflow_on_GCC10.patch to make build working even with GCC10 (bpo#38965).- Just cleanup and reordering items to synchronize with python38- Format with spec-cleaner- riscv64-support.patch: bpo-33377: add triplets for mips-r6 and riscv (#6655) - riscv64-ctypes.patch: bpo-35847: RISC-V needs CTYPES_PASS_BY_REF_HACK (GH-11694) - Update list of tests to exclude under qemu linux-user- Update the python keyring - Correct libpython name- Drop patches which are not mentioned in spec: * CVE-2019-5010-null-defer-x509-cert-DOS.patch * F00102-lib64.patch * F00251-change-user-install-location.patch * OBS_dev-shm.patch * SUSE-FEDORA-multilib.patch * bpo-31046_ensurepip_honours_prefix.patch * bpo34022-stop_hash-based_invalidation_w_SOURCE_DATE_EPOCH.patch * bpo36302-sort-module-sources.patch * bpo40784-Fix-sqlite3-deterministic-test.patch * bsc1167501-invalid-alignment.patch * python3-imp-returntype.patch - Working around missing python-packaging dependency in python-Sphinx (bsc#1174571) is not necessary anymore.- Update to 3.6.12 (bsc#1179193) * Ensure python3.dll is loaded from correct locations when Python is embedded * The __hash__() methods of ipaddress.IPv4Interface and ipaddress.IPv6Interface incorrectly generated constant hash values of 32 and 128 respectively. This resulted in always causing hash collisions. The fix uses hash() to generate hash values for the tuple of (address, mask length, network address). * Prevent http header injection by rejecting control characters in http.client.putrequest(…). * Unpickling invalid NEWOBJ_EX opcode with the C implementation raises now UnpicklingError instead of crashing. * Avoid infinite loop when reading specially crafted TAR files using the tarfile module - Drop merged fixtures: * CVE-2020-14422-ipaddress-hash-collision.patch * CVE-2019-20907_tarfile-inf-loop.patch * recursion.tar - This release also fixes CVE-2020-26116 (bsc#1177211) and CVE-2019-20907 (bsc#1174091).- Add CVE-2019-20907_tarfile-inf-loop.patch fixing bsc#1174091 (CVE-2019-20907, bpo#39017) avoiding possible infinite loop in specifically crafted tarball. Add recursion.tar as a testing tarball for the patch.- Make library names internally consistent- Disable profile optimalizations as they deadlock in test_faulthandler- Disable lto as it causes mess and works with 3.7 onwards only- Sync the test disablements from the python3 in sle15- Update to 3.6.11: - bpo-39073: Disallow CR or LF in email.headerregistry. Address arguments to guard against header injection attacks. - bpo-38576 (bsc#1155094): Disallow control characters in hostnames in http.client, addressing CVE-2019-18348. Such potentially malicious header injection URLs now cause a InvalidURL to be raised. - bpo-39503: CVE-2020-8492: The AbstractBasicAuthHandler class of the urllib.request module uses an inefficient regular expression which can be exploited by an attacker to cause a denial of service. Fix the regex to prevent the catastrophic backtracking. Vulnerability reported by Ben Caller and Matt Schwager. - bpo-39401: Avoid unsafe load of api-ms-win-core-path-l1-1-0.dll at startup on Windows 7. - Remove merged patch CVE-2020-8492-urllib-ReDoS.patch, CRLF_injection_via_host_part.patch, and CVE-2019-18348-CRLF_injection_via_host_part.patch.- Fix minor issues found in the staging.- Do not set ourselves as a primary interpreter- Add CVE-2020-14422-ipaddress-hash-collision.patch fixing CVE-2020-14422 (bsc#1173274, bpo#41004), where hash collisions in IPv4Interface and IPv6Interface could lead to DOS.- Change name of idle3 icons to idle3.png to avoid collision with Python 2 version (bsc#1165894).- Add CVE-2019-9674-zip-bomb.patch to improve documentation warning about dangers of zip-bombs and other security problems with zipfile library. (bsc#1162825 CVE-2019-9674) - Add CVE-2020-8492-urllib-ReDoS.patch fixing the security bug "Python urrlib allowed an HTTP server to conduct Regular Expression Denial of Service (ReDoS)" (bsc#1162367)- Add Requires: libpython%{so_version} == %{version}-%{release} to python3-base to keep both packages always synchronized (bsc#1162224).- Reame idle icons to idle3 in order to not conflict with python2 variant of the package bsc#1165894 * renamed the icons * renamed icon load in desktop file- Add pep538_coerce_legacy_c_locale.patch to coerce locale to C.UTF-8 always (bsc#1162423).- Update to 3.6.10 (still in line with jsc#SLE-9426, jsc#SLE-9427, bsc#1159035): - Security: - bpo-38945: Newline characters have been escaped when performing uu encoding to prevent them from overflowing into to content section of the encoded file. This prevents malicious or accidental modification of data during the decoding process. - bpo-37228: Due to significant security concerns, the reuse_address parameter of asyncio.loop.create_datagram_endpoint() is no longer supported. This is because of the behavior of SO_REUSEADDR in UDP. For more details, see the documentation for loop.create_datagram_endpoint(). (Contributed by Kyle Stanley, Antoine Pitrou, and Yury Selivanov in bpo-37228.) - bpo-38804: Fixes a ReDoS vulnerability in http.cookiejar. Patch by Ben Caller. - bpo-38243: Escape the server title of xmlrpc.server.DocXMLRPCServer when rendering the document page as HTML. (Contributed by Dong-hee Na in bpo-38243.) - bpo-38174: Update vendorized expat library version to 2.2.8, which resolves CVE-2019-15903. - bpo-37461: Fix an infinite loop when parsing specially crafted email headers. Patch by Abhilash Raj. - bpo-34155: Fix parsing of invalid email addresses with more than one @ (e.g. a@b@c.com.) to not return the part before 2nd @ as valid email address. Patch by maxking & jpic. - Library: - bpo-38216: Allow the rare code that wants to send invalid http requests from the http.client library a way to do so. The fixes for bpo-30458 led to breakage for some projects that were relying on this ability to test their own behavior in the face of bad requests. - bpo-36564: Fix infinite loop in email header folding logic that would be triggered when an email policy’s max_line_length is not long enough to include the required markup and any values in the message. Patch by Paul Ganssle - Remove patches included in the upstream tarball: - CVE-2019-16935-xmlrpc-doc-server_title.patch (and also bpo37614-race_test_docxmlrpc_srv_setup.patch, which was resolving bsc#1174701). - CVE-2019-16056-email-parse-addr.patch - Move idle subpackage build from python3-base to python3 (bsc#1159622). appstream-glib required for packaging introduces considerable extra dependencies and a build loop via rust/librsvg. - Correct installation of idle IDE icons: + idle.png is not the target directory + non-GNOME-specific icons belong into icons/hicolor - Add required Name key to idle3 desktop file- Unify all Python 3.6* SLE packages into one (jsc#SLE-9426, jsc#SLE-9427, bsc#1159035) - Patches which were already included upstream: - CVE-2018-1061-DOS-via-regexp-difflib.patch - CVE-2018-14647_XML_SetHashSalt-in_elementtree.patch- Add CVE-2019-16935-xmlrpc-doc-server_title.patch fixing bsc#1153238 (aka CVE-2019-16935) fixing a reflected XSS in python/Lib/DocXMLRPCServer.py- Add bpo-36576-skip_tests_for_OpenSSL-111.patch (originally from bpo#36576) skipping tests failing with OpenSSL 1.1.1. Fixes bsc#1149792 - Add bpo36263-Fix_hashlib_scrypt.patch which works around bsc#1151490- Add CVE-2019-16056-email-parse-addr.patch fixing the email module wrongly parses email addresses [bsc#1149955, bnc#1149955, CVE-2019-16056]- jsc#PM-1350 bsc#1149121 Update python3 to the last version of the 3.6 line. This is just a bugfix release with no changes in functionality. - The following patches were included in the upstream release as so they can be removed in the package: - CVE-2018-20852-cookie-domain-check.patch - CVE-2019-5010-null-defer-x509-cert-DOS.patch - CVE-2019-10160-netloc-port-regression.patch - CVE-2019-9636-urlsplit-NFKC-norm.patch - CVE-2019-9947-no-ctrl-char-http.patch - Patch bpo23395-PyErr_SetInterrupt-signal.patch has been reapplied on the upstream base without changing any functionality. - Add patch aarch64-prolong-timeout.patch to fix failing test_utime_current_old test.- FAKE RECORD FROM SLE-12 CHANNEL Apply "CVE-2018-1000802-shutil_use_subprocess_no_spawn.patch" which converts shutil._call_external_zip to use subprocess rather than distutils.spawn. [bsc#1109663, CVE-2018-1000802]- FAKE RECORD FROM SLE-12 CHANNEL bsc#1109847: add CVE-2018-14647_XML_SetHashSalt-in_elementtree.patch fixing bpo#34623.- boo#1141853 (CVE-2018-20852) add CVE-2018-20852-cookie-domain-check.patch fixing http.cookiejar.DefaultPolicy.domain_return_ok which did not correctly validate the domain: it could be tricked into sending cookies to the wrong server.- bsc#1138459: add CVE-2019-10160-netloc-port-regression.patch which fixes regression introduced by the previous patch. (CVE-2019-10160) Upstream gh#python/cpython#13812- FAKE RECORD FROM SLE-12 CHANNEL bsc#1137942: Avoid duplicate files with python3* packages (https://fate.suse.com/327309)- bsc#1094814: Add bpo23395-PyErr_SetInterrupt-signal.patch to handle situation when the SIGINT signal is ignored or not handled- Update to 3.6.8: - bugfixes only - removed patches (subsumed in the upstream tarball): - CVE-2018-20406-pickle_LONG_BINPUT.patch - refreshed patches: - CVE-2019-5010-null-defer-x509-cert-DOS.patch - CVE-2019-9636-urlsplit-NFKC-norm.patch - Python-3.0b1-record-rpm.patch - python-3.3.0b1-fix_date_time_compiler.patch - python-3.3.0b1-test-posix_fadvise.patch - python-3.3.3-skip-distutils-test_sysconfig_module.patch - python-3.6.0-multilib-new.patch - python3-sorted_tar.patch - subprocess-raise-timeout.patch - switch off LTO and PGO optimization (bsc#1133452) - bsc#1130840 (CVE-2019-9947): add CVE-2019-9947-no-ctrl-char-http.patch Address the issue by disallowing URL paths with embedded whitespace or control characters through into the underlying http client request. Such potentially malicious header injection URLs now cause a ValueError to be raised.- bsc#1129346: add CVE-2019-9636-urlsplit-NFKC-norm.patch Characters in the netloc attribute that decompose under NFKC normalization (as used by the IDNA encoding) into any of ``/``, ``?``, ``#``, ``@``, or ``:`` will raise a ValueError. If the URL is decomposed before parsing, or is not a Unicode string, no error will be raised. (CVE-2019-9636) Upstream gh#python/cpython#12224- bsc#1120644 add CVE-2018-20406-pickle_LONG_BINPUT.patch fixing bpo#34656 Modules/_pickle.c in Python before 3.7.1 has an integer overflow via a large LONG_BINPUT value that is mishandled during a "resize to twice the size" attempt. This issue might cause memory exhaustion, but is only relevant if the pickle format is used for serializing tens or hundreds of gigabytes of data.- bsc#1122191: add CVE-2019-5010-null-defer-x509-cert-DOS.patch fixing bpo-35746. An exploitable denial-of-service vulnerability exists in the X509 certificate parser of Python.org Python 2.7.11 / 3.7.2. A specially crafted X509 certificate can cause a NULL pointer dereference, resulting in a denial of service. An attacker can initiate or accept TLS connections using crafted certificates to trigger this vulnerability.- Add -fwrapv to OPTS, which is default for python3 anyway See for example https://github.com/zopefoundation/persistent/issues/86 for bugs which are caused by avoiding it. (bsc#1107030)- Apply "CVE-2018-1061-DOS-via-regexp-difflib.patch" to prevent low-grade poplib REDOS (CVE-2018-1060) and to prevent difflib REDOS (CVE-2018-1061). Prior to this patch mail server's timestamp was susceptible to catastrophic backtracking on long evil response from the server. Also, it was susceptible to catastrophic backtracking, which was a potential DOS vector. [bsc#1088004 and bsc#1088009, CVE-2018-1061 and CVE-2018-1060]- As we run in main python package do not generate the pre_checkin from both now- Move the tests from base to generic package wrt bsc#1088573 * We still fail the whole distro if python3 is not build * The other archs than x86_64 took couple of hours to unblock build of other software, this way we work around the issue - Some tests are still run in -base for the LTO tweaking, but at least it is not run twice- update to 3.6.5 * bugfix release * see Misc/NEWS for details - drop ctypes-pass-by-value.patch - drop fix-localeconv-encoding-for-LC_NUMERIC.patch - refresh python-3.6.0-multilib-new.patch- Apply "python-3.6-CVE-2017-18207.patch" to add a check to Lib/wave.py that verifies that at least one channel is provided. Prior to this check, attackers could cause a denial of service (divide-by-zero error and application crash) via a crafted wav format audio file. [bsc#1083507, CVE-2017-18207]- Created %so_major and %so_minor macros - Put Tools/gdb/libpython.py script into proper place and ship it with devel subpackage.- ctypes-pass-by-value.patch: Fix pass by value for structs on aarch64- Add python3-sorted_tar.patch (boo#1081750, bsc#1086001)- Add patch to fix glibc 2.27 fail bsc#1079761: * fix-localeconv-encoding-for-LC_NUMERIC.patch- move XML modules and python3-xml provide to python3-base (fixes bsc#1077230) - move ensurepip to base- Add skip_random_failing_tests.patch only for PowerPC- update to 3.6.4 * bugfix release, over a hundred bugs fixed * see Misc/NEWS for details - drop upstreamed python3-ncurses-6.0-accessors.patch - drop PYTHONSTARTUP hooks that cause spurious startup errors * fixes bsc#1070738 * the relevant feature (REPL history) is now built into Python itself- Install 2to3-%{python_version} executable (override defattr of the -tools package). 2to3 (unversioned) is a symlink and does not carry permissions (bsc#1070853).- move 2to3 to python3-tools package- update to 3.6.3 * bugfix release, over a hundred bugs fixed * see Misc/NEWS for details - drop upstreamed 0001-3.6-bpo-30714-ALPN-changes-for-OpenSSL-1.1.0f-3093.patch- drop python-2.7-libffi-aarch64.patch: this patches the intree copy of libffi which is unused/deleted in the line afterwards - fix build against system libffi: include flags weren't set so it actually used the in-tree libffi headers.- Fix test broken with OpenSSL 1.1 (bsc#1042670) * add 0001-3.6-bpo-30714-ALPN-changes-for-OpenSSL-1.1.0f-3093.patch- fix missing %{?armsuffix}- distutils-reproducible-compile.patch: ensure distutils order files before compiling, which works around bsc#1049186- Add libnsl-devel build requires for glibc obsoleting libnsl- update to 3.6.2 * bugfix release, over a hundred bugs fixed * see Misc/NEWS for details - drop upstreamed test-socket-aead-kernel49.patch - add Provides: python3-typing (fixes bsc#1050653) - drop duplicate Provides: python3- Add missing link to python library in config dir (bsc#1040164)- update to 3.6.1 * bugfix release, over a hundred bugs fixed * never add import location's parent directory to sys.path * switch to git for version control, build changes related to that * fix "failed to get random numbers" on old kernels (bsc#1029902) * several crashes and memory leaks corrected * f-string are no longer accepted as docstrings- prevent regenerating AST at build-time more robustly - add "--without profileopt" and "--without testsuite" options to python3-base to allow short circuiting when working on the package- FAKE RECORD FROM SLE-12 CHANNEL update to 3.4.6 (bsc#1027282): * fixed potential crash in PyUnicode_AsDecodedObject() in debug build * fixed possible DoS and arbitrary execution in gettext plurals * fix possible use of uninitialized memory in operator.methodcaller * fix possible Py_DECREF on unowned object in _sre * fix possible integer overflow in _csv module * prevent HTTPoxy attack (CVE-2016-1000110) * fix selectors incorrectly retaining invalid fds - drop upstreamed python-3.4-CVE-2016-1000110-fix.patch - move _elementtree to python3.rpm to match its pyexpat dependency (bsc#1029377)- Add 0001-allow-for-reproducible-builds-of-python-packages.patch upstream https://github.com/python/cpython/pull/296- reenable test_socket with AEAD patch (test-socket-aead-kernel49.patch) - reintroduce %py3_soflags macro (and better named %cpython3_soabi equivalent)- update to 3.6.0 * PEP 498 Formated string literals * PEP 515 Underscores in numeric literals * PEP 526 Syntax for variable annotations * PEP 525 Asynchronous generators * PEP 530 Asynchronous comprehensions * PEP 506 New "secrets" module for safe key generation * less memory consumed by dicts * dtrace and systemtap support * improved asyncio module * better defaults for ssl * new hashing algorithms in hashlib * bytecode format changed to allow more optimizations * "async" and "await" are on track to be reserved words * StopIteration from generators is deprecated * support for openssl < 1.0.2 is deprecated * os.urandom now blocks when getrandom() blocks * huge number of new features, bugfixes and optimizations * see https://docs.python.org/3.6/whatsnew/3.6.html for details - rework multilib patch: drop Python-3.5.0-multilib.patch, implement upstreamable python-3.6.0-multilib-new.patch - refresh python-3.3.0b1-localpath.patch, subprocess-raise-timeout.patch - drop upstreamed Python-3.5.1-fix_lru_cache_copying.patch - finally drop python-2.6b1-canonicalize2.patch that was not applied in source and only kept around in case we needed it in the future. (which we don't, as it seems) - update import_failed map and baselibs - build ctypes against system libffi (buildrequire libffi-devel in python3-base) - add new key to keyring (signed by keys already in keyring) - introduced common configure section between python3 and python3-base - moved pyconfig.h and Makefile to devel subpackage as distutils no longer need it at runtime - added python-rpm-macros dependency, regenerated macros file, drop macros.python3.py because it is not used now - improve summaries and descriptions (fixes bsc#917607) - enabled Link-Time Optimization, see what happens - including skipped_tests.py in pre_checkin.sh run - run specs through spec-cleaner, rearrange sections- FAKE RECORD FROM SLE-12 CHANNEL apply fix for CVE-2016-1000110 - CGIHandler: sets environmental variable based on user supplied Proxy request header: python-3.4-CVE-2016-1000110-fix.patch (fixes bsc#989523, CVE-2016-1000110) - refresh python3-urllib-prefer-lowercase-proxies.patch- FAKE RECORD FROM SLE-12 CHANNEL update to 3.4.5 check: https://docs.python.org/3.4/whatsnew/changelog.html (fixes bsc#984751, CVE-2016-0772) (fixes bsc#985177, CVE-2016-5636) (fixes bsc#985348, CVE-2016-5699) - drop upstreamed werror-declaration-after-statement.patch- FAKE RECORD FROM SLE-12 CHANNEL Due to being fixed upstream (differently), removed outdated patch CVE-2014-4650-CGIHTTPServer-traversal.patch (bsc#983582)- move _hashlib and _ssl modules and tests to python3-base - recommend python3- Add Python-3.5.1-fix_lru_cache_copying.patch Fix copying the lru_cache() wrapper object. Fixes deep-copying lru_cache regression, which worked on previous versions of python but fails on python 3.5. This fixes a bunch of packages in devel:languages:python3. See: https://bugs.python.org/issue25447- update to 3.5.1 * bugfix-only release, dozens of bugs fixed - Drop upstreamed Python-3.5.0-_Py_atomic_xxx-symbols.patch - "Python3" to "Python 3" in summary * This seems cleaner and fixes and rpmlint warning- FAKE RECORD FROM SLE-12 CHANNEL Issue #21121: Don't force 3rd party C extensions to be built with -Werror=declaration-after-statement. (werror-declaration-after-statement.patch, bsc#951166)- Add Python-3.5.0-_Py_atomic_xxx-symbols.patch This fixes a build error for many packages that use the Python, C-API. This patch is already accepted upstream and is slated to appear in python 3.5.1.- update to 3.5.0 * coroutines with async/await syntax * matrix multiplication operator `@` * unpacking generalizations * new modules `typing` and `zipapp` * type annotations * .pyo files replaced by custom suffixes for optimization levels in __pycache__ * support for memory BIO in ssl module * performance improvements in several modules * and many more - removals and behavior changes * deprecated `__version__` is removed * support for .pyo files was removed * system calls are auto-retried on EINTR * bare generator expressions in function calls now cause SyntaxError (change "f(x for x in i)" to "f((x for x in i))" to fix) * removed undocumented `format` member of private `PyMemoryViewObject` struct * renamed `PyMemAllocator` to `PyMemAllocatorEx` - redefine %dynlib macro to reflect that modules now have arch+os as part of name - module `time` is now built-in - dropped upstreamed patches: python-3.4.1-fix-faulthandler.patch python-3.4.3-test-conditional-ssl.patch python-fix-short-dh.patch (also dropped dh2048.pem required for this patch) - updated patch Python-3.3.0b2-multilib.patch to Python-3.5.0-multilib.patch - python-ncurses-6.0-accessors.patch taken from python 2 to fix build failure with new gcc + ncurses- Add python3-ncurses-6.0-accessors.patch: Fix build with NCurses 6.0 and OPAQUE_WINDOW set to 1.- improve import_failed hook to do the right thing when invoking missing modules with "python3 -m modulename" (boo#942751)- Build with --enable-loadable-sqlite-extensions to make it works as geospatial database.- dh2048.pem: added generated 2048 dh parameter set to fix ssl test (bsc#935856) - python-fix-short-dh.patch: replace the 512 bits dh parameter set by 2048 bits to fix build with new openssl 1.0.2c (bsc#935856)- ctypes-libffi-aarch64.patch: remove upstreamed patch - python-2.7-libffi-aarch64.patch: Fix argument passing in libffi for aarch64- python-3.4.3-test-conditional-ssl.patch - restore tests failing because test_urllib was unconditionally importing ssl (without really needing it) - restore functionality of multilib patch - drop libffi-ppc64le.diff because upstream completely changed everything yet again (sorry ppc64 folks :| )- Update to version 3.4.3 - Drop upstreamed CVE-2014-4650-CGIHTTPServer-traversal.patch (bpo#21766)- Add python-3.4.1-fix-faulthandler.patch, upstream patch for bogus faulthandler which fails with GCC 5.- asyncio has been merged in python3 main package; provide and obsolete it - Remove obsolete AUTHORS section - Remove redundant %clean section- add %python3_version rpm macro for Fedora compatibility - add missing argument in import_failed, rename Novell Bugzilla to SUSE Bugzillapython3-idles390zp35 1733142579  !"#"%&%()(+,+./0121454787:;:=>?@A@CDCFGFIJILMLOPQRRRUUUXYX[\[^_`abcdedghgjkjmnmpqpsssvwvyzy|}|     ! #$#&'&)*),-,/0/232565898;<;>?>ABADEDGHGJKJMNMPQPSTSVWXYZY\]\_`_bcbefehihklknonqrqtutwxwz{z}~}      !"#$%3.6.15-150300.10.78.13.6.153.6.15-150300.10.78.13.6.15-150300.10.78.13.6.15   idle3.6config-extensions.defconfig-highlight.defconfig-keys.defconfig-main.defidle3.6idlelibCREDITS.txtChangeLogHISTORY.txtIconsfolder.gifidle.icnsidle.icoidle_16.gifidle_16.pngidle_32.gifidle_32.pngidle_48.gifidle_48.pngminusnode.gifopenfolder.gifplusnode.gifpython.giftk.gifNEWS.txtNEWS2x.txtREADME.txtTODO.txt__init__.py__main__.py__pycache____init__.cpython-36.opt-1.pyc__init__.cpython-36.opt-2.pyc__init__.cpython-36.pyc__main__.cpython-36.opt-1.pyc__main__.cpython-36.opt-2.pyc__main__.cpython-36.pyc_pyclbr.cpython-36.opt-1.pyc_pyclbr.cpython-36.opt-2.pyc_pyclbr.cpython-36.pycautocomplete.cpython-36.opt-1.pycautocomplete.cpython-36.opt-2.pycautocomplete.cpython-36.pycautocomplete_w.cpython-36.opt-1.pycautocomplete_w.cpython-36.opt-2.pycautocomplete_w.cpython-36.pycautoexpand.cpython-36.opt-1.pycautoexpand.cpython-36.opt-2.pycautoexpand.cpython-36.pycbrowser.cpython-36.opt-1.pycbrowser.cpython-36.opt-2.pycbrowser.cpython-36.pyccalltip.cpython-36.opt-1.pyccalltip.cpython-36.opt-2.pyccalltip.cpython-36.pyccalltip_w.cpython-36.opt-1.pyccalltip_w.cpython-36.opt-2.pyccalltip_w.cpython-36.pyccodecontext.cpython-36.opt-1.pyccodecontext.cpython-36.opt-2.pyccodecontext.cpython-36.pyccolorizer.cpython-36.opt-1.pyccolorizer.cpython-36.opt-2.pyccolorizer.cpython-36.pycconfig.cpython-36.opt-1.pycconfig.cpython-36.opt-2.pycconfig.cpython-36.pycconfig_key.cpython-36.opt-1.pycconfig_key.cpython-36.opt-2.pycconfig_key.cpython-36.pycconfigdialog.cpython-36.opt-1.pycconfigdialog.cpython-36.opt-2.pycconfigdialog.cpython-36.pycdebugger.cpython-36.opt-1.pycdebugger.cpython-36.opt-2.pycdebugger.cpython-36.pycdebugger_r.cpython-36.opt-1.pycdebugger_r.cpython-36.opt-2.pycdebugger_r.cpython-36.pycdebugobj.cpython-36.opt-1.pycdebugobj.cpython-36.opt-2.pycdebugobj.cpython-36.pycdebugobj_r.cpython-36.opt-1.pycdebugobj_r.cpython-36.opt-2.pycdebugobj_r.cpython-36.pycdelegator.cpython-36.opt-1.pycdelegator.cpython-36.opt-2.pycdelegator.cpython-36.pycdynoption.cpython-36.opt-1.pycdynoption.cpython-36.opt-2.pycdynoption.cpython-36.pyceditor.cpython-36.opt-1.pyceditor.cpython-36.opt-2.pyceditor.cpython-36.pycfilelist.cpython-36.opt-1.pycfilelist.cpython-36.opt-2.pycfilelist.cpython-36.pycgrep.cpython-36.opt-1.pycgrep.cpython-36.opt-2.pycgrep.cpython-36.pychelp.cpython-36.opt-1.pychelp.cpython-36.opt-2.pychelp.cpython-36.pychelp_about.cpython-36.opt-1.pychelp_about.cpython-36.opt-2.pychelp_about.cpython-36.pychistory.cpython-36.opt-1.pychistory.cpython-36.opt-2.pychistory.cpython-36.pychyperparser.cpython-36.opt-1.pychyperparser.cpython-36.opt-2.pychyperparser.cpython-36.pycidle.cpython-36.opt-1.pycidle.cpython-36.opt-2.pycidle.cpython-36.pyciomenu.cpython-36.opt-1.pyciomenu.cpython-36.opt-2.pyciomenu.cpython-36.pycmacosx.cpython-36.opt-1.pycmacosx.cpython-36.opt-2.pycmacosx.cpython-36.pycmainmenu.cpython-36.opt-1.pycmainmenu.cpython-36.opt-2.pycmainmenu.cpython-36.pycmulticall.cpython-36.opt-1.pycmulticall.cpython-36.opt-2.pycmulticall.cpython-36.pycoutwin.cpython-36.opt-1.pycoutwin.cpython-36.opt-2.pycoutwin.cpython-36.pycparagraph.cpython-36.opt-1.pycparagraph.cpython-36.opt-2.pycparagraph.cpython-36.pycparenmatch.cpython-36.opt-1.pycparenmatch.cpython-36.opt-2.pycparenmatch.cpython-36.pycpathbrowser.cpython-36.opt-1.pycpathbrowser.cpython-36.opt-2.pycpathbrowser.cpython-36.pycpercolator.cpython-36.opt-1.pycpercolator.cpython-36.opt-2.pycpercolator.cpython-36.pycpyparse.cpython-36.opt-1.pycpyparse.cpython-36.opt-2.pycpyparse.cpython-36.pycpyshell.cpython-36.opt-1.pycpyshell.cpython-36.opt-2.pycpyshell.cpython-36.pycquery.cpython-36.opt-1.pycquery.cpython-36.opt-2.pycquery.cpython-36.pycredirector.cpython-36.opt-1.pycredirector.cpython-36.opt-2.pycredirector.cpython-36.pycreplace.cpython-36.opt-1.pycreplace.cpython-36.opt-2.pycreplace.cpython-36.pycrpc.cpython-36.opt-1.pycrpc.cpython-36.opt-2.pycrpc.cpython-36.pycrstrip.cpython-36.opt-1.pycrstrip.cpython-36.opt-2.pycrstrip.cpython-36.pycrun.cpython-36.opt-1.pycrun.cpython-36.opt-2.pycrun.cpython-36.pycrunscript.cpython-36.opt-1.pycrunscript.cpython-36.opt-2.pycrunscript.cpython-36.pycscrolledlist.cpython-36.opt-1.pycscrolledlist.cpython-36.opt-2.pycscrolledlist.cpython-36.pycsearch.cpython-36.opt-1.pycsearch.cpython-36.opt-2.pycsearch.cpython-36.pycsearchbase.cpython-36.opt-1.pycsearchbase.cpython-36.opt-2.pycsearchbase.cpython-36.pycsearchengine.cpython-36.opt-1.pycsearchengine.cpython-36.opt-2.pycsearchengine.cpython-36.pycsqueezer.cpython-36.opt-1.pycsqueezer.cpython-36.opt-2.pycsqueezer.cpython-36.pycstackviewer.cpython-36.opt-1.pycstackviewer.cpython-36.opt-2.pycstackviewer.cpython-36.pycstatusbar.cpython-36.opt-1.pycstatusbar.cpython-36.opt-2.pycstatusbar.cpython-36.pyctextview.cpython-36.opt-1.pyctextview.cpython-36.opt-2.pyctextview.cpython-36.pyctooltip.cpython-36.opt-1.pyctooltip.cpython-36.opt-2.pyctooltip.cpython-36.pyctree.cpython-36.opt-1.pyctree.cpython-36.opt-2.pyctree.cpython-36.pycundo.cpython-36.opt-1.pycundo.cpython-36.opt-2.pycundo.cpython-36.pycwindow.cpython-36.opt-1.pycwindow.cpython-36.opt-2.pycwindow.cpython-36.pyczoomheight.cpython-36.opt-1.pyczoomheight.cpython-36.opt-2.pyczoomheight.cpython-36.pyczzdummy.cpython-36.opt-1.pyczzdummy.cpython-36.opt-2.pyczzdummy.cpython-36.pyc_pyclbr.pyautocomplete.pyautocomplete_w.pyautoexpand.pybrowser.pycalltip.pycalltip_w.pycodecontext.pycolorizer.pyconfig-extensions.defconfig-highlight.defconfig-keys.defconfig-main.defconfig.pyconfig_key.pyconfigdialog.pydebugger.pydebugger_r.pydebugobj.pydebugobj_r.pydelegator.pydynoption.pyeditor.pyextend.txtfilelist.pygrep.pyhelp.htmlhelp.pyhelp_about.pyhistory.pyhyperparser.pyidle.batidle.pyidle.pywidle_testREADME.txt__init__.py__pycache____init__.cpython-36.opt-1.pyc__init__.cpython-36.opt-2.pyc__init__.cpython-36.pychtest.cpython-36.opt-1.pychtest.cpython-36.opt-2.pychtest.cpython-36.pycmock_idle.cpython-36.opt-1.pycmock_idle.cpython-36.opt-2.pycmock_idle.cpython-36.pycmock_tk.cpython-36.opt-1.pycmock_tk.cpython-36.opt-2.pycmock_tk.cpython-36.pyctemplate.cpython-36.opt-1.pyctemplate.cpython-36.opt-2.pyctemplate.cpython-36.pyctest_autocomplete.cpython-36.opt-1.pyctest_autocomplete.cpython-36.opt-2.pyctest_autocomplete.cpython-36.pyctest_autocomplete_w.cpython-36.opt-1.pyctest_autocomplete_w.cpython-36.opt-2.pyctest_autocomplete_w.cpython-36.pyctest_autoexpand.cpython-36.opt-1.pyctest_autoexpand.cpython-36.opt-2.pyctest_autoexpand.cpython-36.pyctest_browser.cpython-36.opt-1.pyctest_browser.cpython-36.opt-2.pyctest_browser.cpython-36.pyctest_calltip.cpython-36.opt-1.pyctest_calltip.cpython-36.opt-2.pyctest_calltip.cpython-36.pyctest_calltip_w.cpython-36.opt-1.pyctest_calltip_w.cpython-36.opt-2.pyctest_calltip_w.cpython-36.pyctest_codecontext.cpython-36.opt-1.pyctest_codecontext.cpython-36.opt-2.pyctest_codecontext.cpython-36.pyctest_colorizer.cpython-36.opt-1.pyctest_colorizer.cpython-36.opt-2.pyctest_colorizer.cpython-36.pyctest_config.cpython-36.opt-1.pyctest_config.cpython-36.opt-2.pyctest_config.cpython-36.pyctest_config_key.cpython-36.opt-1.pyctest_config_key.cpython-36.opt-2.pyctest_config_key.cpython-36.pyctest_configdialog.cpython-36.opt-1.pyctest_configdialog.cpython-36.opt-2.pyctest_configdialog.cpython-36.pyctest_debugger.cpython-36.opt-1.pyctest_debugger.cpython-36.opt-2.pyctest_debugger.cpython-36.pyctest_debugger_r.cpython-36.opt-1.pyctest_debugger_r.cpython-36.opt-2.pyctest_debugger_r.cpython-36.pyctest_debugobj.cpython-36.opt-1.pyctest_debugobj.cpython-36.opt-2.pyctest_debugobj.cpython-36.pyctest_debugobj_r.cpython-36.opt-1.pyctest_debugobj_r.cpython-36.opt-2.pyctest_debugobj_r.cpython-36.pyctest_delegator.cpython-36.opt-1.pyctest_delegator.cpython-36.opt-2.pyctest_delegator.cpython-36.pyctest_editmenu.cpython-36.opt-1.pyctest_editmenu.cpython-36.opt-2.pyctest_editmenu.cpython-36.pyctest_editor.cpython-36.opt-1.pyctest_editor.cpython-36.opt-2.pyctest_editor.cpython-36.pyctest_filelist.cpython-36.opt-1.pyctest_filelist.cpython-36.opt-2.pyctest_filelist.cpython-36.pyctest_grep.cpython-36.opt-1.pyctest_grep.cpython-36.opt-2.pyctest_grep.cpython-36.pyctest_help.cpython-36.opt-1.pyctest_help.cpython-36.opt-2.pyctest_help.cpython-36.pyctest_help_about.cpython-36.opt-1.pyctest_help_about.cpython-36.opt-2.pyctest_help_about.cpython-36.pyctest_history.cpython-36.opt-1.pyctest_history.cpython-36.opt-2.pyctest_history.cpython-36.pyctest_hyperparser.cpython-36.opt-1.pyctest_hyperparser.cpython-36.opt-2.pyctest_hyperparser.cpython-36.pyctest_iomenu.cpython-36.opt-1.pyctest_iomenu.cpython-36.opt-2.pyctest_iomenu.cpython-36.pyctest_macosx.cpython-36.opt-1.pyctest_macosx.cpython-36.opt-2.pyctest_macosx.cpython-36.pyctest_mainmenu.cpython-36.opt-1.pyctest_mainmenu.cpython-36.opt-2.pyctest_mainmenu.cpython-36.pyctest_multicall.cpython-36.opt-1.pyctest_multicall.cpython-36.opt-2.pyctest_multicall.cpython-36.pyctest_outwin.cpython-36.opt-1.pyctest_outwin.cpython-36.opt-2.pyctest_outwin.cpython-36.pyctest_paragraph.cpython-36.opt-1.pyctest_paragraph.cpython-36.opt-2.pyctest_paragraph.cpython-36.pyctest_parenmatch.cpython-36.opt-1.pyctest_parenmatch.cpython-36.opt-2.pyctest_parenmatch.cpython-36.pyctest_pathbrowser.cpython-36.opt-1.pyctest_pathbrowser.cpython-36.opt-2.pyctest_pathbrowser.cpython-36.pyctest_percolator.cpython-36.opt-1.pyctest_percolator.cpython-36.opt-2.pyctest_percolator.cpython-36.pyctest_pyparse.cpython-36.opt-1.pyctest_pyparse.cpython-36.opt-2.pyctest_pyparse.cpython-36.pyctest_pyshell.cpython-36.opt-1.pyctest_pyshell.cpython-36.opt-2.pyctest_pyshell.cpython-36.pyctest_query.cpython-36.opt-1.pyctest_query.cpython-36.opt-2.pyctest_query.cpython-36.pyctest_redirector.cpython-36.opt-1.pyctest_redirector.cpython-36.opt-2.pyctest_redirector.cpython-36.pyctest_replace.cpython-36.opt-1.pyctest_replace.cpython-36.opt-2.pyctest_replace.cpython-36.pyctest_rpc.cpython-36.opt-1.pyctest_rpc.cpython-36.opt-2.pyctest_rpc.cpython-36.pyctest_rstrip.cpython-36.opt-1.pyctest_rstrip.cpython-36.opt-2.pyctest_rstrip.cpython-36.pyctest_run.cpython-36.opt-1.pyctest_run.cpython-36.opt-2.pyctest_run.cpython-36.pyctest_runscript.cpython-36.opt-1.pyctest_runscript.cpython-36.opt-2.pyctest_runscript.cpython-36.pyctest_scrolledlist.cpython-36.opt-1.pyctest_scrolledlist.cpython-36.opt-2.pyctest_scrolledlist.cpython-36.pyctest_search.cpython-36.opt-1.pyctest_search.cpython-36.opt-2.pyctest_search.cpython-36.pyctest_searchbase.cpython-36.opt-1.pyctest_searchbase.cpython-36.opt-2.pyctest_searchbase.cpython-36.pyctest_searchengine.cpython-36.opt-1.pyctest_searchengine.cpython-36.opt-2.pyctest_searchengine.cpython-36.pyctest_squeezer.cpython-36.opt-1.pyctest_squeezer.cpython-36.opt-2.pyctest_squeezer.cpython-36.pyctest_stackviewer.cpython-36.opt-1.pyctest_stackviewer.cpython-36.opt-2.pyctest_stackviewer.cpython-36.pyctest_statusbar.cpython-36.opt-1.pyctest_statusbar.cpython-36.opt-2.pyctest_statusbar.cpython-36.pyctest_text.cpython-36.opt-1.pyctest_text.cpython-36.opt-2.pyctest_text.cpython-36.pyctest_textview.cpython-36.opt-1.pyctest_textview.cpython-36.opt-2.pyctest_textview.cpython-36.pyctest_tooltip.cpython-36.opt-1.pyctest_tooltip.cpython-36.opt-2.pyctest_tooltip.cpython-36.pyctest_tree.cpython-36.opt-1.pyctest_tree.cpython-36.opt-2.pyctest_tree.cpython-36.pyctest_undo.cpython-36.opt-1.pyctest_undo.cpython-36.opt-2.pyctest_undo.cpython-36.pyctest_warning.cpython-36.opt-1.pyctest_warning.cpython-36.opt-2.pyctest_warning.cpython-36.pyctest_window.cpython-36.opt-1.pyctest_window.cpython-36.opt-2.pyctest_window.cpython-36.pyctest_zoomheight.cpython-36.opt-1.pyctest_zoomheight.cpython-36.opt-2.pyctest_zoomheight.cpython-36.pychtest.pymock_idle.pymock_tk.pytemplate.pytest_autocomplete.pytest_autocomplete_w.pytest_autoexpand.pytest_browser.pytest_calltip.pytest_calltip_w.pytest_codecontext.pytest_colorizer.pytest_config.pytest_config_key.pytest_configdialog.pytest_debugger.pytest_debugger_r.pytest_debugobj.pytest_debugobj_r.pytest_delegator.pytest_editmenu.pytest_editor.pytest_filelist.pytest_grep.pytest_help.pytest_help_about.pytest_history.pytest_hyperparser.pytest_iomenu.pytest_macosx.pytest_mainmenu.pytest_multicall.pytest_outwin.pytest_paragraph.pytest_parenmatch.pytest_pathbrowser.pytest_percolator.pytest_pyparse.pytest_pyshell.pytest_query.pytest_redirector.pytest_replace.pytest_rpc.pytest_rstrip.pytest_run.pytest_runscript.pytest_scrolledlist.pytest_search.pytest_searchbase.pytest_searchengine.pytest_squeezer.pytest_stackviewer.pytest_statusbar.pytest_text.pytest_textview.pytest_tooltip.pytest_tree.pytest_undo.pytest_warning.pytest_window.pytest_zoomheight.pyiomenu.pymacosx.pymainmenu.pymulticall.pyoutwin.pyparagraph.pyparenmatch.pypathbrowser.pypercolator.pypyparse.pypyshell.pyquery.pyredirector.pyreplace.pyrpc.pyrstrip.pyrun.pyrunscript.pyscrolledlist.pysearch.pysearchbase.pysearchengine.pysqueezer.pystackviewer.pystatusbar.pytextview.pytooltip.pytree.pyundo.pywindow.pyzoomheight.pyzzdummy.pyidle3.6.desktoppython3-idleChangeLogNEWS.txtREADME.txtTODO.txtextend.txthicolor16x16appsidle3.6.png32x32appsidle3.6.png48x48appsidle3.6.pngmetainfoidle3.6.appdata.xml/etc//etc/idle3.6//usr/bin//usr/lib64/python3.6//usr/lib64/python3.6/idlelib//usr/lib64/python3.6/idlelib/Icons//usr/lib64/python3.6/idlelib/__pycache__//usr/lib64/python3.6/idlelib/idle_test//usr/lib64/python3.6/idlelib/idle_test/__pycache__//usr/share/applications//usr/share/doc/packages//usr/share/doc/packages/python3-idle//usr/share/icons//usr/share/icons/hicolor//usr/share/icons/hicolor/16x16//usr/share/icons/hicolor/16x16/apps//usr/share/icons/hicolor/32x32//usr/share/icons/hicolor/32x32/apps//usr/share/icons/hicolor/48x48//usr/share/icons/hicolor/48x48/apps//usr/share//usr/share/metainfo/-fmessage-length=0 -grecord-gcc-switches -O2 -Wall -D_FORTIFY_SOURCE=2 -fstack-protector-strong -funwind-tables -fasynchronous-unwind-tables -fstack-clash-protection -gobs://build.suse.de/SUSE:Maintenance:36642/SUSE_SLE-15-SP3_Update/df6e32a377fdd10600dff632973ed625-python3.SUSE_SLE-15-SP3_Updatedrpmxz5s390x-suse-linux   directoryASCII textPython script, ASCII text executableUTF-8 Unicode textASCII text, with very long linesGIF image data, version 89a, 15 x 13GIF image data, version 89a, 16 x 16PNG image data, 16 x 16, 16-bit/color RGBA, non-interlacedGIF image data, version 89a, 32 x 32PNG image data, 32 x 32, 16-bit/color RGBA, non-interlacedGIF image data, version 89a, 48 x 48PNG image data, 48 x 48, 16-bit/color RGBA, non-interlacedGIF image data, version 89a, 11 x 11GIF image data, version 89a, 16 x 13GIF image data, version 89a, 14 x 11python 3.6 byte-compiledHTML document, UTF-8 Unicode text, with very long linesDOS batch file, ASCII text, with CRLF line terminatorsPython script, UTF-8 Unicode text executableXML 1.0 document, UTF-8 Unicode text  !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~RRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRPPPPPmyW78:Qlutf-86c98264518ca83c47777f4e62f7f4e83e5711c0bb0a2574d2d32a57a38804766?7zXZ !t/~'K]"k%a ~SРQi0! (d~Տo)Vѳ1P7[|`|>̤aJ ; ȣP &~.?qR:;2L{e=)CP i7ӐCT!(U.Jk5%g9k b2|DVwaHzpD\6K (tgĻ|F$Wz#'ۦ\8 >~~Xcxs %! ZmK$. Z V/[x'"F71o-i:q;6i`I1qJ@rdFa3'&l_(ax-|YSH }>2\/u`jrAwFt1G6UGTdZ>MzUa_$,Ԑg!:mtd>Cc棵?5ZM[ᄼ"ӕz^! E3JU8"H./)_^"j!')fryat? !hrT>SD UϨ b1Me]77wX;6V -ffln0~:  ѺV4uZ" mW%s7; <*+JzcDʦMC}{e!Ne?D6c;>{1W:ǻ>T<1}FC H_Җfh̴ݧ3تY0{)PEՁP: )2|wX`-H5$Ƈ)$8{6Jkje^MYY־Q比`tc[1k9͗ZK֘zDEPGQDBG&\:~4!"jvAP|rV5-gbkKP%> i?V"Ǭ>#<yR(N9Ej5\I] r&Ox9a }^}Q (p7jzVK,DANiF} HX3u)@{ )WMlP4ʢk } Z oy±(6V~ ,{X\#h9aQʖ@O90t [(nЉ[jf\_g sz0YRo-\ze+6*84CBF:.ڛ59jTm<0R%>&5`@Pq'{țV=+HJygo/>69$0ܪ0X%*ANKP }΄+e J2Ɨg<\I zxZ?oPv\֏|%h +bć ܃?sTQb# A؍J!rQrB@Y5SM:Ȟ \2v0L;k>g!4Jу gFjL_q9"# F<&M"\a}Ұnb6ݎHLd96ru~ZϪ,$$m[ 翭b0vJ-IxL $fހ hF݂//DYNAH6C=GJ˕l7 @y54 xJTB61E54O?Wtʠ焽{ SτFlf̸bGU9 70K;8,5lceк(u?藅9C1?:*Ǜs e<ҬEيaP_27zݖi.B{3Xԙ 6^)q*nqZQ4|dH *e]g|YbC@ *\C_ Q_M!),ΨzKPTh0:kqy&Ӹ ~ Q}iZ"pwB4`tsqݤ94 sЯ]Ffڏ! %7UW-0s6N Ds3f:,>xPv}NeNe}gkfKr7+^}gF˒ =9)e 4ٶQ*_"_0Бb"rѿ=/׋SuŸr~ĆvNtn%~ a[' 2&ܦ>1Hdae{Js sKSj~fsܕt2LoPliL3H 32 .반]q':1`R=kr*L}AkޖSL"z[orrҥ|mYv+}C*AtHۯ/] ll0719?~C jz(dZE[;Ԟ8T"M4v;ɾ-U hatӌ}}.v/ 6[\ቪR:6`P hWkw5=w{ ɒ혥3fJZ4,T^ G]ũeߐ#|Bϐc.wo~1?q%m;^1HpKLPboun]kMip])L;X!oq] r(\N{kH3vU Ų<[9ε6J2Ġ/Wke4<Ђ͜3nscʪT ^kH/? k,Xi:@ ̦.h(N5Za ?a(@Y6Ŵa-6F`~ dMfc3:+ r %OlzLbEoP jMՄW<3jJ8ဦH$8d'V$˒Iffe@!wke&{AM &aj֢0] Wb4]&t4 U޿* z;|30ahsn/v+\3~hiae(3y>:ex k5s8nȽ2"^>3kS/A L<ֵF_LÀxn&gӚ~3={X{hN J^:IS;)_|$[ cBZKVԯ!Fv?zomm2*җA*TVd!`׍-b_cIlE MrC_&w:ڵ$MK'Dz}O@۽ҝ-@C?%IqY*ZFRk5rf8CJd77pT.O݄rf7;2bSw@p4ź y'MVr-AIZ).Wwe`4n:+bP3&n &I;egC6lQv+LgW7QrKzgz%;0'Qj]3e:urPGFviXtUyHp%$)u=vCe}#59x&W`W0 )< =aN-q`j eIôp7e.rxHD=lQ *xL ͡; 93E5,K憎d8lNWǸV9HQ\~I:faT.a(-jK8qTpw>c`e:C[m1 U;V GfZs"ɧs*o̅tWqyԥckeG<_r|۵c lc=mjRGQ,Z Ԍ1TczEcEY-}'Y:2Na\ki&rUYZt<|Q7B|wh A\*|Q{5Ydyߺ/ڂ } x9k,Oٳ&"P0+x/b֗K u'::01aݹRoJYAq^EnL҃tkJ@Ʃ[}w 3(R3rH)>T˞(}dk>)C| #"!f_!%Ӵa'kiLDyMQn} t`|R.U84[2wθd|UǠe$T F_PK_s*0Jn|9]E:@=?I"W'jvڸLW4uZ7XGG9^eM~irNԢ*OCi'> E@/9 mv62WU?!(eyȃ13KTGd+x퓖U&% ۲ 7TzD\MjX9E ^Vn62JdJo ہrGa hmDoHd--wᤓtrXyZ :l\Ai@G٠".a7|hI8 ~w=Nu@B eO3:@ ~uãirU/?1mjv i~ͰB=gTԎm:iK/!$J). &; P3bмfގ3y$O8U^]|xצؽd ex ^S 8ahLAKy} o ;.V_ r4Ґ8ɽȃ0Q4D33̱-wH 'FR|ISwK /n=AL+*䊸+ lP{>5=ökĵƮrn"|-rR} W*N]VWmE|47MeH$4lV/tL-$Z8J $=i.g׏wduf,iY~82]i+|n{WP p5$YvM|dy {W5V !l+v0Nd #O33`<15ǐHzCnzk6^~xo̓dLi$6~R]XDMkoXCvȣFz#wƞWJPҀ.{NV35Ua+:a(.A9C|;Zulswԍq?i/77(1³=ˑ$*h6k8"WZ~h3ם}9ga+8jd?a-dXssIy lSw'P/V-;M&P%銢tI`DQ'&{&ATjbFD|' 0(pwմ/*<%o^CYc&EɋyP2}&hmL +s!47= `_{%0;̖_o~mqg{ο6X!WN~M@GTk Ϣ޼{*|e_<ޯH^ULKƚ/䨙?v)!ۀȈ,{q2Ґx$Q+6m{dȃ5tx0M!@tJA!opN(D/F!A@^TMJٟ`QrO)3hmq [3zM: ТގjHK]@Nءjᆟ;W6u2edo SP0yZ$o%NTZp=ץy!VZ3%.q蓜~mkг rql+ t9$?^x/(3i\'}sT#cTO1[5NUnSF"J=ކe24)&)q է 4)P DgJzr; {GYJ1ږ űzo`v[&Wȇ{kKGJff{x:Bt"l$&sCAiTMmQ6V5B~:zT˄zO<ȲE5ۡ`sX56305 y}nNljuWTV3tI)N?g: }@:r=w]Bx +՗He'[KP9޳MߦwSWf_Za*@YA#*޺W5SFq µi" ްbm$ g*SB) A9+CX6)N0n\lQko)ʎ7 }xG,`^cf,; hFrwdBzFKz!$ Z\B#{F%ļ7'K d[5!XԷY-k噑=}w ѷ#6pIg+>|zʇD^S&G%fɌ!9`R:u~3dݸiZ5S;/A;bdmH"l"Hncn_[q9"ҭJollo)nj|Go$r nF5Qy.~l!>fLD SJ.FCq+1ڬ^Yn7XvV`Tճt"Eyf` ݔy.2U}2ҟ :k*tpcYqP`6EghJymF̻M{-%&LvMma&vFަ|1+ū=V}nxXw/ɬ=~iVfnb`̧=OG2Qi!M y.)h;ο=XG )}ThwaC- q̸ XՃto#r@~*ܓUwY^&&@*= c~`{  )?֫[i[2 @z#bR%tIjG1uhY k @}Y)$VGu r*ȋu$L( z^KNo-#23!˺՜􎸅mS8'჊ ɚuFRwM/xb^dk(viQL M_kޣ@bU( 4{6]N@pgۿY~[ zwk; ^c2ykmh.BPd m ʥ\>{yyۑi#GƂF=Ƌy` ʒ[j \%ͻKu&c|CG E9S_sȬNP9qZq%nJ02:rgiԉ ăs]ѬcVb6pByt#h W֍R81P!-+SXxaCF! ݬaɇT6f)?^Z/ZR0L[:](꧰#ʼnۂcI#7*O<zo MdOf13d|d!d^v6-9K(Tc wn'x91x&ͰKej}nsCw̅d=5pmߚ v'Mk,)5@DrTshPX _o;*ǚB:ES.jO.  Y4edtaaTw\(&/ :zQ~sڒ0=Vt}WBLA"OSh[WH z@CRd[=jw rVbzmC:bo/Up?bSsX] `p#Cl2 *gy!e*KNDP'.#e88Z': 쀬Wf.[wѻXփH}$ MBQq%_VM2fFTX4\YgIQ%PL,Q?@{'w2_ɞ7ֵ[V[UW~^Y3>~?"{ώ)l8C+Nh{4(=elBEjL * O7/cn@%Ȫ틔Ȇ`#w]-)0Eh#ܸ n0bw9幫q'p] =IoL8oJe2f#Nk YZ