python-2.7.18-150000.105.1<>,yiSp9|ر_0>O4fV/*6OGƏ2]n5湕HU< S{a/H!*:tppDѣ)S7en2+d/<6Q#! NC3 se <bG+ | D5JZdn_@m;[]|uˉr/+0*XE3xrH޲ ]uvF@Jg5KuryĕJJ]W#hƮ|656pKHC*N|EL9,1̹TJY1u5r>C?d   0  (@FP    | . /01477::T:<(<8<~9>~:G(~>@ BFSGlHI4XYZ[(\,]^ bc~defluvx w(xЌyzըոռCpython2.7.18150000.105.1Python InterpreterPython is an interpreted, object-oriented programming language, and is often compared to Tcl, Perl, Scheme, or Java. You can find an overview of Python in the documentation and tutorials included in the python-doc (HTML) or python-doc-pdf (PDF) packages. If you want to install third party modules using distutils, you need to install python-devel package.iSibs-power9-21SUSE Linux Enterprise 15SUSE LLC Python-2.0https://www.suse.com/Development/Languages/Pythonhttps://www.python.org/linuxppc64le>t00 PP,CII-&22x__K [[L ``=IPPFF;&M"M"66U c c"R"RK#WW g g g-77;-- ""& w w D D `**@@  "/mmOD==BB>$;;>p&>H v n -8<<7&& <JAJA:OO;`X`X ==10AA큤A큤AA큤A큤A큤iSiSi@iSiSi@iSiSi@iSiSi@iSiSi@iSiSi@iSiSi@iSiSiSi@iSiSi@iSiSi@iSiSi@iSiSi@iSiSi@iSiSi@iSiSi@iSiSi@iSiSi@iSiSi@iSiSi@iSiSi@iSiSi@iSiSi@iSiSi@iSiSi@iSiSi@iSiSi@iSiSi@iSiSi@iSiSi@iSiSi@iSiSi@iSiSi@iSiSiSiSiSiSiSiSiSi@iSiSi@iSiSi@iSiSiSi@iSiSi@iSiSi@iSiSi@iSiSi@iSiSi@iSiSi@iSiSi@iSiSi@iSiSi@iSiSi@iSiSiSiSiSiSfd6c6e5b098ade0aa1b123b2963e56728eb3619754881baff7fb10fb165becdb6dfff73f3f0322974e3a6847a7cf745b6d5b029baff7abd2cbcd9e2ebfc6ea546dfff73f3f0322974e3a6847a7cf745b6d5b029baff7abd2cbcd9e2ebfc6ea54abd3f646419f3a33f64814342bb894047bfda3ec695286aa2b07e340700f733f26bf0c4e0e1751e3ba71b37cbd6134948235ee56b2ff6f4cabf7ac2d1c36544926bf0c4e0e1751e3ba71b37cbd6134948235ee56b2ff6f4cabf7ac2d1c365449fa3f60506840cc9f608d660fcd6265dbb22b53362a4bfdd98cd9c9887692730818fd94da93fe94cc80085b5c1685bf3210d9da970a8704ed3f438e0ad4b2b2b518fd94da93fe94cc80085b5c1685bf3210d9da970a8704ed3f438e0ad4b2b2b5046a34799e33a47832a21f34ded777c64616710f52cc75e7116796442c05cd4342394f89571d9e48d0d704cc1131368dea5d08004efee56ba8a2f395a2d6f79342394f89571d9e48d0d704cc1131368dea5d08004efee56ba8a2f395a2d6f793228a008dd77f0bfe90718c9577fab61ef96b7adb4e608c5492385cea0c206e2d8d851718ce70461eaa1a2daf41129cd74b38402d9f4cc579bc6b718394281f538d851718ce70461eaa1a2daf41129cd74b38402d9f4cc579bc6b718394281f53b708a282a1e9d211cccbdcc194ec3c6f8894a7e9ae003806b933f2c0cbde5f23475dd76901ff74eb8ae6596318035c4de3acf0db6a59623d077758f4bfe49ef1bbf29fe3043fd5d69b09e9407a507fe1bbf6428e1f3f288a23edc75a5b3387baaf71194b97feb43ce6583f4f2fe8f894d8df89b2565bff32daecc7c42f7b0eef7bf4838069973ef788231c7e0452396fd79e411d5d6236aa01c74676d37e17f87bf4838069973ef788231c7e0452396fd79e411d5d6236aa01c74676d37e17f8e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855754e1731a5cecc076a80eace8bb493935bb8f84c21685795308862128fbdfbcb754e1731a5cecc076a80eace8bb493935bb8f84c21685795308862128fbdfbcbdf8c414bcf1679eec7aa0bff235cdf98829730da9b75ad50baa432b7ee87d2e40571cc7e196ff19773e87389842f1478f94f94e5469e54513df1ff4a990ad57e0571cc7e196ff19773e87389842f1478f94f94e5469e54513df1ff4a990ad57eb379c1e0ea1bc3db50745e3700fbd617b58424ce07f96dae45ab79ddc56d7b305e61b79b7748448060b07b8f45c2fdb42e355a9707bc2ea7cda4e7d0aab7db615e61b79b7748448060b07b8f45c2fdb42e355a9707bc2ea7cda4e7d0aab7db617b22ab3d374af60bb0eb9693c736e502b0e530263916c416611fe5ee8790e3cc282e81a05fb4ab0d9be2e29884f8083a556f6b9306fb2fd227a137a3637d923c282e81a05fb4ab0d9be2e29884f8083a556f6b9306fb2fd227a137a3637d923c2b29f5758fb7a2b3e876794c563b53aaebb88529ea40c6374975be54f83237b8782f8f25349c3256b21b735cd03ee8c4f4c3aebdac3356f7410fa83c70584155782f8f25349c3256b21b735cd03ee8c4f4c3aebdac3356f7410fa83c70584155cc530147bfd552b8ea9c2613f7956de578196a3129b01d73ff50925094af826bd4ed6110e0eecfbe4b3da675a8f9da3a817fb94db7874e72c10f88b21b709064d4ed6110e0eecfbe4b3da675a8f9da3a817fb94db7874e72c10f88b21b70906489bbcb75081406a2dd0d728e09138a21f469634cf7aef1e5c55f2779a9a6b76370d260d0083bb81defde696e4ac80255c9cfac5731bb02ba80a632b1b74071f970d260d0083bb81defde696e4ac80255c9cfac5731bb02ba80a632b1b74071f908cca8469491cfead102a6bef69be1afab7529e129001a4ffb31433766a4335d07f207a01eae7be0659467111db5ff90d1952d59b328dbc4d35b6127682a842d07f207a01eae7be0659467111db5ff90d1952d59b328dbc4d35b6127682a842d3f207cd262365b5c64246a76caf4fe319255eb83493a0985976607440c2c19e5739cf96a7ad72b72ebc6e8ed98eac3891bf428745312b3551533c54fe637a95f739cf96a7ad72b72ebc6e8ed98eac3891bf428745312b3551533c54fe637a95fef974db90bc549f14427a792ccfd7c6bdade19f281a679e2197cb18f3b13a811ca10b32397972a80f6cd10845a0e10fd2df62f454be477636e5afc07b5687845ca10b32397972a80f6cd10845a0e10fd2df62f454be477636e5afc07b5687845c6ddc76661905a142bb489e72a19bb3c4ec045b4193656518acd4430f8ecbbdcb13ab954ab54a14dcaba71cbdd6414d5dc52ef88d3989ff500bc770a72cb954db13ab954ab54a14dcaba71cbdd6414d5dc52ef88d3989ff500bc770a72cb954d4e721a412fd4561c75485a1c4cf11262aa5d82bc68bd5d984629b62b398221d485ef0421afb29d2c6f85e7469d751e2446db41a6106d1122b5ef4d644c500f9b85ef0421afb29d2c6f85e7469d751e2446db41a6106d1122b5ef4d644c500f9bc622e4e53e332adaeb9a9ecd06f109c319be5146eb7de4b95c8bedc72cd819fae882116d5e4e5b7364f705bdf146505dd4eb9c7feae610d51e310043001d3d32e882116d5e4e5b7364f705bdf146505dd4eb9c7feae610d51e310043001d3d3283f7d09faa6a85a2cfe48f30e75252019da7356c97f5ff8a50a3db246c55dcfff98cc2d4fb920a7314ca850271ce7fcb149f78cfa25efe01cd2ea3bb711819edf98cc2d4fb920a7314ca850271ce7fcb149f78cfa25efe01cd2ea3bb711819ed832dd1a240df8ab4bb34d8f2597591f614a5312faa4a867e287ad4c7bf29980837593486bb1883192fc919ca271a7bb36e85105d3ee8cfa158620c6b6599035a37593486bb1883192fc919ca271a7bb36e85105d3ee8cfa158620c6b6599035a6ff2b127c2698dc1384dedb8b99c70d305bf7511cd9a51be1a98c8c97fd23d6994afccbeae832a3c8b7047f940cfcbcfc3615674d701597b028e31ebec08642994afccbeae832a3c8b7047f940cfcbcfc3615674d701597b028e31ebec0864291c57c2ca2176e7d7b88e983a86cc904d22f480ccf5f124a213728b51a961e9438fe89f6dfba31b03f68e819412e25bfc6d612a0af887fa5614e676d2244e55448fe89f6dfba31b03f68e819412e25bfc6d612a0af887fa5614e676d2244e554420a74746b7619ff8dc09a2538bef118bfcf001908524d77d9dc8d831a19f03c9d59853329e0429b158d16437576d01db29bb6cddf3a015fa9c172310b45bde59d59853329e0429b158d16437576d01db29bb6cddf3a015fa9c172310b45bde5999be4f02902c038f1558b7cb9524bc4b42a6564fa6616f070b718b905ddfe62d2fbfbf843e0d4f8097f440dca0fe30d69f63680cae69dd66c18222dc58f6fc682fbfbf843e0d4f8097f440dca0fe30d69f63680cae69dd66c18222dc58f6fc6865f3f64e35c9db4f85672bf2193f645ab2ea2d3649bb28eba5d83e6a3f804d4fbc018f98f8582a5a8ff8e6ae3e43efb6172935d113b704fb2ae1b0af07531789bc018f98f8582a5a8ff8e6ae3e43efb6172935d113b704fb2ae1b0af075317895915ab9ffdfa1e5299c7512175011a7ced2bc924970de1eee645bc3943c482a0c442a53b83901095f3e55527e6e0f180b107d8ed883a6e9690a47dea1449d2b9c442a53b83901095f3e55527e6e0f180b107d8ed883a6e9690a47dea1449d2b9cb65b79ad7a67f67fc49cd170648d9e2a4dd7cd72cf4a013a032f680bc2cb738bcf9967386d58747fcf585bfe11f12977a0cc7382461ba00e4267c70da502bd1bcf9967386d58747fcf585bfe11f12977a0cc7382461ba00e4267c70da502bd1f97b0df5f745f51f764634e3c0965295f2d1643d12ad8a94ba0e1a32301d390f374c5d06f847ac76c29d87d1c76b9c70f99eb63ae0fdd091eadd09402ea55669374c5d06f847ac76c29d87d1c76b9c70f99eb63ae0fdd091eadd09402ea556694f05568dd9fa927ef7f6e7b0189567e3d46b8a70a6f9eedee80d2eeab7fda7ce87bd188b39363dcbc2079ae5c41ec8e0564b3ba74552f7db2a7c7434883907a887bd188b39363dcbc2079ae5c41ec8e0564b3ba74552f7db2a7c7434883907a8e3850d1a493b6b958e2bd9f66ec8b62a0d72ebb7c3eafcb83cfddf4faf920dd28759ad5feeddc05746f8b137a22cef83094bd69c1b3dc8bdf9d50db5646380b58759ad5feeddc05746f8b137a22cef83094bd69c1b3dc8bdf9d50db5646380b536ca850f377c9af2a8367424602b2ae3be3c577f3f7772777818e750a066c0fa3febf58543131660457edb01b12884e6049a9eed419e88fe0b70d0bff8be3d058dde755acd95e1fee01ea43ddb50a3e086d8ddb5f2718df42cbb62893d31e4d456533aefa40cc3324bc7609edc18569a56c86c428cbea083d6a5df8f682083ffcdb24f90703065dfcc3e6325326449becb253ca701b15a16f6286a31f5d5d9e1a57e80b8a0d16549b7a466ef3585bc8f13c1983dcf13845b22be1a748be3a0e66edac194025cc19b82e522c50b478303e6972be15c485cc2bf98fc978c9714026edac194025cc19b82e522c50b478303e6972be15c485cc2bf98fc978c9714025186810c169e033eae41c2010a89c982276999b94f1d4cebc5b9267f8e97ab70115d15f0fb4642f75e2ab702232c3eff21bd984fef881863766ae1137799f365115d15f0fb4642f75e2ab702232c3eff21bd984fef881863766ae1137799f3654268c68294b00b82adc2dba7e600310cb45c468e5780aff2455eb8103d21d2825161274bc978697cbe5477cde7ad52c6c538f832bfe85f9fdbb79d2e6e9925985161274bc978697cbe5477cde7ad52c6c538f832bfe85f9fdbb79d2e6e992598e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855d6adc572b8b523aa76eb7b7cfac382876e2a466ee6b5488a6463bc0e0464c94dd6adc572b8b523aa76eb7b7cfac382876e2a466ee6b5488a6463bc0e0464c94d47532d524864d6ad2aa109f05f7bf77b68d48772fe421efb29605e23bad8ddc0e12db7b2584bde33d5fb89f27ed9f11efe4912c212ed342ead57911dc338af3575dd3d78e12882194157110c42715122fcdb08953207781ad192973a146524b9b86371d3fc23f7b32d2c4fd4728e91ad1dc0fa95f253ee27fad4ba9025cd8a9f718f1c545d09f021d523262ea0488f78bf0d35df301b3305e567cc34af8b4d38718f1c545d09f021d523262ea0488f78bf0d35df301b3305e567cc34af8b4d3837b4cb47babf65937b399f9dbc7fca98c3bf0528f3f0de63e3774c4326bf7875e159cac436d318ebae942f57d18dd45f60dd328fb4ff82f9f43c0cdf4278d3f8e159cac436d318ebae942f57d18dd45f60dd328fb4ff82f9f43c0cdf4278d3f87d9827fec848c29932e32465e761271475a0edca1ea0b4f2961e6d4521c632f326fbe041ad3bb875c4ab9036142da89e6815b8a3c0f89ab1c5d46349c4321b7f26fbe041ad3bb875c4ab9036142da89e6815b8a3c0f89ab1c5d46349c4321b7fe10c9954f20298e5ba4d7a6628b9df60f8ae907e9a7336293330f2fbdc81e137b0769fbeb0cc4f343bef687b49953dc55bea0901f44cfaf8f026ae070e9b4ab0b0769fbeb0cc4f343bef687b49953dc55bea0901f44cfaf8f026ae070e9b4ab000b137ea0cd5d5bced4ad9b4c0665a83efc3b3039756eb11dce285a65fd23b0f784d3e68aa5639a2e90e5fff6745d217152b6fc0a5ffeb1b94c9f42f0cdd9740784d3e68aa5639a2e90e5fff6745d217152b6fc0a5ffeb1b94c9f42f0cdd97407e90a937b6d21b59029d2b66b1276eed2451d5f5bdd115aa9b16175b581be43a7cf58ad69eda9d341114d9a1f06adf91746ad5dfc2969cd64b9508a41a7ea2047cf58ad69eda9d341114d9a1f06adf91746ad5dfc2969cd64b9508a41a7ea20416da7063b627f6ba101642ee6a3e8814fa88b3ab1912bad182e72caf48e85d87f6d678b2b765233182efcf12eea4234219af851bd197c611ddee3fad5509f580f6d678b2b765233182efcf12eea4234219af851bd197c611ddee3fad5509f5801ae0959ef8161b6a63e22dd21b776af8a6c040135d4c7d3bc721dacb5c99d6c415d9b6a9d989fb9ee1362436d438a977b81c045d9f31d41a61586f1d2d6d5d4f15d9b6a9d989fb9ee1362436d438a977b81c045d9f31d41a61586f1d2d6d5d4f369b613a54ce6e385476ee99b3c0d7defe482a742b2ef6a97a98e76c50782230ee600781188f69574df78b8e81e19a54f1b86a27ff4413c3b775cd0ea7bce87fee600781188f69574df78b8e81e19a54f1b86a27ff4413c3b775cd0ea7bce87fde4d1f2d2ad5ad0cfd1657a106476b31cb5db5ef9d1ff842b237c0c81f0c8a239f47df778a81f7a6db680f44c1611a5b4c4c9c4ff840b09d3bcf6fea974cdf2ac1649ee90f8535de061b77e5db7a60bdd33daa50c5fbd48f54123fd1c2127854rootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootpython-2.7.18-150000.105.1.src.rpmpythonpythonpython(ppc-64)python2python2_split_startup@@@@@@@@@@@@@     /sbin/ldconfig/sbin/ldconfiglibc.so.6()(64bit)libc.so.6(GLIBC_2.17)(64bit)libcrypto.so.1.1()(64bit)libcrypto.so.1.1(OPENSSL_1_1_0)(64bit)libdb-4.8.so()(64bit)libpthread.so.0()(64bit)libpthread.so.0(GLIBC_2.17)(64bit)libpython2.7.so.1.0()(64bit)libreadline.so.7()(64bit)libsqlite3.so.0()(64bit)libssl.so.1.1()(64bit)libssl.so.1.1(OPENSSL_1_1_0)(64bit)python(abi)python-baserpmlib(CompressedFileNames)rpmlib(FileDigests)rpmlib(PartialHardlinkSets)rpmlib(PayloadFilesHavePrefix)rpmlib(PayloadIsXz)2.72.7.183.0.4-14.6.0-14.0.4-14.0-15.2-14.14.1i@ici@iwW@i_@ii h@hxgw@g@g@g4f@fH@f?]fh@e,e @eedeeeRd˖dD@dq@du@dtdm@dxdc>@cӼc0c|ck@c pcbbb@b@b@ba@a@a(@aim@aI@a'@a#aj@a`t`8`@_T^J^@^@^>^>^;^8 @^.^g@^ @]f@]@]]]d@]d@]@]z@]V]y@]9]1]\t@\\7\7\\J@\J@\C@\2[[#@[6@[@[ @[Za@Z@ZxG@ZtRZp^@Z, gh#python/cpython#103848#issuecomment-2708135083).- Modify CVE-2025-0938-sq-brackets-domain-names.patch: we don't use bracketed_host variable any more (correction of the fix for bsc#1236705, discovered during analysis for bsc#1223694).- Add CVE-2025-0938-sq-brackets-domain-names.patch which disallows square brackets ([ and ]) in domain names for parsed URLs (bsc#1236705, CVE-2025-0938, gh#python/cpython#105704)- 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 ipaddress module from https://github.com/phihag/ipaddress - Remove -IVendor/ from python-config boo#1231795- Stop using %%defattr, it seems to be breaking proper executable attributes on /usr/bin/ scripts (bsc#1227378).- 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).- Switch to using the system libexpat (bsc#1219559, CVE-2023-52425) - Make sure to remove all embedded versions of other packages (including expat). - Add CVE-2023-52425-libexpat-2.6.0-remove-failing-tests.patch removing failing test fixing bpo#3151, which we just not support. - Remove patches over those embedded packages (cffi): - python-2.7-libffi-aarch64.patch - sparc_longdouble.patch- Modify CVE-2023-27043-email-parsing-errors.patch to fix the unicode string handling in email.utils.parseaddr() (bsc#1222537). - Revert CVE-2022-48560-after-free-heappushpop.patch, the fix was unneeded.- Switch off tests. ONLY FOR FACTORY!!! (bsc#1219306)- Build with -std=gnu89 to build correctly with gcc14, bsc#1220970- Add CVE-2023-27043-email-parsing-errors.patch to gh#python/cpython!111116, fixing bsc#1210638 (CVE-2023-27043).- Add CVE-2022-48560-after-free-heappushpop.patch fixing use-after-free in Python via heappushpop in heapq (bsc#1214675, CVE-2022-48560). - switch from %patchN style to the %patch -P N one.- (bsc#1214691, CVE-2022-48566) Add CVE-2022-48566-compare_digest-more-constant.patch to make compare_digest more constant-time. - Allow nis.so for SLE-12.- (bsc#1214685, CVE-2022-48565) Add CVE-2022-48565-plistlib-XML-vulns.patch (from gh#python/cpython#86217) reject XML entity declarations in plist files. - Remove BOTH CVE-2023-27043-email-parsing-errors.patch and Revert-gh105127-left-tests.patch (as per discussion on bsc#1210638).- 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)- IT MEANS THAT bsc#1210638 STILL HAS NOT BEEN FIXED! - Add Revert-gh105127-left-tests.patch (gh#python/cpython!106941) partially reverting CVE-2023-27043-email-parsing-errors.patch, because of the regression in gh#python/cpython#106669.- (bsc#1210638, CVE-2023-27043) Add CVE-2023-27043-email-parsing-errors.patch, which detects email address parsing errors and returns empty tuple to indicate the parsing error (old API).- Fix the application of the python-2.7.17-switch-off-failing-SSL-tests.patch.- python-2.7.5-multilib.patch: Update for riscv64 - Don't fail if _ctypes or dl extension was not built- The condition around libnsl-devel BuildRequires is NOT switching off NIS support on SLE < 15, support for NIS used to be in the glibc itself. Partial revert of sr#1061583.- Add PygmentsBridge-trime_doctest_flags.patch to allow build of the documentation even with the current Sphinx. (SUSE-ONLY PATCH, DO NOT SEND UPSTREAM!)- Enable --with-system-ffi for non-standard architectures.- SLE-12 builds nis.so as well.- 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- Disable NIS for new products, it's deprecated and gets removed- Add skip_unverified_test.patch because apparently switching off SSL verification doesn't work on older SLE.- Restore python-2.7.9-sles-disable-verification-by-default.patch for SLE-12.- 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 bpo34990-2038-problem-compileall.patch making compileall.py compliant with year 2038 (bsc#1202666, gh#python/cpython#79171), backport of fix to Python 2.7.- Add patch CVE-2021-28861-double-slash-path.patch: * BaseHTTPServer: 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.- Filter out executable-stack error that is triggered for i586 target.- Update bundled pip wheel to the latest SLE version patched against bsc#1186819 (CVE-2021-3572). - Recover again proper value of %python2_package_prefix (bsc#1175619).- 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.- Older SLE versions should use old OpenSSL.- Add CVE-2022-0391-urllib_parse-newline-parsing.patch (bsc#1195396, CVE-2022-0391, bpo#43882) sanitizing URLs containing ASCII newline and tabs in urlparse.- Add CVE-2021-4189-ftplib-trust-PASV-resp.patch (bsc#1194146, bpo#43285, CVE-2021-4189, gh#python/cpython#24838) make ftplib not trust the PASV response.- build against openssl 1.1.x (incompatible with openssl 3.0x) for now.- on sle12, python2 modules will still be called python-xxxx until EOL, for newer SLE versions they will be python2-xxxx- 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.- 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. - Provide the newest setuptools wheel (bsc#1176262, CVE-2019-20916) in their correct form (bsc#1180686). - Add CVE-2020-26116-httplib-header-injection.patch fixing bsc#1177211 (CVE-2020-26116, bpo#39603) no longer allowing special characters in the method parameter of HTTPConnection.putrequest in httplib, stopping injection of headers. Such characters now raise ValueError.- Renamed patch for assigned CVE: * bpo44022-fix-http-client-infinite-line-reading-after-a-HTTP-100-Continue.patch -> CVE-2021-3737-fix-HTTP-client-infinite-line-reading-after-a-HTTP-100-Continue.patch (boo#1189241, CVE-2021-3737)- Renamed patch for assigned CVE: * bpo43075-fix-ReDoS-in-request.patch -> CVE-2021-3733-fix-ReDoS-in-request.patch (boo#1189287, CVE-2021-3733) - Fix python-doc build (bpo#35293): * sphinx-update-removed-function.patch - Update documentation formatting for Sphinx 3.0 (bpo#40204).- Add bpo43075-fix-ReDoS-in-request.patch which fixes ReDoS in request (bpo#43075, boo#1189287). - Add missing security announcement to bpo44022-fix-http-client-infinite-line-reading-after-a-HTTP-100-Continue.patch.- Add bpo44022-fix-http-client-infinite-line-reading-after-a-HTTP-100-Continue.patch which fixes http client infinite line reading (DoS) after a http 100 (bpo#44022, boo#1189241).- Modify Lib/ensurepip/__init__.py to contain the same version numbers as are in reality the ones in the bundled wheels (bsc#1187668).- Add CVE-2021-23336-only-amp-as-query-sep.patch which forbids use of semicolon as a query string separator (bpo#42967, bsc#1182379, CVE-2021-23336).- 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.- (bsc#1180125) We really don't Require python-rpm-macros package. Unnecessary dependency.- Add patch configure_PYTHON_FOR_REGEN.patch which makes configure.ac to consider the correct version of PYTHON_FO_REGEN (bsc#1078326).- Use python3-Sphinx on anything more recent than SLE-15 (inclusive).- Update to 2.7.18, final release of Python 2. Ever.: - 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. - Fixes a ReDoS vulnerability in `http.cookiejar`. Patch by Ben Caller. - Fixed line numbers and column offsets for AST nodes for calls without arguments in decorators. - bsc#1155094 (CVE-2019-18348) Disallow control characters in hostnames in http.client. Such potentially malicious header injection URLs now cause a InvalidURL to be raised. - Fix urllib.urlretrieve failing on subsequent ftp transfers from the same host. - Fix problems identified by GCC's -Wstringop-truncation warning. - AddRefActCtx() was needlessly being checked for failure in PC/dl_nt.c. - Prevent failure of test_relative_path in test_py_compile on macOS Catalina. - Fixed possible leak in `PyArg_Parse` and similar functions for format units "es#" and "et#" when the macro `PY_SSIZE_T_CLEAN` is not defined. - Remove upstreamed patches: - CVE-2019-18348-CRLF_injection_via_host_part.patch - python-2.7.14-CVE-2017-1000158.patch - CVE-2018-14647_XML_SetHashSalt-in_elementtree.patch - CVE-2018-1061-DOS-via-regexp-difflib.patch - CVE-2019-10160-netloc-port-regression.patch - CVE-2019-16056-email-parse-addr.patch- 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)- Change to Requires: libpython%{so_version} == %{version}-%{release} to python-base to keep both packages always synchronized (add %{so_version}) (bsc#1162224).- 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)- Provide python-testsuite from devel subkg to ease py2->py3 dependencies- Add python-2.7.17-switch-off-failing-SSL-tests.patch to switch off tests coliding with the combination of modern Python and ancient OpenSSL on SLE-12.- libnsl is required only on more recent SLEs and openSUSE, older glibc supported NIS on its own.- Add provides in gdbm subpackage to provide dbm symbols. This allows us to use %%{python_module dbm} as a dependency and have it properly resolved for both python2 and python3- Drop appstream-glib BuildRequires and no longer call appstream-util validate-relax: eliminate a build cycle between as-glib and python. The only thing would would gain by calling as-uril is catching if upstream breaks the appdata.xml file in a future release. Considering py2 is dying, chances for a new release, let alone one breaking the xml file, are slim.- Unify packages among openSUSE:Factory and SLE versions. (bsc#1159035) ; add missing records to this changelog. - Add idle.desktop and idle.appdata.xml to provide IDLE in menus (bsc#1153830)- Add python2_split_startup Provide to make it possible to conflict older packages by shared-python-startup.- Move /etc/pythonstart script to shared-python-startup package.- 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 adapted-from-F00251-change-user-install-location.patch fixing pip/distutils to install into /usr/local.- Update to 2.7.17: - a bug fix release in the Python 2.7.x series. It is expected to be the penultimate release for Python 2.7. - Removed patches included upstream: - CVE-2018-20852-cookie-domain-check.patch - CVE-2019-16935-xmlrpc-doc-server_title.patch - CVE-2019-9636-netloc-no-decompose-characters.patch - CVE-2019-9947-no-ctrl-char-http.patch - CVE-2019-9948-avoid_local-file.patch - python-2.7.14-CVE-2018-1000030-1.patch - python-2.7.14-CVE-2018-1000030-2.patch - Renamed remove-static-libpython.diff and python-bsddb6.diff to remove-static-libpython.patch and python-bsddb6.patch to unify filenames.- 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 bpo36302-sort-module-sources.patch (boo#1041090)- Add CVE-2019-16056-email-parse-addr.patch fixing the email module wrongly parses email addresses [bsc#1149955, CVE-2019-16056]- 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.- Skip test_urllib2_localnet that randomly fails in OBS- 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- Set _lto_cflags to nil as it will prevent to propage LTO for Python modules that are built in a separate package.- 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#1130847 (CVE-2019-9948) add CVE-2019-9948-avoid_local-file.patch removing unnecessary (and potentially harmful) URL scheme local-file://.- bsc#1129346: add CVE-2019-9636-netloc-no-decompose-characters.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 commits e37ef41 and 507bd8c.- (bsc#1111793) Update to 2.7.16: * bugfix-only release: complete list of changes on https://github.com/python/cpython/blob/2.7/Misc/NEWS.d/2.7.16rc1.rst * Removed openssl-111.patch and CVE-2018-1000802-shutil_use_subprocess_no_spawn.patch which are fully included in the tarball. * Updated patches to apply cleanly: CVE-2019-5010-null-defer-x509-cert-DOS.patch bpo36160-init-sysconfig_vars.patch do-not-use-non-ascii-in-test_ssl.patch openssl-111-middlebox-compat.patch openssl-111-ssl_options.patch python-2.5.1-sqlite.patch python-2.6-gettext-plurals.patch python-2.7-dirs.patch python-2.7.2-fix_date_time_compiler.patch python-2.7.4-canonicalize2.patch python-2.7.5-multilib.patch python-2.7.9-ssl_ca_path.patch python-bsddb6.diff remove-static-libpython.patch * Update python-2.7.5-multilib.patch to pass with new platlib regime.- bsc#1109847 (CVE-2018-14647): add CVE-2018-14647_XML_SetHashSalt-in_elementtree.patch fixing bpo-34623.- bsc#1073748: add bpo-29347-dereferencing-undefined-pointers.patch PyWeakref_NewProxy@Objects/weakrefobject.c creates new isntance of PyWeakReference struct and does not intialize wr_prev and wr_next of new isntance. These pointers can have garbage and point to random memory locations. Python should not crash while destroying the isntance created in the same interpreter function. As per my understanding, both wr_prev and wr_next of PyWeakReference instance should be initialized to NULL to avoid segfault.- bsc#1122191: add CVE-2019-5010-null-defer-x509-cert-DOS.patch fixing bpo-35746 (CVE-2019-5010). 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.- Use upstream-recommended %{_rpmconfigdir}/macros.d directory for the rpm macros.- Add patch openssl-111.patch to work with openssl-1.1.1 (bsc#1113755)- 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]- 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]- Apply "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]- Apply "python-sorted_tar.patch" (bsc#1086001, boo#1081750) sort tarfile output directory listing- update to 2.7.15 * dozens of bugfixes, see NEWS for details - removed obsolete patches: * python-ncurses-6.0-accessors.patch * python-fix-shebang.patch * gcc8-miscompilation-fix.patch - add patch from upstream: * do-not-use-non-ascii-in-test_ssl.patch- Add gcc8-miscompilation-fix.patch (boo#1084650).- Apply "python-2.7.14-CVE-2017-1000158.patch" to prevent integer overflows in PyString_DecodeEscape that could have resulted in heap-based buffer overflow attacks and possible arbitrary code execution. [bsc#1068664, CVE-2017-1000158]- exclude test_socket & test_subprocess for PowerPC boo#1078485 (same ref as previous change)- Add python-skip_random_failing_tests.patch bypass boo#1078485 and exclude many tests for PowerPC- Add patch python-fix-shebang.patch to fix bsc#1078326- exclude test_regrtest for s390, where it does not segfault as it should (fixes bsc#1073269) - fix segfault while creating weakref - bsc#1073748, bpo#29347 (this is actually fixed by the 2.7.14 update; mentioning this for purposes of bugfix tracking)- update to 2.7.14 * dozens of bugfixes, see NEWS for details * fixed possible integer overflow in PyString_DecodeEscape (CVE-2017-1000158, bsc#1068664) * fixed segfaults with dict mutated during search * fixed possible free-after-use problems with buffer objects with custom indexing * fixed urllib.splithost to correctly parse fragments (bpo-30500) - drop upstreamed python-2.7.13-overflow_check.patch - drop unneeded python-2.7.12-makeopcode.patch - drop upstreamed 0001-2.7-bpo-30714-ALPN-changes-for-OpenSSL-1.1.0f-3094.patch - Apply "python-2.7.14-CVE-2018-1000030-1.patch" and "python-2.7.14-CVE-2018-1000030-2.patch" to remedy a bug that would crash the Python interpreter when multiple threads used the same I/O stream concurrently. This issue is not classified as a security vulnerability due to the fact that an attacker must be able to run code, however in some situations -- such as function as a service -- this vulnerability can potentially be used by an attacker to violate a trust boundary. [bsc#1079300, CVE-2018-1000030]- Call python2 instead of python in macros- Fix test broken with OpenSSL 1.1 (bsc#1042670) * add 0001-2.7-bpo-30714-ALPN-changes-for-OpenSSL-1.1.0f-3094.patch- drop SUSE_ASNEEDED=0 as it is not needed anymore- Add libnsl-devel build requires for glibc obsoleting libnsl- obsolete/provide python-argparse and provide python2-argparse, because the argparse module is available from python 2.7 up- SLE package update (bsc#1027282) - refresh python-2.7.5-multilib.patch - dropped upstreamed patches: python-fix-short-dh.patch python-2.7.7-mhlib-linkcount.patch python-2.7-urllib2-localnet-ssl.patch CVE-2016-0772-smtplib-starttls.patch CVE-2016-5699-http-header-injection.patch CVE-2016-5636-zipimporter-overflow.patch python-2.7-httpoxy.patch - Add python-ncurses-6.0-accessors.patch: Fix build with NCurses 6.0 and OPAQUE_WINDOW set to 1. (dimstar@opensuse.org)- Add reproducible.patch to allow reproducible builds of various python packages like python-amqp Upstream: https://github.com/python/cpython/pull/296- update to 2.7.13 * dozens of bugfixes, see NEWS for details * updated cipher lists for openssl wrapper, support openssl >= 1.1.0 * properly fix HTTPoxy (CVE-2016-1000110) * profile-opt build now applies PGO to modules as well - update python-2.7.10-overflow_check.patch with python-2.7.13-overflow_check.patch, incorporating upstream changes (bnc#964182) - add "-fwrapv" to optflags explicitly because upstream code still relies on it in many places- provide python2-* symbols, for support of new packages built as python2-foo - rename macros.python to macros.python2 accordingly - require python-rpm-macros package, drop macro definitions from macros.python2- initial packaging of `python27` side-by-side variant (fate#321075, bsc#997436) - renamed `python` to `python27` in package names and requires - removed Provides and Obsoletes clauses - dropped SLE12-only patch python-2.7.9-sles-disable-verification-by-default.patch, companion sle_tls_checks_policy.py file and the python-strict-tls-checks subpackage - dropped profile files - removed /usr/bin/python and /usr/bin/python2, along with other unversioned aliases - rewrote macros file to enable stand-alone packages depending on py2.7 - re-included downloaded version of HTML documentation- update to 2.7.12 * dozens of bugfixes, see NEWS for details * fixes multiple security issues: CVE-2016-0772 TLS stripping attack on smtplib (bsc#984751) CVE-2016-5636 zipimporter heap overflow (bsc#985177) CVE-2016-5699 httplib header injection (bsc#985348) (this one is actually fixed since 2.7.10) - removed upstreamed python-2.7.7-mhlib-linkcount.patch - refreshed multilib patch - python-2.7.12-makeopcode.patch - run newly-built python interpreter to make opcodes, in order not to require pre-built python - update LD_LIBRARY_PATH to use $PWD instead of "." because the test process escapes to its own directory - modify shebang-fixing scriptlet to ignore makeopcodetargets.py- CVE-2016-0772-smtplib-starttls.patch: smtplib vulnerability opens startTLS stripping attack (CVE-2016-0772, bsc#984751) - CVE-2016-5636-zipimporter-overflow.patch: heap overflow when importing malformed zip files (CVE-2016-5636, bsc#985177) - CVE-2016-5699-http-header-injection.patch: incorrect validation of HTTP headers allow header injection (CVE-2016-5699, bsc#985348) - python-2.7-httpoxy.patch: HTTPoxy vulnerability in urllib, fixed by disregarding HTTP_PROXY when REQUEST_METHOD is also set (CVE-2016-1000110, bsc#989523)- Add python-2.7.10-overflow_check.patch to fix broken overflow checks. [bnc#964182]- copy strict-tls-checks subpackage from SLE to retain future compatibility (not built in openSUSE) - do this properly to fix bnc#945401 - update SLE check to exclude Leap which also has version 1315, just to be sure- Add python-ncurses-6.0-accessors.patch: Fix build with NCurses 6.0 and OPAQUE_WINDOW set to 1.- add missing ssl.pyc and ssl.pyo to package - implement python-strict-tls-checks subpackage * when present, Python will perform TLS certificate checking by default. it is possible to remove the package to turn off the checks for compatibility with legacy scripts. * as discussed in fate#318300 * this is not built for openSUSE, but retained here in case we want to build the package for a SLE system- python-fix-short-dh.patch: Bump DH parameters to 2048 bit to fix logjam security issue. bsc#935856- add __python2 compatibility macro (used by Fedora) (fate#318838)- update to 2.7.10 - removed obsolete python-2.7-urllib2-localnet-ssl.patch- Reenable test_posix on aarch64- python-2.7.4-aarch64.patch: Remove obsolete patch - python-2.7-libffi-aarch64.patch: Fix argument passing in libffi for aarch64- update to 2.7.9 * contains full backport of ssl module from Python 3.4 (PEP466) * HTTPS certificate validation enabled by default (PEP476) * SSLv3 disabled by default (bnc#901715) * backported ensurepip module (PEP477) * fixes several missing CVEs from last release: CVE-2013-1752, CVE-2013-1753 * dozens of minor bugfixes - dropped upstreamed patches: python-2.7.6-poplib.patch, smtplib_maxline-2.7.patch, xmlrpc_gzip_27.patch - dropped patch python-2.7.3-ssl_ca_path.patch because we don't need it with ssl module from Python 3 - libffi was upgraded upstream, seems to contain our changes, so dropping libffi-ppc64le.diff as well - python-2.7-urllib2-localnet-ssl.patch - properly remove unconditional "import ssl" from test_urllib2_localnet that caused it to fail without ssl- skip test_thread in qemu_linux_user mode/sbin/ldconfig/sbin/ldconfigpython-elementtreepython-nothreadspython-sqlitepython21ibs-power9-21 1772180408  "##%&&())+,,.//122455788:;;=>>@AACDDFGGIJJLMMOPPRSSUVVXYY[\\^__abbdefghijkllnooqrrtuvvxyz{||~2.72.7.18-150000.105.12.7.18-150000.105.12.7.18python2.7bsddb__init__.py__init__.pyc__init__.pyodb.pydb.pycdb.pyodbobj.pydbobj.pycdbobj.pyodbrecio.pydbrecio.pycdbrecio.pyodbshelve.pydbshelve.pycdbshelve.pyodbtables.pydbtables.pycdbtables.pyodbutils.pydbutils.pycdbutils.pyotest__init__.py__init__.pyc__init__.pyotest_all.pytest_all.pyctest_all.pyotest_associate.pytest_associate.pyctest_associate.pyotest_basics.pytest_basics.pyctest_basics.pyotest_compare.pytest_compare.pyctest_compare.pyotest_compat.pytest_compat.pyctest_compat.pyotest_cursor_pget_bug.pytest_cursor_pget_bug.pyctest_cursor_pget_bug.pyotest_db.pytest_db.pyctest_db.pyotest_dbenv.pytest_dbenv.pyctest_dbenv.pyotest_dbobj.pytest_dbobj.pyctest_dbobj.pyotest_dbshelve.pytest_dbshelve.pyctest_dbshelve.pyotest_dbtables.pytest_dbtables.pyctest_dbtables.pyotest_distributed_transactions.pytest_distributed_transactions.pyctest_distributed_transactions.pyotest_early_close.pytest_early_close.pyctest_early_close.pyotest_fileid.pytest_fileid.pyctest_fileid.pyotest_get_none.pytest_get_none.pyctest_get_none.pyotest_join.pytest_join.pyctest_join.pyotest_lock.pytest_lock.pyctest_lock.pyotest_misc.pytest_misc.pyctest_misc.pyotest_pickle.pytest_pickle.pyctest_pickle.pyotest_queue.pytest_queue.pyctest_queue.pyotest_recno.pytest_recno.pyctest_recno.pyotest_replication.pytest_replication.pyctest_replication.pyotest_sequence.pytest_sequence.pyctest_sequence.pyotest_thread.pytest_thread.pyctest_thread.pyolib-dynload_bsddb.so_hashlib.so_sqlite3.so_ssl.soreadline.sosqlite3__init__.py__init__.pyc__init__.pyodbapi2.pydbapi2.pycdbapi2.pyodump.pydump.pycdump.pyotest__init__.py__init__.pyc__init__.pyodbapi.pydbapi.pycdbapi.pyodump.pydump.pycdump.pyofactory.pyfactory.pycfactory.pyohooks.pyhooks.pychooks.pyopy25tests.pypy25tests.pycpy25tests.pyoregression.pyregression.pycregression.pyotransactions.pytransactions.pyctransactions.pyotypes.pytypes.pyctypes.pyouserfunctions.pyuserfunctions.pycuserfunctions.pyossl.pyssl.pycssl.pyopythonLICENSEREADMEREADME.SUSE/usr/lib64//usr/lib64/python2.7//usr/lib64/python2.7/bsddb//usr/lib64/python2.7/bsddb/test//usr/lib64/python2.7/lib-dynload//usr/lib64/python2.7/sqlite3//usr/lib64/python2.7/sqlite3/test//usr/share/doc/packages//usr/share/doc/packages/python/-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:42941/SUSE_SLE-15_Update/e1bcfe9fa63ab4026d4cca0b18a4f3e8-python.SUSE_SLE-15_Updatedrpmxz5ppc64le-suse-linux          directoryPython script, ASCII text executablepython 2.7 byte-compiledASCII textemptyELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=8af747538a1f7f8d37ec680e5d70186c3c25e5bb, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=1d37fec71938da8ec69e1eae77d93bf0a0bd394a, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=ccf06ce9f32158c6859eef9f15f2b4c1f3979d7a, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=88d776973235695e182ae61e38966616d9c1fdd8, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=f63e836fcb4773d5e3750709dd3161bdd69e4edc, strippedPython script, ISO-8859 text executable  !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`fms} RRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRR RRRRRRR RRRRR R RRRRRRR R RR RRRRRR R RRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRR FdK8ho8'8utf-8abec2e4cbcfbc5039d1c7bd53f83a3d30046124cd5dfb020ba7a1ca377e69ba1?7zXZ !t/2k]"k%UN) ӚGyޓQ` @f? 8=Ŝ-},:=z2oarN Fe{tko}86p4l.RGĭb'JH}Aw^AiN)h̡݆]Ip?-5 In?K5F&'(EڻG)sh#T ٴp9%T[YY_h.Z_AQ1X\ϔ K?h8gboBesp6*UYVkOP)Uh\qXS  bٶO8$ׇOF+h!ycSAk.=kK`:ps[:n|z,SLV |AXIc?O]t;C[kʘ0}"`Y3|P;@6bPIX‡gm?n(ZAA./[D@`Ӯ$ojҗ# ~ήkTNoK5灢k>KW6- bhYJ,KO1[-|QU y+{J*z5Bݷ.L!ݦЩH'NE 28g JQ+2ֹXjR;j4 D#f፛u$O^0m F'oL:N[|oK cN jaՑ Z8|TΌul$@En"@1}eXj0aA!_m5mFrg7_b_oRVXFZ{VG1$}^p x]L`ŷWl]/-L%\/;q2{In'cw g:/xkVgFV˿BᎭ/cy1'Y z/WVvɞ'- Tot5LpbVDoAԜS>#k0VݨrbL'y쮴.h(()d#<Nwm>9x8yfw\?{e{FHBUHME ҲNsf/qkٌ|s1W*3#R š)m4ptltgxla]t KO"kv(@.MToY&7᨝P: =urlIӠ$Pq[ٕinLg3Ž1o4j(aU?WgR )ꂪWJeg< MeGϤ%GIl̽|7ڵ5 +?'{+[YD3,ڤOlm*gWPt\0 >}ӚUbݬt-"F˾*CXGI0N˸7"Ɓ䆳|'S0`q&r ExK٦=I%$1 QB]=f=7\#̱仆gо4"czϰx>l{_0HЭw!Z5QD:8˒k jMӞ&Zcl+pK^^s?#h#dkBQRhIJW[LQ4;U:%lR`mQa?K%Ƥ)۹І=v2Nw-y> {AL|J a6F =8}rvjhIxbpԹW&Q %I1(XOE[T)Urau18q0 V}Pt|/6=}Z2P#>9iyR-tQi$g߆ Mx̆a `33Yi[ƚ8SuT!fls$nŴP&:vTD$jHf#c ׻N4ܙ7zh)hU&v!@׍E݃Yދl{H& %Ǧ=y/+(wgJm\_>O]hpQEXloz]sbl1ybG|8ȳ™tH/#lܿCt8*2*ys2I!f{b@3:>cSTYj(2O2|zL<9髥w&Xkp7كݕrC:QZWkZ =‡о憨p_f$ b6qw[h^}HQrgA"!;ԿdK7aPJAnpS4&|%)q MPsM5>&Y9i>7s[.9-ԈP[{ E=& ><)6WPyUlp_Sr+a 3yIZlpPC`.=Ճ *ғ4]Jz[aŖ?v'N?FsdHYp;tD.ބS4,ləqDe|H'5ġ_qrK!21ag5VYz?G_ʽ-V} ]:&S𫩠 lRzReNV¦Rre> g-&nZO7dGaqu)AXTR?t]b}/dwZFUV1n5cUC&$Hb?2ۿ#&wi!5JhjB:S}mG ^f^ƅp* aݐ92U1M޺la g0VՖs!l,k8{TY%>^'|i G~MV3[10yul O6ZR@^"ȹW<^ct02,}h# /@J(d#ҵ^^J(ܽN^Z#? R/F2~ Dς.IkWLr.py'ꕂxFX߱(shYg;ptm{pu8ʱZ7*bfZ9EH 7/$L-2:`uc=>E[a:vѓzs1Y lYC,Ẅ́{~.FFV|yB^׊n0,cΓBEnu꩓se#bCl=JKLE$ 5NIG Xgj} eѤ8i"mӱ6ɑփ>3^J/s>WDZ0R"L3ݏ/M}k]ʉÎ5! Me=F3c-?&Rۓxq5}z}֍Cd3Eo=FJrsf_ogRoѹ`QށK إ|$W\'%?b +@6o5{apCf=K!mnAqy,LS_(u 7ɸ>Gf¾&zTHLR#4ñD `,5Y1]D(5 j ^Puq>8;b!eÉ;$f z'rb>i:}S'\(ɸSށsm5*S3ڃFv$e@ybyJݐ$e/Fِ)ܲfޞ`L7NP =쐜v N/Z#1/׏ajyy:旹DFL*©n%0{G6.O=LH]KExk Z:}Č8Pdza6tʵbŽv":X#J@jI61#-6^ ;xLw!?.EԼbo*nEI Ve}#@g-)u»b 3,=JL`PK,yX#azR-$l=SP$ʔ~xn#wfFvD@N콶U|[;A3%T3 +s9TVf-dQ!lƹˢ\_s[6Gk'\ z@%Gs9!~-ޚcL+kzISCfdH[]G6nk4bXOfZ7Z\+J$ k*34-Y8 uk ^qR>703tx?Gr8Q(]?c\#KJe@Hݠ'$NKR_Pr7Ho;p`S3ljnib@o FM^a]Rt:!Z+}سEYV ;feG}'ބcg;?QQ3tcYI)S??-V⩕qD (81Vj/,ėCz#!Q*˃ޥa Dh7'WA^|>dapF)46|Aˑ6yS6V}2.c> к<2Yx+j[Llr:O}_76FA3BIo@._t Uf~Ji0D<9ˇ3kj9x^w;W/HW,̢pLQq406R= ()Щ3! NR,oX^H q-I2Cڈc6lpB|TJEzh8 Pz 1*=T_la:WZVk~~u4y?GQKCQ^~[+ǞKv+>A \wb*Ffvo$Ee& Qm=V$K%ޣ_Ix;=wު.S閂A|HVs $0 YɭTCǜ#HTM3M*.5͋Is1; _y 4{|7StEbӸ *^a,A蒜1+Ґ@f6 gGR{] nN"OZ:јԔFo23* ^lƵn=f/n$` Yvͩ2<ůT8:sfkɶ)K.fFJ{v1)*or,؞tp:HX-2]mU r*c1z1&zx>UD-|'Y7_icoUCr/ªf#>xWpϬO=#> œ632~Y1EX-kWGQu& H$ּƹrnx" J]z˾@&cQKj]Rct$ Fx_-Zh-fJqL8 sVPzxew}NiE:PU<-,VIgB߬D#cQ$PQOp^YކAZ>2VJ *+LIгzxx‹i爰֩J:DuGruNOo2F"32a +\ D džZO7vt'7 ]KV?R?X~~U3[2_ӎ_0i@:m ϊT%H/GR$?[:G'x +FFGګdk JŨ`؀_Y~KILw|&ءcߥ0`*ZWYU0]أPIYF^˛/"VY\6>=zhӯg3 ;(ZkQrM";SnfK>&}BOXT^ #~8DsӹPK3"uk:Zrһ?XT`gHZXs\!d/u NEjc~0U>R$GXlt4UMBWl5 d|Y!Mwr^CCk{e/Sj' Gk" aYPr8 \kXgǠ=0|W ]ۇw~/7/n߇qSӻF=]e^6]\GKx L.-X5<>:]msYj29o[<4>Ô@Ve :т,/|Osyh ig2:Hj[|ND2_}u舾9WY?^BοATeu/G ;IIu]>(ҡrۃDcOB;=609Y(EOZ]n3n!!*ļ\щE,>V!ɔ-!ȁa)4b{"An1 uԮguI2l\wNC+in6k=0}'VOxz<-*EVݍ촐+ EFuK}X2}WOTHsn֍-WiPI?hFp޾耧ަmGcƄ+Ns G}VWZ >Y_9ɿ>j}ҷl{ESuGp]Um c3q eW7ۏ?@˅Hhow (+}z8ӳexc8Egxz ! §8+[:ǷU CvE tiժBS6"2t+{Ys6 4R gb)}MB4垾ZaSBWOp uKS1n5&AZŔ1$%}qjz-PIS !JD 0z sy'[ ŇZ"T85WZ|"p@׍'>Q!28.X1s3L Ͱ'ϪzX m+6+hhs M21mV>} PwM/?KSBL.KtXxɁ :O`\ywy8V]n vfiۊThZ?d`W$?r<}Pd(Ğ/0$85h 9B|% N[q{c q^ube6}F?_="7d`"~ $9=xV^ek^퍄Q>D#g2yDGJJsQoLT[7,_..XNZ{(})E;`7F+XAxLR6p̤S\ID@`Uhϫ ԚD-C6-ޓ/6M]lXLGA`w; q =ޫH(}/ }rSM(S\Qv521 '||HhC3R#VK'O'SfoT`{gY0I3-  %m#=ݸ2>\×ދf۞7]$bn;࿅، TP4]ޘ䌭̫ Bɚa( J(iD(HIH\ź+P|F>6*>90J0O ·<$1(]2B934is;^9"񿪙&po5,K6!F2_e~ Dt״n]}.yYTt1/R @qmq,(2[B1cuHٟn{L{Cj>%, 3xi?O U Qc@ym;94\%k Mspk.Sc!STKb-By5#,yOU#h4*1bա]c~p1K]9Su?@0Ю $SGTx2[>}^DԯĴ8=G$\+hh[Dq0P<"2Ҵ,Wʾ,` NXLn]U"0(8o?³,.کw7&H lҶSOGzf9/qtGHhrWIbz|B z*LhG\%CNk8AjvwbMãЋyyo/ :%G&A1ia&k׬YQ͘=uʿgRŁ)>4(\*& 9?o؜HʅďX|@"1taf[AtF(RK|/ɦGNHKlJ_NKe>c~h^C= A7bgIߜA68zIV(jEb%Hҡ 1^.0iWdo:=lmI.'0޴Lyq ^w.EdLcbhVI?]`9 #K8)̾ਪA/,TGͷ|߀s/X1~̬d.g)"V5OqS|u='uOx%XilXFnQxoB>Ȁ :fM1g9_0ҽ􎗥U[xN@bbluS~.缭Fd$ikۖN.Kq9;wY%JiX0o] fCP*鷐m@ʂ潓I)޶r/V/,R2u9#o c;wt)f޹C5DV4eʤe}xʞ|E+5Խ, iB2'v wgpac}1mC2tovdmݣm36KnH4>oB~7J)T4.9IڗFצ)6ߗ^C,^#ŒgW{KHOt',\|߅d/6 '=$oɖ44ɓ-N&(É_5tH2;'wxR?5[ET>}2KB)M8p x&ƧvHX\"W9tN99lSUj'GTIU~Bs#_Q_#j'}V4<=C 2;3 &L)e#UƁZaoɺ-Ye}8aodG*N l Q9(iSψ? :M3yHEI-8*uH?,ZuIQ&q>:0٩\-˳R+X)!c5lvhg !X'ZMǬt X}TJmV4"ۍVL(XϫpU=y:xXho(QVna b8 eYLuAϵ'Xi}R6 A{WDtt=pÁZެ96u} դAM#{]a "DŽz`ۍP>q׶Ƅq@t/ze0L) aQݠ\Ub{Xq{"}G)t k'b9wY Zw1ԆOWc1NdXqJ> 媠ۓN`O 5F@i3f 6F)7053jjEסH;jbu{< C$h?/-:|3y[AzDKvbdP܇טS?{B ܯk_OiK/(ppQHWR> Ʒ̭o 2[8}*_Hq./C!K\]5+x zVbo %kq%TѪo':dihO6_?B)R#i%ދ7pKჱ]HCDC\ަZE?RO&.z DLBq##5jr(mxG4 @/r*{ e9^?M.!/QJD?FbԸ*zXeЈ,G0&uɂ88.7?Sg;Եn\s&6{] G3'ZmdN~H7ZZAPâ w뎓13`0@zROrsS94 W;2# Bp8QXI +H<:V 0dXg^B$3crKͼL[]ޚVmenC鮰zKˍ}_)aHu9s\1w" ӣea=ԂVԸЁ!\V5xK7='~Ah.xȧ+8van(@`x#lr) ʔ5Jd#zN58oG).262B?ǨR<]S傫Q-*YrŅ/v05Qʧ{c˒u؝(,pçhru5G;y<|7{mbPVXL#efgޤFD*GIr9gD%qnCb>1ú'-"'wX(Э5YVk?жyv'RDm%,?p󢲗(j̄olC.t5-Mi9NRfEF?z8kٍM99#TNUǫ+S$p<1%udaD`U ڂ[ƨᜡ x;ȃG#+a8|eN1-&ˮ^̠$a{%tRV]urdmp=hu}R.xGa?t9W#ѝOY6QF;kꭡq ]@"A|H$@u'ynR}I{Z  WýAPI%Yt !7MzZf{>exRhmn@:/@zsIpoU+o/;PDӒ?tqQ%8rnmKE<ŎSDCPY|D"Mp13o}TZ2t*8惆جkH-=AQ*ۯW=ӆp Jsq~?q~ I`hQёT WyT bp8XSl]$ɯ) |F)N]H3Uv#pEn܋c31V~I2.IZ6\QXlntI Z[:+f[; R/ 5go0[ѧ#iYؓ+H7MU*:u*.VxProne d**sb%3ړU3nM O ]-d{qԀ=i]-EJo 8+ii7::5Mhm. շ$O&^OFreG1-B| Pǖ4Z;/UdSL)Z Gқ=i q@qRl< 1ۮXL\e&)éfN/ovnH^##aw, ܎O6=)W~͏BTI>iyKfz?l k5[6>}*gX-pgq)]W^Gb̴cOSafɘYg3!-7,{*?^pQ.֤$HU< v#^]'~-E$hDRȉx#Fm979TPk /WBzfI3q^? vMt cnvS2[esaw. PpjD:ҋ+(DՅ"`!Ү8Rɭ!NmU4KJ܌,_O+iLrKʖ;xZ'ʝ̴L>[ҋT>C9M!p8}KHVˁ nFca,iR<|xm{KZf֭R<1q>IL=4`ԛFO: ?5eI~ \g F&Qqu"bj%?އ8{MV~zUfU 6Dӻ4nKSEj 4vM-0dLZl"/˺?R} X@w)("cTB2TzZuiS霆LSŨTW6F7 mP5Wo(xdj4PX_6vx+UrVi78%?^~>= z7@*I*ɀ>_1ΡPlrYfd:)Xaz?.rG\]K,9yTʛ׈wLs 甼aå!l{jX BU#C%dVkrXT#P~>MLQQf@t PD`PeeSCh:Fnϐϔ$Κg oiU1Nؾi֝1aᅓzA\,gdT O%~!"Uj$&_]όœ&k}RUr"C?[h#(L-0ipn$-}FQ>u;䚀ɡ 'U\D~qp Lk*ijV:cuhU.*Km\]aX ml(NO.e"u|4QAhCcwFk0G_TsƊPE,NޥT_b$yǞG'N6 >|~McwͭMq3B\#kO8w<911=U+|^rRSEv Gm1.`6;,?d}U-AABS0 oR4ޢh*/W:<& UnTR:)PS`^I;yÕ)s1c'|\A}557@s0mDDkED(?o928M{aC@39m(-bJsͦ=af/ :om`UC/q/'gt\SXT`2S?$\Pax >&R_ 塟kU_>%P |M>K]04 5"bZtƂ \ O|v?ݞlbqj89Z%f-6o!Dtť @GKUmZ܄(|*YLJoo @)è=KhAxLYXҢGJ^/0̓bo̞ᩰ+2%hiϠZ<}*(!ZPP@_&-C`4OqnH:LxEY\BX`٢.GCn}&Dݕcmt5XJͩޡs9O bnLJgSg bn8KV/A13ɭt;W$KGcCs8mIyiTMQY`Ug+&WXNJ fB3Uo1qra;aa|C0b-^<8 1cȢ}$dcw7ڹz!Z")-EѴ V+*8λ '7$$T;gH/ph qP9!puA}E!qqy2G[/+Ζf>Fr( C|*78 ஀s)hA4d|۔I~-a)‹e&Ğ0ԟ!D$*&~m:'Dыcu^a.&ժZU`'o vccX6g+utJQ)N~i|D=u: dm0E=[T!LCX 5UCG⌯|kk1jo:f6f+y;!R""&-4*_]MГ]&Јۢe6$Tn\m0U\Sqؾyz^jݝPp7t,R۝Bb$:u}zXت`FRnza1d ᷠad]➨`WǶa$EYC%CsIOۼ Zp؄qFMx&]$.SnjKגAk9a(%KqGPLygNZH/?׭~I3fIFXyk+$5JE%'jg;{ًq;މc'HH!e5?X0[hBdn<=uR#BO|/X|Zܪg4x9nED2y^C70 zr:PK-SfKЖ`! ;~tDH A=Dy)ɛo٫?\mP$gWɶ(<.eڻɒ9NVK7 ™ r7 oP:2|/#sZ͝RcBDmDBh/yXoH Cc<vZyF Rl_\Mi.iϙj_[$qC.Ɯp.7bޖZ} ~.qCbЄdr7~FB;i%4^SAb}0 _UL+=Gů-Ggƨ'K mw?,kXLꧼ`f F?|R]G>DkQ!dJ SHv͈uhTeV5]̃ȓeUWKJk 2&BL''fW,K˙0L7[;5ʗ62"|=F^FerMCIʈɾ_MjǤm*Q_1|d:Bid^HQ]5 <}T:WfQ\9slT(`47q|!Esc6;LNo6` \bш }XryyOh>[+WQ{0PKR$1xfdt KpyNIް ݧz@pG4m0Kr9d}^L&hXo"JpRϠ(\܁,)[Txk D!:#W`꓆`%l) nJg-(us|Qxt qt.^Ig)2fPBAvOuE`Ft$?{YA9P)dd[ү.=IK#5 d֡zP" HٛNcL2FdMi)p qZ0!\S&&^BwҜHen8mGsbb䳼@O#i? ~9$d IΛEE^=Q1Xu}9J /#؉3K9uuC)'ƕ/ꋌixƏ ^ <*dP$鳷7|>0iq.BXh,fi{Ř MjbĀ W(+mZQ2sl3Wto)v=RV&=<$ }K Ke..J o{6$N.G˻e{\un>ԣ \`{v)6rЂ~:ٌ#$>J4\^" F+pK̄C~w鵗QUuI`DOn7mEolgs/עG\ UDne_F=d[ãBd?Iٍb'#L :$*u^?|yMurZ (˥ūzRdVʼON~b tpTV(YP Y?m[7Q6@x%ƬJtf]hƚgZ J$ es^zăL1N Jr?{J:$`#rGW5!!KC920ڄ)hd5x.'^l&]֘eTqEOZ鞄e Wĉy\&1_%R>R}pA8P~g:`'axI!z0m=_b"e&{DqEs%uF%p>MUnH^X,y8t.: 6,%߹; Wi@+{2~u#B֕tZ6nVߴwm;z vUύI&'X(3s'5N"B +왦 ;BnSaZgО6̮mJЃNUUb2c3/ sPf[#MܲMTn,0~4kEsn┸o3*V,yM9nsYH{\c2"Y3⻵dרXg&+>Q6ʑWVhLS)2{F~54EZ6N4V.M 5 iAW|׉3+,)poHoc3U֏؉@ =ފt_+`WX`LD0 yHo,J1:yOxW({xAʞogGmxW-(rxzPU-&F 9ë06<* jk쨹,ϫZr> Ԇ7CmNP&(Eշ6@K#mdm=1-B5Wlѕk!.u=& P!ܩ5䕱Dk4IWK!wT;Y|%QGD]70cw ,͏-h|i`SH.UՂ3.*d9OJD$ ֤ҏ޼R\F8$b]NHgk}n7u,-UV֑>nx$zaq\WXSY35vrh*zmd67lT@*w$}w2?x Ipʶה 9Eds.9Dտ#19z3'|p n Yn6:A#&&r}Ra3i4 K$`F9µS_kiʚ pS&d֒ ig%"lH;t. Pw#&BG !At+,9I 9UW@Ki@ZX;!z)I:bAˉ8vĂyK;Svo0.u#=FV9ӷS9F*@]QyI)$~7 B:q>T( :#+ddYu 3cqKʮy1"u\(Cz  s1]L\]!"6P?SDbp7#y>ٸJ .9[U*Pzz̒>8uRQ)ue~P@01+NEG%f=6(j@lh 4ܔGN><IE R@eM^{2{ J*:_ y%!k05zd O-BN2NPu1AU to|~k.[ c*(Z?bIA^%e쭐s~>D,^>$i4~u2Y vaĜZʑ\5sUL9 6.KX\.z^ÍxENb@@ 䵃 c~~eG=aӺgUN67ADoJNT\5V@2RH{#{Gm{w&vYdzoFJ1"XMP[EAiҭe-\{t>?V }TA*N]ߠQDZ?/c`6:/d]>^j9R _FAo-2knl6 ǽ[`>@-08aKL$S'Ln3ŝ^͡_T4h_qccjߗt9rW &cL52z<]h7XG seB@Gl/YӲX4Q,ԓǬ`YS#z%ș+KOx\,v%>$!X c7W0t.@5#XDS؈qmT{_QzD/LE)Qݙ]>݆#_"b;EDzO-$g@yܿԗȃIk4cN㢞p9&2"+mF\՟q>г̏R|654'tb.|lp}S1wh:ӯq-'hh@ge>r90/6WH :Z6vצ+/z:g*zt%"rX8/IAib@~wtj.Вv22H%qHR'! ,"K]Be=0qa}k1_/.@kGٰ7:.[#0Jʁռ1#L'W Tr T3L{50i(٧G\ܳ6-?qc9KqpMٜ9's6Q q0IGl9#FE]P#σ6nan@{Vy#2I\w k;?gfjWy4q@Hc F.W I|ۿ}qaQͩ OQCE(8Y3ibܲ5cҚVJzO$qS} Py20WPB c*-:_+ZKD!Cڮȵv.i"rP[Sծ_XSH n'1!1'n`R:$S^TI40CC{y46dMYJ/<Ե v^6r<޹ (W85r11'LM6b&:-paFX 3 HeOӲ/0  |ɪ eRԳ.p0Β4QLʫD)Zzex" pX)))q];@47:?N38՗ͪh2 .D#!=bqddY s,nUTbsVq}C3f(Җz'${BB%g0:xƊN JƄL_-3 .0C{4p8ޝ}- .1K ӈ(PN1UK {떞)Cj&, b`.%"v]&ѲC\d1Nc;zu>vy6u7!40N*hyj| H ŗjN7L.u෣< g𑏝51x݉h׍lϐ7D/=U9|Ed9Wr`Djs Ҫ2ۜ\Io:ﱱa_@L|ꦃ52PS\zn¸GR~GF]CJm⹻vk50 pUSQ[NOt92B@rYARp*UV'iC5"aƠvX  ȪX,|&Zμ[bǧ`=o[_)2'p(XkIODUlcAs3_΋)W Z'sO<$Q9ǖ,撈q9 @ήyD;t2tn"E&3'y^vsa_/haX) ajp^1m_M| V4)i TBGdž.Oդc`dܽyGL\/[C͟D9!yڬDNȴHTM=&w]&ʔr6~2^% \t:xߤN`\.|E1rNP oH g*yS ">E,\"h >KVK_0b˧Mւ~l?Һ Ig%X]>HsVk'.ź[# Vmv Çn*VIo\Uo@P2tqvw2V=PZvUZ;{3{U*osIO@UJ5 |2r&'a"+De>j^vJ#;ħ9xol&v[IufWqw{<]>7Q~d$ xAۺ}/ aF*4[kYTs@Q3" d:M[0{@G4Ӷz0 F묠Ue48L,ȥ{ 9^k}\evŒsۀ*]$Al66FsJȫj]ڣk; =/'dغmXNzyýŏYolp6 *j$ T f52*~OJnTm9 Jt7Lfń eL$Ϸ`k|pˤ':M , 񓋘׉߬.yVF_r-,O~[Ϊ@ bcԵЗ^*Mf;t#z+GjI[j-|)޶<:V[>e+l,ЍCji<Kkc h EB Bm5rل~dľt1'ڟy5 t+W})y+uD"-1b!sv56G% Y $76F{ OWKKDgzu۸OER%MG ! l c hw*\`0.Yvu(06u%G߂r*pO\{9)ЋJi*P{"*<]2/n 5}pd?c~GT{f~h"ᦨj]H͊9J4~ހ62%lefoa.lKغzqC_|إSl.%UgxVE8u;Q@zIT raa"~ty{qS7XMy!:laS_**q$t@c!SoOǜ0 ܪY녶(N;Pd{ 9qeO4:goJ)ECg"Rǝt=&х@#[G+}Sk+xV 5Pcjwsf7GMe!ģ4޵hW3;>Z)9x<>Xo~ j&X)GֈRR!-. ^kWcpj^k,X6\ lJoK^l[^-c|vVꪰL٠Sd1"9Afܺ@?WQ/P'^E]>ðӪ4Yb&4:q [4egj$Ql%is4DlRF*ge:0u:-dQsĐ2aC4=-EP褿9w| ;̮`vM޸trEM.II"Z:) #"n?Gd5@f̔ZkAOJ;wHWsmPS = lz[p6}o.ƤD<4:{> Rutb^1Xq˳!kt>iࢧd7U GҜ' 20ͪ¤ɡ֡l 7RWc\}0B6ԇr +ጯ@ۅBe5?@DRM[]w,59:YXGSqz#dG NOZA~\Ge\ܽH *@GJVD 21|k0O^>n{W_&E%:`uT:~57T5?jl?ns%u5]2~?W[UNrsleà'hKq%H7- j mD}9]‘xTsߥ4픡VGd<d˻ bjޭ*GEZi$i\_S,>7.[y2R2g5(0w"8EWãę&c "8 {VvKgJ&8OAg \>Q1䀒,wN!<~9ULG˱;IEΟ>-\+lHiD`%q_$ ('e*_S;cZ_K5t.ai=?rJZIk*s&HHT3ΗZ俩Wm;]H=maN԰;zCI$CϾ.-$exn򀾝A ,9T8)b RMO\=aU&kZ^\jAf(U .$|M?Y ׈ce 8Gu`77&bt%Wv&x2k$@8<)|Y7]q\WM\m-np3c%0152[>Z9Lݨ7 My{A!ӟ#iZTHvZ5rVDesӺrW}Ǭs4pl+˟K`HRW(:NX;sH;`;z|jed>4Ka K >opU *rt^G %%yc7h5$8wl ֱ#? PloH \iV]-kW3(+DȍxWf~y)Q+6REvLiv sqٲ!/ YL- ;U~h?f ;Q1]WƑh?r w]ɫp:=&@q ^SV䚥Ɓڎ_nˮ\DzgոfO^d%gpA>krMXљ790:MTW`|f 7|sZ0*N4.wV\`!yUVELx`].*#ŀj&.F}]ݫ 3s'W6hB5?zCٙTWB[]6M& 5 T/YTfImM|(5&O\gX&0sRhjϼFea, /FIefJ&=$N2dQC8fU;1sU6Ty'G>m|YMO\ @el"^ԙ.!sh@+qpIa6wqTӺ^t }!GIshfS9j.uIz? ,oă }/9\Яlɿ4q "ǡm<+L˜HImiSGڱ3tB>̴!ZA `7?:(j/;[qslw{uS1|^LBS-J5i׉j6NbU~oi>p]q׶w7Y;] +oe:j%C̆Ժl@ xDH2.W[ S"r1'`ysf)¤!,NTn>Tc֢ҝDdVY]e^lix4'Ij<65[ qBycWʛ*/Η) |?|TA@UC}g w3ίOuC;ib4qU D_J.Uf xT|('y \+$7=lkJQD}[BlBp'[&5|Ř)~yW xNf\Ɓp*c![]R:$p>:{K?nk{@} 2o1a"sí} MH+ԕlp+e^Jd꛿O5;& PO4u!vNřX>WS:NX1L i>aϛzA7Hfnt_Mit4"s|?]*o{?Dn 'd -s-/&dH,ay,_( Og2Pٱr0h6qFC}(k͆# J>{F)&HlWZ#TB\/~$,C.^wF0(#:+I>b QΙҠJDk ;Yі٤ɍMHVGO[l6B/0*hVIx[evcF̚'ۇ} oGZJ\; on$Go8%zdg }guB`؍+!i_bʌ(lzd+O @ acrj{;@ >@ c_S[H, S5q4Uz6w{0OhYUlӄxIDݞ)cz@SmcQh}6,HtvmA=pbl$#Fj,hpkLز8{?/eloLQ<1ȂUx3(S0eŇQSd-4uz))!/@ePVdh"J:rG8bI׮/B30Y7CXȣSG8&AFRu(+9s76VX{Քw@,,@'VHB X!j%٪j 9 2VVr55$^JU% 뿎$Ol2,\Ĉ('hVʹ~j;RsQZ)jȾ%P!ݲXIb.Yrl2g`RR p:[p9QDEįtb6,TqS4ͤZ4t#lr竔 b>52 x .v}ĺ0lƍYeh:=}~9zĝ5|ќH%eů@aᒅHBNHfDgvR?-$(xl 4ի'ܣHV@4zM78IIW6;P<4?U[|cYoa-!pnoDqs8}[~Ho 4_ɤ+?9QUv4 &^H;')O:;U6HQÝMTm&1Ky얳cϳ:rG}c7`95Ÿ'^wT;^Kx!Gƌ6Y7r6tW#g<,  @s3h J.i1ʪ:V'B)^t$.o#U,Lv}xAX.a6l*tb?6lCAk!iLtssԳ&#-풿J.(%:a態$間ț:AQ/ @ i6غǬU! XC'[Gf+q;1^6Ìa&CFC7rGd:UF`D "PatJڴrF=2XB5G#nr)44{^+?C1s'ݗ bmfcr%4u갴}WަCDQZXcyd%vֵ pC"<h%` S8]+JR "#@f;|Y  i7/'a( ^`̭T?} w *+.vt,2ө\%B֢N \E4Gl)-ʯ"Bp/8u.O8 W0V1Vp('_!)ت#8ꉭ^̨`i?0ɿ8oȘGǷYEr$}FfF}$(BTZ{єZO%ً1b݄+4yM^kl|,+=yԺ# *yl*?u&}RA$FQ:l:қ~LNCL_IebfO{ъ3$jW8Ȋ~6buVPr!CboRSqOh6 1I9mY7ӠI'Kuկ` KLmPp2TF7y *Vn(QZ`tH`E՗7(܀"8c*(*+YFPeYc-2PVSP7&ZXiL6c5Wdg_a\4M[A41_Rajm4eLp-@-fM*x[=;Dn@[ɸ s=ą~#iSXN鯋#)Hd0fVZ;n Qt1R)[{}N: PƉ*Jh(ҫZ qZ⾥.9.7./k '۵I3b˸/R#U^QmT^3UM(M+E :3hr[v\سOjd#v|r>K i`?0iqp@>jQ%t586):VL7Pbps̆O: k'$N ݨ\Ͻ@Pq$@g\uN+p˶ig;hUbijX$U,nt^%-~is)!a3ʴ۞y G3yP?1ɜL ؔ+$ޏP'YtA8CZoY;eVm"{\JkTdu,)gHw&'b YE ŠU1swi⅊Jp-q-k?UXmjbiC"eβWۧQګ_Ԛ cGOg5W&vzzaNh$%Ss%U T 52_Tߵ [Lft.nş2T5PqԭвS@?QUsXqչ$J^f0K]7#4G+%,aΡKR;&=F Jbu"~^5f#?q~m#!¡jXyLz= TzֵM6Ra{5?oČP!mm0/|vh ݱL$is0/ynpN#E+sSZT׽*\VQ˺^O(%*Q 34 B?n8N$d(c& .E|Whp@\p<,!ߛ|MS==-g myƮPd4[@p} ^[ϧ!ܥsJOm5в+xc.Fb5K%?\x/P*LrCl&{NۥG[Z.Al)ebޤ{y%L-; $E7CvE>R=24vW W`Q/bHhڼ}te>vxȒJ`bJqa#21fl~$h IM&i;o8q#&rN&k(VE9!p?vGxnV+ "FJIr6c3a ﺣSn~zZXJlGl᧒!=xh DcِK%OJl;Z,5a HOrWYvdwͽ>)7 _ш2Z_d.VA$dM)Ih#oC2r3F =0A-,Ɂ-fy!\U놃^KDTY@ψ""&񌇾_Z|O W53h.Ѳ(Ƿ c Ob_ YZ