python3-libxml2-2.10.3-150500.5.23.1<>,Љg#p9|QAwhJq:i|PF0]Q+Za%.'vkTX#k:xԥKMak}ggfNa1 vD^kg5(F/G !j;%#y{QƵS}+B`AFYnӔU˜F5;A?d ' K $=^b x       T  a  p   &T  55s5(8C9C: CBFG H8 Il X|YZ[\ ]4 ^Gbcdeflu, v`wh x y5zCpython3-libxml22.10.3150500.5.23.1Python Bindings for libxml2-pythonThis package contains a module that permits applications written in the Python programming language to use the interface supplied by the libxml2 library to manipulate XML files. This library allows manipulation of XML files. It includes support for reading, modifying, and writing XML and HTML files. There is DTD support that includes parsing and validation even with complex DTDs, either at parse time or later once the document has been modified.g#h01-ch2dSUSE Linux Enterprise 15SUSE LLC MIThttps://www.suse.com/Unspecifiedhttps://gitlab.gnome.org/GNOME/libxml2linuxx86_64$$;UI}QHYA큤큤g#g#g#g#^gjg#g#g#bObOgg3729757a1347fc292366de7a96dee6a5d19a0a2ac026bedf743df4ef6aa88daf3729757a1347fc292366de7a96dee6a5d19a0a2ac026bedf743df4ef6aa88daf873fb884c63bb3b9706e35b67b728bea3d8aa8ec50b3de735d181f835b3a23a8873fb884c63bb3b9706e35b67b728bea3d8aa8ec50b3de735d181f835b3a23a8a5e89415342706ac6f6060034de1e3746d3e3599c205a01331432e7f5c604716e691801855738770e8555bd4f2cfbc5b41d00eea7da96bb44505755896e106e9b63ce49594dd534e47072f85a226dbaa1a486dbea9d1d284d2068d742dc9f4a8da3cf7928c51996a200bd8ff1fb5bf8e067110aae75f80faea8d5d20a4ec061bdddc7124866372807012c012687e2ddccbc44e90e70e3cabb7c7f9d625ba7e34c5016e56b110c3c2208c95af25071148014323c28658112821201ed9c96267e0bbf0522c50c093fb3f316ae3cd33547d7fbb0885855f6f4ccea78011a6846138f7c45183fc5f3aec2b9fb3d8e90c394b7f0c6f4d18841501a34c57113033eb5brootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootlibxml2-python-2.10.3-150500.5.23.1.src.rpmlibxml2-pythonlibxml2mod.cpython-36m-x86_64-linux-gnu.so()(64bit)python3-libxml2python3-libxml2(x86-64)python3-libxml2-python@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@     libc.so.6()(64bit)libc.so.6(GLIBC_2.14)(64bit)libc.so.6(GLIBC_2.2.5)(64bit)libc.so.6(GLIBC_2.28)(64bit)libc.so.6(GLIBC_2.3.4)(64bit)libc.so.6(GLIBC_2.4)(64bit)libpthread.so.0()(64bit)libpthread.so.0(GLIBC_2.2.5)(64bit)libpython3.6m.so.1.0()(64bit)libxml2-2libxml2.so.2()(64bit)libxml2.so.2(LIBXML2_2.4.30)(64bit)libxml2.so.2(LIBXML2_2.5.0)(64bit)libxml2.so.2(LIBXML2_2.5.2)(64bit)libxml2.so.2(LIBXML2_2.5.4)(64bit)libxml2.so.2(LIBXML2_2.5.6)(64bit)libxml2.so.2(LIBXML2_2.5.7)(64bit)libxml2.so.2(LIBXML2_2.5.8)(64bit)libxml2.so.2(LIBXML2_2.5.9)(64bit)libxml2.so.2(LIBXML2_2.6.0)(64bit)libxml2.so.2(LIBXML2_2.6.1)(64bit)libxml2.so.2(LIBXML2_2.6.10)(64bit)libxml2.so.2(LIBXML2_2.6.11)(64bit)libxml2.so.2(LIBXML2_2.6.12)(64bit)libxml2.so.2(LIBXML2_2.6.14)(64bit)libxml2.so.2(LIBXML2_2.6.15)(64bit)libxml2.so.2(LIBXML2_2.6.16)(64bit)libxml2.so.2(LIBXML2_2.6.17)(64bit)libxml2.so.2(LIBXML2_2.6.18)(64bit)libxml2.so.2(LIBXML2_2.6.2)(64bit)libxml2.so.2(LIBXML2_2.6.20)(64bit)libxml2.so.2(LIBXML2_2.6.21)(64bit)libxml2.so.2(LIBXML2_2.6.23)(64bit)libxml2.so.2(LIBXML2_2.6.25)(64bit)libxml2.so.2(LIBXML2_2.6.27)(64bit)libxml2.so.2(LIBXML2_2.6.28)(64bit)libxml2.so.2(LIBXML2_2.6.3)(64bit)libxml2.so.2(LIBXML2_2.6.5)(64bit)libxml2.so.2(LIBXML2_2.6.6)(64bit)libxml2.so.2(LIBXML2_2.6.8)(64bit)libxml2.so.2(LIBXML2_2.7.0)(64bit)libxml2.so.2(LIBXML2_2.7.3)(64bit)libxml2.so.2(LIBXML2_2.8.0)(64bit)libxml2.so.2(LIBXML2_2.9.0)(64bit)libxml2.so.2(LIBXML2_2.9.1)(64bit)libxml2.so.2(LIBXML2_2.9.11)(64bit)python(abi)python3-extrasrpmlib(CompressedFileNames)rpmlib(FileDigests)rpmlib(PartialHardlinkSets)rpmlib(PayloadFilesHavePrefix)rpmlib(PayloadIsXz)2.10.33.63.0.4-14.6.0-14.0.4-14.0-15.2-14.14.3gjgf|ee@e?ddBzdBzd?c_cIO@cc cd@b)bob4t@b'E@ap`!@`!@`` @`N@`N@`N@`4@_H@_G@__V ^V@^oj@^oj@^l@] @]߶]Γ@]v>]D%]B@]A]@\s\LKZZZ@Z@Y@Y*@YéYéY)@YBvYA%@Y"XWXWH6W>@W(VTQ@TWn@TWn@TSyTApgajdos@suse.compgajdos@suse.comdavid.anes@suse.comdavid.anes@suse.comdavid.anes@suse.comdavid.anes@suse.comdavid.anes@suse.comdavid.anes@suse.comdaniel.garcia@suse.comdavid.anes@suse.combjorn.lie@gmail.compmonreal@suse.combjorn.lie@gmail.combjorn.lie@gmail.comdavid.anes@suse.comdavid.anes@suse.comdimstar@opensuse.orgluc14n0@opensuse.orgmcepl@suse.compmonreal@suse.comrpm@fthiessen.depmonreal@suse.compmonreal@suse.compmonreal@suse.compmonreal@suse.compmonreal@suse.comwicked@iki.fipmonreal@suse.compmonreal@suse.comcode@bnavigator.depmonreal@suse.compmonrealgonzalez@suse.compmonrealgonzalez@suse.comtchvatal@suse.comtchvatal@suse.comstefan.bruens@rwth-aachen.depmonrealgonzalez@suse.compmonrealgonzalez@suse.comtchvatal@suse.comtchvatal@suse.comtchvatal@suse.compmonrealgonzalez@suse.compmonrealgonzalez@suse.compmonrealgonzalez@suse.commgorse@suse.comkukuk@suse.detchvatal@suse.comaavindraa@gmail.comaavindraa@gmail.comjmatejek@suse.comjmatejek@suse.comjengelh@inai.detchvatal@suse.comtchvatal@suse.compmonrealgonzalez@suse.compmonrealgonzalez@suse.compmonrealgonzalez@suse.compmonrealgonzalez@suse.comkstreitova@suse.compsimons@suse.comkstreitova@suse.comsflees@suse.derpm@fthiessen.devcizek@suse.comvcizek@suse.comvcizek@suse.comvcizek@suse.com- security update - added patches fix CVE-2024-56171 [bsc#1237363], use-after-free in xmlSchemaIDCFillNodeTables and xmlSchemaBubbleIDCNodeTables in xmlschemas.c + libxml2-CVE-2024-56171.patch fix CVE-2025-24928 [bsc#1237370], stack-based buffer overflow in xmlSnprintfElements in valid.c + libxml2-CVE-2025-24928.patch fix CVE-2025-27113 [bsc#1237418], NULL Pointer Dereference in libxml2 xmlPatMatch + libxml2-CVE-2025-27113.patch- security update - added patches fix CVE-2022-49043 [bsc#1236460], use-after-free in xmlXIncludeAddNode + libxml2-CVE-2022-49043.patch- Security fix (CVE-2024-34459, bsc#1224282) buffer over-read in xmlHTMLPrintFileContext in xmllint.c * Added libxml2-CVE-2024-34459.patch- Security fix (CVE-2024-25062, bsc#1219576) use-after-free in XMLReader * Added libxml2-CVE-2024-25062.patch- Security update: * [CVE-2023-45322, bsc#1216129] use-after-free in xmlUnlinkNode() in tree.c - Added file libxml2-CVE-2023-45322.patch- Security update: * [CVE-2023-39615, bsc#1214768] Crafted xml can cause global buffer overflow - Added file libxml2-CVE-2023-39615.patch- Security update: * [CVE-2023-29469, bsc#1210412] Hashing of empty dict strings isn't deterministic - Added patch libxml2-CVE-2023-29469.patch * [CVE-CVE-2023-28484, bsc#1210411] NULL dereference in xmlSchemaFixupComplexType - Added patch libxml2-CVE-2023-28484-1.patch - Added patch libxml2-CVE-2023-28484-2.patch- Remove unneeded dependency (bsc#1209918).- Build also for modern python version (jsc#PED-68)- Add W3C conformance tests to the testsuite (bsc#1204585): * Added file xmlts20080827.tar.gz- Update to version 2.10.3 (bsc#1204366, CVE-2022-40303, bsc#1204367, CVE-2022-40304): + Security: - [CVE-2022-40304] Fix dict corruption caused by entity reference cycles - [CVE-2022-40303] Fix integer overflows with XML_PARSE_HUGE - Fix overflow check in SAX2.c + Build system: cmake: Set SOVERSION - Rebase patches with quilt.- Build for now with --with-legacy to enable APIs that have been deprecated recently. (bsc#1202965)- Update to version 2.10.2: * Improvements: + Remove set-but-unused variable in xmlXPathScanName + Silence -Warray-bounds warning * Build system + build: require automake-1.16.3 or later + Remove generated files from distribution * Test suite: Don't create missing.xml when running testapi - Add configure --with-python=%{__python3} inbefore python build, as upstream no longer ships pre-grenerated files. - Use sed to fix env-script-interpreter in documentation example. - Pass with-ftp to configure, build ftp support.- Update to version 2.10.1: * Regressions: Fix xmlCtxtReadDoc with encoding * Bug fixes: Fix HTML parser with threads and --without-legacy * Build system: + Fix build with Python 3.10 + cmake: Disable version script on macOS + Remove Makefile rule to build testapi.c * Documentation: + Switch back to HTML output for API documentation + Port doc/examples/index.py to Python 3 + Fix order of exports in libxml2-api.xml + Remove libxml2-refs.xml- Update to 2.10.0: * Security + [CVE-2022-2309] Reset nsNr in xmlCtxtReset + Reserve byte for NUL terminator and report errors consistently in xmlBuf and xmlBuffer + Fix missing NUL terminators in xmlBuf and xmlBuffer functions + Fix integer overflow in xmlBufferDump() + xmlBufAvail() should return length without including a byte for NUL terminator + Fix ownership of xmlNodePtr & xmlAttrPtr fields in xmlSetTreeDoc() + Use xmlNewDocText in xmlXIncludeCopyRange + Fix use-after-free bugs when calling xmlTextReaderClose() before xmlFreeTextReader() on post-validating parser + Use UPDATE_COMPAT() consistently in buf.c + fix: xmlXPathParserContext could be double-delete in OOM case. * Removals and deprecations + Disable XPointer location support by default + Remove outdated xml2Conf.sh + Deprecate module init and cleanup functions + Remove obsolete XML Software Autoupdate (XSA) file + Remove DOCBparser + Remove obsolete Python test framework + Remove broken VxWorks support + Remove broken Mac OS 9 support + Remove broken bakefile support + Remove broken Visual Studio 2010 support + Remove broken Windows CE support + Deprecate IDREF-related functions in valid.h + Deprecate legacy functions + Disable legacy support by default + Deprecate all functions in nanoftp.h + Disable FTP support by default + Add XML_DEPRECATED macro + Remove elfgcchack.h * Regressions + Skip incorrectly opened HTML comments + Restore behavior of htmlDocContentDumpFormatOutput() * Bug fixes + Fix memory leak with invalid XSD + Make XPath depth check work with recursive invocations + Fix memory leak in xmlLoadEntityContent error path + Avoid double-free if malloc fails in inputPush + Properly fold whitespace around the QName value when validating an XSD schema. + Add whitespace folding for some atomic data types that it's missing on. + Don't add IDs containing unexpanded entity references * Improvements + Avoid calling xmlSetTreeDoc + Simplify xmlFreeNode + Don't reset nsDef when changing node content + Fix unintended fall-through in xmlNodeAddContentLen + Remove unused xmlBuf functions + Implement xpath1() XPointer scheme + Add configuration flag for XPointer locations support + Fix compiler warnings in Python code + Mark more static data as `const` + Make xmlStaticCopyNode non-recursive + Clean up encoding switching code + Simplify recursive pthread mutex + Use non-recursive mutex in dict.c + Fix parser progress checks + Avoid arithmetic on freed pointers + Improve buffer allocation scheme + Remove unneeded #includes + Add support for some non-standard escapes in regular expressions. + htmlParseComment: handle abruptly-closed comments + Add let variable tag support + Add value-of tag support + Remove useless call to xmlRelaxNGCleanupTypes + Don't include ICU headers in public headers + Update `xmlStrlen()` to use POSIX / ISO C `strlen()` + Fix unused variable warnings with disabled features + Only warn on invalid redeclarations of predefined entities + Remove unneeded code in xmlreader.c + Rework validation context flags * Portability + Use NAN/INFINITY if available to init XPath NaN/Inf + Fix Python tests on macOS + Fix xmlCleanupThreads on Windows + Fix reinitialization of library on Windows + Don't mix declarations and code in runtest.c + Use portable python shebangs + Use critical sections as mutex on Windows + Don't set HAVE_WIN32_THREADS in win32config.h + Use stdint.h with newer MSVC + Remove cruft from win32config.h + Remove isinf/isnan emulation in win32config.h + Always fopen files with "rb" + Remove __DJGPP__ checks + Remove useless __CYGWIN__ checks * Build system + Don't autogenerate doc/examples/Makefile.am + cmake: Install libxml.m4 on UNIX-like platforms + cmake: Use symbol versioning on UNIX-like platforms + Port genUnicode.py to Python 3 + Port gentest.py to Python 3 + cmake: Fix build without thread support + cmake: Install documentation in CMAKE_INSTALL_DOCDIR + cmake: Remove non needed files in docs dir + configure: move XML_PRIVATE_LIBS after WIN32_EXTRA_LIBADD is set + Move local Autoconf macros into m4 directory + Use XML_PRIVATE_LIBS in libxml2_la_LIBADD + Update libxml-2.0-uninstalled.pc.in + Remove LIBS from XML_PRIVATE_LIBS + Add WIN32_EXTRA_LIBADD to XML_PRIVATE_LIBS + Don't overlink executables + cmake: Adjust paths for UNIX or UNIX-like target systems + build: Make use of variables in libxml's pkg-config file + Avoid obsolescent `test -a` constructs + Move AM_MAINTAINER_MODE to AM section + configure.ac: make AM_SILENT_RULES([yes]) unconditional + Streamline documentation installation + Don't try to recreate COPYING symlink + Detect libm using libtool's macros + configure.ac: disable static libraries by default + python/Makefile.am: nest python docs in $(docdir) + python/Makefile.am: rely on global AM_INIT_AUTOMAKE + Makefile.am: install examples more idiomatically + configure.ac: remove useless AC_SUBST + Respect `--sysconfdir` in source files + Ignore configure backup file created by recent autoreconf too + Only install *.html and *.c example files + Remove --with-html-dir option + Rework documentation build system + Remove old website + Use AM_PATH_PYTHON/PKG_CHECK_MODULES for python bindings + Update genChRanges.py + Update build_glob.py + Remove ICONV_CONST test + Remove obsolete AC_HEADER checks + Don't check for standard C89 library functions + Don't check for standard C89 headers + Remove special configuration for certain maintainers * Test suite, CI + Disable network in API tests + testapi: remove leading slash from "/missing.xml" + Build Autotools CI tests out of source tree (VPATH) + Add --with-minimum build to CI tests + Fix warnings when testing --with-minimum build + cmake: Run all tests when threads are disabled + Also build CI tests with -Werror + Move doc/examples tests to new test suite + Simplify 'make check' targets + Fix schemas and relaxng tests + Remove unused result files + Allow missing result files in runtest + Move regexp tests to runtest + Move SVG tests to runtest.c + Move testModule to new test suite + Move testThreads to new test suite + Remove major parts of old test suite + Make testchar return an error on failure + Add CI job for static build + python/tests: open() relative to test scripts + Port some test scripts to Python 3 * Documentation + Improve documentation of tree manipulation API + Update xml2-config man page + Consolidate man pages + Rename xmlcatalog_man.xml + Make examples a standalone HTML page + Fix documentation in entities.c + Add note about optimization flags- Update to 2.9.14: * Security: + [CVE-2022-29824] Integer overflow in xmlBuf and xmlBuffer + Fix potential double-free in xmlXPtrStringRangeFunction + Fix memory leak in xmlFindCharEncodingHandler + Normalize XPath strings in-place + Prevent integer-overflow in htmlSkipBlankChars() and xmlSkipBlankChars() + Fix leak of xmlElementContent * Bug fixes: + Fix parsing of subtracted regex character classes + Fix recursion check in xinclude.c + Reset last error in xmlCleanupGlobals + Fix certain combinations of regex range quantifiers + Fix range quantifier on subregex * Improvements: + Fix recovery from invalid HTML start tags * Build system, portability: + Define LFS macros before including system headers + Initialize XPath floating-point globals + configure: check for icu DEFS + configure.ac: produce tar.xz only (GNOME policy) + CMakeLists.txt: Fix LIBXML_VERSION_NUMBER + Fix build with older Python versions + Fix --without-valid build- Build python bindings in a 2nd run, using multibuild: otherwise, libxml2 requires pkgconfig(libxml-2.0) to build, causing issues to bootstrap.- Update to version 2.9.13: * Security fixes: + [CVE-2022-23308] Use-after-free of ID and IDREF attributes (boo#1196490); + Several memory leaks and another issues. * Many regressions fixes. * Numerous bug fixes, including, among many others: + xmllint's --maxmem option should work as expected now; + xmllint now returns an error if arguments are missing. * Numerous tests and code and fuzzing fixes and improvements. * Updated documentation. - The full Libxml2 2.9.13 NEWS can be found here: https://download.gnome.org/sources/libxml2/2.9/\ libxml2-2.9.13.news. - Replace version-release macros in all 3 Obsoletes tag with plain 2.9.13 to avoid unwanted behaviors in the future. - Remove dropped upstream AUTHORS file from list of files to be installed in the documentation location with 'cp' command. - Update http://xmlsoft.org URL tag to Libxml2's new web home: https://gitlab.gnome.org/GNOME/libxml2. - Update ftp://xmlsoft.org Source tag to Libxml2's new download host: https://download.gnome.org. - Drop deprecated Python-2-related macro definitions/conditional statement from spec file. - Drop merged upstream patches: libxml2-fix-lxml-corrupted-subtree-structures.patch; libxml2-fix-regression-in-xmlNodeDumpOutputInternal.patch. - Drop libxml2.keyring source file as the new download host doesn't offer GPG signatures. - Use ldconfig_scriptlets macro for post(un) handling.- Rewrite package to the single-spec %python_subpackage_only style and eliminate unnecessary multibuild.- Fix python-lxml regression with libxml2 2.9.12: * Work around lxml API abuse: gitlab.gnome.org/GNOME/libxml2/issues/255 - Add upstream patches: * libxml2-fix-lxml-corrupted-subtree-structures.patch * libxml2-fix-regression-in-xmlNodeDumpOutputInternal.patch- Update to version 2.9.12 * Fix CVE-2021-3541, CVE-2021-3537 (bsc#1185698, bsc#1185879), CVE-2021-3518, CVE-2021-3517, CVE-2021-3516, CVE-2020-7595, CVE-2019-20388, CVE-2020-24977, and CVE-2019-19956 (bsc#1159928) * Fix null deref in legacy SAX1 parser * Fix handling of unexpected EOF in xmlParseContent * Fix user-after-free * Validate UTF8 in xmlEncodeEntities * Fix memory leak in xmlParseElementMixedContentDecl * Fix integer overflow in xmlSchemaGetParticleTotalRangeMin * Fix SEGV in xmlSAXParseFileWithData * Don't process siblings of root in xmlXIncludeProcess * Full changes: http://xmlsoft.org/news.html - Drop upstream fixed * libxml2-CVE-2021-3541.patch * libxml2-CVE-2021-3537.patch * libxml2-CVE-2021-3518.patch * libxml2-CVE-2021-3517.patch * libxml2-CVE-2021-3516.patch * libxml2-CVE-2020-7595.patch * libxml2-CVE-2019-20388.patch * libxml2-CVE-2020-24977.patch * libxml2-CVE-2019-19956.patch * libxml2-python39.patch * libxml2-Avoid-quadratic-checking-of-identity-constraints.patch - Drop since 2.9.10 merged libxml2-xmlFreeNodeList-recursive.patch - Drop since 2.8.0 merged fix-perl.diff - Refresh libxml2-make-XPATH_MAX_NODESET_LENGTH-configurable.patch- Security fix: [bsc#1186015, CVE-2021-3541] * Exponential entity expansion attack bypasses all existing protection mechanisms. - Add libxml2-CVE-2021-3541.patch- Security fix: [bsc#1185698, CVE-2021-3537] * NULL pointer dereference in valid.c:xmlValidBuildAContentModel * Add libxml2-CVE-2021-3537.patch- Security fix: [bsc#1185408, CVE-2021-3518] * Fix use-after-free in xinclude.c:xmlXIncludeDoProcess() * Add libxml2-CVE-2021-3518.patch- Security fix: [bsc#1185410, CVE-2021-3517] * Fix heap-based buffer overflow in entities.c:xmlEncodeEntitiesInternal() * Add libxml2-CVE-2021-3517.patch- Security fix: [bsc#1185409, CVE-2021-3516] * Fix use-after-free in entities.c:xmlEncodeEntitiesInternal() * Add libxml2-CVE-2021-3516.patch- Fails to build against Python 3.9: * Add upstream commit that fixes the issue https://github.com/GNOME/libxml2/commit/e4fb36841800038c289997432ca547c9bfef9db1 - Add patch libxml2-python39.patch- Security fix: [bsc#1161521, CVE-2019-20388] * Memory leak in xmlSchemaPreRun in xmlschemas.c - Add libxml2-CVE-2019-20388.patch- Avoid quadratic checking of identity-constraints: [bsc#1178823] * key/unique/keyref schema attributes currently use qudratic loops to check their various constraints (that keys are unique and that keyrefs refer to existing keys). * This fix uses a hash table to avoid the quadratic behaviour. - Add libxml2-Avoid-quadratic-checking-of-identity-constraints.patch- Make python subpackage ready for multiple python3 flavors gh#openSUSE/python-rpm-macros#66- Security fix: [bsc#1176179, CVE-2020-24977] * xmllint: global-buffer-overflow in xmlEncodeEntitiesInternal - Add patch libxml2-CVE-2020-24977.patch- Fix invalid xmlns references since the fix for CVE-2019-19956 [bsc#1172021] - Revert upstream commit 5a02583c7e683896d84878bd90641d8d9b0d0549 * Add patch libxml2-CVE-2019-19956.patch- Security fix: [bsc#1161517, CVE-2020-7595] * xmlStringLenDecodeEntities in parser.c has an infinite loop in a certain end-of-file situation - Add libxml2-CVE-2020-7595.patch- Do not pull in the non-python deps on the python build- Revert the previous change and use multibuild to determine supported flavors. We need to be able to enable/disable pythons in prjconf and multibuild directly clashes with that.- Build python2 and python3 bindings in separate flavors. As python3-libxml2 is a dependency of e.g. itstools and thus many other packages these packages no longer have a build dependency on python2. Breaks a build loop for python2.- Since libxml2-2.9.10 perl-XML-LibXSLT fails to build: [bsc#1157450] * Revert upstream commit to make xmlFreeNodeList non-recursive https://github.com/GNOME/libxml2/commit/0762c9b69ba01628f72eada1c64ff3d361fb5716 - Add patch libxml2-xmlFreeNodeList-recursive.patch- Version update to 2.9.10: * Portability: + Fix exponent digits when running tests under old MSVC + Work around buggy ceil() function on AIX + Don't call printf with NULL string in runtest.c + Switched from unsigned long to ptrdiff_t in parser.c + timsort.h: support older GCCs + Make configure.ac work with older pkg-config * Bug Fixes: + Fix for conditional sections at end of document + Make sure that Python tests exit with error code + Audit memory error handling in xpath.c + Fix error code in xmlTextWriterStartDocument + Fix integer overflow when counting written bytes + Fix uninitialized memory access in HTML parser + Fix memory leak in xmlSchemaValAtomicType + Disallow conditional sections in internal subset + Fix use-after-free in xmlTextReaderFreeNodeList + Fix Regextests + Fix empty branch in regex + Fix integer overflow in entity recursion check + Don't read external entities or XIncludes from stdin + Fix Schema determinism check of ##other namespaces + Fix potential null deref in xmlSchemaIDCFillNodeTables + Fix potential memory leak in xmlBufBackToBuffer + Fix error message when processing XIncludes with fallbacks + Fix memory leak in xmlRegEpxFromParse + 14:00 is a valid timezone for xs:dateTime + Fix memory leak in xmlParseBalancedChunkMemoryRecover + Fix potential null deref in xmlRelaxNGParsePatterns + Misleading error message with xs:{min|max}Inclusive + Fix memory leak in xmlXIncludeLoadTxt + Partial fix for comparison of xs:durations + Fix null deref in xmlreader buffer + Fix unability to RelaxNG-validate grammar with choice-based name class + Fix unability to validate ambiguously constructed interleave for RelaxNG + Fix possible null dereference in xmlXPathIdFunction + fix memory leak in xmlAllocOutputBuffer + Fix unsigned int overflow + dict.h: gcc 2.95 doesn't allow multiple storage classes + Fix another code path in xmlParseQName + Make sure that xmlParseQName returns NULL in error case + Fix build without reader but with pattern + Fix memory leak in xmlAllocOutputBufferInternal error path + Fix unsigned integer overflow + Fix return value of xmlOutputBufferWrite + Fix parser termination from "Double hyphen within comment" error + Fix call stack overflow in xmlFreePattern + Fix null deref in previous commit + Fix memory leaks in xmlXPathParseNameComplex error paths + Check for integer overflow in xmlXPtrEvalChildSeq + Fix xmllint dump of XPath namespace nodes + Fix float casts in xmlXPathSubstringFunction + Fix null deref in xmlregexp error path + Fix null pointer dereference in xmlTextReaderReadOuterXml + Fix memory leaks in xmlParseStartTag2 error paths + Fix memory leak in xmlSAX2StartElement + Fix commit "Memory leak in xmlFreeID (xmlreader.c)" + Fix NULL pointer deref in xmlTextReaderValidateEntity + Memory leak in xmlFreeTextReader + Memory leak in xmlFreeID (xmlreader.c) * Improvements: + Propagate memory errors in valuePush + Propagate memory errors in xmlXPathCompExprAdd + Make xmlFreeDocElementContent non-recursive + Avoid ignored attribute warnings under GCC + Make xmlDumpElementContent non-recursive + Make apibuild.py ignore ATTRIBUTE_NO_SANITIZE + Mark xmlExp* symbols as removed + Make xmlParseConditionalSections non-recursive + Adjust expected error in Python tests + Make xmlTextReaderFreeNodeList non-recursive + Make xmlFreeNodeList non-recursive + Make xmlParseContent and xmlParseElement non-recursive + Remove executable bit from non-executable files + Fix expected output of test/schemas/any4 + Optimize build instructions in README + xml2-config.in: Output CFLAGS and LIBS on the same line + xml2-config: Add a --dynamic switch to print only shared libraries + Annotate functions with __attribute__((no_sanitize)) + Fix warnings when compiling without reader or push parser + Remove unused member `doc` in xmlSaveCtxt + Limit recursion depth in xmlXPathCompOpEvalPredicate + Remove -Wno-array-bounds + Remove unreachable code in xmlXPathCountFunction + Improve XPath predicate and filter evaluation + Limit recursion depth in xmlXPathOptimizeExpression + Disable hash randomization when fuzzing + Optional recursion limit when parsing XPath expressions + Optional recursion limit when evaluating XPath expressions + Use break statements in xmlXPathCompOpEval + Optional XPath operation limit + Fix compilation with --with-minimum + Check XPath stack after calling functions + Remove debug printf in xmlreader.c + Always define LIBXML_THREAD_ENABLED when enabled + Fix unused function warning in testapi.c + Remove unneeded function pointer casts + Fix -Wcast-function-type warnings (GCC 8) + Fix -Wformat-truncation warnings (GCC 8) * Cleanups: + Rebuild docs + Disable xmlExp regex code + Remove redundant code in xmlRelaxNGValidateState + Remove redundant code in xmlXPathCompRelationalExpr - Rebase patch fix-perl.diff- Do not depend on setuptools to keep the depgraph small and avoid build cycles- Use python[23]-libmxl2 as python names not python-libxml2-python which is kinda confusing- Do not ship libtool archive anymore- Enable tests also in the python subpackages- Added a new configurable variable XPATH_DEFAULT_MAX_NODESET_LENGTH to avoid nodeset limit when processing large XML files [bsc#1135123] * Added libxml2-make-XPATH_MAX_NODESET_LENGTH-configurable.patch- Merge python-libxml2-python spec and changes files into the libxml2 ones using _multibuild [bsc#1126499, bsc#1123919]- Version update to 2.9.9: * Security: + CVE-2018-9251 CVE-2018-14567 Fix infinite loop in LZMA decompression (boo#1088279 boo#1105166). + CVE-2018-14404 Fix nullptr deref with XPath logic ops (boo#1102046). * Bug fixes: + Fix building relative URIs + Problem with data in interleave in RelaxNG validation + Fix memory leak in xmlSwitchInputEncodingInt error path + Set doc on element obtained from freeElems + Fix HTML serialization with UTF-8 encoding + Use actual doc in xmlTextReaderRead*Xml + Unlink node before freeing it in xmlSAX2StartElement + Check return value of nodePush in xmlSAX2StartElement + Free input buffer in xmlHaltParser + Reset HTML parser input pointers on encoding failure + Fix xmlSchemaValidCtxtPtr reuse memory leak + Fix xmlTextReaderNext with preparsed document + HTML noscript should not close p + Don't change context node in xmlXPathRoot * Improvements: + Remove redefined starts and defines inside include elements + Allow choice within choice in nameClass in RELAX NG + Look inside divs for starts and defines inside include + Add newlines to 'xmllint --xpath' output + Don't include SAX.h from globals.h + Support xmlTextReaderNextSibling w/o preparsed doc + Improve restoring of context size and position + Simplify and harden nodeset filtering + Avoid unnecessary backups of the context node + Fix inconsistency in xmlXPathIsInf - Add libxml2-python3-string-null-check.patch: fix NULL pointer dereference when parsing invalid data (bsc#1065270 glgo#libxml2!15).).- Use %license instead of %doc [bsc#1082318]- Version update to 2.9.8: * Various -Werror fixes and compilation updates as travis is now used by upstream * Few additional tests added for ICU operations - Drop patch python3.6-verify_fd.patch merged upstream- Version update to 2.9.7 release: * Bug Fixes: + xmlcatalog: restore ability to query system catalog easily + Fix comparison of nodesets to strings * Improvements: + Add Makefile rules to rebuild HTML man pages + Remove generated file python/setup.py from version control + Fix mixed decls and code in timsort.h + Rework handling of return values in thread tests + Fix unused variable warnings in testrecurse + Fix -Wimplicit-fallthrough warnings + Upgrade timsort.h to latest revision + Fix a couple of warnings in dict.c and threads.c + Fix unused variable warnings in nanohttp.c + Don't include winsock2.h in xmllint.c + Use __linux__ macro in generated code * Portability: + Add declaration for DllMain + Fix preprocessor conditional in threads.h + Fix macro redefinition warning + many Windows specific improvements * Documentation: + xmlcatalog: refresh man page wrt. quering system catalog easily - Includes bug fixes from 2.9.6: * Fix XPath stack frame logic * Report undefined XPath variable error message * Fix regression with librsvg * Handle more invalid entity values in recovery mode * Fix structured validation errors * Fix memory leak in LZMA decompressor * Set memory limit for LZMA decompression * Handle illegal entity values in recovery mode * Fix debug dump of streaming XPath expressions * Fix memory leak in nanoftp * Fix memory leaks in SAX1 parser - Drop libxml2-bug787941.patch * upstreamed in 3157cf4e53c03bc3da604472c015c63141907db8- clean with spec-cleaner- libxml2-python3-unicode-errors.patch: work around an issue with libxml2 supplied error strings being undecodable UTF-8 (bsc#1065270)- convert to singlespec, build a python 3 version - change build instructions to use setup.py (and %python_build macros) instead of makefile-based approach - add python3.6-verify_fd.patch that fixes libxml2 on python 3.6 - rename to python-libxml2-python to conform to package naming policy (PyPI name is "libxml2-python")- Update package summaries and RPM groups. Trim descriptions for size on secondary subpackages. Replace install call by a commonly-used macro.- Add patch to fix TW integration: * libxml2-bug787941.patch- Version update to 2.9.5 release: * Merged all the previous cve fixes that were patched in * Few small tweaks - Remove merged patches: * libxml2-CVE-2016-4658.patch * libxml2-CVE-2017-0663.patch * libxml2-CVE-2017-5969.patch * libxml2-CVE-2017-9047.patch * libxml2-CVE-2017-9048.patch * libxml2-CVE-2017-9049.patch * libxml2-2.9.4-fix_attribute_decoding.patch- Security fix: * libxml2-CVE-2017-0663.patch [bsc#1044337, CVE-2017-0663] * Fix Heap buffer overflow in xmlAddID- Security fix: * libxml2-CVE-2017-5969.patch [bsc#1024989, CVE-2017-5969] * Fix NULL pointer deref in xmlDumpElementContent- Security fixes: * libxml2-CVE-2017-9049.patch [bsc#1039066] * heap-based buffer overflow (xmlDictComputeFastKey func) * libxml2-CVE-2017-9048.patch [bsc#1039063] * stack overflow vulnerability (xmlSnprintfElementContent func) * libxml2-CVE-2017-9047.patch [bsc#1039064] * stack overflow vulnerability (xmlSnprintfElementContent func)- Added libxml2-CVE-2016-4658.patch: Disallow namespace nodes in XPointer ranges. Namespace nodes must be copied to avoid use-after-free errors. But they don't necessarily have a physical representation in a document, so simply disallow them in XPointer ranges [bsc#1005544] [CVE-2016-4658]- add libxml2-2.9.4-fix_attribute_decoding.patch to fix attribute decoding during XML schema validation [bnc#983288]- Update libxml2 to version libxml2-2.9.4. The new version is resistant against CVE-2016-3627, CVE-2016-1833, CVE-2016-1835, CVE-2016-1837, CVE-2016-1836, CVE-2016-1839, CVE-2016-1838, CVE-2016-1840, CVE-2016-4483, CVE-2016-1834, CVE-2016-3705, and CVE-2016-1762. - Remove obsolete patches libxml2-2.9.1-CVE-2016-3627.patch, 0001-Add-missing-increments-of-recursion-depth-counter-to.patch, and libxml2-2.9.3-bogus_UTF-8_encoding_error.patch.- add libxml2-2.9.3-bogus_UTF-8_encoding_error.patch to fix XML push parser that fails with bogus UTF-8 encoding error when multi-byte character in large CDATA section is split across buffer [bnc#962796]- Add libxml2-2.9.1-CVE-2016-3627.patch to fix stack exhaustion while parsing certain XML files in recovery mode (CVE-2016-3627, bnc#972335). - Add 0001-Add-missing-increments-of-recursion-depth-counter-to.patch to improve protection against Billion Laughs Attack (bnc#975947).- Update to new upstream release 2.9.3 (bsc#954429): * Fixes for CVE-2015-8035, CVE-2015-7942, CVE-2015-7941, CVE-2015-1819, CVE-2015-7497, CVE-2015-7498, CVE-2015-5312, CVE-2015-7499, CVE-2015-7500 and CVE-2015-8242 * And other bugfixes - Removed upstream fixed patches: * libxml2-dont_initialize_catalog.patch * 0001-Fix-missing-entities-after-CVE-2014-3660-fix.patch * 0002-Adding-example-from-bugs-738805-to-regression-tests.patch- fix a missing entities after CVE-2014-3660 fix (https://bugzilla.gnome.org/show_bug.cgi?id=738805) * added patches: 0001-Fix-missing-entities-after-CVE-2014-3660-fix.patch 0002-Adding-example-from-bugs-738805-to-regression-tests.patch- fix a regression in libxml2 2.9.2 * https://bugzilla.redhat.com/show_bug.cgi?id=1153753 - add libxml2-dont_initialize_catalog.patch- update to 2.9.2 * drop libxml2-CVE-2014-3660.patch (upstream) * add keyring to verify tarball Security: Fix for CVE-2014-3660 billion laugh variant CVE-2014-0191 Do not fetch external parameter entities Improvements: win32/libxml2.def.src after rebuild in doc elfgcchack.h: more legacy needs xmlSAX2StartElement() and xmlSAX2EndElement() elfgcchack.h: add xmlXPathNodeEval and xmlXPathSetContextNode Provide cmake module Fix a couple of issues raised by make dist Fix and add const qualifiers Preparing for upcoming release of 2.9.2 Fix zlib and lzma libraries check via command line wrong error column in structured error when parsing end tag doc/news.html: small update to avoid line join while generating NEWS. Add methods for python3 iterator Support element node traversal in document fragments xmlNodeSetName: Allow setting the name to a substring of the currently set name Added macros for argument casts adding init calls to xml and html Read parsing entry points Get rid of 'REPLACEMENT CHARACTER' Unicode chars in xmlschemas.c Implement choice for name classes on attributes Two small namespace tweaks xmllint --memory should fail on empty files Cast encoding name to char pointer to match arg type- fix for CVE-2014-3660 (bnc#901546) * denial of service via recursive entity expansion (related to billion laughs) * added libxml2-CVE-2014-3660.patchlibxml2-pythonpython3-libxml2-pythonh01-ch2d 1740148771 2.10.3-150500.5.23.12.10.3-150500.5.23.12.10.3-150500.5.23.12.10.3-150500.5.23.12.9.132.9.13drv_libxml2.cpython-36.opt-1.pycdrv_libxml2.cpython-36.pyclibxml2.cpython-36.opt-1.pyclibxml2.cpython-36.pycdrv_libxml2.pylibxml2.pylibxml2_python-2.10.3-py3.6.egg-infolibxml2mod.cpython-36m-x86_64-linux-gnu.sopython3-libxml2READMETODOapibuild.pylibxml2class.txt/usr/lib64/python3.6/site-packages/__pycache__//usr/lib64/python3.6/site-packages//usr/share/doc/packages//usr/share/doc/packages/python3-libxml2/-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:37638/SUSE_SLE-15-SP5_Update/22a33bf60f73267ffcd30a87c58b49cf-libxml2.SUSE_SLE-15-SP5_Update:pythondrpmxz5x86_64-suse-linuxpython 3.6 byte-compiledPython script, ISO-8859 text executablePython script, ASCII text executableASCII textELF 64-bit LSB shared object, x86-64, version 1 (SYSV), dynamically linked, BuildID[sha1]=1cb72f68778df7bf5b9579a399beb567def80f91, strippeddirectory/R.R.R.R.R.R.R.PRRRRRRR!R,R(R#RRR"R&RRR RR+RRR)R'RR-RRRRRR*RR%RR R RRR R$RR RRR TAe0[{utf-84d1a33f3b39eda89f96e64979c540d753be7f71bf500fdea11c653b71955bd07?7zXZ !t/O2]"k%a Ó\Ǩ//TJ j6nsU΂kFݹ78E4&sǬo.8" $?[3kIL1gA YSXziK7)rQҿ{ҏ]qH15y^LO$xmɬveƤDP~,0?!߮0k6Xڦ(2Q0$o,5reA.̲>Te <^>Ue3 @Sh{"db0ء Vat؀أn%P=KAeCYknX:ÛVHC(m?Qĭ~CYvZw86.CƣԊMCKQX sNT, O'O^^o̹cd2_YĥU V++v0D1^`-@=E@ۧ1 f U$kM #I~=eܐ%( tVt.! {s8 ~#CkNXy1xQFƓi`Ӽ`Fum^{9==780:^E8 P^c.2'&Q7\]%`lzw6|jbŲw`ųu~\~FvLeWvfr\fp<A4`)Cyb"k NMu v~c&6B!s;hIbQBVԬs(m>Tds vkd?Z))=b nqk#(>悢*p4ړ3  ukʒ.HGR UmkZ8O\Y;w%E '\{_BX0VTx1 ߡIhaaZs]第 D,C7mC[}S 5ڽn>HTx9*ѻ2> l.ԍ㗉˕% |SE}`2W5l=F ٽ}X=a% /W?3D[V(?D7 !z̤!/kJ幁W[ SRV'-] )4[ƷX`).`q竿`Ӏ=QשĠұў L7Szǘ5̞=ögiUa[*ޗgJ΍{.]ZVX"W5CNuYv㔥tq{"I5ǘߊ+[iƃI9Ǖuo܋(&QB '3~YczDL+ɜ a:YQS}~߉tLLZH0Sƀf1mRGup[G2@e%%#hP>Eό,GrX7Klod}B]u;tiuKiX!JQ{A^o}CO4Xۑ[zDm #_Zok̓n܊떙 y f34 ݞh͡[S"ۑāYn>{#0Pp$Z)Z}-1j8 սP_ʃmG֋$o[BUE<}EO2_uxrOVƊY9A`@e2`.kƵjSTƘ#+&N6&}3BqwE6B{<z<)ʴS L*z͑5Uk-Nn%tsKnWw)հ)}!8o+]);ɰ<f\acy=`>[G` ]{]r `EQ\~3II+x湞Ū}'Bd]ѩ~4̸3c}.O 9ŠL \Hh68\P?S$J%PP*e&}MCM'gF8 K4Y 뜜0[\ &W\@*b mϲ"ȓ (.=oNѯpcQ(Opw wbܰ,hZ:YzXD>-1.ڨQuʞE,j v.SN1%_0s +u cU2oj.Qpoj 8٘\P @p@շ^oAfSCaHVYh0)L' 3]J^ ٤?BnP$弶H%|_hʡ-jM\V)nPU]`׈N<;iQ^ UCan,\fF ּ!WG֡#eכem`]kdeˏ»6 l3>;{ģѧbD+" K~_ a3j[e-D`3r~HMP !B_Ӑ9<׷OX+dP:Oӽv;p)OhP,iBSwNԳӠb0V;_0I[bbdskR1qpqmu|v䀬 @̓'[8Q__'Tmp܉)˺'ɝ4L3-m1}\`9!0JḞ"gI1ˑ4Wx5\:Aw&t<ҬhH}6(zo v𘬶YbȬ@hWh(k62rd>BM>`4Q}*JgAVyd^ BjL&ȽzX4Y5uD|L .*&s*~_!Q?~I̸i=3F/[oQIoEi6Aɿӏer駞/Js *oDϘ(ơy*!a҄Ϯ#<8,ԕ7Nr|Ս3(bnr"' ^p@CM:;lzؤ@l`˗(:G۷8:v6(ZQB^Ռ,TvEj-&=2LGx|]S)r}"dDȃ!:-/B+AVm\E!-j2Wv pyxrF"((,?<\P׽Wm%lγq#( ف>?sjЖ}0jR<ºp3eB|_au"tAcS> HoY @B,]Q;/+|Edj5 Ge."'@w ,"v)V$PL" >,K~ Wtm]X頀L ؾZrwb(ÁMc 93ivl67Mo ^y8kV2]uqҐn \@[S v S•⍼*_ (S2Sfi:ْcg^Sha=\R{}L -`bX5ӭq&F,+#¦#vv'OFa1ϐ:Uʪ9K<# $>ێe'B "\cWCUAT;U>7m"qe[i_]f@[ g*- )o);S`tl9Rz^|#ٙSɚ]| `@ؿ6 >o;!ʧ17X .F`Z)z+VGc492X:,ՈwގsOLARqAU}1YN<.,p[KȾE@M]*54 '|@C̼q_o-Zi[EXr\ۀAboN)&:ip@<ŝN,QZQP*^xν$]SБ\+= `(}4=ܚY#6!vF![f6Uk94i ^٭u?V 7*<2!mӪdal$m *$ 嵊3ۻg\޷U5X@Ϯj sxoamJA "eOJ/)O.H^tqC1j46Z? +cY%ŧK^%vdf"x¦w5ﰪ*F$̲?40^~ߵ9Ⱦ'"_G%7U{emѽoqqY0edgsìBpG\ R$&LVo?;(bQ=VPg~ίe;an"zM<=c5@aҫ0SB0Th 5GoI cɤ/:`~\|%=Umg!Ɯ:Xlj`C,;JR.ˏ#k6C_WN u)22P0"Db?h87(دrS {nw,Y%w 9YPեqZ17C V ᙒk]Be-x a &1|z3;ḿC X1ާ0qx.@7"fYضT%vS7xc'%N|R).PWu!i(\#kC!wj&^}R] n [6"GH'1Ie-`N@Ovk \*͛QuH>Owx &j49\iMHx&D*ˠې֝q3+iJ(:/Q-e 5Q Ha[ӭjy߽>o5ڱD8*nO?e䏭9cCaCي9kn9# _0m1URH]Sp2$% XboE˫Xc'k*w ;pŧP,xeƹa,oқp!XfA(m<%o20rupG!Q+]8V3oմsNF(Y/NA) B5VgKGew%-I;dGI \ TszG׹'tG6cK75eCw~diM͡0O YOA|hu9J <JaӤakɹ[T eaJ*۷~+aW :!sxKtkNqX 4V/'y ㈥+T(U@Mv{lMFdu{3@|)8;؏K{zckVos<"Ev n:SOͣit~CWlpsp`IÒc0UcamN깱Oy,9,ZQ eV6,h/O5z)b*LMHxTdAhU9 ~:ōҝ_ƏKlZ-GvSA_zԥ׃G#dI"dW) -9Tbҋ1" DB;=G%m(^6.P'Y$+\:_F;@;|:ـumYd7.2C^m:v`Ƌ=jgAnv3xK`Tt>4-6^Fw ʿ S5SP>σi3-r&51}B'==; aJ'4H?({O_Vz U'JNS}Ii|:]W(Id&&q(00() ji% pmE Z9wS4?+6<+HqOJhG)WN )\ Y Hr]l}bniˑ*>]-aV>6+ 旛1\eamO,^ FafJ=P̎f-:$bpͮY^2f3`4=_~iB=RS6 kiA1O1S|#5 w,6CBi޻OğO"*PǤ#݇A:T { w"9Uܴ;m6!sc5Po[ݙz͚goAmwTV $ͣ ,LYyhzqX"ߜa ]8"]E^9y5#S0q5iԀJ#5!.\rQ7c9T=ʯ:/\ut|Ί ߵ~5p^85[bhmcgnn ipJȂ [ɼY$IYU=XL)p!L3/-bǶGr 0RhB5Fh 'w*F0ԝH*fEV%Em. !0$A{L{uR,7Ii bn*~ÕBJ-y-^JxsUwx"yfş{Q c_x DDX B!?;K&>~O$a,0[>uZ+[گ9G;:sLS;GbgD?*LUC>ν q\P'h.Fme4M!kv"mS<}@JdM|fIЈ2S+L'W4w[vQΎ fx漭V;%ޖW6'k̓7㛣k[=ͤԓθ)jN9F$02p;QEސg\Ī*OIMNp f vlQm z*R==?y<ڜG՗ŐwC ֲMNlY*)7ߚULt t{@KDg5d|w>[/@rfv?Y)bE/þPZ)6GxkDN'jލA2fV9NO7yeeyDZ7R@;vRws$m_v{5Weq8D$ahYbyn&Qe0Zk2+bv: 3] NTgQlt2: nO{aj܋w'Q}T1h#Pd4i@KTCӺ. '%-A(QفafV,~ĺ?όߘj"j¶ry /B)gMhh^ IVX F+f٩rqDH,9Raۗȴ( XAeD5Qgu_-6sJ ߑCdN@mxnުs W2:*V^zwZ*c+0v ,\UTW6ŻcY(7I 5̵Z;8 hY#(B샲< Ui"GZ_&ĄX_X~FKg>")ؗC-{L7`/{~,x)9^WDORF E/;N[rEr뮽 pO)Kؿ6o]E>fW(!DL5gF޸ؔm|ȇo(i3՛BrB]mw:zVb$~loT"<?`MY6B `6(Z9ᛘme0s?uSVw3`t'z):fxʗ͂(0ti:@(B"Obm|;\ceQ^C9fm)mD\,| )3wh?qш7[zmtb0 Pc}$\ !YJ֕owOZ-Hchv> 028 gO/P:tߨ>,KAAW0Rcw8;2,PuabU2Gʿ>prgReR` 鰇c11JsQ?@jǼp\M*i.fa1 t{nWU^h!UEsJHm&J !vI>媯9Z~bed),JCf@H0a1 V݇^=DG+0Զ&rhvE˃jG'U\6/SIקѲ^k-WMSGN/#5pw@yk3;E,|id}:+h;p9`>I!܎ɓ}?rpSRǭp /ُv] [S|)6ؖЂwz.UnE0ZEb]O]<&g\2f Bjy޽MAQm.;wBb1xuԵ'2^bIi;0V"99c] AWM ܊XdŐ،-2»H6T@` y:*ӳxq{_>puj+_o.Sb*Sp{NS.=YcȾ ~gAu :w6r(|XLK7X y99~m}7rZ y" x#,oG%E]ۇ=:[nYr{*B(q E騟0gH)Mqшd 7LkgEe u+] NC)S9,gh'!2W%IC` ]yl.W]<4ՙ#[4݋2*3sζu?(pލ,lqBBJnaYƗ7[Ql-vvM4GmCM{l, &l]OmLkwfќd$ч}a{HUfr@n5 zm#oCwFj=Qd[&~fSjq[I0>Qfxj <(T;e YwoٖKr0+ WwɈDۏ&^u0dZuFFV|,~ {n޾ە'I͈LoUC[_=w>DES+4bdZjbx5+(_¿ijʕn>j #\f^OJ9XʔY dٚWUcsWaKגnn!?rʏ뻠|'C{HV^|q@fE+"8$* n3Uq'WTqK*-qZz0T;Bx!EwMC[u Rtԋ9ųkRZ*'^ Mf_\I{mü+S@9'W0"K/K}Tf>YvWyLTV`,9}KF w|d9*plk!GנJ3g:gàګN;v)ʢC~jD2`,NcXM PKLaV^UQ[=Yu 7pYS@):EEb0̏jD :<C(PIٗ)-$PC,?p*d2x._*:S(<V}`{J`׋U@I0]e2®VE" M!o7T| mײC )GZh1>3 MK,4VZoezg~:]X1EM cV$5Ύo7AlXŮHq)o"@}͉]MUT,NH!EtoZYF5к!&Uldr,繑2vT'11G 2!FŁ?lJdz*`n%@1Շ .\w N>#w|_| [7|Gr?$ya3266n1eCoOw(]*Ģi# $4M F;4 3B *5PoE BFeѸVP)H'_{FI:K5~ 9Aw]%5e '0%[nA5;$V}[Ǟ4@)gEPC]u@Ǥ؞z\؏a z94:4Q`,ٜ]Y^,1qnZyȿ8Cǂ0 [Js835L&(a Tv>/XiYWȑC7.I^p7K~{xfCB?C0n^iY^r]kZ#q4% >tL5Gm֌f`ޯ!mNI֫*x)Vz2*IK,bL'?p[;.zn@^紓Ya(SDdb5<kO2`*}_e'f^z(upcQ.tu .tDWXYN1' D罁шLM(ؤR}Ldܤ eq<ߓO<|5I>@sΞ5uEC,wC/Isz1>S+ʸH,4]rS4a05CC\F{:Q_*Ԭ?Yu<- b TytkSbR].$-%B|0r2ewZ6c| RP\ ODі?ilx堵Er+QdN=R8:Mnyԉb $ Y\poy0ҙ/ԏ1;w 14$}+UB+)A~AȘE9_eF3@P>hU"X& K#C/dևbSnECyQUY">ߍK+v~VCaZ?:ѺԳ^ӗz&uR3#9Vl(j!"Z+fnhc 0~!ؒtNBc}9#S_m3[ucɩoTxyߤC4K}7r)D{΍i ]텢Z k)ޞ$VuW MyAg IO0Dr1ĩ ܻItX l\Ǣ~ ;6R?>c%9ۣu0",:~uA6rMf9E8Ofa|Īq]﹪zY?%U6Ǻa^竄A-1nGƳ6/`I3!Xێ$h#4mɓ3',#kzX bP諲.꾯ޕۯ G HxJ UAI.j3)! o}P'_j$uxޑ?QD|<`o,FpCq^*%Yj ynieb|DxI }LN2rz#nPM]$XdE#S0؍2|/ؗםJL~^!X;PB5x]CVHKbHUtqݯ% K~+P̽ؔlP~[8 m{2>3ؼv΃_]իLpK%ě%Df;# chm}zSg,0Hҏ͔٦1ޮӬ抶O35,2EJ@3TP:sdzeĒe'֐趔D[rF3)Aܥ Y.B4}y'tladIs>}nt-3o!FȚbאtm*皑gB%Aܧ4Eo*1R((1D߱&5>tXϭ`OOfs$ \ِWkhXD`/[hV_?\jH@Ş OS@.7" |.שO²BŃޤ70XFRLU;ԒIKGG* j.dKٔ~H%`s1LnIְ䂃+ 8RbC0ԝ(6-Tjn֍1lׅYII=G܁.ذGT\,” WYs I,%WlgHS''h:TQ/YsqgU6z.Acc%sɘyoZuΑ 9pt Q&U{R}IK M_rA2maH8ni3I7azd%x(H6-Xlf{{)⣅Ĩ"PxڕmӮky1"ScK}}Nv;)^vdW$Hd龗Ucr?C:?TVe}bF_|ieRYB@蚸&‹A068hv.0yJpmeBpS)]g {'QJeA: QuT I$Wi5}i% yxؚ]3SAWOD&69#޽xCl@+N/Z&eh-3gO=̑}=ᴫV;ktОSp|zAlK gX|/2w!PKE36?G1'#\5YoiƆEIG9xk(`s[YȐ^U3ٮgtAa,ʶىk2Ʉ`)R鼻]>jlE 8-\*ZsMTJY4K2$] 2 G3͉֗Y$r?@\ UgQh,3DB2^`#ΪN)ˑ4;r^ :7'HIs:7&kl ~C{ xj4j TnzC.~G.cLs$V68 GVnUԇnM;{` /?>bIL  γasp|;${[oO~Kag'ߐߒvvT-D</l_cI.İengdt4OxAP !PsÛPSÐ N/C(U'< gDG&4:o zXlȭR~kǰ7½XBFD+7s? MI[8yز ՍeuvlubM_2hV&^ܹW&1{F@ cʪ#[P=?Vf!$wbb>;'kVM__ցm+^'nޕ1{\oKȚVs}dv7>y_ia>]>٥dμx\d6mKǞm9wuI v"d ɘ &lZoZArlhԛ5*1Q!Qr󒌹Qb!& #:oC5h ֝=2sRߑ!n:Ñ !,hUS|C>l5 =` >e|q^s䔹[XQMZ"={5yM< 2Bh/dPJ-],62-Rޫ% 98UdLK|Z}n*WOg`8y Р*82WuBO塂]Ke{7T߀=U%zHeSb[]|R)wf!o)A^ȷf(ImoJWN4 z"9<&!rָC=lJARq_<}?X?' MF@ĉ. ('\H?Ή(pIU~& ^qC@-=zs!k ctQP{^KIo>x|q3ȫ)Y1/ѡw~/t2DJdaeEov slN|b+ 4 Yf v 58q6z~I՞4=zUaU8f+| k>Ӂu'/*z xP!7{٬$6dĸ3QÙ#L@8\𜻾@}! t7}ܝFp1։*VĞr>&:x٩3R\1%Tcͬ٢⊷>;pvÝL =7Ck- (J|/UKn}>IGW6~2XѓUde_+ώ,X R/$=-,)=Y*#},ofL?NUSTߜ)Θ60B>mE਑'(qp([6'[/ks%MA-DvJv،V[{~K XP&bb hٗ?JPK7T8} f6x:/~Z$r3M(@WvD ;JLQQz^BRO]ozHãGmQ=ԹJ+6aֽ61s&*VzƗXuLT:1 $nFt"o;ώ۞Kk: 1SoD}?!>WXPj"J0W̧ `p @ TCXCvOtzƂg+^|`9]Y1J HzIU*ǓKM:G o[.d=(`={&YJO$}2LQ&e+Ų;c]΃gHFhtZu,<_.\Pk)ɳv@@gAd ;35UX.<|1KZmP3AάQDTV_8AvNsv|^FgfPEҐj m1OdYEڙA8}lpHpZq[?I[ɣN#ڷN>vq~ p3q=vD{P}iW[mD12GxMl%f5*?5U=I`{:5L_8=^{,^w|xYNsC2j0,4Hu*6c%l-LVf'8tah蔴t斈_Å_< ޠ'i5:9PM8^{XhRgNзJw-@iW TMA{Eɿ|7+ ÒΛ?!.@6ͅSnoق[@=h]?NğACY^TSG+@b*wsA~L0*4B,,P xO Q7]fQ}awaKFvFR$̩yca#xG -?t w (i1-JR[R.v8gTJ a28m9wf+4)^N޳joez4g},K;&Fh^ԡ -թZf7a^}BSf۴̌B%{atfHs-K=;3 t"w4n=(Gl/|pܥgO#UBKz+>\{^9Nq=b[v㦹 J:;Z}@?,F2XeI{#Fej#!lwqf ,BIOj A!Q PQt1>_F_@BՠRY="\Yguۅ)BmWn*=eY?ky_'<~T;rPCR;^>)$.+]vU'=<lbRY%V~q[+ȵYy[#% ,Q$'}l;IBc7RSD߮ljČf2٢%4"Lƒ#+et@sm [Y=[Կ6wvT2wժHS_\`_i";m̝XŖm^1%EMzC#{xzWYK,;'R*#fKcˋac'S''>8wYqk |<n J]#B GٟDG'J2cu`E8lDM]L(geKྛ$'mt ,uڝ3 "8 'Szr#DHI"΁). O<;4QG,oFAz[rqkGt>5E3xW!:խ?$cqԿ! SS)؍S؂7[zn"k<8OzmZB~"'_ 3/uXm,5^IF>d v7{*1sjzs<`i"RNsԓMWTrŽ.]6x@3 "3hsoPI2`*F!xΝ@Θa9&mմU>&q(sOȯsM(*3(0c9t0ogxXwIoѥY{N :qxb/=jFsPç%S f&ez/lvGChs=+s!.(`ȍբsv?G0G2eGt&%Ş%Hլ—::>ɿ ^.QSf"ni:_[dtcwHD0j·6^!uGCZ"Ϫ-H݂ &6hz%$—9(ѐ-ҹ RˣV<"]W159@R;:o*75]Rq2a~PxnFd5bv -녘%qgF!OL΂h +!AZaS-&@/8w,Lr(V>g&$fl>`WrgcZ~iQjI%#l/(#\TYOR_BmSKtd<,R(wekQp2 n[;2E|#C?:HA)?зf'yd1{$ֳ6Cꦋe[$y#c;dc:̬]Cݽ3#~ `{Gݺ;4Agm*).0w}3A+Frr>&}r B(2?nae$?C8T`dAcF m[sfJQN7C:$23ezQ@j1ti}Pƒ m]l̄L9VJڡKXLv6!fIoR"RsKaB]je)<?Hلc}<`0ȯ(zRԨF&uSȿbE4 &Stuyq<'qf?a."mLiSďq ='H"w*-@;#+e:6y.aioe ;l@8n\Cq`\tu)i 'z"6V82Yu2๮WFvޠK89zaK6&n1Gq{XY*sYbZ 9Y{atXn*B)mhe׿,}yqVwQ U,ƀb?1]gF!o% ^AK8Pp)):9':/L#sa:ZѸ%@T->Ns魊;@v,G֘FĖJVx&ɿJF} /&L;;Nenmru d{ȼۥ)i'>0-!zCTu T }Վ)+KUiuhD}0Nx U%k^NoyF vD!OɈS B+֒qo5 8SA6(4ksWWM<0q'jރ-mgi"QP[=R3أWJa6+**6r/F?pwevT@QJFYɣy 2ma|7H9E)< c;|/o "FSU!zggB C7-g"qLs[/}K|ID8If| 6n[Ol#@b+lh_7Ê_ܴqZ=7LFG_Gʓ VYCGcX܍]B>e]4. Ϫ?;>=6? L" JjͩwX"gm+K~X !<~}Yp{͝p 7zDž]dƝܵqgo (dL`{=߻g_H"[VKFe PKOЈe<Xdj:ލrP׾HPظu*ܙGi+B/R;6|WaYa!C8mG:HT3No]JPպGoALI8ORUpY7]Ti cw7#ʃ=ݯҍ$7y mYb:Z=-C\λw hrD,-rPc)7fmD(N/(X\Hf9n;X:nqb -znX]x' y Un{3g[A+TO'kKN:>K}^]UVSkC,0`Tkƾ;VWy 'j$x˭6W7AuI}̈g35P`'@z'wE^7 >9VD2Kԓ-b(+bR"#UI/gnm^יnC|hľ o`B 'MQhv32 U<mEj#SI,Ek7HAC+.x#k234_m=A 'OCU+i7BrgB q1<ϴGu_Mn-T7gb0Ns,1@G.\)Ml$qV$iRx; LLWct4I$g4W: $?S[<9o?SPfvr\tH:&}A X[#^I y] NXIn?.Sŋ*/#lXh!܍CbO 3f:ÈMcYv,l \#]J5Nxk1 Y9MdAj퇪XW,aNhRsυś))p-aZTkvbn.;vwA;ͪ]M*TNgz04pBtꋩ9pR$<-N:ݰ˕55΅K:gvlsܰ@=O@4IvU[!j/=2Ug渻^Ӝ.NܙJh!*&4:X?<1cc1-L3d͌tqߑ?ǶَO[P\;U, RB(dXR٧+V7$S?Y;Ň^QWwLw] [C#4X?~Ah+KyA]>E0Ҕ_J\=R;Hj 49z@E|YRHy UElE[x xȂp }bqETڝ,v9״ep຿W; '؜sl)L<(U0* ?ΩuʱWꏧ(y69 /epHֈ~SLcr$eܷHqx >e[̜KO1W_/I|fJU^mp<#QYwZW~(8>Z6Z|Q밝W%"P^nǬRҹCu3U/`%3=ƝzhSfjpn# jQI2]:gb N6ݻJ?A-x?{6QEo9ܯ )E1?z0:0FF68xӮg v 8[0ACa}rlͨ@<1MgI~F'fQyJ ڞB|ԗg XENd&_>/$>jD.OD|ЌӱcbywhS?墺r5 iF#+<0",I"tZɷ Fd #PyOvWqv>HKF5kYQj$0²+>sZ=ZM|);<մR]iXb(k9"F`#ɗIη˩K@Kd(u2|>J(,If:,:k'l {T=ddSBYnəmlACw%[bj8r%5#^aynV^|>IOw yCh7i|fЊu!5e`F2šs^LQ CP6b$&Z961A`=|[|I)/l XQm?qVѲ9obmzf̐gh 5VDĶU[3E%0)u'*@nJf!'5<9ήAzo0г)pP KdeEM  b3"=,ZzZw(K@ o~Rs?:i>vuUޞǥGX 4rQ'X{w֟:OԘ%I;Л)ɷE-PKedr-7"dlBa8)GœX{߄y8)R?9I¯a[1IDRE:sѭTA&;%Q)oY7{c[ymQ#2$S1g{g>Bu#̊X"i⯰AhwY6ekInWrI4[@6*K$voE l.Kii g}csՃ=Vehkk/_ ;tt+T0" (\Y3"ty43z GK3Ǹ\9~Ha92).qOcZKoգmgax&0JSJ璡4v+ؙ5aț=BG.Dm|eF}yITSµp"Йd ]ԮZ/jfI8l'3G#&P( U!E.\GFzĆh&Pe1=oml6Ue٣ reKF[6Cbt&n'sh`pH'Whvs̸rݸc_jJsWuhfȘ  u8ܖbK\j v8-h[GļN~lmr27[Y#J`ho^o0(nr;!ױйIZx?cKΛMn We'C=Ɏ\.'zBY-Qkӱx_[N#}3Ά2$GQ׹1YKHY޹^Se֌"|m[H6/jU,;4ːUp)T#\l[jy{? kz~\@2{ O/XD{a&K kJch*l~M..cLXѡ321!"֧f918.NΚ0@V<"ZP tH V t3 Jңk.aF7=z`8yCB j`zuk%p9_Btxy2n^|FC)`et;F#B YWꢮ9] jqݜIJgo?lR+#J`0!aVˎQ~o>b#CTr| |i+vzN޲兟u& E-73.M"깛{iʛsifyΆR#ZQtI? +4a_HOChݐcVovOt=xû>B`ԺpLZ^ve]f>H7w^#(( Ҩҁ!?{W%I';FN+0_:1 'jV0R`Aާ#ιnךDh>m7YF#f25gCmډVUiJXwB'tY3_Q,wtv"PɃ"]*=5 8T/xzC@$f'1-fbZo7t'C8q6I 'GH2e M#zh-fܘR~qF(IxMsz$;зi =I LWŽ>+ >wxz)R\gqME͘!  TIs|5aXuuSC M0w1=(xi1*dP\P] ֞bdLoE|b̓d(mOc821f-<^vHv|͞p dK!#Uod)Zp}i-" #׈{ClG|iس iٌٕpF5<%8S:ǏҘ¸l=q.b4|JQ*`ت[aްB߽+,:q;KCm?Y$E-ѰNk\HFwn gQ"(N:AQMOfq&< ĹDsa3Dşb9qp_#Z4ŽA;[j͇ tLTkYʷj$ sLx܂;XwyQ d `R⡱,5ؽmC0c@pde 9{O'o Bu3qV3mk%xU<V{<5kƘpdx,O#}PeQ-#oɊィ; Md}b 'S!D)p,Z&?c4 xkE$6B1cD)x=zըs.Eq0Ejb#z̓ʈ`M;sf/̻;kyȆ[XXbɔ1ڎn RZ8)'C1YX+{N';ʷ~}h4^{ɠDbw9dLVJ K5TU1S/ _/ jtȆZ%fwyYy|3X?4Gʋ;kGTc\m>\qfk%79U_M)W 9 cap #,u}7'o~L\0LXm֦5v0|Sy(;?zk*ƅcx&0܄ik#bn&Pr'ޒhvTI&-QLzr2o0jV Սz6.atF|}@ mb/f پ¡)2ȣ(u#ͨf>hKNm|g!=׎emu |_OI]5y7`W;_!8 % DZ%?[ɰl{xCBX9\b„pj`ST%UIDV` Q5t^NG(:S ͕ί"onRŶ嵛@x󡥃ǎ# H*'~ .2'=dn%F:YP2zb(*Z<>O*ʹ.NIOI-p#EުL!:h#u=vTRp0]#.nQx<܏s:RD=A2l) 9^ h/vwXycH9m/ݴ #v #g@2짣RbLJvZ+&ducDr"uF*d7/NY*+gcy3êP[w^4"QݹޭGmDE?v$qvV#$۫v' IGd f #30ڶ4Y':o9x8P#v[QGvN\~S.:5G6$0˽<9@{jf{m2xb]=o/ ELH@{ oYm|4TvBwo >`kAwSu7d <1jO\07')p,Y&|5yE< pu A١MDpaV\n]{g8 @*NU5ChE &i 6hY6qЪ!?&J֬gk".$r>=: BH>[{~$uyP⌚r~ܯ\Iˏ|Hpt^Z VKb֏JtinVxu}L5'aZM?f(y)n~'`Zi~k35-\?[N_+uZ'+O>x2a5ĜԺ_lжbn2>*D#t@͑!U5Ny+Y{l%<9&/Yi(!H-\XRq%SEUg5@: % ^3M;z)܋vl&-C 4d"%f *B $͑GyqQ#r+Q+#tLRCOĄ#ϼiOpċDT:|yNgw.o9Y|CvdsߙpWD@{*QPoeG.fIE}o ڻw03!z;GLX&^Ȕ)F =m- jQa}t?eZ*4ԆjkA! 1%Tir&£DԈ*7]'}N ‡>v|!})Əxp8#sf86Kc ibOہa4`Й ڟƾc15pӊ؄W4oa9 9uɄE6$ }j1&FNoe hp2V2Ǟ0n&P1i9/T=Q_]>~pkƒ 84ZYL2`^$6H`Mn.'sêLj!w;|~Rmb:.ZYUaT3(wqbhfN$n#tQLGO{\mLDxOZs K*z^]VÑCW9nX1HⴒdIU61a̻0Ű $VBmv{v1D1\gUZٚ~+F@wDO4;bܞkyd5tgRY8&^e]6g>k,9Bi{~(䟓eV#5 Jau{ h8i@lL,,™n0|̿()tkEϊ>8 t=ѼņD%Zp6 ±[-NŐaGw2QFp'(w.aEC7$V{%|72#atә'FsU#ӳ.=go#3ʞ ,SC:Gˍ:D8u;|Ҭu=v2 p{u#|& Rc̺Uhcm*t} .弐QfKZFl 8~EJ qVN7sCb:GBO\\V`j1~D=kvL@jqꍉD&|& $9Ibuaaenyz8Ro!:Ł&*t?)Dbh: Jv*WZQf_Έi@:4k(Xl ;РtX._]N~Y}*CD`- U?uQ6MѲU  ~wlk㈱鸯HoۛFu@INH5g9sYS!m/ƗIgϼ)ÉG"ƫq@~J׳V"db$6wBq0)QGF6[V/B /A_..0KM=3^pq2Ƌr?Fn7Nؖ%l@`> 4]c ӛ؇'vSKqu{9<55:f㤨#P;@3^s.2Je>2[ 5/TԳ!b<>g$tq-ho݁835t\+ ffGn|cp-^_-"tV5Ʈ^">&ؗа_[JE("p.Bj=(3ESvkx҂ C}W.]&"+M zo##g6㶛3u%;ۜ-̭S\ T+C_]c*YxIC(iݣ-E-xH7ՂD2Bz,|4ilvINx]$=$Ô}8~nD0kH$١R{'Kv /h_t])nau^0-*$j4{ҝْg iI&"m(P)|qYUWYׁ| ႈGEyZLYY]e]aվǹE>+WK[HFc#:<^afK4yrf%UqvĔ? B"+ `VȺI )\oV+J)n<~ j&b#g峛mMwUy`-J|;oۣnTգ| 5#SEECoPs,&ZMO\:4#I,F<чCd}P/K+}kC/"[3^-Ẳq"<Ց@I%ESe9535\;FU&oX >y.ةllE:}I]7s(él5Ŋ8HgXWP#zǗ#K=p"ͨwyRIkPww~?&=$IEז7WMA8!UdH YИsXtO&{C-p*У'XO(KYe;v#V\(V7_Q"*Pƻ[K|!PVh)}'8TDI^}u)C*^)5r|j "3Rp#28`JXD͔n_o? yt)JLYVΦ1#xu86o+pKIgV-u_45wZ01!Qw$;XC&xk1eꋄ ]7}ʬ8gptE MxtM@x=C!% NYӅYb4:.FR=:Jj2fmQK@VH/^ >5ɡHWg ?g| hI85O.>MX>^j]tgȳDދW{~"-^v]hdӞXP"ڨ¹hRK6wHTW@|a'$jM0CfA'v>7Jpf3 9L@͖2rn[0$+ 5C4pH,>H ε/o[cqtgxi?"nEyTUCة;GFHU\ Ŷ+䐣'9XXTHlO̗.){j>IjB8Yl"  x;$=M\1%I'ϝ5zf=57'Ď6N Raqb>g_0'|썹qqo\%IlXCtH?Օ''~jTp)#;m~|J[b@>y;YP1j`kqD8 [o'*ea.0hP0L"_://My Om?XU "Ic0N!  {",2ovr&D KN?ɋ6.M0L#_QkIrKw3fH oB5<̼zuJ0u%v¾f۟!&.V057{T,{XSyl sR/Kj n. LKGj w{3AA 07dĕ$P"u| B`[vws1 [POJ]'ȁfNl1w0[lL+"QzZp68",3o.lO`HRE`@1֮_SC!k>;R2t4Yi jPP]jX:Ns骪>AjeTDs]l 5A$˛#Nqc' 1 LE L/Yi|ʹ˂Фxj}=侘{,$_;R 5MMѩ' Z%;Ѳ#]El>=.n/)œtp+]RyqRokTw,6?bm"F%AfS.(Kw"7DMP}%gf:319;`Q]䘌X+=ͶJU>%V$RzJXg]wPIk0w }!n4{Q o)/f (bJ?D+DmZIzsO'r?6I2++ZBaiC`7r^.7M.t_9o5v\LRڡ!tѽuſ8w65-mpn :sqWt(*> R3/ !_mT泏'ՠr*F`N*HC|T!ȪWٹ=+W[_-*@+JTg.ghV}5'W#q x)m w؋xl֞rel%(_ Pd+8S ,^Xm̰]>.mF*4Xo8!UСjCCKԼQGo!0^2 oBHVX^,t^'Ԝw26J(*8ʺ׎u]x ev1 eF1vpK]GQ?8uvU& F^XC=@EOV&5ƭIpcOjE)4wﬞ'MQV{jHVa$iRMִU IAWZ%ICl7$j͕` )Bn&*WպS,}5U9J!g"vY}ј1Rvu2v ii[VY>W,)]S$h7v6fWoXFzth;WY:(^kcęqT=^#sF(QB= IXD.}$csIFOR˷hp rO']xJ!oRcą`5H U}|/Tp31n@sgYxZ fė+e0* (>G+-3-sV}ҹ@cy1p!ے>Q=;e8RtRRL֜s e9}sz&v&գWI(QÙ%z";p&fe(y@Y2n:=X ՜tfm׳K3sˢmlOQaEȔ1YrE( $%ԷSMhK:`vbe` :VaX1wj(IMR/U45&>658$T,_m-- Ukpҕh8=r(9Z,}2!R,Ճ֯^,&[.(ֈ|4趿~ uFDA-b@+Gus;F #w!J.T{Cekc hsCBG ,=Gus9g0$je9Èpɀ[3&e5 12(U (ch1Kam7ЪkP bǭD~r? qQSZv2z!#Y$+WzV1:P6yY󱜘x,(yglNI?١Pwa4`Sy>*ݪrVmoy4'iaa?i_0!ISj=;IRMtE;2XĘiR@طDӏRo. Y%|f/ #l{ cp|߳4% L٨oBP;m9ŝ4E"2|kS @C͖rZ!XYU?L%çc2:b0m. Θv|\^ d)9.e}|]!f|24J8Do(Hʑ8߃(5?.ɗ|^r&!AVU>S eOQa xVMEh{(2V5 /\;19@YYA@0o:2t7<&OqՉlikv:75]U |-#or2(٩gjK!nVh5Kmŝ.4+^K<pLD-C^.r* )Y1ۡ.-&M b)-$-4}Yvk#e=[VD&Rz⾽|B7Ab|e9%8yU_u@OC;)$_㺫M *bU1vM#Qa(u(/hz r`h!nx7Vːϑ *._ i֕s$e]C+9lb \J/f$LB?AMk!!H'C"%RI=ΈzEf,MzmZNy˲@IW.\[.~/L᷒8r 1pKXmH_yaCSuSmUA㰶-#sC}\=6D@Xe 3 _? Y$}qtyk, W5mfLzdqw~ƉJ4;K8Q~AJTlK! b?ڐEE Fˑ&)u<-49͔>&fCQOS9lSg!5o4z3*^'2j^q9/@a–=sH78p(Pjsfc2 TK:X=,{ɹ Q*%^SǠS˹E(ׇ Sr аA"p&BFڈ&Ǔ#Q=$ɫ^}Q|JGi&tcƪ`̂Ssu>Z^_ ވ9}t/-ӧ@`1$%$~; iBʲ͡FA%bR㬀>q3 x$73Y$)SI]b0^#,>V[k-׭伓8/ƝDȵOz/R|Gh4:SeOS$!FҞO @?8VjOUy:eiW(1~Lv{ar8Pyn9!n"@W8BiK،y=LR cߓso(b,eg$7 K&aA:/3 <dN{}%oD}4:]G֜oB?1a#og(Mt"2:붎ԖIۡ]JwLnBSõ'?vk``,qS<ρIҡs?(ԯyWkGhs,=3I4 !`CX@,xFZ]Ėa+`5QI D |RHAƮ:tJlh>ZDc:HBޱ+N0lo2{T;ψfhKuO" 7Q-ɇ~pgI#ic$smMx{-<)DJPGJ Ҍ{NYgVE#_ϥJK"gQ+wߊ :x: A!AoTe/ZIYTNAo.lݒ s8E~R`%CN'wruPu\tW>Ek-@\g"`h%_C;XD'3^glӊ%DԪ'yWߟb8-vD;NPP ^,n"TB O#g{UɏMWͺщeB!P " f#ꃘ b!d~>DD}=?v6ay\?1do2 ƻ#PegB[F.E"l#29O_M?OU}3nCyU2mc֩^6DkP&xGQ[0zo3!Uq,曎&{c g+D͕]Ѩ+nR^9T0HKUZn>+|KqˑԗR>x"Ģ!D輨Z+8ŠU.2 ݨ"xTku4v 5DK2c'v^dUt6e.}F(?5m t ;[=dЀ7t-!8a;\i8ȌxSH;ZjԔv뎂CX;f\ZO9Kr-> GA'B7YIaJyEN,oJ05Ѳz@FdMiRHthRp?T+AM)-_ }鼰>sZ.hR{q(P^qdM)Kw& vn  Tl;?CCnt:ۏ\Ѱ]Zcpl\0(=,By %ߙ 57 Q1Ăʕ@^nJƣka͕Sċ A pGiniBb8+o"|..ѝ@Ue3+_D| +q1K f&S̈́#63"Ya!2lƑrGWm[k>79TV%C7wٿ1Q0F&ً8;D q]fߌɭ󟌆ȁu@ KcN z[Vmo,mэ.'䍊3rz}sG~eAm/pk w4!鿘~P_nBEq] U9`rNd+Hfi[+l(+a;YآZqNrzA鳶lR2?0t졍dcw@1~/9vG}9Urg㝏6⤦D8j7خm0tL1i5>0f _QًB5xF[b|2Z `>Tkj .\Af6r#nd>>Ӥ vUD-c+a䡜#XPFlazr`˪{V'0`KX u8&}W݋"yn'IV iHuu`jta^l~}qpϞGI=6!^ VۚaxH}⟢4cu0bu-Z̀ѓWCBN}=K<.0psMʩpʳCŷWCFhr 2OYUfK/,~nИ:.Cj-Bpͥ!:?aFxǠT!/,Mw-LŎ#(7][qEcxDУˋJ}]@2T>N̒$4q¤%L LVݗWAɰ{:%,4jEv}A7̛$c^¦oEzcFK>m@Y/E/4d Fnc&cagGj?7}=kw*+'Tz6v/ ?ds| Z /@oMv|"m#QQc crN$C<穋@ײlP%aZa{:{ b%iO 2'q(xBkca~y9t"s7q*e[BwԑsiI˂D/u|oq+rc'㖙S Q/cѭBxp, i"Fm\x{>ro6V5 UGo 7G1=nvl֒E@c"ep .(+3:DθO^iCplFpFTP@:`pEI1e `.VAz1D1ජ66yy{b_k;irWSs[&=a7v &PiKK[Up2jA'MAoZ's/j\ bZ1<ճ/C -:#.ߔz`$si*wz4l_dW,7 Cc:UZO )z2;hLD) yemO jS; 13Hm L%IϸF@fuP?ˤ#(_B?8*^̍ ~MT(/cGsO]F4 tR)=bs";>ASм͑W@,^[W^ܔ젉VFA7aŹOHbKd!EPq܌*[n D|4Qդ DX-R. 6~P6>V֭7'p]  lە Rz_[_W/kŘR*"}0@5;n{Dk x$B٣?d]8?,Gz~)k6kb:ptKx;'UR0m4izgGW-H? g2pc(J!m~.xܨC>It;ZTizE(U ,ճ3q j0={cg7Fu)hGڛ_UK!:w%&de8!^-j4//\l=n`bWzl k" ޑX=<[a>~.>?tD`B EdDvF!)#LI fAH:%豠\farz|ݟ]8]#]8$ɸ4 uۨ / M [Ʋ4w`3[5I!4 Ewzu%Z jO X6+YtHGmFNu=7z2r)obI2fwr cGs缱z9_*ەQ YDf_-VK\yW L.jDZ5i~ҀxP[}hj#9^*iȜ$m菍 uG}A [s2rInư/DSz<-JQ:f?’?g1 &Ə϶\[0=(Քdm;I2x5հMQMhra&G:?(Y:|O+c g:(bxb^FNcûN9& 'slt- aʘxW}% VW+®\pءGBUwy: /ڃ6P7ei%_L ]>H*<0;1HOmoSuEŕqHKlo$$@nXނ1b)`.#8A@.y͛g L.N, >xƘt688حC~kx;ohK=ʥXbBִuC㕋 G8`5~KN#l`yp3ǜo..k7TR3nIשׂph<GϒeTRf6,sw-DsclពjDrж- 3fQn &:+a ; p<¬xRʱ#5`tN1wY'TZɝZvMx[F.G\yK g@ L!\[s.79XjqeB>%U{Xa)j1|o 767,hϊP\#ߧDBHKPp\,f68y[]q[fw+h%VXPDP63zPV V3>'.,)3]{= !1UA& R A_M8~5*. \\)@oDF\J~$W Ǽ53"ʧHH+~-aqQ5G=o/y-n[+'a̙26Ή[L34g)kPʫ/Am:2#t#P93]/|~Ge@aRpglݼ]\)a/kS$G{Č{w%Zz Mb]lZ[^B@m#@C"~`9%GzLPt@>nkq.WDwX֫2230a`ԳG;ovZ,RX fUԕN#{{ ,U(8<~d7 _ :^r0[ʛݭb%G|'XH\7@K59 .*K"fiKkiGx Gd|Q=' M'?`QOGj79B%;{_8t=u99Y,ճ ]`nGm ˆ U=ޠGlcX!o/Y݉P5R; &3O _~R״Swkp^`A=~7*};hl sު8G`cc^q)(4TPПfypvP06U0lQp!f2E8ފ^I?j( ܟ.h@(Y:~Mm[w^nu >H~*jv>|J՝WYe[Na- םI5_$CRCnFsHB\|eĺ*塲`1`2VLL?ٰwa:†.K l'2:*7G^rm#^}3kpksf^wռ*,/J+贺g%wzc ϑJR._jpx /2=ŵzDjڭjztx[:g^t$Z `~N М0ŲȂTè=z|z-k\ aUЄq<(r#U>s/SGinq& 3ѱ[-1QմQRG_la8!*GRpy쟏gzA X"~:(הt53B;fXVEq}x:M[lX#<O4*W$ ccs=W*&.7a@p=y ]ŸN>- uT7CǬK>ß0.@sQe@޻~ me9z(ҲPyR}ٙI̦wps̨qrأ%/Emͩ𴏄C̋9ohyQN T\M52a9>%uuViDtZ&f(Q9%;To)G.jUFp:0KVt)t#b݈a8ZKX6)WUhޟC 9{_W C0tiR=oܤ6[J&ī]d*\jd>+,! ȅax"UP,wȑYo=y ah5 DHIOb 0 GzMt q8h<{,xpK0Y|;NG*ۇqs8ecB5DmTŔ5e|̆`F)dMA-u+͊o>ܨ$Yl:I ~RnIWY:6寧rLCNnʥy!z'+/HY_%f )zXc OSW!砶*沵jdp39iUg^ekg"B͑K `c">3(do+c&_s( 6W:'e1u&yނ@}PlI-FpMO.75kl[M"K ,!>.6>KZgI+ͲI(@~)=n̴L0RuxV9tuO ug./B'*'h|M H6e@f``SPy3-~kuݮ8A4Dcw8! ^.`GX/ XiJƤ&)֓1 k)Q13/-zjJfC/?SGfc̖0|9ۨFQv{~AddP8 `TIKSݯog0paEBlF( { F=B"{iR8I\lؚ(1ى#vCt9]5G? -(Z]ǩУe0JCaƱΡ\]Cxg<׹gU{ד~ <JoXߥi1 `F28ϥ,=>]Z^ù4mLGxA\SRzժ4aP#W}4&Pk:L4N/ˡhJvl/xݏRx)[ :X̖lN ~ Zǿ1]<͎xPoX*ޕ:l'eYIN /5)bns {&)4䅛77_O? iScc Dz&=Ydc gr؂C}Ѱ^6=I-/ox4Lm "NC\Ld|R:aU&/5 i5aSwC'ܸf G-(kr q]hm i̋zFX62Χ0@tfsws8EXT"e.{7,.5@\;彖 '5}7}0,477{Q-Y@Tau+.yN ?=7s &[_9T*Wuu:pզS=_ 㘺C $pŹ6ķKl]yLoZ2® Qj aWvB-\ ߠ>“{u=TY$=Vj۸ ڐyҒ灢$h$BCH;(#{$dLfHG9 pZ) ݊@L&JC$ ڰv_Hw=FCi#åASvgzʋ 2 u1~qT6D~88!w# {C%0]Ghy'>Aó+W6l1( 71/`.k^-]j nADѩvlzI mllCF%2.5jWDD1AeHJP9kzn] v@\̊GJ}ZTbޯzHDA#ؒ m- 0o@)YC)׋,}֌l0\ЮW#n:x/z]A؇i|>{Zl8R$0hTp<5n#(_VR Օ[mf~cׂ;IU" (ѡ}%(o"{ے5Q+:XvDypS[^~@o= cQtFAȸڎ#Q'.\vH*h"b5"1Fmƒ!By4Ҿ)0Sפa8\LYj?kXL\jazZDXV鏏[nyN;uG+R,wYy'b_~f]g%v8ق ~&=x1 d$jW Yx0Ƭh$'|(Xc6>Խ x1ӝ2wt_;購: PB 9e4V);%H}Z)ucqf b=d¨4 bݏ,r#_]=í='<Acs1&6s fm~~ ԹMo6Af~wzlrif 0|Co@y =Ҹ]JOb< WgÑ)_ݐW64$gz{=)E~1[ITGG3U'rIw4i*ffotY"oRbmб\ZfkB\mK'*9B0RJq̎C #8~f;~b6S?&؊EP̂\SmfzZgL+3^NeKȋ"!#sIVymS]i-TV+~ޙ eV~ڐJ+&^0#!$@ʎÈ@޷枤 1KA\rGccs)?AjP`Zxё;,R \a%Wz-kX6\mR,;MJ.P_ xhp1ƾJ8%jmtTd.p3-ZޖExES.FaN՞8سb(W߈e=N "[ Tk>~g 84F՘l8J?zzv:0]ߜBٱ4/ nN$AV9uf#*:1OOQÎld] 6gt@^FZSŠmA]OF)NBB{~x*cհoH! F0%S?J2g&2@t/8Z%L@Fkcsq46 %,>Խ&7ԣ£w.B!@n՞ F q h(Ah!oT OGdgbr` 1܋@)jRʗ]jt84s;w Ae~j6 6>!407!znj~?OQur_ r:@ܨXȁ΋d?"E( L=3{\vͧh 5(V,?i%s\Eb7e>SgX0cJYN8gnZRs&ߧ_ 4(gf4Fu ?WZV/R*i8Ei<7g jg֨ߴOD>ŜVIz1 2ѠQkeǙ³Hj> H O1Po6-6b ڰuwt0{ƦB'8szv4H$V2Zզi7'?\ˁ ɌjmiCɓZ0}YEjTȲgq8!c=.'gz `t+@eǴ: Rߔ6Iq9X7%Io <]fJS&>o7Az0W[bu,СKʀ.!=ҝ١*5`d>8̾6'r%FͨSr%IWZ hďw; lQn!s Pk,T?^{+O"GS-PtXwb)jb.4ߓɒ h thmSkz/cCfiDs$,!<^:0["X% 7@9Gl,o8fHnmm)x֬:OኛRm"Fݣ|?C2NoNR$!o{v&%'g/ogyycOA򀥰z$~K'@j[ _߱է&O 郱н`ޱ0 C'c>˓c#CRƃ\mF/rR=u1q1jㄿ uK'q}=4?ռ R#?mAv-BӚ˗;Xd&izn}it2DRTOF>JD-{b>zx^XlVu髹sN*-Y9ΤLz1?fo0r9Zt Qq| KvU!t3 =׼rZ hXXO%G]ŘGZdIYhNPTGɀKOFSܕ( rGG.m/\ ]ylMV4n@1/^pN"*yҡ깐Re@(=1Bn.˻"UAؐ$ "Dv$LM,E^|5O}iWwELjQ}Ro4sƲ0f$ 6(tr&]37V+&Bjzz 2 y|mD%$O3vtXQbM+X`팭"֙3`{ d#żcJ2}X32l$։xBxS->,~j"QQaÙSj!~|!Dq/|p5bs~N*ܓ1Xl{ӏ- vok;$ %wvLa'btU(EȤd}P’!]sԺ8_e5\)v3o]jA_"Bq`9#^ |!RG~yyPB*0xD6^Q8p&3k n~:5(͙Ož~x= #,ɨd>0fuDQ6Ӻ,1oۧڷ @Mވ2ԯrVb~bs#jDX%JfE g0h+wolN0jnYX](:%+6,[Rۦy ')pLD[Xo-J}w;ydRN_=ա?XOv6-xg=繳{!ۢAdGݢD}w P% v XwTe?6ˏ8_zI\[r/-UG_f r5ZӖiˇ Cv_ivLOt.BmA7ȾX\iD4L[6>G2TN3ՠ'Mצ.LMTmi2nP!J}=bMaFBXĈ&3'U!b3s%{:,}%]p2#Ժ#L# >ٮUoTŊ_5DZ¹wu\"2 W%֣cC\Q`D'%x k@/)=<:գ؞'4h6=3[ZBU9#6XG4LNpϗHdit:5l4J2*-@Yz/w,~;цӻ^s$9Y$N3Öe:zQ:a| a}%e/2:(-` ٳ9,0Jp\# S]uMyfrH/>Z>` ^O7a%tɸ÷{WPg{eƫ~!ؾ9›gB*q }1 'E[z#ľWc,b^&m|n̸υ "D;%u$6[=7DY_~b| i/jߐg|Xۣʌ@BF$0YaࡘӾР{yN8R,׏]j+vd$b1ȸ}ZC (!ƎY^"Ufb铋?L7 LCk:M/'ՓbۡaW 8h%`?<|Ph +ZB12xupb/w9xmX,I Q|S%eBd巃%ys(7 ɫ!=f Ta^- hZC`^t<"m']G9:ZԿ0wǀ h&f`N\+r-QPNE@P~>[,U;Q^aG 'D#9 4ig'/ o~#h}ŨA@ECCɪe*"Ր ~'ȥQUńHG@wA orL@TQ'uh@HdECo\x)QP{"d8u {Hdn}̇fyGgI?h۱g.< S92&4'i2źRK)g$aaXvf@LKŕXg, cK gA4=`fm$|ӴPE=_^kS@:is@ gPpL<ߺDϿSAYvZBG%b_P#e7uI o*,8'b/݅lN#S/NIo|tݽ8Kg6|6n&n e*q/&?3چ0ܬo|=t#|pbYZ,W5٥"+p_oFk=ǨKS'\tCy e MO{J _(!]1IQXIWL۪޹ ;0C@SWHi˗/Rr'cF|XEPJ|נ“򂲱/wvHtAe@6ӏf- D$6]Pa\yf@jp 8:-kY'"[%9=%f$ . (r5Bۼ.Ԯ6s4 $|S zٰ:yWl0Ӓ]Bܿ @w¹O?sT85D$@VT\~q3A8{1>V\'†/,G Z]HQ,;݄: 擐c̥xDϏu=*|[.̂9l.7O4 ~Up 1Ǫȃo^0ѠK$'=@}W1q@J8Ύo%ȃbG%oV2&U:tm&"z܅TP'XI3=fAVRF M0j?mWhwŮQM$Zq^o=Gl=@PdMm9ЊGj8xnD}APW5pia?MsXXc ͎vo1LZkrczgΞ^? EYM"˯H>/)(B}3]5Nk;ܐsD:H8UW>Ҏc`m$P1 rh壔4^)y[pϋVu@"az99t.dPliI3LF# Dw J4RD喾4Yk!3fد6onh`d@7Qȕ6na~[).Id t/,ޫOXC:mO\]b- iJTTǎ1ˁ&T{jGCңC,5j-Qj59GԸoc]\{h%$-L 3 H;^/GJSt;eIMpT e$[>GpES&#.fجtQ.Pݣ], `K%vuntxwZK$,o;B]y-g/HdYԟmN5:^]EҦ^zc'\egzsKˍFeQ6p7E?싹7h QI s;K +tIy  )kSTdct\OAfuJ7\Zw g2=RgzUbwHllm< r)H,u1C}s_`w!e_M]U oxZ4VgKxQm'"j<zF*f8@G& ]XQW%p1A*ת- #t \ǤdCyO 34qw~k'oa%xD=mS0j k\-.-(^0H+FwhTdmmQ86.>2e,ѩ̀ Z֍4% ,ް_-{Ov^4"H-xce)Br49 Ia! viuH$:5B?7W5W~ͭ -x MIP*a+2 YZ