From 12a3499ca365756a77958d616423aca39a23234b Mon Sep 17 00:00:00 2001 From: Fire-Head Date: Thu, 7 May 2020 09:26:16 +0300 Subject: [PATCH] oal wav/mp3 stream update --- libsndfile/ChangeLog | 9764 +++++++++++++++++++++++++++ libsndfile/NEWS | 199 + libsndfile/dist/libsndfile-1.dll | Bin 0 -> 1679360 bytes libsndfile/include/sndfile.h | 857 +++ libsndfile/include/sndfile.hh | 446 ++ libsndfile/lib/libsndfile-1.def | 47 + libsndfile/lib/libsndfile-1.lib | Bin 0 -> 9948 bytes libsndfile/lib/pkgconfig/sndfile.pc | 12 + mpg123/dist/libmpg123.dll | Bin 0 -> 150528 bytes mpg123/include/mpg123.h | 1034 +++ mpg123/include/mpg123_pre.h | 40 + mpg123/lib/libmpg123.lib | Bin 0 -> 19996 bytes src/audio/oal/channel.cpp | 59 +- src/audio/oal/channel.h | 4 +- src/audio/oal/stream.cpp | 476 +- src/audio/oal/stream.h | 89 +- src/audio/sampman_oal.cpp | 71 +- src/core/common.h | 2 + src/core/re3.cpp | 14 + 19 files changed, 13007 insertions(+), 107 deletions(-) create mode 100644 libsndfile/ChangeLog create mode 100644 libsndfile/NEWS create mode 100644 libsndfile/dist/libsndfile-1.dll create mode 100644 libsndfile/include/sndfile.h create mode 100644 libsndfile/include/sndfile.hh create mode 100644 libsndfile/lib/libsndfile-1.def create mode 100644 libsndfile/lib/libsndfile-1.lib create mode 100644 libsndfile/lib/pkgconfig/sndfile.pc create mode 100644 mpg123/dist/libmpg123.dll create mode 100644 mpg123/include/mpg123.h create mode 100644 mpg123/include/mpg123_pre.h create mode 100644 mpg123/lib/libmpg123.lib diff --git a/libsndfile/ChangeLog b/libsndfile/ChangeLog new file mode 100644 index 00000000..62576177 --- /dev/null +++ b/libsndfile/ChangeLog @@ -0,0 +1,9764 @@ +2013-04-05 Erik de Castro Lopo + + * Makefile.am + Make sure checkprograms are built as part of 'make test-tarball'. + Closes: https://github.com/erikd/libsndfile/issues/37 + +2013-03-29 Erik de Castro Lopo + + * tests/dft_cmp.c + Fix a buffer overflow detected using GCC 4.8's -fsantiize=address runtime + error checking functionality. This was a buffer overflow in libsndfile's + test suite, not in the actual library code. + +2013-03-09 Erik de Castro Lopo + + * M4/gcc_version.m4 + Fix to work with OpenBSD's sed. + +2013-03-07 Erik de Castro Lopo + + * src/ALAC/alac_encoder.c + Patch from Michael Pruett (author of libaudiofile) to add correct byte + swapping for the mChannelLayoutTag field. + +2013-03-02 Erik de Castro Lopo + + * doc/bugs.html + Bugs should bt reported on the github issue tracker. + +2013-02-22 Erik de Castro Lopo + + * configure.ac + Improve sanitization of FLAC_CFLAGS value. + +2013-02-21 Erik de Castro Lopo + + * src/Makefile.am + Call python interpreter instead of using '#!' in script. Thanks to Jan + Stary for reporting this. + + * doc/index.html doc/FAQ.html + Make internal links relative. Patch from Jan Stary. + +2013-02-13 Erik de Castro Lopo + + * src/test_endswap.def src/test_endswap.tpl + Add tests for psf_put_be32() and psf_put_be64(). + + * src/sfendian.h src/test_endswap.(def|tpl) + Add functions psf_get_be(16|32|64) with tests. + These are needed for platforms where un-aligned accesses cause bus faults. + + * src/ALAC/ag_enc.c src/ALAC/alac_decoder.c + Replace all un-aligned accesses with safe alternatives. + Closes: https://github.com/erikd/libsndfile/issues/19 + +2013-02-12 Erik de Castro Lopo + + * src/sfendian.h + Add big endian versions of H2BE_16 and H2BE_32. + +2013-02-11 Erik de Castro Lopo + + * src/ALAC/ + Replace Apple endswap routines with ones from libsndfile. + + * merge from libsndfile-cart repo + Add ability to set and get a cart chunk with WAV and RF64. + Orignal patch by Chris Roberts required a number of + tweaks. + +2013-02-10 Erik de Castro Lopo + + * src/common.h + Bump SF_HEADER_LEN from 8192 to 12292, the value it was in the 1.0.25 + release. + +2013-02-09 Erik de Castro Lopo + + * src/alac.c + Fix segfault when encoding 8 channel files. + Closes: https://github.com/erikd/libsndfile/issues/30 + +2013-02-07 Erik de Castro Lopo + + * src/ALAC/EndianPortable.c + Fall back to compiler's __BYTE_ORDER__ for endian-ness detection. + +2013-02-06 Erik de Castro Lopo + + * configure.ac src/common.h src/ima_adpcm.c src/ms_adpcm.c src/paf.c + Drop tests for and #ifdef hackery for C99 struct flexible array feature. + libsndfile assumes the compiler supports most of the ISO C99 standard. + + * src/alac.c + Fix valgrind invalid realloc. Reported by nu774. + Closes: https://github.com/erikd/libsndfile/issues/31 + +2013-02-05 Erik de Castro Lopo + + * src/alac.c + The 'pakt' chunk header should now be written correctly. + Closes: https://github.com/erikd/libsndfile/issues/24 + + * configure.ac Makefile.am + Use PKG_INSTALLDIR when it exists. Suggestion from Christoph Thompson. + Closes: https://github.com/erikd/libsndfile/pull/28 + +2013-02-03 Erik de Castro Lopo + + * src/common.h src/caf.c + Read the ALAC 'pakt' header and stash the values. + + * src/sfendian.h + Add functions psf_put_be64() and psf_put_be32(). + + * src/alac.c + Start work on filling on the 'pakt' chunk header. + +2013-02-02 Erik de Castro Lopo + + * doc/FAQ.html + Add missing opening

tag. + + * src/alac.c + Increase ALAC_BYTE_BUFFER_SIZE to 82000. + +2013-01-27 Erik de Castro Lopo + + * doc/FAQ.html + Improve question #8. + +2013-01-02 Erik de Castro Lopo + + * src/ogg_opus.c + Add skeleton implementation so someone else can run with it. + +2012-12-12 Erik de Castro Lopo + + * src/common.h src/dwd.c src/rx2.c src/txw.c + Fix for compiling when configured with --enable-experimental. Thanks to + Eric Wong for reporting this. + +2012-12-01 Erik de Castro Lopo + + * configure.ac programs/sndfile-play.c + OS X 10.8 uses a different audio API to previous versions. + Fix compile failure on by disabling sndfile-play on this version. + Someone needs to supply code for the new API. + +2012-11-30 Erik de Castro Lopo + + * Octave/Makefile.am Octave/octave_test.sh + Fix 'make distcheck'. + +2012-10-13 Erik de Castro Lopo + + * M4/octave.m4 + Relax constraints on Octave version. + +2012-10-11 Erik de Castro Lopo + + * tests/utils.tpl + Improve compare_*_or_die() functions. + + * src/command.c + Fix bug reported by Keiler Florian. When reading short or int data from a + file containing float data, and setting SFC_SET_SCALE_FLOAT_INT_READ to + SF_TRUE would fail 3, 5, 7 and other channels counts. Problem was that + psf_calc_signal_max() was not calculating the signal max correctly. + Calculation of the signal max was failing because it was trying to read + a sample count that was not an integer multiple of the channel count. + + * tests/channel_test.c tests/Makefile.am tests/test_wrapper.sh.in + Add test for the above. + +2012-09-25 Erik de Castro Lopo + + * src/sndfile.hh + Added a constructor to allow the use of SF_VIRTUAL_IO. Patch from + DannyDaemonic : https://github.com/erikd/libsndfile/pull/20 + +2012-08-23 Erik de Castro Lopo + + * doc/octave.html + Fix link to octave.sourceforge.net. Thanks to IOhannes m zmoelnig. + + * src/mat5.c + Allow reading of mat5 files without a specified sample rate (default to + 44.1kHz). Thanks to IOhannes m zmoelnig. + +2012-08-19 Erik de Castro Lopo + + * src/paf.c + Error out if channel count is zero. Bug report from William ELla via + launchpad: + https://bugs.launchpad.net/ubuntu/+source/libsndfile/+bug/1036831 + +2012-08-04 Erik de Castro Lopo + + * configure.ac programs/sndfile-play.c + Patch from Ricci Adams to use OSX's AudioQueues on OSX 10.7 and greater. + +2012-07-09 Erik de Castro Lopo + + * programs/common.c + Accept "ogg" as a file extention for Ogg/Vorbis files. + +2012-06-22 Erik de Castro Lopo + + * src/flac.c + Make sure any previously allocated FLAC stream encoder and stream decoder + objects are deleted before a new one is allocated. + +2012-06-20 Erik de Castro Lopo + + * tests/utils.tpl + Rename gen_lowpass_noise_float() to gen_lowpass_signal_float() and add a + sine wave component so that different FLAC compression levels can be + tested. + + * src/sndfile.h.in doc/command.html + Add SFC_SET_COMPRESSION_LEVEL and document it. + + * src/sndfile.c + Catch SFC_SET_VBR_ENCODING_QUALITY command and implement it as the inverse + of SFC_SET_COMPRESSION_LEVEL. + + * src/ogg_vorbis.c src/flac.c + Implement SFC_SET_COMPRESSION_LEVEL command. + + * tests/test_wrapper.sh.in tests/compression_size_test.c + Use the compression_size_test on FLAC as well. + +2012-06-19 Erik de Castro Lopo + + * tests/ + Rename vorbis_test.c -> compression_size_test.c so it can be extended to + test FLAC as well. + +2012-06-18 Erik de Castro Lopo + + * src/broadcast.c + Fix a bug where a file with a 'bext' chunk with a zero length coding + history field would get corrupted when the file was closed. + Reported by Paul Davis of the Ardour project. + + * src/test_broadcast_var.c + Add a test for the above. + +2012-05-19 Erik de Castro Lopo + + * src/sndfile.c + sf_format_check: For SF_FORMAT_AIFF, reject endian-ness setttings for + non-PCM formats. + +2012-04-12 Erik de Castro Lopo + + * src/aiff.c + Fix regression in handling of odd length SSND chunks. + Thanks Olivier Tristan for the example file. + + * src/aiff.c src/wav.c + Exit parser loop when marker == 0. + +2012-04-04 Erik de Castro Lopo + + * doc/FAQ.html + Fix text. Thanks to Richard Collins. + +2012-03-24 Erik de Castro Lopo + + * src/caf.c + Exit parse loop if the marker is zero. Pass jump offsets as size_t instead + of int. + +2012-03-20 Erik de Castro Lopo + + * src/alac.c + Fix segfault when decoding CAF/ALAC file with more than 4 channels. + Fixes github issue #8 reported by Charles Van Winkle. + +2012-03-20 Erik de Castro Lopo + + * src/common.h + Change 'typedef SF_CHUNK_ITERATOR { ... } SF_CHUNK_ITERATOR' into 'struct + SF_CHUNK_ITERATOR { ... }' to prevent older compilers from complaining of + re-typedef-ing of SF_CHUNK_ITERATOR. + + * configure.ac + Fix if test for empty $prefix. + +2012-03-18 Erik de Castro Lopo + + * src/*.c tests/chunk_test.c + Reworking of custom chunk handling code. + - Memory for the iterator is now attached to the SF_PRIVATE struct and + freed one sf_close(). + - Rename sf_create_chunk_iterator() -> sf_get_chunk_iterator(). + - Each SNDFILE handle never has more than one SF_CHUNK_ITERATOR handle. + + * tests/string_test.c + Fix un-initialised char buffer. + +2012-03-17 Erik de Castro Lopo + + * src/*.c tests/chunk_test.c + Add improved handling of custom chunk getting and settings. Set of patches + from IOhannes m zmoelnig submitted via github pull request #6. + + * src/alac.c + Fix calculated frame count for files with zero block length. + +2012-03-13 Erik de Castro Lopo + + * src/avr.c + Remove double assignment to psf->endian. Thanks Kao Dome. + + * src/gsm610.c + Fix clearing of buffers. Thanks Kao Dome. + + * src/paf.c + Remove duplicate code. Thanks Kao Dome. + + * src/test_strncpy_crlf.c + Fix minor error in test. Thanks Kao Dome. + + * src/common.h src/*.c + Fix a bunch of valgrind errors. + +2012-03-13 Erik de Castro Lopo + + * src/sndfile.c + Fix typo in error string 'Uknown' -> 'Unknown'. + + * tests/fix_this.c + Fix potential int overflow. + +2012-03-10 Erik de Castro Lopo + + * src/alac.c + Fix decoding of last block so that the decode length is not a multiple of + the block length. Fixes github issue #4 reported by Charles Van Winkle. + + * src/sfconfig.h src/sfendian.h + Fix for MinGW cross compiling. Use '#if (defined __*66__)' instead of + '#if __*86__' because the MinGW header use '#ifdef __x86_64__'. + +2012-03-10 Erik de Castro Lopo + + * src/ALAC/ src/alac.c + Unify the interface between libsndfile and Apple ALAC codec. Regardless of + file bit width samples are now passed between the two as int32_t that are + justified towards the most significant bit. Without this modification, 16 + conversion functions would have been needed between the libsndfile (short, + int, float, double) types and the ALAC types (16, 20, 24 and 32 bit). With + this mod, only 4 are needed. + + * tests/floating_point_test.tpl tests/write_read_test.(def|tpl) + Add tests for 20 and 24 bit ALAC/CAF files. + + * src/command.c + Add ALAC/CAF to the SFC_GET_FORMAT_* commands. Fixes github issue #5. + + * configure.ac + Only use automake AM_SLIENT_RULES where supported. Thanks Dave Yeo. + + * tests/pipe_test.tpl + Disable tests on OS/2. Thanks Dave Yeo. + +2012-03-09 Erik de Castro Lopo + + * configure.ac src/sfconfig.h src/sfendian.h + For GCC, use inline assembler for endian swapping. This should work with + older versions of GCC like the one currently used in OS/2. + +2012-03-06 Erik de Castro Lopo + + * src/alac.c + Make sure temp file gets opened in binary mode. + + * src/alac.c src/common.c src/common.h + Fix function alac_write16_d(). + + * tests/floating_point_test.tpl + Add tests for 16 bit ALAC/CAF. + + * src/alac.c src/common.c src/common.h + Add support for 32 bit ALAC/CAF files. + + * tests/floating_point_test.tpl tests/write_read_test.tpl + Add tests for 32 bit ALAC/CAF files. + +2012-03-05 Erik de Castro Lopo + + * src/ + Refactor chunk storage so it work on big as well as little endian CPUs. + + * tests/chunk_test.c + Clean up error messages. + + * src/sfendian.h src/*.c + Rename endian swapping macros and add ENDSWAP_64 and BE2H_64. + + * configure.ac + Detect presence of header file. + + * src/sfendian.h + Use intrinsics (ie for MinGW) when is not + present. + Make ENDSWAP_64() work with i686-w64-mingw32 compiler. + + * src/ALAC/EndianPortable.c + Add support for __powerpc__. + + * src/sfconfig.h + Make sure HAVE_X86INTRIN_H is either 1 or 0. + +2012-03-03 Erik de Castro Lopo + + * src/ALAC/* + Big dump of code for Apple's ALAC file format. The copyyright to this code + is owned by Apple who have released it under an Apache style license. A few + small modifications were made to allow this to be integrated into libsndfile + but unfortunately the history of those changes were lost because they were + developed in a Bzr tree and during that time libsndfile moved to Git. + + * src/alac.c src/caf.c src/common.[ch] src/Makefile.am src/sndfile.h.in + src/sndfile.c + Hook new ALAC codec in. + + * programs/sndfile-convert.c + Add support for alac codec. + + * tests/write_read_test.tpl + Expand tests to cover ALAC. + +2012-03-02 Erik de Castro Lopo + + * src/aiff.c src/wav.c + Fix a couple of regressions from version 1.0.25. + +2012-03-01 Erik de Castro Lopo + + * src/strings.c + Minor refactoring. Make sure that the memory allocation size if always > 0 + to avoid undefined behaviour. + +2012-02-29 Erik de Castro Lopo + + * src/chunk.c + Fix buffer overrun introduced in recently added chunk logging. This chunk + logging has not yet made it to a libsndfile release version. Thanks to + Olivier Tristan for providing an example file. + + * src/wav.c + Fix handling of odd sized chunks which was causing the parser to lose some + chunks. Thanks to Olivier Tristan for providing an example file. + +2012-02-26 Erik de Castro Lopo + + * tests/util.tpl + Used gnu_printf format checking with mingw-w64 compiler. + + * tests/header_test.tpl + Printf format fixes. + +2012-02-25 Erik de Castro Lopo + + * M4/extra_pkg.m4 + Update PKG_CHECK_MOD_VERSION macro to add an AC_TRY_LINK step. This fix + allows the configure process to catch attempts to link incompatible + libraries. For example, linking 32 bit version of eg libFLAC to a 64 bit + version of libsndfile will now fail. Similarly, when cross compiling + libsndfile from Linux to Windows linking the Linux versions of a library + to the Windows version of libsndfile will now also fail. + + * src/sndfile.h.in src/sndfile.c src/common.h src/create_symbols_file.py + Add API function sf_current_byterate(). + + * src/dwvw.c src/flac.c src/ogg_vorbis.c src/sds.c + Add codec specific handlers for current byterate. + + * tests/floating_point_test.tpl + Add initial test for sf_current_byterate(). + +2012-02-24 Erik de Castro Lopo + + * src/common.[ch] + Add function psf_decode_frame_count(). + + * src/dwvw.c + Fix a termnation bug that caused the decoder to go into an infinite loop. + +2012-02-24 Erik de Castro Lopo + + * src/wav.c + Fix a regression in the WAV header parser. Thanks to Olivier Tristan for + bug report and the example file. + +2012-02-21 Erik de Castro Lopo + + * src/sndfile.c + Return error when SF_BROADCAST_INFO struct has bad coding_history_size. + Thanks to Alex Weiss for the report. + +2012-02-20 Erik de Castro Lopo + + * src/au.c src/flac.c src/g72x.c src/ogg_vorbis.c src/wav_w64.c + Don't fake psf->bytewidth values. + +2012-02-19 Erik de Castro Lopo + + * tests/string_test.c + Fix valgrind warnings. + + * src/common.h src/sndfile.c src/strings.c + Make string storage dynamically allocated. + + * src/sndfile.c + Add extra validation for custom chunk handling. + +2012-02-18 Erik de Castro Lopo + + * src/wav.c + Improve handlling unknown chunk types. Thanks to Olivier Tristan for sending + example files. + + * src/utils.tpl + Add GCC specific testing for format string parameters for exit_if_true(). + + * tests/*.c tests/*.tpl + Fix all printf format warnings. + + * programs/sndfile-play.c + Remove un-needed OSX include . Thanks jamesfmilne for github + issue #3. + + * tests/chunk_test.c + Extend custom chunk test. + +2012-02-12 Erik de Castro Lopo + + * src/wav.c + Jump over some more chunk types while parsing. + +2012-02-04 Erik de Castro Lopo + + * src/common.h src/strings.c + Change way strings are stored in SF_PRIVATE in preparation for dynamically + allocating the storage. + +2012-02-02 Erik de Castro Lopo + + * src/common.h src*.c + Improve encapsulation of string data in SF_PRIVATE. + +2012-02-01 Erik de Castro Lopo + + * src/common.h src*.c + Remove the buffer union from SF_PRIVATE. Most uses of this have been + replaced with a BUF_UNION that is allocated on the stack. + +2012-01-31 Erik de Castro Lopo + + * src/common.h src*.c + Rename logbuffer field of SF_PRIVATE to parselog and reduce its size. + Put the parselog buffer and the index inside a struct within SF_PRIVATE. + +2012-01-26 Erik de Castro Lopo + + * configure.ac + Fix typo, FLAC_CLFAGS -> FLAC_CFLAGS. Thanks to Jeremy Friesner. + +2012-01-21 Erik de Castro Lopo + + * src/sndfile.c src/ogg.c + Fix misleading error message when trying to create an SF_FORMAT_OGG file + with anything other than SF_FORMAT_FILE. Thanks to Charles Van Winkle for + the bug report. Github issue #1. + +2012-01-20 Erik de Castro Lopo + + * src/sndfile.c src/wav.c + Allow files opened in RDWR mode with string data in the tailer to be + extended. Thanks to Bodo for the patch. + + * tests/string_test.c + Add tests for the above changes (patch from Bodo). + +2012-01-09 Erik de Castro Lopo + + * src/aiff.c + Refactor reading of chunk size and use of psf_store_read_chunk(). + + * src/(caf|wav).c + Correct storing of chunk offset. + +2012-01-05 Erik de Castro Lopo + + * src/aiff.c src/wav.c src/common.h + Refactor common code into src/common.h. + + * src/caf.c + Make custom chunks work for CAF files. + + * tests/chunk_test.c tests/test_wrapper.sh.in + Test CAF files with custom chunks. + + * src/sndfile.c + Prevent psf->codec_close() being called more than once. + +2012-01-04 Erik de Castro Lopo + + * programs/sndfile-cmp.c + Catch the case where the second file has more frames than the first. + +2012-01-02 Erik de Castro Lopo + + * src/create_symbols_file.py + Add sf_set_chunk/sf_get_chunk_size/sf_get_chunk_data. + +2011-12-31 Erik de Castro Lopo + + * tests/chunk_test.c tests/Makefile.am + New test for custom chunks. + + * src/aiff.c src/chunk.c src/common.h src/sndfile.c + Make custom chunks work on AIFF files. + + * src/wav.c + Make custom chunks work on WAV files (includes refactoring). + +2011-11-12 Erik de Castro Lopo + + * src/sndfile.h.in src/common.h src/sndfile.c + Start working on setting/getting chunks. + +2011-11-24 Erik de Castro Lopo + + * src/binheader_writef_check.py src/create_symbols_file.py + Make it work for Python 2 and 3. Thanks Michael. + +2011-11-19 Erik de Castro Lopo + + * libsndfile.spec.in + Change field name 'URL' to 'Url'. + + * src/sndfile.h.in + Add SF_SEEK_SET/CUR/END. + +2011-11-05 Erik de Castro Lopo + + * src/id3.c + Fix a stack overflow that can occur when parsing a file with multiple + ID3 headers which would cause libsndfile to go into an infinite recursion + until it blew the stack. Thanks to Anders Svensson for supplying an example + file. + +2011-10-30 Erik de Castro Lopo + + * src/double64.c src/float32.c src/common.h + Make (float32|double_64)_(be|le)_read() functions const correct. + +2011-10-28 Erik de Castro Lopo + + * src/sfendian.h + Minor tweaking of types. Cast to ptr to correct final type rather void*. + + * programs/sndfile-play.c tests/utils.tpl + Fix compiler warnings with latest MinGW cross compiler. + +2011-10-13 Erik de Castro Lopo + + * src/file_io.c + Use the non-deprecated resource fork name on OSX. Thanks to Olivier Tristan. + +2011-10-12 Erik de Castro Lopo + + * src/wav.c + Jump over the 'olym' chunks when parsing. + +2011-10-06 Erik de Castro Lopo + + * tests/write_read_test.tpl + Remove windows only truncate() implementation. + +2011-09-04 Erik de Castro Lopo + + * src/sd2.c src/sndfile.c + Make sure 23 bit PCM SD2 files are readable/writeable. + + * tests/write_read_test.tpl + Add tests for 32 bit PCM SD2 files. + +2011-08-23 Erik de Castro Lopo + + * configure.ac + Use AC_SYS_LARGEFILE instead of AC_SYS_EXTRA_LARGEFILE as suggested by + Jan Willies. + +2011-08-07 Erik de Castro Lopo + + * configure.ac Makefile.am + Move ACLOCAL_AMFLAGS setup to Makefile.am. + +2011-07-15 Erik de Castro Lopo + + * doc/command.html + Merge two separate blocks of SFC_SET_VBR_ENCODING_QUALITY documentation. + + * src/paf.c + Replace ppaf24->samplesperblock with a compile time constant. + +2011-07-13 Erik de Castro Lopo + + * src/ogg_vorbis.c + Fix return value of SFC_SET_VBR_ENCODING_QUALITY command. + + * doc/command.html + Document SFC_SET_VBR_ENCODING_QUALITY, SFC_GET/SET_LOOP_INFO and + SFC_GET_INSTRUMENT. + + * NEWS README configure.ac doc/*.html + Updates for 1.0.25. + +2011-07-07 Erik de Castro Lopo + + * src/sfconfig.h + Add handling for HAVE_SYS_WAIT_H. + + * Makefile.am src/Makefile.am tests/Makefile.am + Add 'checkprograms' target. + +2011-07-05 Erik de Castro Lopo + + * src/common.h src/sndfile.c + Purge SF_ASSERT macro. Use standard C assert instead. + + * src/paf.c src/common.h src/sndfile.c + Fix for Secunia Advisory SA45125, heap overflow (heap gets overwritten with + byte value of 0) due to integer overflow if PAF file handler. + + * src/ima_adpcm.c src/ms_adpcm.c src/paf.c + Use calloc instead of malloc followed by memset. + + * tests/utils.tpl + Clean up use of memset. + +2011-07-05 Erik de Castro Lopo + + * src/ogg.c + Fix log message. + + * tests/format_check_test.c + Fix compiler warnings. + +2011-07-04 Erik de Castro Lopo + + * src/sndfile.c + Fix error message for erro code SFE_ZERO_MINOR_FORMAT. + + * tests/format_check_test.c + Add a test to for SF_FINFO format field validation. + + * src/ogg.c src/ogg_vorbis.c src/ogg.h src/ogg_pcm.c src/ogg_speex.c + src/common.h src/Makefile.am + Move vorbis specific code to ogg_vorbis.c, add new files for handling PCM + and Speex codecs in an Ogg container. The later two are only enabled with + ENABLE_EXPERIMENTAL_CODE config variable. + +2011-06-28 Erik de Castro Lopo + + * src/strings.c + Clean up and refactor storage of SF_STR_SOFTWARE. + +2011-06-23 Erik de Castro Lopo + + * src/sndfile.h.in doc/api.html + Fix definition of SF_STR_LAST and update SF_STR_* related docs. Thanks to + Tim van der Molen for the patch. + +2011-06-21 Erik de Castro Lopo + + * programs/sndfile-interleave.c + Fix handling of argc. Thanks to Marius Hennecke. + + * src/wav_w64.c + Accept broken WAV files with blockalign == 0. Thanks to Olivier Tristan for + providing example files. + + * src/wav.c + Jump over 'FLLR' chunks. + +2011-06-14 Erik de Castro Lopo + + * src/sndfile.h.in + Fix -Wundef warning due to ENABLE_SNDFILE_WINDOWS_PROTOTYPES. + + * configure.ac + Add -Wundef to CFLAGS. + + * src/ogg.c + Fix -Wunder warning. + +2011-05-18 Erik de Castro Lopo + + * configure.ac + Use int64_t instead of off_t when they are the same size. + + * src/Makefile.am tests/Makefile.am + Use check_PROGRAMS instead of noinst_PROGRAMS where appropriate. + +2011-05-08 Erik de Castro Lopo + + * src/wav.c + Don't allow unknown and/or un-editable chunks to prevent the file from being + opened in SFM_RDWR mode. + +2011-04-25 Erik de Castro Lopo + + * tests/format_check_test.c + Fix segfault in test program. + +2011-04-25 Erik de Castro Lopo + + * tests/format_check_test.c + New test program to check to make sure that sf_open() and sf_check_format() + agree as to what is a valid program. + + * tests/Makefile.am tests/test_wrapper.sh.in + Hook into build and test runner. + + * src/sndfile.c + Fix some sf_format_check() problems. Thanks to Charles Van Winkle for the + notification. + +2011-04-06 Erik de Castro Lopo + + * src/caf.c + Add validation to size of 'data' chunk and fix size of written 'data' + chunk. Thanks to Michael Pruett for reporting this. + +2011-03-28 Erik de Castro Lopo + + * src/* tests/* programs/* + Fix a bunch of compiler warnings with gcc-4.6. + +2011-03-25 Erik de Castro Lopo + + * tests/util.tpl + Add NOT macro to util.h. + + * src/strings.c + Fix handling of SF_STR_SOFTWARE that resulted in a segfault due to calling + strlen() on an unterminated string. Thanks to Francois Thibaud for reporting + this problem. + + * tests/string_test.c + Add test for SF_STR_SOFTWARE segfault bug. + + * configure.ac + Sanitize FLAC_CFLAGS value supplied by pkg-config which returns a value of + '-I${includedir}/FLAC'. However FLAC also provides an include file + which clashes with the Standard C header of the same name. The + solution is strip the 'FLAC' part off the end and include all FLAC headers + as . + + * configure.ac src/Makefile.am + Use non-recursive make in src/ directory. + +2011-03-23 Erik de Castro Lopo + + * NEWS README docs/*.html + Updates for 1.0.24 release. + +2011-03-22 Erik de Castro Lopo + + * configure.ac + Fix up usage of sed (should not assume GNU sed). + + * M4/add_(c|cxx)flags.m4 + Test flags in isolation. + + * tests/cpp_test.cc + Fix a broken test (test segfaults). Report by Dave Flogeras. + +2011-03-21 Erik de Castro Lopo + + * programs/common.[ch] + Add function program_name() which returns the program name minus the path + from argv [0]. + + * programs/*.c programs/Makefile.am + Use program_name() where appropriate. Fix build. + +2011-03-20 Erik de Castro Lopo + + * src/wav.c + For u-law and A-law files, write an 18 byte 'fmt ' chunk instead of a 16 + byte one. Win98 accepts files with a 16 but not 18 byte 'fmt' chunk. Later + version accept 18 byte but not 16 byte. + +2011-03-15 Erik de Castro Lopo + + * doc/FAQ.html + Add examples for question 12. + + * doc/libsndfile.css.in + Add tweaks for h4 element. + + * doc/api.html + Add documentation for virtual I/O functionality. Thanks to Uli Franke. + + * tests/util.tpl + Add static inline functions sf_info_clear() and sf_info_setup(). + + * tests/(alaw|dwvw|ulaw)_test.c + Use functions sf_info_clear() and sf_info_setup(). + +2011-03-08 Erik de Castro Lopo + + * configure.ac + Fail more gracefully if pkg-config is missing. Suggestion from Brian + Willoughby. + +2011-02-27 Erik de Castro Lopo + + * src/common.c + Use size_t instead of int for size params with varargs. + +2011-02-09 Erik de Castro Lopo + + * doc/index.html + Update supported platforms with more Debian platforms and Android. + +2011-01-27 Erik de Castro Lopo + + * src/sndfile.hh + Add an LPCWSTR version of the SndfileHandle constructor to the SndfileHandle + class definition. Thanks to Eric Eizenman for pointing out this was missing. + + * tests/cpp_test.cc + Add test for LPCWSTR version of the SndfileHandle constructor. + +2011-01-19 Erik de Castro Lopo + + * programs/sndfile-play.c + Remove cruft. + +2010-12-01 Erik de Castro Lopo + + * src/sndfile.hh + Add methods rawHandle() and takeOwnership(). Thanks to Tim Blechmann for + the patch. + + * tests/cpp_test.cc + Add tests for above two methods. Also supplied by Tim Blechmann. + +2010-11-11 Erik de Castro Lopo + + * doc/api.html + Add mention of use of sf_strerror() when sf_open() fails. + +2010-11-01 Erik de Castro Lopo + + * configure.ac + Make TYPEOF_SF_COUNT_T int64_t where possible. This may fix problems where + people are compiling on a 64 bit system with the GCC -m32 flag. + + * src/sndfile.h.in + Fix comments on sf_count_t. + +2010-10-26 Erik de Castro Lopo + + * src/aiff.c + Handle non-zero offset field in SSND chunk. Thanks to Michael Chinen. + +2010-10-20 Erik de Castro Lopo + + * configure.ac + Sed fix for FreeBSD. Thanks Tony Theodore. + +2010-10-14 Erik de Castro Lopo + + * shave.in M4/shave.m4 + Fix shave invocation of windres compiler. Thanks Damien Lespiau (upstream + shave author). + + * configure.ac M4/shave.m4 shave-libtool.in shave.in + Switch from shave to automake-1.11's AM_SILENT_RULES. + +2010-10-13 Erik de Castro Lopo + + * shave-libtool.in shave.in + Sync to upstream version. + + * src/rf64.c + More work to make the parser more robust and accepting of mal-formed files. + +2010-10-12 Erik de Castro Lopo + + * src/common.h + Add functions psf_strlcpy() and psf_strlcat(). + + * src/broadcast.c src/sndfile.c src/strings.c src/test_main.c + src/test_main.h src/test_strncpy_crlf.c + Use functions psf_strlcpy() and psf_strlcat() as appropriate. + + * tests/string_test.c + Add tests for SF_STR_GENRE and SF_STR_TRACKNUMBER. + + * src/rf64.c + Fix size of 'ds64' chunk when writing RF64. + +2010-10-10 Erik de Castro Lopo + + * programs/*.c + Add the libsndfile version to the usage message of all programs. + +2010-10-10 Erik de Castro Lopo + + * configure.ac src/version-metadata.rc.in src/Makefile.am + Add version string resources to the windows DLL. + + * doc/api.html + Update to add missing SF_FORMAT_* values. Closed Debian bug #545257. + + * NEWS README configure.ac doc/*.html + Updates for 1.0.23 release. + +2010-10-09 Erik de Castro Lopo + + * tests/pedantic-header-test.sh.in + Handle unusual values of CC environment variable. + + * src/rf64.c + Minor tweaks and additional sanity checking. + + * src/Makefile.am src/binheader_writef_check.py + Use python 2.6. + +2010-10-08 Erik de Castro Lopo + + * src/sndfile.hh + Add a missing 'inline' before a constructor defintion. + +2010-10-06 Erik de Castro Lopo + + * src/common.h + Add macro NOT. + + * src/rf64.c + Minor tweaks. + + * Makefile.am */Makefile.am + Add *~ to CLEANFILES. + +2010-10-05 Erik de Castro Lopo + + * src/sndfile.c + Fix a typo in the error string for SFE_OPEN_PIPE_RDWR. Thanks to Charles + Van Winkle for the report. + +2010-10-04 Erik de Castro Lopo + + * src/flac.c src/ogg.c src/sndfile.h.in src/strings.c src/wav.c + Add ability to read/write tracknumber and genre to flac/ogg/wav files. + Thanks to Matti Nykyri for the patch. + + * src/common.h src/broadcast.c src/strings.c + Add function psf_safe_strncpy() and use where appropriate. + +2010-10-04 Erik de Castro Lopo + + * NEWS README configure.ac doc/*.html + Updates for 1.0.22 release. + +2010-10-03 Erik de Castro Lopo + + * src/common.h src/broadcast.c src/rf64.c src/sndfile.c src/wav.c + Rewrite of SF_BROADCAST_INFO handling. + + * src/test_broadcast_var.c tests/command_test.c + Tweak SF_BROADCAST_INFO tests. + + * src/test_broadcast_var.c + Fix OSX stack check error. + +2010-09-30 Erik de Castro Lopo + + * src/sds.c + Set sustain_loop_end to 0 as suggested by Brian Lewis. + +2010-09-29 Erik de Castro Lopo + + * src/sds.c + Make sure the correct frame count gets written into the header. + + * tests/write_read_test.tpl + Don't allow SDS files to have a long frame count. + +2010-09-17 Erik de Castro Lopo + + * src/sds.c + Apply a pair of patches from Brian Lewis to fix the packet number location + and the checksum. + +2010-09-10 Erik de Castro Lopo + + * src/aiff.c src/file_io.c src/ogg.c src/rf64.c src/sndfile.c + src/strings.c src/test_audio_detect.c src/test_strncpy_crlf.c + src/wav.c tests/pcm_test.tpl + Fix a bunch of minor issues found using static analysis. + +2010-08-23 Erik de Castro Lopo + + * src/test_broadcast_var.c + New file containing tests for broadcast_set_var(). + + * src/Makefile.am src/test_main.[ch] + Hook test_broadcast_var.c into tests. + +2010-08-22 Erik de Castro Lopo + + * src/broadcast.c src/common.(c|h) + Move function strncpy_crlf() to src/common.c so the function can be tested + in isolation. + + * src/test_strncpy_crlf.c + New file. + + * src/Makefile.am src/test_main.[ch] + Hook test_strncpy_crlf.c into tests. + +2010-08-18 Erik de Castro Lopo + + * src/common.h + Move code around to make comments make sense. + + * src/broadcast.c + Add debugging code that is disabled by default. + +2010-08-02 Erik de Castro Lopo + + * src/flac.c + When the file meta data says the file has zero frames set psf->sf.frames + to SF_COUNT_MAX. Fixes Debian bug #590752. + + * programs/sndfile-info.c + Print 'unknown' if frame count == SF_COUNT_MAX. + +2010-06-27 Erik de Castro Lopo + + * src/sndfile.c + Only support writing mono SVX files. Multichannel SVX files are not + interleaved and there is no support infrastructure to cache and write + multiple channels to create a non-interleaved file. + + * src/file_io.c + Don't call close() on a file descriptor of -1. Thanks to Jeremy Friesner + for the bug report. + +2010-06-09 Erik de Castro Lopo + + * src/common.h + Add macro SF_ASSERT. + + * src/sndfile.c + Use SF_ASSERT to ensure sizeof (sf_count_t) == 8. + + * src/svx.c + Add support for reading and writing stereo SVX files. + +2010-05-07 Erik de Castro Lopo + + * configure.ac + When compiling with x86_64-w64-mingw32-gcc link with -static-libgcc flags. + + * programs/common.c programs/sndfile-metadata-set.c + Update metadata after the audio data is copied. Other minor fixes. Patch + from Marius Hennecke. + +2010-05-04 Erik de Castro Lopo + + * src/nist.c + Fix a regression reported by Hugh Secker-Walker. + + * src/api.html + Add comment about sf_open_fd() not working on Windows if the application + and the libsndfile DLL are linked to different versions of the Microsoft + C runtime DLL. + +2010-04-23 Erik de Castro Lopo + + * tests/pedantic-header-test.sh.in + Fix 'make distcheck'. + +2010-04-21 Erik de Castro Lopo + + * tests/pedantic-header-test.sh.in + New file to test whether sndfile.h can be compiled with gcc's -pedantic + flag. + + * configure.ac tests/test_wrapper.sh.in + Hook pedantic-header-test into test suite. + + * src/sndfile.h.in + Fix -pedantic warning. + +2010-04-19 Erik de Castro Lopo + + * programs/sndfile-salvage.c programs/Makefile.am + New program to salvage the audio data from WAV/WAVEX/AIFF files which are + greater than 4Gig in size. + +2010-04-09 Erik de Castro Lopo + + * programs/sndfile-convert.c + Fix valgrind warning. + +2010-04-06 Erik de Castro Lopo + + * programs/sndfile-cmp.c + When files differ in the PCM data, also print the difference offset. + Minor cleanup. + +2010-03-19 Erik de Castro Lopo + + * src/aiff.c + Don't use the 'twos' marker for 24 and 32 bit PCM, use 'in24' and 'in32' + instead. Thanks to Paul Davis (Ardour) for this suggestion. + +2010-02-28 Erik de Castro Lopo + + * configure.ac + Clean up configure report. + + * tests/utils.tpl + Add functions test_read_raw_or_die and test_write_raw_or_die. + + * tests/rdwr_test.(def|tpl) tests/Makefile.am + Add new test program and hook into build. + + * src/sndfile.c + Fix minor issues with sf_read/write_raw(). Bug reported by Milan Křápek. + + * tests/test_wrapper.sh.in + Add rdwr_test to the test wrapper script. + +2010-02-22 Erik de Castro Lopo + + * configure.ac + Remove -fpascal-strings from OSX's OS_SPECIFIC_CFLAGS. + + * programs/common.[ch] programs/sndfile-metadata-set.c + Apply a patch from Robin Gareus allowing the setting of the time reference + field of the BEXT chunk. + +2010-02-06 Erik de Castro Lopo + + * src/ima_adpcm.c + Add a fix from Jonatan Liljedahl to handle predictor overflow when decoding + IMA4. + +2010-01-26 Erik de Castro Lopo + + * src/sndfile.hh + Add a constructor which takes an existing file descriptor and then calls + sf_open_fd(). Patch from Sakari Bergen. + +2010-01-10 Erik de Castro Lopo + + * programs/sndfile-deinterleave.c programs/sndfile-interleave.c + Improve usage messages. + +2010-01-09 Erik de Castro Lopo + + * src/id3.c src/Makefile.am + Add new file src/id3.c and hook into build. + + * src/sndfile.c src/common.h + Detect and skip and ID3 header at the start of the file. + +2010-01-07 Erik de Castro Lopo + + * programs/common.c + Fix update_strings() copyright, comment, album and license are correctly + written. Thanks to Todd Allen for reporting this. + + * man/Makefile.am + Change GNU makeism to something more widely supported. Thanks to Christian + Weisgerber for reporting this. + + * configure.ac programs/Makefile.am programs/sndfile-play.c + Apply patch from Christian Weisgerber and Jacob Meuserto add support for + OpenBSD's sndio. + +2010-01-05 Erik de Castro Lopo + + * doc/api.html + Discourage the use of sf_read/write_raw(). + +2009-12-28 Erik de Castro Lopo + + * configure.ac + Test for Unix pipe() and waitpid() functions. + + * src/sfconfig.h tests/pipe_test.tpl + Disable pipe_test if pipe() and waitpid() aren't available. + +2009-12-16 Erik de Castro Lopo + + * configure.ac src/Makefile.am src/create_symbols_file.py + src/make-static-lib-hidden-privates.sh + Change name of generated file src/Symbols.linux to Symbols.gnu-binutils and + and use the same symbols file for other systems which use GNU binutils like + Debian's kfreebsd. + + * M4/shave.m4 shave.in + Update shave files from upstream. + +2009-12-15 Erik de Castro Lopo + + * man/sndfile-metadata-get.1 + Fix typo. + + * man/sndfile-interleave.1 man/Makefile.am + New man page. + +2009-12-13 Erik de Castro Lopo + + * src/ogg.c + When decoding to short or int, clip the decoded signal to [-1.0, 1.0] if + its too hot. Thanks to Dmitry Baikov for suggesting this. + + * NEWS README doc/*.html + Updates for 1.0.21. + +2009-12-09 Erik de Castro Lopo + + * programs/sndfile-jackplay.c man/sndfile-jackplay.1 + Remove these which will now be in found in the sndfile-tools package. + + * programs/Makefile.am man/Makefile.am + Remove build rules for sndfile-jackplay. + + * configure.ac + Remove detection of JACK Audio Connect Kit. + + * programs/sndfile-concat.c man/sndfile-concat.1 + Add new program with man page. + + * man/Makefile.am programs/Makefile.am + Hook sndfile-concat into build system. + +2009-12-08 Erik de Castro Lopo + + * tests/error_test.c + Don't terminate when sf_close() returns zero in error_close_test(). + It seems that Windows 7 behaves differently from earlier versions of + Windows. + +2009-12-03 Erik de Castro Lopo + + * configure.ac M4/*.m4 + Rename all custom macros from AC_* to MN_*. + + * programs/sndfile-interleave.c + Make it actually work. + +2009-12-02 Erik de Castro Lopo + + * doc/*.html configure.ac + Corrections and clarifications courtesy of Robin Forder. + + * programs/sndfile-convert.c programs/common.[ch] + Move some code from convert to common for reuse. + + * programs/sndfile-interleave.c programs/sndfile-interleave.c + Add new programs sndfile-interleave and sndfile-deinterleave. + + * programs/Makefile.am + Hook new programs into build. + +2009-12-01 Erik de Castro Lopo + + * src/create_symbols_file.py tests/stdio_test.c tests/win32_test.c + Minor OS/2 tweaks as suggested by David Yeo. + + * tests/multi_file_test.c + Fix file creation flags on windows. Thanks to Bruce Sharpe. + + * src/sf_unistd.h + Set all group and other file create permssions to zero. + + * tests/win32_test.c + Add a new test. + +2009-11-30 Erik de Castro Lopo + + * doc/print.css doc/*.html + Add a print stylesheet and update all HTML documents to reference it. + Thanks to Aditya Bhargava for suggesting this. + + * doc/index.html + Minor corrections. + +2009-11-29 Erik de Castro Lopo + + * sndfile.pc.in + Add a Libs.private entry to assist with static linking. + +2009-11-28 Erik de Castro Lopo + + * src/make-static-lib-hidden-privates.sh src/Makefile.am + Add a script to hide all non-public symbols in the libsndfile.a static + library. + +2009-11-22 Erik de Castro Lopo + + * tests/locale_test.c + Correct usage of ENABLE_SNDFILE_WINDOWS_PROTOTYPES. + +2009-11-20 Erik de Castro Lopo + + * src/windows.c + Correct usage of ENABLE_SNDFILE_WINDOWS_PROTOTYPES. + +2009-11-16 Erik de Castro Lopo + + * programs/sndfile-convert.c + Allow the program to read from stdin by specifying '-' on the command line + as the input file. + + * src/sndfile.h.in + Hash define ENABLE_SNDFILE_WINDOWS_PROTOTYPES to 1 for greater safety. + + * tests/virtual_io_test.c + Add a PAF/PCM_24 test and verify the file length is not negative + immediately after openning the file for write. + +2009-10-18 Erik de Castro Lopo + + * src/wav.c + When writing loop lengths, adjust the end position by one to make up for + Microsoft's screwed up spec. Thanks to Olivier Tristan for the patch. + +2009-10-14 Erik de Castro Lopo + + * src/flac.c + Apply patch from Uli Franke allowing FLAC files to be encoded at any sample + rate. + +2009-10-09 Erik de Castro Lopo + + * src/nist.c + Fix parsing of odd ulaw encoded file provided by Jan Silovsky. + + * configure.ac + Insist on libvorbis >= 1.2.3. Earlier verions have bugs that cause the + libsndfile test suite to fail on MIPS, PowerPC and others. + See: http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=549899 + +2009-10-06 Erik de Castro Lopo + + * man/sndfile-convert.1 + Fix warning from Debian's lintian checks. + + * man/sndfile-cmp.1 man/sndfile-jackplay.1 man/sndfile-metadata-get.1 + man/Makefile.am + Add three new minimal manpages and hook into build. + +2009-10-05 Erik de Castro Lopo + + * tests/test_wrapper.sh.in + Don't run cpp_test on x86_64-w64-mingw32. + +2009-09-28 Erik de Castro Lopo + + * tests/utils.tpl + On windows, make sure the open() function doesn't get called with a third + parameter of 0 which fails for no good reason. Also make sure this third + parameter doesn't get called with S_IRGRP when compiling for windows because + Wine complains. + + * src/sndfile.hh + Add a SndfileHandle constructor for windows that takes a 'const wchar_t *' + string. + + * doc/FAQ.html + Add Q/A : I'm cross compiling libsndfile for another platform. How can I + run the test suite? + + * src/create_symbols_file.py src/Makefile.am + Add Symbols.static target, a list of symbols, one per line. + +2009-09-27 Erik de Castro Lopo + + * tests/test_wrapper.sh.in + Update to allow all tests to be gathered up into a testsuite tarball and + then be run using this script. + + * build-test-tarball.mk.in + Add a Make script to build a tarball of all the test binaries and the test + wrapper script. This is useful for cross compiling; you can build the + binaries, build test test tarball and transfer the test tarball to the + target machine for testing. + +2009-09-26 Erik de Castro Lopo + + * src/common.h src/*.c + Modify SF_FILE struct to allow it to carry either 8-bit or 16-bit strings + for the file path, directory and name. Fixes for this change throughout. + + * src/windows.c src/Makefile.am + New file defining new windows only public function sf_wchar_open() which + takes a 'const wchar_t *' string (LPCWSTR) for the file name parameter. + + * src/sndfile.h.in + Add SF_CHANNEL_MAP_ABISONIC_* entries. + Add windows only defintion for sf_wchar_open(). + + * src/create_symbols_file.py + Add sf_wchar_open() to the list of public symbols (windows only). + + * tests/locale_test.c + Add a wchar_test() to test sf_wchar_open(). + +2009-09-25 Erik de Castro Lopo + + * src/common.h src/*.c + Split file stuff into PSF_FILE struct within the SF_PRIVATE struct. + +2009-09-23 Erik de Castro Lopo + + * src/aiff.c src/voc.c + When a byte is needed, use unsigned char. + + * src/ima_oki_adpcm.c src/broadcast.c src/test_ima_oki_adpcm.c + Include sfconfig.h to prevent compile errors with MinGW compilers. + + * configure.ac + Remove AM_CONFIG_HEADER due to warnings from autoconf 2.64. + + * tests/locale_test.c + Update to work with xx_XX.UTF-8 style locales. Refactoring. + +2009-09-22 Erik de Castro Lopo + + * configure.ac + Set __USE_MINGW_ANSI_STDIO to 1 when compiling using MinGW compilers. + Remove unneeded AC_SUBST. + Report Host CPU/OS/vendor. + +2009-09-19 Erik de Castro Lopo + + * src/sndfile.c + Fix error message string. + + * src/flac.c + Add 88200 to the list of supported sample rates. + + * src/ogg.c + Fix compiler warning when using gcc-4.5.0. + + * programs/sndfile-info.c tests/utils.tpl + Remove WIN32 snprintf #define. + + * src/ima_adpcm.c + Fix minor bug in aiff_ima_encode_block. Thanks to Denis Fileev for finding + this. + +2009-09-16 Erik de Castro Lopo + + * src/caf.c + Use the correct C99 format specifier for int64_t. + + * M4/endian.m4 + Fix detection of CPU endian-ness when cross compiling. Thanks to Pierre + Ossman for the bug report. + + * src/caf.c src/sndfile.c + Fix reading and writing of PEAK chunks in CAF files. + + * tests/peak_chunk_test.c tests/test_wrapper.sh.in + Run peak_chunk_test on CAF files. + +2009-09-15 Erik de Castro Lopo + + * src/aiff.c src/wav.c + Use the correct C99 format specifier for int64_t. + +2009-08-30 Erik de Castro Lopo + + * src/rf64.c src/sndfile.c src/wav.c src/wav_w64.h + Apply a patch (massaged slightly) from Uli Franke adding handling of the + BEXT chunk in RF64 files. + + * tests/command_test.c + Update channel_map_test() function so WAV test passes. + + * src/rf64.c + Add channel mapping and ambisonic support. + + * src/sndfile.h + Add comments showing correspondance between libsndfile channel map + defintiions and those used by Apple and MS. + + Add handling of reading/writing channel map info. + + * tests/command_test.c tests/test_wrapper.sh.in + Update channel map tests. + +2009-07-29 Erik de Castro Lopo + + * src/common.h + Add function psf_isprint() a replacement for the standard C isprint() + function which ignores any locale settings and treats all input as ASCII. + + * src/(aiff|common|rf64|sd2|strings|svx|wav).c + Use psf_isprint() instead of isprint(). + +2009-07-13 Erik de Castro Lopo + + * src/command.c + Add string descriptions for SF_FORMAT_RF64 and SF_FORMAT_MPC2K. + +2009-06-30 Erik de Castro Lopo + + * programs/sndfile-play.c + Allow use of Open Sound System audio output under FreeBSD. + +2009-06-24 Erik de Castro Lopo + + * configure.ac + Add patch from Conrad Parker to add --disable-jack. + +2009-05-28 Erik de Castro Lopo + + * src/alaw.c src/float32.c src/htk.c src/pcm.c src/sds.c src/ulaw.c + Fix bugs where invalid files can cause a divide by zero error (SIGFPE). + Thanks to Sami Liedes for reporting this a Debian bug #530831. + +2009-05-26 Erik de Castro Lopo + + * src/chanmap.[ch] + New files for channel map decoding/encoding. + +2009-05-25 Erik de Castro Lopo + + * configure.ac src/sndfile.h.in + Fix MSVC definition of sf_count_t. + +2009-05-24 Erik de Castro Lopo + + * src/wav_w64.[ch] + Add wavex_channelmask to WAV_PRIVATE struct and add a function to convert + an array of SF_CHANNEL_MASK_* values into a bit mask for use in WAV files. + + * src/wav.c + Add ability to write the channel mask. + +2009-05-23 Erik de Castro Lopo + + * programs/sndfile-info.c + Add -c command line option to dump the channel map information. + + * src/wav_w64.c + Don't bail from parser if channel map bitmask is faulty. + + * src/common.h src/sndfile.c + Remove error code SFE_W64_BAD_CHANNEL_MAP which is not needed any more. + + * src/sndfile.c + On SFC_SET_CHANNEL_MAP_INFO pass the channel map command down to container's + command handler. + +2009-05-22 Erik de Castro Lopo + + * src/sndfile.h.in src/common.h src/sndfile.c src/wav_w64.c + Apply a patch from Lennart Poettering (PulseAudio) to allow reading of + channel data in WAV and W64 files. + Add a test for the above. + +2009-05-20 Erik de Castro Lopo + + * src/FAQ.html + Update the section about pre-compiled binaries for Win64. + +2009-05-14 Erik de Castro Lopo + + * src/common.h src/test_conversions.c + Be more careful when including so compiling on pre-C99 platforms + (hello Slowlaris) might actually work. + + * NEWS README doc/*.html + Updates for 1.0.20. + +2009-04-21 Erik de Castro Lopo + + * src/voc.c + Fix a bug whereby opening a specially crafted VOC file could result in a + heap overflow. Thanks to Tobias Klein (http://www.trapkit.de) for reporting + this issue. + + * src/aiff.c + Fix potential (heap) buffer overflow when parsing 'MARK' chunk. + +2009-04-12 Erik de Castro Lopo + + * tests/stdin_test.c + Check psf->error after opening file. + + * src/file_io.c + Fix obscure seeking bug reported by Hugh Secker-Walker. + + * tests/utils.tpl + Add check of sf_error to test_open_file_or_die(). + + * src/sndfile.c + Clear error if opening resource fork fails. + +2009-04-11 Erik de Castro Lopo + + * tests/alaw_test.c tests/locale_test.c tests/ulaw_test.c + Cleanup output. + +2009-03-25 Erik de Castro Lopo + + * src/float32.c + Fix f2s_clip_array. + +2009-03-24 Erik de Castro Lopo + + * src/float32.c + In host_read_f2s call convert instead of f2s_array. + + * src/ima_adpcm.c + Remove dead code. + + * src/test_ima_oki_adpcm.c examples/generate.c tests/dither_test.c + tests/dwvw_test.c tests/fix_this.c tests/generate.c + tests/multi_file_test.c + Minor fixes. + +2009-03-23 Erik de Castro Lopo + + * M4/shave.m4 shave.in + Pulled update from upstream. + +2009-03-19 Erik de Castro Lopo + + * doc/api.html + Add pointers to example programs in source code tarball. + +2009-03-17 Erik de Castro Lopo + + * src/common.h + Define SF_PLATFORM_S64 for non-gcc compilers with 'long long' type. + + * configure.ac + Add documentation for --disable-external-libs and improve error handling + for that option. + + * src/sndfile.c src/sndfile.h.in src/create_symbols_file.py + Add public function sf_version_string. + + * tests/sfversion.c + Test function sf_version_string. + + * M4/shave.m4 shave-libtool.in shave.in + Add new files from 'git clone git://git.lespiau.name/shave'. + + * configure.ac + Enable shave. + + * src/Makefile.am src/binheader_writef_check.py Octave/* + Shave related tweaks. + +2009-03-15 Erik de Castro Lopo + + * src/common.h src/caf.c src/sndfile.c + Add SF_MAX_CHANNELS (set to 256) and use it. + + * src/sndfile.h.in + Check for either _MSCVER or _MSC_VER being defined. + +2009-03-04 Erik de Castro Lopo + + * tests/vorbis_test.c + Relax test slighly to allow test to pass on more CPUs etc. + +2009-03-03 Erik de Castro Lopo + + * configure.ac + Detect vorbis_version_string() correctly. + +2009-03-02 Erik de Castro Lopo + + * doc/index.html + Add a 'See Also' section with a link to sndfile-tools. + + * NEWS README doc/*.html + Updates for 1.0.19 release. + + * configure.ac + Fix --enable-external-libs logic. + +2009-03-01 Erik de Castro Lopo + + * src/aiff.c + Fix resource leak and potential read beyond end of buffer. + + * src/nist.c + Fix reading of header value sample_n_bytes. + + * src/sd2.c src/wav.c + Fix potential read beyond end of buffer. + + * src/sndfile.c src/svx.c + Check return values of file_io functions. + + * tests/win32_test.c + Fix resource leak. + + * configure.ac + Detect the presence/absence of vorbis_version_string() in libvorbis. + + * src/ogg.c + Only call vorbis_version_string() from libvorbis if present. + +2009-02-24 Erik de Castro Lopo + + * tests/win32_test.c + Don't use sprintf, even on windows. + + * src/aiff.c src/rf64.c src/wav.c + Eliminate dead code, more validation of data read from file. + +2009-02-22 Erik de Castro Lopo + + * src/ima_adpcm.c + Clamp values to a valid range before indexing ima_step_size array. + + * src/GSM610/*.c tests/*c programs/*.c src/audio_detect.c + Don't include un-needed headers. + + * programs/sndfile-info.c + Remove dead code. + + * tests/test_wrapper.sh.in + Add 'set -e' so the script exits on error. + + * src/test_ima_oki_adpcm.c + Fix read beyond end of array. + + * tests/win32_test.c + Add missing close on file descriptor. + + * src/nist.c programs/sndfile-metadata-set.c + Fix 'unused variable' warnings. + + * src/aiff.c + Fix potential memory leak in handling of 'MARK' chunk. + Remove un-needed test (unsigned > 0). + + * src/sd2.c + Improve handling of heap allocated buffer. + + * src/sndfile.c + Remove un-needed test (always true). + + * src/wav.c src/rf64.c + Ifdef out dead code that will be resurected some time in the future. + + * src/wav.c src/w64.c src/xi.c + Handle error return values from psf_ftell. + + * src/wav_w64.c + Fix handling and error checking of MSADPCM coefficient arrays. + + * regtest/*.c + Bunch of fixes. + + * src/test_file_io.c + Use snprintf instead of strncpy in test program. + +2009-02-21 Erik de Castro Lopo + + * src/sd2.c + Validate data before using. + + * src/caf.c + Validate channels per frame value before using, fixing a possible integer + overflow bug, leading to a possible heap overflow. Found by Alin Rad Pop of + Secunia Research (CVE-2009-0186). + +2009-02-20 Erik de Castro Lopo + + * Octave/octave_test.sh + Unset TERM environment variable and export LD_LIBRARY_PATH. + +2009-02-16 Erik de Castro Lopo + + * src/file_io.c + In windows code, cast LPVOID to 'char*' in printf. + +2009-02-15 Erik de Castro Lopo + + * M4/octave.m4 + Clear the TERM environment before evaluating anything in Octave. This works + around problems that might occur if a users TERM settings are incorrect. + Thanks to Rob Til Freedmen for helping to debug this. + + * src/wav.c + Handle four zero bytes as a marker within a LIST or INFO chunk. + Thanks to Rogério Brito for supplying an example file. + +2009-02-14 Erik de Castro Lopo + + * src/common.h src/*.c + Use C99 snprintf everywhere. + +2009-02-11 Erik de Castro Lopo + + * tests/test_wrapper.sh.in + New file to act as the template for the test wrapper script. + + * configure.ac + Generate tests/test_wrapper.sh from the template. + + * tests/Makefile.am + Replace all tests with a single invocation of the test wrapper script. + +2009-02-09 Erik de Castro Lopo + + * src/ogg.c + Record vorbis library version string. + + * configure.ac + Require libvorbis >= 1.2.2. + + * M4/endian.m4 + Fix bracketing of function for autoconf 2.63. Thanks to Richard Ash. + + * M4/octave.m4 M4/mkoctfile_version.m4 + Clean up AC_WITH_ARG usage using AC_HELP_STRING. + +2009-02-08 Erik de Castro Lopo + + * Octave/Makefile.am + Use $(top_buildir) instead of $(builddir) which may not be defined. + + * M4/octave.m4 + Improve logic and status reporting. + +2009-02-07 Erik de Castro Lopo + + * configure.ac AUTHORS NEWS README doc/*.html + Final tweaks for 1.0.18 release. + +2009-02-03 Erik de Castro Lopo + + * programs/sndfile-convert.c + Add 'htk' to the list of convert formats. + + * programs/sndfile-info.c + Simplify get_signal_max using SFC_CALC_SIGNAL_MAX command. + Increase size of files for which signal max will be calculated. + +2009-01-14 Erik de Castro Lopo + + * doc/index.html + Fix links for SoX and WavPlay. Thanks to Daniel Griscom. + +2009-01-11 Erik de Castro Lopo + + * programs/sndfile-metadata-get.c + Make valgrind clean. + Clean up temp string array usage. + Error out if trying to update coding history in RDWR mode. + +2009-01-10 Erik de Castro Lopo + + * doc/index.html + Fix links to versions of the LGPL. + +2008-12-14 Erik de Castro Lopo + + * tests/string_test.c + Add test for RDWR mode where the file ends up shorter than when it was + opened. + + * src/wav.c + Truncate the file on close for RDWR mode where the file ends up shorter + than when it was opened. + +2008-11-30 Erik de Castro Lopo + + * M4/add_cflags.m4 + Fix problem with quoting of '#include'. + + * M4/add_cxxflags.m4 configure.ac + Add new file M4/add_cxxflags.m4 and use it in configure.ac. + +2008-11-19 Erik de Castro Lopo + + * programs/sndfile-info.c + Apply patch from Conrad Parker to calculate and display total duration when + more than one file is dumped. + +2008-11-10 Erik de Castro Lopo + + * configure.ac src/Makefile.am + Tweaks to generation of Symbols files. + + * tests/win32_ordinal_test.c + Update tests for above changes. + +2008-11-06 Erik de Castro Lopo + + * programs/common.c + When merging broadcast info, make sure to clear the destination field + before copying in the new data. + + * programs/test-sndfile-metadata-set.py + Add test for the above. + + * src/broadcast.c + Fix checking of required coding_history_size. + +2008-10-28 Erik de Castro Lopo + + * tests/command_test.c + Add test to detect if coding history is truncated. + + * src/broadcast.c + Fix truncation of coding history. + +2008-10-27 Erik de Castro Lopo + + * tests/command_test.c + Add broadcast_coding_history_size test. + + * programs/*.[ch] + Use SF_BROADCAST_INFO_VAR to manipulate larger 'bext' chunks. + + * src/rf64.c + Add code to prevent infinite loop on malformed file. + + * src/common.h src/sndfile.c src/w64.c src/wav_w64.c + Rationalize and improve error handling when parsing 'fmt ' chunk. + + * M4/octave.m4 + Simplify and remove cruft. + Check for correct Octave version. + + * Octave/* + Reduce 3 C++ files to one, fix build for octave 3.0, fix build. + + * Octave/sndfile.cc Octave/PKG_ADD + Add Octave function sfversion which returns the libsndfile version that the + module is linked against. + + * Octave/Makefile.am + Bunch of build and 'make distcheck' fixes. + +2008-10-26 Erik de Castro Lopo + + * programs/common.c + Return 1 if SFC_SET_BROADCAST_INFO fails. + + * programs/test-sndfile-metadata-set.py + Update for new programs directory, exit on any error. + + * tests/error_test.c + Fix failure behaviour in error_number_test. + + * src/common.h src/sndfile.c + Add error number SFE_BAD_BROADCAST_INFO_SIZE. + + * src/* + Reimplement handling of broadcast extentioon chunk in WAV/WAVEX files. + + * src/broadcast.c + Fix generation of added coding history. + +2008-10-25 Erik de Castro Lopo + + * programs/sndfile-metadata-get.c programs/sndfile-info.c + Exit with non-zero on errors. + +2008-10-21 Erik de Castro Lopo + + * examples/sndfile-to-text.c examples/Makefile.am + Add a new example program and hook it into the build. + + * examples/ programs/ + Add a new directory programs and move sndfile-info, sndfile-play and other + real programs to the new directory, leaving example programs where they + were. + +2008-10-20 Erik de Castro Lopo + + * tests/Makefile.am + Automake 1.10 MinGW cross compiling fixes. + +2008-10-19 Erik de Castro Lopo + + * examples/sndfile-play.c + Remove call to deprecated function snd_pcm_sw_params_get_xfer_align. + Fix gcc-4.3 compiler warnings. + + * tests/command_test.c + Fix a valgrind warning. + + * tests/error_test.c tests/multi_file_test.c tests/peak_chunk_test.c + tests/pipe_test.tpl tests/stdio_test.c tests/win32_test.c + Fix gcc-4.3 compiler warnings. + +2008-10-17 Erik de Castro Lopo + + * src/broadcast.c + Fix termination of desitination string in strncpy_crlf. + When copying BROADCAST_INFO chunk, make sure destination gets correct line + endings. + + * examples/common.c + Fix copying of BROADCAST_INFO coding_history field. + +2008-10-13 Erik de Castro Lopo + + * tests/command_test.c + Add test function instrument_rw_test, but don't hook it into the testing + yet. + + * src/common.h src/command.c src/sndfile.c src/flac.c + Error code rationalization. + + * src/common.h src/sndfile.c + Set psf->error to SFE_CMD_HAS_DATA when adding metadata via sf_command() + fails due to psf->have_written being true. + + * doc/command.html + Document the SFC_GET/SET_BROADCAST_INFO comamnds. + +2008-10-10 Erik de Castro Lopo + + * tests/command_test.c + Improve error reporting when '\0' is found in coding history. + Fix false failure. + +2008-10-09 Erik de Castro Lopo + + * src/broadcast.c + Convert all coding history line endings to \r\n. + + * tests/command_test.c + Add test to make sure all line endings are converted to \r\n. + +2008-10-08 Erik de Castro Lopo + + * src/broadcast.c + Changed the order of coding history fields. + + * tests/command_test.c + Update bextch test to cope with previous change. + + * examples/common.c + Add extra length check when copying broadcast info data. + +2008-10-05 Erik de Castro Lopo + + * tests/utils.tpl tests/pcm_test.tpl + Update check_file_hash_or_die to use 64 bit hash. + + * tests/checksum_test.c tests/Makefile.am + Add new checksum_test specifically for lossy compression of headerless + files. + +2008-10-04 Erik de Castro Lopo + + * src/gsm610.c + Seek to psf->dataoffset before decoding first block. + + * src/sndfile.c + Fix detection of mpc2k files on big endian systems. + +2008-10-03 Erik de Castro Lopo + + * src/broadcast.c + Use '\r\n' newlines in Coding History as required by spec. + +2008-10-02 Erik de Castro Lopo + + * src/test_conversions.c + Use int64_t instead of 'long long'. + +2008-10-01 Erik de Castro Lopo + + * examples/sndfile-metadata-set.c + Remove --bext-coding-history-append command line option because it didn't + really make sense. + + * examples/sndfile-metadata-(get|set).c + Add usage messages. + + * examples/test-sndfile-metadata-set.py + Start work on test coding history. + +2008-09-30 Erik de Castro Lopo + + * README doc/win32.html + Bring these up to date. + + * src/aiff.c + Fix parsing of REX files. + +2008-09-29 Erik de Castro Lopo + + * src/file_io.c + Use intptr_t instead of long for return value of _get_osfhandle. + + * src/test_conversions.c src/test_endswap.tpl + Fix printing of int64_t values. + + * examples/sndfile-play.c + Fix win64 issues. + + * tests/win32_ordinal_test.c + Fix calling of GetProcAddress with ordinal under win64. + + * tests/utils.tpl + Fix win64 issues. + +2008-09-25 Erik de Castro Lopo + + * examples/* + Rename copy_data.[ch] to common.[ch]. Fix build. + Move code from sndfile-metadata-set.c to common.c. + + * examples/Makefile.am tests/Makefile.am regtest/Makefile.am + Clean paths. + +2008-09-19 Erik de Castro Lopo + + * doc/tutorial.html doc/Makefile.am + Add file doc/tutorial.html and hook into build/dist system. + +2008-09-14 Erik de Castro Lopo + + * examples/sndfile-metadata-set.c + Clean up handling of bext command line params. + +2008-09-13 Erik de Castro Lopo + + * src/w64.c + Add handling/skipping of a couple of new chunk types. + +2008-09-09 Erik de Castro Lopo + + * configure.ac + Add -funsigned-char to CFLAGS if the compiler supports it. + + * examples/sndfile-metadata-(get|set).c + Add handling for more metadata types. + +2008-09-04 Erik de Castro Lopo + + * src/common.h + Add macros SF_CONTAINER, SF_CODEC and SF_ENDIAN useful for splitting format + field of SF_INFO into component parts. + + * src/*.c + Use new macros everywhere it is appropriate. + +2008-09-02 Erik de Castro Lopo + + * examples/sndfile-bwf-set.c + Massive reworking. + +2008-08-24 Erik de Castro Lopo + + * examples/sndfile-bwf-set.c + Add --info-auto-create-date command line option. + + * examples/sndfile-metadata-set.c examples/sndfile-metadata-get.c + examples/Makefile.am examples/test-sndfile-bwf-set.py + Rename sndfile-bwf-(set|get).c to sndfile-metadata-(set|get).c. + Change command line args. + +2008-08-23 Erik de Castro Lopo + + * src/wav.c + Allow 'PAD ' chunk to be modified in RDWR mode. + + * src/sndfile.h.in src/sndfile.c + Add handling (incomplete) for SFC_SET_ADD_HEADER_PAD_CHUNK. + + * tests/Makefile.am tests/write_read_test.tpl tests/header_test.tpl + tests/misc_test.c + Add tests for RF64. + + * src/rf64.c + Fixes to make sure all tests pass. + + * tests/Makefile.am tests/string_test.c + Add string tests (not yet passing). + +2008-08-22 Erik de Castro Lopo + + * src/rf64.c + First pass at writing RF64 now working. + +2008-08-21 Erik de Castro Lopo + + * examples/sndfile-convert.c + Add SF_FORMAT_RF64 to format_map. + + * src/common.h src/sndfile.c + More RF64 support code. + + * examples/sndfile-bwf-set.c + Fix the month number in autogenerated date string and use hypen in date + instead of slash. + + * examples/test-sndfile-bwf-set.py + Update tests. + + * examples/sndfile-info.c + When called with -i or -b option, operate on all files on command line, not + just the first. + +2008-08-19 Erik de Castro Lopo + + * src/rf64.c + New file to handle RF64 (WAV like format supportting > 4Gig files). + + * src/sndfile.h.in src/common.h src/sndfile.c src/Makefile.am + Hook the above into build so hacking can begin. + + * src/pcm.c + Improve log message when pcm_init fails. + + * src/sndfile-info.c + Only calculate and print 'Signal Max' if file is less than 10 megabytes in + length. + +2008-08-18 Erik de Castro Lopo + + * tests/string_test.c + Polish string_multi_set_test. + + * src/wav.c + In RDWR mode, pad the header if necessary (ie LIST chunk has moved or + length has changed). + Minor fixes in wav_write_strings. + Write PAD chunk with default endian-ness, not a specific endian-ness. + + * examples/test-sndfile-bwf-set.py + Add Python script to test sndfile-bwf-set/get. + + * examples/sndfile-bwf-set.c + Clean up and fixes. + + * src/wav.c + Merge function wavex_write_header into wav_write_header, deleting about 70 + lines of code. + + * src/common.h + Double value of SF_MAX_STRINGS. + + * tests/string_test.c + Add string tests for WAVEX and RIFX files. + + * tests/command_test.c + Add broadcast test for WAVEX files. + +2008-08-17 Erik de Castro Lopo + + * tests/string_test.c + Add a new string_rdwr_test (currently failing for WAV). + Add a new string_multi_set_test (currently failing). + + * tests/command_test.c + Add new broadcast_rdwr_test (currently failing). + + * src/wav.c + Fix to WAV parser to allow 'bext' chunk to be updated in place. + In wav_write_tailer, seek to psf->dataend if its greater than zero. + + * src/sndfile.c + Make sure psf->have_written gets set correctly in mode SFM_RDWR. + + * configure.ac + Test for and gettimeofday. + + * src/common.c + Use gettimeofday() to initialize psf_rand_int32. + + * src/common.h src/sndfile.c + Add unique_id field to SF_PRIVATE struct. + + * src/common.h src/sndfile.c src/wav.c src/wav_w64.[ch] + Move wavex_ambisonic field from SF_PRIVATE struct to WAV_PRIVATE struct. + + * src/common.h src/strings.c + Add function psf_location_string_count. + +2008-08-16 Erik de Castro Lopo + + * configure.ac + Test for localtime and localtime_r. + + * examples/sndfile-convert.c + In function copy_metadata(), copy broadcast info if present. + + * examples/copy_data.[ch] examples/Makefile.am + Break some functionality out of sndfile-convert.c so it can be used in + examples/sndfile-bwf-set.c. + + * tests/utils.tpl + Add new function create_short_sndfile(). + + * examples/sndfile-bwf-set.c examples/sndfile-bwf-get.c + examples/Makefile.am + Add new files and hook into build. + +2008-08-11 Erik de Castro Lopo + + * src/sndfile.h.in + Fix comments. Patch from Mark Glines. + +2008-07-30 Erik de Castro Lopo + + * tests/misc_test.c + Use zero_data_test on Ogg/Vorbis files. + + * src/ogg.c + Fix segfault when closing an Ogg/Vorbis file that has been opened for write + but had no actual data written to it. Bug reported by Chinoy Gupta. + + * tests/Makefile.am + Make sure to run mist_test on Ogg/Vorbis files. + +2008-07-19 Erik de Castro Lopo + + * regtest/Makefile.am + Use SQLITE3_CFLAGS to locate sqlite headers. + +2008-07-10 Erik de Castro Lopo + + * doc/index.html doc/FAQ.html + Add notes about which versions of windows libsndfile works on. + +2008-07-03 Erik de Castro Lopo + + * tests/misc_test.c + Add a test for correct handling of Ambisonic files. Thanks to Fons + Adriaensen for the test. + + * src/wav.c src/wav_w64.c + Fix handling of Ambisonic files. Thanks to Fons Adriaensen for the patch. + +2008-06-29 Erik de Castro Lopo + + * configure.ac + Fix detection/enabling of external libs. + + * M4/extra_pkg.m4 M4/Makefile.am + Add m4 macro PKG_CHECK_MOD_VERSION which is a hacked version + PKG_CHECK_MODULES. The new macro prints the version number of the package + it is searching for. + +2008-06-14 Erik de Castro Lopo + + * src/aiff.c + Apply a fix from Axel Röbel where if the second loop in the instrument + chunk is none, the loop mode is written into the first loop. + +2008-05-31 Erik de Castro Lopo + + * src/test_float.c src/test_main.(c|h) src/Makefile.am + Add new file to test functions float32_(le|be)_(read|write) and + double64_(le|be)_(read|write). Hook into build and testsuite. + + * src/double64.c src/float32.c + Fix bugs in functions found by test added above. Thanks to Nicolas Castagne + for reporting this bug. + + * src/sndfile.h.in + Change time_reference_(low|high) entries of SF_BROADCAST_INFO struct to + unsigned. + + * examples/sndfile-info.c + Print out the BEXT time reference in a sensible format. + +2008-05-21 Erik de Castro Lopo + + * src/*.c + Fuzz fixes. + + * src/ogg.c + Add call to ogg_stream_clear to fix valgrind warning. + + * src/aiff.c + Fix x86_64 compile issue. + + * configure.ac src/Makefile.am src/flac.c src/ogg.c + Link to external versions of FLAC, Ogg and Vorbis. + + * tests/lossy_comp_test.c tests/ogg_test.c tests/string_test.c + tests/vorbis_test.c tests/write_read_test.tpl + Fix tests when configured with --disable-external-libs. + + * tests/external_libs_test.c tests/Makefile.am + Add new test and hook into build and test suite. + + * src/command.c + Use HAVE_EXTERNAL_LIBS to ensure that the SFC_GET_FORMAT_* commands return + the right data when external libs are disabled. + +2008-05-11 Erik de Castro Lopo + + * tests/write_read_test.tpl + Add a test for extending a file during write by seeking past the current + end of file. + + * src/sndfile.c + Allow seeking past end of file during write. + +2008-05-10 Erik de Castro Lopo + + * doc/api.html doc/command.html + Move all information about the sf_command function to command.html and add + a link from documentation of the sf_read/write_raw function to the + SFC_RAW_NEEDS_ENDSWAP command. + + * doc/index.html doc/FAQ.html doc/libsndfile.css + Minor documentation tweaks. + +2008-05-09 Erik de Castro Lopo + + * configure.ac + Add AM_PROG_CC_C_O. + +2008-04-27 Erik de Castro Lopo + + * tests/error_test.c + Add a test to make sure if file opened with sf_open_fd, and then the file + descriptor is closed, then sf_close will return an error code. Thanks to + Dave Flogeras for the bug report. + + * src/sndfile.c + Make sf_close return an error is the file descriptor is already closed. + +2008-04-19 Erik de Castro Lopo + + * configure.ac + Set object format to aout for OS/2. Thanks to David Yeo. + + * src/mpc2k.c src/sndfile.c src/sndfile.h.in src/common.h src/Makefile.am + Add ability to read MPC 2000 file. + + * tests/write_read_test.tpl tests/misc_test.c tests/header_test.tpl + tests/Makefile.am + Add tests for MPC 2000 file format. + + * examples/sndfile-convert.c + Allow conversion to MPC 2000 file format. + +2008-04-17 Erik de Castro Lopo + + * src/VORBIS/lib/codebook.c + Sync from upstream SVN. + + * autogen.sh configure.ac + Minor tweaks. + +2008-04-13 Erik de Castro Lopo + + * src/ogg.c + Add a patch that fixes finding the length in samples of an Ogg/Vorbis file. + The patch as supplied segfaulted and required many hours of debugging. + + * src/OGG/bitwise.c + Sync from upstream SVN. + +2008-04-09 Erik de Castro Lopo + + * src/aiff.c + Fix up handling of 'APPL' chunk. Thanks to Axel Röbel for bringing up + this issue. + +2008-04-06 Erik de Castro Lopo + + * tests/*.c + Add calls to sf_close() where needed. + + * tests/utils.tpl tests/multi_file_test.c + Always pass 0 as the third argument to open when OS_IS_WIN32. + +2008-04-03 Erik de Castro Lopo + + * src/test_* + Add files test_main.[ch]. + Collapse all tests into a single executable. + +2008-03-30 Erik de Castro Lopo + + * src/FLAC + Sync to upstream CVS. + +2008-03-25 Erik de Castro Lopo + + * src/common.h + Make SF_MIN and SF_MAX macros MinGW friendly. + + * examples/sndfile-(info|play).c + Use Sleep function from instead of _sleep. + + * tests/locale_test.c + Disable some tests when OS_IS_WIN32. + + * src/FLAC/src/share/replaygain_anal/replaygain_analysis.c + src/FLAC/src/share/utf8/utf8.c + MinGW fixes. + +2008-03-11 Erik de Castro Lopo + + * doc/FAQ.html + Tweaks to pcm16 <-> float conversion answer. + +2008-02-10 Erik de Castro Lopo + + * src/OGG + Sync to SVN upstream. + + * Makefile.am + Add 'DISTCHECK_CONFIGURE_FLAGS = --enable-gcc-werror'. + +2008-02-05 Erik de Castro Lopo + + * examples/sndfile-jackplay.c + Minor tweaks to warning message printed when compiled without libjack. + +2008-01-27 Erik de Castro Lopo + + * tests/peak_chunk_test.c + Improve read_write_peak_test to find more errors. Inspired by example + provided by Nicolas Castagne. + + * src/aiff.c + Another SFM_RDWR fix shown up by above test. + +2008-01-24 Erik de Castro Lopo + + * src/aiff.c + Fix reading of COMM encoding string. + + * src/chunk.c src/common.h src/Makefile.am + New file for storing and retrieving info about header chunks. Hook into + build. + + * src/aiff.c + Use new chunk logging to fix problem with AIFF in RDWR mode. + +2008-01-22 Erik de Castro Lopo + + * src/command.c + Add WVE to the list of major formats. + + * tests/aiff_rw_test.c + Fix error reporting. + +2008-01-21 Erik de Castro Lopo + + * src/common.[ch] + Add internal functions str_of_major_format, str_of_minor_format, + str_of_open_mode and str_of_endianness. + + * tests/write_read_test.tpl + Fix reporting of errors in new_rdwr_XXXX_test. + +2008-01-20 Erik de Castro Lopo + + * examples/sndfile-play.c + Apply patch from Yair K. to fix compiles with OSS v4. + + * src/common.h src/float32.c src/double64.c + Rename psf->float_enswap to psf->data_endswap. + + * src/sndfile.h.in src/sndfile.c src/pcm.c + Add command SFC_RAW_NEEDS_ENDSWAP. + + * tests/command.c + Add test for SFC_RAW_NEEDS_ENDSWAP. + + * doc/command.html + Document SFC_RAW_NEEDS_ENDSWAP. + + * tests/peak_chunk_test.c + Add test function read_write_peak_test. Thanks to Nicolas Castagne for the + bug report. + +2008-01-09 Erik de Castro Lopo + + * examples/sndfile-cmp.c + Add new example program contributed by Conrad Parker. + + * examples/Makefile.am + Hook into build. + + * doc/development.html + Change use or reconfigure.mk to autogen.sh. + +2008-01-08 Erik de Castro Lopo + + * tests/win32_test.c + Add another win32 test. + + * tests/util.tpl + Add function file_length_fd which wraps fstat. + + * tests/Makefile.am + Run the multi_file_test on AU files. + + * tests/multi_file_test.c + Use function file_length_fd() instead of file_length() to overcome stupid + win32 bug. Fscking hell Microsoft sucks so much. + +2008-01-05 Erik de Castro Lopo + + * src/sd2.c + Fix a rsrc parsing bug. Example file supplied by Uli Franke. + +2007-12-28 Erik de Castro Lopo + + * doc/index.html + Allow use of either LGPL v2.1 or LGPL v3. + + * tests/header_test.tpl + Add header_shrink_test from Axel Röbel. + + * src/wav.c + Add fix from Axel Röbel for writing files with float data but no peak + chunk (ie peak chunk gets removed after the file is opened). + + * src/aiff.c tests/header_test.tpl + Apply similar fix to above for AIFF files. + + * src/wav.c tests/header_test.tpl + Apply similar fix to above for WAVEX files. + + * src/command.c + Add Ogg/Vorbis to 'get format' commands. + +2007-12-16 Erik de Castro Lopo + + * src/ogg.c + Fix seeking on multichannel Ogg Vorbis files. Reported by Bodo. + Set the default encoding quality to 0.4 instead of 4.0 (Bodo again). + + * tests/ogg_test.c + Add stereo seek tests. + +2007-12-14 Erik de Castro Lopo + + * tests/ogg_test.c + Add a test (currently failing) for stereo seeking on Ogg Vorbis files. Test + case supplied by Bodo. + + * tests/utils.(def|tpl) + Add compare_XXX_or_die functions. + +2007-12-05 Erik de Castro Lopo + + * src/aiff.c + Fix a bug where ignoring ssnd_fmt.offset and ssnd_fmt.blocksize caused + misaligned reading of 24 bit data. Thanks to Uli Franke for reporting this. + +2007-12-03 Erik de Castro Lopo + + * src/vox_adpcm.c src/ima_oki_adpcm.[ch] src/Makefile.am + Merge in code from the vox-patch branch. Thanks to Robs for the patch + which fixes a long standing bug in the VOX codec. + +2007-12-01 Erik de Castro Lopo + + * examples/sndfile-convert.c + Fix handling of -override-sample-rate=X option. + +2007-11-25 Erik de Castro Lopo + + * src/ogg.c src/VORBIS + Merge in Ogg Vorbis support from John ffitch of the Csound project. + +2007-11-24 Erik de Castro Lopo + + * src/sndfile.c + Recognise files with 'vox6' extension as 6kHz OKI VOX ADPCM files. Also + recognise 'vox8' as and 'vox' as 8kHz files. + + * configure.ac + Detect libjack (JACK Audio Connect Kit). + + * examples/sndfile-jackplay.c examples/Makefile.am + Add new example program to play sound files using the JACK audio server. + Thanks to Jonatan Liljedahl for allowing this to be included. + +2007-11-21 Erik de Castro Lopo + + * doc/index.html + Update support table with SD2 and FLAC. + +2007-11-17 Erik de Castro Lopo + + * src/sndfile.c + Fix calculation of internal value psf->read_current when attempting to read + past end of audio data. + Remove redundant code. + + * tests/lossy_comp_test.c + Add read_raw_test to check that raw reads do not go past the end of the + audio data section. + Clean up error output messages. + + * src/sndfile.c + Add code to prevent sf_read_raw from reading past the end of the audio data. + + * tests/Makefile.am + Add the wav_pcm lossy_comp_test. + +2007-11-16 Erik de Castro Lopo + + * configure.ac src/Makefile.am src/create_symbols_file.py + More OS/2 fixes from David Yeo. + +2007-11-12 Erik de Castro Lopo + + * src/file_io.c tests/utils.tpl tests/benchmark.tpl + Improve handling of requirements for O_BINARY as suggested by Ed Schouten. + +2007-11-11 Erik de Castro Lopo + + * src/common.h + Fix symbol class when SF_MIN is nested inside SF_MAX or vice versa. + + * src/create_symbols_file.py + Add support for OS/2 contributed by David Yeo. + +2007-11-05 Erik de Castro Lopo + + * M4/gcc_version.m4 + Add macro AC_GCC_VERSION to detect GCC_MAJOR_VERSION and GCC_MINOR_VERSION. + + * configure.ac + Use AC_GCC_VERSION to work around gcc-4.2 inline warning stupidity. + See http://gcc.gnu.org/bugzilla/show_bug.cgi?id=33995 + Use -fgnu-inline to prevent stupid warnings. + +2007-11-03 Erik de Castro Lopo + + * tests/util.tpl + Increase the printing width for print_test_name(). + + * tests/command_test.c tests/Makefile.am + Add tests for correct updating of broadcast WAV coding history. + + * examples/sndfilehandle.cc examples/Makefile.am + Add example program using the C++ SndfileHandle class. + +2007-10-29 Erik de Castro Lopo + + * src/common.h src/sndfile.c + Add error codes SFE_ZERO_MAJOR_FORMAT and SFE_ZERO_MINOR_FORMAT. + +2007-10-26 Erik de Castro Lopo + + * src/sd2.c + Identify sample-rate/sample-size/channels by resource id. + +2007-10-25 Erik de Castro Lopo + + * src/broadcast.c src/common.h src/sndfile.c + Improvements to handling of broadcast info in WAV files. Thanks to Frederic + Cornu and other for their input. + +2007-10-24 Erik de Castro Lopo + + * src/FLAC/include/share/alloc.h + Mingw fix for SIZE_T_MAX from Uli Franke. + +2007-10-23 Erik de Castro Lopo + + * tests/open_fail_test.c tests/error_test.c tests/Makefile.am + Move tests from open_fail_test.c to error_test.c and remove the former. + +2007-10-22 Erik de Castro Lopo + + * tests/scale_clip_test.(def|tpl) + Add tests for SFC_SET_INT_FLOAT_WRITE command. + + * doc/command.html + Add docs for SFC_SET_INT_FLOAT_WRITE command. + + * examples/sndfile-play.c tests/dft_cmp.c + Fix gcc-4.2 warning messages. + +2007-10-21 Erik de Castro Lopo + + * src/sndfile.h.in src/sndfile.c + Add command SFC_GET_CURRENT_SF_INFO. + + * src/sndfile.h.in src/sndfile.c src/create_symbols_file.py + Remove function sf_get_info (only ever in pre-release code). + + * tests/command_test.c + Add test for SFC_GET_CURRENT_SF_INFO. + +2007-10-15 Erik de Castro Lopo + + * src/wav.c + Add parsing of 'exif' chunks. Originally coded by Trent Apted. + + * configure.ac + Put config stuff in Cfg directory. + Remove check for inttypes.h. + +2007-10-10 Erik de Castro Lopo + + * src/w64.c + Fix writing of 'riff' chunk length and check for correct value in parser. + +2007-09-20 Erik de Castro Lopo + + * doc/index.html + Link to MP3 FAQ entry. + +2007-09-18 Erik de Castro Lopo + + * src/flac.c + Move the blocksize check to an earlier stage of flac_buffer_copy. + +2007-09-12 Erik de Castro Lopo + + * src/FLAC + Huge merge from FLAC upstream. + +2007-09-10 Erik de Castro Lopo + + * examples/*.c + Change license to all example programs to BSD. + +2007-09-08 Erik de Castro Lopo + + * src/FLAC/include/FLAC/metadata.h + Include to prevent compile error on OSX. + + * Octave/octave_test.sh + Disable test on OSX. Can't get it to work. + + * src/flac.c + Check the blocksize returned from the FLAC decoder to prevent buffer + overruns. Reported by Jeremy Friesner. Thanks. + +2007-09-07 Erik de Castro Lopo + + * Makefile.am M4/octave.m4 + Fix build when Octave headers are not present. + +2007-08-27 Erik de Castro Lopo + + * doc/development.html + Add note about bzr repository directory looking empty. + +2007-08-26 Erik de Castro Lopo + + * configure.ac Octave/* M4/octave_* + Bunch of changes to add ability to build GNU Octave modules to read/write + sound files using libsndfile from Octave. + +2007-08-23 Erik de Castro Lopo + + * acinclude.m4 configure.ac ... + Get rid of acinclude.m4 and replace it with an M4 directory. + +2007-08-21 Erik de Castro Lopo + + * src/sndfile.h.in + Remove crufty Metrowerks compiler support. Allow header file to be compiled + on windows with both GCC and microsoft compiler. + +2007-08-19 Erik de Castro Lopo + + * tests/dft_cmp.[ch] tests/floating_point_test.tpl + Clean up floating point tests. + +2007-08-14 Erik de Castro Lopo + + * src/aiff.c + Fix segfault when COMM chunk length is byte swapped. + +2007-08-09 Erik de Castro Lopo + + * src/common.h src/mat4.c src/mat5.c src/sndfile.c + Add a generic SFE_CHANNEL_COUNT_ZERO error, remove format specific errors. + + * src/au.c + Fix crash on AU files with zero channel count. Reported by Ben Alison. + +2007-08-08 Erik de Castro Lopo + + * src/voc.c + Fix bug in handling file supplied by Matt Olenik. + +2007-07-31 Erik de Castro Lopo + + * src/OGG + Merge from OGG upstream sources. + +2007-07-25 Erik de Castro Lopo + + * src/FLAC + Merge from FLAC upstream sources. + +2007-07-15 Erik de Castro Lopo + + * src/flac.c + Fix memory leak; set copy parameter to FALSE in call to + FLAC__metadata_object_vorbiscomment_append_comment. + + * src/common.[ch] + Add function psf_rand_int32(). + +2007-07-14 Erik de Castro Lopo + + * src/FLAC + Merge from FLAC upstream sources. + + * src/strings.c tests/string_test.c tests/Makefile.am + Make sure string tests for SF_STR_LICENSE actually works. + +2007-07-13 Erik de Castro Lopo + + * tests/string_test.c + Add ability to test strings stored in metadata secion of FLAC files. + + * src/string.c + Fix logic for testing if audio data has been written and string is added. + Make sure SF_STR_ALBUM actually works. + + * src/flac.c + Finalize reading/writing string metadata. Tests pass. + + * src/sndfile.h.in tests/string_test.c src/flac.c + Add string type SF_STR_LICENSE, update test and use for FLAC files. + + * src/sndfile.h.in + Add definition for SFC_SET_SCALE_FLOAT_INT_WRITE command. + + * src/common.h src/double64.c src/float32.c src/sndfile.c + Add support for SFC_SET_SCALE_FLOAT_INT_WRITE (still needs testing). + +2007-07-12 Erik de Castro Lopo + + * src/flac.c + Apply patch from Ed Schouten to read artist and title metadata from FLAC + files. + Improve reporting of FLAC metadata. + + * src/sndfile.h.in tests/string_test.c src/flac.c + Add string type SF_STR_ALBUM, update test and use for FLAC files. + +2007-06-28 Erik de Castro Lopo + + * src/FLAC/* + Merge from upstream CVS. + +2007-06-16 Erik de Castro Lopo + + * src/FLAC/* + Update from upstream CVS. + +2007-06-14 Erik de Castro Lopo + + * tests/cpp_test.cc + Add extra tests for when the SndfileHandle constructor fails. + + * src/sndfile.hh + Make sure failure to open the file in the constructor does not allow later + calls to other methods to fail. + +2007-06-10 Erik de Castro Lopo + + * tests/util.tpl + Add function write_mono_file. + + * tests/generate.[ch] tests/Makefile.am + Add files generate.[ch] and hook into build. + + * tests/write_read_test.tpl + Add multi_seek_test. + + * src/flac.c + Fix buffer overflow bug. Test provided by Jeremy Friesner and fix provided + by David Viens. + +2007-06-07 Erik de Castro Lopo + + * doc/FAQ.html + Minor update. + + * configure.ac src/FLAC/src/libFLAC/ia32/Makefile.am src/Makefile.am + Apply patch from Trent Apted make it compile on Intel MacOSX. Thanks Trent. + +2007-05-28 Erik de Castro Lopo + + * src/wav.c + Fix writing of MSGUID subtypes. Thanks to Bruce Sharpe. + +2007-05-22 Erik de Castro Lopo + + * src/wav.c + Fix array indexing bug raised by Bruce Sharpe. + +2007-05-12 Erik de Castro Lopo + + * src/FLAC/src/share/getopt/getopt.c + Fix Mac OSX / PowerPC compile warnings. + + * configure.ac + Make sure WORDS_BIGENDIAN gets correctly defined for FLAC code. + +2007-05-04 Erik de Castro Lopo + + * doc/FAQ.html + Add Q/A about MP3 support. + +2007-05-03 Erik de Castro Lopo + + * doc/new_file_type.HOWTO + Minor updates. + +2007-05-02 Erik de Castro Lopo + + * src/wve.c + Fix a couple bad parameters with psf_log_printf. + + * src/pcm.c + Improve error reporting. + + * src/common.h src/common.c + Constify psf_hexdump. + +2007-04-30 Erik de Castro Lopo + + * src/FLAC + Ditch and re-import required FLAC code. + + * configure.ac + Force FLAC__HAS_OGG variable to 1. + + * src/FLAC/src/libFLAC/stream_encoder.c + Fix compiler warnings. + +2007-04-23 Erik de Castro Lopo + + * configure.ac tests/win32_ordinal_test.c + Detect if win32 DLL is beging generated and only run win32_ordinal_test if + true. + + * src/G72x/Makefile.am src/Makefile.am + Use $(EXEEXT) where possible. + +2007-04-18 Erik de Castro Lopo + + * src/wve.c src/common.h src/sndfile.c + Complete definition of SfE_WVE_NO_WVE error message. + + * src/wve.c + Fix error in files generated on big endian systems. Robustify parsing. + +2007-04-16 Erik de Castro Lopo + + * src/double64.c + Fix clipping of double to short conversions on 64 bit systems. + + * src/flac.c regtest/database.c tests/cpp_test.cc + Fix compile warnings for 64 bit systems. + +2007-04-15 Erik de Castro Lopo + + * src/wav.c src/wav_w64.c + Use audio detect function when 'fmt ' chunk data is suspicious. + + * configure.ac + Add ugly hack to remove -Werror from some Makefiles. + +2007-04-14 Erik de Castro Lopo + + * src/GSM610/long_term.c src/macbinary3.c tests/cpp_test.cc + Add patch from André Pang to clean up compiles on OSX. + + * src/wve.c src/common.h src/sndfile.c src/sndfile.h.in + examples/sndfile-convert.c + Merge changes from Reuben Thomas to improve WVE support. + + * tests/lossy_comp_test.c tests/Makefile.am + Add tests for WVE files. + +2007-04-11 Erik de Castro Lopo + + * src/sndfile.hh + Add a static SndfileHandle::formatCheck method as suggested by Jorge + Jiménez. + +2007-04-09 Erik de Castro Lopo + + * src/sndfile.c + Fixed a bug in sf_error() where the function itself was being compared + against zero. Add a check for a NULL return from peak_info_calloc. Fix a + possible NULL dereference. + +2007-04-07 Erik de Castro Lopo + + * src/flac.c + Turn off seekable flag when writing, return SFE_BAD_RDWR_FORMAT when + opening file for RDWR. + + * src/sndfile.c + Improve error message for SFE_BAD_RDWR_FORMAT. + + * src/mat4.c + Fix array indexing issue. Thanks to Ben Allison (Nullsoft) for alerting me. + +2007-03-05 Erik de Castro Lopo + + * doc/FAQ.html + Add Q/A 19 on project files. + +2007-03-01 Erik de Castro Lopo + + * src/sndfile.c + Guard agains MacOSX universal binary compiles. + + * doc/FAQ.html + Add Q/A 18 and clean up Q3. + +2007-02-22 Erik de Castro Lopo + + * src/aiff.c + Add support for 'in24' files. + +2007-02-13 Erik de Castro Lopo + + * src/wav.c src/wav_w64.c src/wav_w64.h + Start work towards detecting ausio codec type from the actual audio data. + + * src/audio_detect.c src/test_audio_detect.c + Add new file and its unit test. + +2007-02-07 Erik de Castro Lopo + + * examples/cooledit-fixer.c examples/Makefile.am + Remove old broken example program. + +2007-02-06 Erik de Castro Lopo + + * src/sndfile.c src/sndfile.h.in src/create_symbols_file.py + Add function sf_get_info. + +2007-01-25 Erik de Castro Lopo + + * examples/sndfile-play.c + For ALSA, use the 'default' device instead of 'plughw:0'. + +2007-01-22 Erik de Castro Lopo + + * src/sndfile.c + Allow writing of WAV/WAVEX 'BEXT' chunks in SFM_RDWR mode. + +2007-01-21 Erik de Castro Lopo + + * doc/development.html doc/embedded_files.html man/sndfile-play.1 + Minor documentation fixes. Thanks Reuben Thomas. + +2006-12-16 Erik de Castro Lopo + + * examples/sndfile-convert.c + Add -override-sample-rate command line option. + +2006-11-19 Erik de Castro Lopo + + * tests/misc_test.c + Force errno to zero at start of some tests. + + * src/sndfile.c + Minor clean up of error handling. + + * configure.ac + Remove an assembler test which was failing on OSX. + +2006-11-15 Erik de Castro Lopo + + * src/common.h + Fix the definition of SF_PLATFORM_S64 for MinGW. + + * src/FLAC/Makefile.am src/FLAC/share/grabbag/Makefile.am + Fix path problems for MinGW. + +2006-11-13 Erik de Castro Lopo + + * src/sfendian.h + Add include guard. + + * src/Makefile.am src/flac.c + Clean up include paths. + + * src/test_conversions.c + New file to test psf_binheader_readf/writef functions. + + * src/Makefile.am src/test_file_io.c src/test_log_printf.c src/common.c + Clean up unit testing. + + * src/common.c + Fix a bug reading/writing 64 bit header fields. Thanks to Jonathan Woithe + for reporting this. + + * src/test_conversions.c + Complete unit test for above fix. + +2006-11-11 Erik de Castro Lopo + + * src/sndfile.c + More refactoring to clean up psf_open_file() and vairous sf_open() + functions. + +2006-11-09 Erik de Castro Lopo + + * src/wav.c + Apply a patch from Jonathan Woithe to allow opening of (malformed) WAV + files of over 4 gigabytes. + +2006-11-05 Erik de Castro Lopo + + * src/sndfile.c + Refactor function psf_open_file() to provide a single return point. + + * tests/misc_test.c + Fix permission_test to ensure that read only file can be created. + +2006-11-03 Erik de Castro Lopo + + * src/common.h + Add SF_PLATFORM_S64 macro as a platform independant way of doing signed 64 + bit integers. + + * src/aiff.c src/svx.c src/wav.c + Add warning in log if files are larger than 4 gigabytes in size. + +2006-11-01 Erik de Castro Lopo + + * src/FLAC src/OGG confgure.ac src/Makefile.am + Pull in all required FLAC and OGG code so external libraries are not + needed. This makes compiling on stupid fscking Windoze easier. + +2006-10-27 Erik de Castro Lopo + + * src/sd2.c + Add workaround for switched sample rate and sample size. + + * src/wav.c + Add workaround for excessively long coding history in the 'bext' chunk. + +2006-10-23 Erik de Castro Lopo + + * src/sndfile.h.in src/sndfile.c src/wav.c doc/command.html + Use SF_AMBISONIC_* instead of SF_TRUE/SF_FALSE. + +2006-10-22 Erik de Castro Lopo + + * src/sndfile.h.in src/wav.c src/wav_w64.c src/common.h doc/command.html + Apply a patch from Fons Adriaensen to allow writing on WAVEX Ambisonic + files. Still needs a little tweaking before its ready for release. + + * src/*.c + Use the UNUSED macro to prevent compiler warnings. + +2006-10-19 Erik de Castro Lopo + + * src/aiff.c + Fix a bug in parsing AIFF files with a slightly unusual 'basc' chunk. Thanks + to David Viens for providing two example files. + + * src/common.(c|h) src/aiff.c + Add a function psf_sanitize_string and use it in aiff.c. + +2006-10-18 Erik de Castro Lopo + + * src/wav_w64.c + Apply a patch from Fons Adriaensen which fixes a minor WAVEX GUID issue. + +2006-10-17 Erik de Castro Lopo + + * src/Makefile.am + Fix problem related to recent test coverage changes. + +2006-10-15 Erik de Castro Lopo + + * configure.ac tests/Makefile.am + Add --enable-test-coverage configure option. + +2006-10-05 Erik de Castro Lopo + + * src/sndfile.hh + Add an std::string SndfileHandle constructor. + + * tests/scale_clip_test.tpl + Fix the 'make distcheck' target. + +2006-10-03 Erik de Castro Lopo + + * src/double64.c src/float32.c + Add optional clipping on float file data to int read data conversions. + + * tests/tests/scale_clip_test.(def|tpl) + Add test for above new code. + +2006-09-06 Erik de Castro Lopo + + * tests/aiff_rw_test.c + Add 'MARK' chunks to make sure they are parsed correctly. + +2006-09-05 Erik de Castro Lopo + + * src/aiff.c + Fix parsing of MARK chunks. Many thanks to Sciss for generating files to + help debug the problem. + +2006-09-02 Erik de Castro Lopo + + * src/common.h + Make the SF_MIN and SF_MAX macros at least partially type safe. + + * tests/lossy_comp_test.c + Fix overflow problems when ensuring that signalis not zero. + +2006-08-31 Erik de Castro Lopo + + * configure.ac docs/*.html + Changes for release 1.0.17. + +2006-08-08 Erik de Castro Lopo + + * src/flac.c + Remove inline from functions called by pointer. Thanks to Sampo Savolainen + for notifying me of this. + +2006-07-31 Erik de Castro Lopo + + * src/sndfile.hh + Add writeSync method. + Add copy constructor and assignment operator (thanks Daniel Schmitt). + Add methods readRaw and writeRaw. + Make read/write/readf/writef simple overlaods instead of templates (thanks + to Trent Apted for suggesting this). + + * tests/cpp_test.cc + Cleanup. Add tests. + +2006-07-30 Erik de Castro Lopo + + * src/sndfile.hh + Templatize the read/write/readf/writef methods as suggested by Lars Luthman. + Prevent the potential leak of SNDFILE* pointers in the openRead/openWrite/ + openReadWrite methods. + Add const to SF_INFO pointer in Sndfile constructor. + Make the destrictor call the close() method. + + * tests/cpp_test.cc + Add more tests. + +2006-07-29 Erik de Castro Lopo + + * tests/cpp_test.cc + Remove the generated file so "make distcheck" passes. + + * src/Makefile.am + Add sndfile.hh to distributed header files. + + * src/sndfile.hh + Change the license for the C++ wrapper to modified BSD. + +2006-07-28 Erik de Castro Lopo + + * src/sndfile.hh + Complete it. + + * tests/cpp_test.cc + Add more tests. + +2006-07-27 Erik de Castro Lopo + + * tests/utils.tpl + Add extern C to generated header file. + + * src/sndfile.hh + Work towards completing this. + + * tests/cpp_test.cc tests/Makefile.am + Add a C++ test and hook into build. + + * configure.ac + Add appropriate CXXFLAGS. + +2006-07-26 Erik de Castro Lopo + + * configure.ac + Test if compiler supports -Wpointer-arith. + + * src/common.c + Fix a warning resulting from -Wpointer-arith. + +2006-07-15 Erik de Castro Lopo + + * examples/sndfile-play.c + Explicitly set endian-ness as well as setting 16 bit output. + + * examples/sndfile-info.c + Make sure to parse info if file fails to open. + + * src/sndfile.c + Handle parse error a little better. + + * src/wav_w64.[ch] + Minor clean up, add detection of IPP ITU G723.1. + +2006-06-23 Erik de Castro Lopo + + * src/sndfile.c + Make sure psf->dataoffset gets reset to zero when openning headersless + files based on the file name extension. + +2006-06-21 Erik de Castro Lopo + + * tests/(command|lossy_comp|pcm|scale_clip)_test.c tests/fix_this.c + tests/write_read_test.(tpl|def) + Fix gcc-4.1 compiler warnings about "dereferencing type-punned pointer will + break strict-aliasing rules". + + * examples/cooledit-fixer.c + More fixes like above. + +2006-06-20 Erik de Castro Lopo + + * src/file_io.c + Fix a windows bug where the syserr string of SF_PRIVATE was not being set + correctly. + + * src/sndfile.c + Fixed a logic bug in sf_seek(). Thanks to Paul Davis for finding this. + +2006-06-04 Erik de Castro Lopo + + * configure.ac + Fixed detection of S_IRGRP. + +2006-05-30 Erik de Castro Lopo + + * sndfile-convert.c + Add conversion SF_INSTRUMENT data when present. + +2006-05-22 Erik de Castro Lopo + + * doc/development.html + Removed references to tla on windows. + + * src/common.h src/sndfile.c + Add separate void pointers for file containter and file codec data to + SF_PRIVATE struct. Still need to move all existing fdata pointers. + + * tests/write_read_test.tpl + Change the order of some tests. + + * src/aiff.c + When writing 'AIFC' files, make sure get an 'FVER' gets added. + + * src/common.h src/(dwvw|flac|g72x|gsm610|ima_adpcm|ms_adpcm|paf|sds).c + src/(sndfile|voc|vox_adpcm|xi).c + Remove fdata field from SF_PRIVATE struct and replace it with codec_data. + +2006-05-10 Erik de Castro Lopo + + * Win32/testprog.c Win32/Makefile.am + Add a minimal win32 test program. + + * Win32/README-precompiled-dll.txt Mingw-make-dist.sh + Update readme and Mingw build script. + +2006-05-09 Erik de Castro Lopo + + * configure.ac acinclude.m4 + Minor fixes for Solaris. + +2006-05-05 Erik de Castro Lopo + + * src/test_endswap.(def|tpl) + Fix printf formatting for int64_t on 64 bit machines. + +2006-05-04 Erik de Castro Lopo + + * src/binhead_check.py + New file to check for bad parameters passed to psf_binheader_writef(). + + * src/Makefile.am + Hook into test suite. + + * src/voc.c src/caf.c src/wav.c src/mat5.c src/mat4.c + Fix bugs found by new test program. + + * src/double64.c + Clean up double64_get_capability(). + +2006-05-03 Erik de Castro Lopo + + * src/wav_w64.c + Fix a bug on x86_64 where an int was being passed via stdargs and being + read using size_t which is 64 bits. Thenks to John ffitch for giving me a + login on his box. + +2006-05-02 Erik de Castro Lopo + + * src/caf.c src/double64.c examples/sndfile-info.c tests/virtual_io_test.c + tests/utils.tpl + Fix a couple of signed/unsigned problems. + +2006-05-01 Erik de Castro Lopo + + * tests/command_test.c + Add channel map tests. + + * src/common.h src/sndfile.c + Add a pointer to the SF_PRIVATE struct and make sure it gets freed in + sf_close(). + +2006-04-30 Erik de Castro Lopo + + * configure.ac doc/(command|index|api).html NEWS README + Updates for 1.0.16 release. + + * src/sndfile.h.in + Define enums for channel mapping. + + * examples/sndfile-info.c + Clean up usage of SF_INFO struct. + +2006-04-29 Erik de Castro Lopo + + * tests/util.tpl + Add function testing function exit_if_true(). + + * tests/floating_point_test.tpl + Fix a problem where the test program was not exiting when the test failed. + +2006-04-15 Erik de Castro Lopo + + * src/sndfile.h.in src/sndfile.c src/common.h src/command.c + Implement new commands SFC_GET_SIGNAL_MAX and SFC_GET_MAX_ALL_CHANNELS. + + * doc/commands.html + Document new commands. Other minor updates. + + * tests/peak_chunk_test.c + Update tests for new commands. + +2006-04-02 Erik de Castro Lopo + + * tests/peak_chunk_test.c + Add test for RIFX and WAVEX files. + Try and confuse the PEAK chunk writing by enabling and disabling it. + + * src/sndfile.c + Fix a bug where enabling and disabling PEAK chunk was screwing up. + +2006-03-31 Erik de Castro Lopo + + * src/sndfile.h.in + Add the block of 190 reserved bytes into this struct to allow for + future expansion. + + * src/wav.c src/sndfile.c src/broadcast.c + Significant cleanup of broadcast wave stuff. + + * examples/sndfile-info.c + Fix print message. + + * tests/command_test.c tests/Makefile.am + Complete bext tests, hook test in test suite. + +2006-03-30 Erik de Castro Lopo + + * src/sndfile.h.in + Make coding_history field of SF_BROADCAST_INFO struct a char array instead + of a char pointer. + + * src/sndfile.c src/common.h src/wav.c + Clean up knock on effects of above chnage. + + * examples/sndfile-info.c + Add -b command line option to usage message. + Clean up output of broadcast wave info. + + * src/wav.c + Ignore and skip the 'levl' chunk. + +2006-03-26 Erik de Castro Lopo + + * configure.ac + Fix handling of --enable and --disable configure args. Thanks to Diego + 'Flameeyes' Pettenò who sent the patch. + +2006-03-22 Erik de Castro Lopo + + * doc/win32.html + Make it really clear that although the MSVC++ cannot compile libsndfile, + the precompiled DLL can be used in C++ programs compiled with MSVC++. + +2006-03-18 Erik de Castro Lopo + + * src/aiff.c + Fix bug in writing of INST chunk in AIFF files. + Fix potential bug in writing MARK chunks. + + * src/sndfile.c + Make sure the instrument chunk can only be written at the start of the file. + + * tests/command_test.c + Add check of log buffer. + + * tests/utils.tpl + Add usage of space character to psf_binheader_writef. + +2006-03-17 Erik de Castro Lopo + + * src/Makefile.am tests/Makefile.am + Remove --source-time argument from autogen command lines. + + * src/broadcast.c + New file for EBU Broadcast chunk in WAV files. + + * src/sndfile.c src/sndfile.h.in src/wav.c src/common.h + Add patch from Paul Davis implementing read/write of the BEXT chunk. + +2006-03-16 Erik de Castro Lopo + + * Win32/README-precompiled-dll.txt + New file descibing how to use the precompiled DLL. + + * Win32/Makefile.am + Add Win32/README-precompiled-dll.txt to EXTRA_DIST files. + + * configure.ac + Bump version to 1.0.15. + +2006-03-11 Erik de Castro Lopo + + * src/wav.c + On read, only add the endian flag if the file is big endian. + + * src/ms_adpcm.c + Fixed writing of APDCM coeffs in RIFX files. + + * tests/write_read_test.tpl tests/lossy_comp_test.c + Add tests for RIFX files. + +2006-03-10 Erik de Castro Lopo + + * Mingw-make-dist.sh + Bunch of improvements. + + * doc/win32.html + Update MinGW program versions. + +2006-03-09 Erik de Castro Lopo + + * src/create_symbols_file.py + Fix the library name in created win32 DEF file. Add correct DLL name for + Cygwin DLL. + + * Win32/Makefile.am tests/Makefile.am + Remove redundant files, add win32_ordinal_test to test suite. + + * tests/win32_ordinal_test.c + Update to do test in cygsndfile-1.dll as well. + + * doc/win32.html + Fix typo, mention that -mno-cygwin with the Cygwin compiler does not work. + + * src/wav.c src/wav_w64.c src/sndfile.c src/sndfile.h.in + Apply large patch from Jesse Chappell which adds support for RIFX files. + +2006-03-08 Erik de Castro Lopo + + * Makefile.am + Add Mingw-make-dist.sh to the extra dist files. + + * configure.ac + Fix setting SHLIB_VERSION_ARG for MinGW. + + * tests/win32_ordinal_test.c + New test program to test that the win32 DLL ordinals agree with the DEF + file. + +2006-03-04 Erik de Castro Lopo + + * src/common.h + Add a static inline function to convert an int to a size_t. This will be + a compile to nothing on 32 bit CPUs and a sign extension on 64 bit CPUs. + + * src/aiff.c src/avr.c src/common.c src/xi.c src/gsm610.c + Fix an ia64 problem where a varargs function was being passed an int in + some places and a size_t in other places. + + * src/sd2.c + Add a workaround for situations where OSX seems to add an extra 0x52 bytes + to the start of the resource fork. + +2006-02-19 Erik de Castro Lopo + + * Mingw-make-dist.sh + Add a shell script to build the windows binary/source ZIP file. + + * doc/index.html + Add download link for windows binary/source ZIP file. Add links for GPG + signatures. + + * doc/win32.html + Remove info about building using microsoft compiler. + + * configure.ac + Bump version to 1.0.14. + +2006-02-11 Erik de Castro Lopo + + * src/sd2.c + Improve logging of errors in resource fork parser. + +2006-01-31 Erik de Castro Lopo + + * Win32/Makefile.msvc + Replace au_g72x.* with g72x.*. Thanks to ussell Borogove. + +2006-01-29 Erik de Castro Lopo + + * src/common.c + Make sure return values are initialised header buffer is full. + + * src/wav.c + Add workarounds for messed up WAV files. + +2006-01-21 Erik de Castro Lopo + + * Win32/config.h + Undef HAVE_INTTYPES_H for win32. + + * tests/command_test.c + Don't exit on error in instrument test for XI files. + + * configure.ac + Bump version to 1.0.13. + + * doc/*.html NEWS README + Update version numbers. + +2006-01-19 Erik de Castro Lopo + + * src/xi.c + Start work on add read/write of instrument chunks. + + * src/command_test.c + Add tests for XI instrument chunk. + + * tests/largefile_test.c tests/Makefile.am + Add new test and hook it into the build system. This test will not be run + automatically because it requires 3 Gig of disk space and takes 3 minutes + to run. + +2006-01-10 Erik de Castro Lopo + + * examples/sndfile-play.c + Fix calculation of samples remaining in win32 code. Thanks Axel Röbel. + + * src/common.h + Make sure length of header buffer can hold header plus strings. Thanks Axel + Röbel. + +2006-01-09 Erik de Castro Lopo + + * src/sndfile.h.in src/aiff.c src/wav.c + Apply a patch from John ffitch (Csound project). + Add detune field to SF_INSTRUMENT struct. + Add reading/writing instrument chunks to WAV files. + + * tests/command_test.c + Update SF_INSTRUMENT tests. + + * tests/Makefile.am + Hook instrument tests into test suite. + +2006-01-05 Erik de Castro Lopo + + * configure.ac + Check for because some broken systems (like Solaris) don't have + which is the 1999 ISO C standard file containing int64_t. + + * src/sfendian.h src/common.h + Use if is not available. + +2005-12-30 Erik de Castro Lopo + + * tests/peak_chunk_test.c + Extend and clean up tests. + + * src/sndfile.c + Fix a bug that prevented the turning off of PEAK chunks. + +2005-12-29 Erik de Castro Lopo + + * tests/error_test.c + Make the test distclean correct. + + * src/file_io.c + Fix an SD2 MacOSX bug (reported by vince schwarzinger). + +2005-12-28 Erik de Castro Lopo + + * src/aiff.c tests/command_test.c + Apply a big patch from John ffitch (Csound project) to add reading and + writing of instrument chunks to AIFF files. Also update the test. + +2005-12-10 Erik de Castro Lopo + + * tests/aiff_rw_test.c tests/virtual_io_test.c tests/utils.tpl + Move test function dump_data_to_file() to utils.tpl. + + * tests/error_test.c tests/Makefile.am + Updates, including a new test to test that sf_error() returns a valid error + number. + +2005-12-07 Erik de Castro Lopo + + * examples/list_formats.c + Make sure the SF_INFO struct is memset to all zero before being used. + Thanks to Stephen F. Booth. + + * src/sndfile.c + Make the return value of sf_error() match the API documentation. + +2005-11-19 Erik de Castro Lopo + + * examples/sndfile-convert.c + Allow conversion to raw gsm610. + + * src/common.h src/sndfile.c src/au.c + Remove au_nh_open() and all references to it (wasn't working anyway). + + * tests/headerless_test.c + Add new test for file extension based detection. + + * src/sndfile.c + Rejig file extension based file type detection. + +2005-11-16 Erik de Castro Lopo + + * src/sndfile.c + Add "gsm" as a recognised file extension when no magic number can be found. + + * tests/lossy_comp_test.c tests/Makefile.am + Test headerless GSM610. + +2005-11-13 Erik de Castro Lopo + + * doc/api.html + Fix a minor typo and a minor error. Thanks Christoph Kobe and John Pavel. + +2005-10-30 Erik de Castro Lopo + + * src/wav_w64.c + Add more reporting of 'fmt ' chunk for G721 encoded files. + + * src/wav.c + Gernerate a more correct 20 byte 'fmt ' chunk rather than a 16 byte one. + +2005-10-29 Erik de Castro Lopo + + * src/G72x/g72x.[ch] + Minor cleanup of interface. + +2005-10-28 Erik de Castro Lopo + + * src/ogg.c + Removed the horribly broken and non-functional OGG implementation when + --enable-experimental was enabled. When OGG does finally work it will be + merged. + + * src/caf.c + Fix a memory leak. + +2005-10-27 Erik de Castro Lopo + + * src/g72x.c src/G72x/*.(c|h) src/common.h src/sndfile.c src/wav.c src/au.c + Add support for G721 encoded WAV files. + + * doc/index.html + Update support matrix. + + * tests/lossy_comp_test.c + For file formats that support it, add string data after the audio data and + make sure it isn't treated as audio data on read. + + * src/gsm610.c + Add code to ensure that the container close function (ie for WAV files) gets + called after the codec's close function. This allows GSM610 encoded WAV files + to have string data following the audio data. + Add an AIFF specific check on psf->datalength. + + * src/wav.c + Simplify wav_close function. + + * src/aiff.c + Make sure the tailer data gets written at an even file offset. Pad if + necessary. + + * src/common.h + Replace the close function pointer in SF_PRIVATE with separate functions + codec_close and container_close. The former is always called first. + + * src/*.c + Fix knock on effects of above. + +2005-10-26 Erik de Castro Lopo + + * examples/sndfile-info.c + Complete dumping SF_INSTRUMENT data. + + * src/dwvw.c src/ima_adpcm.c src/gsm610.c src/ms_adpcm.c + Add extra checks in *_init function. + + * tests/lossy_comp_test.c + Add a string comment to the end of the files to make sure that the decoder + doesn't decode beyond the end of the audio data section. + +2005-10-25 Erik de Castro Lopo + + * examples/sndfile-info.c + Minor code cleanup. + Start work on dumping SF_INSTRUMENT data. + +2005-10-23 Erik de Castro Lopo + + * src/sndfile.h.in src/common.h src/common.c + Update definition of SF_INSTRUMENT struct and create a function to allocate + and initialize the struct (input from David Viens). + Clean up definition of SF_INSTRUMENT struct. + + * src/wav.c src/wav_w64.c + Add support for Ambisoncs B WAVEX files (David Viens). + + * src/aiff.c src/wav.c src/wav_w64.c + Start work on reading/writing the SF_INSTRUMENT data. + + * src/sndfile.c + Add code to get and set SF_INSTRUMENT data. + + * tests/command_test.* tests/Makefile.am + Add test for set and getof SF_INSTRUMENT data. + The file command_test.c is no longer autogen generated. + +2005-10-15 Erik de Castro Lopo + + * src/gsm610.c + Minor cleanup. + +2005-10-14 Erik de Castro Lopo + + * tests/lossy_comp_test.c + Minor cleanup. + +2005-10-13 Erik de Castro Lopo + + * src/*.c + Ensure sfconfig.h is included before any other header file. + + * src/file_io.c + Add comments documenting the three sections of the file. + + * src/gsm610.c + Make sure SF_FORMAT_WAVEX are handled correctly. + +2005-10-07 Erik de Castro Lopo + + * configure.ac + Add options to allow disabling of FLAC and ALSA. Suggested by Ben Greear. + +2005-09-30 Erik de Castro Lopo + + * tests/locale_test.c + Modify the way the unicode strings were encoded so that older compilers + do not complain. Thanks Axel Röbel. + + * configure.ac + Bump the version to 1.0.12 for release. + + * NEWS README Win32/config.h doc/(FAQ|index.html|command|api).html + Update version numbers. + +2005-09-26 Erik de Castro Lopo + + * src/flac.c + Fix valgrind error and minor cleanup. + +2005-09-25 Erik de Castro Lopo + + * src/(au|paf|aiff|w64|wav|svx).c + Make sure structs are initialised. + +2005-09-24 Erik de Castro Lopo + + * configure.ac + Make -Wdeclaration-after-statement work with --enable-gcc-werror configure + option. + Add -std=gnu99 (C99 plus posix style stuff like gmtime_r) to CFLAGS if the + compiler supports it. + +2005-09-23 Erik de Castro Lopo + + * configure.ac acinclude.m4 + Add -Wdeclaration-after-statement to CFLAGS if the compilers supports it. + +2005-09-22 Erik de Castro Lopo + + * tests/util.(tpl|def) + Make the test_write_*_or_die() functions const safe. + +2005-09-21 Erik de Castro Lopo + + * src/nist.c + Make sure the data offset is read from the file header. Thanks to + David A. van Leeuwen for a patch. + +2005-09-20 Erik de Castro Lopo + + * configure.ac src/sfconfig.h + Check for and the function setlocale(). + Set config variables to zero if not found. + + * tests/locale_test.c tests/Makefile.am + Add new test program and hook into build/test system. + +2005-09-18 Erik de Castro Lopo + + * src/common.h src/file_io.c + On windows, use windows specific types for file handles. + Add functions psf_init_files() and psf_use_rsrc(). + + * src/sd2.c + Make resource fork handling independant of file desciptor/handles. + + * src/sndfile.c src/test_file_io.c + Fix knock on effects. + +2005-09-06 Erik de Castro Lopo + + * src/float_cast.h + The lrint and lrintf implementations in Cygwin are both buggy and slow. + Add replacements which were pulled from the Public Domain MinGW math.h + header file. + +2005-09-05 Erik de Castro Lopo + + * tests/(lossy_comp_test|virtual_io_test).c + More Valgrind fixups. + + * configure.ac + Simplify and correct configuring for Cygwin. + + * Win32/config.h Win32/sndfile.h Win32/Makefile.msvc + Update build for MSVC. + +2005-09-04 Erik de Castro Lopo + + * tests/lossy_comp_test.c + Make sure to close SNDFILE when exiting test when file format is not seekable. + + * tests/(aiff_rw_test|virtual_io_test).c + Do a few valgrind fix ups. + +2005-09-03 Erik de Castro Lopo + + * src/float32.c src/double64.c + Replace floating point equality comparisons with greater/less comparisons. + Found by John Pavel using the Intel compiler. + + * src/sfconfig.h + New file to clean up issues surrounding autoconf generated preprocessor + symbols. + + * src/*.(c|h) tests/*.(c|tpl) examples/*.c + Fixed a bunch of other stuff found by John Pavel using the Intel compiler. + + * src/file_io.c + Remove Mac OS9 Metrowerks compiler specific hacks. + +2005-08-31 Erik de Castro Lopo + + * src/w64.c + Cast integer literal to sf_count_t in call to psf_binheader_writef() to + prevent Valgrind error. + +2005-08-30 Erik de Castro Lopo + + * doc/command.html + Improve documentation of SF_GET_FORMAT_SUBTYPE. + +2005-08-26 Erik de Castro Lopo + + * examples/sndfile-convert.c + Allow files to be converted to SD2 format. + + * src/sd2.c + Fix a bug in reading and writing of SD2 files on little endian CPUs. + Thanks to Matthew Willis for finding this. + +2005-08-25 Erik de Castro Lopo + + * doc/api.html + Update Note2 to point to SFC_SET_SCALE_FLOAT_INT_READ. + +2005-08-16 Erik de Castro Lopo + + * configure.ac + Use $host_os instead of $target_os (thanks to Mo De Jong). + +2005-08-15 Erik de Castro Lopo + + * src/Makefile.am + Apply a patch from Mo DeJong to allow building outside of the source dir. + + * src/file_io.c + Fix psf_fsync() for win32. + + * src/wav.c src/wav_w64.(c|h) + Move some code from wav.c to wav_w64.c to improve the log output of files of + type WAVE_FORMAT_EXTENSIBLE. + +2005-08-10 Erik de Castro Lopo + + * src/create_symbols_file.py + Make sure sf_write_fsync is an exported symbol. + + * examples/sndfile-convert.c + Add support for writing VOX adpcm files. + +2005-07-31 Erik de Castro Lopo + + * doc/api.html + Document the new function sf_write_sync(). + + * doc/FAQ.html + Do you plan to support XYZ codec. + +2005-07-28 Erik de Castro Lopo + + * src/sndfile.h.in src/sndfile.c + Add function sf_write_sync() to the API. + + * src/common.h src/file_io.c + Low level implementation (win32 not done yet). + + * tests/write_read_test.tpl + Use the new function in the tests. + +2005-07-24 Erik de Castro Lopo + + * src/common.h src/double64.c src/float32.c src/sndfile.c + Change the way PEAK chunk info is stored. Peaks now stored as an sf_count_t + for position and a double as the value. + + * src/aiff.c src/caf.c src/wav.c + Fix knock on effects of above changes. + + * src/caf.c + Implement 'peak' chunk for file wuth data in SF_FORMAT_FLOAT or + SF_FORMAT_DOUBLE format. + +2005-07-23 Erik de Castro Lopo + + * src/nist.c + Fix a bug where a variable was being used without being initialized. + + * src/flac.c + Add extra debug in sf_flac_meta_callback. + Make a bunch of private functions static. + + * src/aiff.c src/wav.c + Fix allocation for PEAK_CHUNK (bug found using valgrind). + +2005-07-21 Erik de Castro Lopo + + * src/common.h + Move the peak_loc field of SF_PRIVATE to the PEAK_CHUNK struct. + Remove had_peak field of SF_PRIVATE, use pchunk != NULL instead. + Rename PEAK_CHUNK and PEAK_POS to PEAK_CHUNK_32 and PEAK_POS_32. + + * src/aiff.c src/caf.c src/wav.c src/float32.c src/double64.c + Fix knock on effects from above. + +2005-07-19 Erik de Castro Lopo + + * src/wav.c + Prevent files with unknown chunks from being opened read/write. + +2005-07-14 Erik de Castro Lopo + + * src/flac.c + Do not use psf->end_of_file because it never gets set to anything. + + * src/common.h + Remove unused SF_PRIVATE field end_of_file. + +2005-07-12 Erik de Castro Lopo + + * src/common.c + Change the 'S' format specifier of psf_binheader_writef() to write AIFF + style strings (no terminating character). + + * src/aiff.c + Move to new (correct) AIFF string style. Thanks to Axel Röbel for being + so persistent on this issue. + +2005-07-11 Erik de Castro Lopo + + * src/sndfile.c + Allow SFE_UNSUPPORTED_FORMAT as an error from sf_open(). + + * doc/api.html doc/command.html + Documentation updates (thanks to Kyroz for promoting these updates). + + * src/mat5.c + Modify the way the header is written. + +2005-07-10 Erik de Castro Lopo + + * src/caf.c + Add a 'free' chunk to the written file so that the audio data starts at + an offset of 0x1000. + + * src/sndfile.c + Allow SFE_UNSUPPORTED_FORMAT as an error from sf_open(). + +2005-07-09 Erik de Castro Lopo + + * src/caf.c src/sndfile.c + Add support for signed 8 bit integers. + + * tests/write_read_test.tpl + Add test for signed 8 bit integers in CAF files. + + * doc/index.html + Update matrix for signed 8 bit integers in CAF files. + +2005-07-08 Erik de Castro Lopo + + * src/sndfile.c + Update sf_check_format() to support CAF. + + * examples/sndfile-convert.c + Add support for ".caf" file extension. + + * doc/index.html + Add Apple CAF to the support matrix. + + * src/caf.c + Add file write support. + + * src/common.c + Fix printing of Frames. + + * tests/Makefile.am tests/write_read_test.tpl tests/lossy_comp_test.c + tests/header_test.tpl misc_test.c + Add tests for CAF files. + +2005-07-07 Erik de Castro Lopo + + * doc/FAQ.html + Fix Q/A about reading/writing memory buffers. + + * src/caf.c + Bunch of work to support reading of CAF files. + +2005-07-04 Erik de Castro Lopo + + * src/(aiff|ima_adpcm|mat4|mat5|ms_adpcm).c examples/sndfile-play.c + Fix sign conversion errors reported by gcc-4.0. + + * src/caf.c + New file for Apple's Core Audio File format. + + * src/sndfile.c src/common.h src/sndfile.h.in src/Makefile.am + Hook new file into build system. + +2005-06-21 Erik de Castro Lopo + + * src_wav_w64.c + Fix handling of stupidly large 'fmt ' chunks. Thanks to Vadim Berezniker + for supplying an example file. + + * src/common.h src/sndfile.c + Remove redundant error code SFE_WAV_FMT_TOO_BIG. + +2005-06-20 Erik de Castro Lopo + + * src/sndfile.h.in src/common.h src/sndfile.c + Add public error value SF_ERR_MALFORMED_FILE. + + * src/sndfile.c + When parsing a file header fails and we don't have a system error, then set + the error number to SF_ERR_MALFORMED_FILE (suggested by Kyroz). + + * configure.ac + Allow sqlite support to be disabled in configure script. + + * regtest/database.c regtest/sndfile-regtest.c + Fix compiling when sqlite is missing. + +2005-06-11 Erik de Castro Lopo + + * src/file_io.c + Fix psf_is_pipe() and return value of psf_fread() when using virtual i/o. + + * src/sndfile.c + Fix VALIDATE_AND_ASSIGN_PSF macro for virtual i/o. + + * tests/virtual_io_test.c + Fill in skeleton test program. + + * tests/Makefile.am + Move virtual i/o tests to end of tests with stdio/pipe tests. + + * src/(sndfile.h.in|file_io.c|common.h|sndfile.c) tests/virtual_io_test.c + Rename some of the virtual i/o functions and data types. + +2005-06-10 Erik de Castro Lopo + + * src/sndfile.c + Fix the return values of sf_commands : SFC_SET_NORM_DOUBLE, + SFC_SET_NORM_FLOAT, SFC_GET_LIB_VERSION and SFC_GET_LOG_INFO. Thanks to + Kyroz for pointing out these errors. + + * doc/command.html + Correct documented return values for SFC_SET_NORM_DOUBLE and + SFC_SET_NORM_FLOAT. Thanks to Kyroz again. + +2005-05-17 Erik de Castro Lopo + + * regtest/* + Add new files for sndfile-regtest program. + + * configure.ac Makefile.am + Hook regetest into build. + + * src/wav.c src/common.c + Fix a regression where long ICMT chunks were causing the WAV parser + to exit. + +2005-05-15 Erik de Castro Lopo + + * libsndfile.spec.in + Add html docs to the files section as suggested by Karsten Jeppesen. + + * src/aiff.c + Fix parsing of odd length ANNO chunks. + +2005-05-13 Erik de Castro Lopo + + * src/common.h + Change the include guard to prevent clashes with other code. + +2005-05-12 Erik de Castro Lopo + + * examples/sndfile-play.c + Improve error handling in code for playback under Linux/ALSA. + +2005-05-10 Erik de Castro Lopo + + * src/ircam.c + Fix writing of IRCAM files on big endian systems (thanks to Axel Röbel). + + * src/wav.c + Add workaround for files created by the Peak audio editor on Mac which can + produce files with very short LIST chunks (thanks to Jonathan Segel who + supplied the file). + +2005-04-30 Erik de Castro Lopo + + * src/aiff.c + Apply a patch From David Viens to make the parsing of basc chunks more + robust. + + * src/wav.c + Another patch from David Viens to write correct wavex channel masks for + the most common channel configurations. + +2005-04-08 Erik de Castro Lopo + + * src/command.c + Only allow FLAC in the format arrays if FLAC is enabled. Thanks to + Leigh Smith. + +2005-03-09 Erik de Castro Lopo + + * src/common.h + Add a directory field for storing the file directory to the SF_PRIVATE + struct. + + * src/sndfile.c + Grab the directory name when copying the file path. + + * src/file_io.c + Cleanup psf_open_rsrc() and also check for resource fork in + .AppleDouble/filename. + +2005-03-01 Erik de Castro Lopo + + * src/svx.c + Fix a bug in the printing of the channel count. Bug reported by Michael + Schwendt. Thanks. + +2005-01-26 Erik de Castro Lopo + + * src/paf.c + Fix a seek bug for 24 bit PAF files. + + * tests/write_read_test.tpl + Update write_read_test to trigger the previously hidden PAF seek bug. + +2005-01-25 Erik de Castro Lopo + + * src/aiff.c src/w64.c src/wav.c + Do not return a header parse error when the log buffer overflows. + Continuing parsing works even on files where the log buffer does overflow. + This avoids a bug on some weirdo WAV (and other) files. + + * src/common.h src/sndfile.c + Remove SFE_LOG_OVERRIN error and its associated error message. + + * src/file_io.c + Fix a rsrc fork problem on MacOSX. + +2004-12-31 Erik de Castro Lopo + + * src/sndfile-play.c + In the ALSA output code, added call to snd_pcm_drain() just before + snd_pcm_close() as suggested by Thomas Kaeding. + In the OSS output code, added two ioctls (SNDCTL_DSP_POST and + SNDCTL_DSP_SYNC) just before the close of the audio device. + + * tests/virtual_io_test.c tests/Makefile.am + Add a new test program (currently empty) and add it to the build. + +2004-12-29 Erik de Castro Lopo + + * src/sndfile.h.in src/sndfile.h src/common.h src/file_io.c + src/create_symbols_file.py + Apply patch from Steve Baker which is the beginnings of a virtual + I/O interface. + +2004-12-23 Erik de Castro Lopo + + * src/*.c src/sndfile.h.in + Const-ify the write path throughout the library. + +2004-12-14 Erik de Castro Lopo + + * doc/development.html + Minor improvements. + +2004-11-29 Erik de Castro Lopo + + * doc/bugs.html + Minor improvements. + +2004-11-18 Erik de Castro Lopo + + * src/aiff.c + Add workaround for Logic Platinum AIFF files with broken COMT chunks. + +2004-11-16 Erik de Castro Lopo + + * doc/FAQ.html + Remove some ambiguities in the SD2 FAQ answer. + +2004-11-15 Erik de Castro Lopo + + * Win32/sndfile.h Win32/config.h MacOS9/sndfile.h MacOS9/config.h + Updates from autoconfig versions. + +2004-11-13 Erik de Castro Lopo + + * src/aiff.c + Fix parsing of COMT chunks. Store SF_STR_COMMENT data in ANNO chunks + instead of COMT chunk. + +2004-11-07 Erik de Castro Lopo + + * src/file_io.c src/common.h + Change the ptr argument to psf_write() from "void*" to a "const void*". + Thanks to Tobias Gehrig for suggesting this. + +2004-10-31 Erik de Castro Lopo + + * src/file_io.c src/common.h + Add functions psf_close_rsrc() and read length of resourse fork into + rsrclength field of SF_PRIVATE. + + * src/sd2.c + Make sure resource fork gets closed. + + * tests/util.tpl + Add functions to check for file descriptor leakage. + + * src/write_read_test.tpl + Use the file descriptor leak checks. + + * src/sndfile.h.in + Add SFC_GET_LOOP_INFO and SF_LOOP_INFO struct. + + * src/common.h + Add SF_LOOP_INFO pointer to SF_PRIVATE. + + * src/wav.c src/aiff.c + Improve and add parsing of 'ACID' and 'basc' chunks, filling in + SF_LOOP_INFO data in SF_PRIVATE. + +2004-10-30 Erik de Castro Lopo + + * src/sd2.c + Further cleanup: remove printfs, change snprintf to LSF_SNPRINTF. + + * Win32/config.h Win32/sndfile.h + Updates. + + * tests/util.tpl + Add win32 macro for snprintf. + +2004-10-29 Erik de Castro Lopo + + * src/sfendian.h + Add macros : H2BE_SHORT, H2BE_INT, H2LE_SHORT and H2LE_INT. + + * src/sd2.c + Use macros to make sure writing SD2 files on little endian machines works + correctly. + + * tests/util.tpl + Add a delete_file() function which also deletes the resource fork of SD2 + files. + + * tests/write_read_test.tpl + Use delete_file() so that "make distcheck" works. + +2004-10-28 Erik de Castro Lopo + + * src/sndfile.c src/file_io.c + Move resource filename construction and testing to psf_open_rsrc(). + + * src/common.h src/sndfile.c + Add error SFE_SD2_FD_DISALLOWED. + + * tests/util.tpl tests/*.(c|tpl) + Add and allow_fd parameter to test_open_file_or_die() so that use of + sf_open_fd() can be avoided when opening SD2 files. + +2004-10-27 Erik de Castro Lopo + + * src/wav.c + Update ACID chunk parsing. + + * src/sd2.c + More fixes for files with large resource forks. + +2004-10-23 Erik de Castro Lopo + + * src/common.h src/sndfile.c + Add error numbers and messages for sd2 files. + + * src/sd2.c + Reading of sd2 (resource fork version) now seems to be working. + +2004-10-17 Erik de Castro Lopo + + * src/file_io.h + Update file_io.c to include win32 psf_rsrc_open(). + + * tests/floating_point_test.tpl + Remove use of __func__ in test programs (MSVC++ doesn't grok this). + + * Win32/(config|sndfile).h MacOS9/(config|sndfile).h + Updates. + +2004-10-13 Erik de Castro Lopo + + * src/sfendian.h + Fix endswap_int64_t_(array|copy). + + * src/test_endswap.(tpl|def) + Add tests for above and inprove all tests. + +2004-10-12 Erik de Castro Lopo + + * src/sfendian.h + Improve type safety, add endswap_double_array(). + + * src/double64.c + Use endswap_double_array() instead of endswap_long_array(). + + * src/test_endswap.(tpl|def) src/Makefile.am + Add preliminary endswap tests and hook into build system. + +2004-10-06 Erik de Castro Lopo + + * src/configure.ac src/makefile.am + Finally fix the bulding of DLLs on Win32/MinGW. + + * tests/makefile.am + Fix running of tests on Win32/MinGW. + +2004-10-01 Erik de Castro Lopo + + * src/sndfile.h.in src/sndfile.c tests/floating_point_test.tpl + Rename SFC_SET_FLOAT_INT_MULTIPLIER to SFC_SET_SCALE_FLOAT_INT_READ. + + * doc/command.html + Document SFC_SET_SCALE_FLOAT_INT_READ. + +2004-09-30 Erik de Castro Lopo + + * tests/floating_point_test.(tpl|def) + Derived from floating_point_test.c. + Add (float|double)_(short|int)_test functions. + + * tests/util.(tpl|def) + Make separate float and double versions of gen_windowed_sine(). + + * tests/write_read_test.tpl + Fix after changes to gen_windowed_sine(). + + * src/(float32|double64).c + Implement SFC_SET_FLOAT_INT_MULTIPPLIER. + +2004-09-29 Erik de Castro Lopo + + * acinclude.m4 + Fix warnings from automake 1.8 and later. + + * examples/sndfile-info.c + Add a "fflush (stdout)" after printing Win32 message. + +2004-09-28 Erik de Castro Lopo + + * Win32/Makefile.mingw.in + Add a "make install" target. + +2004-09-24 Erik de Castro Lopo + + * src/sndfile.h.in src/common.h src/sndfile.c src/command.c + Start work on adding command SFC_SET_FLOAT_INT_MULTIPLIER. + +2004-09-22 Erik de Castro Lopo + + * examples/sndfile-convert.c + Fix a bug converting stereo integer PCM files to float. + +2004-09-22 Erik de Castro Lopo + + * examples/sndfile-play.c + Appy patch from Conrad Parker to make Mac OSX error messages more + consistent and informative. + + * doc/api.html + Fix a HTML HREF which was wrong. + + * doc/win32.html + Add information about when nmake fails. + +2004-09-05 Erik de Castro Lopo + + * examples/sndfile-play.c + Another patch from Denis Cote to prevent race conditions. + +2004-09-02 Erik de Castro Lopo + + * src/common.h src/ms_adpcm.c src/ima_adpcm.c + Fix alternative to ISO standard flexible struct array feature for broken + compilers. + +2004-08-31 Erik de Castro Lopo + + * src/common.h src/string.c src/sndfile.c + Make sf_set_string() return an error if trying to set a string when in + read mode. + +2004-08-29 Erik de Castro Lopo + + * src/common.h + Change the unnamed union into a named union so gcc-2.95 will compile it. + + * src/*.c + Fixes to allow for the above change. + +2004-08-20 Erik de Castro Lopo + + * examples/sndfile-play.c + Fixes for Win32. Thanks to Denis Cote. + + * Win32/Win32/Makefile.(msvc|mingw.in) + Fix build system after removal of sfendian.h. + Build sndfile-convert. + + * src/Makefile.am + Remove sfendian.c from dependancies. + +2004-08-10 Erik de Castro Lopo + + * src/sndfile.h.in + Fix typo in comments (thanks Tommi Sakari Uimonen). + +2004-07-31 Erik de Castro Lopo + + * tests/(a|u)law_test.c + Minor cleanup. + +2004-07-29 Erik de Castro Lopo + + * src/(pcm|float|double64|ulaw|alaw|xi).c + Optimise read/write loops by removing a redundant variable. + +2004-07-24 Erik de Castro Lopo + + * src/file_io.c + Remove call to fsync() in psf_close(). + +2004-07-19 Erik de Castro Lopo + + * src/pcm.c + Inline x2y_array() functions where possible. + + * configure.ac + Detect presence of type int64_t. + + * src/sfendian.c src/sfendian.h + Move functions in the first file to the sfendian.h as static inline + functions. + Improve endswap_long_*() where possible. + +2004-07-17 Erik de Castro Lopo + + * src/pcm.c + When converting from unsigned char to float or double, subtract 128 before + converting to float/double rather than after to save a floating point + operation as suggested by Stefan Briesenick. + + * src/(pcm|sfendian|alaw|ulaw|double64|float32).c + Optimize inner loops by changing the loop counting slightly as suggested + by Stefan Briesenick. + + * configure.ac + Detect presence of . + + * src/sfendian.h + Use if present as suggested by Stefan Briesenick. + + * src/pcm.c + Update bytewapping. + +2004-07-02 Erik de Castro Lopo + + * src/common.h src/*.c + Change the psf->buffer field of SF_PRIVATE into a more type safe union with + double, float, int etc elements. + +2004-06-28 Erik de Castro Lopo + + * examples/sndfile-play.c + Merge slightly modifed patch from Stanko Juzbasic which allows playback of + mono files on MacOSX. + +2004-06-25 Erik de Castro Lopo + + * examples/sndfile-convert.c + Move copy_metadata() after the second sf_open(). + +2004-06-21 Erik de Castro Lopo + + * examples/sndfile-convert.c + Fix a bug which caused the program to go into an infinite loop if the source + file has no meta-data. Thanks to Ron Parker for reporting this. + + * src/sndfile.h.in + Add SF_STR_FIRST and SF_STR_LAST to allow enumeration of string types. + + * Win32/sndfile.h MacOS9/sndfile.h + Update these as per the above file. + +2004-06-17 Erik de Castro Lopo + + * configure.ac src/common.h src/ogg.c src/sndfile.c src/sndfile.h.in + src/Makefile.am + Apply large patch from Conrad Parker implementing Ogg Vorbis, Ogg Speex and + Annodex support via liboggz and libfishsound. Thanks Conrad. + +2004-06-15 Erik de Castro Lopo + + * src/avr.c src/ircam.c src/nist.c src/paf.c src/xi.c + Add cast to size_t for some parameters passed to psf_binheader_writef. This + is Debian bug number 253490. Thanks to Anand Kumria and Andreas Jochens. + + * src/w64.c + Found and fixed a bug resulting from use of size_t when writing W64 'fmt ' + chunk. + +2004-06-14 Erik de Castro Lopo + + * configure.ac + Bump version to 1.0.10 ready for release. + + * Makefile.am + Remove redundant files (check_libsndfile.py libsndfile_version_convert.py) + from distribution tarball. + + * tests/header_test.tpl + Fix uninitialised variable. + + * src/GSM610/short_term.c + Fix compiler warning on MSVC++. + +2004-05-23 Erik de Castro Lopo + + * src/wav.c + Improve record keeping of chunks seen and return an error if a file with + unusual chunks is opened in mode SFM_RDWR. + + * src/mmreg.h + This file not needed so remove it. + +2004-05-22 Erik de Castro Lopo + + * tests/header_test.tpl + Add extra_header_test(). + + * src/common.h src/sndfile.c + Add SFE_RDWR_BAD_HEADER error number and string. + +2004-05-21 Erik de Castro Lopo + + * tests/utils.tpl tests/*.c tests/*.tpl + Add a line number argument to check_log_buffer_or_die() and update all + files that use that function. + + * tests/header_test.tpl + Modify/update tests for files opened SFM_RDWR and SFC_UPDATE_HEADER_AUTO. + + * src/aiff.c src/wav.c + Fix another bug in AIFF and WAV files opened in SFM_RDWR and using + SFC_UPDATE_HEADER_AUTO. + + * src/test_file_io.c + Add a test for psf_ftruncate() function. + +2004-05-19 Erik de Castro Lopo + + * src/sndfile.c + Fix another weird corner case bug found by Martin Rumori. Thanks. + + * tests/header_test.(tpl|def) + Two new files to test for the absence of the above bug and include tests + moved from tests/misc_test.c. + + * tests/Makefile.am + Hook new tests into build/test system. + + * tests/misc_test.c + Remove update_header_test() which has been moved to the new files above. + +2004-05-16 Erik de Castro Lopo + + * src/aiff.c + Fixed a bug reported by Martin Rumori on the LAD list. If a file created + with a format of SF_FORMAT_FLOAT and then closed before any data is written + to it, the header can get screwed up (PEAK chunk gets overwritten). + + * tests/write_read_test.tpl + Add a test (empty_file_test) for the above bug. + +2004-05-13 Erik de Castro Lopo + + * Win32/Makefile.mingw.in + Added a Makefile for MinGW (needs to be processed by configure). + + * src/mmsystem.h src/mmreg.h + Add files from the Wine project (under the LGPL) to allow build of + sndfile-play.exe under MinGW. + +2004-05-12 Erik de Castro Lopo + + * src/GSM610/gsm610_priv.h + Replace ugly macros with inline functions. + + * src/GSM610/*.c + Remove temporary variables used by macros and other minor fixes required by + above change. + +2004-05-10 Erik de Castro Lopo + + * tests/pipe_test.tpl tests/stdio_test.c Win32/Makefile.msvc + Make sure these programs compile (even though they do nothing) on Win32 + and add them to the "make check" target. + + * src/sfendian.h + Fix warning on Sparc CPU and code cleanup. + +2004-05-09 Erik de Castro Lopo + + * src/file_io.c + Fix warning messages when compiling under MinGW. + +2004-05-01 Erik de Castro Lopo + + * configure.ac + Set HAVE_FLEXIBLE_ARRAY in src/config.h depending on whether the compiler + accepts the flexible array struct member as per 1999 ISO C standard. + + * src/common.h src/ima_adpcm.c src/paf.c src/ms_adpcm.c + Added ugly #if HAVE_FLEXIBLE_ARRAY and provided a non-standards compliant + hack for non 1999 ISO C compliant compilers. + +2004-04-26 Erik de Castro Lopo + + * src/strings.c + If adding an SF_STR_SOFTWARE string, only append libsndfile-X.Y.Z if the + string does not already have libsndfile in the string. Thanks to Conrad + Parker. + + * tests/string_test.c + Add test to verify the above. + + * examples/sndfile-convert.c + Add ability to transcode meta data as well (Conrad Parker). + +2004-04-25 Erik de Castro Lopo + + * doc/command.html + Fix minor error. Thanks to Simon Burton. + + * doc/win32.html + Started adding instructions for compiling libsndfile under MinGW. + + * configure.ac + Add --enable-bow-docs to enable black text on a white background HTML docs. + + * doc/libsndfile.css.in + This is now a template file for configure which sets the foreground and + background colours. + +2004-04-20 Erik de Castro Lopo + + * configure.ac + Do some MinGW fixes. + + * configure.ac doc/Makefile.am + Install HTML docs when doing make install. + +2004-04-19 Erik de Castro Lopo + + * examples/sndfile-info.c + Print out the dB level with the signal max. + +2004-04-15 Erik de Castro Lopo + + * src/file_io.c + Define S_ISSOCK in src/file_io.c if required. + +2004-04-03 Erik de Castro Lopo + + * configure.ac + Improve printout configuration summary (as suggested by Axel Röbel). + + * doc/index.html + Add link to pre-release location. + + * src/sndfile.h.in + Remove comma after last element of enum. + + * src/float32.c src/double64.c + Fix read/write of float/double encoded raw files to/from pipes. + + * tests/pipe_test.c tests/pipe_test.tpl tests/pipe_test.def + Turn pipe_test.c into an autogenerated file and add tests for reading/ + writing floats and doubles. + + * tests/Makefile.am + Hook tests/pipe_test.* into build system. + +2004-04-02 Erik de Castro Lopo + + * configure.ac acinclude.m4 + Rename AC_C_STRUCT_HACK macro to AC_C99_FLEXIBLE_ARRAY. + +2004-03-31 Erik de Castro Lopo + + * tests/misc_test.c + Perform update_header_test in RDWR mode as well. + + * src/aiff.c + Fix problems when updating header in RDWR mode. + +2004-03-30 Erik de Castro Lopo + + * src/wav.c src/w64.c src/wav_w64.c + Integrate code supplied by David Viens for supporting microsoft's + WAVEFORMATEXTENSIBLE stuff. Thanks David for supplying this. + + * configure.ac doc/*.html + Bump version to 1.0.9. + +2004-03-28 Erik de Castro Lopo + + * src/command.c src/sndfile.c src/sndfile.h.in src/wav.c + Started work on supporting microsoft's WAVEFORMATEXTENSIBLE gunk. + +2004-03-26 Erik de Castro Lopo + + * src/avr.c + New file to handle Audio Visual Resaerch files. + + * src/sndfile.h.in src/common.h src/sndfile.c src/command.c + Hook AVR into everything else. + + * tests/Makefile.am tests/write_read_test.tpl tests/misc_test.c + Add testing for AVR files. + +2004-03-22 Erik de Castro Lopo + + * src/file_io.c + Fix psf_set_file() for win32. Thanks to Vincent Trussart (Plogue Art et + Technologie) for coming up with the solution. + +2004-03-21 Erik de Castro Lopo + + * tests/write_read_test.tpl + Fixed a bug that was causing valgrind to report a memory leak. The bug was + in the test code itself, not the library. + +2004-03-20 Erik de Castro Lopo + + * examples/generate.cs + An example showing how to use libsndfile from C#. Thanks to James Robson + for providing this. + +2004-03-19 Erik de Castro Lopo + + * src/common.c + Fix problems with WAV files containing large chunks after the 'data' + chunk. Thanks to Koen Tanghe for providing a sample file. + +2004-03-17 Erik de Castro Lopo + + * configure.ac + Detect presense of ALSA (Advanced Linux Sound Architecture). + + * examples/sndfile-play.c + Add ALSA output support. + + * examples/Makefile.am + Add ALSA_LIBS to link line of sndfile-play.c. + +2004-03-15 Erik de Castro Lopo + + * acinclude.m4 + Add new macro (AC_C_STRUCT_HACK) to detect whether the C compiler allows + the use of the what is known as the struct hack introduced by the 1999 ISO + C Standard. + + * configure.ac + The last release would not compile with gcc-2.95 due to the use of features + (ie struct hack) introduced by the 1999 ISO C Standard. + Add check to make sure compiler handles this and bomb out if it doesn't. + +2004-03-14 Erik de Castro Lopo + + * tests/write_read_test.tpl + Fix compiler warning on Win32. + + * src/file_io.c + Fix use of an un-initialised variable in Win32 stuff. + + * Win32/config.h examples/sndfile-play.c + Win32 fixes. + +2004-03-10 Erik de Castro Lopo + + * configure.ac + Fix bug which occurres when configuring for MinGW. + If compiler is gcc and cross compiling use -nostdinc. + +2004-03-09 Erik de Castro Lopo + + * src/common.h src/aiff.c src/wav.c src/float32.c src/double64.c + src/sndfile.c + Fix a bug with PEAK chunk handling for files with more than 16 channels. + Thanks to Remy Bruno for finding this. + +2004-03-08 Erik de Castro Lopo + + * src/common.c + Fix a bug which was preventing WAV files being openned correctly if the + file had a very large header. Thanks to Eldad Zack for finding this. + +2004-03-04 Erik de Castro Lopo + + * configure.ac src/file_io.c + Fix cross-compiling from Linux to Win32 using the MinGW tools. + +2004-03-01 Erik de Castro Lopo + + * src/create_symbols_file.sh + Christian Weisgerber pointed out that the shell script did not run on a + real Bourne shell although it did run under Bash in Bourne shell mode. + + * src/create_symbols_file.py + Rewrite of above in Python. Also add support for writing Win32 .def files. + The Python script generates Symbols.linux, Symbols.darwin and + libsndfile.def (Win32 version). These files get shipped with the tarball + so there should not be necessary to run the Python script when building + the code from the tarball. + + * configure.ac src/Makefile.am Win32/Makefile.am + Hook new Python script into the build system. + +2004-02-25 Erik de Castro Lopo + + * src/configure.ac + Add --enable-gcc-werror option and move GCC specific stuff down. + +2004-02-24 Erik de Castro Lopo + + * acinclude.m4 configure.ac + Fix clip mode detection (tested in one of HP's testdrive Itanium II boxes). + + * src/file_io.c + Added check for sizeof (off_t) != sizeof (sf_count_t) to prevent recurrence + of missing large file support on Linux and Solaris. + +2004-02-19 Erik de Castro Lopo + + * examples/sndfile-play.c + Fix a MacOSX specific bug which was caused by a space being inserted in + the middle of a file name. + + * configure.ac src/Makefile.am examples/Makefile.am + Fix a couple of MacOSX build issues. + +2004-02-17 Erik de Castro Lopo + + * doc/command.html + Document SFC_SET_CLIPPING and SFC_GET_CLIPPING. + +2004-02-14 Erik de Castro Lopo + + * doc/*.html + Applied patch from Frank Neumann (author of lakai) which fixes many minor + typos in documentation. Thanks Frank. + +2004-02-13 Erik de Castro Lopo + + * ChangeLog + Changed my email address throughout source and docs. + +2004-02-08 Erik de Castro Lopo + + * src/file_io.c + Make sure config.h is included before stdio.h to make sure large file + support is enabled on Linux (and Solaris). + + * tests/misc_test.c + Disable update_header test on Win32. This should work but doesn't and + I'm not sure why. + + * Make.bat Win32/Makefile.msvc + Updates. + +2004-01-07 Erik de Castro Lopo + + * src/common.h + Changed logindex, headindex and headend files of SF_PRIVATE from unsigned + int to int to prevent weird arithmetic bugs. + + * src/common.c src/aiff.c src/wav.c src/w64.c + Fixed compiler warnings resulting from above change. + +2004-01-06 Erik de Castro Lopo + + * src/common.c + Fixed a bug in header reader for some files with data after the sample data. + +2003-12-29 Erik de Castro Lopo + + * tests/lossy_comp_test.c tests/Makefile.am + Add tests for AIFF/IMA files. + +2003-12-26 Erik de Castro Lopo + + * src/macbinary3.c src/macos.c + Two new files required for handling SD2 files. + + * src/common.h + Add prototypes for functions in above two files. + + * src/Makefile.am + Hook new files into build system. + +2003-12-21 Erik de Castro Lopo + + * configure.ac + Add checks for mmap() and getpagesize() which might be used at some time + for faster file reads. + Add detection of MacOSX. + +2003-12-13 Erik de Castro Lopo + + * doc/FAQ.html + Minor mods to pkg-config section. + +2003-12-12 Erik de Castro Lopo + + * src/create_symbols_file.sh + Andre Pang (also known as Ozone) pointed out that on MacOSX, all non + static symbols are exported causing troubles when trying to link + libsndfile with another library which has any of the same symbols. + He fixed this by supplying the MacOSX linker with a file containing + all the public symbols so that only they would be exported and then + supplied a patch for libsndfile. + This wasn't quite ideal, because I would have to maintain two (3 if + you include Win32) separate files containing the exported symbols. + A better solution was to create this script which can generate a + Symbols file for Linux, MacoSX and any other OS that supports + minimising the number of exported symbols. + + * configure.ac src/Makefile.am + Hook the new script into the build process. + +2003-12-10 Erik de Castro Lopo + + * doc/index.html + Added comments about Steve Dekorte's SoundConverter scam. + +2003-12-07 Erik de Castro Lopo + + * src/file_io.c + Axel Röbel pointed out that on Mac OSX a pipe is not considered a fifo + (S_ISFIFO (st.st_mode) is false) but a socket (S_ISSOCK (st.st_mode) is + true). The test has therefore been changed to is S_ISREG and anything + which which does not return true for S_ISREG is considered a pipe. + +2003-11-25 Erik de Castro Lopo + + * tests/misc_test.c + Fix update_header_test to pass SDS. + + * src/sds.c + More minor fixes. + + * tests/floating_point_test.c + Add test for SDS files. + + * src/command.c + Add SDS to major_formats array. + +2003-11-24 Erik de Castro Lopo + + * tests/write_read_test.tpl tests/misc_test.c + Add tests for SDS files. + + * src/sds.c + Fix a bug in header update code. + +2003-11-23 Erik de Castro Lopo + + * src/sds.c + Get file write working. + + * src/paf.c + Fix a potential bug in paf24_seek(). + +2003-11-04 Erik de Castro Lopo + + * doc/FAQ.html + Add Q/A about u-law encoded WAV files. + + * Win32/*.h + Updated so it compiles on Win32. + +2003-11-03 Erik de Castro Lopo + + * examples/sndfile-convert.c + Add -alaw and -ulaw command line arguments. + + * configure.ac + Add library versioning comments. + Add arguments to AC_INIT. + +2003-10-28 Erik de Castro Lopo + + * src/file_io.c + Ross Bencina has contributed code to replace all of the (mostly broken) + Win32 POSIX emulation calls with calls the native Win32 file I/O API. + This code still needs testing but is likely to be a huge improvemnt + of support for Win32. Thanks Ross. + +2003-10-27 Erik de Castro Lopo + + * src/dwvw.c + Removed filedes field from the DWVW_PRIVATE struct. + + * src/file_io.c + Change psf_fopen() so it returns psf->error instead of the file descriptor. + Add new functions psf_set_stdio() and psf_set_file(). + + * src/sndfile.c + Change these to work with changed psf_fopen() return value. + Remove all uses of psf->filedes from sndfile, making it easier to slot native + Win32 API file handling functions. + + * src/test_file_io.c + Minor changes to make it compile with new file_io.c stuff. + +2003-10-26 Erik de Castro Lopo + + * src/gsm610.h + Rename a variable from true to true_flag. As Ross Bencina points out, + true is defined in the C99 header . + + * src/file_io.c + If fstat() fails, return SF_TRUE instead of -1 (Ross Bencina). + +2003-10-09 Erik de Castro Lopo + + * src/common.h + Increase the size of SF_BUFFER_LEN and SF_HEADER_LEN. + + * src/sndfile.c + Fix sf_read/write_raw which were dividing by psf->bytwidth and + psf->blockwidth which can both be zero. + + * examples/sndfile-info.c + Increase size of BUFFER_LEN. + +2003-09-21 Erik de Castro Lopo + + * configure.ac + Add checks for and ssize_t. + Other Win32/MinGW checks. + + * src/aiff.c src/au_g72x.c src/file_io.c src/gsm610.c src/interleave.c + src/paf.c src/sds.c src/svx.c src/voc.c src/w64.c src/wav.c src/xi.c + Fix compiler warnings. + +2003-09-20 Erik de Castro Lopo + + * tests/scale_clip_test.tpl + Add definition of M_PI if needed. + +2003-09-19 Erik de Castro Lopo + + * configure.ac + Detect if S_IRGRP is declared in . + + * src/file_io.c tests/*.tpl tests/*.c + More fixes for Win32/MSVC++ and MinGW. MinGW does have but that + file doesn't declare S_IRGRP. + +2003-10-18 Erik de Castro Lopo + + * src/config.h.in + Add comment stating that the sf_count_t typedef is determined when + libsndfile is being compiled. + + * tests/utils.tpl + Modified so that utils.c gets one copy of the GPL and not two. + + +2003-09-17 Erik de Castro Lopo + + * Win32/unistd.h src/sf_unistd.h + Move first file to the second. This will help for Win32/MSVC++ and MinGW. + + * Win32/Makefile.am src/Makefile.am + Changed in line with above. + + * Win32/Makefile.msvc + Removed "/I Win32" which is no longer required. + + * src/file_io.c src/test_file_io.c tests/*.tpl tests/*.c + If HAVE_UNISTD_H include else include . This should + work for Win32, MinGW and other fakes Unix-like OSes. + + * src/*.c + Removed #include from files which didn't need it. + +2003-09-16 Erik de Castro Lopo + + * libsndfile.spec.in + Apply fix from Andrew Schultz. + +2003-09-07 Erik de Castro Lopo + + * src/vox_adpcm.c + Only set psf->sf.samplerate if the existing value is invalid. + +2003-09-06 Erik de Castro Lopo + + * examples/sndfile-play.c + Started adding support for ALSA output. + +2003-09-04 Erik de Castro Lopo + + * src/sndfile.h.in + Removed from sndfile.h. + + * src/*.c examples/*.c tests/*.c tests/*.tpl + Added where needed. + +2003-09-02 Erik de Castro Lopo + + * src/common.h + Added ARRAY_LEN, SF_MAX and SF_MIN macros. + +2003-08-19 Erik de Castro Lopo + + * doc/index.html + Remove statements about alternative licensing arrangements. + +2003-08-17 Erik de Castro Lopo + + * MacOS MacOS9 Makefile.am configure.ac + Change directory name from MacOS to MacOS9 + + * MacOS9/MacOS9-readme.txt + Change name to make it really obvious, add text to top of file to make it + still more obvious again. + +2003-08-16 Erik de Castro Lopo + + * src/test_log_printf.c + Add tests for %u conversions. + + * src/common.c + Fix psf_log_printf() %u conversions. + +2003-08-15 Erik de Castro Lopo + + * src/aiff.c + Fixed a bug where opening a file with a non-trival header in SFM_RDWR mode + would over-write part of the header. Thanks to Axel Röbel for pointing + this out. Axel also provided a patch to fix this but I came up with a + neater and more general solution. + Return error when openning an AIFF file with data after the SSND chunk + (Thanks Axel Röbel). + + * tests/aiff_rw_test.c + Improvements to test program which will later allow it to be generalised to + test WAV, SVX and others as required. + +2003-08-14 Erik de Castro Lopo + + * tests/pipe_test.c + Add useek_pipe_rw_test() submitted by Russell Francis. + + * src/sndfile.c + In sf_open_fd(), check if input file descriptor is a pipe. + + * src/sndfile.[ch] + Fix typo in variable name do_not_close_descriptor. + +2003-08-13 Erik de Castro Lopo + + * src/test_log_printf.c + Improve the tests for %d and %s conversions. + + * src/common.c + Fixed a few problems in psf_log_printf() found using new tests. + +2003-08-06 Erik de Castro Lopo + + * configure.ac + Add -Wwrite-strings warning to CFLAGS if the compiler is GCC. Thanks to + Peter Miller (Aegis author) for suggesting this and supplying a patch. + + * src/*.c examples/*.c tests/*.c + Fix all compiler warnings arising from the above. + +2003-08-02 Erik de Castro Lopo + + * tests/aiff_rw_test.c tests/Makefile.am + New test program to check for errors re-writing the headers of AIFC files + opened in mode SFM_RDWR. + +2003-07-21 Erik de Castro Lopo + + * examples/sndfile-play.c + Applied a patch from Tero Pelander to allow this program to run on systems + using devfs which used /dev/sound/dsp instead of /dev/dsp. + +2003-07-11 Erik de Castro Lopo + + * doc/new_file_type.HOWTO + Updated document. Still incomplete. + +2003-06-29 Erik de Castro Lopo + + * src/sndfile.c + Fix VALIDATE_SNDFILE_AND_ASSIGN_PSF which was returning an error rather + than saving it and returning zero. + +2003-06-25 Erik de Castro Lopo + + * src/file_io.c + Two fixes for Mac OS9. + Fix all casts from sf_count_t to ssize_t (not size_t). + +2003-06-22 Erik de Castro Lopo + + * src/wav.c + Fix for reading files with RIFF length of 8 and data length of 0. + +2003-06-14 Erik de Castro Lopo + + * src/*.c tests/*.c tests/*.tpl + Added comments to mark code for removal when make Lite version of + libsndfile. + +2003-06-09 Erik de Castro Lopo + + * examples/sndfile-convert.c + Add extra error checking for unrecognised arguments. + +2003-06-08 Erik de Castro Lopo + + * src/ima_adpcm.c + Started adding code to write IMA ADPCM encoded AIFF files. + + * src/test_log_printf.c src/Makefile.am + New file to test psf_log_printf() function and add hooks into build system. + + * src/common.c + Move psf_log_printf() function to top of the file and only compile the rest + of the file if if PSF_LOG_PRINTF_ONLY is not defined. + +2003-06-03 Erik de Castro Lopo + + * Win32/config.h Win32/sndfile.h + Updated with new config variables. + + * Win32/unistd.h src/file_io.c + Added implementation of S_ISFIFO macro which Win32 seems to lack and is + used in src/file_io.c. + + * tests/utils.tpl + Added #include to pull in Win32/unistd.h so it compiles for + Win32. + + * src/Makefile.msvc + Added src\test_file_io.exe build target and run this as the very first + test. + + * tests/win32_test.c + Add support for testing Cygwin32. + + * configure.ac + Detect POSIX fsync() and fdatasync() functions. + + * src/file_io.c + If compiling for Cygwin, call fsync() before calling fstat() to retrieve + file length. + + * tests/pcm_test.tpl + Add a test for lrintf() function. This was required to detect a really + broken lrint() and lrintf() on Cygwin. + + * tests/misc_test.c + Don't run permission test when compiling under Cygwin. + + * src/float_cast.h + Fix fallback macro for lrint() and lrintf() to cast to long instead of int + to match official function prototypes. + +2003-06-02 Erik de Castro Lopo + + * examples/sndfile-convert.c + Modifications to improve accuracy of conversions; use double data for + floating point and int for everything else. + + * src/ima_apdcm.c + Completed work on decoding IMA ADPCM encoded AIFF files. Still need to + get encoding working. + +2003-05-28 Erik de Castro Lopo + + * src/aiff.c src/ima_adpcm.c + Start working on getting IMA ADPCM encoded AIFF files working. + +2003-05-27 Erik de Castro Lopo + + * configure.ac + Fixed the touch command for when the autogen program is not found (Matt + Flax). + + * src/ulaw.c src/alaw.c + Made these pipe-able. + +2003-05-24 Erik de Castro Lopo + + * src/paf.c src/ircam.c + Fixed writing to pipe. + + * src/wav.c src/aiff.c src/nist.c src/mat*.c src/svx.c src/w64.c + Return SFE_NO_PIPE_WRITE if an attempt is made to write to a pipe. + +2003-05-23 Erik de Castro Lopo + + * examples/sndfile-info.c + Modified to detect unknown file lengths. + + * src/mat4.c + Fix reading from a pipe. + +2003-05-22 Erik de Castro Lopo + + * tests/pipe_test.c + Add more file types to tests. + + * src/mat4.c + Removed explicit setting of psf->sf.seekable to SF_TRUE. + + * tests/utils.tpl + Add macro for generating and check data in the stdio and pipe tests. + + * tests/stdout_test.c tests/stdin_test.c + Use the above macro to generate known data on output and check data on + input. + + * src/voc.c src/htk.c common.h sndfile.c + Disallow reading/writing VOC and HTK files from/to pipes be returning new + error values. + + * src/w64.c + Fixes to allow reading from a pipe. + +2003-05-21 Erik de Castro Lopo + + * configure.ac src/sndfile.h.in + When the configure script determines the sizeof (sf_count_t), also set the + value of SF_COUNT_MAX in sndfile.h. + + * configure.ac + Remove -pedantic flag from default GCC compiler flags. + + * tests/pipe_test.c + Add a pipe_read_test() before doing pipe_write_test(). + + * tests/scale_clip_test.c + Add test to make sure non-normalized values also clip in the right way. + +2003-05-18 Erik de Castro Lopo + + * configure.ac + Add test to detect processor clipping capabilities. + + * tests/stdin_test.c tests/stdout_test.c + Fix a pair of compiler warnings. + + * src/common.h + Add new pipeoffset field to SF_PRIVATE. This will contain the current file + offset when operating on a pipe. + + * src/common.c + Removed direct calls to psf_fread()/psf_fseek()/psf_fgets() etc from + psf_binheader_readf and redirect them to new buffered versions + header_read(), header_seek() and header_gets(). + Add "G" format specifier to emulate fgets() functionality with buffering. + This will allow reading some file types from pipes. + + * src/file_io.c + When the file descriptor is a pipe, manintain psf->pipeoffset. + + * src/pvf.c + Change use of psf_fgets() to psf_binheader_readf() as required but changes to header re + + * src/au.c + Fix reading from a pipe. + +2003-05-17 Erik de Castro Lopo + + * src/pcm.c + Add clipping versions of the f2XXX_array() functions to allow option of + clipping data that would otherwise overflow. + + * tests/scale_clip_test.tpl tests/scale_clip_test.def + New files test that clipping option does actually work. + +2003-05-14 Erik de Castro Lopo + + * doc/index.html + Fixed a typo ("OS(" instead of "OS9"). + +2003-05-13 Erik de Castro Lopo + + * tests/open_fail_test.c + Include to prevent warning message of missing declaration of + memset(). + +2003-05-12 Erik de Castro Lopo + + * src/common.h + Add new "add_clipping" field to SF_PRIVATE. + + * src/sndfile.h.in src/sndfile.c + Add command SFC_SET_CLIPPING which sets/resets add_clipping field. + +2003-05-11 Erik de Castro Lopo + + * doc/api.html + Add docs for sf_set_string() and sf_get_string(). + + * src/common.h src/sndfile.c + Add new SFE_STR_BAD_STRING error. + + * tests/stdin_test.c tests/stdout_test.c + Removed all non-error print statements. + + * tests/stdio_test.c tests/pipe_test.c tests/Makefile.am + Add print statements removed from two files above. + +2003-05-10 Erik de Castro Lopo + + * libsndfile.spec.in + Fixed a coulpe of minor errors discovered by someone calling themselves + Agent Smith. + + * src/common.c src/common.h src/file_io.h + Added is_pipe field to SF_PRIVATE and declaration of psf_is_pipe() + function. (Axel Röbel) + + * src/sndfile.c + Fixed determination of whether the file is a pipe. (Axel Röbel) + + * src/paf.c + Force paf24 to start with undefined mode. (Axel Röbel) + + * tests/pipe_test.c + Mods to make this test work and actually do the test on RAW files. (Axel + Röbel). + +2003-05-05 Erik de Castro Lopo + + * src/sndfile.c + Fixed a potential bug where psf->sf.seekable was being set to FALSE when + operating on stdin or stdout but then the default initialiser was reseting + it to TRUE. Thanks to Axel Röbel. + + * src/aiff.c + Fixed a bug in the header parser where it was not handling an odd length + COMM chunk correctly. Thanks to Axel Röbel. + + * src/test_file_io.c + Add more tests. + + * tests/win32_test.c + New file for showing the bugs in the Win32 implementation of the POSIX API. + It also runs on Linux for sanity checking. + + * tests/Makefile.am Win32/Makefile.msvc + Hook the new test program into the build system. + +2003-05-04 Erik de Castro Lopo + + * src/test_file_io.c + New test program to test operation of functions defined in file_io.c. This + should make supporting win32 significantly easier. + + * src/Makefile.am + Hook new test program into the build system. + + * src/file_io.c + Add compile/run time check that sizeof statbuf.st_size and sf_count_t are + the same. + + * src/common.h src/sndfile.c + Added new error code and error message for new check. + + * tests/benchmark.tpl + Fix to use frames instead of samples in SF_INFO. + +2003-05-03 Erik de Castro Lopo + + * src/file_io.c + More stuffing about working around PLAIN OLD-FASHIONED **BUGS** in Win32. + + * examples/sndfile-info.c + Applied patch from Conrad Parker to add "--help" and "-h" options as + well as an improved usage message. + +2003-05-02 Erik de Castro Lopo + + * src/au.c + Added embedded file support. + + * tests/multi_file_test.c + Added tests for embedded AU files. + Added verbose testing mode. + + * src/common.h src/sndfile.c + Added an embedded AU specific error code and message. + + * src/wav.c + Added patch from Conrad Parker which filled in a little more information + about ACIDized WAV files. + +2003-04-30 Erik de Castro Lopo + + * src/file_io.c + Fixed Win32 version of psf_fseek() which was calling psf_get_filelen() + which was in turn calling psf_fseek() which in the end blew the stack. + Now of course this would have been easy to find on Linux, but this blow + up was happening in kernel32.dll and the fscking MSVC++ debugger couldn't + figure out what call caused this (it couldn't even tell me the stack had + overflowed) and was absolutley useless for this debugging exercise. + On top of that, the reason I got into this mess was that windoze doesn't + have a working fstat() function which can return file lengths > 2 Gig. It + HAS a fscking _fstati64() but the file length value is only updated AFTER + the bloody file is closed. That makes it completely useless. + How the hell do people stand working on this crap excuse of an OS? + +2003-04-29 Erik de Castro Lopo + + * Win32/unistd.h src/file_io.c + Moved definitions of S_IGRP etc from file_io.c to unistd.h so that these + can be used in the test programs. + + * Win32/libsndfile.def + Added sf_open_fd. + + * Win32/sndfile.h + Updated to match src/sndfile.h.in. + + * Win32/Makefile.msvc + Added dither.c and htk.c to libsndfile.dll target. + +2003-04-28 Erik de Castro Lopo + + * src/file_io.c + First attempt at getting the Win32 versions of the these functions working. + They still need to be tested. + +2003-04-27 Erik de Castro Lopo + + * src/strings.c + Found and fixed a bug which was causing psf_store_string() to fail on + Motorola 68k processors. Many thanks to Joshua Haberman (Debian maintainer + of libsndfile) for compiling and running debug code to help me debug the + problem. + +2003-04-26 Erik de Castro Lopo + + * src/sndfile.c src/file_io.c src/wav.c src/aiff.c + Much hacking to get reading and writing of embedded files working (ie sound + files at a non-zero files offset). + + * doc/embedded_files.html + First pass atempt at documenting reading/writing embedded files. + +2003-04-21 Erik de Castro Lopo + + * doc/FAQ.html + Updated answer to "Why doesn't libsndfile do interleaving/de-interleaving?" + +2003-04-19 Erik de Castro Lopo + + * src/wav.c src/aiff.c + Fix retrieving and storing of string data from files. Need to be careful + about using psf->buffer for strings. + +2003-04-18 Erik de Castro Lopo + + * src/file_io.c + Fix psf_fseek() for seeks withing embedded files. + +2003-04-15 Erik de Castro Lopo + + * src/sndfile.h.in + Changed the definition of SNDFILE slightly to produce warnings when it isn't + used correctly. This should have zero affect in code which uses the SNDFILE + type correctly. + + * src/sndfile.c + Fixed a few compiler warnings cause by the changes to the SNDFILE type. + +2003-04-12 Erik de Castro Lopo + + * doc/FAQ.html + Added question and answer to the question "How about adding the ability + to write/read sound files to/from memory buffers?". + +2003-04-08 Erik de Castro Lopo + + * tests/write_read_test.tpl + Removed un-needed enums declaring TRUE and FALSE and replaced usage of + these with SF_TRUE and SF_FALSE. + + * tests/multi_file_test.c + New test program to test sf_open_fd() on files containing data other than + a single sound file. + +2003-04-06 Erik de Castro Lopo + + * src/file_io.c + When creating files, set the readable by others flag. This still allows + further restrictions to be enforced by use of the user's umask. Fix + suggested by Eric Lyon. + +2003-04-05 Erik de Castro Lopo + + * src/sndfile.h.in src/sndfile.c + Changed sf_open_fd(). Dropped offset parameter and added a close_desc + parameter. If close desc is TRUE, the file descritpor passed into the + library will be closed when sf_close() is called. + + * tests/utils.tpl + Modified call to sf_open_fd() to set close_desc parameter to SF_TRUE. + +2003-04-04 Erik de Castro Lopo + + * tests/write_read_test.tpl + Add a string (using sf_set_string() function) before and after data section + of all files. This will make sure that if string data can be added, it + doesn't overwrite real audio data. + +2003-04-02 Erik de Castro Lopo + + * src/sndfile.c + Started work on supporting a non-zero offset parameter for sf_open_fd (). + + * src/.c + Removed many uses of psf_fseek (SEEK_END) which to allow for future use of + sf_open_fd() with non-zero offset. + Associated refactoring. + + * src/aiff.c + Implemented functionality required to get sf_get_string() and + sf_set_string() working for AIFF files. + +2003-04-01 Erik de Castro Lopo + + * tests/utils.tpl + Modified test_open_file_or_die() to alternately use sf_open() and + sf_open_fd(). + + * src/svx.c + Fixed a bug which occurred when openning an existing file for read/write + using sf_open_fd(). In this case, the existing NAME chunk needs to be + read into psf->filename. + Fixed printing of sf_count_t types to logbuffer. + +2003-03-31 Erik de Castro Lopo + + * src/sndfile.h.in + Added prototype for new function sf_open_fd(). + + * src/sndfile.c + Moved most of the code in sf_open() to a new function psf_open_file(). + Created new function sf_open_fd() which also uses psf_open_file() but + does not currently support the offset parameter. + + * doc/api.html + Document sf_open_fd(). + +2003-03-09 Erik de Castro Lopo + + * src/sndfile.c + Fixed a memory leak reported by Evgeny Karpov. Memory leak only occurred + when an attempt was made to read and the open() call fails. + +2003-03-08 Erik de Castro Lopo + + * tests/open_fail_test.c + New test program to check for memory leaks when sf_open fails on a valid + file. Currently this must be run manually under valgrid. + + * tests/Makefile.am + Hook new test program into build. + +2003-03-03 Erik de Castro Lopo + + * Octave/sndfile_save.m Octave/sndfile_play.m + Added a -mat-binary option to the octave save command to force the output + to binary mode even if the user has set ascii data as the default. Found + by Christopher Moore. + +2003-02-27 Erik de Castro Lopo + + * doc/dither.html + New file which will document the interface which allows the addition of + audio dither when sample word sizes are being reduced. + + * src/dither.c + More work. + +2003-02-26 Erik de Castro Lopo + + * tests/misc_test.c + In update_header_test(), make HTK files a special case. + + * doc/index.html + Added HTK to the feature matrix. + +2003-02-25 Erik de Castro Lopo + + * src/htk.c + New file for reading/writing HMM Tool Kit files. + + * src/sndfile.h.in src/sndfile.c src/command.c src/Makefile.am + Hook in htk.c + + * tests/write_read_test.tpl tests/misc_test.c tests/Makefile.am + Add tests for HTK files. + +2003-02-22 Erik de Castro Lopo + + * src/wav.c + Fixed a bug where the LIST chunk length was being written incorrectly. + + * tests/string_test.c + Added call to check_log_buffer(). + Minor cleanups. + +2003-02-10 Erik de Castro Lopo + + * src/wav_w64.h + Applied patch from Antoine Mathys to add extra WAV format definitions and + a G72x_ADPCM_WAV_FMT struct definition. + + * src/wav_w64.c + Applied patch from Antoine Mathys which converts wav_w64_format_str() from + one huge inefficient switch statement to a binary search. + + * tests/string_test.c + Dump log buffer if tests fail. + +2003-02-07 Erik de Castro Lopo + + * tests/string_test.c + David Viens supplied some modifications to this file which showed up a bug + when using sf_set_string() and the sf_writef_float() functions. + + * src/sndfile.c + Fixed the above bug. + +2003-02-06 Erik de Castro Lopo + + * doc/FAQ.html + Added Q and A on how to detect libsndfile in configure.in (at the suggestion + of Davy Durham). + +2003-02-05 Erik de Castro Lopo + + * src/sndfile.h.in + Add enums and typedefs for dither. + Deprecate SFC_SET_ADD_DITHER_ON_WRITE and SFC_SET_ADD_DITHER_ON_READ, to be + replaced with SFC_SET_DITHER_ON_WRITE and SFC_SET_DITHER_ON_READ which will + allow different dither algorithms to be enabled. + Added SFC_GET_DITHER_INFO_COUNT and SFC_GET_DITHER_INFO. + + * src/sndfile.h.in src/Version_script.in Win32/libsndfile.def. + Added public sf_dither_*() functions. + + * src/sndfile.c + Implement commands above. + + * src/dither.c + More work. Framework and external hooks into dither algorithms complete. + +2003-02-03 Erik de Castro Lopo + + * doc/version-1.html libsndfile_version_convert.py + Remove redundant files. + + * doc/index.html doc/api.html + Remove links to version-1.html. + + * src/dither.c + New file to allow the addition of audio dither on input and output. + + * src/common.h + Add prototype for dither_init() function. + + * Makefile.am doc/Makefile.am + Changes for added and removed files. + +2003-02-02 Erik de Castro Lopo + + * Win32/Makefile.msvc + Changes to force example binaries to be placed in the top level directory + instead of the examples/ directory. + Add src/strings.c and src/xi.c to the build. + Add string_test to build and to tests on WAV files. + + * doc/index.html + Added XI to support matrix. + +2003-01-27 Erik de Castro Lopo + + * src/sndfile.h.in + Added prototypes for sf_get_string() and sf_set_string() and SF_STR_* + enum values. + + * src/sndfile.c + Added public interface to sf_get_string() and sf_set_string(). + + * src/wav.c + Added code for setting and getting strings in WAV files. + + * tests/string_test.c + New test program for sf_get_string() and sf_set_string() functionality. + + * tests/Makefile.am + Hook new test program into build and test framework. + +2003-01-26 Erik de Castro Lopo + + * src/common.h + Added fields to SF_PRIVATE for string data needed to implement + sf_get_string() and sf_set_string(). + + * src/strings.c + New file for storing and retrieving strings to/from files. + + * src/Makefile.am + Added strings.c to build. + +2003-01-25 Erik de Castro Lopo + + * src/xi.c + Read seems to be working so looking at write. + + * src/sndfile.h.in + Added SF_FORMAT_XI, SF_FORMAT_DPCM_8 and SF_FORMAT_DPCM_16 enum values. + + * tests/floating_point_test.c tests/lossy_comp_test.c tests/Makefile.am + Added test for 8 and 16 bit XI format files. + +2003-01-24 Erik de Castro Lopo + + * doc/index.html + Added a non-lawyer readable summary of the licensing provisions as + suggested by Steve Dekorte. + +2003-01-23 Erik de Castro Lopo + + * src/wav.c + Fixed a compiler warning found by Alexander Lerch. + +2003-01-18 Erik de Castro Lopo + + * configure.ac + Fixed the multiple linking of libm. + +2003-01-17 Erik de Castro Lopo + + * Win32/Makefile.mcvs + Added comments on the correct way to set up the MSVCDir environment + variable. + + * doc/win32.html + Add on how to set up the MSVCDir environment variable. + +2003-01-15 Erik de Castro Lopo + + * examples/sndfile-play.c examples/sndfile-info.c + When run on Win32 without any command line parameters print a message and + then sleep for 5 seconds. This means the when somebody double clicks on + these programs in explorer the user will actually see the message. + +2003-01-14 Erik de Castro Lopo + + * tests/misc_test.c + Bypass permission test if running as root because root is allowed to open + a readonly file for write. + +2003-01-08 Erik de Castro Lopo + + * Win32/Makefile.msvc + Added pvf.c and xi.c source files to project. + + * src/sndfile.h + Updated for PVF files. + +2003-01-07 Erik de Castro Lopo + + * src/sndfile.c + Modified validate_sfinfo() to force samplerate, channels and sections + to be >= 1. + In format_from_extension() replaced calls to does_extension_match() + with strcmp(). + + * src/xi.c + More work. + +2003-01-06 Erik de Castro Lopo + + * doc/Makefile.am + Added octave.html which had been left out. Found by Jan Weil. + +2003-01-05 Erik de Castro Lopo + + * src/pvf.c src/common.h src/sndfile.c + Fixed error handling for PVF files. + + * src/xi.c + New file for handling Fasttracker 2 Extended Instrument files. Not working + yet and included when configured with --enable-experimental. + + * src/sndfile.c src/common.h + Hooked in new file xi.c. + +2002-12-30 Erik de Castro Lopo + + * src/rx2.c + Added a patch from Marek Peteraj which sheds a little more light on the + slices within an RX2 file. Still need to find out data encoding. + +2002-12-20 Erik de Castro Lopo + + * src/wav.c + Started work on decoding 'acid' and 'strc' chunks. + +2002-12-14 Erik de Castro Lopo + + * tests/peak_check_test.c + Minor cleanup. + +2002-12-12 Erik de Castro Lopo + + * tests/write_read_test.tpl + Added check to make sure no error was generated when an attempt was made to + read past the end of the file. + +2002-12-11 Erik de Castro Lopo + + * doc/lists.html + Added "mailto" links for all three lists. + + * src/pvf.c + New file for Portable Voice Format files. + + * src/sndfile.h.in src/sndfile.c src/common.h src/command.c src/Makefile.am + Added hooks for SF_FORMAT_PVF format files. + + * tests/write_read_test.tpl tests/std*.c + Add tests for SF_FORMAT_PVF. + + * doc/index.html + Add PVF to the compatibility matrix. + + * src/pcm.c src/alaw.c src/ulaw.c src/float32.c src/double64.c + Previously, attempts to read beyond the end of a file would set psf->error + to SFE_SHORT_ERROR. This behaviour diverged from the behaviour of the POSIX + read() call but has now been fixed. + Attempts to read beyond the end of the file will return a short read count + but will not longer set any error. + +2002-12-09 Erik de Castro Lopo + + * src/sndfile.c + Add more sanity checking when opening a RAW file for read. When format is + not RAW, zero out all members of the SF_INFO struct. + + * tests/raw_test.c + Add bad_raw_test() to check for above problem. + + * tests/stdin_test.c examples/sndfile-info.c + Set the format field of the SF_INFO struct to zero before calling + sf_open(). + + * doc/api.html + Add information about the need to set the format field of the SF_INFO struct + to zero when opening non-RAW files for read. + + * configure.ac + Removed use of conversion script on Solaris. Not all Solaris versions + support it. + + * doc/lists.html + New file containg details of the mailing lists. + + * doc/index.html + Add a link to the above new file. + +2002-12-04 Erik de Castro Lopo + + * tests/dft_cmp.c + Fixed a SIGFPE on Alpha caused by a log10 (0.0). Thanks to Joshua Haberman + for providing the gdb traceback. + +2002-11-28 Erik de Castro Lopo + + * src/wav.c + Added more capabilities to 'smpl' chunk parser. + + * src/sndfile.c + Fixed some (not all) possible problems found with Flawfinder. + +2002-11-24 Erik de Castro Lopo + + * src/sndfile.c + Fixed a bug in sf_seek(). This bug could only occur when an attempt was + made to read beyond the end and then sf_seek() was called with a whence + parameter of SEEK_CUR. + + * src/file_io.c + Win32's _fstati64() does not work, it returns BS. Re-implemented + psf_get_filelen() in terms of psf_fseek(). + + * tests/write_read_test.tpl + Add a test to detect above bug. + + * src/float_cast.h + Modification to prevent compiler warnings on Mac OS X. + + * src/file_io.c + Fixes for windows (what a f**ked OS). + +2002-11-08 Erik de Castro Lopo + + * configure.ac + Disable use of native lrint()/lrintf() on Mac OSX. These functions exist on + Mac OSX 10.2 but not on 10.1. Forcing the use of the versions in + src/float_cast.h means that a library compiled on 10.2 will still work on + 10.1. + +2002-11-06 Erik de Castro Lopo + + * configure.in configure.ac + Renamed configure.in to configure.ac as expected by later versions of + autoconf. + Slight hacking of configure.ac to work with version 2.54 of autoconf. + Changed to using -dumpversion instead of --version for determining GCC + version numer as suggested by Anand Kumria. + + * src/G72x/Makefile.am + Slight hacking required for operation with automake 1.6.3. + +2002-11-05 Erik de Castro Lopo + + * src/common.c + In psf_binheader_readf() changed type parameter type "b" type from size_t + to int to prevent errors on IA64 CPU where sizeof (size_t) != sizeof (int). + Thanks to Enrique Robledo Arnuncio for debugging this. + +2002-11-04 Erik de Castro Lopo + + * test/command_test.tpl + Changed test value so test would pass on Solaris. + + * src/Version_script.in + Modified version numbering so that later versions of 1.0.X can replace + earlier versions without recompilation. + + * src/vox_adpcm.c + Fixed bug causing short reads. + +2002-11-03 Erik de Castro Lopo + + * test/floating_point_test.c + Code cleanup using functions from util.c. + Add test for IEEE replacement floats and doubles. + +2002-11-01 Erik de Castro Lopo + + * src/wav.c + Fixed a possible divide by zero error when read the 'smpl' chunk. Thanks to + Serg Repalov for the example file. + + * tests/pcm_test.tpl + Used sf_command (SFC_TEST_IEEE_FLOAT_REPLACE) to test IEEE replacement code. + Clean up pcm_double_test(). + + * src/float32.c src/double64.c + Force use of IEEE replacement code using psf->ieee_replace is TRUE, + Print message to log_buffer as well. + Rename all broken_read_* and broken_write* functions to replace_read_* and + replace_write_*. + + * tests/util.tpl + Added string_in_log_buffer(). + + * tests/pcm_test.tpl + Use string_in_log_buffer() to ensure that IEEE replacement code has been + used. + + * configure.in + Removed --enable-force-broken-float option. IEEE replacement code is now + always tested. + +2002-10-31 Erik de Castro Lopo + + * src/double64.c + Implement code for read/writing IEEE doubles on platforms where the native + double format is not IEEE. + + * src/float32.c src/common.h + Remove float32_read() and float32_write(). Replace with float32_le_read(), + float32_be_read(), float32_le_write() and float32_be_write() to match stuff + in src/double64.c. + + * src/common.c + Fix all usage of float32_write(). + + * src/sndfile.h.in + Added SFC_TEST_IEEE_FLOAT_REPLACE command (testing only). + + * src/common.h + Added SF_PRIVATE field ieee_replace. + + * src/sndfile.c + In sf_command() set/reset psf->ieee_replace. + +2002-10-26 Erik de Castro Lopo + + * tests/pcm_test.tpl + Fixed a problem when testing with --enable-force-broken-float. The test was + generating a value of negative zero and the broken float code is not able + to write negative zero. Removing the negative zero fixed the test. + +2002-10-25 Erik de Castro Lopo + + * src/file_io.c + Added fix for Cygwin (suggested by Maros Michalik). + +2002-10-23 Erik de Castro Lopo + + * src/file_io.c + Improved error detection and handling. + + * src/file_io.c src/common.h + Removed functions psf_ferror() and psf_clearerr() which were redundant + after above improvements. + + * src/aiff.c src/svx.c src/w64.c src/wav.c + Removed all use of psf_ferror() and psf_clearerr(). + + * src/sndfile.c + Removed #include of , , and which + are no longer needed. + + * tests/misc_test.c + Added test to make sure the correct error message is returned with an + existing read-only file is openned for write. + +2002-10-21 Erik de Castro Lopo + + * doc/index.html doc/api.html + Updated for OKI Dialogic ADPCM files. + + * src/command.c + Added VOX ADPCM to sub_fomats. + +2002-10-20 Erik de Castro Lopo + + * src/vox_adpcm.c src/Makefile.am + New file for handling OKI Dialogic ADPCM files. + + * src/sndfile.h + Add new subtype SF_FORMAT_VOX_ADPCM. + + * src/sndfile.c + Renamed function is_au_snd_file () to format_from_extenstion () and expanded + its functionality to detect headerless VOX files. + + * src/raw.c + Added hooks for SF_FORMAT_VOX_ADPCM. + + * examples/sndfile-info.c + Print out file duration (suggested by Conrad Parker). + + * libsndfile.spec.in + Force installation of sndfile.pc file (found by John Thompson). + + * tests/Makefile.am tests/lossy_comp_test.c tests/floating_point_test.c + Add tests for SF_FORMAT_VOX_ADPCM. + +2002-10-18 Erik de Castro Lopo + + * tests/misc_test.c + Add test which attempts to write to /dev/full (on Linux anyway) to check + for correct handling of writing to a full filesystem. + + * src/sndfile.c + Return correct error message if the header cannot be written because the + filesystem is full. + + * tests/util.tpl + Corrected printing of file mode in error reporting. + + * src/mat5.c + Fixed a bug where a MAT5 file written by libsndfile could not be opened by + Octave 2.1.36. + +2002-10-13 Erik de Castro Lopo + + * src/common.h src/file_io.c + All low level file I/O have been modified to be better able to report + system errors resulting from calling system level open/read/write etc. + + * src/*.c + Updated for compatibility with above changes. + + * examples/cooledit-fixer.c + New example program which fixes badly broken file created by Syntrillium's + Cooledit which are marked as containing PCM samples but actually contain + floating point data. + + * examples/Makefile.am + Hooked cooledit-fixer into the build system. + +2002-10-10 Erik de Castro Lopo + + * doc/command.html + Document SFC_GET_FORMAT_INFO. + +2002-10-09 Erik de Castro Lopo + + * examples/wav32_aiff24.c examples/sndfile2oct.c examples/sfhexdump.c + examples/sfdump.c + Removed these files because they weren't interesting. + + * examples/sfconvert.c examples/sndfile-convert.c + Renamed the first to the latter. + + * examples/Makefile.am + Added sndfile-convert to the bin_PROGRAMS, so it is installed when the lib + is installed. + Removed old programs wav32_aiff24 and sndfile2oct. + + * man/sndfile-convert.1 + New man page. + + * examples/sndfile-convert.c + Added some gloss now that sndfile-convert.c is an installed program. + + * src/sndfile.h.in src/sndfile.c src/common.h src/command.h + Added command SFC_GET_FORMAT_INFO. + + * tests/command_test.c + Added tests form SFC_GET_FORMAT_INFO. + +2002-10-08 Erik de Castro Lopo + + * src/sndfile.c + In sf_format_check() return error if samplerate < 0. + +2002-10-07 Erik de Castro Lopo + + * src/aiff.c + Fixed bug in handling of COMM chunks with a 4 byte encoding byte but no + encoding string. + +2002-10-06 Erik de Castro Lopo + + * src/sndfile.c + Fixed repeated word in an error message. + +2002-10-05 Erik de Castro Lopo + + * doc/index.html + Improved advertising in Features section. + +2002-10-04 Erik de Castro Lopo + + * src/wav.c + Added decoding of 'labl' chunks within 'LIST' chunks. + + * src/common.h + Added (experimental only) SF_FORMAT_OGG and SF_FORMAT_VORBIS and definition + of ogg_open(). This is nowhere near working yet. + + * src/sndfile.c + Added detection of 'OggS' file marker and added call to ogg_open() to + switch statement. + + * src/ogg.c + New file. Very early start of Ogg Vorbis support. + + * src/wav.c + Added handling of brain-damaged and broken Cooledit "32 bit 24.0 float + type 1" files. These files are marked as being 24 bit WAVE_FORMAT_PCM with + a block alignment of 4 times the numbers of channels but are in fact 32 bit + floating point. + +2002-10-02 Erik de Castro Lopo + + * configure.in + Modified option --enable-experimental to set ENABLE_EXPERIMENTAL_CODE in + config.h to either 0 or 1. + + * src/sndfile.c + Modify sf_command (SFC_GET_LIB_VERSION) to append "-exp" to the version + string if experimental code has been enabled. + +2002-10-01 Erik de Castro Lopo + + * src/Makefile.am + Added -lm to libsndfile_la_LIBADD. This means that -lm is not longer needed + in the link line when linking something to libsndfile. + + * tests/Makefile.am examples/Makefile.am + Removed -lm from all link lines. + + * sndfile.pc.in + Removed -lm from Libs line. + +2002-09-24 Erik de Castro Lopo + + * src/file_io.c + Removed all perror() calls. + + * src/nist.c + Removed calls to exit() function. + Added check to detect NIST files dammaged from Unix CR -> Win32 CRLF + conversion process. + +2002-09-24 Erik de Castro Lopo + + * src/sndfile.h.in src/sndfile.c + New function sf_strerror() which will eventually replace functions + sf_perror() and sf_error_str(). + Function sf_error_number() has also been changed, but this was documented + as being for testing only. + + * doc/api.html + Documented above changes. + + * tests/*.c examples/*.c + Changed to new error functions. + +2002-09-22 Erik de Castro Lopo + + * configure.in + Detect GCC version, and print a warning message about writeable strings + it GCC major version number is less than 3. + +2002-09-21 Erik de Castro Lopo + + * src/sndfile.h.in doc/api.html + Documentation fixes. + +2002-09-19 Erik de Castro Lopo + + * src/Version_script.in src/Makefile.am configure.in + Use the version script to prevent the exporting of all non public symbols. + This currently only works with Linux. Will test on Solaris as well. + + * src/float_cast.h + Added #ifndef to prevent the #warning directives killing the SGI MIPSpro + compiler. + + * src/au_g72x.c src/double64.c src/float32.c src/gsm610.c src/ima_adpcm.c + src/ms_adpcm.c + Fix benign compiler warnings arising from previously added compiler + flags. + +2002-09-18 Erik de Castro Lopo + + * src/sndfile.c + Fixed a bug in sf_error_str() where errnum was used as the index instead + of k. Found by Tim Hockin. + + * examples/sndfile-play.c + Fixed a compiler warning resulting from a variable shadowing a previously + defined local. + +2002-09-17 Erik de Castro Lopo + + * src/sndfile.h.in src/sndfile.c + Added command SFC_SET_RAW_START_OFFSET. + + * doc/command.html + Document SFC_SET_RAW_START_OFFSET. + + * tests/raw_test.c tests/Makefile.am + Add new file for testing SF_FORMAT_RAW specific functionality. + + * tests/dwvw_test.c + Updates. + +2002-09-16 Erik de Castro Lopo + + * src/wav.c + Modified reading of 'smpl' chunk to take account of the sampler data field. + + * tests/utils.tpl tests/utils.h + Added function print_test_name(). + + * tests/misc_test.c tests/write_read_test.tpl tests/lossy_comp_test.c + tests/pcm_test.tpl tests/command_test.tpl tests/floating_point_test.c + Convert to use function print_test_name(). + +2002-09-15 Erik de Castro Lopo + + * doc/octave.html + Added a link to some other Octave scripts for reading and writing sound + files. + + * src/paf.c + Change type of dummy data field to int. This should fix a benign compiler + warning on some CPUs. + Removed superfluous casts resulting from the above change. + + * src/rx2.c + More hacking. + +2002-09-14 Erik de Castro Lopo + + * src/mat5.c src/common.c + Changed usage of snprintf() to LSF_SNPRINTF(). + + * Win32/Makefile.msvc + Updated to include new files and add new tests. + + * Win32/config.h Win32/sndfile.h + Updated. + + * doc/api.html + Added note about the possibility of "missing" features actually being + implemented as an sf_command(). + +2002-09-13 Erik de Castro Lopo + + * tests/misc_test.c + Added previously missing update_header_test and zero_data_tests for PAF, + MAT4 and MAT5 formats. + + * src/paf.c src/mat4.c src/mat5.c + Fixed bugs uncovered by new tests above. + + * src/mat5.c + Generalised parsing of name fields of MAT5 files. + + * src/mat5.c src/sndfile.c + Added support for unsigned 8 bit PCM MAT5 files. + + * tests/write_read_test.tpl + Added test for unsigned 8 bit PCM MAT5 files. + + * doc/index.html + Added unsigned 8 bit PCM MAT5 to capabilities matrix. + +2002-09-12 Erik de Castro Lopo + + * test/update_header_test.c tests/misc_test.c + Renamed update_header_test.c to misc_test.c. + Added zero_data_test() to check for case where file is opened for write and + closed immediately. The resulting file can be left in a state where + libsndfile cannot open it. Problem reported by Werner Schweer, the author + of Muse. + + * src/aiff.c + Removed superfluous cast. + + * src/wav.c src/svx.c + Fixed case of file generated with no data. + Removed superfluous cast. + + * src/sndfile.c + Fixed error on IA64 platform caused by incorrect termination of + SndfileErrors struct array. This problem was found in the Debian buildd + logs (http://buildd.debian.org/). + + * configure.in + Added Octave directory. + + * Octave/Makefile.ma + New Makfile.am for Octave directory. + + * Octave/sndfile_load.m Octave/sndfile_save.m Octave/sndfile_play.m + New files for working with Octave. + + * doc/octave.html + Document explaining the use of the above three Octave scripts. + +2002-09-10 Erik de Castro Lopo + + * src/sndfile.c + Fixed bug in RDWR mode. + +2002-09-09 Erik de Castro Lopo + + * src/common.c + Fixed psf_get_date_str() for systems which don't have gmtime_r() or + gmtime(). + + * src/file_io.c + Added #include for Win32. Reported by Koen Tanghe. + +2002-09-08 Erik de Castro Lopo + + * src/common.c + Added 'S' format specifier for psf_binheader_writef() which writes a C + string, including single null terminator to the header. + Added 'j' format specifier to allow jumping forwards or backwards in the + header. + Added function psf_get_date_str(). + + * src/mat5.c + Complete read and write support. + + * doc/index.html + Added entries for MAT4 and MAT5 in capabilities matrix. + +2002-09-06 Erik de Castro Lopo + + * src/mat4.c + Completed read and write support. + + * src/common.h src/sndfile.c + Added MAT4 and MAT5 specific error messages. + + * tests/write_read_test.tpl tests/Makefile.am + Added tests for MAT4 and MAT5 files. + + * tests/stdio_test.c tests/stdout_test.c tests/stdin_test.c + Added tests for MAT4 and MAT5 files. + +2002-09-05 Erik de Castro Lopo + + * src/command.c + Added elements for SF_FORMAT_MAT4 and SF_FORMAT_MAT5 to major_formats + array. + + * examples/sfconvert.c + Added mat4 and mat5 output targets. + +2002-09-04 Erik de Castro Lopo + + * src/sndfile.c + Added check to prevent errors openning read only formats for read/write. + + * src/interleave.c + New file for interleaving non-interleaved data. Non-interleaved data is + only supported on read. + + * src/Makefile.am + Added src/interleave.c to build. + +2002-09-03 Erik de Castro Lopo + + * src/double64.c src/common.h + Added double64_be_read(), double64_le_read(), double64_be_write() and + double64_le_write() which replace double64_read() and double64_write(). + + * src/common.c + Cleanup of psf_binheader_readf() and add ability to read big and little + endian doubles (required by mat4.c and mat5.c). + Add ability for psf_binheader_writef() to write doubles to sound file + headers. + +2002-09-01 Erik de Castro Lopo + + * src/mat5.c + New file for reading Matlab (tm) version 5 data files. This is also the + native binary file format for version 2.1.X of GNU Octave which will be + used for testing. + Not complete yet. + + * src/mat4.c + New file for reading Matlab (tm) version 4.2 data files. This is also the + native binary file format for version 2.0.X of GNU Octave which will be + used for testing. + Not complete yet. + + * src/sndfile.h.in src/sndfile.c src/common.h src/command.c src/Makefile.am + Mods to add Matlab files. + + * src/common.[ch] + Added readf_endian field to SF_PRIVATE struct allowing endianness to + remembered across calls to sf_binheader_readf(). + Fixed bug in width_specifier behaviour for printing hex values. + +2002-08-31 Erik de Castro Lopo + + * src/file_io.c + Check return value of close() call in psf_fclose(). + +2002-08-24 Erik de Castro Lopo + + * src/ms_adpcm.c + Commented out some code where 0x10000 was being subtracted from a short + and the result assigned to a short again. Andrew Zaja found this. + +2002-08-23 Erik de Castro Lopo + + * doc/command.html + Fixed typo found by Tommi Ilmonen. + + * src/ima_adpcm.c + Changed type of diff from short to int to prevent errors which can occur + during very rare circumstances. Thanks to FUWAFUWA. + +2002-08-16 Erik de Castro Lopo + + * tests/floating_point_test.c + Disable testing on machines without lrintf(). + + * Win32/Makefile.msvc + Added dwd.c and wve.c to build. + + * configure.in + Bumped version to 1.0.0. + +2002-08-15 Erik de Castro Lopo + + * src/file_io.c + Add a #include for Mac OS 9. Thanks to Stephane Letz. + + * src/wav.c + Changed an snprintf to LSF_SNPRINTF. + + * doc/Makefile.am + Added version-1.html. + +2002-08-14 Erik de Castro Lopo + + * configure.in + Bumped version to 1.0.rc6. + + * src/*.c + Modified scaling of normalised floats and doubles to integers. Until now + this has been done by multiplying by 0x8000 for short output, 0x80000000 + for 32 bit ints and so on. Unfortunately this can cause an overflow and + wrap around in the target value. All thes values have therefore been + reduced to 0x7FFF, 0x7FFFFFFF and so on. The conversion from ints to + normalised floats and doubles remains unchanged. This does mean that for + repeated conversions normalised float -> pcm16 -> normalised float would + result in a decrease in amplitude of 0x7FFF/0x8000 on every round trip. + This is undesirable but less undesireable than the wrap around I am trying + to avoid. + + * tests/floating_point_test.c + Removed file hash checking because new float scaling procedure introduced + above prevented the ability to crate a has on both x86 and PowerPC systems. + +2002-08-13 Erik de Castro Lopo + + * src/txw.c + Completed reading of TXW files. Seek doesn't work yet. + + * src/file_io.c + Added a MacOS 9 replacement for ftruncate(). + + * MacOS/sndfile.h + Added MacOS 9 header file. This should be copied into src/ to compile + libsndfile for MacOS9. + +2002-08-12 Erik de Castro Lopo + + * src/sndfile.c + Fixed commands SF_SET_NORM_DOUBLE and SFC_SET_NORM_FLOAT to return their + values after being set. Reported by Jussi Laako. + + * configure.in + If autogen is not found, touch all .c and .h files in tests/. + + * src/common.c + Added format width specifier to psf_log_printf() for %u, %d, %D and %X. + + * src/dwd.c + Completed implementation of read only access to these files. + + * src/common.h src/*.c src/pcm.c + Removed redundant field chars from SF_PRIVATE struct and modified + pcm_init() to do without it. + +2002-08-11 Erik de Castro Lopo + + * src/wve.c + New file implementing read of Psion Alaw files. This will be a read only + format. Implementation complete. + + * src/dwd/c + Started implementation of DiamondWare Digitized files. Also read only, not + complete. + + * src/wav.c + Add parsing of 'smpl' chunk. + + * src/paf.c + Fixed reading on un-normalized doubles and floats from 24 bit PAF files. + This brings it into line with the reading of 8 bit files into + un-normalized doubles which returns values in the range [-128, 127]. + + * src/common.c + Modified psf_log_printf() to accept the %% conversion specifier to allow + printing of a single '%'. + + * src/sds.c + Read only of 16 bit samples is working. Need to build a test harness for + this and other read only formats. + +2002-08-10 Erik de Castro Lopo + + * configure.in + Added --enable-experimental configure option. + Removed pkg-config message at the end of the configure process. + + * src/sds.c src/txw.c src/rx2.c src/sd2.c + Moved all the code in these files inside #if ENABLE_EXPERIMENTAL_CODE + blocks and added new *_open() function for the case where experimental is + not enabled. These new functions just return SFE_UNIMPLMENTED. + + * Win32/sndfile.h src/sndfile.h.in src/common.h + Removed un-necessary #pragma pack commands. + + * src/file_io.c + Implemented psf_ftruncate() and much other hacking for Win32. + + * Win32/Makefile.msvc + Updated. + + * doc/win32.html + Updated to include the copying of the sndfile.h file from the Win32/ + directory to the src/ directory. + + * Make.bat + Batch file to make compiling on Wi32 a little easier. Implements "make" and + "make check". + +2002-08-09 Erik de Castro Lopo + + * src/file_io.c + Add place holder for ftruncate() on Win32 which doesn't have ftruncate(). + This will need to be fixed later. + + * src/sndfile.h.in + New file (copy of sndfile.h) with sets up @TYPEOF_SF_COUNT_T@ which will be + replaced by the correct type during configure. + + * configure.in + Modified to find a good type for TYPEOF_SF_COUNT_T. + + * src/aiff.c + Fixed a bug when reading malformed headers. + + * src/common.c + Set read values to zero before performing read. + +2002-08-08 Erik de Castro Lopo + + * doc/command.html + Fixed some HTML tags which were not allowing jumps to links within the + page. + + * src/sds.c + Massive hacking on this. + + * src/wav.c + Added recognition of 'clm ' tag. + +2002-08-07 Erik de Castro Lopo + + * doc/index.html + Added beginning of a capabilities list beyond simple file formats which + can be read/written. + + * src/aiff.c + Added parsing of INST and MARK chunks of AIFF files. At the moment this + data is simply recorded in the log buffer. Later it will be possible to + read this data from an application using sf_command(). + + * src/wav.c + Added parsing of 'cue ' chunk which contains loop information in WAV files. + + * exampes/sndfile-info.c + Changed reporting of Samples to Frames. + + * src/wav.c src/w64.c src/aiff.c src/wav_w64.h + Moved from a samples to a frames nomenclature to avoid confusion. + + * doc/FAQ.html + What's the best format for storing temporary files? + + * src/sds.c + New file for reading/writing Midi Sample Dump Standard files. + + * src/Makefile.am src/sndfile.c src/common.[ch] + Added hooks for sds.c. + + * examples/sndfile-info.c + Changed from using sf_perror() to using sf_error_str(). + +2002-08-06 Erik de Castro Lopo + + * doc/api.html + Added explanation of mode parameter for sf_open(). + Added explanation of usage of SFM_* values in sf_seek(). + + * src/sndfile.[ch] src/command.c src/file_io.c src/common.h + Implemented SFC_FILE_TRUNCATE to allow a file to be truncated. File + truncation was suggested by James McCartney. + + * src/command.html + Documented SFC_FILE_TRUNCATE. + + * tests/command_test.c + Add tests for SFC_FILE_TRUNCATE. + + * src/sndfile.c + Added a thrid parameter to the VALIDATE_SNDFILE_AND_ASSIGN_PSF macro to + make resetting the error number optional. All uses of the macro other than + in error reporting functions were changed to reset the error number. + + * src/pcm.c + Fixed a bug were sf_read_* was logging an SFE_SHORT_READ even when no error + occurred. + + * tests/write_read_test.tpl + Added tests of internal error state. + +2002-08-05 Erik de Castro Lopo + + * src/GSM610/private.h src/GSM610/*.c src/GSM610/Makefile.am + Renamed private.h to gsm610_priv.h to prevent clash with other headers + named private.h in other directories. (Probably only a problem on MacOS 9). + + * src/G72x/private.h src/G72x/*.c src/G72x/Makefile.am + Renamed private.h to g72x_priv.h to prevent clash with other headers + named private.h in other directories. (Probably only a problem on MacOS 9). + + * MacOS/config.h + Changed values of HAVE_LRINT and HAVE_LRINTF to force use of code in + float_cash.h. + + * src/sndfile.h + Changes the name of samples field of the SF_INFO to frames. The old name + had caused too much confusion and it simply had to be changed. There will + be at least one more pre-release. + +2002-08-04 Erik de Castro Lopo + + * doc/index.html + Updated formats matrix to include RAW (header-less) GSM 6.10. + Fix specificaltion of table and spelling mistakes. + + * src/sndfile.c src/command.c + Fixed bug in SFC_CALC_MAX_SIGNAL family and psf_calc_signal_max (). + + * tests/command.c + Removed cruft. + Added test for SFC_CALC_MAX_SIGNAL and SFC_CALC_NORM_MAX_SIGNAL. + + * configure.in + Update version to 1.0.0rc5. + + * sfendian.h + Removed inclusion of un-necessary header. + +2002-08-03 Erik de Castro Lopo + + * src/aiff.c + Minor fixes of info written to log buffer. + + * src/float_cast.h + Add definition of HAVE_LRINT_REPLACEMENT. + + * tests/floating_point_test.c + Fix file hash check on systems without lrint/lrintf. + + * tests/dft_cmp.c + Limit SNR to less than -500.0dB. + + * examples/sndfile2oct.c + Fixed compiler warnings. + + * doc/api.html + Fixed error where last parameter of sf_error_str() was sf_count_t instead + of size_t. + +2002-08-02 Erik de Castro Lopo + + * doc/FAQ.html + Why doesn't libsndfile do interleaving/de-interleaving. + + * tests/pcm_test.tpl + On Win32 do not perform hash check on files containing doubles. + +2002-08-01 Erik de Castro Lopo + + * src/common.h + Defined SF_COUNT_MAX_POSITIVE() macro, a portable way of setting variables + of type sf_count_t to their maximum positive value. + + * src/dwvw.c src/w64.c + Used SF_COUNT_MAX_POSITIVE(). + +2002-07-31 Erik de Castro Lopo + + * src/paf.c + Fixed bug in reading/writing of 24 bit PCM PAF files on big endian systems. + + * tests/floating_point_tests.c + Fixed hash values for 24 bit PCM PAF files. + Disabled file has check if lrintf() function is not available and added + warning. + Decreased level of signal from a peak of 1.0 to a value of 0.95 to prevent + problems on platforms without lrintf() ie Solaris. + +2002-07-30 Erik de Castro Lopo + + * src/wav.c + Fixed a problem with two different kinds of mal-formed WAV file header. The + first had the 'fact' chunk before the 'fmt ' chunk, the other had an + incomplete 'INFO' chunk at the end of the file. + + * src/w64.c + Added fix to allow differentiation between W64 files and ACID files. + + * src/au_g72x.c src/common.h src/sndfile.c + Added error for G72x encoded files with more than one channel. + + * tests/pcm_test.tpl tests/utils.tpl + Moved function check_file_hash_or_die() to utils.tpl. Function was then + modified to calculate the has of the whole file. + + * src/wav.c + Fixed problem writing the 'fact' chunk on big endian systems. + + * tests/sfconvert.c + Fixed bug where .paf files were being written as Sphere NIST. + +2002-07-29 Erik de Castro Lopo + + * src/voc.c + Fix for reading headers generated using SFC_UPDATE_HEADER_NOW. + + * doc/command.html + Add docs for SFC_UPDATE_HEADER_NOW and SFC_SET_UPDATE_HEADER_AUTO. + +2002-07-28 Erik de Castro Lopo + + * man/sndfile-info.1 man/sndfile-play.1 + Added manpages supplied by Joshua Haberman the Debian maintainer for + libsndfile. Additional tweaks by me. + + * configure.in man/Makefile.am + Hooked manpages into autoconf/automake system. + + * src/sndfile.c + Added hooks for SFC_SET_UPDATE_HEADER_AUTO. + + * tests/update_header_test.c + Improved rigor of testing. + + * src/*.c + Fixed problem with *_write_header() functions. + +2002-07-27 Erik de Castro Lopo + + * doc/*.html + Updates to documentation to fix problems found by wdg-html-validator. + + * src/common.h src/command.c + Added normalize parameter to calls to psf_calc_signal_max() and + psf_calc_max_all_channels(). + + * src/sndfile.c + Added handling for commands SFC_CALC_NORM_SIGNAL_MAX and + SFC_CALC_NORM_MAX_ALL_CHANNELS. + + * doc/command.html + Added entry for SFC_CALC_NORM_SIGNAL_MAX and SFC_CALC_NORM_MAX_ALL_CHANNELS. + +2002-07-26 Erik de Castro Lopo + + * examples/sndfile-play.c Win32/Makefile.msvc + Get sndfile-play program working on Win32. The Win32 PCM sample I/O API + sucks. The sndfile-play program now works on Linux, MacOSX, Solaris and + Win32. + +2002-07-25 Erik de Castro Lopo + + * doc/FAQ.html + New file for frequently asked questsions. + +2002-07-22 Erik de Castro Lopo + + * doc/api.html + Documentation fixes. + + * src/au.[ch] src/au_g72x.c src/G72x/g72x.h + Add support of 40kbps G723 ADPCM encoding. + + * tests/lossy_comp_test.c tests/floating_point_test.c + Add tests for 40kbps G723 ADPCM encoding. + + * doc/index.html + Update support matrix. + +2002-07-21 Erik de Castro Lopo + + * doc/command.html + Documented SFC_GET_SIMPLE_FORMAT_COUNT, SFC_GET_SIMPLE_FORMAT, + SFC_GET_FORMAT_* and SFC_SET_ADD_PEAK_CHUNK. + + * src/sndfile.c src/pcm.c + Add ability to turn on and off the addition of a PEAK chunk for floating + point WAV and AIFF files. + + * src/sndfile.[ch] src/common.h src/command.c + Added sf_command SFC_CALC_MAX_ALL_CHANNELS. Implemented by Maurizio Umberto + Puxeddu. + + * doc/command.html + Docs for SFC_CALC_MAX_ALL_CHANNELS (assisted by Maurizio Umberto Puxeddu). + +2002-07-18 Erik de Castro Lopo + + * src/sndfile.c src/gsm610.c + Finalised support for GSM 6.10 AIFF files and added support for GSM 6.10 + encoded RAW (header-less) files. + + * src/wav.c + Add support for IBM_FORMAT_MULAW and IBM_FORMAT_ALAW encodings. + + * src/api.html + Fixed more documentation bugs. + +2002-07-17 Erik de Castro Lopo + + * src/sndfile.h src/common.h + Moved some yet-to-be-implelmented values for SF_FORMAT_* from the public + header file sndfile.h to the private header file common.h to avoid + confusion about the actual capabilities of libsndfile. + +2002-07-16 Erik de Castro Lopo + + * src/aiff.c src/wav.c + Fixed file parsing for WAV and AIFF files containing non-audio data after + the data chunk. + + * src/aiff.c src/sndfile.c + Add support for GSM 6.10 encoded AIFF files. + + * tests/lossy_comp_test.c tests/Makefile.am + Add tests for GSM 6.10 encoded AIFF files. + + * src/*.c + Fix compiler warnings. + +2002-07-15 Erik de Castro Lopo + + * tests/command_test.c + For SFC_SET_NORM_* tests, change the file format from SF_FORMAT_WAV to + SF_FORMAT_RAW. + + * src/sndfile.c + Added sf_command(SFC_TEST_ADD_TRAILING_DATA) to allow testing of reading + from AIFF and WAV files with non-audio data after the audio chunk. + + * src/common.h + Add test commands SFC_TEST_WAV_ADD_INFO_CHUNK and + SFC_TEST_AIFF_ADD_INST_CHUNK. When these commands are working, they will be + moved to src/sndfile.h + + * src/aiff.c src/wav.c + Begin implementation of XXXX_command() hook for sf_command(). + + * tests/write_read_test.tpl + Added sf_command (SFC_TEST_ADD_TRAILING_DATA) to ensure above new code was + working. + +2002-07-13 Erik de Castro Lopo + + * tests/update_header_test.c + Allow read sample count == write sample count - 1 to fix problems with VOC + files. + + * tests/write_read_test.tpl tests/pcm_test.tpl + Fixed some problems in the test suite discovered by using Valgrind. + +2002-07-12 Erik de Castro Lopo + + * tests/utils.[ch] tests/*.c + Renamed check_log_buffer() to check_log_buffer_or_die(). + + * src/sndfile.c + SFC_UPDATE_HEADER_NOW and SFC_SETUPDATE_HEADER_AUTO almost finished. Works + for all file formats other than VOC. + +2002-07-11 Erik de Castro Lopo + + * src/sndfile.[ch] src/common.h + Started adding functionality to allow the file header to be updated before + the file is closed on files open for SFM_WRITE. This was requested by + Maurizio Umberto Puxeddu who is using libsndfile for file I/O in iCSound. + + * tests/update_header_test.c + New test program to test that the above functionality is working correctly. + + * tests/peak_chunk_test.c tests/floating_point_test.c + Cleanups. + +2002-07-10 Erik de Castro Lopo + + * src/sfendian.[ch] + Changed length count parameters for all endswap_XXX() functions from + sf_count_t (which can be 64 bit even on 32 bit architectures) to int. These + functions are only called frin inside the library, are always called with + integer parameters and doing the actual calculation on 64 bit values is + slow in comparision to doing it on ints. + + * examples/sndfile-play.c + More playback hacking for Win32. + +2002-07-09 Erik de Castro Lopo + + * src/common.c + In psf_log_printf(), changed %D format conversion specifier to %M (marker) and + added %D specifier for printing the sf_count_t type. + + * src/*.c + Changed all usage of psf_log_printf() with %D format conversion specifiers + to use %M conversion instead. + + * tests/pcm_test.tpl tests/pcm_test.def + New files to autogen pcm_test.c. + + * src/pcm.c + Fixed bug in scaling floats and doubles to 24 bit PCM and vice versa. + +2002-07-08 Erik de Castro Lopo + + * configure.in + Fix setup of $ac_cv_sys_largefile_CFLAGS so that sndfile.pc gets valid + values for CFLAGS. + + * examples/sndfile-play.c + Start adding playback support for Win32. + +2002-07-07 Erik de Castro Lopo + + * src/*.c + Worked to removed compiler warnings. + Extensive refactoring. + + * src/common.[ch] + Added function psf_memset() which works like the standard C function memset + but takes and sf_count_t as the length parameter. + + * src/sndfile.c + Replaced calls to memset(0 with calls to psf_memset() as required. + +2002-07-06 Erik de Castro Lopo + + * src/sndfile.c + Added "libsndfile : " to the start of all error messages. This was suggested + by Conrad Parker author of Sweep ( http://sweep.sourceforge.net/ ). + + * src/sfendian.[ch] + Added endswap_XXXX_copy() functions. + + * src/pcm.c src/float32.c src/double64.c + Use endswap_XXXX_copy() functions and removed dead code. + Cleanups and optimisations. + +2002-07-05 Erik de Castro Lopo + + * src/sndfile.c src/sndfile.h + Gave values to all the SFC_* enum values to allow better control of the + interface as commands are added and removed. + Added new command SFC_SET_ADD_PEAK_CHUNK. + + * src/wav.c src/aiff.c + Modified wav_write_header and aiff_write_header to make addition of a PEAK + chunk optional, even on floating point files. + + * tests/benchmark.tpl + Added call to sf_command(SFC_SET_ADD_PEAK_CHUNK) to turn off addition of a + PEAK chunk for the benchmark where we are trying to miximize speed. + + * src.pcm.c + Changed tribyte typedef to something more sensible. + Further conversion speed ups. + +2002-07-03 Erik de Castro Lopo + + * src/command.c + In major_formats rename "Sphere NIST" to "NIST Sphere". + + * src/common.c src/sfendian.c + Moved all endswap_XXX_array() functions to sfendian.c. These functions will + be tweaked to provide maximum performance. Since maximum performance on one + platform does not guarantee maximum performance on another, a small set of + functions will be written and the optimal one chosen at compile time. + + * src/common.h src/sfendian.h + Declarations of all endswap_XXX_array() functions moved to sfendian.h. + + * src/Makefile.am + Add sfendian.c to build targets. + +2002-07-01 Erik de Castro Lopo + + * src/pcm.c src/sfendian.h + Re-coded PCM encoders and decoders to match or better the speed of + libsndfile version 0.0.28. + +2002-06-30 Erik de Castro Lopo + + * src/wav.c + Add checking for WAVPACK data in standard PCM WAV file. Return error if + found. This WAVPACK is *WAY* broken. It uses the same PCM WAV file header + and then stores non-PCM data. + + * tests/benchmark.tpl + Added more tests. + +2002-06-29 Erik de Castro Lopo + + * tests/benchmark.tpl + Added conditional definition of M_PI. + For Win32, set WRITE_PERMS to 0777. + + * Win32/Makefile.msvc + Added target to make generate program on Win32. + + * src/samplitude.c + Removed handler for Samplitude RAP file format. This file type seems rarer + than hens teeth and is completely undocumented. + + * src/common.h src/sndfile.c src/Makefile.am Win32/Makefile.msvc + Removed references to sampltiude RAP format. + + * tests/benchmark.tpl + Benchmark program now prints the libsndfile version number when run. This + program was also backported to version 0 to compare results. Version + 1.0.0rc2 is faster than version 0.0.28 on most conversions but slower on + some. The slow ones need to be fixed before final release. + +2002-06-28 Erik de Castro Lopo + + * tests/benchmark.def tests/benchmark.tpl + New files which generate tests/benchmark.c using Autogen. Added int -> + SF_FORMAT_PCM_24 test. + + * tests/benchmark.c + Now and Autogen output file. + + * tests/Makefile.am + Updated for above changes. + +2002-06-27 Erik de Castro Lopo + + * tests/benchmark.c + Basic benchmark program complete. Need to convert it to Autogen. + + * Win32/Makefile.msvc + Added benchmark.exe target. + +2002-06-26 Erik de Castro Lopo + + * examples/generate.c + New program to generate a number of different output file formats from a + single input file. This allows testing of the created files. + + * tests/benchmark.c + New test program to benchmark libsndfile. Nowhere near complete yet. + + * examples/Makefile.am tests/Makefile.am + New make rules for the two new programs. + +2002-06-25 Erik de Castro Lopo + + * Win32/libsndfile.def + Removed definition for sf_signal_max(). + + * src/sndfile.c + Removed cruft. + + * doc/index.html + A number of documentation bugs were fixed. Thanks to Anand Kumria. + + * doc/version-1.html + Minor doc updates. + + * configure.in + Bumped version to 1.0.0rc2. + + * src/sf_command.h src/Makefile.am + Removed the header file as it was no longer being used. Thanks to Anand + Kunria for spotting this. + + * doc/index.html + A number of documentation bugs were fixed. Thanks to Anand Kumria. + +2002-06-24 Erik de Castro Lopo + + * src/common.h + Test for Win32 before testing SIZEOF_OFF_T so that it works correctly + on Win32.. + + * src/file_io.c + Win32 fixes to ensure O_BINARY is used for file open. + + * doc/win32.html + New file documenting the building libsndfile on Win32. + + * doc/*.html + Updating of documentation. + +2002-06-23 Erik de Castro Lopo + + * tests/pcm_test.c + Minor changes to allow easier determination of test file name. + + * src/sndfile.[ch] + Removed function sf_signal_max(). + + * examples/sndfile-play.c + Changed call to sf_signal_max() to a call to sf_command(). + +2002-06-22 Erik de Castro Lopo + + * src/format.c src/command.c + Renamed format.c to command.c which will now include code for sf_command() + calls to perform operations other than format commands. + + * src/sndfile.c src/sndfile.h + Removed function sf_get_signal_max() which is replaced by commands passed + to sf_command(). + + * src/command.c + Implement commands SFC_CALC_SIGNAL_MAX. + + * doc/command.html + Documented SFC_CALC_SIGNAL_MAX. + +2002-06-21 Erik de Castro Lopo + + * examples/sndfile-play.c + Mods to make sndfile-play work on Solaris. The program sndfile-play now + runs on Linux, MaxOSX and Solaris. Win32 to come. + + * src/format.c + Added SF_FORMAT_DWVW_* to subtype_formats array. + + * src/nist.c + Added support for 8 bit NIST Sphere files. Example file supplied by Anand + Kumria. + +2002-06-20 Erik de Castro Lopo + + * examples/sndfile-info.c + Tidy up of output format. + + * examnples/sndfile-play.c + Mods to make sndfile-play work on MacOSX using Apple's CoreAudio API. + + * configure.in + Add new variables OS_SPECIFIC_INCLUDES and OS_SPECIFIC_LINKS which were + required to supply extra include paths and link parameters to get + sndfile-play working on MacOSX. + + * examples/Makefile.am + Use OS_SPOECIFIC_INCLUDES and OS_SPECIFIC_LINKS to build commands for + sndfile-play. + +2002-06-19 Erik de Castro Lopo + + * src/nist.c + Added ability to read/write new NIST Sphere file types (A-law, u-law). + Header parser was re-written from scratch. Example files supplied by Anand + Kumria. + + * src/sndfile.c + Support for A-law and u-law NIST files. + + * tests/Makefile.am tests/lossy_comp_test.c + Tests for A-law and u-law NIST files. + +2002-06-18 Erik de Castro Lopo + + * tests/utils.c + Fixed an error in error string. + +2002-06-17 Erik de Castro Lopo + + * acinclude.m4 + Removed exit command to allow cross-compiling. + + * Win32/unistd.h src/file_io.c + Moved contents of first file into the second file (enclosed in #ifdef). + Win32/unistd.h is now an empty file but still must be there for libsndfile + to compile on Win32. + + * src/sd2.c, src/sndfile.c: + Fixes for Sound Designer II files on big endian systems. + +2002-06-16 Erik de Castro Lopo + + * configure.in + Modified to work around problems with crappy MacOSX version of sed. + Added sanity check for proper values for CFLAGS. + +2002-06-14 Erik de Castro Lopo + + * src/sndfile.c + Code clean up in sf_open (). + + * Win32/Makefile.msvc + Michael Fink's contributed MSVC++ makefile was hacked to bits and put back + together in a new improved form. + + * src/file_io.c + Fixes for Win32; _lseeki64() returns an invalid argument for calls like + _lseeki64(fd, 0, SEEK_CUR) so need to use _telli64 (fd) instead. + + * src/common.h src/sndfile.c src/wav.c src/aiff.c + Added SFE_LOG_OVERRUN error. + Added termination for potential infinite loop when parsing file headers. + + * src/wav.c src/w64.c + Fixed bug casuing incorrect header generation when opening file read/write. + +2002-06-12 Erik de Castro Lopo + + * doc/api.html + Improved the documentation to make it clearer that the file read method + and the underlying file format are completely disconnected. Suggested + by Josh Green. + + * doc/command.html + Started correcting docs to take into account changes made to the + operations of the sf_command () function. Not complete yet. + + * src/sndfile.c + Reverted some changes which had broken the partially working SDII header + parsing. Now have access to an iBook with OS X so reading and writing SDII + files on all platforms should be a reality in the near future. On Mac this + will involve reading the resource fork via the standard MacOS API. To move + a file from Mac to another OS, the resource and data forks will need to be + combined before transfer. The combined file will be read on both Mac and + other OSes like any other file. + +2002-06-08 Erik de Castro Lopo + + * ltmain.sh + Applied a patch from http://fink.sourceforge.net/doc/porting/libtool.php + which allows libsndfile to compile on MacOSX 10.1. This patch should not + interfere with compiling on other OSes. + + * src/GSM610/private.h + Changes to fix compile problems on MacOSX (see src/GSM610/ChangeLog). + + * src/float_cast.h + Added MacOSX replacements for lrint() and lrintf(). + +2002-06-05 Erik de Castro Lopo + + * src/sndfile.c + Replaced the code to print the filename to the log buffer when a file is + opened. This code seems to have been left out during the merge of + sf_open_read() and sf_open_write() to make a single functions sf_open(). + +2002-06-01 Erik de Castro Lopo + + * src/wav.c + Fixed a bug where the WAV header parser was going into an infinite loop + on a badly formed LIST chunk. File supplied by David Viens. + +2002-05-25 Erik de Castro Lopo + + * configure.in + Added a message at the end of the configuration process to warn about the + need for the use of pkg-config when linking programs against version 1 of + libsndfile. + + * doc/pkg-config.html + New documentation file containing details of how to use pkg-config to + retrieve settings for CFLAGS and library locations for linking files + against version 1 of libsndfile. + +2002-05-17 Erik de Castro Lopo + + * src/wav.c + Fixed minor bug in handling of so-called ACIDized WAV files. + +2002-05-16 Erik de Castro Lopo + + * Win32/libsndfile.def Win32/Makefile.msvc + Two new files contributed by Michael Fink (from the winLAME project) + which allows libsndfile to be built on windows in a MSDOS box by doing + "nmake -f Makefile.msvc". Way cool! + +2002-05-15 Erik de Castro Lopo + + * configure.in + MacOSX is SSSOOOOOOO screwed up!!! I can't believe how hard it is to + generate a tarball which will configure and compile on that platform. + Joined the libtool mailing list to try and get some answers. + +2002-05-13 Erik de Castro Lopo + + * configure.in + Changed to autoconf version 2.50. MacOSX uses autoconf version 2.53 which + is incompatible with with version 2.13 which had been using until now. + The AC_SYS_LARGE_FILE macro distributed withe autoconf 2.50 is missing a + few features so AC_SYS_EXTRA_LARGE file was defined to replace it. + + * configure.in + Changed to automake version 1.5 to try and make a tarball which will + work on MacOSX. + +2002-05-12 Erik de Castro Lopo + + * src/wav_gsm610.c + Changed name to gsm610.c. Added reading/writing of headerless files. + + * src/sndfile.c src/raw.c + Added ability to read/write headerless (SF_FORMAT_RAW) GSM 6.10 files. + +2002-05-11 Erik de Castro Lopo + + * tests/lossy_comp_test.c + Clean up in preparation for Autogen-ing this file. + + * src/GSM610/*.[ch] + Code cleanup and prepartion forgetting file seek working. Details in + src/GSM610/ChangeLog. + + * sndfile.pc.in + Testing complete. Is sndfile.m4 still needed? + +2002-05-09 Erik de Castro Lopo + + * tests/write_read_test.tpl tests/rdwr_test.tpl + Merged tests from these two programs into write_read_test.tpl and deleted + rdwr_test.tpl. + +2002-05-08 Erik de Castro Lopo + + * src/w64.c src/svx.c src/paf.c + Fixed bugs in read/write mode. + +2002-05-07 Erik de Castro Lopo + + * examples/Makefile.am + Renamed sfplay.c to sndfile-play.c and sndfile_info.c to sndfile-info.c for + consistency when these programs become part of the Debian package + sndfile-programs. + + * sndfile.pc.in + New file to replace sndfile-config.in. Libsndfile now uses the pkg-config + model for providing installation parameters to dependant programs. + + * src/sndfile.c + Cleanup of code in sf_open(). + +2002-05-06 Erik de Castro Lopo + + * tests/utils.tpl tests/write_read_test.tpl + More conversion to Autogen fixes and enchancements. + + * src/*.c + Read/write mode is now working for 16, 24 and 32 bit PCM as well as 32 + bit float and 64 bit double data. More tests still required. + + * src/Makefile.am + Added DISTCLEANFILES target to remove config.status and config.last. + + * Win32/Makefile.am MacOS/Makefile.am + Added DISTCLEANFILES target to remove Makefile. + +2002-05-05 Erik de Castro Lopo + + * src/*.[ch] tests/rdwr_test.c + More verifying workings of read/write mode. Fixing bugs found. + + * tests/utils.[ch] + Made these files Autogen generated files. + + * tests/util.tpl tests/util.def + New Autogen files to generate utils.[ch]. Moved some generic test functions + into this file. Autogen is such a great tool! + +2002-05-03 Erik de Castro Lopo + + * src/pcm.c src/float_cast.h Win32/config.h + Fixed a couple of Win32 specific bugs pointed out by Michael Fink + (maintainer of WinLAME) and David Viens. + + * tests/check_log_buffer.[ch] tests/utils.[ch] + Moved check_log_buffer() to utils.[ch] and deleted old file. + +2002-05-02 Erik de Castro Lopo + + * src/common.[ch] src/sndfile.c + New function psf_default_seek() which will be the default seek function + for things like PCM and floating point data. This default is set for + both read and write in sf_open() but can be over-ridden by any codec + during it's initialisation. + +2002-05-01 Erik de Castro Lopo + + * src/au.c + AU files use a data size value of -1 to mean unknown. Fixed au_open_read() + to allow opening files like this. + + * tests/rdwr_test .c + Added more tests. + + * src/sndfile.c + Fixed bugs in read/write mode found due to improvements in the test + program. + +2002-04-30 Erik de Castro Lopo + + * tests/rdwr_test .c + New file for testing read/write mode. + +2002-04-29 Erik de Castro Lopo + + * m4/* + Removed all m4 macros from this directory as they get concatenated to form + the file aclocal.m4 anyway. + + * sndfile.m4 + Moved this from the m4 directory to the root directory asn this is part of + the distribution and is installed during "make install". + +2002-04-29 Erik de Castro Lopo + + * src/float32.c + Removed logging of peaks for all file formats other than AIFF and WAV. + + * tests/write_read_test.tpl tests/write_read_test.def + New files which autogen uses to generate write_read_test.c. Doing it this + way makes write_read_test.c far easier to maintain. Other test programs + will be converted to autogen in the near future. + + * src/*.c + Fixed a few bugs found when testing on Sparc (bug endian) Solaris. + +2002-04-28 Erik de Castro Lopo + + * doc/*.html + Fixed documention versioning. + + * configure.in + Fixed a bug in the routines which search for Large File Support on systems + which have large file support by defualt. + +2002-04-27 Erik de Castro Lopo + + * src/*.[ch] + Found and fixed an issue which can cause a bug in other software (I was + porting Conrad Parker's Sweep program from version 0 of the library to + version 1). When opening a file for write, the libsndfile code would + set the sfinfo.samples field to a maximum value. + + * tests/write_read_test.c + Added tests to detect the above problem. + +2002-04-25 Erik de Castro Lopo + + * src/*.[ch] + Finished base implementation of read/write mode. Much more testing still + needed. + + * m4/largefile.m4 + Macro for detecting Large File Standard capabilities. This macro was ripped + out of the aclocal.m4 file of GNU tar-1.13. + + * configure.in + Added detection of large file support. Files larger than 2 Gigabytes should + now be supported on 64 bit platforms and many 32 bit platforms including + Linux (2.4 kernel, glibc-2.2), *BSD, MacOS, Win32. + + * libsndfile_convert_version.py + A Python script which attempts to autoconvert code written to use version 0 + to version 1. + +2002-04-24 Erik de Castro Lopo + + * src/*.[ch] + Finished base implementation of read/write mode. Much more testing still + needed. + + * tests/write_read_test.c + Preliminary tests for read/write mode added. More needed. + +2002-04-20 Erik de Castro Lopo + + * src/sndfile.[ch] + Removed sf_open_read() and sf_open_write() functions,replacting them with + sf_open() which takes an extra mode parameter (SF_OPEN_READ, SF_OPEN_WRITE, + or SF_OPEN_RDWR). This new function sf_open can now be modified to allow + opening a file formodification (RDWR). + +2002-04-19 Erik de Castro Lopo + + * src/*.c + Completed merging of separate xxx_open_read() and xxx_open_write() + functions. All tests pass. + +2002-04-18 Erik de Castro Lopo + + * src/au.c + Massive refactoring required to merge au_open_read() with au_open_write() + to create au_open(). + +2002-04-17 Erik de Castro Lopo + + * src/*.c + Started changes required to allow a sound file to be opened in read/write + mode, with separate file pointers for read and write. This involves merging + of encoder/decoder functions like pcm_read_init() and pcm_write_init() + int a new function pcm_init() as well as doing something similar for all + the file type specific functions ie aiff_open_read() and aiff_open_write() + were merged to make the function aiff_open(). + +2002-04-15 Erik de Castro Lopo + + * src/file_io.c + New file containing psf_fopen(), psf_fread(), psf_fwrite(), psf_fseek() and + psf_ftell() functions. These function will replace use of fopen/fread/fwrite + etc and allow access to files larger than 2 gigabytes on a number of 32 bit + OSes (Linux on x86, 32 bit Solaris user space apps, Win32 and MacOS). + + * src/*.c + Replaced all instances of fopen with psf_open, fread with psd_read, fwrite + with psf_write and so on. + +2002-03-11 Erik de Castro Lopo + + * src/dwvw.c + Finally fixed all known problems with 12, 16 and 24 bit DWVW encoding. + + * tests/floating_point_test.c + Added tests for 12, 16 and 24 bit DWVW encoding. + +2002-03-03 Erik de Castro Lopo + + * m4/endian.m4 + Defines a new m4 macro AC_C_FIND_ENDIAN, for determining the endian-ness of + the target CPU. It first checks for the definition of BYTE_ORDER in + , then in and . If none of these work + and the C compiler is not a cross compiler it compiles and runs a program + to test for endian-ness. If the compiler is a cross compiler it makes a + guess based on $target_cpu. + + * configure.in + Modified to use AC_C_FIND_ENDIAN. + + * src/sfendian.h + Simplified. + +2002-02-23 Erik de Castro Lopo + + * tests/floating_point_test.c + Tests completely rewritten using the dft_cmp function. Now able to + calculate a quick guesstimate of the Signal to Noise Ratio of the encoder. + +2002-02-15 Erik de Castro Lopo + + * tests/dft_cmp.[ch] + New files containing functions for comparing pre and post lossily + compressed data using a quickly hacked DFT. + + * tests/utils.[ch] + New files containing functions for saving pre and post encoded data in a + file readable by the GNU Octave package. + +2002-02-13 Erik de Castro Lopo + + * m4/lrint.m4 m4/lrintf.m4 + Fixed m4 macros to define HAVE_LRINT and HAVE_LRINTF even when the test + is cached. + +2002-02-12 Erik de Castro Lopo + + * tests/floating_point_test.c + Fixed improper use of strncat (). + +2002-02-11 Erik de Castro Lopo + + * tests/headerless_test.c + New test program to test the ability to open and read a known file type as a + RAW header-less file. + +2002-02-07 Erik de Castro Lopo + + * tests/losy_comp_test.c + Added a test to ensure that the data read from a file is not all zeros. + + * examples/sfconvert.c + Added "-gsm610" encoding types. + +2002-01-29 Erik de Castro Lopo + + * examples/sfconvert.c + Added "-dwvw12", "-dwvw16" and "-dwvw24" encoding types. + + * tests/dwvw_test.c + New file for testing DWVW encoder/decoder. + +2002-01-28 Erik de Castro Lopo + + * src/dwvw.c + Implemented writing of DWVW. 12 bit seems to work, 16 and 24 bit still broken. + + * src/aiff.c + Improved reporting of encoding types. + + * src/voc.c + Clean up. + +2002-01-27 Erik de Castro Lopo + + * src/dwvw.c + New file implementing lossless Delta Word Variable Width (DWVW) encoding. + Reading 12 bit DWVW is now working. + + * src/aiff.c common.h sndfile.c + Added hooks for DWVW encoded AIFF and RAW files. + +2002-01-15 Erik de Castro Lopo + + * src/w64.c + Robustify header parsing. + + * src/wav_w64.h + Header file wav.h was renamed to wav_w64.h to signify sharing of + definitions across the two file types. + + * src/wav.c src/w64.c src/wav_w64.c + Refactoring. + Modified and moved functions with a high degree of similarity between + wav.c and w64.c to wav_w64.c. + +2002-01-14 Erik de Castro Lopo + + * src/w64.c + Completed work on getting read and write working. + + * examples/sfplay.c + Added code to scale floating point data so it plays at a reasonable volume. + + * tests/Makefile.am tests/write_read_test.c + Added tests for W64 files. + +2002-01-13 Erik de Castro Lopo + + * src/*.c + Modded all code in file header writing routines to use + psf_new_binheader_writef(). + Removed psf_binheader_writef() from src/common.c. + Globally replaced psf_new_binheader_writef with psf_binheader_writef. + +2002-01-12 Erik de Castro Lopo + + * src/*.c + Modded all code in file parsing routines to use psf_new_binheader_readf(). + Removed psf_binheader_readf() from src/common.c. + Globally replaced psf_new_binheader_readf with psf_binheader_readf. + + * src/common.[ch] + Added new function psf_new_binheader_writef () which will soon replace + psf_binheader_writef (). The new function has basically the same function + as the original but has a more flexible and capable interface. It also + allows the writing of 64 bit integer values for files contains 64 bit file + offsets. + +2002-01-11 Erik de Castro Lopo + + * src/formats.c src/sndfile.c src/sndfile.h + Added code allowing full enumeration of supported file formats via the + sf_command () interface. + This feature will allow applications to avoid needing recompilation when + support for new file formats are added to libsndfile. + + * tests/command_test.c + Added test code for the above feature. + + * examples/list_formats.c + New file. An example of the use of the supported file enumeration + interface. This program lists all the major formats and for each major + format the supported subformats. + +2002-01-10 Erik de Castro Lopo + + * src/*.[ch] tests/*.c + Changed command parameter of sf_command () function from a test string to + an int. The valid values for the command parameter begin with SFC_ and are + listed in src/sndfile.h. + +2001-12-20 Erik de Castro Lopo + + * src/formats.c src/sndfile.c + Added an way of enumerating a set of common file formats using the + sf_command () interface. This interface was suggested by Dominic Mazzoni, + one of the main authors of Audacity (http://audacity.sourceforge.net/). + +2001-12-26 Erik de Castro Lopo + + * src/sndfile.c + Added checking of filename parameter in sf_open_read (). Previousy, if a + NULL pointer was passed the library would segfault. + +2001-12-18 Erik de Castro Lopo + + * src/common.c src/common.h + Changed the len parameter of the endswap_*_array () functions from type + int to type long. + + * src/pcm.c + Fixed a problem which + +2001-12-15 Erik de Castro Lopo + + * src/sndfile.c + Added conditional #include for EMX/gcc on OS/2. Thanks to + Paul Hartman for pointing this out. + + * tests/lossy_comp_test.c tests/floating_point_test.c + Added definitions for M_PI for when it isn't defined in . + +2001-11-30 Erik de Castro Lopo + + * src/ircam.c + Re-implemented the header reader. Old version was making incorrect + assumptions about the endian-ness of the file from the magic number at the + start of the file. The new code looks at the integer which holds the + number of channels and determines the endian-ness from that. + +2001-11-30 Erik de Castro Lopo + + * src/aiff.c + Added support for other AIFC types ('raw ', 'in32', '23ni'). + Further work on IMA ADPCM encoding. + +2001-11-29 Erik de Castro Lopo + + * src/ima_adpcm.c + Renamed from wav_ima_adpcm.c. This file will soon handle IMA ADPCM + encodings for both WAV and AIFF files. + + * src/aiff.c + Started adding IMA ADPCM support. + +2001-11-28 Erik de Castro Lopo + + * src/double.c + New file for handling double precision floating point (SF_FORMAT_DOUBLE) + data. + + * src/wav.c src/aiff.c src/au.c src/raw.c + Added support for SF_FORMAT_DOUBLE data. + + * src/common.[ch] + Addition of endswap_long_array () for endian swapping 64 bit integers. This + function will work correctly on processors with 32 bit and 64 bit longs. + Optimised endswap_short_array () and endswap_int_array (). + + * tests/pcm_test.c + Added and extra check. After the first file of each type is written to disk + a checksum is performed of the first 64 bytes and checked against a pre- + calculated value. This will work whatever the endian-ness of the host + machine. + +2001-11-27 Erik de Castro Lopo + + * src/aiff.c + Added handling of u-law, A-law encoded AIFF files. Thanks to Tom Erbe for + supplying example files. + + * tests/lossy_comp_test.c + Added tests for above. + + * src/common.h src/*.c + Removed function typedefs from common.h and function pointer casting in all + the other files. This allows the compiler to perform proper type checking. + Hopefully this will prevernt problems like the sf_seek bug for OpenBSD, + BeOS etc. + + * src/common.[ch] + Added new function psf_new_binheader_readf () which will eventually replace + psf_binheader_readf (). The new function has basically the same function as + the original but has a more flexible and capable interface. It also allows + the reading of 64 bit integer values for files contains 64 bit file + offsets. + +2001-11-26 Erik de Castro Lopo + + * src/voc.c + Completed implementation of VOC file handling. Can now handle 8 and 16 bit + PCM, u-law and A-law files with one or two channels. + + * src/write_read_test.c tests/lossy_comp_test.c + Added tests for VOC files. + +2001-11-22 Erik de Castro Lopo + + * src/float_cast.h + Added inline asm version of lrint/lrintf for MacOS. Solution provided by + Stephane Letz. + + * src/voc.c + More work on this braindamaged format. The VOC files produced by SoX also + have a number of inconsistencies. + +2001-11-19 Erik de Castro Lopo + + * src/paf.c + Added support for 8 bit PCM PAF files. + + * tests/write_read_test.c + Added tests for 8 bit PAF files. + +2001-11-18 Erik de Castro Lopo + + * tests/pcm_test.c + New test program to test for correct scaling of integer values between + different sized integer containers (ie short -> int). + The new specs for libsndfile state that when the source and destination + containers are of a different size, the most significant bit of the source + value becomes the most significant bit of the destination container. + + * src/pcm.c src/paf.c + Modified to pass the above test program. + + * tests/write_read_test.c tests/lossy_comp_test.c + Modified to work with the new scaling rules. + +2001-11-17 Erik de Castro Lopo + + * src/raw.c tests/write_read_test.c tests/write_read_test.c + Added ability to do raw reads/writes of float, u-law and A-law files. + + * src/*.[ch] examples/*.[ch] tests/*.[ch] + Removed dependance on pcmbitwidth field of SF_INFO struct and moved to new + SF_FORMAT_* types and use of SF_ENDIAN_BIG/LITTLE/CPU. + +2001-11-12 Erik de Castro Lopo + + * src/*.[ch] + Started implmentation of major changes documented in doc/version1.html. + + Removed all usage of off_t which is not part of the ISO C standard. All + places which were using it are now using type long which is the type of + the offset parameter for the fseek function. + This should fix problems on BeOS, MacOS and *BSD like systems which were + failing "make check" because sizeof (long) != sizeof (off_t). + +-------------------------------------------------------------------------------- +This is the boundary between version 1 of the library above and version 0 below. +-------------------------------------------------------------------------------- + +2001-11-11 Erik de Castro Lopo + + * examples/sfplay_beos.cpp + Added BeOS version of sfplay.c. This needs to be compiled using a C++ + compiler so is therefore not built by default. Thanks to Marcus Overhagen + for providing this. + +2001-11-10 Erik de Castro Lopo + + * examples/sfplay.c + New example file showing how libsndfile can be used to read and play a + sound file. + At the moment on Linux is supported. Others will follow in the near future. + +2001-11-09 Erik de Castro Lopo + + * src/pcm.c + Fixed problem with normalisation code where a value of 1.0 could map to + a value greater than MAX_SHORT or MAX_INT. Thanks to Roger Dannenberg for + pointing this out. + +2001-11-08 Erik de Castro Lopo + + * src/pcm.c + Fixed scaling issue when reading/writing 8 bit files using + sf_read/sf_write_short (). + On read, values are scaled so that the most significant bit in the char + ends up in the most significant bit of the short. On write, values are + scaled so that most significant bit in the short ends up as the most + significant bit in the char. + +2001-11-07 Erik de Castro Lopo + + * src/au.c src/sndfile.c + Added support for 32 bit float data in big and little endian AU files. + + * tests/write_read_test.c + Added tests for 32 bit float data in AU files. + +2001-11-06 Erik de Castro Lopo + + * tests/lossy_comp_test.c + Finalised testing of stereo files where possible. + +2001-11-05 Erik de Castro Lopo + + * src/wav_ms_adpcm.c + Fixed bug in writing stereo MS ADPCM WAV files. Thanks to Xu Xin for + pointing out this problem. + +2001-10-24 Erik de Castro Lopo + + * src/wav_ms_adpcm.c + Modified function srate2blocksize () to handle 44k1Hz stereo files. + +2001-10-21 Erik de Castro Lopo + + * src/w64.c + Added support for Sonic Foundry 64 bit WAV format. As Linux (my main + development platform) does not yet support 64 bit file offsets by default, + current handling of this file format treats everything as 32 bit and fails + openning the file, if it finds anything that goes beyond 32 bit values. + + * src/sndfile.[hc] src/common.h src/Makefile.am + Added hooks for W64 support. + +2001-10-21 Erik de Castro Lopo + + * configure.in + Added more warnings options to CFLAGS when the gcc compiler is detected. + + * src/*.[ch] tests/*.c examples/*.c + Started fixing the warning messages due to the new CFLASG. + + * src/voc.c + More work on VOC file read/writing. + + * src/paf.c + Found that PAF files were not checking the normalisation flag when reading + or writing floats and doubles. Fixed it. + + * tests/floating_point_test.c + Added specific test for the above problem. + + * src/float_cast.h src/pcm.c + Added a section for Win32 to define lrint () and lrintf () in the header + and implement it in the pcm.c + +2001-10-20 Erik de Castro Lopo + + * sndfile-config.in m4/sndfile.m4 + These files were donated by Conrad Parker who also provided instructions + on how to install them using autoconf/automake. + + * src/float_cast.h + Fiddled around with this file some more. On Linux and other gcc supported + OSes use the C99 functions lrintf() and lrint() for casting from floating + point to int without incurring the huge perfromance penalty (particularly + on the i386 family) caused by the regular C cast from float to int. + These new C99 functions replace the FLOAT_TO_* and DOUBLE_TO_* macros which + I had been playing with. + + * configure.in m4/lrint.m4 m4/lrintf.m4 + Add detection of these functions. + +2001-10-17 Erik de Castro Lopo + + * src/voc.c + Completed code for reading VOC files containing a single audio data + segment. + Started implementing code to handle files with multiple VOC_SOUND_DATA + segments but couldn't be bothered finishing it. Multiple segment files can + have different sample rates for different sections and other nasties like + silence and repeat segments. + +2001-10-16 Erik de Castro Lopo + + * src/common.h src/*.c + Removed SF_PRIVATE struct field fdata and replaced it with extra_data. + + * src/voc.c + Further development of the read part of this woefult file format. + +2001-10-04 Erik de Castro Lopo + + * src/float_cast.h + Implemented gcc and i386 floating point to int cast macros. Standard cast + will be used when not on gcc for i385. + + * src/pcm.c + Modified all uses of FLOAT/DOUBLE_TO_INT and FLOAT/DOUBLE_TO_SHORT casts to + comply with macros in float_cast.h. + +2001-10-04 Erik de Castro Lopo + + * src/voc.c + Changed the TYPE_xxx enum names to VOC_TYPE_xxx to prevent name clashes + on MacOS with CodeWarrior 6.0. + + * MacOS/MacOS-readme.txt + Updated the compile instructions. Probably still need work as I don't have + access to a Mac. + +2001-10-01 Erik de Castro Lopo + + * src/wav.c src/aiff.c common.c + Changed all references to snprintf to LSF_SNPRINTF and all vsnprintf to + LSF_VSNPRINTF. LSF_VSNPRINTF and LSF_VSNPRINTF are defined in common.h. + + * src/common.h + Added checking of HAVE_SNPRINTF and HAVE_VSNPRINTF and defining + LSF_VSNPRINTF and LSF_VSNPRINTF to appropriate values. + + * src/missing.c + New file containing a minimal implementation of snprintf and vsnprintf + functions named missing_snprintf and missing_vsnprintf respectively. These + are only compliled into the binary if snprintf and/or vsnprintf are not + available. + +2001-09-29 Erik de Castro Lopo + + * src/ircam.c + New file to handle Berkeley/IRCAM/CARL files. + + * src/sndfile.c src/common.h + Modified for IRCAM handling. + + * tests/*.c + Added tests for IRCAM files. + +2001-09-27 Erik de Castro Lopo + + * src/wav.c + Apparently microsoft windows (tm) doesn't like ulaw and Alaw WAV files with + 20 byte format chunks (contrary to ms's own documentation). Fixed the WAV + header writing code to generate smaller ms compliant ulaw and Alaw WAV + files. + +2001-09-17 Erik de Castro Lopo + + * tests/stdio_test.sh tests/stdio_test.c + Shell script was rewritten as a C program due to incompatibilities of the + sh shell on Linux and Solaris. + +2001-09-16 Erik de Castro Lopo + + * tests/stdio_test.sh tests/stdout_test.c tests/stdin_test.c + New test programs to verify the correct operation of reading from stdin and + writing to stdout. + + * src/sndfile.c wav.c au.c nist.c paf.c + Fixed a bugs uncovered by the new test programs above. + +2001-09-15 Erik de Castro Lopo + + * src/sndfile.c wav.c + Fixed a bug preventing reading a file from stdin. Found by T. Narita. + +2001-09-12 Erik de Castro Lopo + + * src/common.h + Fixed a problem on OpenBSD 2.9 which was causing sf_seek() to fail on IMA + WAV files. Root cause was the declaration of the func_seek typedef not + matching the functions it was actually being used to point to. In OpenBSD + sizeof (off_t) != sizeof (int). Thanks to Heikki Korpela for allowing me + to log into his OpenBSD machine to debug this problem. + +2001-09-03 Erik de Castro Lopo + + * src/sndfile.c + Implemented sf_command ("norm float"). + + * src/*.c + Implemented handling of sf_command ("set-norm-float"). Float normalization + can now be turned on and off. + + * tests/double_test.c + Renamed to floating_point_test.c. Modified to include tests for all scaled + reads and writes of floats and doubles. + + * src/au_g72x.c + Fixed bug in normalization code found with improved floating_point_test + program. + + * src/wav.c + Added code for parsing 'INFO' and 'LIST' chunks. Will be used for extract + text annotations from WAV files. + + * src/aiff.c + Added code for parsing '(c) ' and 'ANNO' chunks. Will be used for extract + text annotations from WAV files. + +2001-09-02 Erik de Castro Lopo + + * examples/sf_info.c example/Makefile.am + Renamed to sndfile_info.c. The program sndfile_info will now be installed + when the library is installed. + + * src/float_cast.h + New file defining floating point to short and int casts. These casts will + eventually replace all flot and double casts to short and int. See comments + at the top of the file for the reasoning. + + * src/*.c + Changed all default float and double casts to short or int with macros + defined in floatcast.h. At the moment these casts do nothing. They will be + replaced with faster float to int cast operations in the near future. + +2001-08-31 Erik de Castro Lopo + + * tests/command_test.c + New file for testing sf_command () functionality. + + * src/sndfile.c + Revisiting of error return values of some functions. + Started implementing sf_command () a new function will allow on-the-fly + modification of library behaviour, or instance, sample value scaling. + + * src/common.h + Added hook for format specific sf_command () calls to SNDFILE struct. + + * doc/api.html + Updated and errors corrected. + + * doc/command.html + New documentation file explaining new sf_command () function. + +2001-08-11 Erik de Castro Lopo + + * src/sndfile.c + Fixed error return values from sf_read*() and sf_write*(). There were + numerous instances of -1 being returned through size_t. These now all set + error int the SF_PRIVATE struct and return 0. Thanks to David Viens for + spotting this. + +2001-08-01 Erik de Castro Lopo + + * src/common.c + Fixed use of va_arg() calls that were causing warning messages with the + latest version of gcc (thanks Maurizio Umberto Puxeddu). + +2001-07-25 Erik de Castro Lopo + + * src/*.c src/sfendian.h + Moved definition of MAKE_MARKER macro to sfendian.h + +2001-07-23 Erik de Castro Lopo + + * src/sndfile.c + Modified sf_get_lib_version () so that version string will be visible using + the Unix strings command. + + * examples/Makefile.am examples/sfinfo.c + Renamed sfinfo program and source code to sf_info. This prevents a name + clash with the program included with libaudiofile. + +2001-07-22 Erik de Castro Lopo + + * tests/read_seek_test.c tests/lossy_comp_test.c + Added tests for sf_read_float () and sf_readf_float (). + + * src/voc.c + New files for handling Creative Voice files (not complete). + + * src/samplitude.c + New files for handling Samplitude files (not complete). + +2001-07-21 Erik de Castro Lopo + + * src/aiff.c src/au.c src/paf.c src/svx.c src/wav.c + Converted these files to using psf_binheader_readf() function. Will soon be + ready to attempt to make reading writing from pipes work reliably. + + * src/*.[ch] + Added code for sf_read_float () and sf_readf_float () methods of accessing + file data. + +2001-07-20 Erik de Castro Lopo + + * src/paf.c src/wav_gsm610.c + Removed two printf()s which had escaped notice for some time (thanks + Sigbjørn Skjæret). + +2001-07-19 Erik de Castro Lopo + + * src/wav_gsm610.c + Fixed a bug which prevented GSM 6.10 encoded WAV files generated by + libsndfile from being played in Windoze (thanks klay). + +2001-07-18 Erik de Castro Lopo + + * src/common.[ch] + Implemented psf_binheader_readf() which will do for file header reading what + psf_binheader_writef() did for writing headers. Will eventually allow + libsndfile to read and write from pipes, including named pipes. + +2001-07-16 Erik de Castro Lopo + + * MacOS/config.h Win32/config.h + Attempted to bring these two files uptodate with src/config.h. As I don't + have access to either of these systems support for them may be completely + broken. + +2001-06-18 Erik de Castro Lopo + + * src/float32.c + Fixed bug for big endian processors that can't read 32 bit IEEE floats. Now + tested on Intel x86 and UltraSparc processors. + +2001-06-13 Erik de Castro Lopo + + * src/aiff.c + Modified to allow REX files (from Propellorhead's Recycle and Reason + programs) to be read. + REX files are basically an AIFF file with slightly unusual sequence of + chunks (AIFF files are supposed to allow any sequence) and some extra + application specific information. + Not yet able to write a REX file as the details of the application specific + data is unknown. + +2001-06-12 Erik de Castro Lopo + + * src/wav.c + Fixed endian bug when reading PEAK chunk on big endian machines. + + * src/common.c + Fixed endian bug when reading PEAK chunk on big endian machines with + --enable-force-broken-float configure option. + Fix psf_binheader_writef for (FORCE_BROKEN_FLOAT ||______) + +2001-06-07 Erik de Castro Lopo + + * configure.in src/config.h.in + Removed old CAN_READ_WRITE_x86_IEEE configure variable now that float + capabilities are detected at run time. + Added FORCE_BROKEN_FLOAT to allow testing of broken float code on machines + where the processor can in fact handle floats correctly. + + * src/float32.c + Rejigged code reading and writing of floats on broken processors. + + * m4/ + Removed this directory and all its files as they are no longer needed. + +2001-06-05 Erik de Castro Lopo + + * tests/peak_chunk_test.c + New test to validate reading and writing of peak chunk. + + * examples/sfconvert + Added -float32 option. + + * src/*.c + Changed all error return values to negative values (ie the negative of what + they were). + + * src/sndfile.c tests/error_test.c + Modified to take account of the previous change. + +2001-06-04 Erik de Castro Lopo + + * src/float32.c + File renamed from wav_float.c and renamed function to something more + general. + Added runtime detection of floating point capabilities. + Added recording of peaks during write for generation of PEAK chunk. + + * src/wav.c src/aiff.c + Added handing for PEAK chunk for floating point files. PEAK is read when the + file headers are read and generated when the file is closed. Logic is in + place for adding PEAK chunk to end of file when writing to a pipe (reading + and writing from/to pipe to be implemented soon). + + * src/sndfile.c + Modified sf_signal_max () to use PEAK values if present. + +2001-06-03 Erik de Castro Lopo + + * src/*.c + Added pcm_read_init () and pcm_write_init () to src/pcm.c and removed all + other calls to functions in this file from the filetype specific files. + + * src/*.c + Added alaw_read_init (), alaw_write_int (), ulaw_read_init () and + ulaw_write_init () and removed all other calls to functions in alaw.c and + ulaw.c from the filetype specific files. + + * tests/write_read_test.c + Added tests to validate sf_seek () on all file types. + + * src/raw.c + Implemented raw_seek () function to fix a bug where + sf_seek (file, 0, SEEK_SET) on a RAW file failed. + + * src/paf.c + Fixed a bug in paf24_seek () found due to added seeks tests in + tests/write_read_test.c + +2001-06-01 Erik de Castro Lopo + + * tests/read_seek_test.c + Fixed a couple of broken binary files. + + * src/aiff.c src/wav.c + Added handling of PEAK chunks on file read. + +2001-05-31 Erik de Castro Lopo + + * check_libsndfile.py + New file for the regression testing of libsndfile. + check_libsndfile.py is a Python script which reads in a file containing + filenames of audio files. Each file is checked by running the examples/sfinfo + program on them and checking for error or warning messages in the libsndfile + log buffer. + + * check_libsndfile.list + This is an example list of audio files for use with check_libsndfile.py + + * tests/lossy_comp_test.c + Changed the defined value of M_PI for math header files which don't have it. + This fixed validation test failures on MetroWerks compilers. Thanks to Lord + Praetor Satanus of Acheron for bringing this to my attention. + +2001-05-30 Erik de Castro Lopo + + * src/common.[ch] + Removed psf_header_setf () which was no longer required after refactoring + and simplification of header writing. + Added 'z' format specifier to psf_binheader_writef () for zero filling header + with N bytes. Used by paf.c and nist.c + + * tests/check_log_buffer.c + New file implementing check_log_buffer () which reads the log buffer of a + SNDFILE* object and searches for error and warning messages. Calls exit () + if any are found. + + * tests/*.c + Added calls to check_log_buffer () after each call to sf_open_XXX (). + +2001-05-29 Erik de Castro Lopo + + * src/wav.c src/wav_ms_adpcm.c src/wav_gsm610.c + Major rehack of header writing using psf_binheader_writef (). + +2001-05-28 Erik de Castro Lopo + + * src/wav.c src/wav_ima_adpcm.c + Major rehack of header writing using psf_binheader_writef (). + +2001-05-27 Erik de Castro Lopo + + * src/wav.c + Changed return type of get_encoding_str () to prevent compiler warnings on + Mac OSX. + + * src/aiff.c src/au.c + Major rehack of header writing using psf_binheader_writef (). + +2001-05-25 Erik de Castro Lopo + + * src/common.h src/common.c + Added comments. + Name of log buffer changed from strbuffer to logbuffer. + Name of log buffer index variable changed from strindex to logindex. + + * src/*.[ch] + Changed name of internal logging function from psf_sprintf () to + psf_log_printf (). + Changed name of internal header generation functions from + psf_[ab]h_printf () to psf_asciiheader_printf () and + psf_binheader_writef (). + Changed name of internal header manipulation function psf_hsetf () to + psf_header_setf (). + +2001-05-24 Erik de Castro Lopo + + * src/nist.c + Fixed reading and writing of sample_byte_format header. "01" means little + endian and "10" means big endian regardless of bit width. + + * configure.in + Detect Mac OSX and disable -Wall and -pedantic gcc options. Mac OSX is + way screwed up and spews out buckets of warning messages from the system + headers. + Added --disable-gcc-opt configure option (sets gcc optimisation to -O0 ) for + easier debugging. + Made decision to harmonise source code version number and .so library + version number. Future releases will stick to this rule. + + * doc/new_file_type.HOWTO + New file to document the addition of new file types to libsndfile. + +2001-05-23 Erik de Castro Lopo + + * src/nist.c + New file for reading/writing Sphere NIST audio file format. + Originally requested by Elis Pomales in 1999. + Retrieved from unstable (and untouched for 18 months) branch of libsndfile. + Some vital information gleaned from the source code to Bill Schottstaedt's + sndlib library : ftp://ccrma-ftp.stanford.edu/pub/Lisp/sndlib.tar.gz + Currently reading and writing 16, 24 and 32 bit, big-endian and little + endian, stereo and mono files. + + * src/common.h src/common.c + Added psf_ah_printf () function to help construction of ASCII headers (ie NIST). + + * configure.in + Added test for vsnprintf () required by psf_ah_printf (). + + * tests/write_read_test.c + Added tests for supported NIST files. + +2001-05-22 Erik de Castro Lopo + + * tests/write_read_test.c + Added tests for little endian AIFC files. + + * src/aiff.c + Minor re-working of aiff_open_write (). + Added write support for little endian PCM encoded AIFC files. + +2001-05-13 Erik de Castro Lopo + + * src/aiff.c + Minor re-working of aiff_open_read (). + Added read support for little endian PCM encoded AIFC files from the Mac + OSX CD ripper program. Guillaume Lessard provided a couple of sample files + and a working patch. + The patch was not used as is but gave a good guide as to what to do. + +2001-05-11 Erik de Castro Lopo + + * src/sndfile.h + Fixed comments about endian-ness of WAV and AIFF files. Guillaume Lessard + pointed out the error. + +2001-04-23 Erik de Castro Lopo + + * examples/make_sine.c + Re-write of this example using sample rate and required frequency in Hz. + +2001-02-11 Erik de Castro Lopo + + * src/sndfile.c + Fixed bug that prevented known file types from being read as RAW PCM data. + +2000-12-16 Erik de Castro Lopo + + * src/aiff.c + Added handing of COMT chunk. + +2000-11-16 Erik de Castro Lopo + + * examples/sfconvert.c + Fixed bug in normalisatio code. Pointed out by Johnny Wu. + +2000-11-08 Erik de Castro Lopo + + * Win32/config.h + Fixed the incorrect setting of HAVE_ENDIAN_H parameter. Win32 only issue. + +2000-10-27 Erik de Castro Lopo + + * tests/Makefile.am + Added -lm for write_read_test_LDADD. + +2000-10-16 Erik de Castro Lopo + + * src/sndfile.c src/au.c + Fixed bug which prevented writing of G723 24kbps AU files. + + * tests/lossy_comp_test.c + Corrrection to options for G723 tests. + + * configure.in + Added --disable-gcc-pipe option for DJGPP compiler (gcc on MS-DOS) which + doesn't allow gcc -pipe option. + +2000-09-03 Erik de Castro Lopo + + * src/ulaw.c src/alaw.c src/wav_imaadpcm.c src/msadpcm.c src/wav_gsm610.c + Fixed normailsation bugs shown up by new double_test program. + +2000-08-31 Erik de Castro Lopo + + * src/pcm.c + Fixed bug in normalisation code (spotted by Steve Lhomme). + + * tests/double_test.c + New file to test scaled and unscaled sf_read_double() and sf_write_double() + functions. + +2000-08-28 Erik de Castro Lopo + + * COPYING + Changed to the LGPL COPYING file (spotted by H. S. Teoh). + +2000-08-21 Erik de Castro Lopo + + * src/sndfile.h + Removed prototype of unimplemented function sf_get_info(). Added prototype + for sf_error_number() Thanks to Sigbjørn Skjæret for spotting these. + +2000-08-18 Erik de Castro Lopo + + * src/newpcm.h + New file to contain a complete rewrite of the PCM data handling. + +2000-08-15 Erik de Castro Lopo + + * src/sndfile.c + Fixed a leak of FILE* pointers in sf_open_write(). Thanks to Sigbjørn + Skjæret for spotting this one. + +2000-08-13 Erik de Castro Lopo + + * src/au_g72x.c src/G72x/g72x.c + Added G723 encoded AU file support. + + * tests/lossy_comp_test.c + Added tests for G721 and G723 encoded AU files. + +2000-08-06 Erik de Castro Lopo + + * all files + Changed the license to LGPL. Albert Faber who had copyright on + Win32/unistd.h gave his permission to change the license on that file. All + other files were either copyright erikd AT mega-nerd DOT com or copyright + under a GPL/LGPL compatible license. + +2000-08-06 Erik de Castro Lopo + + * tests/lossy_comp_test.c + Fixed incorrect error message. + + * src/au_g72x.c src/G72x/* + G721 encoded AU files now working. + + * Win32/README-Win32.txt + Replaced this file with a new one which gives a full explanation + of how to build libsndfile under Win32. Thanks to Mike Ricos. + +2000-08-05 Erik de Castro Lopo + + * src/*.[ch] + Removed double leading underscores from the start of all variable and + function names. Identifiers with a leading underscores are reserved + for use by the compiler. + + * src/au_g72x.c src/G72x/* + Continued work on G721 encoded AU files. + +2000-07-12 Erik de Castro Lopo + + * src/G72x/* + New files for reading/writing G721 and G723 ADPCM audio. These files + are from a Sun Microsystems reference implementation released under a + free software licence. + Extensive changes to this code to make it fit in with libsndfile. + See the ChangeLog in this directory for details. + + * src/au_g72x.c + New file for G721 encoded AU files. + +2000-07-08 Erik de Castro Lopo + + * libsndfile.spec.in + Added a spec file for making RPMs. Thanks to Josh Green for supplying this. + +2000-06-28 Erik de Castro Lopo + + * src/sndfile.c src/sndfile.h + Add checking for and handling of header-less u-law encoded AU/SND files. + Any file with a ".au" or ".snd" file extension and without the normal + AU file header is treated as an 8kHz, u-law encoded file. + + * src/au.h + New function for opening a headerless u-law encoded file for read. + +2000-06-04 Erik de Castro Lopo + + * src/paf.c + Add checking for files shorter than minimal PAF file header length. + +2000-06-02 Erik de Castro Lopo + + * tests/write_read_test.c + Added extra sf_perror() calls when sf_write_XXXX fails. + +2000-05-29 Erik de Castro Lopo + + * src/common.c + Modified usage of va_arg() macro to work correctly on PowerPC + Linux. Thanks to Kyle Wheeler for giving me ssh access to his + machine while I was trying to track this down. + + * configure.in src/*.[ch] + Sorted out some endian-ness issues brought up by PowerPC Linux. + + * tests/read_seek_test.c + Added extra debugging for when tests fail. + +2000-05-18 Erik de Castro Lopo + + * src/wav.c + Fixed bug in GSM 6.10 handling for big-endian machines. Thanks + to Sigbjørn Skjæret for reporting this. + +2000-04-25 Erik de Castro Lopo + + * src/sndfile.c src/wav.c src/wav_gsm610.c + Finallised writing of GSM 6.10 WAV files. + + * tests/lossy_comp_test.c + Wrote new test code for GSM 6.10 files. + + * examples/sfinfo.c + Fixed incorrect format in printf() statement. + +2000-04-06 Erik de Castro Lopo + + * src/sndfile.h.in + Fixed comments about sf_perror () and sf_error_str (). + +2000-03-14 Erik de Castro Lopo + + * configure.in + Fixed --enable-justsrc option. + +2000-03-07 Erik de Castro Lopo + + * wav.c + Fixed checking of bytespersec field of header. Still some weirdness + with some files. + +2000-03-05 Erik de Castro Lopo + + * tests/lossy_comp_test.c + Added option to test PCM WAV files (sanity check). + Fixed bug in sf_seek() tests. + +2000-02-29 Erik de Castro Lopo + + * src/sndfile.c src/wav.c + Minor changes to allow writing of GSM 6.10 WAV files. + +2000-02-28 Erik de Castro Lopo + + * configure.in Makefile.am src/Makefile.am + Finally got around to figuring out how to build a single library from + multiple source directories. + Reading GSM 6.10 files now seems to work. + +2000-01-03 Erik de Castro Lopo + + * src/wav.c + Added more error reporting in read_fmt_chunk(). + +1999-12-21 Erik de Castro Lopo + + * examples/sfinfo.c + Modified program to accept multiple filenames from the command line. + +1999-11-27 Erik de Castro Lopo + + * src/wav_ima_adpcm.c + Moved code around in preparation to adding ability to read/write IMA ADPCM + encoded AIFF files. + +1999-11-16 Erik de Castro Lopo + + * src/common.c + Fixed put_int() and put_short() macros used by _psf_hprintf() which were + causing seg. faults on Sparc Solaris. + +1999-11-15 Erik de Castro Lopo + + * src/common.c + Added string.h to includes. Thanks to Sigbjxrn Skjfret. + + * src/svx.c + Fixed __svx_close() function to ensure FORM and BODY chunks are correctly + set. + +1999-10-01 Erik de Castro Lopo + + * src/au.c + Fixed handling of incorrect size field in AU header on read. Thanks to + Christoph Lauer for finding this problem. + +1999-09-28 Erik de Castro Lopo + + * src/aiff.c + Fixed a bug with incorrect SSND chunk length being written. This also lead + to finding an minor error in AIFF header parsing. Thanks to Dan Timis for + pointing this out. + +1999-09-24 Erik de Castro Lopo + + * src/paf.c + Fixed a bug with reading and writing 24 bit stereo PAF files. This problem + came to light when implementing tests for the new functions which operate + in terms of frames rather than items. + +1999-09-23 Erik de Castro Lopo + + * src/sndfile.c + Modified file type detection to use first 12 bytes of file rather than + file name extension. Required this because NIST files use the same + filename extension as Microsoft WAV files. + + * src/sndfile.c src/sndfile.h + Added short, int and double read/write functions which work in frames + rather than items. This was originally suggested by Maurizio Umberto + Puxeddu. + +1999-09-22 Erik de Castro Lopo + + * src/svx.c + Finished off implementation of write using __psf_hprintf(). + +1999-09-21 Erik de Castro Lopo + + * src/common.h + Added a buffer to SF_PRIVATE for writing the header. This is required + to make generating headers for IFF/SVX files easier as well as making + it easier to do re-write the headers which will be required when + sf_rewrite_header() is implemented. + + * src/common.c + Implemented __psf_hprintf() function. This is an internal function + which is documented briefly just above the code. + +1999-09-05 Erik de Castro Lopo + + * src/sndfile.c + Fixed a bug in sf_write_raw() where it was returning incorrect values + (thanks to Richard Dobson for finding this one). Must put in a test + routine for sf_read_raw and sf_write_raw. + + * src/aiff.c + Fixed default FORMsize in __aiff_open_write (). + + * src/sndfile.c + Added copy of filename to internal data structure. IFF/SVX files + contain a NAME header chunk. Both sf_open_read() and sf_open_write() + copy the file name (less the leading path information) to the + filename field. + + * src/svx.c + Started implementing writing of files. + +1999-08-04 Erik de Castro Lopo + + * src/svx.c + New file for reading/writing 8SVX and 16SVX files. + + * src/sndfile.[ch] src/common.h + Changes for SVX files. + + * src/aiff.c + Fixed header parsing when unknown chunk is found. + +1999-08-01 Erik de Castro Lopo + + * src/paf.c + New file for reading/writing Ensoniq PARIS audio file format. + + * src/sndfile.[ch] src/common.h + Changes for PAF files. + + * src/sndfile.[ch] + Added stuff for sf_get_lib_version() function. + + +1999-07-31 Erik de Castro Lopo + + * src/sndfile.h MacOS/config.h + Fixed minor MacOS configuration issues. + +1999-07-30 Erik de Castro Lopo + + * MacOS/ + Added a new directory for the MacOS config.h file and the + readme file. + + * src/aiff.c + Fixed calculation of datalength when reading SSND chunk. Thanks to + Sigbjørn Skjæret for pointing out this error. + +1999-07-29 Erik de Castro Lopo + + * src/sndfile.c src/sndfile.h src/raw.c + Further fixing of #includes for MacOS. + +1999-07-25 Erik de Castro Lopo + + * src/wav.c src/aiff.c + Added call to ferror () in main header parsing loop of __XXX_open_read + functions. This should fix problems on platforms (MacOS, AmigaOS) where + fseek()ing or fread()ing beyond the end of the file puts the FILE* + stream in an error state until clearerr() is called. + + * tests/write_read_test.c + Added tests for RAW header-less PCM files. + + * src/common.h + Moved definition of struct tribyte to pcm.c which is the only place + which needs it. + + * src/pcm.c + Modified all code which assumed sizeof (struct tribyte) == 3. This code + did not work on MacOS. Thanks to Ben "Jacobs" for pointing this out. + + * src/au.c + Removed from list of #includes (not being used). + + * src/sndfile.c + Added MacOS specific #ifdef to replace . + + * src/sndfile.h + Added MacOS specific #ifdef to replace . + + * src/sndfile.h + Added MacOS specific typedef for off_t. + + * MacOS-readme.txt + New file with instructions for building libsndfile under MacOS. Thanks + to Ben "Jacobs" for supplying these instructions. + +1999-07-24 Erik de Castro Lopo + + * configure.in + Removed sndfile.h from generated file list as there were no longer + any autoconf substitutions being made. + + * src/raw.c + New file for handling raw header-less PCM files. In order to open these + for read, the user must specify format, pcmbitwidth and channels in the + SF_INFO struct when calling sf_open_read (). + + * src/sndfile.c + Added support for raw header-less PCM files. + +1999-07-22 Erik de Castro Lopo + + * examples/sfinfo.c + Removed options so the sfinfo program always prints out all the information. + +1999-07-19 Erik de Castro Lopo + + * src/alaw.c + New file for A-law encoding (similar to u-law). + + * tests/alaw_test.c + New test program to test the A-law encode/decode lookup tables. + + * tests/lossy_comp_test.c + Added tests for a-law encoded WAV, AU and AULE files. + +1999-07-18 Erik de Castro Lopo + + * src/sndfile.c src/au.c + Removed second "#include ". Thanks to Ben "Jacobs" for pointing + this out. + +1999-07-18 Erik de Castro Lopo + + * tests/ulaw_test.c + New test program to test the u-law encode/decode lookup tables. + +1999-07-16 Erik de Castro Lopo + + * src/sndfile.h + Made corrections to comments on the return values from sf_seek (). + + * src/sndfile.c + Fixed boundary condition checking bug and accounting bug in sf_read_raw (). + +1999-07-15 Erik de Castro Lopo + + * src/au.c src/ulaw.c + Finished implementation of u-law encoded AU files. + + * src/wav.c + Implemented reading and writing of u-law encoded WAV files. + + * tests/ + Changed name of adpcm_test.c to lossy_comp_test.c. This test program + will now be used to test Ulaw and Alaw encoding as well as APDCM. + Added tests for Ulaw encoded WAV files. + +1999-07-14 Erik de Castro Lopo + + * tests/adpcm_test.c + Initialised amp variable in gen_signal() to remove compiler warning. + +1999-07-12 Erik de Castro Lopo + + * src/aiff.c + In __aiff_open_read () prevented fseek()ing beyond end of file which + was causing trouble on MacOS with the MetroWerks compiler. Thanks to + Ben "Jacobs" for pointing this out. + + *src/wav.c + Fixed as above in __wav_open_read (). + +1999-07-01 Erik de Castro Lopo + + * src/wav_ms_adpcm.c + Implemented MS ADPCM encoding. Code cleanup of decoder. + + * tests/adpcm_test.c + Added tests for MS ADPCM WAV files. + + * src/wav_ima_adpcm.c + Fixed incorrect parameter in call to srate2blocksize () from + __ima_writer_init (). + +1999-06-23 Erik de Castro Lopo + + * tests/read_seek_test.c + Added test for 8 bit AIFF files. + +1999-06-18 Erik de Castro Lopo + + * tests/write_read_test.c + Removed test for IMA ADPCM WAV files which is now done in adpcm_test.c + + * configure.in + Added -Wconversion to CFLAGS. + + * src/*.c tests/*.c examples/*.c + Fixed all warnings resulting from use of -Wconversion. + +1999-06-17 Erik de Castro Lopo + + * src/wav.c + Added fact chunk handling on read and write for all non WAVE_FORMAT_PCM + WAV files. + + * src/wav_ima.c + Changed block alignment to be dependant on sample rate. This should make + WAV files created with libsndfile compatible with the MS Windows media + players. + + * tests/adpcm_test.c + Reimplemented adpcm_test_short and implemented adpcm_test_int and + adpcm_test_double. + Now have full testing of IMA ADPCM WAV file read, write and seek. + +1999-06-15 Erik de Castro Lopo + + * src/wav_float.c + Fixed function prototype for x86f2d_array () which was causing ocassional + seg. faults on Sparc Solaris machines. + +1999-06-14 Erik de Castro Lopo + + * src/aiff.c + Fixed bug in __aiff_close where the length fields in the header were + not being correctly calculated before writing. + + * tests/write_read_test.c + Modified to detect the above bug in WAV, AIFF and AU files. + +1999-06-12 Erik de Castro Lopo + + * Win32/* + Added a contribution from Albert Faber to allow libsndfile to compile + under Win32 systems. libsndfile will now be used as part of LAME the + the MPEG 1 Layer 3 encoder (http://internet.roadrunner.com/~mt/mp3/). + +1999-06-11 Erik de Castro Lopo + + * configure.in + Changed to reflect previous changes. + + * src/wav_ima_adpcm.c + Fixed incorrect calculation of bytespersec header field (IMA ADPCM only). + + Fixed bug when writing from int or double data to IMA ADPCM file. Will need + to write test code for this. + + Fixed bug in __ima_write () whereby the length of the current block was + calculated incorrectly. Thanks to Jongcheon Park for pointing this out. + +1999-03-27 Erik de Castro Lopo + + * src/*.c + Changed all read/write/lseek function calls to fread/fwrite/ + fseek/ftell and added error checking of return values from + fread and fwrite in critical areas of the code. + + * src/au.c + Fixed incorrect datasize element in AU header on write. + + * tests/error_test.c + Add new test to check all error values have an associated error + string. This will avoid embarrassing real world core dumps. + +1999-03-23 Erik de Castro Lopo + + * src/wav.c src/aiff.c + Added handling for unknown chunk markers in the file. + +1999-03-22 Erik de Castro Lopo + + * src/sndfile.c + Filled in missing error strings in SndfileErrors array. Missing entries + can cause core dumps when calling sf_error-str (). Thanks to Sam + for finding this problem. + +1999-03-21 Erik de Castro Lopo + + * src/wav_ima_adpcm.c + Work on wav_ms_adpcm.c uncovered a bug in __ima_read () when reading + stereo files. Caused by not adjusting offset into buffer of decoded + samples for 2 channels. A similar bug existed in __ima_write (). + Need a test for stereo ADPCM files. + + * src/wav_ms_adpcm.c + Decoder working correctly. + +1999-03-18 Erik de Castro Lopo + + * configure.in Makefile.am + Added --enable-justsrc configuration variable sent by Sam + . + + * src/wav_ima_adpcm.c + Fixed bug when reading beyond end of data section due to not + checking pima->blockcount. + This uncovered __ima_seek () bug due to pima->blockcount being set + before calling __ima_init_block (). + +1999-03-17 Erik de Castro Lopo + + * src/wav.c + Started implementing MS ADPCM decoder. + If file is WAVE_FORMAT_ADPCM and length of data chunk is odd, this + encoder seems to add an extra byte. Why not just give an even data + length? + +1999-03-16 Erik de Castro Lopo + + * src/wav.c + Split code out of wav.c to create wav_float.c and wav_ima_adpcm.c. + This will make it easier to add and debug other kinds of WAV files + in future. + +1999-03-14 Erik de Castro Lopo + + * tests/ + Added adpcm_test.c which implements test functions for + IMA ADPCM reading/writing/seeking etc. + + * src/wav.c + Fixed many bugs in IMA ADPCM encoder and decoder. + +1999-03-11 Erik de Castro Lopo + + * src/wav.c + Finished implementing IMA ADPCM encoder and decoder (what a bitch!). + +1999-03-03 Erik de Castro Lopo + + * src/wav.c + Started implementing IMA ADPCM decoder. + +1999-03-02 Erik de Castro Lopo + + * src/sndfile.c + Fixed bug where the sf_read_XXX functions were returning a + incorrect read count when reading past end of file. + Fixed bug in sf_seek () when seeking backwards from end of file. + + * tests/read_seek_test.c + Added multiple read test to short_test(), int_test () and + double_test (). + Added extra chunk to all test WAV files to test that reading + stops at end of 'data' chunk. + +1999-02-21 Erik de Castro Lopo + + * tests/write_read_test.c + Added tests for little DEC endian AU files. + + * src/au.c + Add handling for DEC format little endian AU files. + +1999-02-20 Erik de Castro Lopo + + * src/aiff.c src/au.c src/wav.c + Add __psf_sprintf calls during header parsing. + + * src/sndfile.c src/common.c + Implement sf_header_info (sndfile.c) function and __psf_sprintf (common.c). + + * tests/write_read_test.c + Added tests for 8 bit PCM files (WAV, AIFF and AU). + + * src/au.c src/aiff.c + Add handling of 8 bit PCM data format. + + * src/aiff.c + On write, set blocksize in SSND chunk to zero like everybody else. + +1999-02-16 Erik de Castro Lopo + + * src/pcm.c: + Fixed bug in let2s_array (cptr was not being initialised). + + * src/sndfile.c: + Fixed bug in sf_read_raw and sf_write_raw. sf_seek should + now work when using these functions. + +1999-02-15 Erik de Castro Lopo + + * tests/write_read_test.c: + Force test_buffer array to be double aligned. Sparc Solaris + requires this. + +1999-02-14 Erik de Castro Lopo + + * src/pcm.c: + Fixed a bug which was causing errors in the reading + and writing of 24 bit PCM files. + + * doc/api.html + Finished of preliminary documentaion. + +1999-02-13 Erik de Castro Lopo + + * src/aiff.c: + Changed reading of 'COMM' chunk to avoid reading an int + which overlaps an int (4 byte) boundary. diff --git a/libsndfile/NEWS b/libsndfile/NEWS new file mode 100644 index 00000000..d8f549f4 --- /dev/null +++ b/libsndfile/NEWS @@ -0,0 +1,199 @@ +Version 1.0.28 (2017-04-02) + * Fix buffer overruns in FLAC and ID3 handling code. + * Move to variable length header storage. + * Fix detection of Large File Support for 32 bit systems. + * Remove large stack allocations in ALAC handling code. + * Remove all use of Variable Length Arrays. + * Minor bug fixes and improvements. + +Version 1.0.27 (2016-06-19) + * Fix an SF_INFO seekable flag regression introduced in 1.0.26. + * Fix potential infinite loops on malformed input files. + * Add string metadata read/write for CAF and RF64. + * Add handling of CUE chunks. + * Fix endian-ness issues in PAF files. + * Minor bug fixes and improvements. + +Version 1.0.26 (2015-11-22) + * Fix for CVE-2014-9496, SD2 buffer read overflow. + * Fix for CVE-2014-9756, file_io.c divide by zero. + * Fix for CVE-2015-7805, AIFF heap write overflow. + * Add support for ALAC encoder in a CAF container. + * Add support for Cart chunks in WAV files. + * Minor bug fixes and improvements. + +Version 1.0.25 (2011-07-13) + * Fix for Secunia Advisory SA45125, heap overflow in PAF file handler. + * Accept broken WAV files with blockalign == 0. + * Minor bug fixes and improvements. + +Version 1.0.24 (2011-03-23) + * WAV files now have an 18 byte u-law and A-law fmt chunk. + * Document virtual I/O functionality. + * Two new methods rawHandle() and takeOwnership() in sndfile.hh. + * AIFF fix for non-zero offset value in SSND chunk. + * Minor bug fixes and improvements. + +Version 1.0.23 (2010-10-10) + * Add version metadata to Windows DLL. + * Add a missing 'inline' to sndfile.hh. + * Update docs. + * Minor bug fixes and improvements. + +Version 1.0.22 (2010-10-04) + * Couple of fixes for SDS file writer. + * Fixes arising from static analysis. + * Handle FLAC files with ID3 meta data at start of file. + * Handle FLAC files which report zero length. + * Other minor bug fixes and improvements. + +Version 1.0.21 (2009-12-13) + * Add a couple of new binary programs to programs/ dir. + * Remove sndfile-jackplay (now in sndfile-tools package). + * Add windows only function sf_wchar_open(). + * Bunch of minor bug fixes. + +Version 1.0.20 (2009-05-14) + * Fix potential heap overflow in VOC file parser (Tobias Klein, http://www.trapkit.de/). + +Version 1.0.19 (2009-03-02) + * Fix for CVE-2009-0186 (Alin Rad Pop, Secunia Research). + * Huge number of minor bug fixes as a result of static analysis. + +Version 1.0.18 (2009-02-07) + * Add Ogg/Vorbis support (thanks to John ffitch). + * Remove captive FLAC library. + * Many new features and bug fixes. + * Generate Win32 and Win64 pre-compiled binaries. + +Version 1.0.17 (2006-08-31) + * Add sndfile.hh C++ wrapper. + * Update Win32 MinGW build instructions. + * Minor bug fixes and cleanups. + +Version 1.0.16 (2006-04-30) + * Add support for Broadcast (BEXT) chunks in WAV files. + * Implement new commands SFC_GET_SIGNAL_MAX and SFC_GET_MAX_ALL_CHANNELS. + * Add support for RIFX (big endian WAV variant). + * Fix configure script bugs. + * Fix bug in INST and MARK chunk writing for AIFF files. + +Version 1.0.15 (2006-03-16) + * Fix some ia64 issues. + * Fix precompiled DLL. + * Minor bug fixes. + +Version 1.0.14 (2006-02-19) + * Really fix MinGW compile problems. + * Minor bug fixes. + +Version 1.0.13 (2006-01-21) + * Fix for MinGW compiler problems. + * Allow readin/write of instrument chunks from WAV and AIFF files. + * Compile problem fix for Solaris compiler. + * Minor cleanups and bug fixes. + +Version 1.0.12 (2005-09-30) + * Add support for FLAC and Apple's Core Audio Format (CAF). + * Add virtual I/O interface (still needs docs). + * Cygwin and other Win32 fixes. + * Minor bug fixes and cleanups. + +Version 1.0.11 (2004-11-15) + * Add support for SD2 files. + * Add read support for loop info in WAV and AIFF files. + * Add more tests. + * Improve type safety. + * Minor optimisations and bug fixes. + +Version 1.0.10 (2004-06-15) + * Fix AIFF read/write mode bugs. + * Add support for compiling Win32 DLLS using MinGW. + * Fix problems resulting in failed compiles with gcc-2.95. + * Improve test suite. + * Minor bug fixes. + +Version 1.0.9 (2004-03-30) + * Add handling of AVR (Audio Visual Research) files. + * Improve handling of WAVEFORMATEXTENSIBLE WAV files. + * Fix for using pipes on Win32. + +Version 1.0.8 (2004-03-14) + * Correct peak chunk handing for files with > 16 tracks. + * Fix for WAV files with huge number of CUE chunks. + +Version 1.0.7 (2004-02-25) + * Fix clip mode detection on ia64, MIPS and other CPUs. + * Fix two MacOSX build problems. + +Version 1.0.6 (2004-02-08) + * Added support for native Win32 file access API (Ross Bencina). + * New mode to add clippling then a converting from float/double to integer + would otherwise wrap around. + * Fixed a bug in reading/writing files > 2Gig on Linux, Solaris and others. + * Many minor bug fixes. + * Other random fixes for Win32. + +Version 1.0.5 (2003-05-03) + * Added support for HTK files. + * Added new function sf_open_fd() to allow for secure opening of temporary + files as well as reading/writing sound files embedded within larger + container files. + * Added string support for AIFF files. + * Minor bug fixes and code cleanups. + +Version 1.0.4 (2003-02-02) + * Added suport of PVF and XI files. + * Added functionality for setting and retreiving strings from sound files. + * Minor code cleanups and bug fixes. + +Version 1.0.3 (2002-12-09) + * Minor bug fixes. + +Version 1.0.2 (2002-11-24) + * Added support for VOX ADPCM. + * Improved error reporting. + * Added version scripting on Linux and Solaris. + * Minor bug fixes. + +Version 1.0.1 (2002-09-14) + * Added MAT and MAT5 file formats. + * Minor bug fixes. + +Version 1.0.0 (2002-08-16) + * Final release for 1.0.0. + +Version 1.0.0rc6 (2002-08-14) + * Release candidate 6 for the 1.0.0 series. + * MacOS9 fixes. + +Version 1.0.0rc5 (2002-08-10) + * Release candidate 5 for the 1.0.0 series. + * Changed the definition of sf_count_t which was causing problems when + libsndfile was compiled with other libraries (ie WxWindows). + * Minor bug fixes. + * Documentation cleanup. + +Version 1.0.0rc4 (2002-08-03) + * Release candidate 4 for the 1.0.0 series. + * Minor bug fixes. + * Fix broken Win32 "make check". + +Version 1.0.0rc3 (2002-08-02) + * Release candidate 3 for the 1.0.0 series. + * Fix bug where libsndfile was reading beyond the end of the data chunk. + * Added on-the-fly header updates on write. + * Fix a couple of documentation issues. + +Version 1.0.0rc2 (2002-06-24) + * Release candidate 2 for the 1.0.0 series. + * Fix compile problem for Win32. + +Version 1.0.0rc1 (2002-06-24) + * Release candidate 1 for the 1.0.0 series. + +Version 0.0.28 (2002-04-27) + * Last offical release of 0.0.X series of the library. + +Version 0.0.8 (1999-02-16) + * First offical release. diff --git a/libsndfile/dist/libsndfile-1.dll b/libsndfile/dist/libsndfile-1.dll new file mode 100644 index 0000000000000000000000000000000000000000..95ce5bd0ad79ea73c35ecf55e00f1d9e9c9a7434 GIT binary patch literal 1679360 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

2eEm05w?F(lKHGFa>&FUOQ?*?x;_tD| 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

m`-oYBVppq(&&iz%FUk`dQ-6+^UgY zf5Io^Y&8$l)pnl)9ukSN3~aT$!=chLqgwUyX8yyUe z&;f3vWeT78EKxvO5WdNi%@3;8XX1wvp?$0HLYm1_jXj+o6b)}s{2<)0yDl3)O^PLi zA%viCI&3bBX70qNfPMx>$Y>9kCN9rthLY#Rzv&cs`X@Zu!YqtzOS5>(r2C&5B+ctp zUZmNTlI8~RNlWwfLYOm1vj97TG*6MX43Xv;qz#tlbRU-ieL$3L!)A~@r1V!t|G5&S z%!LQ~j|+dL|L)a^wEaJMvinaOaz=Unu2AZ<{!>jlz5i5`st+nwKgjg*3_U0A&1m|M_0b=)XsW zFd6+fUvY!WkFViO{rBt{`fuOa`>z4$e_#LQChGAzrWzhPFh=*^a-B%q-{mQ#k7>vm z`|sC6sX_fWANf;FI=%l?lRm!xq=lLN_Y>fs-hbx$$vto0erw%=cl*cS2figyf=A$^ z^!QUZ?)jW`bj{p4wFSfo9>QS}ykV^mO1}(4NHEE9u9-BfNu!RM@zDNj2sVqIa4E;a zo`#zEesfpdg13pOV949tv!|q!xRo1XO8bd@zFJ@?K=FR_RM)S8Zhfs!fvY4d$b^aP3 zCDdyXucJ%0t(F9GUTW14g;;%sRh?f4vfwjb@L~G8DR?M!BD=k^*wIm0N@fCTHt~1f zb)ge3Bm8|HLnnp>gW%=ws4OeK8w0blLinhovT~yOsS*pgBU@g`RnUhceaI2 zWCh3BC11Qlm6YL*l9#F4`%J@g-L0UN;;_1#1*7t>SIvJfdT)ibwwo53N6<~jN;Z-; zAANRle7`f9vo~~n#Jo=cwAwt1e?E4|-IPB@h;qb$MnJLZ2nip~91R~_DL6nCt5c%U`Z z=a@GV_hhVZxU;iuX>jz>HlumGtIal(_!4TpMt_w4CZ2L5IL-BYX{Kxo_L+T{$*h_8 z28e9oPU5<8kLeMrHZ?-M+Q>);B6&DKM#OvZ*M|1Z54;iCV|feaeXefY1#^pGr%`JB zs2k_Key$Ljjf_Vl{SUgW+Dn{)R|qgE6o$p;#k)hnJ^nG*%)meX1%Fy!T$dFgiz(oConYD zH!}3jm{6-P{*Ed0OYTR8-p);1`x+aH9mZoZSt5R>HD@bSDJrb>7laNwn&WjY zY3{%e!z9zJ8O>*p`s@yDS}hUHf#W2@K8JDb6Ft;d-eXwfnY;BMrqv!qwv^G%YRE^_ zD`~PHYXskASK-pS*eQ45aGg0a@2oq5hAwLq@z`O6F94LWawKcf z=9b{^DU+khbZsKOw$I@;7AL^(RatynBY*158Ls45W>we|D_I{vJupVk^^Y{dzgLZ$ z&Cp!$A1!}8IBcE!j74#3G!I+9=m(N4>Izd2a}tnyigoCl-l!YbaH$b)6|^|Dy3<(H zs~_hVTMsoFOJtc=5kjhQ2aX#nH6;M#mb;6ouK}vfrOsHNJFvs-BLOi4Cxx96{uGGS zEjZYM8OgUA4-{OqmbIt4@`J`=3D>1jp5$-TLk*m^Em_I)QsEz~rogJ^Zs99K2l3h8 z=PKVCJR+u5WEy0HBT5k{rvHwUFc6@9^j;BsSteG<6-MMZEw+u4>LR`ox=-^JJCFg> zsv+Nq$SDYQ3uujFn_*%0I51C${i+!b6BirJv!zX2%|3a9>6|!AUL}*%FgyS|k8mEg z0am+>$S=VQSOu)?Ip*C33p?v4(;}mJ7ewd&Tu~;0-DaGrbII<&?($6!mr>P7b8FA; zSf7hdF>6MK*5xV@7BeY%KYgvmwl0*_m~59=a;?^l<|!lBIOv^#D!MzfsOTSK@f|{> zss6H(jq1HwYa8Tg(N%o0bxvYU3;iS6V*7{3PdEimQSx}m8` zDc4=UECAwtkz);aJL7fc6kjqZ{YNP52ikOOfJbJ)lFBOl1OrI=%WU>lG+e;fJicBm zfyeHoo5F&x4c*)q)&HDSZiFIh=}vBVU3v!ojc4{Q^JpKdVJ& zjiZ>r3I|K^uR3sGtd>7Y*ppu%|EscMO!aA+H#<66V{kkspJqvR{wT&zjv~9ciRLCd z1;GcTo6FRa@B^aSAac(hV`cmd^tv~t-4&sL5bv`dQ!P=Xo-SQVds*FU5w7wipCE`| z$+ySEK|EJP4DssOn=GXD>G6M!k2eM3p9I31Mwl}BRmmX~>-wSCD-xgUk!kQMH(v{{ zb4SE`=Q2C$zs*W+tNB)RMEM(L+_?TtbL(2k64({k8+g-L;Xua{_1?s~%qr0v@q|R0 zWEm^E5ldJ6Ju{h3X^HQXZ`maq#cR9y7P2Qc63Vn^3Z-^tQUCVlT+L!HRlD)borLAaf%zskyPY z-8mb0=DOVIM0b3j^RW4P=ib-UJ^=I@D2ESYWI?*_B;l$fUMr`vB`&EPGP z#DsyLO{c-{u^*b2Dzk?VAz5)yS^vnaN0fFRT|Ql zyRnWzHJR-k$&^^i-%16tQPxd{&qZ%^mv4BWIItmlamRSYDQp%=W(PJ?2v_&T!LiZt zuEOyiGUb?Ac9uKa0x|POH*-6Yx0j_@DCrEenIp|R++ACS*pr$3C^*p|Px8NzFI)c} zO&NZf{Hy3=x6sT@h59JBaSEPUBO%?Mj!GBKHb;l-cVuSiE>J%nF~FF<_g^DF-kqo? zvnIcz(kDVVxc`M7LNE^kBioB}5fd|a4J91(=@d7D6FTTb>Dq&YS>q))n~tUWe4z5f zW@O);HdsBsnFQ2nK%5T5`si#F1~wQY?qlL^_eW=Y+*^4lh|bRCr_6}RNge>2AxGOh zBF}n>bov^^uV3_nEXiTG&>SX8>KBKS$~Qea-xIBL#oviuP2lH&Y&265ip~e%e85bP zKH%oD!u$&_vqSAUycDnXQMQnGUgVe^@3?yZEF*Lg!(jO=7P%g6;mL%zR+FzW)|C@# z%kDZ)^*5rpH5uyj8R5y~iR`LBq_&<0wxgBu&4Xr=o4(N-(fkWbwi%n_`xON9t)3mH zm2ZW{k=N@F!O_N&-|+&30&CX!PAr@2dqSt2^+nc=P8B`l{0o2t=fL53mw7mTfJj7R z`Hs*Dr}5}S(6DOHlT)DbfG~r|1h3P%J=Ebck6Jf7L;IaQd%$=z1vb+gGYEcw3(QeG zdyR#cOTClWJx+*hCu`xcgE@gtP8RV-s7(ST_--tm!(X;JK%#H+RB~($-x|9{3;z=r zvGri+l&{_u>8w8j&_P5vFOvu?hxEj|Mh{T10$`ENHU&P*OQ--+P}~F2J_-iahf<-Lj|kqy#6`E%+AmUPU%fnCdRSWZY&hb4WSz=?Y7TP z>8Of|6GrToa?VS!Di*>pUUq)b&L>n1C=6E8l41%tX@>F00W?g>p5$`MtrF^`n6PW- zQnkTa`aTrPp%8BJU37o!M0V6W#<>N;7@OuzB(xG9E;Uw69pj20TrEN>J(;r`(ie^0 zimf@@XH3|d&7S{cDR#kHVf*ASsC8+os^qsw68#Cs2DU(hgI%o%S)L#oT7OY&UrsEM zn`-!@Bgp*n7XFxt!YU?Fh?6;-5nMturkl8^-hd0_IXc@_UOeX$p>>n&6&XmF{52J; z(p?Aa^~SkTy{&)<&Bs7K`cQuK4mqZvDsY0B(&tF(kWtIQ%d`AgxAcdOv%UC>2q{U+ zNGkb&mPo^ec%||il_f-<{W&_{ZAyshtms27kzDf&yc9(rlEuhr(T6} zkEu#Xn!!}x{!-3(~ZzCQ7b~fss5tDa-G4D=VEUQ zL#`eJoWNFKOp4~Ng)trFuN&9D&hcRJ_pEvS=JwdBG3E)YK|42pY>61QP2oJF-Idm`JcNlvHnSev<5MZgCR2acGpW2jb`F+9Y_12Mu{;`>AW z7g<#o%O+;FL0u_&5XMpp_BeGiigEbQNT;#lQb<%yt{TSc*#10oF9W`nUu7tokE)`MiTKkM^4HcZd}BcZUA0Y^d(gZUM=*^H4f`m&U1K@TsY`C;;loXq{@@? zhiAhmB_DiIAs2p{?|8mCqZ&c!QRzovSK)w?7Nzw>Vx^X@Tx~`H3H{eA`fn@xkM<~j zkhGr~#g8D{^N3u6 zajXhVyU)ko%QKHy^=>$5xD12BHKlS~h!3{H5YDAkh2obhRbu_fYz5s|ae-4hCLf*& z#0n=da8r|DkB_pGtd;S1#>#II#43VT4w!~zk-R2@h84?Wu6nGHN4I(`5aw&T0H2PW zaFP;L;QEb6reGeCm=6JFp>agLm}NYO9)TJz69wiak|(roZpufQo?og)qgSNS`G!?x zIH{t-SaFF^1aU!D-pkYCV$~Zo`T{K=)>I=~>cqY^kE6j6lMSmcq{2XKl`vp@ANyT8 znVoE~+h%T{s){D3YMpwi9)|=b1)6HG+cj5<1TF3U$1t4y= zX20ZrmJG4Jyrv6DsbJq*pV(LV>a|i{-RiNrX+-j7F+mx>)8hE=6qW9?$2X;-lXoGw ztA(SI-3%C#pB@sCs3gtFZ^1Yn(ke=tj2u*5Z0=%_>O=afrddk!cwCZuwvOFk zO>~b!bHxv+Bwy2{3thYYit7I5cvj@pRmBoWFloJai5j51uBBGkC zA<+)9(Dvw5(4GqwXUj;4x2=KkEKE)+l%q2n<*|d8JYJf3iS+a0j%J&~gO_p`%shAb zQ6tg@?9jTY8kh8ZgK3`Cb(jpGpd~{|_{UN|ifg^GI0#KpjnFiY z4)zH93_mHd1lnG!>V=d1${Ity=DKSKLYT} z*-8^SeNH0l`1Qh= zeW6~5d8^A<{72F9*mO!OGRQUDNRUJ>U64<>ve=J=bGEC9&Ju+rQCfxG7tKz5SvzCL z75ELR*17=KsBs!cyqA+U0v(b5`Rl~gb@9g|W{sDJ0vGX^MMn5`*j7PHHF?ST5DW{h zlpjKIV2}P#yDQY@f@bwlP{Lpu?7mIz`Yy{uoB*^~HknA@>8^Q6ErSg1yElR#rZ|H7 z@*@6?2-PXOaI94q@>(@W*$-m>EYxQ^APmM7|H2|Jd|3Vh<_C5VxqP9A~M44 z;#zi-?}(Wk=q|~N<=h_c#bjxd++A=4xpO7w;CvM-pFJO7YM`>q4h*t;PtX1(l^xd9 zaDSjP=AE9gQp0sMO2&EL0b0T7nZ^&U-11(>F$Lpcry_GFDkjY!(x56cX)JGx_gbFy zRLV)K&Q>y?4_8;CmHWn!TUb@HUN05^RCVF^o@9i(ghej|YO&c__+?-867!A1dtK&U zQTT;l&WFw%;Sf7C#)P*dMdEo1Hv+&p+>bJ>`jcB7dpv1ni= zKdu9U(q!pwIfg_)J=02tRQ(KDh?3IJ(2_a1ex@6UhSbk=9qt_cOqajLlZYj~DTB1n zxf?q{B=D5Ooa{H2yoOFT!a11R7zR!F{1~4X})1uF?61 zFpSQ38p{}FRA(Q;Fgkk%%NXXr=!`=cMrX`m8N)2s8HX^9&N!59@~?x(%@Mjp(V3b? zcOVUxSF=v1bEjeMl%Z@W^Em0rw}h&InJG ztlIx{HZA8w%k}JJS{v^(mTwR2XlO~EuS=m_hS}PMli{>>VL76KHL*&iSU6t~el!-p zkLX+1d69WN7`)GKS@LHH1@j-1lS84vA(V#5LpPo678b}ucQC6|+GE}f1{M!0{`g=K zD=-O+??`D41aU6Rep;>~JD25&*n%h$em>k^YHmQKYeC!~l@^CuMG(C%mUzoJ)L3-Z z7oerr>@6Ihiy(ef_$@7nynB=&mTEzy-a@>4gN2N9o(2h7QHIbIWC#sy%@CRnB{Xj# zGza4SA~X+qjU{s6j}g903yrAG%%MngnNUpVWti#=YN6P1vzO(<-Z306lcR-FXQgtR zY=$Xej~JpFeH~Xez@hmW8OI>8wo*T zk@S=t@Ooz(zG!h&%E$(+$i{i+%K2knc9eRr6XOV{59Jro=sx@?UFPPo`kG3=0@$*n1-Ekru1L zspj_JhY&u8wWsW5*E5Ax&z#iu-j5{~;so}d%dfHu+4f`Z<%%7WZ-kExgG@kH=H9bX zv6y@F8ZiRu@!hBanz7Z&XDX590%0a@%TK~hUdqeZSx${ z;^y^~h;l2Cc(M|FMA>5Tb-B=jfezc=^DsGPp5pO~bG6@W2do>gd4WTLQ>L`vhnL`# zSv**sV)hw}H)@+NSL|Rh@ERtd65Wv8+ciqGA@M5g;1QNpOErbwRYUDPk014rHupLL z?U7^i*DFhpKQ1x%JUsZs+`~$iS&9NC?UoiVxd3J==}&%+pA2)aRa{HcVbf_eW`^CV z$%FrDn|l{%Da*6&a9Q48U>~af8(w(*Neo3^RUck=lADCttfCo$`n&^1-_AAPHgzKY}>&@t72gAE_)A5o-! zWBJbbiNJ3B=Zh~UH=S}6rFBB-_?^*wl?g4>&8+d1^H|`BWIRmoU=kcsmXtjl2rv{7 zip`E#53F|{l+5cyf?+}+A0AMLlKl#Eml{3A=)>eP7XL_R6|-|lR_29zpvCMH>+C*} z{JNXim-U7BdRV?9DIXaxgK2W*MNPHj!Apu;9%Obc;}a1)RsO3Bzm5RO0Fs0}ulh2Aj6vu8?P!eunZgFkv6kS6lQGUAvhlIy&B~++%sR^kL$e*qWIW zC6T@*yOq7?h4oM86+IlKxP>KK^L?0}9>}oz(?eEw{FLRoI?!gA9g+#-k&d@#d^!{O zt{1aO5A;k94D%@wBF!hK!KA5JS!!}%nD^_9YH~6ZF7y#|OeO~g2hAynXEaG6sF*%#Geqi7=mhVPC>?Bg}o7ja%$$@Sl$8Mz?YT2N({D`d^y2(_j zw8CDp9wL`aFpty)n3@~Q526{oYA;LR4QGO^GQ;u@6*Qj~Gna^2ff3FFV-Yj25*m>( zMD1P=0wZFE^OrLre2ALAa1NMmRU)*NB`E}fDqjnzCs5p?pUAVBClQIhfcPErObP7L z3Ob8`gxCND2)8qq9DpH=uxukaojg6erDZ7sAsj%2?&BfHpP z%GkRym7QIx+IqW!2W7n#@t~|XF$fuR@T2iCI{9gAwW!OltPn9kl8r-*Hw-y#KS?-6 zDQ1JLsQRQWU{Dm<7`%$~0;|Y^_lV(!8!nDkL}LeX%`ZeN7PG`Aj}N(=2MHm6FSO3B zj3{#bSrv1IOqW0Qb`~A)BB5BVuSUOwP?a*^Mz1@`m}@Nm(AkTXoiNu2dSmbA;wv>T z!#X5r&sCo94|b-YrpCvA2w%?tzMlV8d_5c~_qX6H%brz=uCgi)ZH3-e#hXG`vqDx9 zD&&@z|KJq`r*3FrNqzCdyi>9mlLnLJ`~0|L`?JIrB(>7|w=Dd57XYdPN&-XXS}s>; zJyhKk9b>*OzJM}kJl-ETVXS-@=N&#wEmrRsD{nfPqn;(sqsA5ApYvAifZHs~mgy^? z5Nvnwry)DYY{1@*?5UrIRsNo!WqH0YeXCIt+rQHK9v*j0%8Lb|?+|b2LQ%x`8!K<= z%h@bnV*3eX=JlkRmy;xt#jJKwqnr7mE4V&Yn}S`W7W-IQgAU>jwc{zG6+c#ZMk}7d z*p|lzmorhmOZZO*#7TiFDd73O05U-bGH4`SOBMfBfLQd76#t!&S)Tc3;6&_Q$m=!> z%qfDDtK6&jPeUEde=b) zux4}kb(BO8iLU40VTr$MCMn_0 zc}>2Vml0pJ^5&B{8?^A`mct~$=R)hesfmppe-b$syj=AkC|N}k*2;Q+wBolSAur;o z)#7nD_v`$6GajL&wz#pwSM(&_J%{@*q)FPbOo!}*JeD;@4knE6X2&|;J9 zC(zM)qH{{st%_CB z4MYJ9;2ZsdY?2`WU;tka$jAEKV+Cc--0f2t1mTG%MRmseadR}BG=nGcHn@XpQ|M?l z1M(GeAKqj}6i|?*S&ar-MN<))Ei|#R^!iaWOX$=g{7?msHp$$OjM^1B*gvQlq7s(= z`bl%b$?^(+5Pr~9I0HW@aT0E*f*Vl9LI${^!m3a+Vy1z|%?iH?>8LV0h#g}H4F5dM z7b1sM$RUBG#$uCXX@__(E?_KiiF(AVLRz)ez?k%e^gnM!y8Xt=S@gdW&?(X`gp(U5 z#%`@MZ|P$ID)P%lB!+V}7R67feIWFFm+<~>A%K(d3GSp1;vbm|3bzXXBX&sf&r)rc zhH-B3RS4<(f*b+m6{$g>D4LfN*8y4WN|jtnk=0T}+GDpxupelPFnZAdf2hun=844C zsLr9aG)uL@<_u|@<_wx6N=J#TJGd@g>1p~?>}Ro?aj1RGWo~FZQAeC364-d+8%FqM z9&iHsFEk!~hDT$C+uUNTsCG)A!rQsd!^Vo)S+V!r>VXg-He3)(Y%G-WWE*a*nBrQ~pBWE-|lHWqZBeJw;?&K`*ii`C2AxAgi0(y$k*f4CC5&1c@tHy@m-!LN2 zsHYM47?H<#3blAbv;2OKI<&9x!D06qk%uM2gTudVM8qx8_}~Z%&CJM3x8){pAz>+g z>JR(7o=A`XtLpF(bUixo-p}`p{T8CH7rZ}-zTz-_wcq3wznt?-gp!;P9gRq9bl{Ij zZ`ePZR9u*kwYXc2$ZO~Da?A*?=NHW~Nfi3G=zTjMQ4F)l&hSMSPPJamuf$s82=2RN zi*7Xpa^NAF>z`shoX^NfgCd+4H733k6mB@8%n!ehx%`RvO6o!X7nGvDq6O*>!=|FJ@=?&JNcCX^Z78 zyRTc~x7uCh9|ku-kE#XhgtB+uZT68xs@RnxPi- zWtFrpXR_MO%ytg-aqsJFhJgB!T2eAgt>**l!L6Oi7K!i8ZakiiFjX1hLNeksSn=gy zMB0Y8LBa|n(vKTAEb}yiB8?T3hpqJiKd?PSI8G--s9;CNz&!czK=f z;LkJ%SCEFK!TOL|BRrMhapTdPQ4U8%o)LbAw+dgdPGnBzq}AZ!vliwzQi4S$V=Zua z$dm8lNcX~w(&;?PC?RC`kR%LXxt8)K8g>f5Vx-oX#BS|8f*_^FL(TCi9-2fzVQ%y` zM|6UV*+g~nt4LR7KUhQqowfITd{n*n1Wm{+HG&V~7V13MlFSahlik>t-Bc^R_iZxj z-ZNInQ61A_?_|@DJkGoyxTH|Y({h85ay9KPV+@@n#^^Wvng_lK9y2W^O5^N@&^Ev4xU$ES!x!pZ7q6yvI zgXo^7_c9I*P2)3&-pnPdohgDR-^CFrWP>+E8cO;T-+^#i#>`%AgJqJ{L3>aUoHAn& zU;rtXafGdOw8+{06xAJB-fBGheLy#p(w}UxD@n=Y%fE*xPpwqKJ%G{DKPmm(9 zUZ@B?k`POgG1X=dfIugsQnNkLvx&yGlNH^_Rm>v2#-kS@YRxBQ^cpDxoh_eI(C(6w zV~MpC%t*1G^0$CQ;=cwbCw|Dg*_z78HsF?n!V|P@HgY#BF-Lt5?Hki_a9Fs7q#4Ev zQH;~;uQXp#qomn`7){44%RoF)NilYme~$%3_HVyS=(r51?3+Z*MScjD#>y{`G*$o( z#Ka#?g%Z(cYbOcU!I06hIikG?C~0NyGRYViUmjty3M{OUgqA7!(#n&u%B8q5iKpP&|abuWIefp-`vEX0U`s*YoG;&v%oNm(EwhWt@4P|TIZi`Q_<4L<7zb;Hp=qD;FOmj7udRw%{#w|7r+E}41$Rys z%HAl%3x8eoc!uiPr$!51Ow`T41I$>smcOD~DsnB4>}&=5HY&~5<9d{ERAQ|)2GQDu z`7Be%-pSQ2jyZ>t%WM%(@nF-2Gw|U3Bo5`lg>&IS5%LZWOiQs3j05LYkv${DrWwQS zv_xR=C(@=T&L{269M}N6)hGVaA>T7NFsM0jR((mD1I@iObXFz=90IDKDe7QVrOx z@D9QSR|Y!iC9W)xkw$o*@lYfHiQ)I-q$D^*N?=BqUWpfD`75v$ugabvAVbN4aNHof zz>`s64+TUpUIJIpu6NXb9x_+hEKg(egx~nh9ix94`Cx2x8`2>n>=thR^dArbVm2ks z=7j@>LTvrlikvcD1^ZnJer{WP22&KB}k)PH3_aft2|Rl?XN z_NcA;66@9}^)W|rl~#v|7wxo58&N6kS!|-KxbJnQIWn=a&6mh?e}UX$GTNrf|G;b< z`yS@Q?*$(G`~Qt)`W>laCRJ4A8j)}O@1efpPryAFc-oj!me8GMuXwc-p|I@!9imnE zjPTE}GEu~lTM4Z~3M%Oeu{zbnN!W?!k1_SWour~Xii)xLB@Hs-)=^s1>@JW&s#3AY z*{pR5jY?aOKNgVd!Ce(A^)mw#l_YqD+C|Xai62&ta+H5)L`pF1lhgSl8EmT|vAb1z ztR>VkI{8O|G9c{HdjAY^o>|~U&_&=y@Dcb@rfnb~tj%7eWXs?IA`w)TU@NxwJCbim zHR&O=GWn_)ar)gR!C#@`!UMEp+n-g915`^xJo_|f5aAXGltlt%g2U9exI~%Og#AmU zODDK_Qk&@}c*Hi++goVjG>quGe~>ExKHIL#knZS5bc0;LzrAiS4TUYW?FRlYBMv z{W2BXBvUb0VkMu&>05rd-YYqLl0z7Sb1t8hqAPFXG?YHfmv4ybS=_^S-t+3e%3oiQ zcwj>RNykp`t$*emY<&9@%Ut5i735a7c5N}|WQP447!C(05G1IOxrSpt2fVksT1eHA~Z zUv|$+-Rol-C-v#ER|ObGM@EL{$bb>tl7X07_M*Xb?M=+IRHMZ{lz4`c4+iXcx7cNb zTrAH@QDCxNTk6B`)Q2ze!6rfbKuu|K8sR_b>4pNSNgC_(s1{^rz>I3DramQF(ooyf z{Q)x2q}S`r_2MymUucqrjp?FCVfg3eeY}gO7uAzU&r9mb!_z9BjFsF(+>og2>FDXN zCuS*h;6z=hA7cDBb7r$Ac0leV_E}GTF|W}nM>Efr$E7?z_k(@FLL3|UA)%H}JX+CxyyMdg^?FGyBejL^+y`P= z!iS_)@HX8Dk7V317FY6@yeR*6>?>(-@FsXw>?Cn?dHF1oBV6eteLBD5SgPVzbfOFk z;zR(lgGU(yrkYrJPoT=|^^Qn^v{bU$UL9+|7@YqKa*EdtEn6v4q0UE~>lc~LRl|Xv zB}q+XXauPtai>^vw1+YkXDvevu`HO-T9@hZC;pi-)*}BaG)9W_>qf~~AroD7`T^N^ z)aM~k4bB5cBDYzgS4L4$ytpUDUiCmfFG==2j1JQ+0qeki|x8z?)#z}7c%s?9Xu z%-~2L{QWkL;Rx(tEWQ^HsOHx5c~{(8OWply|M)8&l{#Vg;)GrUsEM59H_^tAk&2n@piKMEDKbg;CnXx#*SU0*I1jW~XsN3-VS`Fs@#L@mnEc{w5Gk#a z{JG@ks?Fe&jJUOyW@9NU^1-h@6~q<_@{^?Gf_5p~eg^-q<(sjnL&0S)&Ah67x83&>;jq!MkReM1tmMkZHJ6pqh>J6N}!cwufF|sy0H`zMhXugSy zF|H-|GKL5pNmBZjHL^tF6>N30b-_9r|LjBfXyE@; zf49GdR9?##-lbZ&yKo``b{f5q612Zltp4;S5T64KAZo;J;I~0W7giYV%}Tz8@u=pH zc1v3CG&|KAK6Dk2#$Zbj`~DBB!00J|7zicX*pw`Um4-`RC2U;7@OZ1U1*d2s zDJATT^_SRWmE1l+nE28p&pd%@*NBD@BwcC;PI+P)Rek$^-4>QXEHTEL1f zl7%LFED$}QwB|_dzLjJtc_!s2eJU0K5R|5|22{uU;K6H#eIWJ78kb#oL(i1M1V!3THrFDezlx)(>#<--~*QMm?=6bv=It_53vIO?Yi- zmxOuEHc_HqeTnxrXz{#IiiB%P2(%HGBeq(Zv2Zd4=&IRZtg?*YL5y?r%c9a=Qcq$` zu2N4zw@K3W4wwH~Sy6_BiQ7v@Ig&~AQhIz`qZWxyl4RSP|I6mUE4$HK@Am-yCE1iF zI_7_%1)tdkv}b^p#$VR^&Fu@`|GhLCgD)zFu$18xOX!5T(c4|j6B>Do-tM+%4AI*? zsm0ipxz>%$VPa|yvo-WKbC}~;W4ExP%y9E3ipAb$BGc!yUUI96Ouc_9dr+0J-*=(f zm0&P`VVtT*92mr8q3kdZRs5eN$B1tV93}*){O4-M!Wt|1mC7u9GElunxP+Q`Vg?b> zKy!_-@+;4l{V#IyP8lP+vhr&%6d^IH^cH8m7q-{X%gEB z4h`d>7`tMpb~$VSQ|>q!H9V;4y;d6qBJdKGO?M9 z;gWJd6Za!*MxG**a@`%+M_ta~W+{Y{s`;3LMX;({3cXArOIsU~UClMbFNJrPcRklQ zgWdn!Zz!e*?o52D!6z4RswrBDC_9FV{tx0S6OE0K9RX`l-W$u+i8WP*$_vpppTTO_XX{0aV5g=2;)f+M^ns^b)4b_>y$`xWV2k* zmEIq!$>r1JQjD%vaG^?t<^2GdcuFAMR;cIfRMh6MUkD%S$c2=>#t$?pL)H*dW)iY@ zxuVqc3_3bn6b<*v7rO&&BPvb)R=z=TDdYwX0jTVdUr3p$aKpeiNK=(zgfvOXT?=p< zGRkY-i0vQ7`5jZ$m|umAlwpG?f02N<$NPWFus6j zjs`v6%Y;vf@~2sPuV&uC6)=gw z|6~Sykhdy+C%kWIr7x#O{X9?EbL>QDbvaK+Q*Jz2zCHM1@*wVHfv|_)6ozMkfY_zW zds5|pA>}fZ5cEjPz}n~e#sreIlm>FPgf<9UxDr3%qkQmzsA2$gmPK0f7h;4-e64h) z6V1{nIj$9}B&?pqDrr(rGRYO)Dptt`tdhjK!cl`%VkS1l0GG9=vna%K`K&cWSnQYN zTl_KGlE23pqGw&L;+WCu4h1KA?L|qkHQ)1E0m`X%wx*NN+e2nopaWf4W#9K`ZkHx& ziLG6kWwLTm3oRc1C9*{^%X`(FKPEk5nPrf4uwI`@-V{NldGNH-_g^7BIUb~?H!l#( zWI)&0mGmpstEE>fUh^p5D|C2pQQH2AW=r&U)eGWnRE}*?091lrPIUhQzb}Wkq?ABB zc~1t{ee3|RkSUR$6;o54&9}B3CHOV5&b=7^llf9bF z?2#~8LCq@O4u?E^;^JIWbquYJ*Azzrm2~oBtjv!7vglc-!>Yk9YsD@*C$tZ%OnhX^ zWc&(=>&L>lGL?1_-uk0ZR9N&o|HVl0Q5LooIps{D@F5rb(B`dRoc>i@o%UhTx1UD#tIFy3YfIy52Rvu?v#&5kQE8z z;VK2Hm39h!5;wA%5z;qzyUpDwx29Uc$y+cU-&aP?6zCv((Nfu7SfOuy(XRkzV~m2znj&wq3|arH)B&Me$=50bK%L^ENnDF z0Uqml6xGFJ1COG+;L8+8a&QC*gtNQ@U$XoYKESJ{%)ses8S6j7NYVu6vDci$5>_V`eB{;vwTMQd~oJTE!|9%qqrwp-j7seTTzddEZhV((UUw+;(raS zC5&DE1DONK*j-Fv<~}VN409iu*ocf<*YP5zE3K<_sc!wJqe3RvVJ7Ev zh`1z9{-+ugiXF;FCAA7YeEd=tpsvJja!6Xr$P-#xFS{4uAOZR-L%#A+r9U?$T}(sC zzi3Fh8se=~euIiL&Wj9F1NR*_>V1HJMmRpL+j zdfK1#b>&YYHlZ!$PYMH{Ba5r<+rsT3c&Dsi$~+WglxfMYT9C3{(KE4u38PH1#H%Dd z#iNW3wI=4^ORLkIDL_8ftHf%r?N~}Y4H^~(3}crzQuQ~W%A{5Tl+)~wvz^4E-oZ&3tTbJOF^ zfMS^iq3Ay85pg$#^hR{f_AT6~v={?{O`09$+o-wJ46h|KPX7vZq<^^TwG&9~le(C~h>F%b_;ud1Z}X z?ZZEqU=T^$mrTT5*%!5h_9a3s#hmAV+vH}EMK17*z3vXZp9>@UVWNWQ_r+$5{zm#e z`eS7`Y~ivBHhX_RpCn@=9uQab`^BkeH^&EVZseM#M>he^Si#n{UroixGF}5G&#T2G zGNmXQ7cdrDl40d1%;IRNoTD((oFY5o-OPbq?UgP^Q_V2*NPFe*g2ukA_R0|>+bi9p zn`&~*DY<5Y_kjsy^|V*!Ioc~P;{V0`za+1{GXI|T%1_Q{ue|gd?UiG`(_ZN#eJua~ ziT|H+m{1D4}e>9=G#!?qF#6(kc~&%_#2Yz zW}jCNu3%2HkEc5GVeH&2>$Xp5e?!SJb)47iQ{}C}qn67oK?Af|Pm3#)_*5$h?_%|Lt1d}T$7LP)x24gFZ9#~C~jt@L3`Jn$A)#si-W^FwTKfLR#D+`c zZa}lG{z{>n12vrb@`C;nlFJ9{FX;$P;a7bRaS^@x7g|R+-koi9OUa(Zm`{#!bbX*Z zdJun2rNQ;IL(W|j&wsI8lJbx<+){sa#i#4XMXfTxEjWIPNx}R)>nl$4aY<+jpHuc} zG-vpna(*0UU#e7aQ|d6grEOG$`;GAX>TQd>1&v4yGY?@aUM)b_ zzsSC6nWq)&J-od+5U2Ekv5de4xT1v3JSOMKcjLHmZtOW6>dl!WC#n|&_Tp*q`6M6b z&mjd6IFD^9k=udKCny}As2_cW!C|a)7dWF&3sKE2!bjrd^mqMp-O>do6wxo{h;*Ci zi$1A|{z*;rc!+)EE%SGnho#?7oIGya&>oOQ!vaC1Fj!y%y2QH9X-1@?_OJp} z$ghUfrm=v4%nrYniN|LL{Y-q@1JFmlfD#ZVj$LaZ6x1q?-!qic|hJ#il#q)IqiiUBsFIg^rl}vWO$htO7FvaelPVu|-P!;ZdQ4HAOM;YqXwJNaeIMy={44B^MjzW15k)`QL;^_)ntqgHf^9W`d%d`xj;mz>!JH*)b? zaMfULyfSSc>CQ~|Z}CDT{3 zxbsFbr3N5r3wgf4kHZK*NS;tETg!NRSV_la(gX#}k-Sr?PRWCy9nF*Tn#PlC606+r z9fcb$&|2QD^r&%jt5(~=8_d?O&uagA2IBKCvcBsyf2TE-s==2+ms=zv+vabxYM6z| z6+;fAI)*y#WIP-d-dKN+Ez@l&nNC>u*^o|?Y4Qggd{(O5i#zv?C*Ml!9OC8ootM!#`lm&Al$|kVZmNQ-X04d^3-_(A0-7I_jxJK|1ysU{fU8r6r zEGhJuRQM8R$w-+i_y$Im6n~_O4=I)SA&oL|2g%Hb)(buORd&0`ph#olDxjJ>5XyEV z@~_yS;OU3_$z#gDG%(03{`p^4VaXRnG}VxhJcs_SXfPtO|256(+J;f8KQDNLtu560 zqS6ek{xXx)I)lUO89)E3&PaAp0{D5MQ~KILkgJ>WS>FKf>J$e4Y0tIN}S^H;O9;u{fu_o_VknwrHOpmyYDPl&1N5>k7uM zT##p2HJ`6wtLYJ|rdYR@{o}?>+jSH3tl24HdrWD$l!^nn2iMYRr2wm#VuW82AL&=5 zp_x|7X(kj>H^_w2!)o|9bUn?>lZB+u@SOaKBxLH3F`3#@)LmMC=xl1(1DXt-8!;@B z?Q|}S3Naa>^LqB^iqz2UYi(k{4wi+E_dI+anynO5qfDF{zRQynC}mwQD@3Ilt{S@4 zH`uozIfw5u@b{4EVVBw7)ofjVDh*>Gvo5TPj02mqS(KL#kfTQ!1nF?_ke^%#C8;Mb zhdDZrh){v(7=G2HnO~)Ik~<||qHw^XkX)QDB8>&0atiR{FprbZ%h|kL7sb_uJw8)TAd)*7dd(iv*kwQt zIqs@BTayjn!MLk|8kO3jKaiTqRTPcd1Skk>3hXHF4bJ@$=N=VE!SiZCDWo#~Koyz` zG8n|!OJokMxPy@l-&5kgb69B>mRzWSbu+H`&;6k^JCr(Z9D9q)4LL%!{J8PRSn1YS z*9+q;;SA%E4@G(WQmCg~BCZY6uk=pBWS16zi_>6~BDUw_gr|v@46PV_Mqvbh&hUWA zT7l}6iF`nub26y904H7t@g}$v(R__r7^ElNpjASj+E6X67w-`Ob3BIrrRq9f3RLMPPFQUTnIPO%{Cb zWJgp83c-lS&gDhUr-E%z;$+ZdB4|P-PMU~=j%7NCjyqAw&Bn@Wxc0m1EewBwYGDH5 zE*uKz-{QFFZt@e(lfm5~8=quw2HDa#U=U&$`UzYO4&POBtuZfvuSn9yzBRdzOq)u7 zJ&#Nf{gn<&AUW}3q^bgV6I0SZI^hH)Ib_7wM}GCcepr&`^2vRQl`Ha%S_f7V*_Cq{ zJ}WOtYB2VR*$R)vztu74sfh|3uNf2~|CU%`Pqq`$#h{>gpeDzePuBxf}YPfaGkmHB+e5U#LTgHs!Z|Uaqb$1)G4x zIF^V^lpEpR>SEspFXe^&KyMU?FGIso>^p-aRaxi@<&-knPud$Ck;&QP+(;3|464l=U4btT z=}_%6YJY@cK+6x%vPa+quw^ImlGLl)urtyIHrDcjz5AqGf0HW!(?S}#6%HzxBAF$U z=%sZrn9n@G$B!%jkRuQ0YOX#IcwAUT^Jg!JbgnCMHadm5AlfA~&N{(39o4TO1*bFt#+S zB14Fm8&%hVoQiKkdE{uU*KLLtloDOK#K>N-ztTTV)f2&S_~(gapoTgr-!8dDGp$ke zA0VR2ZIN=_;Ri6jt8(3OEpX%u+IWGHQnsYX$!auz?8wq%2E-R4XvJ<HcbkAIae*$OpKA+IOg>0rJC3^QT*PZ9}(;b#TwOgWXl@G0_sQ~gJ7A%7^2?4GAIlyOzhHN4D{@sVo z4NAu11xCHA#AZGE4+am8a4OAQ0dW(diNmW<0}xX`M)mDr)>KLerwv+-?dCYv({bsD z;~t2j5q?`WBk)_wcujVuO#fniwIy%f$U<$`Xy44=o%GH-&ACy<&7BsR>e7SOl!CO6_cl+8ArVMC>4K5wqc{H>^T)ZPDajy>k; ziyl{&%~^10!Oj7s2a%m$r!9ktzCj@~cdSmjgNK2xsdm{XbxsmD~&)?<$ zj?|%yu4!HMIY?3}S|5qfG9b8*Fd$?^PDbs(U-4Gb_?BwOQq@r#J7M%hw!&$iB=mC~ zkyWcA0J5je?=-k}VQ)!yE#Xcz{$)naR_%q9!UlD{OY6MA7k=|qcwE)=xXuKdMGhm` zjN)k7>UG9^1_v&x78~DxGQLYeF?t*Gc^LIYzm@y*m|GgzhCgxl?+4#r^tgI|4!$SZ z8nPh;7IEP8V*eY50;gj4xAA8lGRNm08jM4yG6%13jAXp?$A}wmGTy68x|8b?BX{AC z<$j#XrtL@b^@TfMgnbiPjz7BbcYXt!CGuJPu`c`&!XOEzR8{Y4>ZyuPOC_u~jA;#AdVA zQ=)Cu8$z!7r{vcf;#XqlibyUsvK4<+_bt=n{1EPwz_I(O7@fn8uCJRq`Dk_Q$zZ+I zEjZc|H)EVhH$L-Z+pdRbODZkI6Szhhs~OI^Hi^!yqdNyMvlN51}+rMZKvFo5g$mgKh}zBQFQgPzD>6mnfK>|1f? zd_D?~##aY(ri|gPGArEm99*w>WD>(&b+~IsoPL6>xM&;x3PFkB@E1xhGvwwrT9i$qw;0sNY~Q(sM1${j4P3u3GrbBRRTd;paHQd#5{zl%2*4JL_``& zW5*!nQdnMi@zWJ&Aisq!`v(|&!{L|0U|xA$6@_r+f)m)V;79P)&;T`+#XvU_<=C{> z2BAWh4vZpU2@a`vA#}g*3D}?Fc)J1~96N?9O)%+@=*9j!@m6G6%%6rG;L~nnE7nG$ z<-8!?7G$Tc3_{_#@)G#oihD1vfox5eX^LYH!)-f zi6S-Gh#?!Dn-B=Z-gP5AtSPx85!wjimgl`yodkJCLjj$kP13KEn~dRhJcc0*}V*KjIhK z_k>M-jbO__pm%Yn>P;LFP(}F)pZ&VS(K0YHMcG?E_+^6-=?YBc479L}r~rhX82knI zh97ws6VPu<8V{4X$H34fnO zS+PJJ+S3941>XmlM(~^Xi-L#ZxEjbak}`ucI*bMLQFLTIT4&EsAv>4bONr3olk);p zI0+L!I{blH$&WGl;H;JjBoz&A?RU4#(%en2+*p>=ujbUi-ReHCn{wR@(o?VeYTvS} zVL)(y=$%GYf3`5lhl=HPKpqW9;l_gRLC03OvGcY6I(*B#TLO=*#0@)Eo#&0lfxi$+|nBOFRUin=4UaivN01}Oe@xR=x%w!8?%x1q7& zA^&nXLIWc|W8ty+y;%94$ah#iiADS@f3;*=g1`C|JY&qS#9zxry#e1NKfxcoCBq!Z zhRoy%vd(%^UGY1{+z)X#@LRz-NNkIDR^%EB&W4^We%_cj5TAB?_;!439(WW)nqXvW zJn)8p0sP2>^0phbcY*E~aa)S{%ojFlTT!ZxMu`0rxmLv=b+hN*N2gguJO^OoE2h61 z)x{hc_4I}{*lE6;|6{yh)Mle_{n{SvbVbkfo467AiZ#DMX>c}2K4<*~6KpW%-Nb^$ z>{3Cv*l_R`opt5x&s|6)C*e7v1h zr5_cB$BzmlVxz*y`Q^dHx=mt~1Thvopf%+iwWmII*ZY&gG(`D7hpmP?DjWMKCq$+zXFd|@>+*c!~Nd^i%R)x zOWD_9hvb=!=%!d*NMWT4Sn?dsly`1E_?q)+&Yz*Gc*8WE4mTSv(6bFi=Qn1&FFo&dIq2PiZo@o+iHq2@24oaW{mH%Pr>GQL}c|r zJil;uodfD70>lo_Ln#4&A^3q;$EmC6w>$hJ-dU7S?(rAkuesS=e{l002v5iC zKF=Ffe@7)WTJdl;-<_*V{Gyat#5Yv7!LN9OB@UE3L+v{cTX&ptr^LRq#=7&y3v3_x z^~u4i0@l@xuhk9pK71G>n0)FEuf&78LiR2E5B&D?%)(fH0biV~$_UrtZsclog@#nZ z`U9S)$z6*^BXwrh6bMzRm7kz za;dc!KUl-n1pWq>RB-WL*hPp1=Ux}h1606%Dvm)5v2Si8b~`4Y2i za3nQ(--Hf36)p9z%`N#TXbj(0-B6R0 zIr|MB^awI5d@6$2Y7dMO{)o-O=Uey;jLiw;sxo&p~j-F3H; z1JP|fP{#+b*)Pd(@v~&t3Pl9%FW@O;?G9=1xA(fOcK|E-S4^Aw&KldEAMbMwX$XF; z&Hq8}Z72Fy_ik*@#8ac?DU5e$N~-%qt^1ZfJ>%x@-7z(A;zay4xA%Fv?EB`1A@4u+ zqw~OQyLzKvIg01#DzUSl99bW!*vbU%KoSz9*1&PeTT@MP$4Nh<$c5bueySRDU8N~;t z4KSAVt^DA`GH>Mveai}K+?*l9HZ0Az{s*=n;@9jl{_5?h{~n+I4S%>D z^=0xjjgxn<{*)JUt>b}cSf04ZZAK0jD zLzbidGP$q?7wWIYqgw6O&&B1q^@sJLq~GT!{VtSuWAa|Q<4CzU^urVe~jQ-Vb&qlU|E#J~h`hO!kgN2-$Orb1NCQ=SL68=-|4P{O420xsU z$Pd3j1*YqF8kyHMos!OL?NmMuJDVRYezW+Yp(Sf7S`ym0Gt$z0>sc*03-Nbo>TC;> z6#Otl@xux7EHJK&F0q;5Eeuj3b;cdPNXGyUWHd!O|8Z=o2`TQC5buKR@McdYhNrO@5a~ZsG54tcPDbT$~>@p1|MA zhbfsy0-}i>r@V~n{cpO_Ff4dK1&S{Z$#Xln0)Z0~{xjOl z_-~xKX3m>(LN%-+%yesTho7`A z%MM74#*f2s*VL)LnXA<`==w0$V0;$UL_?zgt{#US8dO9f5Eubl5U0Ek4?LQOf~wyy zza$_<0-AFGXvZlJOBY-y<`h+MU=blf6zaT{C=+W-*aH58xlX2EV_!i%`WjX#H-~?Z zCP$x^^V-=0i3kM(J|GRdxi4G|OJ-L1P$atxz!qA7DU7qt5?^>bqHs18W?Q%qE)Wcs zRW>NR7e7t^4BE|$D)1LYUuU+87X$qeT;%bf_`h*`AlC5f_!=;q0Ve|@%BX8WcxrM@ z_aT~R)da(&pnReAJd1iDv8eEng?w&(p*o{Tu#!QTaPd_S7a<=yPEt2mH(OqWPU>_*R6rV!QcX3YJ;>k z`6U&+;O|V(=(Eo!&-goZn_fkCX$%rWIdi|PAKY6DABJ$*r zjnUr*9u@u_1D98g3K+xT`HlfA^EE6<)|`92r7t1WtIHM!0+czMxu6>F0e40)YY|_a zW;YejQvGKvzYP7q84aF-{!b08VE@rSP83Y8?!dPKy<0Ofym76-Sn`6gWIYZHXg&A_ z1=slkRu~%d%jwD1PQqU}{9NMZ1@WkGI|nSrY@)Z{c&w7cbO{Qd{X4`34m)o9RluJEIHCE! zibwOo7Cv1#2SOLVGk)hq(cziz_5rSAB%o1;wU1~Ajvoh;MJD49pThQzD2rwETa<@y z(T8K>TcQRmH$~ZTL8+Jr;6Kqti0Br;ZsY7}wiyO)Ku<%*Ub43@$vSdUykpT=U@wnT zlWP`$-4uS|9lNC#|F_{d)L%f$q6b47hHQ~uP*4)$%l`xP9e>>DyZC^O+OeVUub{6! z4t>X`q3`~;?Ur_vzS@7C058oiDyyMTt9%_JuImjrum6YHD z%Tp?4<)cW6Ep~DGY<<~qaB3b_=g=5Mj4n~1d9C4855HvOYtT{F3zcQntpr9C)<2bz z7pJh0JN8Y;9F!Kb%p;dk)1PQN2l!^`E9xpnzQ-V3j?KOO4ITb1)KdA_`x}-G8u^?R zuPH#Q^NU}q$eVR4a*O!VlT(0>@OFhm9BDq@uxh_qv%is_Sp zj9n1=j#G9i;}yvzINJvgaom#kp^?;(CXY4f$2e0l-7!urdhCYU$C z1aq!x+>;Ufxg!&$FXUe=Xt)yFIlBT^y3MiD+Qj)%48hr0_OR(32BFKo@x-%e(F(e8 zFo900W5~aKK-tBC0shA9;^y-GLDyA;qb{!by?7AeC|6*Z+Z=@oI1?4a(^$TxdP{j; zQ!lnvC*MhvF;UG+cz6X{2|L6fjLdajlkNXtK-sew^)G)rm~&ZjcTQz@u9ogx?T)VM zB(L=)UYUQ`^JX74|1cK6t!x0J>M}?g6c!W(hxV)Ri<*f|p&0UWB|TL9aMANI^L#KY z3d2Qx4pH2Ffhym4ul+0^J6S!3yV>Cr@ffZpYdR?xMTLKxrS7vHzNc zGVt5k5b9!RU)*Kb#MpJ2&+5yhFXo3deTGGaK2<)U&tn2>phl85HkO~RVhPN%P({@9 zs}v3j$QyM+L*y6#loVAL(cT17vi(9um|eH_j#2O$v?)~=btzDD;SqS+s;QDBU{Pp- z!<21`k!6_);N0PdpT&HhT{+db^`un;i~D1yRGuIAC=2WKC`p6Ir{nP_$cES#mYp>> zEIznO7-6$f^&7khjhaioWHt+C--qn5{6!GZp2woPRc!-P(XtD_bpct$Y?}3L>&EsW z8_jpHg}ijqY-$1S0K{6i4b%T?ap5pB-{mS>MnFATRu3JODGB&=%=1)C=I;mhw zSxI0iE5Mc@2_SGbz;PwU{0#KbsC~!baID~DCXO88 z%YZu{m-t!0PqRh(Z-y5aw^wA(b``%jy_fkOts<0C2$cB}*rF&<(}sG2$k%{Ak!&E4 zCLdgt9n4BB9!24+`9A9zv5JRa1`>Zzk}HaMykp0dXidCG;SlKUIo zApN!R-Sax|9eZ`x_%`5~579I0+2;(0olr{Gk@{@m!G! z;z!<=cz}vO$LasqME~FAn*b_K+>y#jZ7QG(By-vMll+I{$&OzWq}_bRM_hWN~= z83AvhK5y~X3J-XF-SocD5nkA%KJz(T&xdGn*f#eCbHM5k7dl_UepWNinp9^j&$-PX zcHtKiACTjK?TRxdVX>?Ka7WG9%<^4mm?&Vx5GfL=`V1y7WIvtgXEG7IgVCq~Xa@FS z@`2UK-xVj|hZoGwgQ%r(!tAj@Rp0HMipe+G{GIVC_}g(s*Ze&d&!pk+hp;r~zpXzw zTLM^*s6YO+zcaMQTYo&b2l&=~t8086*BobjKc4>R4!)zX+Af)Ok2k)AfQI2B3v07tnifvbEcbbJKN#P_#@6>MV4bmzVhE)3;cUCagA`eYfi^UTW;fr z9{&d&HN!G$u635TKqYYOw8p>g;QRWUHoikK{*_=WJ*tL$sD=W_djV9#7cA9~57lt4 zQVm0?XXC~}Jj%OoBK~H9Vc`(nWQ~8?zTUI*==CcB?vZ{4q&SF9lH`EO$OA`uMb3R5G^C(IO^92UxECWexqyoUy5ha=vVH+{@>QG zoR0;Q98tfH+S?i0<1YU#z_$Uqvn%`8`|ab5@5j@x-NE;DtTz0l_3NG;UFg^TqF?Dv zfIScokUhY7K3+2g@o-p;Vpgkj^&a zOE8&aGeX;b4~)3m!A!S(88OY;-cd8kS#u_I0Z)d7a?}bIX~i*{D;Z?ygi;eWSMUuR z*g`1QqT;4binTaiu@)%BDvMJ)E7o_EVod-ex=Bx9ts*o@_HS~#IJ|VSf3fNi^Iz8i%e^?;-iSvIm@ZAL6(UpEFz4kcc`|q}zcKP$fKvddTuxQ?8uW>=!F2sn(q}u$_opx@5)hQ|T~2uXf07YXiX+}xn`kKx zI%`Znk(Q)%)=tOWGflYXAeMq!?3m8n zEwaF+LCb_Is?OBr?prC%U8R+6d=LDa_QaK4%X{HfY32QY#UK9VE*oIW6h7Ye+QO~C z*Lz*p_&UZNXM8`NK23Hnz;~VEm0#NV$>V$BmM-+er@L5D!smf+T{rY=E1pT`4;+(t!^hLFDO{pX`gL3AlgD?zoZ;G*H-ZdcBb_Qz`H&52b>KtcVM8h2aV+;zUi3MxWSEe zUsr3NAezD_NZ?ZK6O_JWgQpZ~XP;n#Wwz2M_=YlD^=xJG1kS0r+u0}RoUfw&gA1RA z{I^1PcBNm(elxxNd;k0K0QfIm#v8Z2n2hxCpAX)$0r=iOp=*2{*B@tmKc0T=4!+a> z{R!f$;{mrebs_(p$u(+Q(#k)0x2N*2;{k2RwV#nI@c?7x`07mm>PqZIE(!P@vTTX@9)!&qvk(-_jepfiIp(XMaM5KYl#=`0K~3U-$&^)%x+O)m_MYROEg8v6T0C z{dkJ4A8qB>+D%zM=lNv7IxENT#LN2lBg*=~l(L?fA9_|}7kG6QUj{GsbUcaEkEg}! zM;owI@#O@G)}zV0*y<)xf;$6tEaJ<0JqCiq$m8aI1w*j}=~}&C0TQr+dG-GN&Kdt_ z<%cqX*B^DgoP8LVxedTG7>3N%HJLmT7iS)?X1YVW$B#|6hG*7{%P4=|pRkQXOIE|0 zX;WoA`~9R>T>Wb0KI%8B{{$w+jt)})Qf68WZE+n$wapvV`+7%*3$c0~iC38&>xVn> zKLh_WXV3gMvNQX}+S_S=hi6g0+TUS)rUNhHKLXdoGb^LNL|EHi>V5#@1v|zbCw5Nt zEOIlLur8Ff0p&$FmWzDE^~c8Za)oCwZ+0f87>VbFvGxg`nKquc>uMX@JWL}aju`;9 ze4EBGl(oqMa0%KQS6?!IS^vg^!My3LGnQ{kFbf3C%p@?+Ndj~B%;v-mG9>Lkl$8p< z%IKf<`X3v=N7fQQ3%&jpXQ=K($^aPYukqt5npF64PmhN3uf_3W$u+XYK>~jJGq9Tm zE|VWGLbWx$CpEUYv582{rO3Cj7*Myr*@ACr3jUM&jOt&K|FT}jlfr{V*Vy=}{S|g% z0y+hLQRjN>$2H11d*;i)E(`SOyuX6R5Bo{1@8!U=mC?BU74EjbG0EY02aNhKU-Epn`K7$L#WY5=9a?#b_; zdnCWZDZmt72yu_(cQ^%@!V4kpB)=D8yoCG?*8-f}Iq0Scw-MEV(zZSNTNUD^--mz&*StF_v;~}pC$bXVMU1}Q@yQtS#f8z8h>ECnxvtkwW&!w0ERSKy0C#`=*L5O;FQ~!*D-1JJ&KOe13(m%aw zu6A})|0sD$vER`dRAzd=qkB<-zoD|mHAruH^B+q+KXxvZ2DI)jOFzf&cVycqMVcnl zLs_rl$@u+l6zf>~-K=*F>cHKZd%!a%#PoMsee8xlb`5ew|6z|{t=JqgnPuTz!`O#_D_AsxKzL7m57BI7^b>FCCH53ldh_}ZqyoRkHUKU#E>@lnTw34L#(0~d2Rx&UXOb)>k zyv`E5_GdI_bDu7fWyh1WzijjC6^q4{d|Tzm@L~C|T$Ht?dAev|CbsZW{6%{Ud%20d zmBe2hA8dGi3zd1dFpey<$ z?U(o+6pv17;#j6d8u>d$^btgQKp(-wqR-ODV)P+#1P?o2f79P3ey119=ryfsg{!}w zA#|rv^%^b4Fc*Q&KY*`Bt;`N%Z=~dTQ?=p`{z8iNtbzGzEi2X=BQ7Pm26#PjX(IMR zHbKEz%aLb@RYFK7<$@wC3MzqhSlGBb)4932f!T+%j2$Bu9YSbe!sa$iAD6#vHe!vn zEL+7v_gJ=?hh?j>_0WQ!LOWLU^K;oMx4Q?E_riayz6aft7qEu1!eEog$#_m);Ovlk zIJu|MMiqFB?WbeS7oGet@r0bK6^U44GXY&t1!KvuET61r=-erLs1nov2&S9x7yE%T z0~asI9*_FMLS& zS;1}rPL#>BMr|C*33<-aB;@aE{RiIgaYgn?SfJKAohJ$TxF#DsY+;@fZ*2Gt77nj` zO!M!!Hsyp!OL=?z{c`>=a5FztW)|(IstY|9&h8N+2 zQOj+qQI#z6!>8msKP9<$G5-p-EDpJb&M#bCd_dOvwqPv^t3mnZI!J|72Hp*FiHPQ1 z=6pgoa3^+<0*!I`urX*(_{Wc;-|#4c*`?+hXoCD;&PTkD`G_j>$#14JkD*#vVJ%Z%Xt8m#lAM^7K*+-N+!f= z1NZtM4>%Z`T7_%h-xGNdg(>o2=@rOBY-~)(f!4Bc(^A1YKbTi)uD5Y6bbbgq;Np3a z10Mo?#9-FFypszx-v3?X9Wn0Xs;NK=`qH4fz)Ra(SNsilVOYn4ENZ}D z_T8uz0VgrKP9cB8-Wqq9XTpuSTkPBYiT(l_6K8S#gd(dfE>1qDv$%N3OedYUMUCf2 zvHsM2DAAtP`KGJy>ssEq$&mKXxJRy0`xY($^-?r1!Q8;_BCb-aL!XKg?b{-4-^R)O z5q*m7e-$1bsu#g2tL!LkBmcBLjoQ5m<4!9k zQMZp6cg@mJ1KdL=t=o3nUj$-{tzlSsgE_%Ch|h}o6EUp4FrBN6O3o zcNbJUHvZqA5(pQ}>0>IH7#Op^MK%yyg(30v!=%((mQ>i3Vk)8X0e?hFDUHO*^mH2O zY}^CTiImwwm~8vu*57D-^1tN&{Skfcx&JpL(fzv;$1eX5_60Hw zz%zyamuLBZIF2~k{d=P;_mBG##C+&cX>_;pp*gxHciGz2#Ma-B+^zLD^+Ou}?;ya_ z_8?CXHfrC-g|zk{+?5{Mg9$dc_5q*14>)pX7_|vlXM6AroS}C4;Yp28W6c+A!ksz< zr)eqisUwD<{|~or7=U5jyak*o3{*3n^{Fl=j0_cM;zn`GZcunCoVa z&ug|PH7YNi3d2*@_5#^ z-)wvPz(V2Q&i*1NnT*O54N6av03mA(O&( zWd>~KeSU2-D}URj$4$S``h>v=?eHLyI03(6^8hLR%j9mXaNrfozBQYz{cPXCezxx< z&7H)@I3YWX`Fl~E8($^n&pDKz{RSx7K0Wk_H<<;>g7J^j|073#-kS7&nQ>*9WiCN3T*vPmU43qM!%#P=7p9n?`>y(qz=GNrzg` z5KHF9H}5%u#yA!G(=HpIeF2u|HSWR5%Sv6mnaqT?vY2Ws3uc(7Qx-)jm4y`#F7e9# z)DH&J;IUQkSbKc%c==aJc*Hzh75}pF;ApQr+$8d;))p#tN-?cvD zP_6Bw4+W)E*5)zRXAk`{0Wn#!;blexCx%bQ`c5b_ObGk*U~Q?g*OR%(9;$f^kv5CC zelx)=N~6j+Sc}vd>IG#MC8;tUFVJ`n3-nljsTE(Lbewl=^w+g_C*esA#*Bs}Jbf^J z;#Ai$!c#yzGd+mUrj0iqFw@BE3&M#F=}`N4`m5kBpkP{l)dx*%#nc z6oiao3T$t(EZQ3V$2KU8V5igQ7p4RSW?TGubN+jg9i)yy$GHhE9E@`gVxw;82HDrV z6ovznq`v)i9Ep7<;PJ05kTeiu`J$nCbL9pCw`7CA-Dw8y!3CZ|owaf!uFCPI#>fMK z6%JeoZ^UzqZr=k;kYuVVjxj8ej7`KXSe|=Oc&1Y979MzsPT1d~5guzi}JXi5E_u zYTLVkMRGu+oF!&uqANk${=yKJ$^TjV3^Gnc5qn1e$fxq3wF0ZJ=U;jtQobaKc zM(rv1YaTZD^V~S|Q66D$%2D?`M6G(`tg}G{w>r%O=RfgwV9|U&1gi>15`{);su(sN7${Z$zc^c7U~K zKaanyW^Ni%sWGA7?%c*>=}45Iw7oY;fGZ@*%e=DSdvZlpT*8VEtBOyQiV5<>QLKa@ z7mnmNg1l)szY*lA!zNFS+>b)A($XK7(t}ZuXo1BD-*7&POO2E%`i}XVeBz zyRZkYaD)}c07r3NF2)Q?zt3ve=ZTZzm|@e+yv%MFeitj)t3M;vvaJmTyu-FmJdfYl zR>$Y~jcvU@A8md2BelLvI*Q7(VHmr=nV*z=h5-o$&XVAFTvDyW;t%fhEO zvVy6x3MPJ*cSM5a8!Koy$EskW4;2iLuVB;9tO}OSjH_Vm46B0H>8!wrRZw_|Rl%l< z`HdA!{VKn)2cEB>f;}ISIUxcbqnhUnD|u`1^C5O+>0ExJyiJ_LZ|sMs5-$c&%bdgN z#g-URDlg|l?9$k;@f&Mw9nEj7vF=j5I2AS8<6FjD8Q;>!kL~@ef>>~rJY=qNczduu z9veFsRD(AhnQA5+$%Qk{y2$E8_OykYo|@Eah;00Gxs3xPtp?Nc5#Ms zpy%mkL8e|P|4gv!h4SBmu*G7XU&D_S!=R4e9Bj5*;@>qJjfrq+C{nY$5Hr2MbD~}P zh#HxLlK*bw`(R}k_~xQJMlE&YvB5VU+q2X@Rz&yb01K-TGww;mm;17I2j5%fA5(n& z4Vi4r!Dg#D8f2z)X^{6(7?LLo|E}o+e0Bc8u-SsII`~0nB0^j8h^&cT@CWwU4OB8u z93WI(43tAz-q&U80WT`Ti3#&Z2m!u80!-vg4$p)G)qNZmWk!6_frn>q z)m>mpDu7_5+-Ca%AL>dtBq_Y%=OhtqKsg^t<%%|88*?N+4M6i%Zx_(S6CvP+xl9pZ zTTw;)`4E%p!XH-kaU5*cEh2Hys0g<}4`ul@e35^FLMW95tyaWJNal$C(H_5SdM&&| z=%teFRbk2bqoj}j2`hh8j`7g>qYM-o^NWOFXD1O%2nC$%?Tvd*FQuE}=oNB3YSF71 ziRM_oq3QLZ|6|iD*F1*wx&`e?NiR*HEvX3fSS%iI>#GB|YkBG%Z?)x!xh0{jeA0=j z>-+K3sC`-SrxzdOQ^}y0AO+Zf?QN z+EixosW@xIa){I_f%rJ9#KTn{598qp!HMKm0- z;;F=Axxyp1ZY0JpozeIay4j74p&=>JAb)U1ssO`sX}~X0fz|#!JN@mR@_c1LkG+dF zFAeC@Mf^qs+Od$|Xh1KmgZaK|zrW4P=jppS=JOuy=KFunZ{lk#;5XXM6N8g+w)|vR z5rMxcN1jJHHc2Fe!*bx!O8mx|h!s9hU_}+b`x)B6QHVLkA65Kd)^`H|apxD&oj0Fj z0HDu{WitmK81Mnk(Oe{ce1Hz?tZ&lQYit{YkCYz#-0A5&_~HY%Ev{}zAGvvWNb_iaE#BUZp=^wdCXZ0}IQ# z!1t5&2V6A3?Ick64!fAqUPyB(2t)D)B;C2jq7G;jo zAE=*o4DHJ(h8?jlE#lbzz|9)Iqw@#m{#58?`2#F0*&iT%KJETM^tO*pFZUhCkY3lJ zJt^tcQ-5I3PqaLB?GH>QojxglpnYbN{hHDrn7HrL<_|3VG4br|4-mZnra$n|j3hi$ z`U48j|E521)sKW9KVg4h{%uM2Z~O|Lcz=KZeWL!ruqkQqIIjLc#q=aR()k0#Gk`x}0vKQMLir^X++^@qpD zAE1Ag7r2Lh4rY{Oixj#f)jO~v#=}+bM(tne`BaXfNAu#4_i@gmi?fgZ29MbU-@+Xl z@wg+jyZCLRwuTSl_K=2P&Y8uVXAP(eA?6?2y(2QcS4+s;#Bhppd-3MkVXF{q@zh&w z|2LgGy=7beO3R?kMfIq#f8bxN_8D{Y;)4}F*J9^}e%sAU-R8HlqrDi0!TvDoo&F}z zMP)vhQO((J|Jpp6g&xuneNf^HI)0q-11&#OylAA_UqlA6YKbyVx1)>+F$TEkL%E8| z&i5R;82A(xx5Kw9syJEpWyl6rL-D^5c=5>KeC*F~GpY&ZNMM+eSLf5gYdQdG^9-ZK zwK_DR+M)NGf7^=w3c%G3Wh1Q%6454IIHMcyEusPwhgnXX+{eL8XMDGV;4X7-__K%s z>MQiNE(S;NEGK%+>ABapM!MLJp4hrcM4f$(4{f2#C=%=Fnp{!;O zqiVUaCMJg3IuANqy(PAx$?t@;0Zm#2m3at#O7dFyAZ%+-=qrI_zGTyP5C+uP{;NA& zbD6FfqxODm_oBDB=`p>hPD(@XFJp%AW750q)+5vVRh! z*8I=+66pVOcj#X$^uPT$(x0m<<7j^xX}{Ao?3mHK;^s6oAKu=H=F=?B((_1N$#^Bw zKNFXYpf7PU-fGkQwbV49R0sJsk09SawB)-YJ-z>&L~ot%chz^(*gK~PQG1c7*wzIC z4UHqpOeP}K&QG!Y^CPc+hhpu#=vC+D&qd@?Z?ofnLMhQ(WnMxZEed^%D7x$eWv-ru z&GH{p`!M32L z>?6_R0Q#!8?y~8jhFJ#iA$UVk1jorDGtU>y`2|2NLF-tkyJHi66jl(EB02jRDAXao$ya!MoP93{J z7x`QWK!L_ z{Fde?J7yzM#mr&i#ma=_Up?$n54Xm;BG3SrQ z){lmM2|KTs0p&5V%mepI)=0qRg8GCrk`L>>z?lCYx^L9Jiod}!*$%7(`han;SsDwdW=Rh?f-`N_t)1BJK z?B7`W2N%;p{L-9a-w$__yJ)ZXwCCT-d?O$vqXScXV*-A9gK$<(Z*s}7i}%@5hxvhd zz-$ix@okJtD`eCx&x2D`iV3n2$U)^zdIyo4p&vp6fYJN-{bJh-={~X z@{0MqJwJNkb=n^69Iw<)k5SFT#5p+Ca&St!CKAMq@iS2R82jyAfpHx+g0(O*aXnvu z@qhGQBx-3+(r%HcJ8mt?Pf5We?zabfPg1(Lbp<9QlfeV)=HQX>Ui1&{;yunhw~l~3{;13r!?kjMRh@vm_bc|sLH72dY-@vnE-xN^0^r# z|FU!}AAgTBmwU!F$&nwgr4HSDjz!!H(-k~ zSVZ2egeDK4cLoL8D+>lVe)7gr+`w~T1NRi0JxM(qc?j9ADTrS9a2(O^e~4rw(Wm~C z-$?Yae`R*=C1mY5evvHmKl2$9e&QebjfCH|l;4E#zem<=U%Y1Xf2?|-&=a0Bs#l}& zs(STm_xLUnV4oQgc>!Nwk4TDlgoVj^JE1G&As?+w(Y9_vb8d>ZP3#(){meurqj<_1 zg+0Jv56CrPw(1w~Jz^%{H>Vx9yk!d`kK!I+y?R_|A9v(|LNS(MTZrLKWBGL%SoSih zagE#DW~|)QxXUx=b>zi68ut!5$Kjam=ySkWzN1gGxvkIovMXDfPlR|Q##6@pi5&ml z*;N~N;7jv~hrmQLuJX4#W{ro*g4K_{9Ns{RnLCu_cpEdn;IQYgNf-=-+*g!Y!-Esn z`mlpfjGtL(e2FuWYvKs)n*DIuHkNvDd+Kt_t#aQMbBQ+6pM+is{kBL7>?83TePe=|#b`0C&93SSAv4c+MSf7DUF7u5|#H8*=*$bt`t)bM-XTn|wl^8hKf*%!c>B!MX>{M5Ahtz;wn!`ktg05(0PTGC?eyS;hYO+R z33t>L-UEdYx=zEbVk*!I`GCV4bj>xlH}1)x=N=r7sJdR%H2VvESz3V^LKwk0#pea^ zzTyaMrhNlmlCZQSJu92(vkLCyxC+Y82i#+-3fZPRZM=gF>Nl3}i|}kR(ZJ6s#Jw6S zfh_uPqJI|0|6_^2gjOcw6`k7vp(>;ZXf{NT3IcT!N7=$SN`l{BsJLeSw}oJ%@i$eT zx+N&u|DZe|>6=#P;^OThE*qw2vzLs=i?}?d66Di~3o^{hkSDqjfvC>naxV#pNev!i z2Le9jAOZIa0Y8J~B_v>nB`DzNm?9%21@+;%M~$tP9!}OcBBVcO9C}Q$BmunSR(PTVM0Z&HUPz7X2>Va8vZVjDJA$b zXn#TC{)Yug`yYZYWBXF4620x%o)BansyQqsdJ9n#IfD^`LBT2amWsYM3w(?>yyXht z^a03sy^FDoy39$+g12O1QN?V>`>UPCvS}G* znf~W1&8E%mI2p48X`LSbp4sLHeOmkMt-0JOXO3mY&Ic@sn;#49Vl&P>nr2`Vs7y9R zn&IDAX+BqTd1hn^aHpeb=cnuWlZ-Lx#%J#Rh}9NP3&TEvzl?o=NfUyX_$~9GsBtKe z_AwN$Cdz0M6;+&$iO>zxxll!IC5^{`n_47;9rJKK9}=nuQ=^7ng&ttdHf#m`zHTq) zM)U5}Q=n%%E>MkD9${*9bf#T%=lN3=mO+uSVK%y*9rj@jniZl^+ghVS*av`T0MLV` z_hA-w2{>GooEPl=Abt?0q-@TyAwFkyS-evhRd08FF{n} zIfk5)FH`0PmPLm_hg0VHh+Hted#J9;Y{u|muEX;s0_YUz9+(5DH%LVY6*Tj_zSssE z#|Q?e6qE?{M4@Q{MlmW$d^U-I(=F7%I_yP)Duomgc`&jEHL0TjP}7Yt1uP<}I2(z` z#rA3voEDvqqi}sM+Y92wtGhayx;U&YHXj@qj-BK=|DDP16gR`(V5Cm$jTMS)2_Qxv zO4fJQdbkTm3;nEoN|_H&Fuq}mn4AwM^t3ywH`H5N-qhYH?4f7ZAlZj|Fv< zeSwmO7E|0y;>6vuGkm{c+|W@Xkevyu;b`W5h9o00G9a&K&dlcHx*}n`5kaU?RWFI(TgO<$c&ZUGvM* zcz*f)QS-|yN&NDaBlAm__SJ2(<87Q^>dHft~xKyta93B6%Nx&wyQE~hC6He zGpEeIR@qeWH^iQL{+y$z9`Pv9JKmf+L55qbnz8?>^+=ubML1BR;~Zd@|; zd#9htc|4e>IcA%BI@Az7$<|*j+d~_jJBvSC_7N%V?rGdMVI)I58HykqPKkHU7+8m^IQn%bdEfyIPzm#;-gNV&UW_m)%gc)|?@E-HIA1CS zCXSDt=Ofup8!xu3nHl`uS7Rj_o@zO2JDC z+UL{7&7U@2ECWXB`BN`UIrtE22hvusGeZ}&251#v$V@ga3LG%N04vmQ0oarVgV%fp zE82^9Q!$5{>1@J}0(b~B&gA=LO|C#rlkq%KV#?MbQ*xb4 zI}fknv4ojaO!Lu3<%a`qFdCK?GyMbE&@-7H)`*}U#?E%jFcPTi%nW*hM~2177=*G zXPrl6z6WmdLYI;)XkU)kJ1hjVqnTrT zL+u4ZW}WSln9l}GUnoXvX6KN|3+TmYUx?>rpq2+%{=+*jk*Yv6bO^-~kIt+3D6?)w;yc4~C3VBLTFU~$WdPFnM0BN~mV3hI?g;)?D zQiTTtk(vjQ0{GZMwmPZD`k4MIU@&N?X#A46 zU{HYsgfPaVi-obdH;EtMN`akUZ-iWPTPCdQ&iaWX2MoOE5$z8%F<`JaeA>GJS_Q_e z_+Q-m35ftCNN;S99yg~o5lmF@z`HkKM_amkF$QF5IqLHlihu+mpO1G zdP}@FHNEY4Z_y<-y{&k!O6F3b!Z7Hf#kd7u0a3CTC(zs14SI*N?tZB5Ns*75&lU)bwxt`1HT{zd-+cdQSgT`Fy#^ z_R{%$$nBAQzAr+|)qX2jELE*DRYZ_t6R(IATnkGk~z z!&W-mNc1rBHwdVpgS4qHFvCvgLUJsy^7wARb>M=WMx)vbrEcZxDU{zvF-9#j1FY;k z)vsU56;y&8z31@EoOXpWLw(69aQE*cma+lPoBSpVUZea*C%rO)6u3X*H62z#Kdkh< zTy!fu<-No3AMNx#=Knn;wQy@2{qz~dVH)byCdBw>kPc66J)Dj!}k( zMY@e_0u(Dk5sSMacdv*lt_PFdNI5Vku1~WwSEP)n=%1S8n5OSHoUc z;~VZdyIXsMahGj52Xz{KZ~*YtI04GjryUQwK5czk&FA~9 z@3XCJ3L`aDJA!kZ=)w+shlh)Nzk9)s{Pjv>bJqR%-hAR8@OQ=){x-+#KIPv6lQP^0 zJ0+Lz^GSS1D&Sx66ysg1vGEFHU3~DBjd)b~GdQ0lKCFn+Lc3-yjV{;nP~QQC#zF^g zNL}nLy4Y9Vj$q@84y|t$KD~@(H}qzoy8%#^1yH5{V6HQ!YF&O+4i+ zNSIN}-E7ll{4@5b^tITkNHerk-+W1_Z%2x!-0($+`Z~A@5>e4ht*4lKu>#_35Fb<8 zOunbF$2^*#YjrT^EsCA#;x66p@ISKq@`PTbvgIS2rl5F=EC8^Q*|=Y!wi%g|X4{NJ zKypa1{_?F^bwO7&rf*XC2hH#get`FF|D20?F;FG?=l5Iwp2l~};I8qV(s}*m3JF%( z>o1RZ{!U74;Z1Sh!i*wd3&$@B-5;CV&2V@fbfJx|mop#85(wtB#G^a*1f&bnzuU0b ziCD5E3qAuM?0KE7)EVF8kQLXrA|5iLC3c=r3Vhea$3tYi(fEQ&aY3sXzGHCx>T%&) z^V8ekI!_T~iB80_N!q^l^7_(UXdYi?sQY@bA2BYW#1f>E&mmIU2 z0{;a5K2kg?0ix(4i{CXp_MF>odT=79t9VmFWe_%*@R0c6$Dqf)!Xwb*pIi}cC-NoG zV_1wHfmc7(^x$j+rvgg@6MUnsY`&)9;ANH6w-nH;q`pUZW#7(-F|QuqjAdU40%Q#A z!gbH}hUnvW^NIC%A?q*(ZJbrG%jF*KY;1QSH?Plun*J?0K91z!4H!vi5wzmdTpbG6 z40koQ=lb^;?r~1M)$XYom%&eW&A3dw;O3~v=NqtNR`ZGf()Pq$UCKjJO3m=z@?w^L zu~)RW@Ehk3i!hd1{w>-a+J)4?$XCJsFiVfV|I>QM1MqCGbO7{<0Whw&g~0mHDFpW6 zQz4LPA<#=BV0FY5kHAXoab+V=sZ05bl!8Rac;uY+`p(4uPwQ<1fb-`P?16!G7&qO@ zAZQuxCg?jbcF`ul`diurwmopx*;;-%79&1+4L|g3OME^XN94}=Y`$G6micUI&*^hu zJtU8iPjO`HYQD-I@q>A4s7D7d@PjLvz$S@G^{&1S`Mx)NB9&gE`EZB+%~?@;lL?V0 zSg~MhCTv=XYEt4dB;H!lMiqThi`!M~33GLp9q|>VWOeK*W=GimQ1x3z?d@bmwAI-> ziTP`VO6N+zadewG_7I|v#cRr6iy+BKMV|DY(~0)PJ(hme_Qc%J2z}D;H_DVyqxQ4- zyGm>b*v!c!Fh3+JW{bJA@uNWmqWDFbGh8#hFJ>;i$Z|k}7p~_Ab0nx}He)i_s96UE zfrv6G?|hoky;Ek+7X?6zAwKFdXtgD;rWJ_Gz%@r@n%CE$C5 zXh7r|+>9@20=~bt_$iM5XMS4f|4GGrOV3D0f28+W^hd_$$EE+^PmKN&@a-P`b;=s; zi5%EcUjGWN&i0m_gmH671HI{G(29uTu0`A~aCKf_ln09{`xURg<3vo-(2DQ4+J%e8 zl2N&f53Z10dpS>vTUPrE@KRzyvGoQjpJWR1Nk$-_WDN32e#sm>&x%L$ij^AY!vDU49`aDkg=p`aVFZ@pE?9XwD|H@ z`M?IZ=gNYa0$)e}z%3qg8kU!qTxTrVAH*)YH!Mcuig93*F^|J=w}*7pE+C!9AX5FcJaZdGW=My* zA$pB%pB1l}RS~$tJ$Mb+x71h?8r)vI-MC^qe&rfV8Ut4p1q*%_%o*t18FXDjwgg|1 zL&GE5Vc9n?J~+#rIVumGEHy{v%{n)5MNaV*xq%xzcl;T4%b$ft6n>Yl<5XM?jLM5H z9Kw7tvrWgF@JK17CKt$yPZrFXIk?T)fI8eDR`|IOAULtd(QMm3pL<$*`@E7G0{i1b z1dXZ_$dQ&c#shtvN)Kqegh!GXwLBCept6?G6c2vUUeDnt6TNP!aAQY7!{NB?J2>%2p@1jjt**g0Z+Ar2SG+w5QMEZ$z;YMIua ze#pZ;52X!6X~mn$hoGuiXQ19(2U>tnk;xVO5nZVCt3DT%!#B6MQNuMr^q?_0bJoTz za4b=O50km4<2eZ-aqcHJwkLEi+NerSK7Z=0Q@e?8mW^*Htm^gG%OO0meG_*9Mx*vQ z{IxL_9c1;97~dMhc(P!u681V_j6B=?@F}#g!8RcnKg2j_#a|WFp}b!tL7fYz^8mFM zQ2PM&d4&2jRPWVL`_MRtf;ylBFvyZg&7Fc)EH2cjs#S=m9{7ZIaqKvO0bUi8nVS$HD-LF+H2UMV0z2q$doV* zObt_z(>B@={T@I77bXLw?|vC~lRFaKr2RRL@65+7#f;i$DCIGMzlij{RrWK|=*P(~ z;-dLZMekXoSD;Tki(&*{MvNTJ{NZ*eXYD=Z_8TK-8NLADGMliiSIL^Itad`Lh!WzV zi4M>7$D{v%eo@Z^k}FMqCl()9<6!~XU0U5SYZi5_RnANs2{`9lOb5OGze8Z_2Q;%4;+paTazLICBTgYcAqw&5!athBzN7e0YeDu{0MU29p!hGL zGu`07@0#t&e9-4Wc~SJ16r9KNIjvsAbKV7Jd!GYkgB8<0JA0jGw$;%UO6w+9(23FX zSQC9+J+Js}f=3ITzxEym_uCX8w6aV1KsTinW=MK+C zMTrN&!2+e}&7os>A=zy=28+P$?!dTgY`TTKIb+Gw#T&}b=1`1QO$BF4Aq|L6^6^Jr zL^i^3W?pmIMoBe}BmE6Wg5iuL<kh(hSi!q<*ymbaUT!*(A|7g%5aek3)qpWmNqBk*;utYkX>E+&a|natM-VwOHm#|u2r0^)+e9PCS#5EV%;2L z{yV6~sNJI~^Wq~`X#(Q&aKl1;R(iy%S%5|y7FkYn_V2j%-P6Adz*n_>T)=+@*kXVq zWs*inGT<8F{;3e&r1a?+Nd3)$JKR)azoz0GSu|v0;G5YvEq%mjXW;rmW69t`8<~P?3X+ZNzGRi$@cs{h!-a*by{$0+&o1nCA4i?;rkNm($uU4V-XIAA+ z4UEjkLO=+3z$L24Y-;St9K6-2SqZW~iMc7q6Lh9%pA|RH?$zh{!E2mNo7*OB{s1TA zmcMy$J?8+7RqKtaJMaQ1UO2cND)^h;IoyE)jKPesrjcI$z}+IPAtp!Add;kMjH9%Dm+fuc4#zBpUBz)$5p0&@JnFLUJd)xQ_e_wt-GUx2G zKi67&?X}ikdu`v>-~;6KS`}Vv0>HXCS~4C-6`zC!!K?Vd1+PLD zyzVp6xk;$Xr(BDaeJwY!6c51#>z?lsOKZrq%_yG)zr@=vjHzHpjYI$ z%?(x83#XO)(ffsAM}LdS4w&*qJH&~-EDOtwS`bRyjjzO4@9uR(PU0fGt3FESohoK5 zVX&serwB|AgODOW}cN{$eb=DT?Ra2c-Dt*T ziXKGolacJuI}nmpB8$4&KSlMe*YqA+4{*_ywK9edX3+b1fCEdcruXI)y<<{?e?&b` zvsiKG!dn3@b#VI9!hRgBxDtS{?VF%j#FoA|TI&Is3t#bFt;s%%lqpH;eOJ4?&@8nM@ya~BI+L$3Wl)Oap)W@2Xb}`!y|(yWzldNu=E6Y z{v(_KzT)mk5UHB1^r`93wnuc`~8fjeWRGHX?Jk#*lF*oGEiP3$)o zK|~qiihPN`BVCa@`RjH?W-A?0*1r#)tH0Sw&()w4c=87A?-wie)VgQZ##-oET6-8i zlPz?Otv)oPwy-_cLg!e&i{I%SyW$vJE$#Erw!Xv~&p>}geF2%EzG~0RTIi;a%XvM( zV6S-+EuCm}_t<{5YgMFrINXYmOhl}7Vh=qm`$ zf1a4!F|`6`iwPbG@H4M<1rL{rUe>%tHPfkAeV^8PqwNfKX{=w&bU~wSJ74Xr>UnKs z_bSq~PqbeQoBY25#rQCrdVLa@5#>)lBSumdL$? zxHXz6ZsKty9x2=7(T&Fk@CXQCvUmi`zu!zO=cloJ-tV}#aQ4$p97zO&gnpIaSxzk` z3-VCF!Cz`bPWSAt?H>XuyWP!kpm(zUD*CM5_9#+V_29Na57r#){{If01mQ}|vZ_Z9ZcdVK2y*+&(>t5WsD$R+F*E6^r`{NKj#s}1RsJ}m< z6i2O<+>V(`KTsf$93m9#Ch4>0Ycu)caoX?Wn*ckOn&E}Z&cZMmu&=heL_}^ zRl!lls=%WiuX(d~M3;f~`VYh!jf$6zRW+mBq9|@_tRFQ5T1ic$%4j}YOP*%TGhGF1 zaSstLAqv+&W>F(WkD{Jm5$_mLzSZC><|XAtdT&a-gT!#h8y+N$iq@Y`5wisU3&fvu zI;KZN`U)d8){6YB*;v}KK9v@!=iOV~F?TnL=V~acgRl>-@_dXURabl5W4>k>tJ=0l8E0?_~o(se0(WtXkw?W@sQIt7Bl`* zz7g$5|E=*wDgk&Q%pQ9kEkECt7h`9I{tI_Q9xfVEcbeJ^kuVx`o3FXCIf0A-1ElVv zN@IQb)GA~BtO+hFprzkl^9=(P#xzJ1Ri zJsd!&jbS>)Ih|mDDcr!NnFg3}g8r)lKL~p{uziFqlRO?F&OXH=KG-W1?W0}x3^X_7 zT(A8fmvI|+O%9qi4;4h-z)i@JPnw59k&9yHC@xVwbowaTNC2~!${iOn$9U6Z!dEX#;bfRu*uNR&4>vC*2#CAW!b}t>=?uvbE*WBPm zhb6uP)&2lle^=Uo9YiKk%U}HB7bu+H z`)bFVS-2zR;?dC3W*1^hz1ZC7HjfU+wO*cI)gAy|squP#RihuniF&R@Dftqc;3$Yb zmDI)fca0ytO6H{PYxpW@K!7o}6EmU|AVidnr>3Zyr>ZGr!lniY!G;9>MRP?t_Rp4* zRWWvdjl@ZuVvWylr3zbPU6tQD#*J5;*f{8Ioic=9Dj8RBs(kX`Z%3cEb<9xfs$6_C zR$u06tsJIbpnP05w6$`0>eH~+N^knp@Yc#~=TmlTp1T>5uw0c(don;@S|eMv(xZXJE;^PxcdZZ}r?zE328DV=j9dYgw+&sgdCzF-3k%YD?{VXUuk0Ty|i zA*8Myj#kXR;RY0FkZ-@)*Jo69s+WzG-R^C|aTXoayk@K1XR+v@W+q#s)ew}RY-8yF zr+?Lx-Klo8au)70Uv&e;xsiO33-M7TBeE9cw+271lHlXk0-DE)$Um)#UiVSFaDO<2 zyt&58VDk#}f4Z80?c66x9Dt?S=QpalumGv@d#3<(fLn2oaSzYy2-0b><+?iF1Hhfs zstg(cm%42j3SH~T&@rme0a=Vguu3t@jP+n-B&P9R>)KpaiEeP63#E094ZFb&#|PZ8 z@gaT`?K(DIrlPrFmPlKeWtHe`HL99oP0m*bTZiDM^>VkokQy%^VqKYwHxS*B*2}Z> z3yChP^>UB%DZBOZq1NPF>q=z%$aH$?UOmiQ=pACTk^TX+%5_{m0OgR-4KZrnnv2DV zga8dya8H{E7{bzM8wxcbJ~uYqCb*21TnE;dpLxt!iLdUCXxR{SEIM^4hns7x&mxud zpM**}A=`ftm0Y zXb&O8bMetb2o5E%_blbQWX%p+cZSq^*@q*qTDN*tl7V{u)bL_GHniq+$FGGUHn~Ok zxvnqe&%pT4q7Cc-yn=;qEw%0nK_s>qX{$63P<=Nq4pP0c#~KUTejcQd!+o{D?NQ%F z?)OpB3jlHNEN03X425#O`zPk6-q$i)wT#qtb_Z4xT!|Myk`m{NFiELxS zLbkqU5q2QQ#5lF}yj*W9|2yDfZ;_|AD6t_3fXr=9 z&`a9hucRaN;LawseZiRzAa~(+|JZ){kKp<{pyv|c<)6D>?wq&leD6c&hcgR|CfW*8 z2jjS-L88g@GQp(^aPTme#DQP!%`=#IY<+X^Z22JyIJlSDqOq^Hk0joBaHnq_w=>2Z z`jGij4S$PMnlJM*3H?^QeE5915xEi!vV$oX!hX@G@Hlvc$u-)m3`n6UM5TU<|D_rFE$Rw-be^6jF$t6!cxfv z9FY0h>SG9kY_#=LDja6^L2iJqCim@F3-gUtUsUmuVYrX?%ACTtnzz)Q7aNxYd~zQ8 zxOyVDR99f2ik_xuXRPeei}*3`bY7oS)q}cA%%uN7`2?4Dx{B05o8E1# zkJLc54p4#`WmFu7(VdU^#>&9&M8I7c{2c`w>}9!kKxJ`v>D}nVT3X$ycd8F-X?5px zh3;szx5#L|475rOZmJg3%CM0##JVOe=-KAvzib<%@RC1UlSwm(Nj(gU(TC7Y=yyUl ziQS?M>-8ps{<7`5BHsXF!O=ljg}XsR=xq2(2hVOzG$bUCla?jqfV0x$hdD_@K@KEc zkb^6+FQYvXOcQ?2PEF)M28mk;9lsuj$md{3-WrDPk(Lr<0t4h7^7kspv%DMaeo^J& z>wG(?-&!iZ&fDi-WG$r)(rQfkI*Y+|{-;!&p3bkKcg=6n)7fj$#w(uAFDwiJsikYt zT7RrD?ed(zhADy`BPu3P@pM+cFzv8Bgo)j6P@ykg^0t?DWV#?}b1Oe$RYTVJw0FD| zRLXIUw|cSeK8_llASuI_bgT!(N|BA8&VG102T)9VI?w0@C|JkKG}NMh@r&rW#+19D zO~J=xPFTb(cb~XCA2b$UgzhF7MiIHhxa>40!XYYVH4w493ZkA@*I%k$j*S(M&iIQE zFwvcy*w_$zsNRf?wN;7y>(ypTs?Pod+C72)b4nhiY^MFatg?`G4ZXc{3j3`aeZ@Bh ztZ#c^=t|a?P`KUEaIGO8mh2dqMTW!cUE=U+Pl8vTgIL;^k}j9(vS&ju-Z<|}lnpZe zGF^pyK&Vv_ggT$WsRdeABg(yiUvOd;Dgku z2z%m9Xa^EnKy|xcTHbr<@~m;8k4_Fl*M}o-NKFnK_t0q%qlc&Na`6S%^9kK(ON_!N ziEPMY59 zhP!RgP%hvDJVS*B7i~yMbt!#7i+4r~X*Dqce>fie@HfEUWCw0-0b@;g@FEVSBk*t% zSKaSt%D-=(0(=dDuQ=mUYGOkvr`&e|nv_a$Vi^DEWH6?%74L!cNEoYuFx~|!jrzU| zw_NaV4PVro#ZvlK)d_qkR|sEQSmKN?(~nYy)~Sc~B!(txlq?Eh*0xjSW657EMNf0karQjO z-@#e!!QG^@4CvtCtOM3#Fj#Auti#(QpG4)Jhizf?mye`O>Uzh^vS{|Oek;dH4u*`T zT^M%M^FBwP*HaAJ@`5jb1=B=Qu7a}D_^(vbZ{kg#sJ=3KdqHfxj8R?8KjC3ie>c&fuPDb{d>y2>xY23P-XM*ZV@C6Wym zG9NP2$ITPp|2MBoZQ}}--GPRg!N<&a4k}OB&^LuSxm*4U$pmgI<9+t#Df_Fs*);AY zk}d-=m67kT3Su`5MhWD^pG7Px-C;(K0{mjy{utAy$C$}&{!k9#!)^Z1$N40eKuQ{S z1lrG>S(~8q54x6v`aSW!*U|U!zC^7?lg!do-#HEs4LUmS@0s^SbhMJ&1(j+WEDLaa z>b)gg>3$dY+{h6+wNowQX019DKk_bU-{dasiZJ`aUE0Ra@JWI=eVR`a#3?khR#R%? zbdJoqFK6<^wX&_T8v;8H`r*Jt(r1~J{H;7QM zDf;xLi{=+q7|#sIva>Ku`g2Z8%e3!+%#M>}LqKPE{yE4Q%#IsPA4eX@vId9@mpdV_PMsgs{Lr{(1ycbe1eV^!nc9#c|ng@OBpBSJk^&IF-F?SE-!YYx{ zQ}{w|8uH0Tq#6A3?i}jWoZ8b^HL8hwSi89g3c4Nqf{8cbLR4n58tEK?BB9UP4ia#7 zDHi95$d{y+RA*vi#fb=sI44+jy?T?fA?_-~A;fQijuQWlKT-67#6dGYD)s7i+294g zKiZ%CH43I=YT2*k7;Ggca<*eOK1&zFE}jhF-_{-lYs`TmxeL1(*azD)dZKT^?i84E zlFt+0&iVv1E%xQVMPBI~eADMKjxM~?nhd$wr;>Sx^SX<>jH`A=%W+;6yn^R1JaEUl zla%8AGhpY5U*DDO%DT}z`bM9+(OcinfkXEZ)J)DPKHBgbEh7^Qh5gBW8TQ{je}{dG zXVhR~8FWf*4*)18R&5(Lmb{Jxqpb&j0p9^uU`L)MEufESYp{jPY5Nu&>^367ISYjQ z+remFsd``Hm6X0A2Chf}Ed0gqHN0+jM;xRNksJOekh`3L3Di!8ms*}jQ!pBoJ~lL^ zY_}AT(TU?sz`&1V|NSp`w`Ig^e?37TJP*lNz1^h)@1H=G)mh(k*4%GfWi?Dc-&xJ*RfXWd-1((|w+BN)_ z7GNF#a0c6f?e)|)2e&2`5;nZGZmNdIfIcSIIrw(yomwULzy2|M@H$BJCzZbb1?Q(I z1qJn-waUCW&NLe5Q)j6|@BqO?&U-Ujj>D!rpBfF!B!|OD(!QJV#&H_sU7>FQwsjqfWWevowUIB1M(kkStXBdpsCzbnikB{P;;p z-VVMU>a0Ib^(Enn>icud(i5w^DSga7iVA&sg1jp2Q5-QDzU-p~bCxu@cQqKV-w%MQhEL%?L zvybAN(e|JQ+5q4=K$~|$pouOU!HmrS+AdIw=&*zJ*Au~Og@)Ji4}({W_+|)@uG2um zRYS)CXuZwe2E*syUp_f}2I!+5gb{h%8Ue`9PXLg#e}e;>J2YsH*G;bnOTgqiPA|35 zcmnnGL?F6fGrsSgoS2$)Fi~>6D*>G2z_L+;uVNX z{xovZ`LZ1AB?Zz_1!u`xsNv2*SUH-_=<3BAk2^go(*c}7Br&af&il1`Ke-ZMwe?FH zFa~$R8M{-`)-Rp?u;1*o@tbk5ha#E13R5CZ?}yRBJ|!=3CUE^c(SF!Yp@EpDfdLYO zhR27?3(Y8-mKQiNc2@n)#SO6nthm^9Ik~)W`+0qn z_e&6hY!?U}rPdRD9{R)kKYQiT{%Ffn91S`XZDHhQu8HXpRwIWq!ZGMU20`e}bIig`-NcMZYUiztvEOzk!lLwE&=(ZM6bIrfZ+z?XTz(beqO&nW%zm2x&RY5ZrD%2T? z!GnuBGB9WtOY39f8R~|lQOypZ#kl$by0`(MAg)*4Xkp;`_hIlb?xCbQ5GEgpOTZ-O z&nLm91Cw5yz&IgH+8!WG=HDJ&Y*Ujry7*~LVV*SPW+0d96w+R)a1QX!IN6cS7_LjZy(>5x&C`)d)7A8&2&%=y*Z6e+otNiCxQa zh5ZaGdBvuS_wG;G?K1CA)?tkb#7i~uddw_^V$6Rm`Z^$C8{*>O$9b+o!98ayzH0kh z{Leoi_*64VO#9A4fD$SM6YtTYvYJs0uE zw?Y#A=i*04(5H7^(_XwXsJk3)(Pp}yFVMI{SKaR1nL_&wyRdO@^4P|CCU*(dvRU|h z_A>4pDlxtlwyR|{yd@A?Ue2G14KcynCG4{=AK~vuU6B!KyImBzAK@YTy_{$8#%rEB zit{}=F6nci=VIx4DZn4A@Q*=X6QyL>6(Uu~DrCxQ<5|H4>@|&N1?TgL#Cg`lG#~&D>6;KrTt=nlSgq0AxmPS)M;db!cx{+oNwt9`G zKj58Xabf)=yLjb3*hwl_KQ7(ofk0Tlcxc6vmYq5;+NSM^74Yb*@M$9)vr8N+R41kw zOJHtkXiFSXz1?}o%fJe4PzZ@NDWHvYAsI1^b^b4L>@?Q(6!3}0x<|hVW1UIsQ^E_( zID42Lxv~F(jbH0iRF1gRK$Eas; zqdLG}jl6or+p#BF+i#WSocky1y1XKE>GZeN@_n?^9JkkaPo0mUQ;h= z4g=3;6bhlTF#HqRiZSP{FIwY6);vlH+QAI|>Xa|1hQm*U&{$r=3NBMG?>J;#<%Rv3 z*6Gc?JBvGw=$Yt?>PESIWW#Nm2cw=dP&>?BxGN5a2Xc(>xA*QO5HOOQ!ricn`J_KM z%f79z?x5OfUFFH^S>Ah8y_olQ@mAx?eZ9NXA@}>m&ly$k7j98KB+re7@8@kq1tE$o zH-nN!-|mTgoC!8tlS84fB9Ftj<^x9S1?X0UTk=i@)O0AG%dfkQ=B4N=zU7*I{gD7n z_~~rOl!Z((_=r7t0LOD5kCogM%u8VGLG>q&a7SM;Avr!|GoLce$zq~hul2T5Bm*tS&QJVuR2bc$; zK_z~V@8+yvqAhW)R$?>P36?a!QCe@$6J zX!@Y;+V*2S04f8lUWBisuR@i_ye017gO%m@YEEAY7p5_|=|I&q+3uRW|GP8S7?Sej$MI!@oz{+Ak;$9XH;_G#^}{9`U}@;JtnG z-vRIA{9S8LqTdtN{{w&540vn({sjK6S3m#3@aFlee?Giz0DtO40A5XfU&Y|@x&snM z^A@9(K_%34*5v`Ldu@9%=r1}kA4dYP?BpiDVjdgb;03D}A326kx&kL^=zTdcXMx{X zHEU!(BLrO$&VCaq))fJ>!(05Wx+1WkZ1mW01J^mm?-2Erd!@j;A1(2B;5>zqA-XLk zOQ^BA$>yafjOzy?mDU^&7T7j=g;;QUyDKMJi3kom`p^sx97R5soMqc*CI%3*!}zb4 z)WpE-3+RE~Q&Zc1YO6IiM^2vR?ZX!1!~m*zcgGv%JMMG)oNV|_Z;D#8J)>s_ z7T(Q?iO#zcQ2e1uCAaJLCS6Fm zG{ub8PJB`EkvO^0#B~6k49()ch3)W>@U6wkn1eXZ76{jU0dc1a``yQISyYskHpozT zir^`0j!(Q=QtPz^5#Z(Md`@wXIv9VJ3*bRf`ggpl7wDJN%h|jF+7pLCsGpn_wMQXX zzJv{2h>Xo!B13xrY>iCbW3TTX^|F+VH!}aB-j^}NibDzd!XduHTWoPo$c<>NW3fdV zOl>YaF6Z}UM%>ui7A|9nuR9PMeR7EXW}yA) ze^m+-5>9hR!#fTPj`JcF@$!dSyu9}Wb7AR;(#UIEX!P1^m_ZXUHXliS$qDNfJEW-1&5*VxI5Lx1YRd59}(WX;-xnt8QxXiKX zxGMR?BlZI;OIIc1dx91`nq6!Uub%h_S+5faQ-OBqe%4*enrK1u$shuQ&i8A6!s9U2 zj6eMbK!)QmWi*rIs~r-xEF8UC)Cq`DiJ#(ow9>upAPi6H3c9@c1Q8IgKupJ5X&_R4 z1tCpFkIhjVBNwZZa6E|sMHeoffzDp|AGB^}cSg>JNCX3$ba@54Tp|in+=XuADE$<5 zTMl9SE))|qmLCn&T4RG4m%E(!3BtLlT71o_^Lj3E(X!iiIbgqr zqF>?mC-{>XgM`8Zkh4?|>|YW%{WyJV`%^Z5st%#uf%nOz`BVPCK3?@@Bz15!tnvSE z#;dM8_>aY_p8e!0!go--YPOrXbIP6bJs`{f)p*r^)w}5bH^r;|^x9K|=XL-~)>DQ+ z0hb+Mv!N7ts`0AZAw6Kl{r^$C>gQ;(_!rAd+IkJ9M*VXQPzL_28M0>4Z-M!R$+5u) zr!Q4KPmt&3#Wm}@irXmp&}>q?67G^S6_$T4{a^e6mQ--o;kl?4EF658t1dVs=>qZ; zlGBzeVYFcAmobjb#2iG3pli2yakJEB&AH>3FF4kpbz89bZR4KX!Dh*1)6uSZ9;PIu z?>}5^)9XP03FkyTs{TJL9__ZL#eL%B@o1~TnBn9Bn+1W6lX(B6c(hgEfG}vCYCKw7 z-X5~bhIc98f3oxUF9PMl8>rg@tA70O*HK0P3Gu`~L9N`LQ~&qI6R#O;q_#Dw|NVI4 z&iwh(%jZ;f|hgXsF8-e{Pw06>O@TVaE}qQe(u1}OqWCe1f(}`zmfyb1ND4u(l?2))LnPOPmg%*5Heb zHSJR&>QCd9i2e6aryDCuhN6QWh?dEo*gQk8AL!AjCy(`?+qnjd3}TkyxDx`=OOIK* zg8$2!bEyAnr6wjlDn&}-TR;8v07@WJ_ zgPM_AgU*E58Lp7bWi@h89PWJPz)mnysp{}rifUu!q6hHVdQ8rRe2?cs#9VHy>}9y8 z7khuq5AJN|>^m|mNl`nOY10iWJc7$c-;gAa4l2F)FcnJ0SadUU`b-G8@=ri}V z{kkW}>Omndn(5QN3)E$>#I`(&y?MlkfpErk&{*;tjDmF;ZGC*2g%Lle_fNS@BAd=F zJ{I*KGuo)9Vf21pq=;W(-^eDWJi66kLm8*g*fdt~{$+s>)G>U%kms{H>lRp10;;e* z8h92Jx&G*3INLvd%Kak32k&D&d1w-23E(tA5c3H^;qRH9IrVtIhrcubvV>TsedMSg%gw$IADH16mCYxaRE#f->#qbe0 zcjM5{v&82zR|tPi5C78m!k~&(3=M&ZuA6}6P&9vt>goM2W>cG_*_Yh!0D04_R#IBl zqe4h)gplCK(MC{b{vV<$_q77jv{1|p9MvR z^d90Bq)0|CK#^&KDN>*70!8AO%TE$-2}P!lNoAIBC{pID=3iBym1)Q`15M7dR+Ddm z#zv7UA>}vqXjG9N!Km@=J>2ktZd;2T`fJfS3alqc3=ZegJd3!EAYA80+>vUmJWAg6 zlFhpgos4&p7kJ>QL*AtjmZPw*@J%9{$oMwf`Z-%BfJi!W39eWV(|k*a=DA-EAQ~Z; zB^xjTqs@<6K%V4&B*7CAO*=9kM>LoM02X=NG$EV_sGA{%-&Z(nx6Bv9YzLoZKkr3x z44i>Yr-60Z`!@m73*wo6%=!-wAzE}_LlPBCL#~`WU=M^GJZlzgi6{wdB5Kz?a7z=`$u1=T5kg<7==RoLXzH!gjGs%cPC+fKr2@N685%_Kigf+4k z&3isSeW}oopX(umPe|kreEvZ0^NR!nJ!T%#%q-z>AG`n8PG0j_3=TBpht1c%71U4P z7V!jJYMCNLwMRY&SrU`cQw^~)J{M<2kz)<-+MvTA7H->K3hR6hfEPcaGOhEEA-RqP ze}!aAgi-5Bx*=N2#5Vq0Hll^p+M6km(lkHqdU(OM5EYgPty**~n8sAjb4vtREyk|6 zfvH?JED>h4NLwp4P?)hyA!n+U#!B2%u`TNRc<+C)ZJfbwaUlmhY4798ofrZ*r_Vnl zYJC)|KS$o^60S@GHx0}*G=~&c#yb#F2OGsse7ChF$TxZ7qP^US#OBjZ{yZM;=Fd~% zKj4R3>RZwuS;v=K0hcy9bgE~~zrJH04H->5>lkgh<$UyQck*L4zHo3hA3lR-yU#ov zikxft5riseFFL2TLojE%KbVzltF&|b>r;A{}HP|4b2e2tXQA@B#x zci&#{8b)k-9B&L8*|HH20D!mT(41NVB8*=JIlcC_WBqHtf{%+faIE5he?yn`qaIYS z_9CPlh`A%Lnd{iFD>Ah4jUka2%>FE+>2v5RT=xm6NLL~UZ>jyz11;~O^pLfq`R!+D zEzGr7Ja?=X=~=tcJRK$2kquOF(2+N8MMo|{i3EjCerdJ8Je&H$O*p-2c5ug@pC7=L zMRnIb>@}KjpK3qAT{po-6-ysuX<%hu3)MOMgV99w2X|l7qk?XX-g9kuG@@k%kIZgb zE*{Yc*LY_o*P#-tja>(yP`pYj*J_F5HCi(Qw}Z^P#%g(;Z-MLGn=u7(Rr!5tEwQe? zI}3lomBZE&sZ_0iuVsa$FZg%>x0~q;O@rb&2qn=W$$s}mAOoHh8E}ltu z%1@q%!c(DR;%We0!J;naa=u$5aR0|h>vGSz@0thQ=FWapjVnQ6(d-hYf&QIDKdnZU zQ-IB>sJ=$1pm7Bzh9lp@g$8`az7HANgR#1WM-R-tp^-0{ebtfk5ta|(U(;(=4NB63 zSpxh5w^OasQd=?V-vdbkI#}D=fDek0eTDGISsdnXw6>quPFE$9ai>XV{XPsYKu4iO z-AnN2rs9F4_UUz;x-7fXUtQ{0_(HfbFr0@`$^Bfh28JZ1_L!2nXqpk3ON;dgB&Kyg zDvG>G%vd}YWJ4pjxY;)ZSB3Fe<0p(q6!`%BbfEi2+pq9<4H@Cd@bkq1 z`1wQ{KUT>yRdSzTXMY+yyFM5@i06WZQmoY{#?DQdkiG^l7zCBBf!G;N>{RHlIkLxU z#;ZZbMhh=aLlH;(;&dPx)4z`u+zre(>J_XFt>&0VT~;gS znCfFBG`i3VcHtnGG3P!nIF$)^W@>%hZo-59sf_oC#0)Wz~>)5JN_7aQP0m) z!e`b020qcZ43}tUR-PI@tNy9@1U(H{KgFM=93l{vlRn%y!8Oxpx}Wn8E4rV?KzOmF z=7(i&MutoFbH+A3k6dup-3@8BX_?GnQ`XctW84}o)ts&3cw<>~#8H=*YU{iIR%jDt zukzKuzhmU!f7d;E%TF{w&B>D1mn6L;q5@HXb2bQd0wE*MSJ_t=f1jBcP0 zOG=QAHNt4yAtM@Y-17y_Dp7b;S&`OxT<8xB;vcc=@G?hPDMmI-i3gEYhS*33u#m8tLGlpZ?NI9^>#?vx!AlW4B{ zqCU;|3FID}@0N^wk)5hjuH?hdS;(8#-j*(f{)VbOl~74%-o^MILHl4w%D;#FgW;gc zL1Lv?!zy|I=9ftt&E$JSJ@|toUUv^e(xO9IsL5FTHz3P0r=gF8Mh-JiaM6?R?L}`g z|Duij3x__1JK&C}R#ueP7j0!~-X?nV{S-@`C=sqw5FUhaU7fV1AlXL{h{^gbTZpb> zDOG~|IAzRhp>w+;mp48&EDPx)A{VXg|Eh>Mo@&U?$R{V$yz!Us$aZaNVSf?KPAY1V ziconBp9;4>>^AQ0#DOliJ_@YvV=qlREP^BN#!Q-?zKlvZ({#uLokmMIQsjj1pm?j= zhf3lF+Q7$XgYh_;#j+}J1E7OOGcIAm-V|G)f|2|Y{QvfHl?;gnvy{CqY=_F5XWh-t zp%#zE$7W+ZgDq1B4-;HB^JQAM9pL@eI@Wb7v%lK+e1)7FV!ynSl$B?w>&`qe+SS&Jm z^HiI5=+S76B0ANQVLc=rre=^1ZJ+3<*Hw!0QkyhJSQIY>={(2= zqQ7M+YRE5O44B3FjZbCWgrpIXPp7D68mXqpp_+$~ag)iOy3D6(j|dq}oAF{-Xi9}> zq=`U*VzuX(lA#Llr{kF;-9Y$AicmtVnHathwG_7NZ<4Ind-?VyeA8cSa!T>@0jbbG z1|bI&ksqHjSLjNh0J_3OO}`*rNzFo6-%Z;?tY*qxWdBX?af}eio9IN-+#bdBkKBR3 zDgFN6Y<<*^?+W{tJYQg}mW$}teu0H4(EH~N$JHS#2*jy!rX)BM&#Vkx&8cNNwkxgX z0yIm6)!UU)4@adW%=opa*!rDdY@GlYll?Ool;B9L+^JdZLGq>+!B1j_=8FY$BHx&e zs*ApHJ0QFrPovN|UT|_Lw%1{z$J19`99ZH~tQ`1W@U7dweLG7qAGXG1rb={U*MRxQ z9y#-mbSU$W9V{L^|K6`V$^6su_EgO0TA*e=4r6=*^DY9md2a_)xcYwd!1z(Sw?jP} z`6yY;RH2O&{=t;%3lE^LrR*zy%k5wCHFORsRdxziBXqIXeC>!cH2kJPAy7byvy+!A z*>SWt8E(8Y%T+f9_qII^q|o!JAk{u-d~|s@ykOqLS#|FuI9_5PgQkvlT1+v|1fo0fVqIY`KwiqY{IJ-MIl)soS zI{F4ZCB&&6g?(U3!B`pP4BT?yUx7ZyhV-DWR6L3@-xU3=@d&@+6ThYG&7?077rirb ztTBG;YOhsn6(Q{E+2)?p&CPD?yy8Z=bNkfB-aj7b!maEZv&ML$54#${a4_p|6!dc) z$Fk1tUB@{1dB=)-7F=SE3Ap9LI7ySh_(s(x^R?k>j3+DbU?ckYB)a4>DtB04gYn0> zYKOYoD`X3MeT*UWi~ANnom|ar8c{dB=wS{<8$54}XMQ1q*5Bc`zT@rKGh}&h$!dv1 zuY6&Bt5kLu=X?CK7^bKVZct~Y~+M!pWG=|k>?)oFYf>zjTnZR&stac<4yY#376AQ)Z; zZaHKJU&Dv&zSi;!L#UWnRdw@lL-)46;+}@JYEF*booJaGXV%9Cr>i9srQXh@m9e}# z=NP?{dQ`X5@*WbwuJkc zsP92;$kSRI|6#4Hz&U8>96TNK5#1|OiDC|nDG z^GD5TKRJWD!(MvH1Cmi3i^PJw3}^l!b)YCGzwj}A&KPu;&+PG^qX*z+`H_+4h9Wt* z4790EoL`G;gS;B+MaYz~IV5gmu@~?Y$;+wzMiBNbsGP)2ABvz82GnT!D!O1bhOmOD z7uLE?pHbV~zGfPJjPg#HKTu|rvE*#zG1^ApuO1b8E=(N1vNR!A2}Wtn30f0F)}W0w;%k6U=y3D3gv zh`x`q)*oR{5fX#@$#lcPo^pRTE|`J=4A-hsCk)AI$Pf8iJsABx$4ibBb!Q3Xw&NhAyg$8oiQ zzc~H_j_<&!;lqEL;G-5l|KG*OWB&j?>aeBo58xvosHz0Q>DN)N#OPg0sVuPIJ1FtKPMo5^>WS{uyi>73*&;;w{sBwlCv%^t~!jB&p@aO zq9Kpk3|jIoM?=2iL-l7h47WI+) z(O@Kk1G=#g2V*jD@Z}TWK=d&ME&U+i|IGgo{->aCUxv5@qNYG`ea3FGT{2gezjNj;Y&HHBbNiLg(+p!?< zE^!7q7cm$Ui*tzr6pbkO#9fB`_;0^QZeQxLgc_Sf0zAY?W4r5#~=BdgzV0BXGO;b z?CWfR%=|MZQY`ZGARCN9c=V+gdV7U;WB=7&on>iGa8habaSfY-YPfkqrGWmgJ}25F z(sGQZ+W-iDNu4&o6bU$Oj5T6>1}u2BP`$ zjmt|GtlREGxJnf9%z|sx)Tdp%GPJL5ABI7*>h(2E7=JV%duPr%A@tlB`Dl|>N8>?p()FtKffIhhz( zJb>c0=F?;x6ddp(6FPnQ)i#8ZfxV$Vr(swzOgdQI?cU2*h%|WjM}zhX|3@h3`KT~d zxFs662oL$tIBMK~O36FM`l)TW%Px4io)Cxt$0L*hk*{*p3@TQB*@(yHdLCMWfTcN` zanCp+WTZ{Rwoo;Ip>cf$`dLRcBD#IAPjG_0f2$#2%@D70Ifiam@vKJ82hM=w_Rk~O zKTn^24jN6C27Gnup1aW}xgF#)swcb8XgUn2Hy@ZUccWP|uyO>gNgilsh#a!;)9m?L z40FI`cNxKO5HBps_^Md;$u6{`lwYgw(MJ(u0=I!WeIA|Kn>L2gzfL z_R`pkP(3v6)j&~iYK09Dy%>dc{SvwVckxBY0dg*~+Bg}l`^1}J4EJtEVS1FPt9@3f zSB(i-V-TrH-vDy;v}{)t^SH46iI1Xd@BI?yjcSbByQE+H6_z5EV_x$at4rpZ?L%2`#!c`^g(j|= z!uR7#s+8DCy#4pJq7*9L30ULS%P)bDA@5PvM4-=Qjq(xlI3~TlS=o^s67^^c4|2t~ z-5}c#w6OSL<t)o393AaYPdElSln#jf+*!F7^e)iDus zQ}dDacy&j)2xB)|jqw^ySLtz#!rhGptQ>vSiz^pI&Uh5-XoAGQDSMy3@eTgI=!npO zo(m;rdoHv6U^t>ofV}F)p(2JoEwUQR+d)s?BaIh#8%;ZbFcv1WNsVHfD^ja`;rR8X zgCKJWBEjO2+pmEZuP7?Z=uu2lRCjsJ? z&Ej*>2+`0;ba=w;h&mYm?mjrS@+mMC4PiaJMuW10hjYeD|>L0n$gmNGDJ0j zE)zlE>IpvtM8qG3kdwF^8p5K(hl#IGpc9cZ79Bpqmn^&(&0|qD%cI&f!55KK0J(y} zon3TzI%-=JWw*ANhwoi;C!f|Qjw02LdA8`)GjMkRT+%eb7XgGNu|_&=R9kSIZ{$wO z9>pg)-Py_~`f1d*@QLASO7G)SF7qwHiO)x8kbgHa^on(v*X*N1DkYu#7)b`I;n#_- zwrlVg`Z;f>6StW$z8LQ?0Ke3x-ogWg+p%kuAN@9*T9)8L!wA@#bB((jnF$^h;u<$g ztgS_b{l>~VxsR4`^&^m7v-#~(TJ3;@^H8TO}#5KUy zn!S9YgUXtR_yimggA@h17}BQTtprPCLq}|?`)0|p{=_fYkWHK9z0B}EJHt3+u+ofh z{MWKwiSL1W%wuk2@lVkLz}KG$p(BWgup}(;5N@7ppU+=`cl%N;ZC;Nsex9?c9-fko zE5T%5FWSJO_71vZFPxJTy(>31mdCAVcx=86Y$rN49DO9*NVw0*K}?^LFxF+xL@$jG z@xF@@w5TV&NXs(NWwV}Al#<*aVB>9pO~e`-h7j(NWxt2kg3c6>3tEWp z0fvsNcktr>BvvQnj@T7w;Svd9%t~v92Tx8Q;Ar{zx8T(ipE8*XuhB%$n8JSbrg~c) z+*ImzZ7M}j_D8nn7>^u7q-lf?RBz(duio8Mn&oP(9HtVj)k9k=hr_*|eYKvD6Df}g zaUD|cb{xuStu$Jzz3NcMA%AOiHh)pk2z98ndZgNCJc10>K6$|B)6_o5B4MP`wvpdj zefnC8O6N_^QQKOpKi+W=wFP+ppTD*8O#XUXD?eu4?s-hk2 zJs5NmIPrXf8#FHK9L{Pzu*ScWSZ{yDU!4SJ zr!82~JL`UN2of3{LjW&vniF}%hHwhJ zZh{wCyf$>RnEOFYY1_Us2b$#))U0;KL$8A$HS!t8azHlzRp}aB=x~=of8mw{Op^VB z_5&Sz1AWuvN>W?)L_qL8hNH%M;*%yqv>kYjXk?5f(F$~sGID)}EVv253-sj(pEeKq zC4zzXew$l;0>27=F85>p%WVOst=dB)El2)BCnb`Os=NE~h>Ky!f!pP~0UvZ7>vj!l=b`M7~((qSH;n9_X@bTKR z3vNM+?B#Pr-doJA)5thf=V!H8jo{&tYf0DxkUcIzqz4aJrLdeci@@>s16^icZCwqz zg(9wX?0{T~*MH{xWeaL8p{<+IA+S|1%29^%^l|bVH^7NULo=@;E)2dPzaoZPCDoP=s!xM57m)eXdg3t)_iYtvRl2K zeN6eGq@uX>9Z&H->LGKkx4!0$`mX8t%TTLmB$%47@E8RjD>Bl9^4`L?v)_%}j&+0^ z5c$!n3s>OTll(+#Juo|_S!1SIU%Le-vXj|ek*{*AZr|)UI{+_2humw>sQBCTMJuNi zw%gYgAsPu(wb565=KR6rJ+F9SIpufW7(cSGeWIYl+&fLZ0X7vu59Yu3OR)Dw)QP37 zUcCzX#d1-Fo>T88X-`2#wP4mYL>2N8WtDu0zX@({ZkUGF=(gkVGu)2^IMX~g5Y8e8 z`r>sUXY!FxUIjP9KF{0*G-5Qu<>|cjaIbNpBHMrWwl^Dk-@q>1s$pt}I|*TN^BFH= z0Ylch*U|Y>iPIb@w65@4XF+}~>?(XI`_GZF03!}neiZ(ufae`6teFoL#^lb|bLbQE zr@HtW&;`1!O`8~74$fWkelR47Qx0wmZBPC=eLiSbxQ1)^1k4xYuBIF{^p*k;4hV++ z+M;j=jMiV<8LY->_{!CAE>mhyq`C$W$wf&~^#)KMD)~2nk?d;Zm4ryCip?!rUkXq( zE&#i1`ZrXf-X@TqBz$h$+R*!2;coX=i;|;H|Rp*m00DU1R&1Box{cN&1Sq1IWpqxw^ZvMph4Xjn@vU?`4zyl z8fOTsA`yJ5wps;pTOxPyO^vC+`Z+Z!rsy zV%?bBNkdYdf}uJ~hrbGf2QUF#-OV1 ze05|_KaQm1CLx%ekRr%#FSHa?!fXn!QH&GwQEi-CY^UNtsL`~apEnh5FKn0T3Gyr4 z-TTI1@{5y0Cg}_Z>ceI^onp`%^C*2IiU9c_7-BuFbB(AD)wknE-5YMgPZVZId}zhv zno|5R#>egU&7&SnnfY@n3%B%cK2h<_71+KV<29zwy!Dv!6- zGa~s4=CiTdi|o_Yh$mP!vL*Sd^?)Ajo7fkA^@!!mQdOQ&W;-@5XYYd(?WkxVD@y|; zxkTuJ=G+v2cJ?a}k;kf#`TYe<&CwMeqvdKn^=qu!^4?8caU-XJ|7>#Wm%8@>3v$na z{4fI*U&kn{3heom5{J-U&(dJsCfSY$O)4Z~Z34#_XeJVz@r203QJs83sV(!MT zy6Rp-`1c(soSQr&m7lMe$Q|JOL4D19jk?K0DbKK`lv}lx_T<5>7kiEXN(Z{KjPfpY z%MUN5E!LZpCihpMmZcc!R_S|_~>E%$5V;|D^t-=hRMjp@(2s`X!+jw*i3*)Bv$FY1N zZkgQpq<+ha;m!hv^5{<~;}%4&i(U!A%#Zjgmgi`o0EOzHtH5ZY7oFq5uoMp>-V31vtgQQ1)EylcinWM+8HL!$k}((~ zK7J9u9Ek|Mct6UHEGs=9xjHPflD}{tLKq{=Q4e72jb{T1`U_?;w^=*n== zfekwDKaASIE%Fy3co=nsr)-AYZtE{QzW^~=q~gEg%c4WmTp?HFD~k@HzM*wxmMNG< z>+L{TOy1Z(jUql_P}6LHCQ4cl^B$Mf`;j2-&VxRR(RoK@*=C?2TB4uEc4;Y3AUuXc zpW{LtXj7hSLlvk%IR4|$^Ii^^OZ2BZbM+_vN*KhS{fZaVJHIH}az9~^&ij)x0YQWo z8BfS=Hj(EH_kdQcJv}xco=<&w1z)U|dr=$qwqS+BkcvQBqu?6(4C>EcLuEWUQtj;6 z#4RK@{$=zGl15t{tJ(>pO;T;r@_@au+G^1gtfVvDx zm(XM$?+c}nRU_sz-%8vP)1F^AF|7n zex23p0vZX{g~(dCWxBFXhZTU;%F!6zNJ%(;lQi(#(@{3n0Fq0kfk;i^_UWp62n3@d zj1o2()PZ_&lcdC*LBIPU?EQVyi3jyqitUo-w#KhDa0?y|@kq`D%+ z=19piNdJ6!T^v8T7uNm7ScUn9!k${ziN*ib2Gz~P^E>to#|y%Uttt;+(DCYUb5BEd zHxiYkd{JH{!lO4nGYo8x8?ijgtOZIxx-5dfqa|pjk`yH=#yzzdZ@q7{1l2T5y3@$a z*NchgKHY=(VfgXOI-MvZd?u;C^0Y^VS5@>`6+TsQ#KOa*BRCZ4HJ>W8F-n^x5IQ0Wp zax$`*@Aj)_kb}R^sduw?$!8$lmAu$ou-}DKD-(Kpw_y>Vupd8Llf$fv9&6HmRnem+ z?YEyXy|{#xqw^qUNKe<_h}~h11Dy&-EBvYgS@(1391md6!GX4aGaJid7v#td;p=bU zD2%5oycm}}n|nRx0;k;YYHTmqXeX_ z$ON-5CvscjyLja~=QUP$392G)Rm3sTM@aJtY8lM#*JW_HLN{9KW6$<9LcWe*GxDKS z)<$_c#coR8klp!MX_!xXynjzE(of+HeUHD~KT9RX#)gjSt%g<2AuJbB-#D7S2?08M>JQq^{ zx5_N@7%g{zJ+c*#kpf9XGLXzUE6_V*aRGA4t89utf6~zv zqiC!`Mwe)kTz}sH55j(tynN6Ab;D5GF-V-JKGkvl3UzUusp5dBvG~^G$J>OAP>Kt< z3dvfEso|TBWz<+b2}`NXf-QRr1vMR#qBJ+d^>>jw*oc1hlTUSHCV-nsCRlt6Z zdlA={kPV6zF0TV?qIgjUr-7S(@C1I3-Qf23be`Zm{)@$j!NIl?GCUxJH``{4k;cOnQ>b zL`y^=1|TnI)wKX=nhQtt2WK*!Qd6TV{Ih?by@-)uQaRPVp)kw~H1*rskUc7U z861p>9$fbgI-XN%X9o@7{(v2Cs_xG~E&zWIUerG;^XUdM)Dy=O-D== zfyqx^7#)D03t;j{uXK4p1Ne)0Q4t*!WA+1~7m_?g3IfPw(6aK{Yl=T)wEVZg0EI)k z4KjYNubc{7v6-Kq3Ut~ByY+_fJFqW58IVtQ1S|G4fHvaBU~@%XO|E1?>cToLLe=18 z2;OSKo>;}}y3C&J4od2;XK%x0sUVgdRqII>k!{>F=_JV&VhCHBM8FD6n%(YoO z2SR=_a3H&|!lehi65rGLG6D10fP9NN(2D(Fm7I?~*%Vk$T<#8C&h9N(EDHHQtWf!Y zLZ6gExKGb%$(qz76Do~ebMGi~0ggR2JuV$1!GfuRAgJX;D#dn1s-Rd6l?x(lPjSUw zV;m-p$i5oNuV)ZK2iC?kv3&y)XdVzs#Ucwu%mr~5wt6b!86`^5bh^Za<~Mx9*{4XD zO$rt>>;L+I`iEu?B{xY8*2YyP4$jwQY$=`6viU6^Bm*=uLeEmPzk%;{Wl~{s9+T5N zc@C%ruu1bbl=mbl&5-u1wKs^3suI+bHE(?~@5Fuiv0gLm%!bpEx^3x^aOp{YC0#s| z*WNr}$zdcWK#9J5lfce;TK(p?{1_NmZhBy=_--^)u9h|u-FO-_zNviIN~0gQ*g@w| zmkVdzDN8&FDK3QMYXz(0jvSS$H~se85P9?3Z&`RlPbz#K^d=3aJh)~LN)Ai)#OioGIbk$FoR7CJo2oasAf?pOFYpdGPSBb8O&j4CB>nuhRd zuaO!pqct+^Iz$qQQXN6lA6WJ952~6a({yay{SJ(q(huJNu?J#D%YWIhD)n*ih-<>2 z@%ZfpY5$YP3j(gX>SRf@ zqC0~reo6PzW?A#FhhtT|5{2vLq*ts--P_(&+wfz)>h68Ha4YHKmC+SDXFsJ0=`zVp zer02kN`DVJMs?n2110geEk>0FGUUqF3FZu~OGqU(Q}!e*k#YAB0kw2b)r&v{M6bP} zx|^+v*KIQgq`LjWm9T1wQ6Xb!*P@{AjA3%eZeWwpDE3$t(!%Mf7Tjzh9*R7~m7`V9+DAxYR@^U0v*Sa)NNB}z?!rN`5^g9f1qW)J`X?&gLkbU!=nxse8q?&tr*-ur;ZbyfGGM~R)tK_Ddqj-A$q3GyVFZ>-k$zW83#%I(~~@UFi$6o0*;80xfRaALvpYYq4o z8RTRLE|nq|OfW^^s^tBCYwfk??9raFlqMGl(r3?EXYIB2{_VB@t-bd-`vAgxI(Lls zluvYC?z97PO41T+$5CLK_@m|AagO|`RK7@0YmuJzMLL#&X?6jl>m!Jk^}j2uCl~36 z@9N3BXig?`nhQ?H%uAAD8J{1E4TxTYU>RnQrwZxE+F84Jex2|MpYK<~OR;t*<#(;ePcoPT@~wkTG9W?8;o1E|yL= zUvw$5=20K1(tXO&?@NE-to0Wt1sQ{}s5HNv$ap%xbWwS27iP?BPji$!{mKGTMi+C5 z)Qz*Yn!rQj7+RIkO_zc0uVo+y2Lu!=5|JL7a><2{EyboK%Xy=oph?3-jYDA{}m z2N{%b!z?EQ%s`h+De1Jc%6Bn<(UtU#FmH31qb%uBE9n=r?}E4Q>X8mjW6zZib<_&{ zbr8}5?*S$AlhUF7Z(WA{i_)?F8kbwpprrie1$RVW17ze~HCg_FW@o4=)!}>4ATU=Q zRFl;q(7Z6zWbGJ}m$9MgDhOH`(6WNOJdO7JP*dv5N133jFRI4+5~#I>YEpgPMm3yk z!5mUp2HnjsYAC7P=?fq-{t{o;uog=fMXMZLLHRs$z1F2mv23<@51^*{`RBco%kc2pFc-R*zT0N(D4pf_ zejh@RzAe9t#050XW?8R=oe->Z{~o-}_F-z*`{IpES=QxF% zkUNQ2oppGq$SDp3Lv!h98|trKc4%}i2QYC#Wo`DBi?l57)>N@z3%hcy?sME$)>OY= z!g}zgR|$vFd6~bh%lx2pOngd>nxi>4R!}kKu$D60JkCN40#np;faK1o8_toT-4%x0 zo^!h!T<)^njeoqn$?nGWb+i3C%ogr$bRm#NRgb;2rsMNTMy>3YFS$EJko#WIY#$?- z5Jz?`{t22$L8nI~+$*l6rX-)*i8ZH z0S3CyBf-M9f`@;~r>7b=9eV1qbs#p|bZ|>3bXiz#zgd_14i;1FV&f2rR?)nzLz38q&>*kaJ>xeESjSr}qdkZsY* z0yG7b7Ip_%NUU&gMoCJgciq9lXsoQ<^;j2$v36Rl92F%}PR{C)YL=o)`swP^rfd4B zc=J;ln_TzJH^-EXVz`c!b}d;ftZ%-Qrpl-UGxZ1RJ3Ax%CZ(lPasupjZr8aI`W)5R zbD)qg>$Tlkh`ZT&7W3&MWL)Z4?c%((%lR05t3cYzE^9T|Tfl0Q>(y))q^+D=a_9!} zL7WVu2WB86-v2jP#`=y=jJpJW{jMwJQA=MhGr#576uKJYk8VP9Q=5z9k1}Gpku^H) zcWh}xP0@w3@g{!&ZlABRl}ikn9|157&i^zgkLF+h9bkZCJY>tbJu*hRe2m zT?QApis*#c4~r4G8LJ*ze`;-KK6{%@^O!8Fnk)8RR8I^|ncLhw&ytp*${CpF&`_mr zU_5rI2IfMs8TfaD#kGI&1{RZ+zP9L#%dhLYRn~cEG`Aq27NixPgVI8w8-vR(wz<+Z zc8`w@HS;3`lbusK@wHlAqiYdPZx?lEdhSQd4hCiCrDBfQw6Q2;FMG~7e5U3l*TG_Q zLz%0ecv=Q_yKD;_nl6{TjH<4Uz=xHE^{`&@6|B0O0Bty8U7tsX$lWLGFSyl_mt#a{ z)y6!CgKo<1FRw?ikWsVBc47F((n#huJkTlm`LUTYu7lk0l$oIQ>G*0r&uf-K!Hs~#>bWaRD8Edd{*!JrBJc9%_m+W z(yLV3S#KR;Jv7SaXCk663q)TlqViHu1Arf51gQ71!EkSLRP29XH5gBD-~lc?KpIQ! z(?Kj3`^P=HZaG}3?0f*R!m~jiYd!BX$Dr4UXeRHFL#QoO3n5w@`X!?pSbDph4l2%`!~q36(q5Qc&}qqvE-K4NLMeI<`Y5j2&E-KlPOl zouYjb$v#LddvU=@RL+*yBDbgmvYv(>1XIIJ?}c5(xvasI6PMw6R)6n%o-@ck^6_&1 zLU;}r<5EL~c66t#+Zy9!R0NT0cy;2)XS>=CF>Sc={H|MuQPd4M=WKey^+o7&v#E2( zh*m2>+PQ-}YK$?P9?-CSibc$kTd{|!&{*1!;zmX>&DvQGykK;>We*h`NehlFQvZJ% z{iqFTuV9K1`TAIP7Gv328OyM9);N}N;SNzF=ufS3wxTQy5ZC!OU)3M>d%{i?^WHawACH%G2@2M%7&BJAj| zUDZ*r7*o;xqe_g)IV*_qNyK=w#MseMi^%_(j}d7$i}d%sP&0{jF4-&5NSTo*FT?pR z>XRZfmvs2O-W1dxAM2sfrulgi&n0M%Tj2YK7ixy@fJ%(*MfnIme1q~Xj)`KL1sxL+ z)9moEA_vVP{_T`d(@eZ6CDhc&FYrRm()s~5XJCu5VZ(iC2fuUBI8q-~G0j=Cxc+-e zsA=Xto)T)Bx$9CwO*6O53pE4uLX*(PBIW4|p0T^RR^HrI+I-5|*5+FOcaqZg%bQR2 zf9DLog8dKu|ArGq3O`Cp-@@su zQTT09n0Lqanl#5X&_U?_Top*6%x}FeQ={BEG z$DzmKjrDQtw`)RmM9q?X$jdg9xK|~{z9&7@DKyx>HBirG?xhXyle*?CaLJ*^;!XMe zJ~0Kx95hSzwGFZ~Yctt4FWXGw5p376O}yG?g0mN~tY(4@{dhVP3l2RNZ}0bLRK6IP z+h)nGZ;)-3;ob(>RvGT{vdvQdE_Pg);pOOQna$3-c*JNr!yoIsi!XKfd|Z0yv3N)E ze`{1;kd|qd?3M=ER>t}D2H94|xvW99m2rN6ZIagQ>?Pv?O_cW(I%rmLR*F-e&yRfbn|As#hp8KT&v z#?2SXRAzjxEPu0H*B}Z`Rhq_2yrX|6@t*p8Qb-d22=y`1hxZOX0vh=6HOWuTYv9j! z{5cJLSaMXrHSoL1=bL2>{EYDN(0&8INBLci{DsO-+P!>Lb_--{rOPulQ;S6y3)l_( zrROjfywGIy7MX6HmKC4|{UtD2IlCBx?epbnx#y1l5Z-Wq4WCrJVAG{6>g-}f!4`KU zyTnsVN!hypQ>qvbOSd+oim~h*d6kNBr^FjAxL&d0)Pl=uK};#QmCBz|aI2I*y@FdU z!cz-Ss1t&{0>%d^Y>O|PDerKNU zuhiEuvwSV|LVhEtlRK2s`~C}-NXD_oCO1Dotr_RzdPf*fvP+Y&C+}YgRzWKF+0H+w zCwKwZ#?Zj#$&`Nj$2E1*~Jb6pn85q1=^hR0 zpv}hLfOi4;P%V}nCa@ZZGmcZyA+9Ti?R|qGd{7GOKk^QtkCbZ6w7s8q$LV_!E8-|; zC&l*d{iAbabD)0|3(wqmltoIg+Z`K)un1G_Gm8*%8k!=A=P3Ih>nLB+_EoSs5$_-E zDkq$^pQhZXdqC$%uEty($#Dq;7tU;Op}&U9F>;p@~pX!`cWP&qgBiPEt*=7ts> zYvYp5P$_p9t0aqZVMwiQruulOH;n(dgpc;;jF&K+2uyC1CkOS%1cDyo#b zubkVzJa->h_u-+f+vXj~9cA{%Z51y&K|^ zQgI_!w0Cd9?<1cgee$}($z0*&+@blKHa`3%R8nnyP2?Va;v`-ye(#3%#A!TnV(&J@ za-zuJ@$*i67cJ-nz;q3)n}d0pBwcG6<;;@)=FQEMJ^}v%>9+T8ACYuNp2l>4=iKRb z^lu-QbcdhDbjNQxXMVf-w;z{uk3Ws+-g=I7kKS>Zy^C%L%3J#OMhiO|G~rlhgZ4YM zv#GHYLCXz8+N$h`>RrtUrG{NU;(L`LKtSgrt?Njxs&|L=B982l+(EtDub2Dvavv{a z|A3!z?!Nk-r}jo@nfFR>bnl{LV$rtTv5VKDZ_tK%YEdpCF?8|TqiDX8b(O0{<*FC2 zJuGsth00+aHxl20i`SyBL42@`$_+>5_Fudf9T4P(`*Zi9*FuMbUW;cKp_ePKJzC1` zDXkquuT@@qxRl#fT6<6Vnmy&~z}Zz^d(ZN3+=4G2Zke-u=r(@t=o_Wn-KDiV(V>;s zqJJxt*6t`@b9ebVa0=zMJElk%w<4X=ZZ>`Nc;&VCr@NQ(07J{tJ(Q(8DNDE07|V*a z$8UKdezweAkvn!9p6ul^MKUHIuTj{=^^(kul8itr=7n=TIRgwW@0C#Dmv@ujm`tg- zPIUSx?ZB=P&b8zWFce?K-BT3UyJcYP$?H!X(Di6Va+h5=MW;wWYiRL&h0x`*^w>? z?MJ7Lkr9-3GlEAxMS3d6zg*uOqm3769Rg|rVt@xAbT{eG27z? z+wXrG0S?{J8sNS=4s&dhBedKzhnyhrdBH9m#`6v|E%*(15@c=#&7zzG(PKxkNJEs8fP}_MjK4vG`D@ZjK`(V-th%w{;Gj) z&;CaFl0`UfgYV+-=_|g_uF@T0N+rktF$9RC9OL6Suj3k|xfsXUi_wC3VO8M+uP1GI|YU7(#Uxcj|;Q$SJ zChjaheR-9)iRhJ%wN?3s^7)Ja^F#nkM<5fCwz@Gociw_j#{L?R4BjWE0S_jR+8U>3 zz<0o0syVc_YEy8`8yu0db0??Z#tK=0`Zs}k7oJ*k4^--7q4j#UvR=>bKSw>g?Z>ER z^HcTgDj@JSonAeg--deDQ0AW-`}=yCk3WT4HeYL5TcnOjdQX+mh^=qJ8+D1_G z9dN0A@%kmuP`?y)P`@N-YP)!Us)p$qJa?R4i6LJcWxj1(#Mwnp9w}zijG?4sIthEiYsx?#3@Talr%t; zB_NgA@F@5-BzD*V!bxig-cWScYYucS8dwh=uKyoJbs-v1cc5ZwKvT=Iw_zZV)u ziWU4S@FxuB%wg0jqo%4~QX z{4>Dxkjur81aBz1tK@{D$HvAa;2_QIPbxDFzmv9B9 zJp_lJjnxEqck}LUWNW=jzsz;4d}gOQRLAgZXKQjZ4jz`cS?J!({{W8y>F$x zFQvW5X*=G4-nY^oN@*W(+KxA%_jPUL`__pLWO1vO9`m2d3Nt_IqM!tBhxK;A*m^%M z%}p!`nRav^M~ZXsdl||RT;Z^o$h)EQQT8#G;vUcoU4P@!SfIB9#@74qF%1AlX+ee0 zEHY-NvdrB&_JH0?Mny%66f#GO*W=eeF(1{b;pR+~f+Mv9B|l6`>vJ4pEj|Chb)9N>xsw4cLSW)hk2SXsC-+Dpr^P z8%;Wac30W-$|zQ+5?J6u^~%sy2rbJmx&)z_WJxF9!dWhK=hbp46?;X9k(P?fgeGUX z&=4Z4R9q?n%vwpN&Sl{&7aBrK5U@gw#`S?S(xLHT3|&?z$qczHz)Qu264he-E*Bc= zWMLea08K+?$--GKb7%;WwL&t+#Q}Mha{L1pX?IF@fzaeEFOr5XFDu0Mq6;rG8NXC@ zS4e?zMM2-A#2T`^DB1tOCMYF1I!W?17b*pG-d}pW^VLI-cXrLK!JmD+bDhwmLcjkI z=1?a0RmdHK+;g4Wmmlx^twWD@UW^%4$NSq8#z3u;dxua(aObYSg*v_Pi;s7HpgKN> zLj@*jKj^#|1B0wBKfuBjNF*$&rvcLKcvZwA!&w=N1q?q8BP54N05}m116OJku zDN`z*m2UQCk>xN(N%J-+OK(GErnu6shnAihogKD@)Rn%6z2-i1rNO=j{f+=y;sGu8 z)Ivw0CjzCj03=$ZECEr{08y5JdgMCAm2Ovd(Os|E2UmI(cgPQY z#~V=3g!witwiNYCLHIbFw;*wt^Wk^{dVlUX7ETIOiNpL0#~aZ5bH}kN6~{8Ai;g#- z_vtvCRn+fZ=PX65q_Ze^*1NbU1Y4}r+X2s(dvU$RDzrMp?gslvaR+`cL*dd~peZ)plESB6e=EYw~n2fZ+Jy3e@GrFp2Dx892MQ02gqwc z>2%tqtMw=+L~z4^vGrb1syTf{Sr{rVaJP;3qfdz_ZB^wQ4>%QL>%FK1vxol&ZFQi?ucu<a(5Eg!KNps>@fi1zhPn^{@qw0XttuxQKg?h(=h6c%ks&t@}f z3cDK`DDIJ%cet2o*Yz%DUU54lG0X4nqY^WP9j<+%eXr9duDhK!ued!R+VZ>mplDNA zw97?mmv`SMamc(yb|lM1=C-{1Ug57oqjsB(cn%2sz4Weh&Qq36$i}Tjo&A(#+p#S9 zEAJkZxRyy=z0@DbN?bZ;BEP(w{Hbv*0k^b!DJ7%~%e(K9xE2bZ6Pxk?Wy*V1hWzqw znea4hJ(mYqgUWmF$1l>E@3y7=6pEjg2=mTKkZ%5k`B)(QZl*LKbEmyJn9`f)tleYDwhGu;BysMGcQnM8efRRr~CoUNNqO4Cgsjd~XMH=DY0wwijzbCaxCByL|L1;a94YR{uOh$CQ~MlME>fl>yFf%vSt6&TA*U>n-z(QClh(VHZ8KCs zJ_H_p0~f?wBG>x>dBdbNw*ST<1FIPL)m(5mQEI|bSj9jnRxuq}Capu@hjZ08$X5B3xoQs_QfzMGS95@G zcR6Z-qp-ON3Y(kw1zwS5UMOjKp)B*FGE?TNZrV`f6_sQU!QrQ2|7V#*;yhKQi;m~^ zB_xY?QyWfYYSZLy7-d~bdzI66JU4%6rM)$!z20d%-hke>(%zHOzT0U#p4+;pYcuoL zAP;ZqJmmMU_5lArr>ECtmvR?R48_bHaDjT&K(Pbo1j8@ar0L< zy=7?LRdcGl;tmt=TNy5aVV8hj8AV?z0iEn_aJy>^U5C)J{OYbsSs#JaM-^q+e!0+C z;9mn#-5DuMq_z*T8vNz5X#k;BBD7LsW!9Q*imb@(XxztOW^J#8sL#1qq6x@6AhuV+ zyaoFh8YyQ97#t*lg+h}PY?Q1JD+K!()LkK3Q(f8q?K_f9x0Q1{rYt`vFR1Tev6~pr>hi9~zOWFSbi&F5AcpCBi*I$d+=Q9pZQ)jXN0aiu9L*i+~b72h60}jtb zlN}8DeSQbyI2L!O?qJNvaD1fLgcu7ecFDc9Ma*kZ5 z>|nTFS$bm(11)zjRw9Zc#VmdmP_L(!IjSs=0qI@`0a2EKC~1HwOF&EII>i}WpltUL z(*{{VUk4sWgHXcY5k>N0sFmbo}C*D2260cD&2D!G^dk0ZDX;w^Kb_nM1y?_gXMe=6u+bh$^0 z75r+Z20g_VL>`{g0)^+a@XJh5mYJfYWs0)Ql*&x;3b#rywk&W(Mz*2@pnIU#=nlpK z)sU5X^FkcYEu1so-bvVJP9g}uFg=`#!+Z|M8_@f6$1#zL!`uqTb5H4T~<1p*Uiy7W|lzh=%h-0CPL$Bf@nv$)PFLNS#RS|WrHpuGxIv4I@T&1@I z#@72OtM6M?Ojh65I~8{=YFKRbeNRg3Zl~q0Ze4xK>iYo|lUyOg`<#}s^*&sEA9gCv zK^$@_#@73(tM8AYdguu>NO#HfIUXPwLQq+McXQ{iJV0T$PMs%NobPJN z0f^gv8LzlKKn?xfeUS73g`M_B(O&AbhakQ{X}RKdpJ>bP?)yZW!lI4JuJfaIPRMyT ztF{zMK@EpsvRirYOBv;6KJl$fuzm^>;Tv zqFWxIuv>knc6s+Ui9;M-d8-I7G6{c^@YkU_mv;Bzw>&_Z@?Lrd>ZX^4-?&1n4?UIK zO8$C@>qd!79CCea=qat_vkdX(lf<=5aPtI15dZB zXA<~dzaawrlMZ;(Nl?0dr%|VC{xgYs@`?y*Db&`h@AVp;MqTGVvz6rP80ybBTQ{9h zrJFz+bsm+>da`HI*1MKOZ2f>k-E7*$nU+qwnw&-d@rQ6`ee^8)%#n6Hym&@W(~$#! z@7Uh{Z%@ukZgWSg>QOv$xH3YLY~n*M#W{BcJVd&sivjr1cSJ?cxZrDQgXpyI!sjZ; z(gD8hYP=ry`LA8`!LHKKk8qML4&VDobrjAtkAjBWs~G(M9X)!K!G|6@9}@g5Cf>k4 zRQfVLOdX&T^myO9|MX&i;KL~n5&qnV)4Utw8#VGC{_pXTwvF<=UwI7-pJi%0Bj3jR zJHUMM@A*^0fedSpUU7yeUmU$+f}f3^M`W*Ws=H$CsVx`dhp)iawm5`WHWkP5p{2Dr zc5Z}&fPDfB=Z&21yz6~P-yQzA*j^Eo{B^)AXR7@QO{W)%S zgT*;rIXef(vvmAm(eG}=wS56{U}v2F(&2X6otbilf%Cuc3i{aN;81lH?0!n$o}%4{ z1k~pUHRFY%{a0+5`pH9ph`#hsUR!U{?P?( z6B2#tAFnu4+CEfz_=dN!|u98^HwSl+bGb{B-c;KoekOn=B_rESi z%>1h2n)cGWaTIDt>D{nzSLxkd`1nrg&GX0GcJ=2@;ay4?5eIJI%rs<9O)-AGC6=B=g8HoqByIA+%I$-1&YK97iXOdflt!tPYW^AOhoZtIUt$aaYd@`>{+YxwCb zeht6zm^+J~wXpLVQ|&CW@oLJwwau3YG1L&G*c^;M@QL^SYfQER1v_c_U3J;-ZD!-v zJoo;+Q#2@&*S||Cz7UEBkl$pi!$(02^4y#&nc>a&G)vTiHwfP%u2Q~0`F9Hc{KmX* z{uS`S>^;+v7qO~nx_tMe)g8cKkc{1~jnzfP&%<0vT%E=Lg5M^v6z)`53U?|jg*&Gy z+=&LbVweKbH`DVNo&#L79MkW{T5S{wnMhb`5Q7$wzV)&l2joLJdg!){mil>TDC3x=@n0%zfAX@AcHsBQO&8#I z`$ygIu%JKJ&OSor5Rz;@o<1iWr}B3^x%u^S+&qU-o~MN~@cOq;`lRv7>|`5y8Hr>^ zb@Trm&+*IlI9VL0lT3Kc^F$LTzn}G*XhmmLb470AmaiiQTq8rPeh~u6;=phpFARbM ztCHT!Zo>&%LTxt(V0}Ljfr;2|wZJPk|D$ruVsE7o(M>X6GDqaO^o{6{AmbrAUL)w_ zBv*dtpmT?Pq+-`jR*k~l`0f93vgMWdx#hwu?^@TEYBbR9|VfAOY`2Oxtp zptKJxrxZD^twzJc5X*VM|_opOWuFH7m-ND^l|96OJX$neWcDDL?$ z-L!FBOTG`}0VJP{-RHa-F|~@{_TgBLUff{2dwmoiu_%IkWV@xf+HOl5eAp{3g%Tct z6AbiD#rT`1B#ckD<6|#}9-V`?O>qjj96B1SmBS<6GQ-X?Bjsy`%h!!K%cN0sbX)HK zN>avmMc21VnHlN)n<0w0s)>(JqDIMw>A`c6tQsT;~L7l&EBiU-6t6M_)g|uIL2L$;N?h(iNqn81_-%lY!_rCm^qp zJe2OS7a(_x<|QyKPo|TPJCKLt3`_HSMpuCE4ll(admKn`E*dd?N#;}dF8}D`2>Zt%5=2s7JK(s0b5nU-n#_`EugC;cL!3d?-lnvmW%>+x~F;re``$*n;Et zmiv9O9k-O#R(G6Us6FV3+ncAXuvTlvVu*S(94{}Ek8F)>~ zG$Q-(mrmx+Jp3&vcsoztaumFg&7)vK1@y^5(KiEsupZ^f>uU8IjUOX~OK*f0Ww5Hd z4xXn&MMqg3IGMx0(Gy=Hh}$mU-E}zr(j80Gam$wxhXv#7g>Wa5v9F`D{I|jj zH*JL7Q;FkF&ceJOA4+uuR8sKp2>RWB4kXN9&D^j87*nz+QKT@Ia`%2ScQ0!y zE6H^=TnX<*!x+$c(B23Rb^9nr1}yW8jH4gM{o(C6s`fDMznL4M8jOa*t($T_Pj4A1 zomV$n=f^jpuO9nL0R*@#kNb%An8P}b$zMGJX*@W$Zz{|uPUemgChE#D!rb_E!aRy4 zvO3J8go%5DdGwn(w7Fx1c`TiZz&sklybUm6Asw;ALzAi{XZGTwRUMsot;e_ss=f2h z4_+wLMV)t^755pT#S2j#%>0j`aGZ;UI@w=ctfxht<)KL(bUsly?O1b}l}j);u0LX87z}JRja%Mh+l8 zI~S|i&1K~K@a|BlX7-WgKX;r_GZ{J0*BxvXm(h%)sGESP*Til)h$tv7_$mv^o3SqY zwV#yE@Qg33K^=6Gc3y<;XzaCEj<#y>P(wACEn+=4EM7GI)t~($ejSVW9bK;V7gOhl zjs1B;Vb8WzJ>0HYVgGd7>Tj?h?|5Flt$wtj_-4CNJ-RSne9vSzdK-)8J6QR`SUacl z&dae(3+jT-JCDoy4aVQ%7AY(}9qR)P1vfjkJriTwAG1*2{hWGx;eo_y7iZR8fair-|5k_O|>`dK=mP(SNY8t%dNdR_c39O`sk{KauOFW}tj z^Ew+juk+6PQE#NzEdGm_M0-eXaiz`k?C`c<&8+`D_P)&9=GQdR+5Fk}Ciyjuu}K}@ z&g(4xS*pxF-jJD}uD2v75WfdNZO)FTAcXQRc6{wp-z%QMa_m2Jei{p43*ytL zZJ!)_46CnpURB3l3AxRW36Pa zRhh?H$*fVC@m4acRpxXnnN=$DudQTOsti8e)?`ADa?h#^z7N-2rdMUow31n-GT0Dk z9?w#h!M6^Z%PdhDd;qe!%wm<9T`}@KN4Q${>=?r?$Ep~PNbhp{it?acHwJJlHvV4= zWGKgCV@9V!SZpj|w3E={Z)4f+Y={d0^1b?4+i=&WpD4Lvg7E&APwH@MtZ$$!EE2|8$OmHbYsgT6Xm ze`mdAtG~0}@(jJ@zhVWvS{`{&A3&dinc@S?&Zw-4{o>82{*`s)a(!mvg3jVU%ifmO zmLZ|1)Rx%^wAGfM!wK|a?#{hYo~+P9F2xIZc9}yK=6*`c9KXj>8t4!&0UL*(fM)=I zVNPf9!>Q)^j(Ew!0zan ztZ%EujtV_x-1xa)T;XXkV?UB78ziISA4}IWP8Len;lb>%>ftG9JWL*Tr?Fn;VQjmW zzTWxiC;W0hRz(}uL(AKT7vT%pe0eKa6_rnf{#G5>*wsRZCE&Mbzk>%7usypby*-;= z7M5MwX)o={&TU#Nf`JvLieb_4R?eY!=T%{rW&% z_K|0zo)6Szi+LvMeSx~{KF>sbU7#)-(=$=OHc*#6>zSyp3DjjfdnW3u19jQyo{9RZ zKwUP$XQI9`P?!DjnW$$2b=f+fiF$9KF1zY8QC}9Q%ZB?*)RzY8vKK!S^(BG2Y}3y~ zeQ}^ZyYV{hHQ)Z~>@tB({C@G43H}PZ{CF0k+YXCKy?C|8zj*Zl|Kb%t$*Ipm%#~G5 zebjMOTxs{X7#xS#V>I2YL)TfpJlI*s=EX%_Gj7VuJCK*W~w15&)&-YX47JzI=FyTy1di}9w^D_7eZ z3U9Up4PUtm+u$?Tfo^5N9Pe-|fOo!Ru26X4>X@zyVi%DI-r6JCILioheTNTr- z8#4K`K0R2&4E&ppY1l^Cn<}qDLsov8PVOecd>3HaD^~A*YOh#z<2d1lSFFOmaNB<$ z8e13RY|Yl(t4#2MRijMo1*=Ax*b7#TGO-t|8fC6kJi!ZAjWTOg zCV0WBQD(Ku1TR=M%B)hE;03EjnUyLNykONR6MMm`Q6~0+RijMo1*=AxrHUtb!KzVa ziOK{oST)KlR+-=ht45jGg@f?CmPY&htatrA&0nv&-M?P7Kqo$Uy{hP6uevVvdQ~?5 z{zr>d{_g+S>s8ZHZ}Ck1bktisu{<6177vV0N4>==|8&$_JRLS2^{!xhCU|0bI_e#P zdho#Lbktis)G;0P7Ed^wTRlJycccDl);V?SPaMqXiRHG2m#gmQ%Of91yhvVQ)L`L-dl5bK{m|2*M7+^U z-p}f{H1$%IKH*a1u%90NXXjB?!Gfoy&N+%<^#3`ZM}3bq}btk;v2e&Kb1+doH_i;)C*O2NpVjp;t=Yr$MC5H*8>f{X^{-Ot;h;KR=;5GK zI+LIC0a6YJ{k}Z6AlV%MgY;WdO8P&@QV(9DnvVLlfqL)~)pXR? z1nR*{RMSyk9jFH{QB6mERiGZcL^U1tm4SNj64i9nvw?c>64i9nTf9Uy9ra~F>cLA? z(@|dom9L=5^K5vM4wHdod|Nqp#(!)MD{&_i=9>8g(wD(0Lkh3Soh{`K9LXJ|fqWVd z<2!X{J3pO6PN#3D6-N)>w#Kb;-}#b- zLgCq%qc3ow#oxeW3kJit%RXBLg2A^T?nk$;Q|iHg|JaV6JXjC@JK|OXoCI-0N7mg` zZN#gQ619q{DFLrY4%2FdGYBf_+0%}!L>oB!GuSQDLGC}~P5>Ts{T0L)G zZP3*6rlthc3Z{mR)8);pjhI@+)Rcf)-qf&)>+<$?pEppNH&d%wL|IeA?t-fIc{Ng+ zHzAle&oMP@sj1qaS0g2Ac~esYAQMyTF|`q|MoQEwrlthcYHMA&VHkFKV-1vA(#?v; zT2eDLCBUhg8U}w=TkX|IY2Jij-i%X$8rn%O>KOmVKGBZU^?u5+*Ql_4S4l805B_8W zBHb_~m6g#*3I&Gz`^R?n#*C4gG9 z=nE1(O`_=_WhGz|63wAjy@JJ6F-;#NoEX%`bH8ELNoWHqF9B56RIzI2%|h(#NrZrr z90A*q(;RBv6uecl%0ad*NH{U5jc1IrXM_@<@)AJJ7}To73aeHudPks2kkcG$@)l+? zT>)wu1+r~H!ihl*JVLDiy-)&FUIM7>ZN#d1i4{<@7QG{28*-XMt(bzhYC$>3wgm|% z1~qu9L!pj92~c?npymx~@>ao&Mr6@D0=8jLbEsL-Oj|Xh9Aw*qgcE}rthX!FZBPPK zUIM5EgIbYTVby{~?+Dn2oaRt#rr@nwRSvRkLBfea4Yp$yYWGTk%1Z#XVo70=6NiIn=6G@cpWCkZlX9 zNE8vP2HRK)brQ0G%1Z#1o}2coR||ngBm|7)2-t?4=1}vd;445@ImosJ2`6n;DTad2 z8|9v0r6U}AtGkr5Qwf$?MdEt&kf5a|vO}LBeM}pAgcr>y-5hfveS$TKjG5FR zR2|{`_)uf4m{KFwJ`qDy8Hh3E|jg+X>Oic;GGd1r~_jxr^TGT?&+Qvyt&3n{?UX7Hf z8yyuvj_ozp_8Y#`2sa1@VH8t;1cf;v(uCY3Vu$!qV!E!S-?@_Pw zYNRx8LNIT}NuZW?jlX-LR7y6Bxe=GO_m?#om#`B+G-?Kha1_W2futOPrc91?0=4(l z(~0<-gOEkr;3Y_hxs-IO5WAOQ(u-q^DqlqM7`P<7f~op+2L-1rN2L9Aw*qgcE}r@i#}H1gN|O zQ1b>g`BlM;zRaR`1Z=~g=1{YuiDK|jGs;1>El4;qs1bj28;t86uvM5Nv)*z&0eBLoJws zhnhD{A0(WZRU`i9L1@FOyaZ6I2DK*9!>UzH2j!^*Y(t_s)XZ{bGF<@@HCLx{}3JAboQAMhId&2IQ$$S5zGQ4C30@0Z!Il`)PB zLe&vYGkB-Bm2kX1`C^IE|SlL$eR zC;^j@Xbv@R3La|KH0wbUg>!b&P$PcXAY=iRmjG(bpjIV%4j@7Rsv}?1dNnX z0=6O19BRQ7Jk-2t`XJ%Npho<%gV2Umc?qBv3~EiHhgGYZ4u)GLU>g$6p=PdNCesxl zQ4abJ3ldHYYQ!(=gA$2L>1#i`ga*%Bc5>6Vbh}$)O=#Y&K@CX2$3%MpUTvERWlc>9q*i;kOResWd9{P4RxmXspjI`tx;N(4CQYqsYDz$@Vrq47 z3~q&bEWLCvxQ(0$!Mqu#U}|-5%&ToPp{%JXfr#>^R`ykD0V8FUfNe-LhgvWN4>fO^K1et*s4-s!+OX?Cb`WT#|5G42&bv9BB6+?V2UJI_PlTItE@$5Ja#3rAaA(c`QsN0g}37m zK2IpT9slJE5m9|zY2@WLY?BhO6(LX;lmLnsrzzMBc+wk)M`E=Q}doopI0L# zY8fHes*F=GHSfs`dNop_mNzveXmwNbp3I0>Bc*vWwTf}Frsh4FZj7*Q*NDU zHB-x&n)hV-yc#LZn-I*KaS~JWp3EMvMoRN$YI)<--W9qe|2kJ|-TSav7;zQ4yCs;H zp!G2tNg>M+>C=QDLM2c!Nm%QvLc!Jhxsh>x8)Om8OOOt8Dd|)sR(A73ARR}bnnFR^QT6r33WSsAQnVJNb04mE-63jA0Od~MzWF$xpobe<3*@PheDEbUY>|@u=Y;@3C6G>m9eS`s zG~(4riCV?flps7)^CNlpOD#20YHd@iSwvY=^CNkmS0g2A86f~t38a=WH9wLMdNop- zH&e?SCowfYl8<;bQkpkYs~D&DPG=H7k}tpjqYeNm&6}y!OsxvF^eVwyQbTfVsCo#1%hJt7m7(>|o6oi019D(Xij&CT0tFGwW$T&9wSp@SEq{CcFI>`%NIyFnj5$FLJ zWa$({0Wd12nH5a}GfqZ1XxtVg9BYu&G^mkrZX1*k%u4{3<)|i+SZNZA-VrbfInANg zyn;ckDhDH^1qmkxH8Re1zeu3+5%p1pqsNG;l!Xu#<@Ny0V*#6 z)Vx70NUVUGx9A;#DnU+js8v(&R;?%p*|s3z#GppTxk)GiDlY-lfqYPEmeZx5rjT{mN`Oq3G<}e8d>czajf@8ep^cpI5_O1T#DpAz&m&z&7MGhnhD94>hYCWZQy-6N4HV z4+fzGsJsMF^9HplvBIhqi{25i4LQxBCeLRk(-okmQ6SqEB%Cx<9S^L!XDJtq2TPQ* zvquQVE;4>Rs8{!f@n9Pikx^bWqi8!7-Y|}eC0OtrB~W#QXf_^9N+_bLnj#67J@1>3 z2k%9!SddHnpcDrBzx8n$S3TW-u59CcPRdQLCDo5`dRAH9rdUqC<22vi5qY zgVyUQ0kw>&`B7k-S0g29s3oT6M}Y%gjg;oi)C$I_tq!~M)8~sRr8|#wvm+Nt zFfT#XWi*mP@*E-1Q&EKF>hA4j9C^WoEX$dAGr-mfXYh%HEU2S5-U2Mf<^BLbVcMehgvfQ54EZsWZQy- z6N4J*BfFm~PfO^K1eues8W?#6QoG1R0#UW z{mR+dBLwTc$XFjqO;_C;`p8KrB7_&sD7ygPmso;{aa<6pj&Pdwk=rB`QDse$1k0ZH z&HKnUw8gRIkb%#P^A7LBevj-172iTPuikHVqjhUfMoMf_n@0i}SAy+|nGX8RKCebf z)G|V__>7Y`HQ#RzdNop_mNzvem{U{p{pPS&BPD7TQ&WPrhFaR6eRHYUsjz9-U zj-^xkbt)j3391cDL4#OO%0VNyAmLd3PeYCLDkD&$NvNBKnzsa#c1al~vFIHElQ5_` z)U0T-PDw6UT*^Tsw;^S*hnavyt@Z&S41gY=> zCtTMRMA}!k&ain2(qS$oCs~HbP$&dzi4tffBrKh*C?J>#ie|wSGzb>Yo2CyEj#XM} z8q`SpItXn9^AbRA)mPz$7G^L(R-3W`Orl6Xjs~W~e-Ls>@c;zwC;>n&{?>YBDRQd(oQ9>SQ$$*^F9vHE~lBc;{F)C$H)pq6ej z<86XhnoOiB^UL7K4lhCdU^J2fzxxgX{jU%x5J$jtC`M8M_@=|kfl>aI#Q-gP&Bim31Aw8CX-PP8k+?P$LgVKLcvE-pj=Q7H!5dm zj}WXwB4hQCn#c~V+E5Pa!jwo zO(gIo(}+ZtU(R&0a?U_Uk@4dY!H8^6T~=NwYbBeh%gR&I ztz`LKdWS(CUuq@G<E*;j2P%kP6bSy{+#CCkraJ6TyJX(iiHmz4=cD_MSd)5R+u zM=M!=)!4~OSKC~+E+~zunV?4IdzkLFFSz&z(i#hJpkeubsavH(U;9bv%%U%rhD+zU zgHYrP;~G)t&f7UIao;7~w!bqssGF#f{iDzApLl-fU3Vg+Jg0aMDyOTO+v>=J4;06$ z+t#{l@S)+7Wd! zl3l#P2a{uX`O#!28+~GQ_|4zC?u+3; zxv%Z`**Ylq8}AaIslD^ghh8NV4$A#gY=Da&ReaNP=<#5i1?PhezRkQ_QsUj_g@Eg) z1f0S2DY-nU%uwK?m}^l1P6QOBm4UUS;W!5}lgqC;=Uwlqb~}E1=Nn^E#wN zCnE%~DFK~|>A3uOok7#dn~oCDDVPqP9AJLD4k^u#=~Rr9H=PBVpSSz`fYSV!PR(?( zri16*nIEr1O7kNG^W!l7yDoC&{p~#V92O*4LUV?;}N71iI{9Ne~0tqPx36WDzC@&gd7fdyi zWgJ9goJ2WT>aif<*c6+ZhBb0_MIV$9%u9f^X3-ZURvJa4hf$OO1Q4yTR=uD_RVt$6!y0*nmPg>SiZI&rCI$N#v1?uuL>d56T=#LW{PLv0xK^8*1Ta&-YTHcq%0lfz+B|C!kQJ;v|TgGLB=ge zI5Dh|2Lfh%7A_X@ES&;~R#B|eBm3~Ow20kWtA(?1OtHnDW7AX;I~&9+krFNe4NH2}a?@N%9F1R8D8k-XEn6j{oc(ilW z%evBZxuuq_Kv>NsV%WXZb8S`t~e6%jcu$ zusVyQZ-0NDxIW@9PQHO=r9VPSM%Ahi80VG1s9NC=@1A^tKhpa~(;=lJu@KNnj8k}z z(@`ID8~BI=VVL>2*kHeoUuooXmS% zI=VXByVTMlrTGzp`SBdn(bd^)UWb(C$8@5n+`?`Ly$&hOkLg5@xP{K7*CD0(F`el7 zw$OP>hudD0@)sj+98b07q!5>2Qdsy6hbpsJ2zVJnaM4W(*bqd$>E@w7g+K(xYI zFhP$suN-9Df`k*p8u7tqe8?^Qa7(8Oq7~N66)saAYoZ+VB^D%{7}kgnHse!nVG~Oy z526*;stJ0m73H8Wu^{23u}W{4x5k*f0oe_FuxH6Jw-t;ZV}FFgw$(kJZ0kHPP&z&d zfx)3_oDA%e_PkzgI@3Jh7Ty5Qv~`{rC`l(P1kzE0>n87Z={V2J>rC@#TY4&9hm_{W z(utmH3!PrL6N-(L=p;gLfHY3QusP4m>ufWLtm!C${NznXSN9Hj9a54`!E}_MCuusm zy7!dMvi)xtNDtf0xfy(g1oIMfz!@a17Gntao-0DYi>fLCR|Q19@g)T7yr`IG0%5vq zR8FtqGmnx`rpG0e2tjvE2^bzkJ)znf3bH&*HE)6%M9WzmK1ev$%F|e5o(Z&pb^52- z!YBrz0-_bx30S9ppe5^l7;ZDA8jrwXDK*33eyELH~+<)AOIAmPNY#yk@!0qgY7w1rJ9ojizESgR)J z?OIU|`VtEgP8w_2?Ij$OL(hboKmUi?u123c_CpjlR)^-`dA=75g+p!s^m#(zP}|R6 zh@!Dw$(PgAvMUKn29t^q7$cNGZ%{>*Nck<@mzxeL(W#k^640rbj@y;=I(?>-5d!Hb z0iA;BxLrxFGiW+_(@_FCdDGDqqY=ULmX7)@PwDX5AI_C_BtA&QHJI_?wdlUO379xR)SFrLUG;<_JQf@p;`bE(Ue$C@YyeYyn+Cx$gLuFv=YTiC?X$%ANxwQ7PM zYehNe(|r($7}m(RKI0Q?VUx?8xe^equ;xwBW6dfD{-Fg4Cx$gLuFv=gTiC?XseovO zHOVyAftq3ULBfe)jg0HPh!5jBFM-coMPDb4IWGy)XV#Qq6D8m?gJ^}dVuIeT1&hN6 z2`7!Up(~+6Fs>g{&d>WHwi6uJUxvKc$UXQH8k3_IDK)(i=-KneDX>$o@AZs$9a5rG zF&!m1qMDA5+}$s=bVzA`Z8|lJC2Kl5a`$;1Qlg{h)pFGF9Mf@6;(MJzlgJCf{1_)O z9rq-@*BLR1is>kU{M6p*Y@jO+PwBkcx2Hzo*x>jAX%y2xuNH$NRHW(_K%^Q4!Mc@z z$jCP118Xr0e4$II79>Nebh9pk&$i2C)UC!mQDdg z-6&JB*1VvhuPO(lqXh{khBY#>&G^V#*yKgdfEf_2uog_v+cmEojE)v0oEX-~$Ts6M zYhe>hrwXDK*31H{m1fsOIT#%+NH{U9k&$i2ht|R-mQEf-E38!$^meT%2cx3}2`7d% zGP2G1)LPgCvny#t35Zr$^CsxAW|f1{(Sn4N#u_%y3gv>4?OAec?Y-#d#@>qDVaAGM zYk$nH*3C|P=hLhl<4DOkk_dq@K?#mm?1t)N+%~U6N_4WOqXhdp)6p^Rpw}TKIt9~F zg1w>X=omNYbx4U$)pV4APGUMb#?APgTFf+`(jm2b=hVCA$S}gwY0-1@5;}3$xSZ4& z!jdpcD3(qYL@TVBi(RHX)V8-Xv!X}nZ9z-jwRTK1B zE6PD_upr^Yutvs!86Q*&n_S||m4Il4HE)6*YgRevS1m|5F|3g>V8$oa!X}nZ1w<>X z$@3fQK+UlFAmOC3>KI^EKFcVAG2mHpRP7r0k7HLMch>VCd>)O-o}ZMqcOlRN6pWK+ zgRb}dlU|3E_Qexu<{aM zWf@9>NrwtIShJ!EL60?~9E@5PB%B!5NY6Oq<7qKNvUCa{T4Al3pvPKO z4l-^*!iiyx^o%n;pB6TGE-ejnWk9sTS};M6HLskVJw8Y{X{-`6D}$73l?p-6_$)b~ zc9K2gE75zwJH`REe~P^u+1V++i7uY=le?ugvlk;J2C2<+##aJ8QUSI~^_G2Jhm`1K zgkXUgCvQ61TMl|1QlgVL9VL)X)^xPDd`gGX=2AUhq(d6HKpQzOVI#NdkiblUhq_J? z>G_1iMh;HBGA0D;)>|UI$&62>MbBpmWkJ*vs{OhE!N6b`D<-HxEFtBfm0OT-tk$Qo zMtYMOA4`kjpxuG0odavu3raSCHKQD~atjhp3~Qt}nen-_u!*Hp0MW{>H52r9tttn# z!GeU7#wxvuFPaP+Ptcn@OAe;phsHGab>z-^jy`D(>^VqjFQ82ZMQofZ3O&_x40;_> z+6$OY-Z&N0(VpWeok#nL^IA5}gW5^(67&KEtD|!0tjuC5!d^f*=mo0a)GJY*U|lZ| zX<0KqkQS{1y|dJ*42XI{S%HT1nW9*(V1gQimX%iy#y$%Yj@8yQ)=0~m@rkrBiltKp z(F$t@OEZ!wk2O&aW^5KDoHSNZ@Y&5%E@)ZLk|Sxa#pp4%9kpM^>EiFR>blW+o76S7 zF;Y_MS*?&5ERB<46|B!?p3-5o|Jv5F8uJud)N)>e_L5j#tT2S_r62^_i*it3$*EV3 z+B@nAMd~1rp`{PbSkm(a=25brz&esp%@R@$hvy)nDiV?k#1z$XqRJL*oQ!hN<}64! zRtHs+F`GhxazPz@mK;Z$pzj)c0yWBN-cve@c9E8zJaICma92+6EZWsPmv+O-o=m;Y z6s#zfpu3ZV>dBZ{L3TP#d@u7cQm9t+qY*#Epj@ zoLID@XNiQtD;I*C44@#nJ_O|F+`19^Bz67(XE8xArdBxCf9Xes!eO<)a+OdxtoDY> zU1;%9Y*Cu~+Xt7E@!-O&1$Wm5cWZ(>9#jfFDhPhc`dm>|xN@9nL#`x@xgx<_<&8rE zn?}D}m03*f{erT;I!DfJ7(^fv*|wfacBB4#x#R7X)|ngS)Qau0!vrAdo2Qfl^eslxhHa#$X8{6|8+^yC-DhMRXdY}{)E~OfPE|DKzpX5@kJ5iVBxf4L~(DzY2qemSpcEA@r5b>qF<3%K9TjQTQA&HDi2>D@XZsMyI*JSH zXmEFJaJMG7Tdj9g5J;5uKq)F*N;LpoB4MnfB&3cSCr@b)w6+e&xN6p;{U`!iM{!{t z4essvR4DC%Rt@Mvt)mEJ9mR!pG`Kq+ z+#L(KqdQVl@&OBm}Y38|yTsZrVktr*b70<;@rFo5#HIvU)~5AM2x zyAHjhfcq3Jnjxrg31e-hzY^gCBVZV=+$K;Oo)NfGt~dMPRoLX6N4XldgMkZ0X{Dt{zl#qK8ZT~ ziovfiobU@mK+qBB_eG<5<*Av5uRK-dpwqG-;l$uaw!J%634C5W{4U-QK8ZT~s=?1P zobWS3K+q8|p=dORUoZ_1Kd&5gS{5Xn82l+4Rp{`c1ncwS;qT`S;ghJtuNnLr!wJ7C z1Oy!c6N*N2_?fp;6&fCXq8xNu79^ZBd{M|--z*k+95$% zv0$!_Xst0$K?&3v5XkATsD`G6Bz&S((-7i`4MVUQohtuXJpIthX^0_&7jMmkbKZ$X zJA2NMOW?whLllIg-+D|(*4=gte&k|RL@lyeGYLem0T(CyxE|Ezlye>Zqvx;CyUsuA zhIcY{*^Ll&TkAJs1qf=qAlmi8-Sxp;KDg`CJ1U4HN?GroQdGERXmEEbxT^(sBYH;#fkaskl%m3=R0GhegaN1!1bW6eBnI7SqsG}!X%DnuKy`)ZGy+*i zaRJcL;OSlbssU&sVXUJhq>dVA38g*ItO3;(o*NO!I*JSHXmEFZ zaF-A6`t*(p0*SI7C`E-!sRp1~31b~4A$8O^8!7F9W(=sV@Z5($)=^woM}xb2gS$#_ zH>h`15J;5uKq)F*N;Lp2NEquV38|yT*-vQ?G%=vM!t?*L_x`bUZP|Sv-5$w3yZ3jV9O~BJh)6pXF}p?BSfoP zFzI7L7&5>=WLSTw4T}mb$D>$8E3~TpVl(z@&A75ddDK|8<%F@HJ^g;xT6^Df?m1Uh z1QZ2|5uml#kMG{+d-mC9@3qgpyyv-sj8PSg(T4T3VI4HA58a}IQ36|t0yQtFA)>n$ zV~nEM7|os+pbOE1&om#Le8X28Q`XzJJ04!#{o~%_D$2rt55v+ZDbX_Du2jp)LZlG4 zG|Ci6x#FQg4!)}z>LojN*OP}?3m;Qaj(q}yW1|d?P50Ze=ZISdYKnkUt|$Yw8aajA zGPZDY+PcKKhKIC@FXpNxWS*SD)#-OVc~ETzD~;r5PWLdZ>!b|mGt9l~h+Eg00zFsM zbyj0E{i#1eRn;i;$K0a~G>6R7MZfFGgDQ#s1?pz{7croZGN3<~>8}un{-P-YhN2|i zYK*48n`;#MTkg@exr9)<=yyGN5SBZTDw+NZ4Ctc_=r3maQ-3n(kC`H1DC$Ca1_ReQ zD$Wq_6V5dX{W7w8DHRHJ1Pn!8Xf;On z{@8a>l^Xek4!jL*n{&uKUG%%2JgAcBpQdi6e+C2kCr}q-y%-$ub3iWDC$D1F}n8;a*fja zyYA7Xl|$y~qTlu8;omj-$5a&hCorIoGN8})MXc3N#GyZBih!Yb=vBSHl4}(Di|)~+ zl|$y~qTlu8L6y||cd46u{~iYPQ3mwcCK~+%;?UnUMZi$hg;ry9@B3S@RHM)z`%^Tg z6}g1WQ>SnD`fk407pVZd!IKAXLi4wUc=BML{Ny2r2TvZdXT=qb8Yw!{c=F)K;=J-f zcXJI>Mm~A?NHFy#Md{5GY!P|#FqZd<=HbbMdqzEZc*iU1L~}(HHSd9uPab}rCl5dR zJ@I{$>KpX;zWEu%g+FQyP$<)zZ&>FV)?CAimv&LXayqaj(*tT=P(zvCl*PDMC}esU zvj-&x7dNtcy7mm>mV!D{3K3mxST`HiO2c~3Eh-o#u!Sg4^MV>8x@a*GH3g#U*@H45 zx|oUjGl<6uiYSGM?lr834QsbyJ#dQ(MhR>o3e>!yhKO!iOhiqA=#%V084#VzMEx1W zu|H-+DMWOlVU0Jev4-`L8r2C>!6<<(M1h(Y)DY2wOv@CAo-nkiqYQ{neMU#%gK>Wb zaX~>HkU~V~8`imoHP^7>9colCN?;37pymZNM0Cnxj8PODquFy2blHuJeI|(dGl*LX zGDcO1=xW2d*|1g`)_ZPI!6<<(M1h(Y)DY1{i!nw~Y>Z~lI_N_5;L}0WpFuoUkTI%4 zME4rj!-lonupYQY1)~JE5Cv*pP(wtwEXEi`u`!xGPe2!kJ;=07u`z0B#wcwRqFb4$KZCfSAY)VoW3*wNYgls) z>m9eKV3fcXqCm|HYKZ8R#TcU~Hb%4OBIrVNB@^{$5VsU$jH+OaHmsWsYo%eui}R>p zl)x6EK+Owki0Gol7^5gQMzd!fbRoJZqV?}Yd}_j&j@n+I{x%C!l$G@i2AKd#w9F@e zYT5FXMdFsDnZ<2QX2=}h7yJxGEdHtsF~?^?2S*WlEM^){uvDGIw=GC zTbceMaqBu$py!IZ&T5RNzm;ng`YX9=37Myhe#hSUv1*GxMWO!$1NtZf`n#F_*qNYz z0Fb^6MO~=SAi;KyoL=tzIjbs9p+Dsw<>n=X(nY^xZ+ul)(WfZ%uVX+TWkCNR)88Ua z@2{95U?@sdt;XoyKgcx-{ayDcH_svSbkXnF8z1`)qfb%jpTK}V%78x0qmBJJ;?SQm zg}!t}U1&8%(_bky^7UBERZGY`UGzKl#&=a)y-!i--@|}D%78v;h|xbF4*gwI1Pn!8 zXf;ODpZX(I<%BbRd##LZZ*s^yUGzKl#urpc^eGDcix|*H8PK20^jC;Of6){HL(vY= zYK*48n`;#MTkg@Ml|$y~qTjJMey&QQPf_T$$v zi@8RjKj$7zS~+B%F8UpN<6EjE`V@u!ItKJn2J}}l{axbp{+1~MhN3RC8l!vP-}t8* zh5muJp-Jm3ttw=mI(_rb<RZL3EGONGFe1PQ2lK@BBH2XYxNW6o@{_9+UymtxVK+#K-;}BT6Bn z6Af#;VU0DckJPA6kP1c#Y#|ENyr71N9%Ndk*cdf5W0W>ZkFI2*z9YV%AY)X8h|V{x za}8^*VZGxP6^s(tLKLWZK@Aa|vKV6&#l~p%Tm)T+E@q;>Bfg~|V^oERt~RWj4Qr)g zz2_Dcj1t&F6sUPY4G~?m7-JO0#%T7egDynpGEv_VKUR=2szOBf8rH*xwcD^BxJ3n{ z1hx+4}<)zNMlpQ|lPE=u3%~d3>vu zEo0mzZi~Jt^qwnP^sPo-^bbBYICjTQ?YY3}42p8>7Z|oOT1)mm}_`Qo;mj@U&7w7UQ@g9$>V1kr{~iYPQ3mu6GW`SM(BCyhz);kMR%0~%sXt6r zYUH_S%sra4a>zVg^gDKH7gR~~DGL3I7|=%<&?l`HYxNUx=r5WgU??7X)!5(7H46PL z_h{0}A@kJfH|O55ybUNjwHLXjhqP03Pwdp@s6dyMo!V6PgrZR+kIpo9Y6tBJKi619 z8M#w?Us3fYMd{6Z80^%xysAcpE7>z@r}m*&)TPc9QPjK#M()(UTkGSqU(g4s_7kF? z`|orwO4G~X{@}l6nqCg~XOF3&_;&T(f6E%BQ2w#quz0ur9kr1)~JE5Cv*pP(wuLEGD9+K=gX{ zpbUu4Wum^1yQ?50PlbqXH>^7iYpY?s?-mt|64*i%sChvR5nZtuV-&^4X!hI#U2^29 zOw{*r&lO~hsu0n`hV`^z9W<;D-J*g~0$YdzH7}?kqPrGjjH1{W&7K#a3(>Jm)c0|x z|A3EC6(Ty*u%;Wk9kUo?6vf79_M8D-h#vf9G2=sR-^X25 zkTI%4M3)-Ym4>z0ur9kr1)~JE5Cv*pP(wuLEXEi`u`!xG*FhJeyCPcO9{r=QG^Vya z>e!+@{uT>Ul(pdr1}iN}w5%-(E!#>v_HUSSbMQ96crD`VP#h9gV=LG2klI+uRR*D;`vGN8|NV)VC&)B7u?K*kki4OU}x?;n&J`FiZ;swHHeF8Uq& zi(^wppQ6w|fdPG#0sXm5e~vixr%Vwr6m_B17)^gA*C@Te=pJR4Ib@zL`W^d=yQ-w# zrzrIAVL%^cKz}jQKOheMT~h=M<<>NzR}G%2f0L@JQRt7kM+tfknWu|>$Nu7iDv3Tt zp??tr`X~eXE1CWZap*6aB48-$LaQ;l_jhxRLVwFWnw4_MJYDoV_7~4pN%ScS{TCR} zM;XxH%Jj>tg2%p<^AIo;b)h`3>ixxBqtKsok0z}gGEbep9bzlrEL-4USN0d{xu%D- zzi?0NFAj3J>@Rk+Clrkud32_+zwl$}5apm_B$jrjo?(vo`^Kg6Lpq@*Fw?=f%Vj^maU)OQfi6%xT_#zRE3CcH>^7iYpY?s?-mt|64*i%sChvR5nZtuV-&^4X!hI#U5IXp zXgx9icr7vSNRFR>+{dtrGO516uq8@Lw5-IOmbI{I9nzx|TVcmc;WE48q1qBfr$u7k zk=b5QErlt{u`goS>Mmt)Y`Wi$y+YhpcT;riMOU=CTaCQBFIo*c%&Y3ADK)ZZD_1Qc z^W^1`nwfq_X8T;V6{aZkUtn0*Ng2>T@FS{!CWHQ%DRiAH9vXCAoBm?1;UOhBbGd2> znWu|>M`n9VwMCzz&|k-ZKFWYT(~0%|E^&H)%M<}aQG#SOM)&^MzfM)vDD)4!4Q)ws z$UI&2J2KnTswDaph5i`~=%WniGi@9FMdHw(Gey8qlptA+(e$@+jY5CLJ-RP)$UI&2 zJ2KnHswDaph5i!^=%Wni&t>{!-xTx@0MeJCs0$T()!>=4s;W`wPq{~VQVyA?i+)FD zdsUT0pQ6yejsbm?0sX~He~UQ1zha7jp{NV3#^~NZ$TbT6UH2%t%pvpC>01x2SU zn}c1+Y){~!7d@oR);*EgF6MB_Z0E8k6pb2rbf%Hn`ms2#e9)C#!<3Ov&L0S--lQnK z`2>T^b{EA)g)7-JDzp8_D{64$iYRK{10yrrpCz;XQGJeQ&&#VH_-a*(9QW2YS_2eX z?N%Gs&4$IRzICWT^0shURIqgoY+3Dqnitg2YPV=H^`t4RcI(-L5`&8ynJIdZ<33hU z2c!_uy@vI$VeK}o2X0ZpD1j|RftnZ85Ya7*iKr4nMCTjUxrQ~@ zu-sB1W%?bt*K^fYn4-{sfni-IWkCPHkEs6n zh9EO$3SH-lhX!4@Xf^8e7jq2{F>mIoC1jp1`W?B~E!7r%ib8)K1NtZf`b;O*`@6&~ zbu>l5EmyRjS&h-XU)~*D=pW>&C1jp1`W?B~>ECbkDGL2~%dk>Mc?a~FwvGNGU`riM z5q*18vHfJA)fi2GE7vIWSKOofB8SY=MZY8WdaO$7eTqW=2?o87GN3<~>5rWZ`Ue0l zb#z6kqe8D5Jabl6O&9u8?osNPL*}W|_uMPrEGyt(S8}iGxu%Ddd$}iauiYFjxz|?q zgrZR+kIppbUadiYkZYJSGWR;=D=J0l%`+I}UQ>D1G!K7!?VeG&*JZD$!I3MX=wf+b zWbXA}YkGb5Nqt0jLcES!wA)*rvYrJ8NHLQ=+sEAU*h=MIdftnZ85YdB7%M^&7 zFtn(n42Vu$45FTKT~JU5q!7{hhIOuC%{8od+@gX}0$YdzH7}?kqEi-Q(4#=~V)md6 zh>l$hqMmWxQcy%GM0B-b-E3GZ4eLF(s9==97NS7S3u=hyqQyki6o{^856Xb(!Cwrb zo^d@^P(&$2bgyAOY*@Pu>w#NTFiKzxQK04pHAHmFVvJD~8>89t1aujryCPaoWH!c) z>8NDl@z?r^s3=pw6AYVBr9{hoIIWg#Js8uMh-^JL0B94cE1FOh8ce8LbXp`b9htys zzKo>D7&Mm?nKKw18)a~8y5H9#;{4I=u;H>CorIoGN3<~>CX{|{*);KhN3RC8l&m2-7u|Dfx`fPAr*9XS zQDg_*r2_0qCU7q|>LFzU?ukrb>^L=5p=1IFxk4x!HNxmj^XH3pEY&Cnoyu*PGBOjm zESLrZMd{7!7-RyAC^jlw$(~V}!24cNgCkc&QS%-cnF)Mao1JH$(6&rZVe~TeU)H2z z-(;+Qgy;D2Jm&e=SW^_5c@G=b(}s1>us(E)3O2`rEi*4r^MV?hd3P8I%YA33kpQfWDm-K z=v*f1*}+u>nFv&f=u*SF(y$gA)@8S-V3fcXqCm|HYKZ8Z#YEH;h+fYglmXGHO!Sz& zt>UhNB1$2m+YReZ!`fqXf1P1!`VULqu0BCZeW5^j`L$42X`2XnoQB$6sMg zZPD#m_-=ibg(=G2wvNF~h7v7n(WPaZdUuI4ca^uthoXhqYUH`=;NKe@yJOXQF0eY0 zq8$4L2FFGj9GmX9V^2-QvByjiFcj?xn-T4TlIibjo3oUv+g$(skA%QZ|HxoW*9n0k|<^yWGS ztJVsNjS5$?XVj|oz$#|!^FiKzx zQK04pHAHmIV%%vcwnAmkbYIXW$NTU|4!YAJk+%6aNp$FO@u%HY^^zfJtR#BJs@MaSN9MKh<> z$Wzah)qtB<)g^wLs`7Y9)7L?+T0-W@Qx7#W{jQl)?J0bkW;6XW7}j-C2K2Ww{YB!| zb*4bi6?L7}7)^gG*C_N?a@7(tPo2JY1~X@F)I-di=E*ZBcWra#EFM=h zbNUS(Gp8S`-tBX_hAE?GPQlch?}5&}xsG8oCyI>9;kUi4c+lu7E@1} z!X5u4dr$^<{20S@Fozz~pw^jEi0DMa8gE!*4eKK{s(Mr~N?;37pymZNMD!rjG6kY1 z3@z#?1EL3ip*b~u&&TYDmXmf&4|m_PFhv;=_b?a;D1-ZpmTh`CAkO`@Yl?uO=&K1< zBi~=Us-d&BV|U!!$DA5PIra$*j*T)nHr;Q>o+Hk&r%Vwr6z%1$Mn3kIv4xw{zB#>; zYj{X)EV}2`AY`6=Z+p#p6T4Js+}rnZqaI=}Z=SrD=dv~K?Sot)6y^F{?Xs6|A9O0W zVamvR`?6r_Y>LvG*D-7_j{)C@cxKUO#F6wLe z4=Xxyu%4Sf*37u)oXRuZ;8VYg_SO1R1g^AVT z-1K!DFYf>T3z#vMc7Zm=(pL6_qUBkh!B}b^?m%&C!<3O@>6G^cMHx$HFc?cyD2yfZ z*e68h88wzJdqu6nxgrWf)dC~O(lt$2&%R2No37HCe_zD)PwLrFwR-5i(d!J$^Cv%l z@Ugd-K5^rEZ|qA4Hcg*a2Ko85FMR&DKasEL@arRcV}EDu7mok<(b~@(|M6dY>v#Xf zKS{?vzV<)A<;VJcx9vFA)J&_X;TI~rc2m=>riR~-@Y+pHwVE3KiH_H9ia)$-_SNv8 zv%PjxldYzPzkvJNO`U8tHT;E)*KUdrZ<;4K{QZj8Zi+`z&8CJQ^t^UcY;u}S4R0M@ zyQ%S3Q^QOBYc|ztXL#9ut#*9LFYg*Vl}>#u?!w~J`^S1`dVgV3e(vp_-*3l%?8#66 z)<6IJ)Qz{-o_zkdKJm$)Tzj$h74h1zxAfYuKjAGOzx9k~#vfA-S)ajwQBNqk=L*db zpFRA#&mR5$Ixz*G^dDEtDw3_hMjQT4*)(>`j}x z)N1Ni-n6NUt){;CrcGUFHTC>Wo0@Mm^?$!m3_xt`#Jgd-#vcq3-2Dk`uXFZtQIVM z&C27SJiqT7)RimtpmXB*=PrJyXYTQ4kE%II zr}<9NW<%>4X019a8%kiI2{O|J3r)vd`$hQ=MDtJPBz(Za2V~|07Cw%-_ABxq>Y)EH_{>}QT16=aJMfWk zK0C%oJ0;_DN03L=mZbA}zi1nw^(ruH)on@mfQ1jp%m*xd9CPj0<$s}r{$%i3w(zxz zQhc`IBjJ3ujgRhrR+Hc8!q=P;R zKHC<)R#A%227Dx(&xY~I<7Zs^_D9v2r1SYmRa`p?tyh6rt6o~8-)~s>fXsZr!pAYK zVZLwSYZayVtinga`K%frZQZSZ&KjRHh0p1t&4kvgz^ql%k~(Gu7Cs;|AF%LoOlv$( zSom5+sk?AlJ62JO(pZ^p#PoQ=h+Pr(QMD-P-E+BU3!(KYFl*H%Nr-`k7|2WvEW{ks z8rZWIzE)9+*isPl(utuPF|EBu?6$Cvs&z>xcB^Qsq4g>-n$jd81{Pu*$oofx_iQ!Z?m@{*c-R9%#GVi$@wA6l;hqxDD~zl6lIbNYC_cmCzu!w+fIIm-QeCV%7jwK1LR9_LG4&R4x`D1(T3b&wCW94Q6}8o zjCKMUjJDlO+3j|N(eP98wdw;^QsN<5XSD2$4&@f3eQ&smGU4uKG@(yBYFF*ZE2iQ$ zyTNGq;kuT0wV~Ngvc~BAs&157`9x&ZyFq980lkuZRZ`|E zS*NohI;--D&a$^!MVWAS)7cJW(AjV^Ww+Z6I>Qh7l^m*)R!_+~oo&(Cmrr!|ywxho zgu9#0Q6PiPp_?hY-EPns{-8iJu4X39xRP}`JEAiqpXf}gu<6#zgu9#0d?16)Y*ff@ zw;OacNQdsPE2^YyOtMaAPjr^$6P+b*wTd#~?xwR5$e^?8X3B223!U2RzT?RA`#S1& zG!kX<*e|jy)u#9Q#|OG2RY!NEB5dHiqxm?qC>zxL_+{_?Dz?meo`Nczfux@a?@X=;_G z8&;B)A1o_B$h`7{W#xBFE4!Squogy@oN26+Ui!+9ZYfFLXkHOk`M9JLyIiz|&@=+1 zDIb@F7+8pb%*4P#%rUL(a@NAi$5o2heh~B0iJ=>@yyLtrtnzV5Cw8l7tD$MZmZp4M z5@KK>1~L-^3o*yEvdbk4D<4-WVtYZ%ODBeI#PZhjp|HxwC7sxVqV0sH8AY1%aY=}Q zg&4?83@pSP)5{#n(}dJN-iWJ1{Pu< zGcm9bb4)9{+_SLqag`#r9mKqJV(3OJZ$_u}JX-m@ycxZuCY6s%I@bQ(+%f2a-0ifrS{zObjf<9Mc;7I~KlH zQHt0?5cATBp&PNh89kw-{84pG(uqwJZ9KGI1!k=plY|&ph=I(+z(UM1t-*g7#3)5< zK8Shg#L)Ae@ALLGv97JzC4FM2F)vwL@~u5Cgxp&77gVr9N11TPsy}OI|MG1ujzhV` zO@TCKCF>2-TWWYiZZ*7W4e7djnQ%wLGjT>7KoxcZiCgA&RLE|(EuF}W+B>WdR7shE zWS!BHw|FSG80~w*Rg?*LH=_xCK1rtpqa&}FvfJ$jqxKGKT5V`1l&mvac1E*ui_uIz zj+Y5{H=~7&^!oErA-mmfFlz6xZm5#db;&xTRc~=sZZTT+hN~zO?ruigfs8)da5H7M z+YLtT9o9ot()ub{XSCsr_T?6%J#V;*GU4uKbQH*7bm(TvZnqnZ+B>Y1`Z!scpk$rV zwlkWMTZ|@EFgl`4xVst62QnDVx|y=u?FOUvChLkSDQlCgGum-R%W{j+k~dsMnQ(VA z+6ZJYT6HsJx7!Uy?S0mLRno#BS!cB8jP~RfqaAO!iZbEuW^@?HV6^XM%5JwCjC7!( z`Dk39-0P9NWS!BzGn$lJj3!iY)uK$eyBW;}G8oOcnTp%&2BY?F>ykj4dL`?O4xQ1G z++ws~4QcB2GU4uKv>M1@v>X+(+wH=Lvz+xKZ9CF7TpQ6yl*wad!$pnyK1ts!)0SFw zbc0HA8k(Hvgmi=D`|QPD9Hj0mIWAOUVy=}06V6Y z7hrsr8RV_k2g2$zEJ-K!xM+K!X?c>SK9z(RScrkl#K1z#F|8zT+rs(`OQncS1Tin2 z7`hS5Td#3_14ticNjkBQRM)km&~zab)rVQux<1U31u>AB7+8oorj_LFTUZ}vsT8pz zO&au=mre}bh~=%J&lE?N>|U?B!F69Wq|$Fv6jhK03@Rw-gTLCi}hhHk|2 z*6XFP+C@t`vFAlQ3{AUeY1&0gLJTa#KxSfKA?BFY;NP>bcF`(DY&(c~>BP{DSl)U~ zE2Y#fTGEM~D%xad${nR?7cB`fun+^8iGhWfV_Jj%D2P#t*hUcZ(utuPvAp%Vs3sp( z7bKn7e9_K@)~mp*RdbRM0}C;bnHX4zIi@xEXDqDzTBV4s1~D(47<%5}e0%J0+8dFR zhoWC0>&q;4)$EMiT4pCz*!1mX!X3-(vYq|Qx7+)Pa{}p8Ey;Sr^p+Z4kXsGUTSNL( z%gcm28eS5RV{!mhSPmp^nM+ZjxXrfpJ2PtUCvFR*+gq~EXxm%dmRpQAtRdYZUMAe# zjP?Qb4K%Wi_xq%Tt%61cQaZFWH4HAGiA5i4My$##7$MwPFb?fXx|xa z$Sp>z-f$IV!rjeiCy>Et+s%~SZZ{aU_Y)tel2Q@LI-^5pbSSqN?R&#jlnHk?qX~WM zxpvi#ykg33w;POfprP!2T5V{yldLm3az?Xqi_uIRC(4Aoo6$lbqmSm@Oxf*rgOM_( zAx1Y;Njqi9IwMjm-My=Fi_x+-Tt%61cQe`!WH8!rGiA5i4My$##6wlm8Y)?5L>4MW z`*MrXo;O@YnQ(VAItpYkI&?E-x7&qLZ6cfWJkRzM6Or>pnLJkZ6ETyO&s}UkaaMJ7 zgGzE5qCOvufR;HMX1J5v9s7wJ0t&wncuHL`oUQ%DPq3dj^G!BoMYOFl!Y~+sf4P|ke>9?7ddoWee*8jp|DD%B%RoU zqV0sHK_E?ulqAH!LJVXk1{PwDX(v(^)+(WrOAy4obYkd6Ebk&-3adm)(uqAU+F@u) zq@*d4l7tvoh=I(+z(UM1?L^ALN~BaW7=oCWP7K|M_G_^=m zA|(kiun+^8iGhWfW7>&S5Ib^WGeOKtCx&js@-E_%n$*V;l1}VG(dI+b^8so4I6@L) zU?B!F69Wq|$FvhE3oDUQsUDjQVqQ8ibR(8`5jTa^#}SfF?7gBbho%Kfnm&$@gcw+e zfy~6fLd-F(!M|W(jdqnHHW9?UbYkd6Ebk)j3#*SKB%RpZqHTw!r%uxJafBqqz(NdU zCI%K_j%f}4RSWB}v`P^>(gMj{>7^4xH)44g@l;rS93kn%J}laPXi9^m>Ej4Vh=GL| z$V?0@#2nKa{5uxb#}O(;>@bLV>BP{DSl&gPP&TEHBP5;JMA61W)5j6g^l^kF#K1xf zWF`g{VvcDI{=*{=jx}u0&i>`w?bP_DKpL}>^@iy!HM}9W8eX-Ablts7xTE160XZfIP=%d9;+DA` z6|&oHTO2c^c53{ADk;g5tTQ_D77yhXqkV6;nsG+^a*NTPH(W)TaCb903S=-k zbTehQ+YLrK&=8}O`dd!zZzb!DW}VTD++sATg3%FW!rjeiK9Ip^*3FdNZZ{aUQ{yYD zq{m;9bw=~fXjyJCTJnagC=>2(MjL?)Myqb7>~_1ssGS<$S0ybBl66K4&S+0=G1~El zt0)uhZbpY0>G$fsn<=~9E{tl^#)RhxmKq;LBT*)gmDD)qjb>^*t@^q_B{>alN^dYv zOEY1HJGtGF8eb7m)#n3GsSAd)l^S2tJn`%szr!B2k01Zshf}8MmFNGHekEUjS)*5; zzu@n@%j5TP{qeLOCQJH)^O628+qI+6^e|abJxrF(f&-QX2V`Dwz_Q>trj^v}TUZa1 zRq8~xbtUL$FMYv5x0Ns_&S#C-nL_Mz(Pl!^wnLg8CQCvLEW|)&VqhWWm{w9VVPQQ? zRw-f|LCi}hhHk`i;(SF|JxrGLe!5(=h0t_yr0HR@B*ef%3}hw-7GjQRB{j1a*283# zBDNaDymVsdMl2`Jw}sUnNYaVjD%xsj+5<_`9!L^mU?B!F69Wq|$F!1~B@1g0q*BC| zgP5024Bd$3#QCAH+5<^Cu?I!l2~BgfH0^;TAqEy=ATu$r5OYi`soAiw_CP8{Y$=F& z>BP{DSWcW@3adSkq!W8yw8PM}2a={ekR-&wLJVXk1{PwDX$}583o98>DPjvj%u6SR zZp3opJgtO4dmu?CcB*KTp=n}~rah1(#K1xfWF`g{VvcDI{-Yp9DPr?M%u6SRZp3op zd{Is6VX~wXn=jhA(DX1_njR)gLJTa#KxSfKA?BFY;GeOu_CP8{Y&M8_>BP`;e)_eM zpSIJ;lfNMP6|%mNP*=^)$jxG_!WLUE6Yf|@X6)==zTM6S&k3Z5$&&Sk=`F6X+-i8< z8q&jLFB9%)cv3))$pKVhIgq$zE=7gxcH35{%&46W-c}{u-ja1j3*O?k++wuh4OdYn z+}(`!0vU{U+)UZ+c7stn8+@ut+C@p$87(=ZBe})s&>OCzOt`xlP3osd>@s=%2{%)A zyWLa&IUhFCGB%0>x?#>(V^U8wC@d9Q6}8o zj3#2?4@O5`F=e;g4MtyTUA1Yoq1jHd&S={i&00p0X5u(eCfwbO76KWJ=G{!$?RH^Q zzeycw+2B$%5@lL8yJUlLmo~G(+rsDumE<&Zn{P)Wpk;1^8SdnEM>hC@fWq$to>CVK zXDb{0WwODq`a|`6@8$ntOP*vbc||)6O-r6MEqRhm;4i#P&#nAEeVzaNE3i!9j%g(c zdluG`r&3fWbcXb#mp*}`+scyjz3KncmORN=@`^SYng)S1EqRiVnDR26veJoxg_vVn zNy1SOqZF|t%~}xi(utuPv7GN+Qj>b@C+Wm46m32^RZ>ix8xmgZX&~TIqcQm{zAR!Jw&u65Y+is@pcH5@<%t*kYl;Hza((Ec( zXS64v4sa+p%b^Mm8)d@X&1m97M?zHfkGx{aZnqnZG)oRKnpPW{2_@@{_Pxbfxy5Kk z1&pFhxVsrG1Tq-SyP2}v?FOUYX)(H?N_y-kS!ZvBcDpdD-4aWVv?OLB8i_J_tRyjUPc)O5 zo2sK5RFcyW^^Ir*w9M6PdYRnrNMareApCaVDRsecwvw1-HT~?*>V0^6eD#&btG{c1 z5TBQtD?i7?xhUxq=jEa;gr!UMQkC6dFjN^ zjaW`+UJ9#+F_KQ~dC?9-Q)VhnnW-eiz(NdUCI%K_j%h80yi{#K1xfWF`g{VvcDI{uv8vEm0|AGrtX5rjtU<-lig->SJ&cj8H%xD-;RU(X z@VqsohcR9z+|lrafObr;upCI-s=pK!vfFK&TQeg~;zNvXtCDVS$vUHXZ*g00G1~Bk zt0)uhZbo~73`RR{rtEgR!RU8djGn5Ja$CtdqXlPlB)1qHdc#$e33oT6$$#u!7K|p` zOvP<>gHd~pJ}ZzO#z@u~Ejgokxy5MK8q!_hWy0OfXep4vXdxV_p&>jGQwwOBN6}`uliM9@^jV*ZCUbR_x?nh4YxLLX9(eZmK3;#&aOr26oGwcG z~}<6On<&Hp=oN7rfst%#K1xfWF`g{VvcDofIAk}wppc!?FBI}ofx_i%PaE<%~0AlOFFTM zqK${9ZL>6OnbYkdv0sM3?nq87x^UHz?MsSn~cg!!_cJ?pdZZ9`C1=5(6tT#+=so@Q|nYgSWU3V`N?r3;J zK#s`)IKe>Tmbo1jvfFK&xH6;ma`S;IY1=GWXSDAv9?C67``&OBWy0OfXyRv_U@$uJ ziYdF@ZZK*uH`8iEX_{o6(V;V%m0OHv;y6(z+}(^80vU|v-Avi-c7suSxw)ZA+BQqp z867#JRk_7z*&D8+Ot`xlZ3i+KZMd0=+w8)qcDeT)Y0J${G!kXdjd zUy{?%fH{grVmKX!8SdnE$8t06_t!++Zj`!UI9toj`z$x#e!{kddNJx>*EbrpIUGM; zowJVu^YrlW1Ez;vNuM4b6m2IoZFQt+t0T$u0G8e=8JYNG;MXHX{#d%F|ZH=nTdggm}6Q?(2RwZO{f&Hg&^jo6GP84{TKAY zB6cM03HjttGj@^nTbsISc1CX9+LJ06C{ZTdacj@p*}r_dJ+Gblr2bd8eE=eBre`UnBh)tcg(A|1>|A}o>CVK zXKP;lHjTJvKdYCA=-!Jz&%Xat+<5mS{l>dnwC&K8luA=lD#?upmKzUbzVX0v<2k04 zVy#+Olcq{hozbCfrS{zObjf<9MhWI4}%z` zh)o1BFP#{Ao~phhrmFUga_N7!VJ2C>Td1pMm*m#nvY>+N5oN+1cgxYgP~-kgmIz33oJnsD?Qv2T+BbK;o9U9Tl?MZMzLKqxQt`fhs8} zm8>(GaYl!7i_yL}Tt%61cQcyESHKw^dBv37ZWl(iQ_BT*)gm5CwFr8zO2 zQyr}Vk})wXL?h8v^I?WNx!o}_+!T%1aLQA} zv`$?~gQO4mQ$?E$O-X|^B@L1cc(4q3ka@s^WxzY8oiscltnr{yr1xWZchYe78x-@NN6MRg;3(n}vy=y_0mT@0%BwZEhWltoC^ zuRV3ScGh}YP{DPIGU1MEzZwUoRE1SX+9h0$T2UsCl}ktsjq~OuyrVk$H5bXaggenl zw7(r@xRcu*m++~8;sP#j7x<9CP$4%%o$~ z;iEa9bd1)z(U=pCu?JV9&i$BUY|AqWGvOG^HAZ2^9b;)jH^u=rqB{YDp>^u5pJ1fb zQImSPN$-bVtbP8ce|PQ0C%>?^zxFZx2&}y*Prm?r>(^M$euWok#;>gZl<77;YH!5* z9N&N$ucoGIZ^W}pudgwV?#5+jt}o<`#@uj>zIZ(vbKNoe4)kcuRmbQLkw#;d9P>-B z!d!8T{-k7dJByCd-wck%Ty~89{BSg8!7<@3&`us7@@sFFK<$qt(xNp7no+Ybka+ubF zLTj6sk<~?H|B`{xd#)!iJ;$VZFq;>U)f}>aj;MWEq}Rs}EsJ#0+RL;~tW~$HrpaMi zD>S`%6KP*1TI;`O;AN!i2~5v1={m^G8%X=6&szT~(F%XBj~`k~7U$2DhI?x#)6#3d z?psZh!?d<(VDqjuvxV&6F)(`1^#rEpn6v?A^L=Esj_ltiYG1p_3b=ejm+HJ|JHoUi6{U7udme6H)MOwEU$lcnz-`AVAG z%2V}h5josZt8%Vw@-C*eY6WTUVCtFPb3K9SIVLR|{yoEAH~bBv6@J|vl5~_sIy-9F z$oubg(NReqRrkrtB{^eW9<|na#!GR=Uiul=eL9aL zRpyMj!ZHuTj52xH&Nx@(%!QnceIRa`6KOFlc z2|3(VJlS2_JdLcTko{?3rYpTbPhfhENj#fg+dPG=P9XayiP}^DULQYQWsx`Ss(Cd+ zSM7OM&4w9e@^DvIEd?^VYQfEv-EKF!s{KU%jwqvWjr!E~;Tu&S5j!COvHg6%T6=eS= z(F(sVoupklBAu6RL7kP8ZeG^et4t1$s9hS^p1|}RlkS1pypOaO zdam{F60PuSUXz3tulnq!HJ@pzw_aLJlf$$QX<+lYHFJRMKQ%CV&-DbR=a|I1Jhg}; z?G>e3#EIHFK6`!q(0XF=t~7Es(^ArXN|&_fa+uZ$h1NDtBJFjZYyD#eou!1NrG z#z1b4Bda40-v7vG;qUeFL(3wa7jY)jQqp~nIxdH4&2oUvcaZi1QmwNFK7({Uf$2FW z&4AoIjjX1S_G;2zg6}nU8b81853)vc9a%y}bt24;{ zSzxAXe4*P5?=-%M+RN}XzR;^FWPch=HG}NqxA8@!b9^1f*?H+Ha^0s>Tu^1sn2RKH zKFlcNZF+XbxngwHav*W5;*y)?g?VnZ+MAqf8#|>Z*l6MpwRx8N*Xje|u-XOTP`5t<89ofG@)LuBKUAc6+$|7&tRoiNW zu40B&S8aqDW%6)WSM3Edx@yPGl-+JOx~iQbkJ~D0a=5FG)SjO7AgdS1{!2+c=|Q@l z!01U2(R7I1e2%ORko~8UdeVdJ|dP*uJ@5G`QZ#j~=s@H#1SG`JKkc=^f{`JpDzXJ69K0PCss*Br0@ zzW=V7eh*Bml%@vc@I{=IQ&R)7I)Ut;1ZKLX26TJtuBHZ}X#%-<3|WmK`{R6Gyomeiwwx?qu$m@^Y0c5V<~eI-7TJHt!039OflOd}j!9>v>p?rRnnCtY6Rq%T z-IRouMLKEiWm-y>Z&*!}!?czZTHCyetQL{|D+WgIxo&R+?l~qcfZ4o^tS%z^mq1qd zdwu-SvPdVbolHx~^7~fPw>p=FUyTHBeHlI4e1)8sI%9fkB{23g%h_U{`QT{{@0y{%YJW{9S3_WIUnZ=;4o&#CISjeKVV z@1oR0P~>o@?8~YB6S8`O?0*2vbUg$`Phj*AlxX6;m3jz@wD)rAAt+IMpQRpxN~cqJ zV`ujbw;CtmrDu3`pH`IoCQ8mtroT{AyLz>$?o1xGS(A$7wCzOgtUh_wQzzu`8PCY6 z92IHr$yAPN;3=f*35=dPfk~6d%~Qzg1k&E1si#iT_0&m{GqyJ-R>+ch!cR%2AQk zItL9FvZ8d}S-h>IJg@QnFX!@AdK1RTg>EQ8lB3(p7ujRg+;xnLOOpRr7(2u9|f- zWw+anu4*T0H&sbrRz(hX)v}z*QIXYkWd8;*)AczidIHmPOj-i7c@e5wV%|3{b!%~&Ulu2$|iJ^!bU7 zRtw1fWdoxt-9jcXJ;$Vr($_XGA**?0{{qnpzrF_{2`!6s(wfh-l%CzTnkI*7ttzBh z8dYEOym ze`t2UX!k_|45yrlxvsrg z&F8wdwl$yYdNNS+q35jY?Z~>cEo!V5oa?Bl1aEb^vZHKPO3RSVu#lVL`gJlxe)^MQ=6nsqZ}x7&@b z>PV(kNy!v)xT}`s)Z~n;t|R+5fSImj3O#{QGDXzhc&lUzy;?-}uMn-4kbV4gl||mP zt2Wd~o^5p>t%ez8@^DvI?F2HqYTM0}-ENnz;t<@3jbtir<$YBpnTi%LfxBH=c%5V_ z8a#{^ynJOc^{XUPU;T&esn_`N&;7M;GEKkm{|~<2H2uQ=AM>9`(|0vBJL|ie$l(in zMov9KLRK@#{%K&QD@Q?3VDw#0qG<}bIgP9)k^NJWnu(Ep{9IUzbY0l<`#I0LV%1Cz zb6QYH&ySGRMP&byfzg$qAQKpUQB!g)%_BE2AgeiK|D2@0sEO?3hm%D*IqexIC0Vzu zn#o~KD+=l15z=0vu7^hkUPii}!020=VA6Hu<_%=EgzR6H)D45|V=UXF){M26FR#WVMd$-%(Ua%i>aC=j3>-=^U((^)Obq{H;$<;R=sN#A8qvwT0(>8MR zF0$G}_U}mQc_FfopYyXw=lQL277~7bZt0x%RguV!^gY*enLK9aXL$PKDDbP&4_!~; z3!4eh`=h-opVgmPDAz*{UvFL=t6UFhuf|obXJB5Fs~HBFz$n*~RIZ2I5q9;q(Am_ezUIUGG2(=?2o0u(;o}2r|^Y6=#Tc&dq*{t&>@HW zV?$2ewa986*}o0UbR~4?35*gtqG=Vmc?(&sAp18ZmCzyk_~{Re{HyfGjw;e0_K4W^ zYTL`?v1Whl2cG`e3tafZ_Wqzv-DHDrUD@4sq#AtXDk@?MSh-y~viw!yi0@ljQxlrk zsO#k`*VILQFYDQV`>pYS;sbm2q{-oHvZs(9Pa~^cq`lW&-zuky>j_NHF=+?P<^yDP z581y@w8F1%K}m8=EYfvNs%8ECTV6PMd3&!iIZW$?LTj5Zk<}rx|J=an`m7O|!1NrG z4y3PbK1JFK-q-pc60Pv-TTqhF+P8Sux0;qREv=o?ngjG{8*-S|q@21#k<|%g|0FQe z^=TV=0;5mch^7hT<}swbvR-*PQG3<99{)&()|kb+Xf0$~`dRI@>Vj~Os(DG@9iJ=O zTxdPRC{2>h?ieh)V~}}w3|79rV_H8DF=JtU2STL={Ja=2=D2RL3Wlzy12v!PO809% z^t@pHTr8N%^%~n6&TCwM6{j~gN&0zxq`#zdjd%0VSG5<-hpMC`0y*4OJ927*L00#W{rkX7 zR}z7qz$l3zYOg3(5`kWAA^UfTR@=xve!9vcZ`xJ+YJ{#@@-yBGGs<{}aaUIz1v0wo z(9N!Q7}K|ms`h$%*5)yj!(BDQbhdfgCbcPKf7-z4$}f-!jPeUfRSRyW>~_11Dh@%H)mPhmE3c}m7To1% z0n->+Sz36Vt!xbVjcCEkS1!BX#IpORzBx9q)o=KZx9JzLHTmdy1akNyF3YLs5yDpeQCop;*LDXLDu1y4bwTSFrAzCdV`}nzt7U{f*lQz;$e0Fz24~(s*$zfVs z3axG4K~@{c{`&?-*A5Gr!1NrG)}`w!3`l!PyuQLfw8F34P7+$H7Vlc=CNeE8z#mvm zlf$(3XkhcPHM5KCKQu79(iLO^qjW`b&0agN*#y11hwR@cTJ0eF_@QNy&fYrG4aw-C z*Yfh`y3(+k&vkvP$ngGGZ0LFU+aLKO($k0VF*$s)lM3m6Mfxjp`zH;|>vENCAQKp6 z8~`Dcquf;jHgY3< z9->P69tv`}tM=v8_fU}46J-AbV5aMPDCh}{zK23I?IAZGBdc9x|DmM5hl1?mr>iXT zrd@TUM)J*~Gd>J6%H-j$uA0<+NX6)?2{%)AyIr~pqz}u%R?8eZ=B%n}@}G$oFoC;W zT6mqwKd$0@wBY3{C;w9#>d*enH^!ce_kH&&lf##8OCimz$Z7-Gf8W69np=?xjOJF! zwX}}hyp6PXf@^LiTH)8+D#@keZQ+Lk`p0qk+xG*32%l{}5P( zuDKPNz-Vrj)ZB{Pe1NpKoNI0+YHtVE+$tSfy#KtL)=s9SA0k?-J`(OxbtLJj|I4Di z2u)i>X=~MUNj3ps*#v;hn*gx#^&Qjt+kkxwYoMv*78L`A2OX4Wch~iOnVJth&*VQo z;@6NlhfDgo5&c5Aq@TluqVa}X-^hT`pQuQ34q!P4kog?^t+@JyaPzf3s-1CnMajGp z=RhfQDWaU3%!M$cOdhs-kP6)s^c_{wBOK)L7}=0hk8qIHIiz35 zTuzI0Ud{z|V4k$6Z6KH&rZuUMaztcx0@*)lV07h($OJ|?qNH*}w0)n^P%S{^T*=1I@_t>N$V1m!zVVOkcc9yF=T(-!05Vt zkO_=#A4%Ol`pGEWKFI0?vj0+2w-2(9-)-D8Rv?exhif161U7%H&b@I zZMS>9j~f$4w6vqDnlQGb1xy&ZU0QgZ2_qWZix#|m<%IF)^=By0uI1kedT8Uxv2$j!URY75!FBdLd0$Uc59okcn?-K4tJCkN7w z=fXd#4kbP9cv`fB(0Yc^&(X*x?Ep*K0Wzl@VCCyOruD6$6 zJ>T;;-Dz@|d?tvs!s(9Rt>JRT&AC7M=|o41hF3bKDwQn@a& zkDrTZk_9JiF0zO zZXQEcW61uvq(&mLkKaZjk@R(bxZJ&+A|QY0vX|xc%jy_Iz7k7Wnc{d-5=D_}7lV z{7c6E9+vvg3)g=Q`v2QsGLE12j#WasyL?kRfT5QV=BgV-Pgva58wIVcfR!O2ad7RKQ?y!=3h6Bp9DRV|G4^? zrsH0P^q=rPziOGaa)T2VLB@}JFXLc(nbNnhEr^V2`abB%&mMivjhW9LeeI1u^Vy@X z{-N*IV#JpVfAHv-zCR|#t$nk;_+8mPnrKAL`r@~g=y)S)*8020e|1;u-;$0Fj&COI zL<$H;ncHrrC?otI^F=oM;u~Ln+K(zUBXcjRL>XbLqH{a-*~2s1Y6zpvgk+qxzTK&a z`s0N~kkMHSYSn`3$(I&HMzuX?@33+BW-*d7_~wWl@huX4Wi2BdugHX!UC_aqL{Mgm zGQ!50M(sOqGf@RXYGKmN6lLXMt71pdb^5`hj|n(0JZ-F!dVIY!!saEYR+M_oMq`*n z-TorqeyCTs_Ml9Ad@pgy@%A0Gg{T{4^4M?E29&9?Cw(=laIu%8N|ecCR)y;i6G|bs zbK`DqxS6usZA+Ev6&uM`w6v$HI^&&a0h8mn-Pyvp;?`%;!lAdYA1z?gg4?A9-MH!E z_}ZuSqwBTvI0~?rKl}wxmVSF}|E(u$=U-}^S)Eh8PrqC{@!9|67(a~u*@L&L-QzcB zm7}R4#*!{0ofn;|0b&>0hM$GGO!56+;STk@s>Wd7&6M44bE(hkCV06K$9TA_R~ro) zneYK>7y2j~j52wwb)jdX3Kx3P^;{;8bzSKBKrZ-&o^>;2x7($Y^Lce$=p|Lvg*~0LJUiB81qXkSmpp~VC?hCyUU@w2~3;k?CAIL=C{~%Lq^ZGJh`b@yp#$rVJ zJs7`T7o&5*&9oG5w>z%yTlGd(1I^vev2&Zzn1@@JcspQB397XbW|a18#PPn07_9kr z-V0=0<()W8cDr4A*gD-td+n3bINd{4)m7e)7BGRk-PywMRrbF+u^$6g&4ft{N7hnl zq5CRN2H4A2U**v^*Q~cvL$yTB|v?cxXXn44pxh{F|Aa zwOa6>&dfidsYFCP;?|vvQ}?oV2jWoGNxuUp;ts@wx!ZOjhg&E^AzGOA7G|OaOgncg zOAA9oA?nTt*vp}zaKE;o-uDId*_0kXsdf8`yDgL(z4Q0IC*M8pt6u5X8S8~|)hEM@ z(te}%H9KiuRdv72dJFM;vTE4ua*CX_ch(Q?4|md%x3CZ`U;=l$w9ws2%K`TC_wFRW zUw%fp$`{|#`w7^#e9!lOVSRmFZz%XHpZV0zd!NuN3SRsNyrO^vrs7xI^*&cge-h3w zy1TX$n!Y6~E&skfNS=p-(@AJ4`;*_g_m;kL5q^IE9^dX;?;gL(U9{mqD_OSKJ{|vC zyMM_(`P44xm&=P0?v@uLyqiDpc&xM6kD(%mA1iV%>c>!#_Wo%77^;DHkgg}YYaNsB z8UDWEw~_t3AS?X(fJBnViWaF>^fDSfJC)Rn5imqt8J2%#@ugKWIn3!$A^koXvN}Na zpBfllpSU9Jmv8k;s6_4ebM*}>^y&$+{{a}g>-9^h(&1#0PEOl-(mSP2*3Y0KhdG^) zQ@{U!v>RK$|6pKlay?E(CNTQ_2TA?@19Ed5Y43d3?>`tP{QA^W5>7|3?c}6;QvIZn zb&d)yhdD7#=*#8E|A)Qz51K1W>-(fdg5E_S4anqmB8S&%Yh5C4%utaF33rNF zTNK)L4?8TAM37E0%nlVnHC1A3$mlNpT667j&@DH~zRqkIx5gaK=I@JYc_j#Uk-+OQ0S0gDTTb0Tm{XNg~oadbLz2}~Le%#yl z-0YaJIBw38+5AD6%ZJS$KsJ96ZapNl4_WXxW5wDBF?g{OS)3lU__lNB>uHvVPgpX; zCa1@hdh4v^F%TAynX_d6$S2I@!_E)jW`0_@bw+4kv0#oE^}{0kW3q`s}So@_d0 zRn=wZ2TN(#q%~FsThDqn!s3ECKP_}Qmk&EXC^jDnx6TXgD;E5jSFtuN)ZcSEtZeK41oyAD|!4!1YWejJ{Me#liD$1x;vI^8;~P$SGe+7CIU z9C&4o!&PQdj$F0xR9J?l->B9Vmf8bc1}#hsOTuPd%`oyDT$sHiEH2B{ z3fHKprK|Bl38s6d*D8uWxlvL62?xVwMRj=(iau4CJt!=Wg1me#bUBv~uWl&TzDvPl zJjvN1VR2Zo_8ALa-9T1FS(`yyQ zYNAn5{s9NWW<^a%&qG*Y_MEV|1hW1Rx}3|0hp>vZuTs!sOU|Aa78ewojfI8mswj)O z--?=%i7IMJMNM5!p?#=gmx@}1YgE+S)%cji`{OgKwTfaI*{G<)HW@H%R#ZoGf~^BK zGuR_6_L;L}W)8w!KKx$_Ow{cw$n>bcsO`j-_&0oJeA?qm(TdmEBecd{Y}spf8BnFAw2{q@_MwJ$GrQVATz zn3OhgzYtl;pg*R#{z;p1N7Tf^4_tZsE1PqDtnsFQtnuc-XFo{iaqGY0<7CW0c#xo> z&~fdYY7E^vAk6j%3*XLHGUrs7cZBX^yY+HTwKs2VM_=2;w~*b=sl~TVKYCP~&5Am_ zLaKZno3xG*#ZDW-tSc-YGH1z52!*+P*l7b~rw!rOQDL?rERKM5cEUn-(XyD(y&QuKotL<6K1D{#Tj#!%$!h|%ZLBZf&70?xb=uIJ0UDig8Y9@Sja9~7Sl>= zBhg~I{j8-lY|?s~DE8YBW+P#7-kc>fClu!LVZRNK{WgSK=Y-i%SUdspLYT0SU9>Ew zl~yOwV#a;hQW`dCO^IUY6=u&1ix~)nk{p?DDED`ZwG$Q^+y-^A&&2f;xy;e;SkZLyge3JWeB+Qnt^R zFOiBJ*oDo8HO9yYEVK=Y8G+6DX`#!xd{{HdCm#v7&I_}rgvB|KHIvXbHde#3nAV0h zhorh_4}A_;wQ; zXap>$gw48Ikslql&^~p+AdJiw>_V4w`LLXlPrejxy)MjN6WT{G_!BxZe?kXUR~B=> zb+zH&E=cdYb&~2~?$JJOH|nYvu2EOrNRiC0*XoK9vQby(NW{B=!e(6!G4gJpFne5B zoRyo&yc;Mvmk;j-D%L)1!EhisJ1s2EDAvA*!7T-3)s@BEZ(WVaMD0o=0j*;cYJ|B* zx7O7(T%)cguG;r5l%eajx>}z#-y{()2MU{YwZO=&En#+DSlp1C$-EpWIhPMF2P)RS zY{9EvlCvwq;;Le^xv-F3b!9R4TURSG(V=NDr>>TvMwokaYh7(HUs1}atB$Mo!3&vP zuhkV7YolGAArb3)VY9CK7?}nLvlGJNq})tqeJ?qe59@oy+NUj8-%HMp35(;3&3eK@ zcGZ=|+;3eC$wY^y(Tchngc@P)(XDkg4%euwk*oH_3uWkfSywWt->S`>qvxBFl)3XH za*!%_*UKF4X6~H2QgZN{-jUVZ!YA{q7TVl-5m6qt&7J=){p+pweT&_{<`W55(!Y3o zM`Xk12_CYqFCB-lwjHuIK&Imm+Lp<59P-Hr!mY=I*=b>M2BhN<7P4E%p_tYaJflX_ zEc!#1(y&SEIc2bQ$+8&>i)YPQGAmVKE+01i2RHMlgNoOW=x;i##bu* zWihR^M$pn_s5X}7u`crjxMFje%e7*2nP<%vo6G)R?3CY#_;i!_uh?e2ZFfu$vr{mY zB3!E!j8uxyHm+vbYR-FvF6SM|?vt0O`5X=7^M-4Zqrd4Q2VLuk8C(`T6TX`#!x zd{}$RC+`cl9ua0IgvCjawWrW_vDP75OlvzB#36ea_r)tVj&Vd*I^?k*@-Wm0ZIkMB z$SF4+Iw>dNDl_WX)jXM9w;>?a)%ry428no!N7$^ZIYuTM!rB)xuE^QHj$vQT;5~Es zLr-BLyXwkf?zgU%WMZS6AMqm82y>720k=_C9X>pulu=hJPnjpP z>$SRCpU9oG4;dIX>#9c-lMP{ZOjy__I!xwSof78q;aQzx?K>RYSC(A+R!3Jph3u*; zeYvB3>`F)HVQae@kXT1N^}6bZ8e#6yt#vgD*Ql$Zt9dfJUaKpLXiVfTlZX$>37d5_ z#mGn`%$^q(_Kgmcxuc;ZxqP^zp;-G62X{0i*FM%UkxwDJ>dHRjalh?qPA00Wnb*}U zsUGGY-C9@6aE-cJM2ci~y{s#hp=+@=k&COj!=S=MZWTF5mAmU@4)uxL^^5Q3CTOAi z6Bpmz+57Q}Uy(|nKj?Z6_NUa1$jxm}=C0dZt`|`re&Ch2f1E#(RPKWQ9d0q-y7Y~4 z7xWS9@eP~j^@KY9t&`UM_k_j6<}8^Bw=kCv-;x41^JBuTfEFJ>+mXxrNUFX$e zTF+~ricIr2+YdT3Y|z0k7wG}keN}+8Y&9qXU`M~@i6K1D{#Tk%krLd4)v@E8T zRxiWD}{yZqGd6y zw7Q9w{?1}44V$!PL@})tW-keg%jPVZX{FHit!7%O*nBG7dQq4?FDzaFnN|u5*+t7@ zT4`-0TJ{Zv*YW2KSUiW=Jx<@9l;byh<+keF9c|xJj&l`%)>Wv(P8*bRIEoGD2y>72 z?oKJ%XIUr7gd3p3W+UohWHc0J$ArakxtYwBEjgDDqoHE+u5jxip>6BUQ&z=Rwggur zdeGwACYH-MJP&;|tlBun0f}{{)!tD1p+;z%d#71eN*R?k3Rjs)IdnBoX4kEMPIa|D z%d*Y1ePiurT}{c43rP6KzNPkk*3~?YSS_3*o`o7=?$O>n8g;b{*Ql$7t9dfJUaPD1 zS(bli!?0Ob8~Ox7%SSf!Sq)y2721b5cu7{CdB^+@2(vxHVjsv$vcf`kwJVEh?VQrl zdDz;ndSs$@r5=L1>V_I&?$NDvH3-+JtG=swGP_=@D~hP~B>W|cMBLsNHtTAPk=y&i z+E+I8T@A(yp?!&i+xzm#N5ZZ1!t5zwaSr76zOay8b!9R4TUS#uNxdy~H3>Ds+@o9T zY96jpS2I`hWOlu*E0v*Zu{O(!t9eOMW?75KL8{zcFLSt?Syp7&@e##lS*ys+ZBN?g zJHGdz&9XLP;PG&Mmi68XW<>^kcf(|XnyHaz%WKF?W7 z!zQgEQOv=F+2g|EtT{_&4kom%%b9~IHXjJL9usD#g~b_=Ihe4JU9>EwmDW7b(j3fE z8a8P?M-+1~p>0;q9L$`@LYH&-Fb9)Q{s=bQYvnGDuvr1xMV8Yq%uWl7GjcPT zyEKw>`EZv;v9?_;cWESNCxpdG#b$kBA-gKTVp=O;V&u6C7YCsmQ&k)4h)mQ`=-5!x zezy_EF1FrxDW#@NEzY?p6pQcPHr4F5x%W#z$brC6& z*>&q|Q(d)81K8L63$VL;+mtCCorkS;)q}0-YVJo|-JBhB?$O>nQf^UKgGebeb>%z3 zzu&$oq6}TH)m6(h!0PIfu-UH07?}nLv!{i{1-Y3_mnGRgCc-p8vH3{2bzYb~B`oX{ zDfZzJrU6*gt}Nz$+trjzbZ84d;z_6x+Sf*QX;<@bjk=n-nkTdCWnHNZRdQ__5VgJ} zsipyugH)qrVVT3-Oamgr4!tZn_%tALa~snD(|sD?ZuY5=?>)Fa4fr`ajay&ajhiiB zpzYV&u7MF1nQpec&i?4E!-dV}_8LYW{|GZ}$Ijy)xtYx4AIZ6Vc>JT-{JL=KhA`7U z?L7VgdHf?RWLI;unAYYtOtcv257W)?q(j)G)xpS<4q>)OSnQLV$vo+hoXdwN9g4M` z-+9s@LfLI$u`NQGHj3v-2Pj$=(@JZQXxaB59wyIgw#T}!_K%~xbSxzPz^8Jvhd`cC zgZ76Z3wQ2n$Xj-K)$VF+xT9?luRg>YJr9d4j17vyrV2}UI$Y+Sc*Q0;jorUz+b!PQ z&(yTG?$8|!ZCuRWV4xp~HYRpS8x>39sR9xc9niNs7I*n^os@TKPa2%8N?TN<;{6lRBn#bLRb%t}+T zZF|g0Q?YqRxOG67?GYCHKvtTrR0Cw9W7HW!?S>j*?$Lh8 zDP>gFAh~+VzN>jMyKbFcs;l+k_!5a&X$qTlHO9ygBg~!_78m4ZGDD2yTs{mjinU$x z8Db>YcG4for;y!-7>jS~iqg^Dp{}MRR$UGKh$o>&n0s_hO^_R(!a{b{ zmBrj|yV`)Q4sGN|+zB5>>Zf{J{R35e;k}g?f0pzt2 zVIjL{Sxjqft?1d*5LIhw7<8FGs8wt(a~sM0eF&ADhQ`m>TlQ^hyc@PnuVM3GwNo_@ z)P>mL3r)g@p74!?=A}vC+RR z$wc*`V?$kp8e#6ye(@_8jiUs$*#IBnVryr{QDO6tH!w1e3bRAP!gu19%s48{<-<6t zSleiuaa3|`GwzOj3fXnYwoP~IAur(cT}^vrhi<)9s;l*};Sz}$M}^J08e^nw3$v$%#Ra*U%s47Jmk;BpV)K!3>%1^~ zN?4o&xnnCVWLI5T%>CBYluXj)!VynGjWGA<*1DR9Yt+@uRr@Z1GIYJHE1A5NR<>V= zT3?b>OSQ;Bs@z>KbGVzaAu{aHOOS&v)gm{yu~akNmul{oZCJQIHv9o^2j4pXZ^lyX zFEw zmDViLvd>7oi2pVF2!O8|UO;#0`H=W12NL&hLGEROS|`YllUJ@EkTZ8e_#KId$?Mk4~NwUF-3*{?U%i*Rr&4^EKPC+4(Psk;GrVkyt5# zY$p$jXYATs@|U;l@~ZKlnE`Tyy7Yp-Ley2n>ab9kp+;z%tfzY@O3~hLA7_VcK8Y%9 zHjXYvp2!Nb2ZhB^xtYwXV3KVgb>4ebY`!7fIwH&t35&xZ@4X5O+0{5KrnPa5;3i%Bx3(zVY99# z7@5Nev*(1xCApc*97eKjsLmWlvH4iI^{g;^T3B2FnZpPR*;Q8-bH8;pBa_tHIpS%k z5#}E4{dS|S7U3FoHFq^nX4lKQQW>hV+MGUWeMM6G?PcU3Rqn2rIowUZ9T{%;6>a@? zC$4U{J!zjyh$n5`i1Ki~-+l*tZ(TiXb9%lm@im=z=9Ybv-R@w%`Ycz|MaSm3ewrwr z012~^usCndk{NS_xqNs@5acC6;nq2!?VruGTd|q!bh4n%_0ZzmrqLtFroQ~Lr8I2P znks{qed?cA65q4l_Oj>cfjskx`F}{5Jtr(Kfjm7B7P5<$#k4lTp`CNqj26Znrm%UO z+a#yn^q<&P-fipnNe4s()Q7p*>&p-skvD!r9mOn@hg5o5Z(2*q7!`!32wJSyY1%3{1UXTNVRU5}RCX;lwP)DIgn0vGza!MJMH4RspNjY&f zPiEKc@~qZ!?E;US<|O3;pG6K*MalIthr7AJBg3WVU>Eoza&z00x$Aa;uOiCB^$Ywx zy1*~_e$;%C;;c1XW(nIgo{NsnGrS~+a37P(aA?7Fo!Io?fciwvipgSECv~bJwl4%_7Rf_15-o z<_fpI<}EgysNa4F|7%$n^uF+DDLoj{Mf2Irj-d0GSx|kR{5YVp-?{SUeEC&*$y;`L)%xhM zJ7x;uHILSzP-?`AF6u1Q2y>72mY@`Oa~>n-rDx^6Mr7+YdJWUP*NCWs?Ov4 zSX-oP@LNq@SZ$qpRe|=QUw+v$tFJuxqra)Y_U+5AR6h!`XY-ZKkG}G`uh#fNA&oQe z<- zs+OFI!M!DaqL!Tb*S#el){?XAytm|MYspzm-dpm=YstBtcyGxct0m{w&dZJWmi%}vId7odTk>PINnJhy-I`YWIP>bHMv^Y-Q!RbR~f?`dpoUah^V z-}}Dr{;rS4-qoMri#*HYUsCQ}{Q`$}EqfmHnc9a+X%Z6mwUKz61mqvbpk`$9tIpKq zExWvGGqsUBrtidQGZg=b&)mNL65*u0n&;PbbZ#nqEA4>O3`0@|M8aCG; zbE3ExCd{q~i>u}=nR{WvTt3_j1GyI_+&0iC4-4xotUinv~Vl&xU z4}zk#u=qAw{X~mp=TT~#+aJOvtqqLaF%o8ngvDXGnasm>$@VoJ9=0ns?+CXJ2(vxH zVjsw#)`W%ZqGd6ywKYhzc%9)9OKI4ob%H3KXA12#DV}GVb5H1UE+5`Wkxzb1xOH4; zFI@6YiefX_c_#%FExnw^LK6zjlQ>MY9^A~%SxUnut)Vj5dcv}KTv(hnXUW`#5!xqy zxDBJ&d?4IE}x6;lRt;d+bqItEG(W?Y$iL;p+FI|m{x*g2>$j5todt5%`TAQ zTJ|*P9mn}n8ijPxe5hq~{-*${gOFdfj$8DPOU<%$mMpbD7OHDmKaXk&0vN0mm4~9&p0u>DX-}R&Bk?U-yKz zSu20tL*}o0!mZbZ*=xe$Cdgm+goW%n9TwAiIy#Whp?lc-27O3unW)loP8wCiCRJ_4 z%B>h-c1&0tH)qLQK|=dd1MlA|);4+N*0kj8L1A%JK3P{-$S$fD(@M3Ehn*!0o$4Y{ zorpM?~>}N0>b&EY6v;WFGJcbNTRq2jl^daO(+S_PDS(3-W+RSjaA_7Sl>~ zjEAUt=v3#4s$R>o+zgvkXGAf$2<>|a3@+yUlF;Q`KD?GCpL{CZdQq4?FDzaF`749a zzN;Xr7Sl>~j-RM{=u~HkDkH%@-Pmw!QeCOItbXPt;_8|#oDTcPIa27cD`U=IcTHW52_wI)d^IsQFxf^GUMjp5LYg` zL8OQZaR`$W+EK z*r~aaaPA3bo-jTw!Z&eDhh3$NrMoWNHJ2*VuGh*KL>X#llo5CJSCJsX_=HrwjIKWb zh`ao`RF&a+t&Dz@G4(R~p0F1QBFtrO*45Bm2kx3nRT-|=%IHNI6E9=z2}hA2!uYyV z{WzxXI&s%rs>*P^R)(LK${*JJjM`s}sJmI@FpnHuU&}$gdU$B&jJgQb&D?b~-R?T7 z1ipZy(fKHYClAR$ADxes(nd(k5|MaF2J(;$)F>=J4ye2_EN|K6RU4gGK|`TFNkbxk zR_Ym~4I;a)=DlRLP~Yp>Nz#uv4?pk`M%&Fp+!*El@}66d^S2At@G?%>!o#0~%)#p& zVm=ZBpPV8x*EN9tOLAJs>7%MRH)au;9wq&noL-aDRh%L+o-4gSJ*m1Sr=^_!F;26{ zY3gA<@$h%#bX!gz!>JLe!~F{fU+EAN?&+~w>Q9y|*oa*akVOjZ+Z*X01L;~HMZpU~ zU5DHlAmu7jMrh{dHPUt04FU?urK&L3Yprh>WvE6dqwfiOksv}dH_I5h>%d*(I~H7r zrq{|CL>V(LW9$h>p0M#*i^g^6t`m2)FHq<>T(6bUk1}*VIF7j|oJAQCnz?x#OLtvF z8B*=USXe8g7iCPmj1IFmosUQmVJ>sCjIO(GSQO{OL;E1a_a3a3v0H!Aw;b|bE5?gZ=4+2d!1sfcbZ2I z9)92>^}Ve0@t|9Wzd8P_@fepA|9TKMCs3y`@}FIy?K97RcFnmjbUBv~|JjvKenPl) zQkeCG#ls-~*%jJ;^_oCgOzT`v?JM1Q(Dw4omW54PBaF{U1OfEG~oGJrWkOiE!&F@&t^S$@^)T;8(Ft9G3)W1nD!bWAGWx-JXlchpml7vlD>AN-Fif5-x%PJ80LIJ=yEO}{)i!; zyeHh!R|r`B3yb3*f5Z?Lva6L?OlvC{;329WI#taPj4D^$CCkmQNp(yVe{B~2v42yb ztyU*N)kCK`OH}EzZWvX=Ce^u7{e)4yA}p?&vt&94p?yAp&Ox#HOt|&3FndW@Tn6bJ zgoW(ZIVh&JRu{ymRy}m8nz2}|vP3@2gDc)%7dEMOFmj((nC%f3`{ZUaZ?8+v<-^*YB8-;H^{}>s)bH<0#(`K5>5-<9xhzi-AEB(F0)O9 zh}&QmqLk_#32o}mG;QE1`;jt2GnZ2+CB=2*u0wY<)iN~QCP1l-L6o63K*EV99DBkn zLNhnZn7QlJU2~}_!}VGj{U}2xk1`gXa2^RFG;_0zmAfw8HMY`c;bVHOj9!#6@iI2N z`|Lz-8e#0LAJgWjtDd`d-PJb1*KxRBE5qxovV8R%Y!`cus~m6nRv zsG^8Wi_f$&t*>z-WmoWGe zXH#hAH@b{HWj|6zxU;*kXn0lI{=pP7bl0}+gypEZ90WTZtS)0OV;p5fXy)c6Hgnf$ zlp$3ax?XF%{U}3qrOVh8&LcsDW^R_Ta@VE1rVV>D*K1|;qKt``p-p$GfV8u3gs~TI z<1%*F*upnYd-S?qE5qxoF!rCPrc5i3d%+-7zX4n0aZdoIGEb+3xqNtp4e|(ExOG#QX}fhEVS_xv78bH=PGK>va|&H< zMvGb5QLY?rP70f}HZZcn5oU*k#bLRb%p+{cxqNtptytT?ovD%JY>%+mr`W6`EMylg zi)p1bfEG(Oc2_KyY|L<9v_ms&5`3O0mbyaQf1jnUIZuQx=kj5xE1npRgZP3qB zSFxGwEOkK<99w+b=^R2ZmTda3Pj&%M9?F7#k)1E4QApf6K;oe+$U|9B7n%I%2g-3% z-m=T9c99L-F;l4Cn)20ydRO+xvt&za9^Z`BuvyJ3{(r|5R+!xu7TX{Xu!Jt>^5FrN zVr_?69$-n%UK18K6`N`2S(-DbYPOixcF;*XcUri<<~fO-&5nglsy&P>w}ja-VR2k; zCiAdWvTXy)!&b%SUE$V4!t6m|aTMfXtFVw=R4t~JY99}s5f9hbJQplC!zR@cQQSTf z*7kVSuCClZ652kn+&+>|J``>}AG9<~a%UKD1}3yT*(9<~Y#*+tc2TB*+Q5LFNBYo53U z(#mCttHz8-5n(QKnk;qNComXxbV8DZ|*#l{3cNtusy-8Ht2HC6Onx8XaLp`Mi} zn=X>D?+JSZN)Vx$%ZW^sF?82~yV@rBO5%F048Qt)LP;58PdJJ)A~bWejH$a$q711j z!}VGjems?ljI)fb+HKQ$9p*f8m|3`%1J%0>kC@0TLUl8b(@eLCj7mt4)9CJaoCbQo zdZd&#LSn>1VxbQ5I1N<)DL-hH{i?iWmshP{T?Gw=OkSoWvM&?&JcINdzpkr!GP`b* zmoiB|l6crykNo9WkIbW4%si|=--^iQQltKSD^fO>8ugXUG>VycsN-rZHHP7#GHE+Q z{+P{4(oVi=2oak34X&QCr_}bkN*Q4;^IEHO*NMB@2DwV&dacd$gPo28c5_cS^MqN1 zW^R_Tbk{|cAys9#UMr(<^>i4G)C)v{2zPefCzm{~(5|~~5XdT3Ww>4|W4EiPZ#md* z`^rJ8a_CvOmIJhg$-|ccgHYYf!z0rxSI^oq-~~K*cm(>D^r2Fkgv7%mByJ>vJUjw* z#mEn8<&`9F+2vKcl1A>BDXd;ev#>|MF?BUhX4m~nYFP&8E8+9V!NcY<;3u^V_{F!y z!=r~deY|=lY>r(IV&pr@Lfhz*?umtRm|N?g?AfcN;A6+2x7-`0bUh?Kc8tWwjzM0} z1l2<2S8ciSmR(-8mOFFDOriQf%D0Qr!h4@vryKIxN|oJagv}~lVC2nGq3x;4o2BNw zv%e}I7?s6+^11nI4^|$T35%xN4$|TcB;$dUr_>Xz9 zUG+1IQ>Gaadi@@CL^kJy^?THjvb_CF`HeYYv(fURq8crM7({5B#=cRb^^}uH8R5s$+>)ZCq%Kfg);AiNX||Ri!+MN2Esyi zjX@UEItHnwF-6)}nIiEh_z}y)uu1R)QT)$HXd6QFKO=MQ30=-J9Qu5Lftbch+|3%qpA5<}Rmz6nOQY7=J92@BtkQ!;mBg}Hp# zs!g%B-DcaCoMZFXHk_(H+pM$o{7&&u2jJoQ9OI_)$qbuRwZA1ZH(_>NSllpY$?S|T zv^_DIxhd9m*5uDllCvwq;;MYIxv-F3R4t~J>Jkr8^{_t2h_jGxF=?|*^>UFS!rb@J zWE3ZE+1{0QJ*97{$x!SkJD0iaN|ltULf>6`;UZP^T(^!emEmD!{P!Gen`1H>L=MBq z!S%HqAU#fH_|kV2s+*t8UAL}OCB*oD6|ZaA70|DUmrH3D(nZ_celxp_&Ng14TE6_M zSA@J}msjnIn7Cu6knVF#qElnoF2Wv1J9jltX4kFzER!r#5(^vS|HCo<}|eX`CA)yr=D^WDI?5fZnl-VyUyIz_E1(~uCJZx+OQk7 zx3nDcMdTn=Ik>)-0|(TJ#vjA(DiXMvePm6qw3W4C_aqry%T9paZXPbBUPwG|K;jRC zApax<)js40wX!Fbx9sw&wVMrh%oJAJ%^>V?=T zfI15`!rY_1Tb{>(dsyi*WgzX6v~-yZ&m!&JnYnJ4K{W>wbfVp-%OJ{jGnawsb{QyP zbeShfMAHYO>6cP3B$_@FO&|1)kFDvW)tbKPG<^#ze=px~$4nt4hf!Y&Q3nwl$J}={ zPiEJ30W=d1BcX?l?(-wO%%YPLh2?&dqH}DVv1#ln7-wt}YJ|2^XX+fQ^nP`xDIgeAz*5=>i76lwQ$Ua@AgHr< z#KN79OWv}}tJZO?f|A1ZlhE^QvN-;(t9dfJUY@=69?VV<+4dtJ51XCXpQE+j`fWCS zGP`aKtWizlNa$gsd-#u{ zdq`Cpb(pF&mN_dA^NvNgS81e7RT^s7LaNllN|ml%zi08FdcmmPQW}Ir^&(NdAk_<6 z^;)=d{mR>_*TPC;>bYau3A9m5qlit_>#A+ytA;Z)y{z7r>o;m}9QkC&FR+H zy?JN*wL_A#(==#5>N6o#Hevfoc4%W0wnJ|{_tYP~X3ta3bMfu$Z&TZZjaQC#*&@aY zd7w}MmdU7=No^~(yU*kf8?xPfCQsFvP=7o7?c9APci5cm?lT$In9vj750kUCOc2J{Hj%S=2w%%4`^Hvs zdm9_c-K4Gm_FlG<)7EimE4lZ4$Lu9ON5A~7*}gq*zk2Z$e~Z3ABjQOB=yRy^rKI<` zW#dT^5>JXio)m$aAdDLn4%FJ=#j+sJkSuJ=p!sc-={)cuiiOu8A{5g}@ zJnq~7Et3u$%r?HfT%?`kHB{~^fX?sXQtE}oeFdcSPOdz~PkvQ?@|Ioi?A8_zde2sq zRE6;49vm;7Yg?*4(rmV;#*v*P{+hj@?L?kHcWD?B&!3Psv$G&yvjA0~{HjFcExWvG zMEdS%uclKp@AvR>Qz9}mB5LZ{3;6M0EYOSpP$^A9;z0=#|HT6NFBYf*OR*e8&BV!|?PBlAjM2?k29xA17NPI^EiPt4Sp4fpZP<~Y+@|Im*H6k5%%oMW9 z9nlYvE<&SYvN6(Fk)6eng(2t_@>nSiLSkWv#KI6{VF;>Z`BfRoTXuQX81>vSQwXE# zZMmo*vl$}|f!QS-uVv4H&gj`v8i&NE^pNP9KwhcN|A#raAbl+s2>+#p2a1|i4|LQo~kugXZ?vdgQ+Xay4-ZTl4%b%T+I&PcK` z()2PrLk=wdL1*+xDfL6*)q5m1Dg!T?r%IMzm65zUjZE%ut#{#!^+h>#daL;S!W)kusTGuTi3_Zq)xx67fJDtWxSb zr4?o|L zx_fK1v?+bYO*&J-Y8< zgHP8BiQN+TC#vbKdm!=Kd~RdkL-%sasxQh)w8wBvkrHYU1t$h075`21*GMQbk@u8(Q&evHIG2;TOeCF^O zVS~>wa+NARuD9};giG)lN6KV&z2u|JqMx6+=cxt7P9u{DbC3IV4N;Y`CqJBNkmF&F z2DBTb;kpEM5M;89Od|h9sA0}s|LiLlPi>bOvA$|KBU5eA89i1?gOE7!NK9QorrMww z$*;;t-m=T9HX%u`k12%FA{cq-j3gT)TPa?`k*PN5jP#bWOXH9jsge8*WPg8ICCjhM zNZztvu&`1`LwC#+!e}0hJak5qjgc)Guj0s58+0Bom(naGIu9hK+8|SHP$kQ+%1GX_ z%d1vL6L+-NxM4I4MjkpN$;Qamj@u+)str1$*Gp*`5>ss?rrID=ZBQl4ugXZ?vdgQ+ zXzq@gLKsbhk%!JmvN5tnq~4)tstr0Ly%g_~UXqu@0EEQl12WYHRkHl5jN~o5ylRYA z!AK#DCc(%f_tmvLmH4A2?9SW457*eC;u`!^sPWq>MKepN>DmR(*oMq_u(6vAj2j68Hk zl8uoqB5&fz*Q`Nj^lB+BLSj;kM1Kyl>jS8gENeOd*U0!N@~rB-t3* zBJvQE>ucEo&>3|~XC#>eIdLrkE z=RA&_rBXuXy64=DV^RsEn1zeXsMAQ9%&yxUAW>RhAKf4k!#P-`H1r&om^s)*WGq#b zTyLe+i5D(|(kfCWv+FfV>+7SV+7R)Bx0rwRw<30(ik(8Mv<{p)spM2l&0YlwKR#8$?STK()#-7Dv1~`!78PR zQ(9n#(mXPjDoU=mQd)&eP+CUHWOltqX?=Zkm~9Z4!huyvQ>WC$45bal-8F>zP*L8N@?blMwp>AjEtp(+X?0SvT`YOq{ zy%1I@&7IO5Gn8hLu~boVy_M23T!PXfQYN$OHAS&Ee$LqI$;lEpNm#X<8TQ| zqez*|u9uW_d_6B}>Ylb-nnWfM<{normz1Kq%JDTZX}C;59S8l-A~K2m=b?r`^}TQ2=ObYQps-MBhUxo50%m+Bpx3jai<>S z@e!!OR(@1Uxp0!V?DDD&!XtOI*Ht;#4XQ+y>7ft8l5JXG3#S_-;5icLj6P9HdM8yj zMkgemBY`|e0#&m7s*L0p%=<_6WNw2Cp zBl&Qr9-RkD_6{Zwl+db-sxex)qrEH(qZM6*>c~T9B-t3*!s)m%I#x1zsFb=P zaXS%-bPU35Jt;jaH-bQVXJyP((1W2K~*TD^|s z!*Um7xeKaf`BfRoTXuQX81>vSQwXC)F!InDNj65daJqye%U#eJJzGlSkXY^_vD^h& z?t&^=epN>DmR(*oMniYZ6vAj8j68Hkl8uoqoUY=?au;+)FPG9RB>Dv;mb)O!T~H;< zugXZ?vdgQ+XyT6c-Y|@2!N@~rB-t3*!fBfXEO$X?^m-{RLt?p$#Bvw(Z5mXv{Hl!P zExWvGjOOl`DTL897nKY~gg89Ij>BFT;8COX*}tEOC*1$Bm2TsgmVaWh8IewHHT? zQP&+ag)kZiBM+UC-*>P|0 zUtbfP#EU0OU^Qpe6FCnslXKs4;>nVSnd_eO5Kl_YR01hR;UY8YFjAIg({1ccl-Ab- zmvG_&2CI~&p5qiVlqQxD`(}A)@7M9xg*`@VP@0EJP?|-`WOltqX?;y_lSC|{!78Ph zQ(9q$(lRoZsv2>hEgvwmMTiF zw^AC0OHdj_%4BxEMrnObaDhbJjsdHb7EWn`8A{{GSgI(w-b!f}EmqvT&AFo1MdCEMBb>qP{W+N-m)e*ha>)j z@K?xP3K`ed1T(D(-u6x9Ba}=0y`K3J=;Pe8r8EwS?iPvp63BcB)OaR8s-j#8$Xj-K z)yBE%yLIBop{WWz^l?tIjl8xJxJnMpmq2Iqaw*M1;@l%KUjmsgfht*kRYvlbU0yXt z6L-uMs?vjzht5c{F|w7wHjd1fKxg!NDJ?@{zJ$bl31q$ms$}_98Od9AdDR%r-7! z$!3gfC2$i*9uI)d=+#nMgyfr8@OS{7#{-~BmS2^Tyk(bHt&V2ym??x&`XHW%UPqFR zk*x#{F+<|<0O*W5rL-?39uFY#cmU+_0H~7XS7jt`+2vJZv_?9TGPjYXNh`AD2J=m4!xWvrCE+S*8 zR;3oUQtHGTl|gA0DU;dt8m09~?oslfmjkPmbj5Ly{sw5?^>T8lqU3rjr9rp^rGBJL zX4h+!)+f2=NW{PkRw=1lg3=hX=1P&VR8exhmC`g^g3=^XCbR1`N}P|z^zAB%7%#yp zrLI$2VAfnIGL~xX#==%gt8fWQ%Sf5buGc70QiGDeJua+L>NzF7<_#r(hnxj#yv*%- zE2Z?lcTkG=#q(r#y+&z$lB=C1_+v(cQr{_!oYK&#>^Sov+E@#YX$Dv@tJ^4a#xW_gt^C+ zlicV&>XY1~q~|gPbsV}hJ;T&Hbwdqv?t054_biSi?}xuaPMM5rliY8kx48AqyyRkA zaDDK^gC_A^hwu3cllUsY6l3?XL004FX%P%SSe}8KiN1JNZjZJ zxzP)%WcgJY$y;`L)fj2RG*ya17>$FGht5c{F|sM}B^+6}fX?XIQW}TE!Uc(i3&_F+ zRLSzIGLpCK@~SZ!x}$w40Y;->ccOT_phv7tk5KTuQT$=!lV6xPUBNK$R@N zDkFKzF0UG+i96a?Xkj!AMjkpN$;Qa0z}qBX;Q~6N*Gp*`5(^h37A_zQ7f>b3ugXZ? zvdgQ+Xzq^o`6Cz&f{};LNU|}qDezH7dKNCAGdfaA8zIqGAhB=(S-5~IS$>{NHGc*nNf$4GMQbsu_jSkpWR&|5f?C6 zr8MvyrSKmdFEW;@@?3AFGz^!ZG>DYR?0SvT z`t0rkiCDaVRZ3&0G{Fp|abzr2lw5D6Gz*uYG>w$W?0SvT`t0roiCDaVRZ0`5w8RXh zMPw{hlw5D6)QRCdD6Jx8GP_=*^hawa?kIWC(}7h=Q>WCkc|zXxa&oDnnPx7jWeE9O#VBm(nOCdJ!aU&w<>Y168v8s*L0_8iE+cR`gbzbYen%Py}Pqp>?? z3Sl%4MjkpN$;Qa$Z#Qw|_8jPpUM;0XNQ_5F+@1ruJqM~}`BfRoTXuQX7|q-=pu#_c)K8Ffl&Ur5}ZL*n)v$n7~$CCjhMNZzu`tHx*1o@9vTaUt=2uj{u-3zpmTZTZ>GTH#u*#(pX0Ce=JHb=`3tpd^T)>;Q308Af zJ(2SSvqm@qyY4xU@sv#^sM3>*t5a9=WOm*9?nDX4#ysE#iRdoDDy2D&6tKjs z5spBVq^fw=TPby34c4B)DpDr1>orPre+^1U$%9@FtWsKdjy=p!>Jo^OR8exhmC_(w zRCydzKT;;M>orP$utw<|iMTxnRw*q#$1!FojUr>IqU3rjrD?bXrAeerX4h+!{&0=b zRT8l(1gn%*PHBM|O7qBAswlbMN@*1?L1`H&liBqer9WDubeJ)PWd>NKqydh4@7jQq zZxHCjNfjm6TPgL!B`EbGWiq>7Qc`AdT@2mRrY3{PB*NU|%Be|Q81<>i1=4Vtf;tYk zPa>1Zf1FegbJts@CRcGF`850$a>`^}o0@z-C+^l&He2z}~xTUTzAluI~r z0|j(O&z90SBqnx9+&}@jfdZ;z`BfRoTXuQX7!BPqQwXDBF!InDNj63{Nx6z6H&8%l z^l~Z9LZaT0xPbz40|ivc@~bkEx9sw&F`BqzrVvJhVC11Ql5C7@lCq5>H&8%l^m-{R zLt<))#MBaGY6+@j`BfRoTXuQX7|q==QwXDeF!InDNj63{Njdr}V)P*BjEemS2^Tyk(bHjnOI?DTGn)bCxbbXC#|3vPsHma^MCE=#2WMbTTBSlSte^ z0l9$!s$}_98Od9AdDR$o-7!-LqweP{U4+g^wlpR9S9~Y0ec(R4Q2D}Y&!)7>7Bijg z1_7*csf3y9-m`7sshkNKgWXBIxq$*!b5=c(^8hnB_dUm4s&aPSbMD}2rFn``xX4Tf z!$_ITu3Mj(DA7ANC|x2E7cf|*)b|{xn4vU@jHRl0*IOyg!zC!qB4skWUZeB}Ym{!1 zhzToLr8IC#E6h+@M#fS_$@NxB8^7c(L8;?vUYbp>QCc5=kK@D*6tGHZ=#=`Hq13aC z_{5%vnd_~ThT#&F29YwEU9VAEAAc{9h;a+7QW`m>31%pbBV(zmCD&Ui&B7%pO(SJ8 zyIxYNG{S{@+W0$9dwDLhqYov);;|C`BEB%#JNXe*$cAl1y!>As*L0dFYHJ8zUQaFXPCv7j#B1meMpNmc2+UdqI}Hph}ism65z2ZKMmFjmqBmmM3p%4tDeVi1WiJxTUXW!ksFLMZWh8IeuJVP|-a~20c8HnYV?Y3_TqjTOKylIMd@+4Pc9<&4kW(*~4TWD;TS zapiy#r@TI(+$0SbKB(iM&8#AmXi>{h!<@U`GN2swi>wpZoI*~SjB5kR-_n5c>4UbQ z<5Oeb%)bWwvtAF`V>*BCdqbVW70^3}mrH3D63Z4OmMtL57Eqml{HUICkde3S@~U+X z6L-uMa@b?eoT}AB?;IrW3^Lm|vTOmJ(d(tO42gjmiDe7OvISJh@~bkEx9sw&F`Bz$ zrVvJ>VC11QlDsp>9OYVK*#bJFBc-$v5@!I3Wedo%1ysrMt1^YMj(dCmdjEM6ZE?8 zXCyiGOvj^VTJJy3{G7@cR<8`DCEFopu8aWzta7P36R!J}vHE=-_xAqvZr}pmOg6!4 z&Z;MJo?s^DvFDgeRnD$^&P#HZO(l?G7A`WQP9tS9yKdK9qO{%(+#nH?O|VL->y(z5 zp|psMrK)(>TPbzYNpMQ5NSVy8my{~U()EPa4Qxav5#}COb^~!R^={xKY3TI9=mrLn zNz_$8)G+6+w{!y+aMXDYe}$Yf8P~djpHVmPBCoJAd3w{q?ANVD`Tb0en~4GFjr~X| zZG^09IS1 z(vof0jyK;RfK@J4jmULxkuy8)?fvU*{UqMB5wM!G>WQ2Om}%>M&oP&(oL%>vr+CVy z5=b!$7nxCqkusTGx3;bXm4p-bw6;EuOd`xZu59aZF!i>6nKTS2V6^plWD>+?p@unk zy``;h;|TLb_$y=zE#q2SKTU6T>xwPV{oVmybmw4n=cTkSB)W4Xx^s~398|mMSh&-| z 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

nS=FDNNmX5+YUbPuTZ-vJ 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

ugt6bw=<{Z<--tQUi9o9{T{%6=*^2%)o( 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

#(>-OS zN++>A8C((V(C3oo#OTC%Y{`nYbEZFQ&G7`ZJ)qcnZ2Jg)T2lpquE2hK`&|3F_sk11 z4Eu^>tp^IKS$nd$)!?L)U1|#^2ypSr>h6W5?DA?20@ZqKJ*^Blb~}aMYdu&HI1Hd; z_KPb2%;GL?$sP{`Z7VFjY)M|&JYZ8em0j{Ug%ua;j4~@zbVH3d)!Lz!GLNn-h}}nL z(%_p4?6%?SXl@!>M>FqhC=27=PUVCW%$8HWH1z{W%u*UHYSe*8GtF8lbwYO`ep(3J z>Mi4*yp;>EzUMF441|~3JEQvotW&JDVh70StynxAP3>;g9TVNJSWO#AXAvu1K*>V^ z)_0qJt$XuU=b=E?rf}}dJVpMIUbi^3MvDUmUJZnEyZ1&nO!e+hV7*?@tQ%xiJ4w2) zQ0oxQ!rw|&Ir2&5)vSHgy1-KBK^jYg{IycFwUnV!5!w*^BN_d;962j?k%?ce-&M&x z=PjHOUMjqb{PDx?BmG_OL`@Kd! z=18e?``QALGu1NIE3$syJ!J@fx^>|*cpnzs#fGK6Y8}>hE0g>xTl74XFpX zPkLL}TlojYBR>K1quJKR+ixRBViICoFWFHyCnr?9l0T#8QQj4d(mRfLW{r$@yAP@u zSQOzr)N%$ZKS5l`pdhA9>EIdp=1NH|OSqmsldgZ|X@Z5RhLfJFf(6FKF*|rDTA-rh za-PxzqS$~alKa_8T6Dw2HOkNC9%W^a%t<06utv4)iq%Kp`yXp{nk(s>DIuSL3aWFIhz@B zd1ojach0N`rwL7?ygbv$Gne~kDz~B26~ZGK4qXgu>Sa|gh7OZ^e>F$fZdEz2Gv4-z zHZ{I$?VDWDhC=cB+gXOi8Vx;){e#bMM~yz`OfC>Y>hwcckE*TnwL5?aYIg^ zE!v*TF8*&z1K|S&W%|!`tpI7x{;&_PPe0!iwUQ?cP8>8BI%krl$n-!Y3a4Z}i z-7%SZ#QS=)O7WI9=v&V^k}hLOHUG|CUAvM?LzmA5!sV$k&51JuZGrVHkWnRE3dTRP z7!muKU8fWD>gpTo&;uVT)ID$V>}T|Cj45)?Cpu|}rNz>%Nj6c;P zZOg24Svi;bPzLALe-XjLmqrhM%55NRZnINI`zyD3D{*Ba{7yMN-;SP_LV=vrAN=){ zKq)m)B9p`<^o0Yv(hS4=UBXhE9cna0!e%zH$ty=O%^xX^{if7lZ!zNPjqeWLWGr{u z-b4qPyPt`I!Zj;?Ee~3jq+2*X;<>< z-?|^8tj?GAOGg$W7P(Is03o_D*L??hm%cc4G-j>X;RUrkQ}hmHJ@}xj>+dr91s~0} zS@x|US&K(6m_U4K(S^=?;D9fi)98UA@TKcTo|g4CSi6&{BipH!qYKy*SGcSmj;aqIMQJ~0* z|Aj1mIu~|@_)>{=3V%pnlM8;EnriszysZy?zC5AuHJrD7G>hNhUJ$vrrXm7sKu3(V zVp_?xR?KbYLLDw7mRrGzAf$R)G?yoi@8!#$J`bW?^6fhUcW9)XM zdei#iL}|`CFk{v21>pU(9JGKVn`)RS)TFf*l*Cc zA;>xCLWd1a+GbRx*jVMZ@i~oH3A#Ib1l@)%jMwNzS1N}X`T<3xo5QbWnrHJ{NVY0| z^Z8XRdCu+QQ3~U2uLdNyjRf&eH`InNQ!Tlqm@3z{L8uh_eU++wCY942z6be~79>p; z#cVssV2K#A?~?228Q`thuR)>vISR;-`0Ho!RZ0_I2=;Z zUJ~at1;_HM<-7d9p%ni=agt3}hD^}bpmX6ZG+zQTER$!6l222)xqr=mhEcJIz_qLu zG+bk2;j446ibVv8`Ij|rT$nFt)h}7eZG2YGw1r>p-elta?mKzxs52Y9>@W&s=mlMi znUHTl-imUQ1XM^U0=GQtvD#z61$@vM4Qw)9k_?Z`u@7+)fwk_lgZ55m5b>z)j~tB7 z=bDDpqausF)6DZZuklHDeon_`*fa8$zk#D+tU_6DU){(c7ad#iMG{?ytrmGhL!ww5`8fk1EM@2QLDHkUa*df`js2PhW#n}=aq|I+xG$%o3n&{{5npiv%z@YCMgDH!Tk)^apwwd^3Oa+SHOHM_K3j=_zabvkOq}ntxm9YZ_qi0NR@3!PJXRp@@wSFp#o!2jFJ#RxExv`$d@N4 zj`r>2kT8D?e^tVq_{s~(ul&Pv0Pyd2uDKXMP9a~@$?3El(o&s%Rn9)56UiH1LpOEH zqI5Igtc(vPC+|b&oeK!xQFnp$*bV#U+A|8-VdQ=aid&D(C`=vBwAZ^2^ErD5JJaKv zv5ggptGSR#(x=7xeH)0176R&_S}Q(_U#?V+Z(DXc zTc6B9sGrt$4=W~z84I)O-$dtcr2Av8wlGt*TxK-N&~`nVwuAUD$D&xV1(Xq5;jX#S z+lzC;TkYPpH{Ni=4gFk?LBC$MJ{i28+ho_;-QMy}$9a#UsoxFBbMy%FC69ryl{_jj zj`#U0{gmcM*wTHuL))&+mtB6Q*pf{rc~fD!S>r4()eGNz9+{WJRs_&!13gF^RJ z=%=*?T)CYdKcvgQHgH^f&Am9Bw_&K_YGbSMAIV=Lc#o3b{gL3QL&!G=z^gxjzI_|O zc)Veiwdxc6_H8JzV&y#eq&lBRw^Q_Dy%%LQeU4NBmU$_@8Ky5ErKX2}3ELmiyid88 z-?J@~STBQIG_9ft{)>E@f@A|DJ^8vsfcY&X5Ur?01-i`7M0Je(${A6#!9>*8$g6R> zHKRmNYPYXAqM&fN-dv1Xiote1B$JV!ZuHZdZOax4joE&7j;!@0Vkl~VM_oQTnzKg# zxnH7TKCEu%N`zARzdkJg4W7NEN0bGrNnDZtI3+Q9_GH$%ZqoL}*0Ug>J-I79)}vqi zL(*}2%uVzllb>b9)ivv*E$8_r_4nT~CUsJ1Ty$@5-{h`Fd-C4!8H}}?zC*DUU+G#7 zQi;i3c3sdO7}LvIJVBeh*S_TiyH)AWjAsTh$DaJM;dk=t07x@r4a!hzFv2fOfXH#p zYtFI=0?<;?G~%D+aXuZU(d~Apy<<#o;+ogO)2px98=jDu{4!pBC~?CJbEDtGtej(S znlO3qPh0n&$5QpZBT$Zk5#cjDd3(m(ft``p38 zfl=1MJ%|I#3Im(c{ROwMT`^dJZoQMZp;NI-Fo=w44^-ggN&fD5mcn1pDs11Lx9ki3 zle=Uku!+XsNlfmPxb30Ye96I?i+n0e5SD$^e$KBiEh_gixt5h<`5SPOE`M^DSQ5U5 z4F~Oki>f&+|Bk&2KPp?hZWJc(R!Y&Q9m*=X?CdniD~<=5?%#xxko~ZMIwAFty(w*_ zHyHyI*y=uuUP(TwzSe%uimiZp*o*c+i7U4*Lti8ytJ8=pQk;d1wd&I(K-`Rdfr^H{ zt&w+p!|tAw4KF=7YnEPLv)5I`z_Z+Ge_8u$lb;`a{Ht^4&gC|6^t0IRA~;n5>WQ$K zmn|fc{qDGaSDRUL%etSSvA85psRZ$$BjXq}_aA6Inp?KT-WoZOxUp0lh9ik-dDYvk z`kl!cxiYxbTi1fvpfzp1Hx+l(o+3j~Okt_z$7KMgl-g7B6H|h?eS1q*Y>@~=H%+#0 z4BCgC_4osUTUDgMehas~FuI{!UWZ$ajmXgNS0xODnDq{ykA$DR7TwCRZ!C3hqh@FJ z_4Lt!wK6(5uR1#Ic|1gC#dPU=_)KdZHzZYPdDV}#AnrjyNYStEbHZE=7MpHBuo!gu-Z(l|_l{JycYV_B4 z25WtT{UIo7#T1+QKjVFY@Ftv(*&dYHW~D7)ql51+{f2z4j^%T_zViuEh1m718z~#W zu-4^!^F?q{Hr_r0b3Z{JVD2ACE87c#e!QuFq)=q2h3lDkx$1~qF8GJ9;iKscvjG<) z_xc(hDhdfDz-B1pDv}lbMt&f*#nXy3eNF$-#mBM%b+4LC_w3<%1HIdM8*xnid$aNN ztW}DAa6VsMo_irrS@PodFV8=In#jPwgtZOd#tf|~;+-ws)_twk>dn#C5t#GDHF=58 z<>PHWV_)-v>4vP&Jrkf)$YTc3^g+*tPvLEDbV)G|)cL04;G24)Hu@{|L~TPo(fQwC zYI|GR2Kxwu1dHA%dPmo{mGNbc)gJR!vhYO-krlfRID`Sanr?U%t!tXRkC#``%JX}Z zQ!An^pE?PDd`shzYHRg1uUS*pH`TG}$oj*v?T7kWORUNL+%#<;9dkIcx%!rut=MQG zb;k?zcdLE{mF=zxlVA2a1#49^34tykx7X1lv_;;bM1%&tfcA}UA5p=VW>cV=zIWB1 zK`s&LWc@T~(`x&+Jnr@bM4BFWIR};Jh8LJ=XnKoBg-zmLBujGHU?P$yHW+V-b4Zb~ z6|9>|em202!G1cxb?|Ahx@+MDi97Oa?#dMnJ$wc< z<(T8-7joOL3{*6oWZhFOtZsRE;qSponC(v7^0NC?$<(74(n9cK1K_ey;+hxYo4@-Z z#ac8bA=)Y?#d#EZn~J8u?Jw~EeYqSD7tuT3g-%gc$$&(ea%*ZS?x23<$}j}heKaE^bL z+{wa^r`zXC$M(oOLM?o9nrLo2`PNbAp!+gUL*qZsBUKpfw(b_3&QcRdOV3_gvA^Rj zSdVEHg2beTH$T$mXBkO6oU z9xh#eVxm?61g(dU1-2d~*fP_|V-vX$~7hq92(BG3aGZ%9tQ4@;3QbMfztW-TiCp@@@~wvt1zQgU ziL@{!7_+Gp+!VMtI>uV1DT?U&Po2~dIxCSMYC6?+#~eY#NM&!>KC601SV47uXz^(Y2$Yy6qG{g5eDZKyU*XOnqp{E8mw3l1w;s!c>X%Rs z#*a;>()F(m{D17dd3;sX)%bk^K?czqHP%?M9@<2R1WZDJOh5t&gEB+88Kma-U3>3y z@5un#_K){{f1mfl$vS7BJ*>U<+H0@9_S*Y&!f!GCN!riZl_1kH8u0^@2nL|heK-CH zPK#c|pICp9iVE47aEhe6W(fN3dLD0)wX?gN563Ko{yP`|$%!vUqqWX|Hmmb6MnX|$ zl#+$NeYkGGAm<1Q)e)2|tyOLDwXGz_$GNPBlrHvU0tSJ@QCU_qs@4Dc9v9!cA$gJO zmZV1{Q)Q57{|;GeMR}7ue%>jEOnb*q(SJ$s30F&KRIEP4SJUZg;&-KE@6`rR6|MPo zRRo#)+MD?+ftWb1;g)2XAQ~B~ib=#n?`6jLZW<=^Cv#z1@T#$&uGy z{1jp9;G)#7nZDmmA5qiZDT}HXhQyQULSx`i`RBbCO4DMx^~ku;w_1;6g#L`~{u6TS zdc)2CPL==gm^ z1$&!((kY3wSd2C>bHsce@ zH3oyV#EP!skC`q!I*NKL`}+0o+{_(*bq@%5RBdXEoHv7enVeou5?LZxW?(fr%X6J1 z2ZjXFvZFiN-0yp>m#73SBh^PXYfgNec{Yabz^e8~pNR4D-dx*Ry7?Ws_4xcESL6_dda3cumI z@!%jhe{*MdYWr~r=-Rt3Nr+|e_9G(a**?89)}O$~`D=S8IQiNes1=BWu75)4r5I}y zO}sF2m}9dQb{|Izb)1ye2)??wz5JOnI|hfBCQ3x-)kp@cDiw{MMMRk|gS=ZMH%$n! zrqi%0sttj!;>A)##fl>G?W(Rn#PB11Me9!cJ`n~iEY^~A-^JmjvOYv{a{S$YG7;;# z*&W|{#g{WJdc}VmclGGk!A{9v+ypCHs4Z)-DeRwm3FSm?2k_x9U9_b5ix8k6&t@toI^bJlYzSIEF88OT<$ z_qAQ<&ALh+K5LfTLJu+=;RnB!uMB_VBQpLT87usKn=eV=(?b=Bj&9uOTd=PLwj7;^ zasatnj*j=WjiE^AZI=-g8$=%^<|Z}#!F&aZyqQwxbA-0EXx3B2FM&4F3uXy)5>p>q ztDonn=Y`PZ)yPh!7SX|AM0-oE2H~{G7h8O7^<<~2iDNRHC$|vxS0;3zL$CG8!;ZwL zD0!mK3hII;h=Z_3^ejQt$TMBFl^mH$3|%9np`|0feOxiHmtmxH^k!FfAcjQH2|g8$~o8|jB)C*x(R3`DNJ&wJeR%zLuqePXZo z!&O?w0hfP>a{%M1>K~+kN773lDdNQrUJ$ki9aOq=hDw{HSezC`L-=$Gg@ibO+pP0w zXVyeoX^Lw1y`=Aiy)&*GCceZtW^ovXlmId7D4>P{gfSjUlicJBO3`-|GQYV{@<%Bg zA(r{~=q{gZLzmB_Qj(nVMo0vg>Aymvma7Nk_}XrUc;RUS9-FA%O6QPxnv_qrMl)NE za-v0{3S&?)OM{=c-gQec9RaF#CK^kgQ zkRi1jAXwAWQOgJDt}xZ}LU<+i;zC|P>}7@~%XlX=Av-C4MD!Fv(HEYXh}KM<9G`Ea z%)C_#>`($hkumy;*yjc#TD~V-E+RI%5EMHGBYF8~i4nQcA4nKfX?-u#$x<}<83`eL zcBmA>q{f@_!&f2b$I%NY-@(%VUj;DuVTj!FN2%R1_)ie5h(1b=xMzw`J499>Hc)CW z6=2t^u6;2tq>*Ix-sSwmd{;F(fgaDPIXe=?nWQ2y`b){-ajC#x;`O*$X!kn;vz~MQ z606Cxgl<&Dt|t*9cnL1vLt>TxmC&ts;55l;v(Cw-h$CT-5f(4-Jc4wMMtW+bo6Xdy zk);l|$*4oO<86xtyfi*hOnVd6e0FoG{Z`9ogF=~m@kcztN$SLHePYP|C|gn0LFsZr z_qO}RbP&SndhdIj3kd=F9h`dW){jSDe(Q5n_r9x2=-i*y`RgVo*n3~wfBsJHUOmwA zW@%^;$FCmUM$!-DjPTxRUmkRvm>R=Z5A5yy_onmrysooI{7pYuT>YAyguD%}llZ^# ztbMKTq`*;j>(R5WJL4fyxDqxdo{Zr1j zWRn8iXESq4m3%5xK3S|^kk<~C*RvZwV#*fz<7o2Q>g0ykCi0zKrmk(B8>b~Y$3kDy z@)dhKpM>vb#|bY6G;>Z)Xn=E8>k~=N5iv_OTr-4m5c)-mgNYb0^^>&~o1 zr%c!=F`5b9+Mi$!(Ue;)JG-+w3zj7LZj~ig32p66rtQ%v!qc$kag({_zyQ|cokOC( zQmJJf=e2H6PB__G zj?)jXI8Joc^9PdbEaWq8w44dSUpn6yJTA{;vJXrGCbw=E2_TM2Dkr4ayyF}Tleb=J z*h#_r5iW&%Bk2f!b%o%Z3n}up2QTc{aGZk^FHrXUOm>Q)-=;8{4C6Hu^1Llg2gz1e z5torcrflqhA|N0uiOU?+hHII;iZs0w{5gw_c~-8tXGx_^dqKHGKE9gu9BprRTzWif zU;55-UrIkHkLMn1eKL{Q&pM^YTVG4agFBo*2meS}xgePtPX1j7Gx+BG@U-K3JJ{y2 z>Nv+hjueA+*J-Z4@VWTPei^O%OP7`QHuEQa(o4t9dK#4}`(^*)BnTMXdIVF`Q7rk) zJ=SuZ6@+p5Nzag|PHt|2RyvGqH7>oJmxEJSgibDe1de?m04mQ_RuNWP^vV?Gw5kAJpg={(VNh zcQ`|)odwaPEe8g%81mr-B*39+fUU~CmvZ4dP77in$3^uSl6K5ZVvKC>6qJaWD;Vm1 zY&&G(OdcKuz&hmg|zpGlh_p z{iofhLiVmtZIDr`L7#VC$2sS9oF0$@Y}osrd|IQ0N?{b(30*H2x^6j;%o;_Baz9Mr zEVDHizMQB})dD4bxVP_yZ$U|nHj;)UQj-*C4^L`>!f_OGS}wJj<=dD*_EK%>e=o9> zkie{l=*x(_P?ECs^+5p2R2L(Rc^c%qB_dA`sCS8YRO?vG6;oK<_TBQb%+hq2EO}Q5 z;=Z=OdUI(13vnQJ%0PXR8q};tE~C6aR^KgW4=0DCr}MDh_uZ`{w>mpFE@Z$*TBws< z5DhTFJ!H$8n3$(9xP(TMU9Q?M0;A5};%rf_3F$jq-x}g8*&-Sf2nTZ;zfTo1y+lMlnWkOW&XKaSGej4PTI54x4HB zS4$fkCb5M{e4F_O5*%f>Zq0lJonT`U+rMtSnNs#{*)#Sb$@wYu#f}^2pQfs~9!pc+ zK~P-p3qMP{uosI+U1NGjzp!ug`y@K&Z*ykGmW2IJ^KlT(t^Ff%S@*u^>iZ$rUbUHt zle-beMd~Pnn|>o)(*8gEm5O1ark!)*@=^EAl*scViJ%YiFkK$0p40x^_Q94T14>G0 zD0{3$>Nry{VLiYNWt0t_io>&P zX_Z%WHsND(uZEZ5aLv!rF)~B_VjQK|E^VhU9nCGR>bvoWLsg3$(1&mx0!#fth_2IR z`yK3hie_18mCL9g=UeAWjf7oAnz`d23W*2+!4!htBLM0a%t-d#Di6*MBV%X?e*ZW=d?JM`sj+U>kh~FykuHXL>7EYEK5Gep2H{avj{7*C5#zA z_U2bCikYXH(IezYZThwtvKZO{7Jeo38-6k{9v zPo=hOfRh?KpCNP7x99D+mJ=<;FtN@0B!RPC$UwaoTHYnh&39i_;q0SfT%!Ake4QgQ zHc~-_c~?YsHkS4@WEb1-t~;M)VD`ND=Iux)X8MkFkz4CAFUxQvCoC>x@Sa6mvb(|8 zc83f%pIj&Y%SGsoi9(!P=`^y;#l7Soxj+iqAzkY4k=Cy$!Y)id=xhHbX$?}5XCSCL zUtt-j-|}}_OE*Pgq?p`X8aO*P3>C{on=FcD?dzDyLFS1<>K5PS@%`)lnnsuQAKA_VYM13%E3~3BWF8YF8uR1%_)kfo`hhg z>;b-8#Q%|4@}^z(t%4zZBSXIE9EmcKj+{mPwD3seu;GN}bJ0b=c zxJi%q4~pOw>4=-Zh-q?J$>*jV)h6pBU6@;G9M2fWQ-&GGeC@NT4Dv_1n*5{?DlAZz z$VB#J2#l5>dtTm?B>_bek-n?CFgX)cCPMGF{gOJR#J?L7;0@02DGAXU?nIuF`y2=?hqV?-7F5QLeogx3 zZ!VN)-d70uY8eb!A+^ofkTI6M+*WCd+V_!5k+1zH($zTJ33|>V&-GGy`jYInv!k!_ z;IMT^c>CAqsmzOI3-?La>!|Lqm z9xvckU)y&j##O{{a$+f+9psUy(k_uV+bMRv6g$hXapWHCpUxI2AtP4n77=E1WRQx? zw23dy3CeYjI1Ber+7 zDElCtoavip@r3IJbGFPU!b4`(vJdN@x6{1DyXbcQ#Pn;Bl1)jVni#RpC+jDpx66=f zI!kmAjzXqJkrw(Eyx|O%4EmB(F}?5=uVOA1-^}UVEN!meu$_!Ev!0>|G(((j z5TW8~*48FB*K)ANEw`S6FxXt)O^G>OXB+;{!$Wj0Oe`mhJKI{0<%Oqrhu&to2aams z<17q@KI|ir*RW&4wnccs^XO}9C1)i5=>>#^hB(7hBacfABhBa#qCG`lr5`J;z@1Le zTSNq?p2NAFAO2=|cz%MIw)G6dBb5lV!)3Cu-rji5o~O|v(bPm^l#j7&q&D!&`aDbr zzP8t3V686FIWxM>j?q&^+3jn4j0h-)9F@rCACjR{9_lRxz2#ljz2})%-lo8(_r3k{ zOIJVCyjiO)ZuNvbWGQFEsA|56v7IiOak^VIH8oHSFSCQ_%dELjb0v%5FFSf8blEOK zi3I(MP>+<2K1OPebV3B+z0p?9KqT0x?YR?a1s5r!tqN`;V59Rv3Wmsmc~W8xic%9z zr;kYv^71hxA6p4YRK$%H9f0KQ(O_zgQwusOyMMS>`PVex`*c^5;io-M3lcD-QNUwE z4AYfiLSSjlSE96n@GgRjsCh3m@8knIPwD9fACudAAc~MuDlCszY>1$40KteGs9&^8>L~CCO;VU^pl`|se5JAZZ+Z8>2 z*8D++6Wm2=W;(Jh)pmvD5X3D4#34-1E-nHIyY)yOu0}K!;!WDurl};Q2Q}%NWKk5o z6nUjoY>%p~S{q7qoz9m@+kQ!E)#JBFk1wXj3zdXgJ$k+n*Jbd5u%H%Bi8AIXi7*wx z1cFMRdopsFIKCed5n=moy#sOAEC+RFvQT{k4?<#>F*lqVT>*jBd}mwBHQkvabUuzs z8j74V#)wFYQR6kc0KZPt<1>cgPg)aJ#Y%cvck~ie4X{?~liSYUK!Fh#U-ZqTXHm$k z;S5DHl8{f~M$+q>{WJ?{hFJFFEhK=YnQFWWud7Cw0BzTj96_pv)_JMhxDm|P> zIL(|By_|^j2HoDzND`5ALKJm&9H=PmQu1L3!6(9YF4dg9B%CFLfUaesAEJZYvQ6^U z=&KH8(2xEH9mvf*`h6Y*eP8gJ&mMwE?Rm7tW%4Qu^gPgp_hu){(?=(SQ~? zh4^o%q%4hPb)u%JuWIl{yo7iedcWoOosx;KUHoNynsbn_w!4SnR>yw$gPqeRZ?B>J75)HX#8!ChnA`GWYmfR&b_aI@nmyw9a^u6Jnu*!@z+LmKw5R#74 zaxCC$`=b^VWsWd!is*`!ggATfppG!RYCSUey3?TNvqwZnIWl;|Cl0puf5+LAO4uyY zv}{O_+f-lM70?pe8~h;q`oRfS^Cwc-yqA5gm-2d`?jxzrUREn)Q775?wCh4euVZL# zho!pDwr*t!szu1fhY)rjaE=b$p7*C9F2lv$;dR~l1Dkh`Asgpt-k+Mfe1F)^S!nd2 zWE@S#$U4R(7~bB355c#Rw!ATj6IjK-kePSLck3=_Bhzrpce9vP)eF{g3M%-t$}OG% zbalp}@Y&GL*_!@R-V4rd->ua`Nik(C!9x=DH9&1zk72$2y1GH)rgKA{wnG=12Yn(5 zHmmC*JM<2GcF=pzW7*g988MseWIHdYMYipU4^tf9)j%#Lb4uI0bSCT*$6> zTRsi=+V>FwsgX<%9>J{zOrhamqVj~6V|?J|JgOw$R%&Y}*thw1A!s-#W1TJWIYGJQ zXo~Mfhqo;EwZ5Ii&)Q_%tD%thV#YCG*t>dyp>#zs68#5 zY3M8cK(l0c;gW;C&8o9GM|IlO&r6RX-DuKfs3Yvq9M}c$EEb>V93#eTVeiEzJWRc+vQ_{xmd~#_x9HObTu^-(o0q}(SUGpfZHazA#PYBjSQV=@AE}{ zFsw8XtA1oNGr~uHD#)nA9OA4Kn@_Og{S_*WVQvpw9Z(?L^y3+cq&9Tbbhw?{)Mx@R zT|Q6;8L;0{=43Y+(zFHCO+x4fRqIUW5GJZEpAKsMEWvrT^;KDqJ@V`k4l&!B@a&Q1 zqaqP*7TXW zJ}6BnN5)hw62legL~|9cYWuCaK^`2W*w$xc<@R!^r?S3Ra5uuqjJF?e zmx;{%3;9N`p;_9g9Oo1Lh{T+lcc#KnTP7p3MO)wDL~+A$t457PK(;;qYm*#A+3uU+D$PH5 zW-)IEGdibTa81(s6xbp(nPt(3jz45m@AQN6d5x{tUL=^%Vp@466FF~`s>|sSBg9lQ zqF@F>_gw1x$Vk#fUxfF0zl^@y?jtnX#vi)bGMQF>1|vj+1dyW|8KeI#>Q;#eCooG^ zMMsYi=G(kPeFUhG;_}N;@WnMzS?c8DKWF*cAK=*?&tG6Xe>>q7-{#Xr%Em@gUz_q! zI@D)?js6Z+OSI4V~0MUmfO@Fr+~ht%s=#~Wx}lY618g&WM78g#jfagr2Y&> zk9?Jg9KwjpzzZlg6yO|E)pb6gx9)zuJ^3!aa_-x_uXWoMw_xhX~J? zN`6|tMH^{;eLU;|X%qxf^kERz{u)Wbc_1~qV^I=2Add{n+vN)j>xZvM=2%jPxlCef zxbO~|C6VtT3wAlFhBX}aZJ=#ZP9mQIC`)AT!w0(~c`y2I_#N>eYbu$u@rTYloc*<5 zcA|J!pbPANgKssZ4&CF-INmYsxTIL~`WPm6pf+642`~Ay_4VW7g=ZzQbTohj>3h>( zV!tMv2ap9j`8FD$G%3Ws$t2^8%y_dyuW#)rRXUdYDsJD)+p&5-9s(U@$Hhrt2TlTO z4hrgrcO@KYJ#d^?;wtbn_8K`#Uo7Y45YBAnD~#b0H|4#A*Tk%3Ie02`DmE>~gJFD_ zW;ocjcG`Kn*Bt!jHaRRgVdpouaSR?#M8AK9nb*TIYfu{uHf`J_V=&r40{n_qf^TfT z^ZOSi4zpS7p-TSr8)a84N-}uSR@W&Miz3TJJ^^j+ZTT|6>i0!MSKru{ zV3;?RBk`W2M@yAOd106%ll3S$e-E!kd_K&hZ}Uw;1$5^2yXh0H=!iEi5pgD4WB7iU z@0M2yE}&BdSG9gRc!U38nasdSa@Luh{?a41JR)wwIp5)qEprxw#bIZ!(pS$8Mx*(qKkekN3GeESK+(yQc8A?JR${({vx#k zZv<%j3=yDsemd_fZ!6J9o+nlTbqmfBG-p00sZ_Ucj-|f>uEV#yH6Z;U-Es)#n86g1 z%vnL;vo+CqW%paY&Fm{0deDL1dxZa;0c#ErXE-@l_-+uz2GlAbN@~2lTX!UOED<)% zJL;4j4<6)Gdhw4NZw-D(3OThPwWH`bo<7+;rsk0e23nn6D#JlV*BLSWB5$j&Z6dGm zQ0f>0SHJ%dlP!yZOm!*r2R=YSBPPfT{nR#4! zV6sGcEZuqE`M9|WVzL?#TE)?O(rz?onRANo+f&F;ZAOXAkwIynQc>c?%K;OhGY|xQ zHze~w@@SICeMqZaexR75oFbbv0u2zonrtaLbbff{0N-Op;(K*k*SY!xA_R2k^wuNk z%?ClcOuoB0Sn`nhftF^v1G5`&JE#BrcozKyg(MUt8Cz}>nn!k=pL0j-K-lixI>tMR zyu+SO%-J0I!yyt%7r1edq^J0@j`N4;RLcnH-rf3+9JaOAb6@syQy?<&t2D4mBja8; zadkNHNlDBsMLV8F^Lc``OS9`5lSBwLuTsG__8ast)K#a*|b8^Q9sv z+`P|Dxv{KI{s8+g=65{<7uRz%B0&OgMJ^F_|Q+xux~BBMDoa z(yBPn|TdzqRx?voGm_s@BON;w<@Yt(+z)RDvo+;R;dOOPrSpkRuZS1ccR`)c1=$ zhpSVQ5?)F;c*Ze@K>QZABp|UzI4^8?$vH-!EE@WuIwEjHLHUqtzlyLa5>h*%Zzt2q zo!!o~q}C@gJo9C}jSr{21R?uZs5qngw$MwMQ3V^pE@nuT0Aw4V9~ll-iIFn=kW?5c ze?v;-N>SI%h7hK{oT5bALwM$YbXe(hY6hd{fE-)j`osveQ94E+eKagODq}-6A8qfr zA}Q~cYlm|{9$TuBZSUiSm^i**rkHbcd_U@BN7cZYO6^*v3LqGR)*unL;>lB#Ou*>y z@Qu#XOvDTGb_LG`fkKy`wZTi|`PMau!ZRguW;pRdfE_O7>-BeWmx?0aZaI((TO0RO3P-f2}?C_#~1@F?D+a|{8?>kki%C;4h+C2 zV`tZpjyao-qXrE^CulxIW;x^|pRUj0Gt_e1YCJ~4U+W_y;1n_cV_@fe7GL{!X&SsN+Ps_gHJ?IP`kWGnk)O*HQ*yb?^s(k&8Zqb`?smIQ*NgB|j zVQ7%V$ZyGAO7peLIiCDYF&@(7J>l5a3(uQ593V$Olcu+>-)+ZA?<{sx1%zels z0!N_3Xy5$rSy)qt-2n z9mV9Ce(+pIjMOAi#WA6g4=BArb0+2eNhV=0O6oC!NL}iP)(Df5GUFECQs^i@9=`Ip?+;tC zWvB0GJu=M6+c4$#m?16aMN@G4mfi1P{}*wp7QvC#o%ddFP{%b#cE2Bp_-KW^L(Q*{LlI&vGvQdmZs)!9&k|nA`}=jH zw7izYphtLuNVo{C;3(o@MNsb~p! zm4!tGV1%L5CptOU8yPX>a}^LT34D^B5n?v7iB?E)a-SIag^r_y5pndmFe7OUr+nhO z!1fHZm)tR=VAc3Sy#IL=g(+3sM4y;$K<_yG9#sDJdLXeQe8y}>9K#mmh6akqWUfkU=KMAW#IJ7A-yu=ul#yeY#SdqbL)p4X|-fpKB+f@3e z;qorAgOwz)!)UenxF&SB^0u$}P?xF*Z}6uyrt1(dNfh}aDJgH)wdvuU*1SW(Z*E``i zzvE@suU!4WR32+r*A`JQ%1JK8i!C9oCEs#(H=ofpA})^!3Y`k+oL%XAIO`sJnYNR; zN(v_(le&URu)tG8<7PCEsF~btt!W_RvW*F-08=E8tov<>OIYwiwULdmh;*5$42fJw|7g{-#S`db=m(J`NeQkdC!s+H9}oAn ziE`JzkJF#Wgz5>c;4qm^{S68yf;r_g4$S?s;UB*KumcYlD|9ud-m_n=V)YfIU;?Hw z@%^sU(mgLRB1`$W{ru?1Q~tH< ziA~OX&ff)5z4#GP45^;~-uiBWR!ZYp!v;KLz57ikBAq0BB?|(S?Y6x@VV$f_+M1z1 zlv>l8XEmSIl@jNln%2T%D>Rh(V&2x~4-ajVf8O-nX-Dq7Hn3?^ciKk=9yIVB10x2$ zY2X0^_Zzs!z~>FzW#CQ&I}Lo)z=sTc(7<~Pyvx8l4cuhl%?55Xu+6|01J@h4*1(W~ z0R!s{TxnpnftMRtVc+a}3NhFvGyn2BsQl8#uziWCN27 z9B$wc0}~Cj3_MQfllD4d;70}?H1Hh*BL*HYaKC|j41C_eT?YQqz?}v@VPL0$4;Xl# zfp;5tmw}rMY%{RM!1V^MH85b{G6OGH(B1L-<9mYF2DZidm%fpB;~*8N#wVnS_;Sgf zh-G{!wEOIX+PWsPYqfkjR4i^E5%zG|!6wXZL+JS>Td{Q5KP{1yAu<1SACQTQk^kD> z(I+dXM^;6itbSUgvKi5RK;hG!CfUaE?M{>T@g64l{`gL+C`jk+Su-rWX&F<|yxptM zZrx@hT0HhaG21zN#YDi0Qfp@tb&1@K=(zsU;Z}$zAL}|+2I0F6m`ennrH*kvKE|VpxP*9@nXbuX=AKweTJFJ+!Q0QTX0Z1&?%*Yo0 zNZ2@_pmaZJovp0tJf}w{R=vd@LAI2q6nj$M?QI+eiqXzC$>Ud=t{oGkiMlxsk@g9l z|I;!>Q*`$30}pk6&=l|nNV4sc3|i>~KNXxqFFf=hF}q>|n?9eYJ5BP6)4x0I3Da+u zDTpuCkMAQnDvkOMT6-sV6`}OKPa{c-l(IuZp+1SyRl>8Z4kUAG0rt_BB8d-e$;nowAk)Wd-D$6|LYW_y<}V_^^kk62nHkG!AVepI=&=5x#0**1m%5Yrp2(oIJ$0IW%OTZ}a6t61KdavgM7Wgcrie zUyWHC2ZG zrM%vjysB1KHZ=I_g8vXEJtGS0a8sqPwwsP4|YKSFNZ?xnl96C+DTjE-A5! zuI|3+Gs`+AyZ%e3P^FtbyP979r{RCf7+>DK;rr)WMKv|u8^)X8IhU4{ymIyM z&;`~7mXCjf`8SY%2f7b*ALQQ={vGF^s^bvrlW$qp(f|5vK|Q;V!G46$CaWV!kV@+sl4y6x66>!O76gsT&NnDB>$eF>i=Bn?Ps z$V;#WSc$|=vTUnJM&6zQCnGOWEvxg9pps`YdOmCJVJ+(ob1##ukInrc?gu}r<1?MH zzHII>_*kRNeG>OM=3e~5^36T|$ySlM$AiVX#N6B5f5Y5oa$jZcv$zkL`y%e!&3!TV zx0(BC-2c$rkL3P-?tjg78TY?4;bq)!Gxy85|FgN5O8?c|U&Z}v=Dvyhcg?+YhNI@5 z+de=0>`-7dSDzQ20HLeUQ0OJ}7TPL00$WCh0uuJm{vAr-E8O}an&NO-1PeWGjSgv-(K0M zN2!mruiK{kd`}e}N}MoNAitZ`MAQ^WQBmw072S04Fr;!lbaCUyOM=%f$sI&;!f7mS$n zmC_3*O+G7Y(pSDyIH~c4S(AS9#-d4wpQ@VV{9DtcUyQwe(qp$flR~YxPkL*}-IE^6 z`1z!nM<1NDZr!7kK6_~Aq?u3rb<*wky)o%X@WV-+Urxxq|pma+fDx zn7jDZ%-lU!6z1OkgIT#B-n%Gw{Ebz)4P{Nay9ZyNd*v!8_uCb>=U%k$2f0I!|15Xq zlMm(=OnWpp{komG_q6{tcd!4A+(^cUxzUfTycvs!=AAzM%)HB)x(@>ULQ%1d~?B`ywgs7 zG_Pj*&b(7+{xvWAYj5Pe`?nAB&i{**KWN<0{LGXy^Y8!edHHAmIxYWqYcliKzh96) z?7~_3J4P+ae=DIXf9=+*@(Uhq$&a4vEBO2L%z_mU6%VD(3OiGOQ21ot&kEZ=`9Q(b9~6Fig*Dmv?U2c@{@WRo2b_N1U)977hT#idBcx4PTu(K+a}LC{Qb!lLw`2;!>zxVd}Q1slLvl%$K?9C&riPm+}9^R z`}D!d-^{h9tO*a9GQR$dDVq*_dCI5{Qm2f&|Kce(o>egA>4KS4=8ju9Wzvz#DQ*7| zm~v}c%aq`{jZQ9(C_56e7Q$PJ}<jNu4S|8YTDkti26*13{Ifnd1#!TS)Gm9b5AZ%PY&xQr7J4VSV{^iKR=9>mnJ zOfKfONnF;4O@VoD6+QCHb004u%m3H^&`(!Xts0v(aa?s>owf9m)k_!nSJVbW{-)`5 zmBFC@^OWJ`){MsHhH87%?2_@L?0Tg@j~iw!@CO^4o2vYFO=HuQcD|h!9A>3SUh^75 zcBQ?#vaYt;_BS;(HrWl$^~?QD_UN?gbP`I$8I4W#l_9%rOtW#>}%rcu>_d$?ZX${hWVUy|M;-M^InUo8Kki!QRMdsSn7 zeI?D8Z&%e<+mr3gwQ1@Ls@6T})q&eD`hV`ajIx_fQvQL@!S7?Kbg)gL&^Q~aON`_gnT;-v%*~iUNvN-=YzjNt0L;9m;P7Z{#EEz#o*ETL);SVh}z1qH5g#`WnE6r`lUsoq% z5gl&v>;(%K70+2Zd%n#$)La#U@7+9_{A70GXt8)}nrcJ-lSC|E$9P_^JCY1~<;{Tr zQpc4hjGQvuE^pRyNJh*0$~p;^QTL?rn;U|$y!;JSjn%acE5=!Bl!hqvm8%$(P4?uP z>3LP#(EF8TDOy%H`h#ld_pe0_v57@WQ3Wbd239oJRg$C7d~~2O7_41hw~iNq+JJv* zy24fEp^^qwjT#!246~~mn-OTs{bW)}t){C-$+j`zZ%{dkf)UqE%IB5Lm_4WTB0JDn z+kiGCna^7^XO6Vl?0GZhyWw^~w4`b~)YwzA@W@i#uCxz>Ehbc&N=95iS7VL65_Hgh z0*E?AJ863<*v)?&(w5>ID(iInWhfmbj+9I5U}H^aO=XkcUQIX*An^fkY?4OO3;ZMHT-nkUm$b5d+so%^P-Ab5j%8!)=;hU`tiJO0z`u zzb}+Xb076^>8$iqMPk!WV*GDTHD4mD2w(y-)Ti3xGU#aV! zyzD-8myR7Lv|G+{n#lA3X`p_kC}_p-lK5ISEoC+kYHV7k7~V+CX$$5TmrO5a8ASDK zBZa-`DWKm-FfP5mvT21&JJk}?ix>3B${Wkzly5JuTw#YQS1b+r*XrJ9km;RR@mC+7 zr^6_+t*J#@a{EkEogdqOwd!}{)Yx!kC4yZtRzpv9bCWcwbT1uMcRKi)b(q@5hF)n@ zkNo^JiyDFfe^o8|q6}4DNu~2cuvOM0^F+kCg0iN$p-M{hOh8mUMfM>UYbzVZHu!@< zCT~saSS_ikY_1D=Us%)invV$ehLDU8SNoe9$5{($4rVj!VgkdC;ii!>f<&kDh_V1P zA(U-+n(_bDZ9M3K@n3#yNaR2h4fn`^i@N+ zb1v|%B*BX2#^#`^zsujXMjuzPV+8COCmw9izcfP)by5pS(xVb?p3(;t8nJ|G#vH>@ z5OCv~DvMlJ=<5Mi7%AS5Rc0j8X=uv@B}*32D}%MFWk**vtqX)|tJI+4<~!XZA5_78 zbF{0Q8KoLU7ZPTb>4%i7M@cV^)6K+H#vVp`e^q5Oa|M-aWu2h8&R)q#SlL`%t2KZa zuKD&1H5AfxeFcuE+_*f14FwrN%P$&&iL_>=(HvY21w?zuX}8{UE7#W6H`lxARHZ}= zRjyEyv1+B!vrZOYvpN;ivE8WBWjr|Bnjt-HsVE|$C#ownQWHzG1f!Bjl6d8XadZjs zuqFQ5CO0&$RvKP_3QLL?tEL!dW2PCkVD^j|qv(^&dg-3B!WwIfK5b36squm;*YktUGNzjvCsu6ApW@+5Vu*MAy4Pd{;dgU%>fpLKC*M59Iy1nMfQ zAgJ3{dem9kZ&X=n@uen>MC*@^-Z*qzvA8YwGambURiVGMiWC^Z8oof>X{dC_yt>*I z4Wg~}P9&TzdMwHiGnEtIDs3)2?vmkTZ60rmIXEI{COJ{Qs@ulYOQlw7^{p3c^+$se zB}fzzV6n2|>6dzxz8J3*my}JP>)~G4FtWThWGmBzheu8nw|})Yj??F-)1DSVn}OM0 zF745ScV?E)otTx`50XZIRK)P&N$*q4$si%jHe>#RxiLenhu4bZ@kYtL8;6RARthKU zls$0qrkOr}ZYptR^M_|PA4kIn9gFH5^uXW{;HlDAI%yvy&=Od61V?y$Mxu> zy*i+$r2gnWPR-c79k~B8O#5h>m{#l`XXdn6*AW5I%T7=)H5@lKFkvzCWDEo~wq$N3 zac_C=l{>|Y49B?C*1XjdZ#NE;O_{pdqsC!*93>O>QPmB>ac;W`ey;J-TNzwgsYH|6@!V3=dDO(OF>dRk)y0v{BWGO_>iqKKuj#a`Ffm)g z9c)Q$Lv`btpgnzoJ$4Fz=geRZ(O}xu4m34Z$uuZlA5R&dSCLpf7SEq<(2{nTP8SN* zuJ+rD8*5pelOZ)u=6=!$pY^3pJWmfF#+Jd<4q`*Lyq2)_Vv50kb%~T!) z`YB&(B5kHkUa_R2Fwni-UZSLlcm4(qTr@J2eLziHJw+MXZT6b zjj)R`fyU&L(0KNO>BVzB45^=ELM2w0-tk|G`xnsv`o#S_{m<3k`Xn^NNN@dZ zZt+6TTxWG|i$2COPQ+Ph~wPfzgBm^c%3=VM~VOjbG>d{r&>8Du|eZ6523N9KCc zO+z3krBo(`3~zKGK_lMop1A#&(F3)3y0XQ3>{IQ}LsonMjPYtbj-cU+*#7cRX!fJE zSIjo`_ht~wKlZkCtw>%YPt>fzh%8gq3HznVp-;E`ymYe`G9f{h^h&5PGo_(fl$2}q zU3!Zlk@j#aD*ezC$xZFG%a)g9t1MzFdZm8U{N$#PT&1fRYq85hy14qvK)>NCfve4V zbCLx8g){iZokV(;VVFcK?%up=m`ul8K28S)OSrinZA(dHHO!$ts_4}?k+8_(;nRE> zTy=agp`!MLYMJz29kbnqR$@$&qWVkgePP!%iZ;5gp(ah6;IcrlPKOPS+aNuLclEKX-ymbH!C{> zg-%Aa>>N+IGbd%Qjm7S3Uy6^-S?)*}r%}1uPN0YCs+EmFOljB_^n4zXg!ylUECN-c zs5C9-jY3K$#CY*A{wZQkFIyDPPzf8%kTKJcTTkd24?NjCu76vQC+)lw7&hDnnxWRg zM53zMMu;UdHTFrbES^(5Jw_`J4W$j3FifAdXx^ng78c_*Tco{3jOrO1!QJ}h+Y6W$ zF;`LxEHYwAF5h(urHv`4rdKXZR0yqp5|CizC1_QFq zD+4G#))hcLp=NCYo(}v8&0>1&g2l!3k z6Tr)X!$$`LR{%4C?60w^flGlm1D634(}RIZU@mYuunkxRycbvvd;;hPMu0Uy`=VfA z1#lKn{AAYxYk~IxR{@^~UI|PZ6AaV=i-7gOWxxjDy+GO5vx?*gs^?gCy7JOaE1Xpaj9)&t9c*8*FB*8v{@ zZUF89wg3|^4hF6VW&*zrTnTIi-UVy}b^_ahZvt-sj>rrKZUoK(ZUnXf9pJsdn}AOM z!@#$Iw*V8ff`MCsnZQlJmB8D8{|>wz_z>_8;C|qpz|*sXf$soE0ly2J3j8-<1@JCl z0Qfy%2k`sAdx1Xyb^`AP9t8dnm@z&W_;=tO;E#aof%gD^3j8tfQD6t~BjC-zoSb0b zC%^#kr@$@1dx86bKLe&r2nPNOSOWYxa4qmZfIk4<2YeKGKXBm0VBkN2Ht+%9Lg0S` z*8=|s_-o)Vfcn=WUD0Z>iY%K`fJ|Tvl-B3eFULYC{lVT?9k8A1z#-s0Tp_L^uF_C_ zE>Uu_LpcJh(j2aukc64wY-_otvdQ6RHQ`HH$!cI-V`G3Zx4LHlZZAzCD~M?iH+xM`teTx)O$-%7i{ZuBu+iI?6b7fva99q*sSb2 zoRYX(G0d_@v&1AmN}}eWbIHf1#YxvFht|lEOBT$ZH*@4jYd#Y-;)bj_)K3Vxq_Rob zO7oSvp*3xL3ckEG<`;K^US3%}lHV{3{8vFrYZjAdJJZay#8oJ^ge!iixC5^huk3nD zmJP(ut$CQ8HWwFd_YrR*jW#H!HK*&h&?g%~V~b^65>=a=Y~^(vi*LnVQ2kh3adyqJ zY};sv3&fZsc@W2*Af z&RT)NIiAP(Y!Z_4WN{|usLXpuAsx#k)5)@@8OluesRiV;?NXz3n;P^RW>21?9qBbu zhgqu>hs=-}kE|gY?M;l6xD_Z@U2=BKiR7%BLfXJX9`|*Y!rpx{kp(m5Ge(C%o7K%g zn9z_v*xB`Rzl7NK;>x;aKh0N@qka9QB*O6YR}>H}kU6z({*}Uan4D)UE?uDU24B5C zAr0%rP&q)yUkOh0wG)#RDzPO=p^;lVK7r^w);@cj%dB; zZmM0HlbtO*pa~)cOYe|<)5fp~ChF02KuxS+t}?9G(9Jwp?RHSwux=nn%*|v%i51^QtB8^8^ zPfK^njTlwsmupE)Iog3my*FKfu;px5X>hX@Y474CxG&Hn!9SiByGpQ1=PJWZHjJ@~ z{1)pa7kjE(;5^(qreQ}8x&aFs5#NRuia$tIUWE_+Lh-@SJVWaTRc~7;?wHa(lDhh0 zE#pM0+x^9!uDqRy33IECUyfaa`pzw0;C6lG86eWWsd0_W1S{86u44))jxkL^aV-X$ zxiOP@R%WIv`Gau=VsJoyi#~1>8Gj9Xc8Td`1jM?$#)A;UR3~FA5y2usWpK9bh4{Yl zBZIYYx;>|Ioh&c&D8gK1Mt>7tXjYNldwf#GDYHIK7P*CLLnHnYhf_8xCPa&0WS zuY!xJU%w^w90XYx^ox0CB^i_B3Gqv-=!IQB=uoDlpRQbC#I_}pZi+S%xYa1>C!L7T zigBR0sS!`(9roJc&!*pX@sHbamjTTrF~aPTc<9cm9*< z`pfH|37by&NnAzXUdAR58Xogbf@VOG{e70DZvozo|1eD;ZgYU&y*L-6E8ov6C8Sr#`~ z->s_E3%vTh2bE%t3P#K<k+Mdv_0flW$1RjC zR#I5+n36%+U#kNbavguZI`ACVeO%XZE#$h0OWuFc>+D|fyLMLxUf_CwtDS2wm&Ntq zb3HE!>m+O!m)xK1IzXI*Um)Je^7vQY-AUQ*)w_=l7??Q7I%TjMoN%6d*FQYx+%NZh zQCfdBdXP*ib$?d3S6^+d^9QYlMk~OqS5F{f!?5j+#Cj%5cKx(6YF%v6NW~X*7fnQV z(yE^sj$^i5CXRTkTzzqnIE)zeuA{RIvc0EeB_1wT3)WiNEN4nc7oTO6ULen2q|=EeD+!f@zM!E99)_e znxe^@`E~pS@g+PaB`!8Pg9(R;B%3PZk8kpkwo~<(rdAa6`Ao{4Q7atmHpR;ug-yl` zNF(vTm>oiBt;i?x%u5h0vdgqo#zucN-9b77(?W zI9F^^!Y^g2{f$9Iszav2ntIl*T1&q);bl#=_zAGA>e^uxv1FcA&-6_;vY9t3+--wV zfyygmPSJYRUY4Plw(5-={o*>smP(Y;Rdu_Nqngw!vzcOKnJ!pN7GS<=_MeHr|4KC{ zrxq7qWRFSTbN!)8!PVPIbvr7F?h!G%Nn(9mTAO?`?a_!! zF)YZ0KvwkTFPgV->D=N9$kaQs>@epiyJc9RUdq0n%B9R1>XySsmXOs z8UDbpxvnSt9nxo%Xa4j{mzK}|Mk(_# z;c3h2KMy0EgDTqRWueD=+#{rc$4+Td{aR+J{9+kNN0j$H{O!zUho;H~w!>i{R)}KM zf=QQ}#d~%qg<|LRX>^*fB{kvjP+1q0RGPP!sv|jir3)%nUaIs7MGT#kejiJG!ZLd^ zrYC(o^-0S1c#1Bq^RM>T^^bg-G+?6wLbSO34Bwyl<;Baat)$J2td#Ye-B)y*Zv=0q}Tp80|yfODPSUS7jO`8 z5AYP=%RtfA-vAB)b^(V14+EuqRkqsYB}|HRVj)w7i4Mv@L==l7fG^Q=cT1LqpCMod za3S?UINxm}~K4e?JmO9!^DOMK6#eP-zf61CheT~e|Fv8S`!G(bwe<{R{7&k0Y*11(C z3agkM!)vT&_1CS{bQh%2)to`L{@QAY?DL+r6_g7-A;bD{x^`v)`H_ zBar1u;c35~sXQ+{(LGJsGrH%6C%WbZ40SW-EwblVg=94>dt4@SDg0;W6i>5P=ZwQq zQ%&cFi4h*vT1!`&=fi?HD*v^;C$6^iBAvvok!9Vq z%-jkbsyz9VxAbRM)+_S5^E)*`(p}jbr^jpQl2b&H6eVT)tm1j|O6Qc5#+yLqg_^N# zLBN%HY9SMWSRa%zk_BZvj2qDQ@Zx7$Vi%5OlZ2?C*gPSE?wXE#BZF zztq$LnNWSg<{k^JBJl+1&FxrOm&{NCHiQ=<+cNr``ITW?7%xaT+hSdN_FP%W zkc`zI4;~(-7L{INpzwz%S7L|wlN-lR!Wkth{QKBeSEW{yY<&Hpqwt5Jlw{a-DY4s+L;SiIn;?7&KHARd^c>J_Vg z-_597ktIx|((#b3xlg52oGIBzCWr6m$m zJ2;mg^HP_$S7qxYZjhcFo&afOD<#iZ{*qa*>bhvFDtXZU0{x*xMpQK^;KVE?X@*(e zFk_td2F1lf&!}jtiK4E$)7e!d%M)$8kET^!2& z0j^zKFdO1?smw(zb58g$1hIG_$95vocJ3>s4M;a<#Wqk|Rm-sk##7slwX^OlXl-g@ zH#TT`aXbL7Nt-x6Xa%b3vE<1}DSztKx`C1*y$4ERJov-NATp98A;#9)eM8c!-O|(~ zLgE;7+~;_Vcs4PNO}=S$v1}Ta%9&+BRho(B35sVXv6dQpK)lL5Lz!Zw<)TZPt@V1c zsXApN|G!5aGX9`8vc_%Fp>jfYukeh}jrI-#67-%sla zFZF4hSWt|8#@q0Tkim`Yp?}t}eyWxm%fl1XQ&`U`le5XASBWOn+dgB1!n$x`?-V&0 zx@67EgvZJaX326*-`K+Np71!^K|RwOhiOC6wAG9g&GcQ*C1GFm`Y=RVuA(*mz*)U6 z3Hzc~CUI>pX$R^5UtsQ{hj29oaK~syNX%dTrSChZL2)Wa9IE|$Fi}38V(usgI~ixm z2Mt_7cQ_Pjug4&jzYIUFqmy1580VSdsIz2-S>@Vv7FVyW>AjrH+`(1Os?qt&;A%!| zPI0Tnt1n>9&?b37LE)g{Xd&)h>@;%U8$d+l`LYhRr zGJ@2usAVe0K{}NUL8i;Ythut0d8}F$vFFyVW&3G^>OaNmpcGsk0PKQyFTqJs*{{9)Q`rdautr~NU)Lf?)Nluw1hU zOPu(!gQ49pcWS5vwrbJ7>sVIrg>GfET=ZS+Y~Sg7y-wIcE_r{l%i?{~=fpW#dYiPF z|3dnc<^4t86;bvs>iHnoQpnCV4)-5^s@GVhxRRDOX4m6U+n6O zTXka&cUG`Ed#T##g1u181~O3_CoECT*i&d{3JbtdnpKTGK^jeYgQAOKv@}QSm_y01 zq-U<35MSC79`No%qXTIz7JGnfDl^;AyuqUS8+F4QtYXJdFqx2jOeIygOX8&l7e>+y zwVEJiS5i_LSAA7+${bbYRl&{S_0tZKpz+Z-^B z;>}3(Jl%FZC*SdKZ!tQw@k-I&aphXLfa8)}YYCalm@90cI^qk0UQsNR&din>tC}RL*`<1hx7DFU$PJEITj{U5 zGKkY9>xUBEGj8kDfl`gG@YUSf>RNZiC}EL{H8UCjhbw#ZxL`Fdm@_gbl@4PVB$^rA zjh^79!o5?@CfAMYhXiW4S)xuU7UnYCF%9cp&p@wp)D&BMtNFRPdTf}n5l!hCZifBG z?U`pLzV_uF9mQxDqgQClB_*on(&d`X4&qvh=;Q|_Fe=MWRYBchDp1fH=5xse8&`EV?wClI8qo&8~vEt1q-n zReM0xb`LXNNi(x_FN!38g7q?Y`lt3moNy~ce3JtLKsnhgo>ijOVj+a6nxG(y`RvEQ zH6t{u)>PYVMOhXP;2Z3D;WCU70zo)oR_*k4RcKL~9<)r4HWgaAZ;Y8xlTZD1->{Gx zJIO@9mN!b%WKO1*<7$^THdIzs)v}?vj@4phZh$u|O`{!}Aj~U`bx}9q9B* zuDE6Z?}k+v=b!Kq)_xMW+Bchhw%RgD2f{I_pRKn&-Fz`kqT+l3|KNUb>&MeqF}?SX z@$(WgxX5rXcEEm)a#40bzjBG{&?{ecV9VH`e}(cx zP_voQU&|7;hF;RrQs3+h-cJWrz3#{G))P9SlvGPR_3n#HBg(2+;& z@TM?T>sWdjOYt^+Q%=1>4d9rUrR6welq@YNURdlNh9mVq5luB!U22*q7^){d`>l7j zt~VRmvJq>snj2nVe_CUOY`@146>~&WT1cO$x*rF%Ad72E?A2hL)FM8PW}iv5$N+a0 z4DvxSd{p`=n^RHPS8wLc*lomhk(D&nZ+oWKqEOSF9TH92IHpiw2opU)pJ1leI@CDS z>u@w8eF6H77y6y`l0Wdti`Y|u?sYBCvrL%0lgq!H&Xy&;gTG2;$r`UIuWbV{d#@}G z_Nk<$oR=+a74?dXKKHj{i~WzQ;@8j2^Y4Iv;9^sv%=y@`CqJg&o})=7`0$lF<6Ttv!JKyyOHoZss_dh>=?|e!qBY<3$1CK;F^c`ViZ-!Yb)#{P3tnB@C zCm1Ym7Efo7j)wAhwtmqRSb;g zcDWe}NM^*mj>7oNv#gxOQh}p)(E7*5>Haps==?mcv6#%iz}^|~c*WD<0mpe?b^yc5VvLD-@rpp?r-yKN zEw5)sGosb%*(c+n|A)QzfRCbh#+&Ni&yF6utCbmJ|pO zauFgRprWE8q9CAxAR?jyqK2Y^fS`bYq6S2yDIgs}@_wJ$z02L@Liox5|N4GDzLR|K zd3M^)&dkot&OGysIwX+dDJ{R7h@-!&D(Y(!0Lv17@EJ#^Na3qb)6+&Bt2Vc)_EAE? zleQqI`N2LvcM-3rtJ$wewb*fH(SU1{PeK^fy(x9>_8CRl2jj@WlKI)@ZQqU~u=o>O z!-XGO;^_ySag>Ghe%cH{%mrD)Q&UFO3B7x6oF)ctt{SLklt%3Z_(cViL{4(2-3vZGy=!3~O{S7He9bcVIohvGqV$<6D3N=$IOldNbII z^)`yzVuN9NTw+b@>NnXg2CdV#i9_2Krj@59YQ(B@q2?toCmUz7`HOmBb?fST*n4A+ zs<@>H@ea{;R5V=$g?NWER8asto!ZXTd^u?BsP;eBZJO0M1uY<{tJ2CeEe{*HRR1*L zW~EpP`t7qIAuWckVvbLJR^eUrmk?i}xn3j9lNk{Z^0L(Zx`;8Wm^?$Dmz7VSA$Wpx zst&ZRM*VKk#4Dl@mKr&s04h$Lj^mCar?Y!w+h1Wi2Bmkpyqj>rRZ zVj=Y^J|HdiLaoXU{1sR>1Jv!e`p(+2{g@ydgU<2YDaCCzb5vChJiLTU|HN88sDRk<$^eowyOitsbZGum>4x7D;?FD zCaEmb8Px*`k$labguc?L?ZXQ)IwV+UULvJ5x?>6zlQ*I+g{d-Ow602Xt>y$`az}lg zsa;bw9*Zwx%QhuZv$cf=95j@jA$nU?9zlD3Eh!Z38OoayL-E0Z_9$Z?s+$g@6YNum zc!3+;4=y-T2zx281|k&2$J0~;^f_SOIzik5HCI#~b6o1ozQ`mu%pZx3Cg!CJ-NV&8 z9`JQfy^nayMANG#B|=p&L3+oa+@QMg)RL)|sFo=( z1!XcYi_r`wWGs3mE0HeA3eEsj&i77M%7D2*EZ_lvuRDE9E$SW+ip3=WO(i?*>IX$T69w6O{C4>Jag zGz8jM`i1(9vatw@vA2mB5#s2!VSWy5!-4`s{0umMAjpBEAq2a99EGAC$qxJnh75z! zY1{OYU2w=~n#RM55gMtEv+qmO8!Vu8k#?CJ$FeHKwLNodW4;XCg6d7&% zeAa$R(#g7pL`4`dcWvxHxWA{3Lnu;d?J+PS)PIc8FTmE9s;t+>W0)aa+|S0+FFZPE zv|2(zHVy$1;n7hMp+@WgF^+sBG}7*-D6FU;zfhYXRDuqQ!78GFD7&W&N5voMKe}cp z+}aP5hf#rkwl`LDe1Oe;qp+W7R8VNBgNkNxqO?W(g^sWZI6BDRu6m%p_ID5sti6l@ z_OD%-fvUGnjA4;M!)z>~qA^~#E-t)5HrEs))Nf2slx;+zF#$o?%~sD4$$BB-Kuu*w0)7x4mC=`%3-L(ne{YnWG5V3gw!Xs*HPVlA8|r5hIBaBy zF>It=$^wI_7TIPN*@@FwY=TFGhlY%_tu+S!0K58YZf*t`4UvH%!8Q>*I%af`qqi_} zct~hSq``<*#NXd01f6GNS0$o`2SrCjnHwcWeVf*4svVe>h3Mj}ujv#VoA^hDjEt!H z5(!%a8nAF1&srN%(|-V(x@csL_Bz!|d}R0`H!|Hfvy2v)P4Zjb;vZ zs0KDSfmK9gl#NyBa0k6Dw8}(<7;N)P)OmFv5f)zh<_+#eC>@BEIuez_ttF&t&i&;Kxv=PpP;n2 zt_qa)*0q01-CNfav^B1WfVKe*18obM0NM_;1hhTqtDqe~*MQywx(&1==pj(r2Y3~< zGiZnDd5R9S4`?^g0MG|PM}u|;Ed=cWItR2T=sTdjK-Yuz2Hgkh0(usdgcB=3A?Cu` z&QSH}_5>Y(Yj056d}9C|1Ue3MFz9s9A)pIEsnTu$9SZtAs5j_oP!fKu1Qq&fXR7*Y zhk*LRJ_Hm3k}MX~A9OruByw0c_A z@7f&{V%tmtO#+PuO$N;XO#v+eO#__|N)yx@K*xc82bv3d8Z-~I{w!5bYgf<$Tn_>r z4;l_S0W=M?5OgZ&M9|kjOF-9wJ_-5_=v2^SpwmDvgO-9enw=-~u66~Tj%yFlr$K{3 zp9dWS`T}SM=qsQzK<9%l0(}*911NKXK4MTO&_6)yfnEcx588MR>KABd(6*rcK)Ztm zgJOFbGlJFwEds3%x)@Xkx`o_Pk$)tLihL2Y1Qod1Gq^^@?FQ-uIuNuTXb5P1(8ocY zK^0KehOucxQIY2pMMYjkREIsMppnSva!?OsbOmT-75271OZtPOusJj|IEaPjv8X&2 zn!utGSU?^#WHLi8i%wwC$(aCAT;_tu?zre&DlbO{kHh9ZufCTrfZ}o3JkVyKFN4zF z)&-z6@$x!obI`@0EkKuo(jM5iL0f{Z0Br@j3KWmY-Ur2FvbCV?KtBd;3%U`M-rvtb z>Al?oipOVPfl~X>tWi*F^X=<9PrYpKoS^8`z9&RijTg6D9mXIVDTgWh(lQnP>9O(VV zK6`buerjBvx|_CFuj-Ann$!h0VF-CTZ6`luB?~E!*SIAsg!BDu@x|a|gmLDgn8o0&VZt@R z>|Ps9ho2Z=65~7~n|_j$ArOl1tvFaYsMcrkPEM@ksOp^s9`?^~|4 zH73%ZYp|%#MJ0evo@9m;yYGMk+7MEQ>E4Vmr zMTjGc34Vy?C(;RH!qAiy%`9och1Hfis6k2~7a`|J*+Om>?<9OmdVg@9qjo>UVQUFN zZY&FhMMejil?kb#FmpVqbsDD;xwAYwMZn?NU_C*ido!CNFV3XLCrWg zLOsGZNi2gPA>@hDgSVZO`-md6S&Xq9p-P9gTBgn|jOF%t+i5$pw&Z7#pV0CQ)fmeY zmT7(~J-yWqVqp_j6vv!1DI%HW#V9$?ARtS4z zY*CKu^MKjCHp)gOE3E+?FbJs4Uv2i0{~(NYTqQ{3|LL)s{n*SUBRhO@`_;paPAc`o zs|sDGECOqT_r@MsXs&GZ$30Yyh~(6^>CpCxtu;uhwlvB{ro}^U zCI_CyzI1ackmLzT*sW7kk&L`LR>E06Phuw>_!X2A|q%e5;+fb2x=dz z>n_GDVmH4UPAqn5VzOEg^IRi^gsm?3ixV=8gtpdQC)AA#54g1G zRm78uK3C_$M6NOnTe4Fkak>!G(MXNrs?HY?ml(C-mRektX!Kl`L{eL!J(aru8_R!C zS+9v|kPs$v!Rk~i>hF-Ds+_ADf?~!EG)p68L!R!jo{5iZH=$e5R+~UtU$1V*1GUZm zHa4Pd7VCKE-z>t=7Ex$xg^&=Jq9ZTzNq$i6l*K7a*e9wcu6uvV50cWr-tDw}7gwzE zlj1Gvat*;j#+dMsu*lG$Fie&QAuXz*PaVCgyQtE?rx1~$N3%8%Ud7=T_`%x=brz7P z1n-GmMr=${9_T{Iq%<$SH=? zO{ImQj%8p{ePc0}XZWTg>08le!D~$sTzd~R{ughsB?#G6S15{vY@*{x3AH*nwoU{+ zKWeK;P|dtBpW33;XL>$yGc6t(jAA}7fs{&;f<+A1tDl;hr0RH^A}qG!)BdWy)ra6& z9sOt>RGg85=pe_4(V_MYKo2P5RK+6j4p^j)|H;Un-cL%>?MLn86~wzN_PYQIG!Du_;8l ztkm_RFH;qzQV(R=Je(CrpZ7vERTT%bDe>wpvuyEV%+mmoc9@In63xx*#}QTFCl>g> zJ!Ygf-rAsFs;P5vq<@q#C>&x7A>qS}SQ82ji5^3;RXvkMU8a4u1&TPK*?f4t_^`x> zEJ znwlcC+uC>*qJh|SAwIIr{vmPuwK}Rm0!UY!y z0I`xpd?2wT{3!6i;-PagS9PKA;ME{3K3B0RQjs6S%xO^)v{b|ups_^|=>5ZdzNNIq zg&z9*SsxL*2T`jkqvdXd79X~CV~&&#BS*A`2#Utdqi`UpZNU|y_b40?92~%)Ov*MA zEqtz$gn&u3*;|AiNYA2PBJf}am9_bnw22E?4`Ch@byxy<#xM8*tWTlJ4IxW$A+lM0 z9)uxl^OL#_(Qb*5gR0rV)i<{Z+rPhcV2|nm13iY?hH)bsk)i!9sivFuhq@U^GO32X zTff%YD9sA1z4X_RwZvaT?Mk>^s%pzznJ*MIeZ>--;+^B26P&)nl`m}DvP)I$nlqch z4zM;(0Zs)@EAUqUu8q?H*rE-+hDaz*=6kDraQR^0Tlp-@Da$FJ;;sh|Hl~k40 z*R?4dUN#)R^-B=%48&Q0zcx-Y)ObXCZu6r)1N}PV85(1;p}F?g6ju$!eawC=(Udur zIkEcX&a8p1fp4Rd=8N0J-V=K->t5EE4bef0h>gPU5L|VSy*Kur#cfKO`!>=wU=0wW zz6g8m^Qx}cc({UgYkDSTA-7#c@Hkh@X^+(9KKUo zSN1uca_Ji>%HD-3iU&Y^!D5y70BsHEEGc!&(57&xDj{9G$>OvsP3RiEXMt{f9u$KX z=xBU!2mYud!MGj=6<`5E93;|B$eUB}+ZyUasXr7zSvEFfs%l4lDY+3P181fK5|xxB zCp0Vd(5lpD&kGw3eB|j68Kf&rg84Og-1EtYV$kydWzx;lwV6xN`TfC)hN4K&0E{wj$eFJ4dZ{~e-C@RcyH(Ctlg^& z&%u!XHCh_-we*)=sZPsWE1p^L$1YdFY4Q2UHspTW6Y% z%R09~A*}Tbpf}>7nQg1tA(}nZna}lg;3DRZv<-#Y#zb=*Ho63bnky0nFsM7IZ2dxE zL57%q!o5Ty)cH}U!E&Ru4DmzHXT5?S6CJ>8CLyh^a0X$p^<|9JMHKc(RELZ7v-W5h zIoisNbj4a-LcfL8RY+8TUzpYPsKEoRuCU?5?sAZoE7S;DU5yU0x`1kUt1CmG!RpFy zWR%qv37cA{))44vk?x$+6V$=5^P z6>tT-ff2xCKnC1yhfMgH49o)FxC8(8aeaU=TmC^fb38vF>`CCpKa8XKhCJndzyt6H z%<}p{*pJ3@G_OhHJGwTH_h|0K-p%^j_S_F9=1Z7GA1d2};LI=) zih;6ps>}*a3DL_+dKN+5jpEXsPCZHr6ne$`!N$gr8eEL=ELy>ZUR+pcDq~RJ%r=_J z11pcS z0};_7nRv$(xVmSn-><<@+U&ndL{qNh=xU2IxVr`pV} zXjTFkKJqE$Dz83;;I)SrJoRnZK~CA+&oC^+mBnE_i221p?@&Q@KRUn@Rs{^51$+rb zxg*o^=nP$ms$g0*Ar;Q!a~XOBEfxs=U`xO1l~!Yay^dIcXD6Nco zN1e;CaQo9F;_@@&;&nJo!j)kyK=>PE=dVAVI-&Z*kqEA|P>aXNh)dHE=b3?!N&-Wd zrgNd6fSl}nd_yIPP3(x%mF1+wF?9Mmm!NFgs6S2@>4*Iau1vu*qhHp!MB)QPj73J~ zU}jPiB82;Rh-&(c(z&Qpvu>0jt}GXID=HWj&P7PN4IT)qWEu$sdXgR}p-BwW#HjYU zx)78Vw9wLf6lj2AiP{uCk}rr*BPsq#IO`%aX<|Py*ytDF7ZnP}WQLK5&c&iqEi^73 zDH)%Wz%T~U?kZ-oF@H;g1f2Zp$|fLDB;AJFYBe8rapP4xp&;L&ka`DKvI!b(;}63H zWQ)+JWWZE+Ql4%A0*_B(qeFBq!C1)`O9psClv^Rm=+|!Qu?C+(&KjUr>RwP+!MA07 zL5B;z6AJ}R6?{jQ3HprSTeBBH-x7R7wgPmk;G47Upl1Z%f}OYU-B`QNv4;YnFI-p9 zK*2X)!$HRiz9owVEfTylD*=5$@DH+=LEjSmJ?vf3ErM^uwu7D&d{cH7w80k?e`D4d zw5#BoF&(In;GGx;jSzezX0Y(>SdxYB%qD=JBmA^tb3vB^cCWcr8|ljI-L&RGsGJu+17dz<%ue2RRL|%Xj_LdHCf%%*9fOJpq56z7I!Fk5u2iF zI9p|zR-tLa>TH=>e`#W_@n-DJ0qFdnhd`-b*F(Jy22b_6HF%@OD>w~oB6zCT^}s)G z;XAVB;Hi#xLvOtf{D+%puZ)iE1W$Fg9(wYV;He%p1YduP%C`lt)A)AaeKo!Tc%#N! zzl&y(8hm4kQxTwF!_t|PBn}h?C8p{~g#^x+RM(gC#3klf5Y|26wvsq%45Smarw}WG z2n(HNq>4&u$uR3z7vqaP+Sy|P>e!=Xn0nq=37tdc!BidWs$7p2x~j7B)~$+)n>TOV zxPJZGwX0XJT)BMt(xrk)?q%V!>p;pynmNw^Zy#6nnh5xd7 z?O!$v{$(Silm5k@`Tw$c)53yDE=Vo~^8?Y+lv1s&AFPDzs{BRc2LD)y%57Rr9MBS1qqv zQ?zkfv!Z_B26`BnWaNGO7m2jnps)_82|Ix!25m<379f+J=@ z60_imSrEl6cw!brG0*Rs=UL73-R5~`^ZcKA9?m=;YMz%guMe5mY0T?o=5;Ic+JSi< z-@Kk;Ue~Z6U)hg0?8o2s<5Bze+5T;{@4xN)GyC}+`}q$0`9J&lF#GRA`|liKB_}LVqG2b8K2Z4pYd@W@(~}@As?}(4*84^>yXb_TZeqiXLZQOY^p;(=ZiYz zb3U&_K4wE5@-ge{kk9$F4*8soce%d*)?KdeFS|?mhIj5#zTxe=T;G55F4y-L-=%!R z(z}#zSaO&0J@4J6e9x-8ly7?fF6En6-=%!dio2BWS$>!DO)KwGzUkd}Ym5kNElN(8 zoGCe3a;oI7l5-_zOa3f5R`Od(dCAd|6D5C?954CZ_j1`~-%Dkee6N;W^}SMd#rHzl z1>f^!=Y21hUG)9C>~ClRU(J@Vx7kMaIa|v{oV}{lvb+-v7;PE8C6zH9OeO<(2CzXI9RyJXv|Ia(m^WN|#En%EpzQDpM;9D~DH( zu3U~$-%N}EPhzyU9V0)NDzB=>Rh_C*s|u@zSBTbr~Tzswk zn(kWcwZ+%Vuj{VIUXQ$`+-iNxM>qC~05P zvE-hTHYKe~+Lg2|xv!*a$pa<#mvk=aRB~@gm$Ih5P0O13HY;oF+qkTWZMTs5(?p;V2`q3=Fh^}!)!duWyR2gnGB_v*-&rx5EK>kV{WWF>&AMs zp3H|0g(gjj4PgD*5H@JE({QIkr&Om-PK}+soLrm^Ic;~khTZ$~on|_%cUtZ=8l%2K zi~u`fwC9D9-yyagN)1l3`D`Xz&z7@T=nW`uu((02v(CBPd9ibBBVD8NMvEK8HqO(n_+@EKzK?8a(h$6INHc)cDkdQT)~Wz_j#KRt3Y7(nR~j zw6vEDKzhOe(%c2|`JKyqExf2Qhyg3bX1a+Af8d_s{~wSGOE7K^*ny>0!f zIy0ekAXkL4QZlWEu#LZV-%!ko)a2#kP+(nl61KfT=So6qQbLAKjaMi=5b3pSSz85IO>#fv&&Z2L1wc^%xroya4P6x?*!lsqF(e2j))S8%O>ey@%$lF^;Pt=_9dv8F0F2 z0UgE&L-E&DH>=+>QTw6C5l4K}d5%_5%Gf+YF;@G<`^s8DN$rKOjtf1h@p4_edYh~-O@1ff{ zDmO>%q9cEf%2#dY#L2tRKuenE5_KtgSw=J{XjGth7mAovMK;*%3%w9l{%If9?Y!Q( zU-v=(Q=O?kvq0#sQ`Nvb);TQVwa!z@m%8dD<#Tm^r}l5Q`6+gbk;-25M@ghvFi*`L z$K~TF-)-YlRo*x%$KgGM2c;S^X zd{STNfX>e8i@kP*>NYp6V-W3#NQbI$H7=793dMtQ*r{ z6nj%vt&NZMclU7j^un%lx1O{I9qk5ju3+g3IySWgl46SJF_A&IF=97Tf|Bq{$)o3J zq1F&$g~4^tf`rs;bNp6!WPTF1HuepcdKUB@C1HbHn1sVtqVa?sRPsx6K-eXXgfFFPCA7eY8|001^Rl8ViZX{9vp8eG4T#<;TMGobrR4qVdK}% zw$>!n**~E@YYlh+k$?is1nH{Mg+yCki6aG1fJI-m98`p{Jwz+Y#eb zEfSH=wCv;@j8dVpS7f9*4n-8Gib$`TZ2@uW>EpyFB^ z{+a!$nP3#7bh90e6||3TOMIkOnJ&*NKpw?_~t-2dV#9=T_lf=L_s-5%KQ z-c3^o3J?dp3gqA^gkomD>}=GELgtrU7>GkXm`SJ!!(nm>{aJEoTmU21gVAG%=)f?c z;Fy_JKWj>B92PJ0tDmnBsE_Q6{yqdef%;81Tt5PS6oBrXx#RkA@bLh3`~7g83Vs|w z;XQC&0G>ep`{Q~t_-O#e=ZR~3)4F9obR}R+&?29P9&9-%UF$&U9;~?<*0-s8kJ!fQ zHEX1~H&pF&67u6xa!5OZOK36P_|>`*B`21%nqRHjYVp3 z6&z&a7iwZu4>s{4NG1iyrSu17#gS%?z@+53g3Nr88uQa=ky^r9(xRT47Z?q7G7h3g zu+V%&4`n+retrQutNf(MY?5qF3bK`wb6eAx2-ULI;1g&rgfCn&ox2(f)2JfZoS=y~Y*DN0dj zHcuWv8I=r;JHn5MsrK9vS<{G3VWFt2v8bnw*c|m41ph4afc-kbKPT)Dfu}l8^&i7) z%b1nkEt>Z;+mj!617|#Vv&MOD)O=+o5=b$$yeqG zeiCaBevRNKvkJ5u`vqUbj)T7@_}Oe1_^v=h_6%DG>I>9X2Il-X=R5hMym#c^Twdg6 zU6y8hYdi8|ZEwCd-vc*`v4vRr<+caBH>!X#ehwXbH%EZdCW}#X+Iw(ym*P7+% z$^u6Q>IPftNp&Nry7b2zWZTwIkx`ibUS=1&T7!(RGYxQhQQv0yN+8Oz0V`mgz^4j+ zJaY#Bl;9_@^XMOz2)>XV0beHg8EiZFp9TLkTL=EC;AgSL;M)N9W$LILsEp12$lY8n zj>?_<*_XLFtfO$`*KF^|UtCsv8Yw+X(4p)`q3}od)s5+^d(;)-#uZ>}f$k2A4b*sR z)VgYD^VPbXtli1p`r7Ot(-C40h}KcM03xdf;M=u254HRw%j*0y=UsKZ z*Xlb|yjk*%3eL)q-tK&ib++Nz>SO6O75rhrPh(@j|0VdRSR{BS!1`IuJUxT;Gn(zm z4%#1clXBGiLlK>NMf&iRRGglMX*fz4(nLDM%MgEwxJR}2Vx~Qb)-)jU&5l`kt#H!_$o4g zTB9?y*m>&`;_x+{mOl~mhq?(lxruqih|}+gK`Qcad}N}x#SPz>_%?tWM*gb8XLm6D z3)GJe9i9sX0x#;9o$WnUyV~xlMvITh{J2b`{Y|QG!AdCa#1B;gXEEF+PSo<&)eKl2 zU6EV^tpFNJ-3v-nkXT}5ZNLuz=->xh zFC7Zr1=J0+H}D|%1khyAOdt(>A?Os)2|zCRNFWBh5qK2*2+(lQK)?_DR^Th}yMP_w z4}ty+dJy;?{CVIq_$uHA_%on?fgT5rf?o{!7U=uHyWl?s{Ty^1@B#Q2ftSHA1YQL{ z6Z9F-8NgKV)1G8(x)Wn_fTzLJI_~SBuK+KAUjuvu{tI9u_?4imL6-qp#w4%!QpzFl3xdx1)zLjd~TYz=e({{YYhd^6CNp!9M$fv-OeYq=PVH3yo2 z?*w`uXh)zecn@F@cn)}je+bkav)=m<{t5aAa18uX(6>QX0V}|-2mK86 z6JRa)xxh={7Xb^v&jx)Kv=n#}db377;v12h{n5r_k?1MLag59kBl2UG?f2=oWv4!8$=SD-U^I$NU!Xd|E= z_$wFEl#YL=DcL|dV7i#5JaGvW*bf9>PE&pb&JDd$>F<7motu=5jygLbiB7PhDIT40(Rq6GAL7y911lhCXE5Cp5Eq)P15d3vf!3-B)Lx-T zX(@*F07?KI;H!cBk}A(|w0UAG09A-WiJYEk0`nn=_=B&DteMeZ3ovsd$Uz+!! zxGRx!EkVukB07pvfYMF&6epz<#bR-z=OMHL9sr>F7YF5qM1%(g8l!OhT@4FlX5>Bj zN*qA(Q&@@{%Tj`Zi1_I~zCb`kxFOmP$Lfs?it_i14hdtyA)|u=S!iScTZ}kX0BeEu zKuCCCP$ZP)(j?e+5V2$ph&CLgp74iGu)<_6X>P4+^3X?MPa0oe##?mnK!C)*hd>DicGAFt+;a4na3pbo4hw+)tMSPDy;jDTUk0l;g z7Mc{7oSBp_j{d`OchEMfb4hYfao0hMbW$c33Ls{OHG+UZ8YaVYq7J9*rsd`L!)i8W z%9CiSt6aJTHlf&{E+Fn>r#^oxMc9)f#o=9LVL9W|lKPEDs&jAx z7!+@3)2IRE^w1z#O``gMIKDb1hvto0WI=o; zeBvPu`9c@C#f8eu-mFJil>x_rOF+F&`ARFGE1(CAfC5Yco(5h3-T^iOJAq$->p<(y z`O1BOClCQQW9xb!cS%`zYytMTc#N;p)=F_P01*1b=CS>SbP+iru;UsaY zJNEal@eFk0xEdDc;>DxBqMg;@a8*A)3T}PhxQXJd93f^AXB)<&#(iv}G(Tm3x1mFI zSY*R3C~o_-iM*lo--U6 zdgp0pda9nZEHyvBhj{oJ&#m4~4e`IGy1HIi$D-ahPpz?O*?1%4@O_FpCHl{>kgy>2 zxO%*S^lppvp*5pr9MP8P6xge(i~5DHW_&4o6nc8#aJ(Tj{mZPrb!lbF z5*vz5J>WPdI@rw%WBiD8)&hCJ zKwwE}x>5{03JeC?0)I_QSH1z>2Brc}0N%hoz~58Tm2ZJ}f$2azAOl^1D^I2?y_Tgb ze=JQ`mIG-(AK=WAbY&Hg1-Jv}-b`240OJ5p;Ns$RWgSoe3|nc69IZ(@Rh;M zAVcv5F7MA!-UW<6dtk@D45b(t0G#|jLwOyD0vZ8Ze?lC98*uE$ z4CNId6mSAQKAfRs06O5np$ugfz=2B#Gn5s;6F@s)`wtn)6u=YsJ}^`H0C)yS1A>5V zz^#Bx`%Kquf*aHg^sSOv@k5&>VJD{w6+Q`rx! z0paZqe1ML?#RZwl9$+Of14sZka4&H6)l6j{@IEjbNC5(X2Y{na zS;`V10q6nzj>9V622ubQ;8azn@-C18^acK`%v4qbIe-Un;Z~-y7RUnz0*4~9lox?; zpb4-oJWDYF-oWLsEM*Ol0rUcnhGr=Xfl)wPVE2eDWhM{+R6d-gYyjT-I7^uWqym9} z4ygDjOF0Cr1Lgvmz;K`kz<`|_vXpm#X@C*%0XhN~*JmkvfR(@uAOYaOy};E^vXp(m z`@n1<1qc8h0MvKX@h^SK7>!{;(SA6$+7F{+F{s5+R8fA>IH?L_@8}qVF=7OTzB9ie zp`k&;{6ZlU6B!eIhhc)EqHwba4BqL)?%)uNkMH>ZhVdM3mEQ)bDOPdyxp_exZBq9+sEaocHb^;`x;%B-|AX?`*hgW z-rM`NuC=$jzjaN$oj>c^c{_i$HS+dpw5^G^_gh;Hyj@!CYu)Yrj`Rz~^g;mYxW8Y( z2m>nT?fi@URWl_l#DLSA0*2q#|EQ=4w2W#1x`$T#Sq18I*Pi*xaG(%a2J8hYfF8Z_ zl~5obSPbj}SZ};9z*t}o5ZE(YNdo2qp8_X<4!yFK0l@ho*-9I)Y()>G05gHNfo%ZR zaUeg{Qyf<&=mfk}Fkg(xR=xsu1N(uWfMdWZ;5={@s0123nyoYk+_RGM<47pWh{*UC^3E9fh#B9Z&(NxfHfFFSdN!iM)so6>&&~1P|Ia{d$OexvQ*mM;;;eG|^mX@td z1@;1d1=-3IKq~MYumac${0uOiIu`|TGAc%kq4{ZSXA<*Zs+bqn99&iTCiC2w#k0mx zKB@IUof$HkMMe!leo+C#>C{E59>rW|?EH$#V&CuB`LT*movSj82@kkke8QLGv|$d- z7!geS5iplkOB^@~%-kB+@_d#q%%QuVe?(L?Ch}k$y4Uu?*5*G3LkCPe;w5}kja4mx zM3m25U>#5nus(P%fIuJ-CKq4?7*bg-BTT6b5daQM@ls_Ti zI9Ruq{IT|XC-u?Vzo=VSt3WzRfpxW|M|57*9lpanu=Zm!PO9<#p}uQzS=9rog(q?U z=5G1QK)~TWqJu(1&0#UruG7!$(qSE!T{;xpe;%-@wseFBg%67!Zk3W+%Es28mYO^A zYm=gDNQcfHeH7sEnbq#DMun-{uUY|SBHnei#jU;rTHK)#2E6FhU^ulxAFSC^k0P)#hWh-w2yMdlNa9`js?1{etI&C|~3PAjC*-8d5#SRN`O;}b3PQd+v z;P#J)efgX!rac?M=8Lzc1%)h zAqJ>N1{$@hgEOSnohtMtZ&Sz34tD*gLqE0k`Q|vVMi&x1#xle)Hw+Hr()^m=3G^#Q zznH*~2qVoy)RM-4&=9QcX~PbOu_C;BSBI|jD$)dlmN18YZqu)7MP@^O>W_6Dpp$35 z;sqoE^MQ@PA)o?qcpvNj*uKp-=clzFv)%2|ZtdTyrLA==Vvf@~TwP<4+lA4VPcd}F zw{m!RP^iIiU2}9l|Bz^dF%pZf>bfdra-I2RPOG*QizzFsc_XcVzFm6#F&%+U8zaU$ zzgL*wXd@P%jS*3z2e{)jJ`x&$=!gg-J{2)mps$AN zMAVrEnov-)Lriwn>EE2M)t?-7=T9x;!^8ntvj)}!=YbvrF;@dD1oi`s2ca(mN`P&^ zCBS8HE$@u=7_YYRqq)4T{oZc;=*Yh|esq{m*6~`sV^o&&k?w84C7|n&TAsmXOk+K- zYFA%v{6W^wYVvC=;x4T%e(UjSZS9J+pWC%3*8c3CbrbGi4m9?v9*o^MxCNr9ph(}Kfk%oK=Vjk6Jgxh6X4h-82}zj=sZ^I5Jes4p0%5>7;3Z%K z@H5cmu^dGP;(_VFyTG@=-$1{yIm%+7<>NU@3&gWPD6l-N$wieD<;#>QeD|(h((YZM za_N#BtO@2Qk-!(gyKm(vOWw{=ep!*DOk0zqtg*rzE1v9Mvb%o6?)n{E<9@z$PoVsf z^}i7HZF=xG-pMU6`ewJzd;iP~Ego@C#6wa|kkwpzNzlsuhqQQylK-;OqQ#p3@-J{*zEt^{ zu63)29VHs;^Q*X@?-LtE{^@4ivw`f(!{Q@_zxTt1JNq;6AYCu+ShSg_FWdQ)cAqA` z$YW{1fIOa+H$EXZ-#rnP!)Tn4k_36{wCuRt6d{a(K<4#RurTG8@OWI`i_U}i6Vozz zhjUwHIMO{J@Ycgl@l|H+5DEg8-iw~6MxT0OztpG)S-OIdt1@?_DB3EY4E zB);wMB0eIem~RU*@e3PG{P3S9zT}pPU#l|lYr$Q zO5exup!D$gQPQm6o|YQTSt&iZV6T*U?wYi0U|Ts+ah3f#_{#y!#>)M?CdglY@w7ZP zZoWK2c}I3W^0B<>`LEKk7>vIxZKO1{`Nusc0eEA z-_)NMPxRuiKE(Oh=YqIt(Fp$5s7H9}x{-X$hmY~bhFD(lLL&blFO|=_lEJ^aFNbHH z9mnP5e7@kh@jNxFkk@Z8iFX-0nZH_C#Gi|u!rOEy=Dk-I^EI7K{NW4}4}8nSOLv+0 z|AzyX$%4 z82x(FY`ss%)%tU}`}MJND)nye_ei;ax=XK_LZlr%H=%JTDE~vqb7;S|`2N z@N21c{ErfU<}c~eW+!>W;^uNmc}Mx<;_mX>h5h9Goj&q|`NQRBa$@9+jq$SK5k+3- zQ7mWonJ!n1eMWAwdY(M%-i31F(xtKzuu`6IeXTrr>qhzUH@3(x&iqCmZ~9(dQ1YYv z?9<2O!>^o{>#g`(p1tvgd^6FBC!{yvewj`9n6wr=Kei2jBC-SjV@PNIM~C~k_bDC! za!n7OpW(vgPJMazkNfe50tfJ{&4YPUH*fASUE*DK`SLcE0X*a0Vf@+d5A(k|gz;8? zNAS{5qWHO_7+(L@DE?&8qg;P{EblPT$SX7A_?6iSyyd(k9$%WmyFH%9pSnMTAK0GB zQ^scV*AD0Ka^G=$)eE_N+MYaq;c7mg-F!Sh*J1+STrq*KI$X#T-kQi?i=D(P|hogQdgq~t-;Gw=ILb21~P%?qE9p5j@OYjlxRarP;x%gJY?7Wcj^Wk2-0crM_U!?&#r=)u8FG^_xDy4MAS^nYICi2RZR`RQj zI>=#PbdmF))yW^__mbC->nlI_l&AdCYA<>1pR(M+KS&+9 z>+z^GXRgm^$UQO}^M;vC`77zo`KFYXJUpQ_@BMgN-Yup*?=a#X{)^m+kMiik$3D=N zf8FeUUU2yV?ti2kZ(i1&uUXuaH!tqZD@VEVRQHE?Zznf?-(GkA&}$xiK)fgK*mEG? z^xGir{KgRegJCG|*uaOs_ko_5jFEX^1?R;J{CLrT0RH&bfxP+1U_Rm3VSH9X2p@dx zVV?R}C~vbTjCYqJ`15Z?^3cXnd_bfBa<(U)AX`J}Y!A zA2;c7{`it7c=$FW4=9i2-dE!I;D!m@t92p|XrIK#woT?wHBI4PRiyBqr&9UyJ!yQ* znsn|vJA)_3X7WS*viPFwS$xN5**vZ&hmRkm@Q$Yx{>Uri_#oe0zW=veE=|qj)9%gZ z>)+4kf5`>hYexZJ89tsrx(66BftPKWz?Tdv$7jpZ?Cw48`WSEB&Dq|uhgN$(IPZXW{f^A%yQq#nep5Vr zI=no>r}68lKBu-%^J(ur&*#TC-|}hA*89wi-s#hN(XT$^f4$_hWmW@yiLQ6`bwq_`+9U2PXEP5e7l`ul5S3#)cA%X zJziQUm3AnRu3woZO+7I~YIl6LwCLP(QkN$4qzNALr4>mFrKQUkOQWwZlQxc8A#L3H zo)jvrm5kdymQIZRRQm457gF1Iw@LGpcStcF-%4JM_DLRR4odxw9FZRU@u+m|_zCIF ziZfEPZWpBPQCFnH&)t+-WHC9dQ+@gBjt27TCmYL8@n-V4`Yq+u-L2)=*W1YvdH2YD zB09?_J-W(8ogR>XZt$R7b*+bd@Ir6-(er)eDVN;j0hJzdZi|7k+k->o(Ry$BAu4hHTosSZ?;g z68V9bm&qR#y)AD{TrT$ue^+iYbd@akTrGdqc8&b9(^~nR3m?jV9s5X5Jn)HJxqXBD z;b))9lRo@Re)!!l99Qd$)9AmX+O)#Q@_d`XC9S1&;Cu$eD-&_!3%%LKfQEHKK|+% zxx*WO%E?R4$vfY^Ap5MmD8KjqWx2z;t8&Kr>+-TqH|3AYZpklitCH_O&iJ0+o%rZK z>hX_H*5}7gIrD?38}Jv-G~~_CHsbzg8*{g_P53uwn(}sMnsMjT&G{=QTk!2CTJqcS5$y_bKy zpesK+_dZ@Q{eB)c`2n7tqvJoscjLt|5Awue-T73n9(=z`Pd=(sFW#V0Z~oJz-u%E( z7k+NHEAO$P4pb0NAC0FTh|TXy~>!SwqBmIW(-qer|pMFOLu8(;o`rzx*A zMDvt3F}%yh7(Oy?B=6d26i-_@ip$}n`TTREdEs+o_|I;S@~^&mlzS#W#=Ehx{KffW z`SgB|^PAfq=YNlWf~TE%g2xvb`A^Ma`GHqsd1S9R9{NEX-{Bq4zupqhgF_Pdux}Ii zH;*Lpz55dR=;$P#xG#xcicIEBb|>?t!&3OxvJ{@-mC6^aPUTVE)A)-or}5av>3n@* zI)D9-bly59gSXq9!QXx;lkc3D$xACT`FHVIeBIYs+~c8a9{5Z)zw~D|_YKS8eOBi1 zj~XfbXuQHd*rf1Y9mes1%yGQwmT`RYJ-Pg~v|OJ4X)ZtAERR3%SRQY(B9E`S4C{=dVf6s=CAR5N8btj&9n(T`mG84 z_^%UqOy@$r{E*Q_MZA~O6h7v@DSU_56kcSQ!t=7G@U_#YaQ&hwyxk|D-%jD{ zk5A#VZ-BNc=Kej3d0($$UO1wdKlDT~4_1o#t|yE6mKTb->(XNG{9!R4xuuwQ|E?JK zFXlu3Eaua06!VxyCjNdq6QB2hi8p%4#G4K_@x{IvBR_27FGQR8-;ZN_oNVIHiO+5Z36TkYJiAzgN+-tdspL);44Ii3#;d&E)^fUCCn@!yKm5ERP z#>Df#HF4MP@!fa;{pleSZ*c@+e?h-}6!9I0{R#B7ClThfiT`;P{rz7io^~F6G{)me z7ft*Ve1rXkzPlOv?$*~Z4hMcfAO0Hp@KAi4odt@}msbGU=+E~7ebJv!1U>_<0)5bb zM+1ex%fS1hwkTp$FKbL%p2l4E_D+>Y<~T92lza#=JYlb@YCJu7~%<_eXf||2)-u(J#}y zpNpC2?Xm4G?+Ja@dp|mJr}wU(fA#*N&t>m9&h?YJov6p`Xe9uboqRf&&brT ze7Z#L^)VLw=<~p#<35JMb3T`1Zuk_huc!YYv9bR7el7K#JGa*dck7~WH(aMLex{fH z$qRk;o%09i{W^H-uk82Ldww`ffARfrz30vt{Tb)S^<5rM)NkCEq5mp1Pw(AzvcA!T zC-vQOp3*0ee_FqP&NKS7wa@Fj{qd6iW}gN6i&NgvH!NSG_k83XecpE~^#FImv@)Kt9nUCd-jpG8Qi3cGd-lNF9%5dnhcSKM0-n9-( z`!K1y*9d9h>ToHfZLWMg;FWv)O6|P<1?ivew!t|^ZOhr>&&y#`9v;^Ni#ovQ#$tBQfWo2x1}HD8*ccuJyR!KjW zua=hF_kpzg@eid@Z+;}nCqI#lUly{yY#;6NvZUs z)6%TKKcz2zI45<>{99V>d|66Zd{vV94e9^k>`ddK`ro)uiXw$dl0sz5R$1qq?{!&| zrLvSr+4p4MnHdqOs1({m_C!ewZM2{yg;rW!3xKjV0n2K)T_^ivVAfjE+PvfadW|RSPsP8=Yw^(Jp8g&1i5Pq zpqf#J6XzC!%u-eObV?1D=xV^zQ;Xok5-spMrwt~IF7U1{hWXY@VP2OWB&|09gSUoY z7h?<;g&0WN%fc~b0O|7x&uvWM#|ty?jNrF@MT=*-&2koE~ z@Uz(r%9^PVG%XGEKBqzI{VlM%J{>9#X8?cmR(Rl_2~~F6V0_7T=$x|y6a=$i=xr8g zcV@##!%kRGybJDS?S`+hIk3}f4;;4J3-gR}K~gynVkPpy?r%Qq9^MD$kN1O5%K`X! z<{%6d9|Ehrhe0y!2$)A5gYM@TnQ9TFNL8AWsvi&4DyD{ zVeEMYoa(NG=9|Z1$(1VjR(Apns^5^g*rfN!d;LNyax^fop5%% z6U@fD;K#pic<}E&JpT6p#{WG8+wn(GKmHi31bSdhpck$SK85ND&)|&Eb9gxM1xO0_ zfuBe}+?)Io97JEipxA5JE&c}VrVqdz$w3&CdJBCshv13yFg%la2P3j0FlpX6!Rv?@T--ISXZW&BExZ(pbGs8m|k_#&c=2F8 zSrqo4iv|62aoPqsT>V%M!<^=!N5?!=ww{lduFpp`kVpS|d5l}4fa^{u;4~FQ+*6>4 z12PLxbk73(E2@N7(v)z;A0@1eR>tlTWxVOT5Vt>Fh|;T7F!Z(x?lM!w#0FK=(N)6} zWor0YP96X4QOB;y8W_UUz&l?w@Jrw#eDQ1%?sC*bp;k>~7%en7sfAw`Xk&D~HlCZJ zgAK_#$o;5;g5J7ld0!WoFI$YF^^0+b`VwqAxCC3omLflSDSjJSifSA5Q2LG@HnRGt zd_o`1<{IGK?FLx$!vKH!8{)tFhIrA;2z5>wq1!xT#O=oTpP|x zqi2R^51L`IfH|7@o8yk#=9s2yf$Dh{nEcZMlQvkQ>Q&koS6+r&wl2e^!^?1|ofYQR zSfPc)ax92gjwM~o(P^nQp4e-RHD9dJ)yW2{PupOnq%E!px5a}Uwzx~v4i{~=!_YxH zbhTK4!-Xqw!QT}q;JOmi&#c5#(^p|i@GAUvV--rt+hbR}JsNe{quC+{98GgT%cl-V z^c?ZY4o8%E<%oZboiJ^;6V?nkVG_Fos`X&>7!tcgBuq z&gi7O786p}qS^hmcw(Uo*2lV_U#knAneB=t0j{Wj-W3Cd*CDfJ9iA*+hs~eYVG_Dw zSC$*zdg6v&D(mrJWl02{1Bu4u({3;M@Ied%wm6>7w(U$HU8NB&L0)j z18};302Ukzz|Q9ZSRxyUvd)3HI42O_-3~-6;UKg$3BrMdAk?S}LWz+eJfIwm&Fh0P zH#ZnX+JkYP&_;Y{yb<-nH==&oM(pX`h{}>7D77pEOA$zYIZR=}qWqy$Lmw zH{p?*O?b9%6Glme;zRRL?2it`J*A;I^dJ=9P71@F`eE4X8-|^G!!Yz(7}k9X!@~LD zXkZtPF$v-HJsgf7yTVa@JRGMjionCp5%^$p1lFI3z-5mjkS`dCK8qsp%j!tf=0)PH z@<^<_8;L{TBk`ep6s>!rus$>jtMj7J{!$d}A4Xx(a0NXuKF7jd4e!@%7bc z6dZ`gjwvx{rxk-q_A$6VDh5B~#o*HV7}V&A!S3HNs5>tfO&}J9JYq4CAB$xLv6#^q zi*sMZqTfHtyf~c8#^Kg=aab82hiUn7IO9wlx^+@M#NkY_c-*2Ik2U7;nBx(T+DY{H z{CLc(jYrS+cpMyvM|HsjRGFKAFZ2>{&B_GK3`oHElmuLOAOUyRCSb#@1T5-Lz~w&^ zutp*g@2e(a10jU-Hm zBwXQ`girjEa8UxiJu3+p6eQuz+9cGwk%WN{lhEgF5~}`6!ZTvD$2u<=)wGjQ5|i=9 zs$?|vOvY{D$#^&=8IyM>qiSI?9zB_iFRvuy*E`AB{WKX<-X-JjpUG%BnTzhyT(nZ= z;`m}NW+E5+?YJnmj*B7zT)ZDe>&_JFQL?zGae#|vrCijm<>H4+Tui;m#dqDbpZkJ~ zWSEO8V_X~#z&4P?JxWCQ6Y$rVVn3^7Qx5X7(U)h;NuN0AB#5gF)*EvbGA`` zltt^_-F!T?mygr-@zM1lA9o$0+b*OvWicO{%J^7SNgd(|>Jv}W8nTvd;|$&Qd0NXh z@KNm&AGckhPPK{lu&>h^wwZ3Tm5-^nXn*@QA9;89=zo`wrk(WpyJ1l4_w@K_eXa44_PuG1eV39)>+IFEKR%V#+LtJPwB8n>_4YA};Ws|EP*&2~yOXkl z*4{TL20!Wjlqs|Z524(mEci{&1Eqx`MQd?a$`Q&litJx{9w?cViKnegK}llJr`<9F{4Q_k z>?S{BP8h#rf)WRrw6+oEr}`+X@|%BQoB z4@t3>`)9H156iH!6?56m7w5CP9xAeyKb6@+B{lZgnnkSjE^RjN-eNX=jy@|JY{WWT zV_3}v$X0AKV_Sb%vKe94?7(|Fb}-7G%@AD8Hs`Npk1cg$D(svcuEA@<`~1KX(q4_#ks6!QVLrXmCDwHZK2PT!Ky`NvU!Qy**oc3Y)9@+c7OS9 zR`bdpHuG^VTm3DcJt%X4T?vQSwtyq7cwPZJyQPR7{8h|ymzJ?l!YbIGCy%o)zMNpU zF(=vY8MUn1!#Z}J`Z@Lizn-=4xxi)_U1ql*Y-DW&uCZ-FH(0SpE$r0gx7a(EZnG=& zJJ_t+d+fHw-K^!=2kd3`G5e*phaGT!#^w#ZUDeI`|IBbJEh_y z+qHU>b(%EBW;c9ic@e)@Rjt2l#>hC^u~v}iU7SE-6eg10TPKn9Pr_ui+hp>$bqYx_ z5F@>1Q;Ec!X=GmZbRr}qNvki%OwiKl`#`Efyq_^e$_3dfd^lX-e% zx1j+s?=>W?DaJ%jjUlF;EHO$3@=wi#O?H=t|lpaoyk^L7qU)q9r-crM!e2#Ah~HCB*)Qm`M$jpDyo6a^VQM z{q{W>Sp1Q+Cw(H^me1s;lgXf# zIR%awibBkwC{*tg1FPjz!R+T$IC@+h+}2Nn_-WJOThnxS5G4UKR3)LdM-oo%lmc<{ z8PN891`M8<2|nJl0A!>gzC#)$(r1GRD+BAl$bdxE98mO;g`Bx_!TtVR*p@8^l2-HJ zo4|Z9x;P&m#mGaqt^zC?QGmX3MfmKq05&Knfyy%_usNsR@tD9hlu3u-kqSprj@&@6v?hd$quSjW#6C)`7QAbl~J+UFh&w43gmJvpZZ|kXaFkdhTvvv1Ot-B(E8XI#tS%*9l$_@4hvP^Szww7$ZrF1 zbwqeO*M#=SOkmO}Q`nPe22qygP$6Lfi=SG+vjCwmkw%%$;5MBdk9pp4`aG15LT1|Vp5yoR_bP`__7%)eN&IlqiJOWyV zN5S*tQ8=Mm08)hokRwwF>N$nbGo=VhQ;Q(;cM)ufJ_h^WAA@H9Vi4^sh5*+Rc-mD0 zL3X7ut)&#&undkil)<*8<*=i=97^YZXWliS@w^7ITu;J;2Pa{t{VC9HKLszXYT@|xTG)!GA@1U7 zNH(m4+`2kw)HwtHs?LDD+F3YTau&1{&q4i>bFfDCJWSem9$IJA!{OcakSg8)N!uGB zUE~53ZMgs)f)_!Ye-SqPxd>MhE`jd%OK>{+GAtXt3`1d8;K=(c;JvXC42Bv(HlPWn zy=ekTpR1tUe-)N_T!Xl0*P!0*I*9aK2Va*P(E0EN*sf`Y``yj3(Xj<2I$PlSs#e(2 z(F%?$Zh}_(O_*hS3&h%Pfw*-W%)8kJMpn1MtK~N2S+>K&8||>b;tnKTzXLDKI$+hc z4rnvI3l3NB!b_8Tz;C(-Dkh!qxUmy*u?yT9yFe4WL8P%8-obt7xpE)6-~n`Bc>uKg z3ZqvZ!gPED`i+mk2Oq=1#>emkpMXNs69_lyf!3xTP%-U=tgF57%k(LPUwaB8W;B;@ z{Tci+e-1ltJck9AFQBRU1^6!OgK4dOaM`LKqHgwsw)IQ+c)>aI4jhG?p;4#~ z{sL|9zQ91pR}lK}739OlfcZ2A&Jo`reDoV^i~0^lU%x|r%n#`J_5)tV{e-VSe!|4W zUm*4S7tBxo4QhXXgAVTx=#BpYgOtCZC-@I^Q~!aQ&^XN7G7eiO2;e_60gOr$z=7)m z=sZynn=J%!ak?NLY8FHx;RzV9Yy!4rOhAp+3Aj~62>Y#s&?r*~vu_IF^T`uY(|RJt zZJUUVw6nk%rV!fCc?zW|w-W_77 zb6X6*iB83Oo2eMReJU<$n~J?t#4*EK92ad9$F`f|=skHFj#*8^&0D9TNb5A*Dm)zp zmQBaV^y&Eg#&k5FD1k-h68JM!043ybOxC%b?R?8O-aE!48=@_}6(3D&@^V z?4E;;lCrpNl`Ohu%i_x0vS>VIF3z!VXVe{>w^KUcya zS!LYktc(qNl<`i7GCmMpi1(H)#4D)_@#vL>82M`<8X2hI=Li)%Qmul_kP5adtKuq8 zRct<_idv6UajTRXcCS!FscmX#c0&#Q#?>%^qmC&t>KK1Y9lhVFBdBPgn3o2&9n!$W zhZ-m+xd>0%E<(MGMR>ev5lZ}CghBe6csfiIM=CXO_G?XCI$sM-T(pqv(ZWUTS|}>4 zjXkK12NSf>rcN8*jc8-CiVpts(82HnI@r~vgUVBN(ce-R_w#h|!g*b6|D=m|)ECqK z(_$<Y{H?ka*Lp6+;{8kU`Msq$d5Rt`Fx5ki z1U*!&)kBdXJ?vG`#{w69bl9zrqpkY5d0ZdI4Gb_O)Bsyb4N&5l0b0#8#7(w_xH;7j z(;5sh`ja6#sv6;ZcO!g~YlNF`8{zB;#(2oc7{$YkF{IQO8+wiLt0V{ImUD0kkAwPW zIH)qr!HEhC-d)4s)*Uprf0enhC_dFoz zFAAuNKzn(Bp%s8%p90MVA+}f|N+u#&*C1|sNj-zK2`1W@pbyUkjZT~3k2fY*I>!`Y zg(+T7F-5&Irnr016d%i)q4-KO)ZA=_MrX`WXV46#WND7c&KwW&sgF2qj`v=h|#`YbR_$`aEoEHO0J5-ln$aZ-;Z)`~5|jt?_7*HJ+`a z^jc$)m<`4jTa=w;hyTp&uszZa zw-ni-$~`-*{YRHtD=^({1$JzszN4OIt_G<4n7I-q%~s-Y*h)NcWF@-XUWp%mti%wN zRrtVZ6{>7rgSCmtND(oY2%2$VjQuy$PpdxIAYHaN3>IR!m?FPIGpH&(q&Gl+3AEDf1FTK zbv5=mti}V$tC3T_8gF#2rdih2xJP9TKD1wh6Oz`TOz9ewzPkqh{8)qS3!E{{&KZ?s zovG_{#`(9LF@Dq;FU(zwZ!Fg0k4$`Vk}mke*admsE;zE?1T0?p-iD0=C-)uj}bStn6Vz?jn`wI$9g=FPV;9~>uFDZJ<5DvkC){( zppDrEYz)|da@iZu`}79f^=Jc@{@H-X6x}g%nL9dfbVsq>?pS%o9d(|#;-XAXOsw+6Qyrdo_p>KHoau$l zhF*ARofod-dZA#U7w*31g_GZSVStD?)~I{qGh1&Q+vJU3cX{K}T5qiC_C}vEZxovC zgFB3T@VBcEIwkqw-ork4>9P;DKlj1raUU#G@WoJ5UsUk+#fDU0KuSfOaN}#8-QnO1Mtq>0PJ`lK)-kCER1>}T3Q9-kZ&MH zr_yBs{rz$v?&t}`hVOxRcV-aYT^xkxRtDkLjX`LV8HD{MK^Ss1h&t3DWPSx9Upg31 zED6TzD}(WBa4=S81Y^RnU|f177#}#gu4% zo!x|Uoj2j;uua&Rxe2EnqaN$xCN#Rg3ANsD!l}Zccz=EF<@-q~BB*U;;Jq&|Q!%)IC42#0UP%bkJQwqZH?zu1&>7ZG|H(~Vi z6oy(esNd2E$0sJ?xN~hdYST+3)Ncu=vjE|^y*3=XTElVD^Kex98jc#G5jamF0)Og9 z;8oiQjP#1Y>2VR5pA~^3$0E?@d;}hEkHDw>^fBKeP+)2#jw(drUHwShXA_Cm9+5a0 z6^Y@Qk@)IxB%0MmVpek`UVRdY{qG}jL@)|p&5FWi^(fp!qR_@63P1QpAvZn>f9!}t z_kt)qc{&P5nxk;mlPFXlp^Vd?rJ`{}IT}wIMx(n;H2zp0jr_1^{Jfd^wp=Z5VAjk>mH(fIpAG`GZvE;QXgj!i}A~1@riRRss+TNZ(J;9ZH>ia`(m-Q zJQnlL$6{n_ERsjDI5rTA2fxLlrZAoHnH7h!3*)Hkj>F65arnhC4yC>0P%R=3Ra2O@)6LA=FF%Bi#=zPNCI9xCohr7q(a6~8`4W;5SOd%fgwd3(POWmGLJpIm& zN4|eNu859D(bRZ6yDJ`79f`+B$K!EjeLS9Nj>pN}@o3i4oHA?3&{!q^-Ox>Ym61vV! z!uW+rxJ`%VPmSrElz9?*u1G@twMqELGYRX0lW=`>5`O0V!bHW}YKQ4hJE&Vcw*CmBMsuF=VOBsm!mY@x0)D;YQDQg3;fy3CSf zY_3Yi=(=Q-zL<2XQ6o})Z zJ(r8QX>|T}8yA1?;^Mq~F6tfTqRBBXnpSYpu!f5Z&Tw(U1ui~nxtaaJc6 zuRP@9hNoN{?Wg{8kgh+%#qd!s_I#%^FMsK_C-AUWgt|>}9y&_#kUyJ;MRGj6pvc3U zDm16Nh=;AZJUp+@!=oG?%`otAr3Lk();xT)f`{3TJmjq9;WIZL#(MHl*pJ>8#6!_g z9`YioH;tvPHHn8Md>(#Doj}$B9$0FK`^?f=tgS(jKbM@%#k0BqYb7=0ErS1^vV@>HC zkOf`Oie{3nX&%^)k7+Aurr4g39!}J~uHmDi3(ftmVl4)+3M;&eo%|@rv%GSO3qg)Ps?mg7!=JL@vpL)lA)Nvl5j`tAtq=%`4JxcexfbLTf z^{vI!377Cui27k}In7sB&|^GKw^>C!Yc-$d5x+^w=-beZEB3zf2uzBOk4(N8Wgqk6G7fmijuq?*`3BQ>Q%GLY-$Tb(%M+ zPi>=4_ckAe+v$E#zxRx)jp3-yqjApkfhoAG&;RQXmK0cnNxcAfTQ72tPaePJnD`n4X zK5D5fFkvQu1EPo z@%%`gF-89q-3N-`XX>vhEtG|$^!-73PBHpIXTK_(nZC zrI<2A(fUrkJf)WMiK6p^x^7B2rJo{8{kJ0}lX8jjiL&4qeXml|D5oiXl&QbzF;KiH z+bO3hPblLQHCVJOwpk*6idn~iYvv35<-clBvZCfvM75g z2PuV=GRg_cY07!ZCCXJwGo_8vLFuGCpgg8LrM#f@Q(jXBC_|KYl=qa6luwjV$`{HQ z<-c71cghdSPs)E8{r?>P|2+O5`tyG-|9?LJKd1kHd;M{G+kgDeYb)NBESq)>< zF*L4gv@o9E?r5C7+RONhOSrN76Tb1Q;jP9}s=JL%iuM}^xfU7kS#{j_Y+9Z1qp?fI zW2G&|({k?_FKFs9*4B7qY~1zHn63Y1Jom!{j fj(FHKj)412&c}_ioSyv(oTk?* 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

QlgvEe>Lx$!RJ38r^V+fApKhnQ!YKQX&4 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 literal 0 HcmV?d00001 diff --git a/libsndfile/include/sndfile.h b/libsndfile/include/sndfile.h new file mode 100644 index 00000000..8a60fb09 --- /dev/null +++ b/libsndfile/include/sndfile.h @@ -0,0 +1,857 @@ +/* +** Copyright (C) 1999-2016 Erik de Castro Lopo +** +** This program is free software; you can redistribute it and/or modify +** it under the terms of the GNU Lesser General Public License as published by +** the Free Software Foundation; either version 2.1 of the License, or +** (at your option) any later version. +** +** This program is distributed in the hope that it will be useful, +** but WITHOUT ANY WARRANTY; without even the implied warranty of +** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +** GNU Lesser General Public License for more details. +** +** You should have received a copy of the GNU Lesser General Public License +** along with this program; if not, write to the Free Software +** Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. +*/ + +/* +** sndfile.h -- system-wide definitions +** +** API documentation is in the doc/ directory of the source code tarball +** and at http://www.mega-nerd.com/libsndfile/api.html. +*/ + +#ifndef SNDFILE_H +#define SNDFILE_H + +/* This is the version 1.0.X header file. */ +#define SNDFILE_1 + +#include +#include +#include + +#ifdef __cplusplus +extern "C" { +#endif /* __cplusplus */ + +/* The following file types can be read and written. +** A file type would consist of a major type (ie SF_FORMAT_WAV) bitwise +** ORed with a minor type (ie SF_FORMAT_PCM). SF_FORMAT_TYPEMASK and +** SF_FORMAT_SUBMASK can be used to separate the major and minor file +** types. +*/ + +enum +{ /* Major formats. */ + SF_FORMAT_WAV = 0x010000, /* Microsoft WAV format (little endian default). */ + SF_FORMAT_AIFF = 0x020000, /* Apple/SGI AIFF format (big endian). */ + SF_FORMAT_AU = 0x030000, /* Sun/NeXT AU format (big endian). */ + SF_FORMAT_RAW = 0x040000, /* RAW PCM data. */ + SF_FORMAT_PAF = 0x050000, /* Ensoniq PARIS file format. */ + SF_FORMAT_SVX = 0x060000, /* Amiga IFF / SVX8 / SV16 format. */ + SF_FORMAT_NIST = 0x070000, /* Sphere NIST format. */ + SF_FORMAT_VOC = 0x080000, /* VOC files. */ + SF_FORMAT_IRCAM = 0x0A0000, /* Berkeley/IRCAM/CARL */ + SF_FORMAT_W64 = 0x0B0000, /* Sonic Foundry's 64 bit RIFF/WAV */ + SF_FORMAT_MAT4 = 0x0C0000, /* Matlab (tm) V4.2 / GNU Octave 2.0 */ + SF_FORMAT_MAT5 = 0x0D0000, /* Matlab (tm) V5.0 / GNU Octave 2.1 */ + SF_FORMAT_PVF = 0x0E0000, /* Portable Voice Format */ + SF_FORMAT_XI = 0x0F0000, /* Fasttracker 2 Extended Instrument */ + SF_FORMAT_HTK = 0x100000, /* HMM Tool Kit format */ + SF_FORMAT_SDS = 0x110000, /* Midi Sample Dump Standard */ + SF_FORMAT_AVR = 0x120000, /* Audio Visual Research */ + SF_FORMAT_WAVEX = 0x130000, /* MS WAVE with WAVEFORMATEX */ + SF_FORMAT_SD2 = 0x160000, /* Sound Designer 2 */ + SF_FORMAT_FLAC = 0x170000, /* FLAC lossless file format */ + SF_FORMAT_CAF = 0x180000, /* Core Audio File format */ + SF_FORMAT_WVE = 0x190000, /* Psion WVE format */ + SF_FORMAT_OGG = 0x200000, /* Xiph OGG container */ + SF_FORMAT_MPC2K = 0x210000, /* Akai MPC 2000 sampler */ + SF_FORMAT_RF64 = 0x220000, /* RF64 WAV file */ + + /* Subtypes from here on. */ + + SF_FORMAT_PCM_S8 = 0x0001, /* Signed 8 bit data */ + SF_FORMAT_PCM_16 = 0x0002, /* Signed 16 bit data */ + SF_FORMAT_PCM_24 = 0x0003, /* Signed 24 bit data */ + SF_FORMAT_PCM_32 = 0x0004, /* Signed 32 bit data */ + + SF_FORMAT_PCM_U8 = 0x0005, /* Unsigned 8 bit data (WAV and RAW only) */ + + SF_FORMAT_FLOAT = 0x0006, /* 32 bit float data */ + SF_FORMAT_DOUBLE = 0x0007, /* 64 bit float data */ + + SF_FORMAT_ULAW = 0x0010, /* U-Law encoded. */ + SF_FORMAT_ALAW = 0x0011, /* A-Law encoded. */ + SF_FORMAT_IMA_ADPCM = 0x0012, /* IMA ADPCM. */ + SF_FORMAT_MS_ADPCM = 0x0013, /* Microsoft ADPCM. */ + + SF_FORMAT_GSM610 = 0x0020, /* GSM 6.10 encoding. */ + SF_FORMAT_VOX_ADPCM = 0x0021, /* OKI / Dialogix ADPCM */ + + SF_FORMAT_G721_32 = 0x0030, /* 32kbs G721 ADPCM encoding. */ + SF_FORMAT_G723_24 = 0x0031, /* 24kbs G723 ADPCM encoding. */ + SF_FORMAT_G723_40 = 0x0032, /* 40kbs G723 ADPCM encoding. */ + + SF_FORMAT_DWVW_12 = 0x0040, /* 12 bit Delta Width Variable Word encoding. */ + SF_FORMAT_DWVW_16 = 0x0041, /* 16 bit Delta Width Variable Word encoding. */ + SF_FORMAT_DWVW_24 = 0x0042, /* 24 bit Delta Width Variable Word encoding. */ + SF_FORMAT_DWVW_N = 0x0043, /* N bit Delta Width Variable Word encoding. */ + + SF_FORMAT_DPCM_8 = 0x0050, /* 8 bit differential PCM (XI only) */ + SF_FORMAT_DPCM_16 = 0x0051, /* 16 bit differential PCM (XI only) */ + + SF_FORMAT_VORBIS = 0x0060, /* Xiph Vorbis encoding. */ + + SF_FORMAT_ALAC_16 = 0x0070, /* Apple Lossless Audio Codec (16 bit). */ + SF_FORMAT_ALAC_20 = 0x0071, /* Apple Lossless Audio Codec (20 bit). */ + SF_FORMAT_ALAC_24 = 0x0072, /* Apple Lossless Audio Codec (24 bit). */ + SF_FORMAT_ALAC_32 = 0x0073, /* Apple Lossless Audio Codec (32 bit). */ + + /* Endian-ness options. */ + + SF_ENDIAN_FILE = 0x00000000, /* Default file endian-ness. */ + SF_ENDIAN_LITTLE = 0x10000000, /* Force little endian-ness. */ + SF_ENDIAN_BIG = 0x20000000, /* Force big endian-ness. */ + SF_ENDIAN_CPU = 0x30000000, /* Force CPU endian-ness. */ + + SF_FORMAT_SUBMASK = 0x0000FFFF, + SF_FORMAT_TYPEMASK = 0x0FFF0000, + SF_FORMAT_ENDMASK = 0x30000000 +} ; + +/* +** The following are the valid command numbers for the sf_command() +** interface. The use of these commands is documented in the file +** command.html in the doc directory of the source code distribution. +*/ + +enum +{ SFC_GET_LIB_VERSION = 0x1000, + SFC_GET_LOG_INFO = 0x1001, + SFC_GET_CURRENT_SF_INFO = 0x1002, + + + SFC_GET_NORM_DOUBLE = 0x1010, + SFC_GET_NORM_FLOAT = 0x1011, + SFC_SET_NORM_DOUBLE = 0x1012, + SFC_SET_NORM_FLOAT = 0x1013, + SFC_SET_SCALE_FLOAT_INT_READ = 0x1014, + SFC_SET_SCALE_INT_FLOAT_WRITE = 0x1015, + + SFC_GET_SIMPLE_FORMAT_COUNT = 0x1020, + SFC_GET_SIMPLE_FORMAT = 0x1021, + + SFC_GET_FORMAT_INFO = 0x1028, + + SFC_GET_FORMAT_MAJOR_COUNT = 0x1030, + SFC_GET_FORMAT_MAJOR = 0x1031, + SFC_GET_FORMAT_SUBTYPE_COUNT = 0x1032, + SFC_GET_FORMAT_SUBTYPE = 0x1033, + + SFC_CALC_SIGNAL_MAX = 0x1040, + SFC_CALC_NORM_SIGNAL_MAX = 0x1041, + SFC_CALC_MAX_ALL_CHANNELS = 0x1042, + SFC_CALC_NORM_MAX_ALL_CHANNELS = 0x1043, + SFC_GET_SIGNAL_MAX = 0x1044, + SFC_GET_MAX_ALL_CHANNELS = 0x1045, + + SFC_SET_ADD_PEAK_CHUNK = 0x1050, + SFC_SET_ADD_HEADER_PAD_CHUNK = 0x1051, + + SFC_UPDATE_HEADER_NOW = 0x1060, + SFC_SET_UPDATE_HEADER_AUTO = 0x1061, + + SFC_FILE_TRUNCATE = 0x1080, + + SFC_SET_RAW_START_OFFSET = 0x1090, + + SFC_SET_DITHER_ON_WRITE = 0x10A0, + SFC_SET_DITHER_ON_READ = 0x10A1, + + SFC_GET_DITHER_INFO_COUNT = 0x10A2, + SFC_GET_DITHER_INFO = 0x10A3, + + SFC_GET_EMBED_FILE_INFO = 0x10B0, + + SFC_SET_CLIPPING = 0x10C0, + SFC_GET_CLIPPING = 0x10C1, + + SFC_GET_CUE_COUNT = 0x10CD, + SFC_GET_CUE = 0x10CE, + SFC_SET_CUE = 0x10CF, + + SFC_GET_INSTRUMENT = 0x10D0, + SFC_SET_INSTRUMENT = 0x10D1, + + SFC_GET_LOOP_INFO = 0x10E0, + + SFC_GET_BROADCAST_INFO = 0x10F0, + SFC_SET_BROADCAST_INFO = 0x10F1, + + SFC_GET_CHANNEL_MAP_INFO = 0x1100, + SFC_SET_CHANNEL_MAP_INFO = 0x1101, + + SFC_RAW_DATA_NEEDS_ENDSWAP = 0x1110, + + /* Support for Wavex Ambisonics Format */ + SFC_WAVEX_SET_AMBISONIC = 0x1200, + SFC_WAVEX_GET_AMBISONIC = 0x1201, + + /* + ** RF64 files can be set so that on-close, writable files that have less + ** than 4GB of data in them are converted to RIFF/WAV, as per EBU + ** recommendations. + */ + SFC_RF64_AUTO_DOWNGRADE = 0x1210, + + SFC_SET_VBR_ENCODING_QUALITY = 0x1300, + SFC_SET_COMPRESSION_LEVEL = 0x1301, + + /* Cart Chunk support */ + SFC_SET_CART_INFO = 0x1400, + SFC_GET_CART_INFO = 0x1401, + + /* Following commands for testing only. */ + SFC_TEST_IEEE_FLOAT_REPLACE = 0x6001, + + /* + ** SFC_SET_ADD_* values are deprecated and will disappear at some + ** time in the future. They are guaranteed to be here up to and + ** including version 1.0.8 to avoid breakage of existing software. + ** They currently do nothing and will continue to do nothing. + */ + SFC_SET_ADD_DITHER_ON_WRITE = 0x1070, + SFC_SET_ADD_DITHER_ON_READ = 0x1071 +} ; + + +/* +** String types that can be set and read from files. Not all file types +** support this and even the file types which support one, may not support +** all string types. +*/ + +enum +{ SF_STR_TITLE = 0x01, + SF_STR_COPYRIGHT = 0x02, + SF_STR_SOFTWARE = 0x03, + SF_STR_ARTIST = 0x04, + SF_STR_COMMENT = 0x05, + SF_STR_DATE = 0x06, + SF_STR_ALBUM = 0x07, + SF_STR_LICENSE = 0x08, + SF_STR_TRACKNUMBER = 0x09, + SF_STR_GENRE = 0x10 +} ; + +/* +** Use the following as the start and end index when doing metadata +** transcoding. +*/ + +#define SF_STR_FIRST SF_STR_TITLE +#define SF_STR_LAST SF_STR_GENRE + +enum +{ /* True and false */ + SF_FALSE = 0, + SF_TRUE = 1, + + /* Modes for opening files. */ + SFM_READ = 0x10, + SFM_WRITE = 0x20, + SFM_RDWR = 0x30, + + SF_AMBISONIC_NONE = 0x40, + SF_AMBISONIC_B_FORMAT = 0x41 +} ; + +/* Public error values. These are guaranteed to remain unchanged for the duration +** of the library major version number. +** There are also a large number of private error numbers which are internal to +** the library which can change at any time. +*/ + +enum +{ SF_ERR_NO_ERROR = 0, + SF_ERR_UNRECOGNISED_FORMAT = 1, + SF_ERR_SYSTEM = 2, + SF_ERR_MALFORMED_FILE = 3, + SF_ERR_UNSUPPORTED_ENCODING = 4 +} ; + + +/* Channel map values (used with SFC_SET/GET_CHANNEL_MAP). +*/ + +enum +{ SF_CHANNEL_MAP_INVALID = 0, + SF_CHANNEL_MAP_MONO = 1, + SF_CHANNEL_MAP_LEFT, /* Apple calls this 'Left' */ + SF_CHANNEL_MAP_RIGHT, /* Apple calls this 'Right' */ + SF_CHANNEL_MAP_CENTER, /* Apple calls this 'Center' */ + SF_CHANNEL_MAP_FRONT_LEFT, + SF_CHANNEL_MAP_FRONT_RIGHT, + SF_CHANNEL_MAP_FRONT_CENTER, + SF_CHANNEL_MAP_REAR_CENTER, /* Apple calls this 'Center Surround', Msft calls this 'Back Center' */ + SF_CHANNEL_MAP_REAR_LEFT, /* Apple calls this 'Left Surround', Msft calls this 'Back Left' */ + SF_CHANNEL_MAP_REAR_RIGHT, /* Apple calls this 'Right Surround', Msft calls this 'Back Right' */ + SF_CHANNEL_MAP_LFE, /* Apple calls this 'LFEScreen', Msft calls this 'Low Frequency' */ + SF_CHANNEL_MAP_FRONT_LEFT_OF_CENTER, /* Apple calls this 'Left Center' */ + SF_CHANNEL_MAP_FRONT_RIGHT_OF_CENTER, /* Apple calls this 'Right Center */ + SF_CHANNEL_MAP_SIDE_LEFT, /* Apple calls this 'Left Surround Direct' */ + SF_CHANNEL_MAP_SIDE_RIGHT, /* Apple calls this 'Right Surround Direct' */ + SF_CHANNEL_MAP_TOP_CENTER, /* Apple calls this 'Top Center Surround' */ + SF_CHANNEL_MAP_TOP_FRONT_LEFT, /* Apple calls this 'Vertical Height Left' */ + SF_CHANNEL_MAP_TOP_FRONT_RIGHT, /* Apple calls this 'Vertical Height Right' */ + SF_CHANNEL_MAP_TOP_FRONT_CENTER, /* Apple calls this 'Vertical Height Center' */ + SF_CHANNEL_MAP_TOP_REAR_LEFT, /* Apple and MS call this 'Top Back Left' */ + SF_CHANNEL_MAP_TOP_REAR_RIGHT, /* Apple and MS call this 'Top Back Right' */ + SF_CHANNEL_MAP_TOP_REAR_CENTER, /* Apple and MS call this 'Top Back Center' */ + + SF_CHANNEL_MAP_AMBISONIC_B_W, + SF_CHANNEL_MAP_AMBISONIC_B_X, + SF_CHANNEL_MAP_AMBISONIC_B_Y, + SF_CHANNEL_MAP_AMBISONIC_B_Z, + + SF_CHANNEL_MAP_MAX +} ; + + +/* A SNDFILE* pointer can be passed around much like stdio.h's FILE* pointer. */ + +typedef struct SNDFILE_tag SNDFILE ; + +/* The following typedef is system specific and is defined when libsndfile is +** compiled. sf_count_t will be a 64 bit value when the underlying OS allows +** 64 bit file offsets. +** On windows, we need to allow the same header file to be compiler by both GCC +** and the Microsoft compiler. +*/ + +#if (defined (_MSCVER) || defined (_MSC_VER) && (_MSC_VER < 1310)) +typedef __int64 sf_count_t ; +#define SF_COUNT_MAX 0x7fffffffffffffffi64 +#else +typedef __int64 sf_count_t ; +#define SF_COUNT_MAX 0x7FFFFFFFFFFFFFFFLL +#endif + + +/* A pointer to a SF_INFO structure is passed to sf_open () and filled in. +** On write, the SF_INFO structure is filled in by the user and passed into +** sf_open (). +*/ + +struct SF_INFO +{ sf_count_t frames ; /* Used to be called samples. Changed to avoid confusion. */ + int samplerate ; + int channels ; + int format ; + int sections ; + int seekable ; +} ; + +typedef struct SF_INFO SF_INFO ; + +/* The SF_FORMAT_INFO struct is used to retrieve information about the sound +** file formats libsndfile supports using the sf_command () interface. +** +** Using this interface will allow applications to support new file formats +** and encoding types when libsndfile is upgraded, without requiring +** re-compilation of the application. +** +** Please consult the libsndfile documentation (particularly the information +** on the sf_command () interface) for examples of its use. +*/ + +typedef struct +{ int format ; + const char *name ; + const char *extension ; +} SF_FORMAT_INFO ; + +/* +** Enums and typedefs for adding dither on read and write. +** See the html documentation for sf_command(), SFC_SET_DITHER_ON_WRITE +** and SFC_SET_DITHER_ON_READ. +*/ + +enum +{ SFD_DEFAULT_LEVEL = 0, + SFD_CUSTOM_LEVEL = 0x40000000, + + SFD_NO_DITHER = 500, + SFD_WHITE = 501, + SFD_TRIANGULAR_PDF = 502 +} ; + +typedef struct +{ int type ; + double level ; + const char *name ; +} SF_DITHER_INFO ; + +/* Struct used to retrieve information about a file embedded within a +** larger file. See SFC_GET_EMBED_FILE_INFO. +*/ + +typedef struct +{ sf_count_t offset ; + sf_count_t length ; +} SF_EMBED_FILE_INFO ; + +/* +** Struct used to retrieve cue marker information from a file +*/ + +typedef struct +{ int32_t indx ; + uint32_t position ; + int32_t fcc_chunk ; + int32_t chunk_start ; + int32_t block_start ; + uint32_t sample_offset ; + char name [256] ; +} SF_CUE_POINT ; + +#define SF_CUES_VAR(count) \ + struct \ + { uint32_t cue_count ; \ + SF_CUE_POINT cue_points [count] ; \ + } + +typedef SF_CUES_VAR (100) SF_CUES ; + +/* +** Structs used to retrieve music sample information from a file. +*/ + +enum +{ /* + ** The loop mode field in SF_INSTRUMENT will be one of the following. + */ + SF_LOOP_NONE = 800, + SF_LOOP_FORWARD, + SF_LOOP_BACKWARD, + SF_LOOP_ALTERNATING +} ; + +typedef struct +{ int gain ; + char basenote, detune ; + char velocity_lo, velocity_hi ; + char key_lo, key_hi ; + int loop_count ; + + struct + { int mode ; + uint32_t start ; + uint32_t end ; + uint32_t count ; + } loops [16] ; /* make variable in a sensible way */ +} SF_INSTRUMENT ; + + + +/* Struct used to retrieve loop information from a file.*/ +typedef struct +{ + short time_sig_num ; /* any positive integer > 0 */ + short time_sig_den ; /* any positive power of 2 > 0 */ + int loop_mode ; /* see SF_LOOP enum */ + + int num_beats ; /* this is NOT the amount of quarter notes !!!*/ + /* a full bar of 4/4 is 4 beats */ + /* a full bar of 7/8 is 7 beats */ + + float bpm ; /* suggestion, as it can be calculated using other fields:*/ + /* file's length, file's sampleRate and our time_sig_den*/ + /* -> bpms are always the amount of _quarter notes_ per minute */ + + int root_key ; /* MIDI note, or -1 for None */ + int future [6] ; +} SF_LOOP_INFO ; + + +/* Struct used to retrieve broadcast (EBU) information from a file. +** Strongly (!) based on EBU "bext" chunk format used in Broadcast WAVE. +*/ +#define SF_BROADCAST_INFO_VAR(coding_hist_size) \ + struct \ + { char description [256] ; \ + char originator [32] ; \ + char originator_reference [32] ; \ + char origination_date [10] ; \ + char origination_time [8] ; \ + uint32_t time_reference_low ; \ + uint32_t time_reference_high ; \ + short version ; \ + char umid [64] ; \ + char reserved [190] ; \ + uint32_t coding_history_size ; \ + char coding_history [coding_hist_size] ; \ + } + +/* SF_BROADCAST_INFO is the above struct with coding_history field of 256 bytes. */ +typedef SF_BROADCAST_INFO_VAR (256) SF_BROADCAST_INFO ; + +struct SF_CART_TIMER +{ char usage [4] ; + int32_t value ; +} ; + +typedef struct SF_CART_TIMER SF_CART_TIMER ; + +#define SF_CART_INFO_VAR(p_tag_text_size) \ + struct \ + { char version [4] ; \ + char title [64] ; \ + char artist [64] ; \ + char cut_id [64] ; \ + char client_id [64] ; \ + char category [64] ; \ + char classification [64] ; \ + char out_cue [64] ; \ + char start_date [10] ; \ + char start_time [8] ; \ + char end_date [10] ; \ + char end_time [8] ; \ + char producer_app_id [64] ; \ + char producer_app_version [64] ; \ + char user_def [64] ; \ + int32_t level_reference ; \ + SF_CART_TIMER post_timers [8] ; \ + char reserved [276] ; \ + char url [1024] ; \ + uint32_t tag_text_size ; \ + char tag_text [p_tag_text_size] ; \ + } + +typedef SF_CART_INFO_VAR (256) SF_CART_INFO ; + +/* Virtual I/O functionality. */ + +typedef sf_count_t (*sf_vio_get_filelen) (void *user_data) ; +typedef sf_count_t (*sf_vio_seek) (sf_count_t offset, int whence, void *user_data) ; +typedef sf_count_t (*sf_vio_read) (void *ptr, sf_count_t count, void *user_data) ; +typedef sf_count_t (*sf_vio_write) (const void *ptr, sf_count_t count, void *user_data) ; +typedef sf_count_t (*sf_vio_tell) (void *user_data) ; + +struct SF_VIRTUAL_IO +{ sf_vio_get_filelen get_filelen ; + sf_vio_seek seek ; + sf_vio_read read ; + sf_vio_write write ; + sf_vio_tell tell ; +} ; + +typedef struct SF_VIRTUAL_IO SF_VIRTUAL_IO ; + + +/* Open the specified file for read, write or both. On error, this will +** return a NULL pointer. To find the error number, pass a NULL SNDFILE +** to sf_strerror (). +** All calls to sf_open() should be matched with a call to sf_close(). +*/ + +SNDFILE* sf_open (const char *path, int mode, SF_INFO *sfinfo) ; + + +/* Use the existing file descriptor to create a SNDFILE object. If close_desc +** is TRUE, the file descriptor will be closed when sf_close() is called. If +** it is FALSE, the descriptor will not be closed. +** When passed a descriptor like this, the library will assume that the start +** of file header is at the current file offset. This allows sound files within +** larger container files to be read and/or written. +** On error, this will return a NULL pointer. To find the error number, pass a +** NULL SNDFILE to sf_strerror (). +** All calls to sf_open_fd() should be matched with a call to sf_close(). + +*/ + +SNDFILE* sf_open_fd (int fd, int mode, SF_INFO *sfinfo, int close_desc) ; + +SNDFILE* sf_open_virtual (SF_VIRTUAL_IO *sfvirtual, int mode, SF_INFO *sfinfo, void *user_data) ; + + +/* sf_error () returns a error number which can be translated to a text +** string using sf_error_number(). +*/ + +int sf_error (SNDFILE *sndfile) ; + + +/* sf_strerror () returns to the caller a pointer to the current error message for +** the given SNDFILE. +*/ + +const char* sf_strerror (SNDFILE *sndfile) ; + + +/* sf_error_number () allows the retrieval of the error string for each internal +** error number. +** +*/ + +const char* sf_error_number (int errnum) ; + + +/* The following two error functions are deprecated but they will remain in the +** library for the foreseeable future. The function sf_strerror() should be used +** in their place. +*/ + +int sf_perror (SNDFILE *sndfile) ; +int sf_error_str (SNDFILE *sndfile, char* str, size_t len) ; + + +/* Return TRUE if fields of the SF_INFO struct are a valid combination of values. */ + +int sf_command (SNDFILE *sndfile, int command, void *data, int datasize) ; + + +/* Return TRUE if fields of the SF_INFO struct are a valid combination of values. */ + +int sf_format_check (const SF_INFO *info) ; + + +/* Seek within the waveform data chunk of the SNDFILE. sf_seek () uses +** the same values for whence (SEEK_SET, SEEK_CUR and SEEK_END) as +** stdio.h function fseek (). +** An offset of zero with whence set to SEEK_SET will position the +** read / write pointer to the first data sample. +** On success sf_seek returns the current position in (multi-channel) +** samples from the start of the file. +** Please see the libsndfile documentation for moving the read pointer +** separately from the write pointer on files open in mode SFM_RDWR. +** On error all of these functions return -1. +*/ + +enum +{ SF_SEEK_SET = SEEK_SET, + SF_SEEK_CUR = SEEK_CUR, + SF_SEEK_END = SEEK_END +} ; + +sf_count_t sf_seek (SNDFILE *sndfile, sf_count_t frames, int whence) ; + + +/* Functions for retrieving and setting string data within sound files. +** Not all file types support this features; AIFF and WAV do. For both +** functions, the str_type parameter must be one of the SF_STR_* values +** defined above. +** On error, sf_set_string() returns non-zero while sf_get_string() +** returns NULL. +*/ + +int sf_set_string (SNDFILE *sndfile, int str_type, const char* str) ; + +const char* sf_get_string (SNDFILE *sndfile, int str_type) ; + + +/* Return the library version string. */ + +const char * sf_version_string (void) ; + +/* Return the current byterate at this point in the file. The byte rate in this +** case is the number of bytes per second of audio data. For instance, for a +** stereo, 18 bit PCM encoded file with an 16kHz sample rate, the byte rate +** would be 2 (stereo) * 2 (two bytes per sample) * 16000 => 64000 bytes/sec. +** For some file formats the returned value will be accurate and exact, for some +** it will be a close approximation, for some it will be the average bitrate for +** the whole file and for some it will be a time varying value that was accurate +** when the file was most recently read or written. +** To get the bitrate, multiple this value by 8. +** Returns -1 for unknown. +*/ +int sf_current_byterate (SNDFILE *sndfile) ; + +/* Functions for reading/writing the waveform data of a sound file. +*/ + +sf_count_t sf_read_raw (SNDFILE *sndfile, void *ptr, sf_count_t bytes) ; +sf_count_t sf_write_raw (SNDFILE *sndfile, const void *ptr, sf_count_t bytes) ; + + +/* Functions for reading and writing the data chunk in terms of frames. +** The number of items actually read/written = frames * number of channels. +** sf_xxxx_raw read/writes the raw data bytes from/to the file +** sf_xxxx_short passes data in the native short format +** sf_xxxx_int passes data in the native int format +** sf_xxxx_float passes data in the native float format +** sf_xxxx_double passes data in the native double format +** All of these read/write function return number of frames read/written. +*/ + +sf_count_t sf_readf_short (SNDFILE *sndfile, short *ptr, sf_count_t frames) ; +sf_count_t sf_writef_short (SNDFILE *sndfile, const short *ptr, sf_count_t frames) ; + +sf_count_t sf_readf_int (SNDFILE *sndfile, int *ptr, sf_count_t frames) ; +sf_count_t sf_writef_int (SNDFILE *sndfile, const int *ptr, sf_count_t frames) ; + +sf_count_t sf_readf_float (SNDFILE *sndfile, float *ptr, sf_count_t frames) ; +sf_count_t sf_writef_float (SNDFILE *sndfile, const float *ptr, sf_count_t frames) ; + +sf_count_t sf_readf_double (SNDFILE *sndfile, double *ptr, sf_count_t frames) ; +sf_count_t sf_writef_double (SNDFILE *sndfile, const double *ptr, sf_count_t frames) ; + + +/* Functions for reading and writing the data chunk in terms of items. +** Otherwise similar to above. +** All of these read/write function return number of items read/written. +*/ + +sf_count_t sf_read_short (SNDFILE *sndfile, short *ptr, sf_count_t items) ; +sf_count_t sf_write_short (SNDFILE *sndfile, const short *ptr, sf_count_t items) ; + +sf_count_t sf_read_int (SNDFILE *sndfile, int *ptr, sf_count_t items) ; +sf_count_t sf_write_int (SNDFILE *sndfile, const int *ptr, sf_count_t items) ; + +sf_count_t sf_read_float (SNDFILE *sndfile, float *ptr, sf_count_t items) ; +sf_count_t sf_write_float (SNDFILE *sndfile, const float *ptr, sf_count_t items) ; + +sf_count_t sf_read_double (SNDFILE *sndfile, double *ptr, sf_count_t items) ; +sf_count_t sf_write_double (SNDFILE *sndfile, const double *ptr, sf_count_t items) ; + + +/* Close the SNDFILE and clean up all memory allocations associated with this +** file. +** Returns 0 on success, or an error number. +*/ + +int sf_close (SNDFILE *sndfile) ; + + +/* If the file is opened SFM_WRITE or SFM_RDWR, call fsync() on the file +** to force the writing of data to disk. If the file is opened SFM_READ +** no action is taken. +*/ + +void sf_write_sync (SNDFILE *sndfile) ; + + + +/* The function sf_wchar_open() is Windows Only! +** Open a file passing in a Windows Unicode filename. Otherwise, this is +** the same as sf_open(). +** +** In order for this to work, you need to do the following: +** +** #include +** #define ENABLE_SNDFILE_WINDOWS_PROTOTYPES 1 +** #including +*/ + +#if (defined (ENABLE_SNDFILE_WINDOWS_PROTOTYPES) && ENABLE_SNDFILE_WINDOWS_PROTOTYPES) +SNDFILE* sf_wchar_open (LPCWSTR wpath, int mode, SF_INFO *sfinfo) ; +#endif + + + + +/* Getting and setting of chunks from within a sound file. +** +** These functions allow the getting and setting of chunks within a sound file +** (for those formats which allow it). +** +** These functions fail safely. Specifically, they will not allow you to overwrite +** existing chunks or add extra versions of format specific reserved chunks but +** should allow you to retrieve any and all chunks (may not be implemented for +** all chunks or all file formats). +*/ + +struct SF_CHUNK_INFO +{ char id [64] ; /* The chunk identifier. */ + unsigned id_size ; /* The size of the chunk identifier. */ + unsigned datalen ; /* The size of that data. */ + void *data ; /* Pointer to the data. */ +} ; + +typedef struct SF_CHUNK_INFO SF_CHUNK_INFO ; + +/* Set the specified chunk info (must be done before any audio data is written +** to the file). This will fail for format specific reserved chunks. +** The chunk_info->data pointer must be valid until the file is closed. +** Returns SF_ERR_NO_ERROR on success or non-zero on failure. +*/ +int sf_set_chunk (SNDFILE * sndfile, const SF_CHUNK_INFO * chunk_info) ; + +/* +** An opaque structure to an iterator over the all chunks of a given id +*/ +typedef struct SF_CHUNK_ITERATOR SF_CHUNK_ITERATOR ; + +/* Get an iterator for all chunks matching chunk_info. +** The iterator will point to the first chunk matching chunk_info. +** Chunks are matching, if (chunk_info->id) matches the first +** (chunk_info->id_size) bytes of a chunk found in the SNDFILE* handle. +** If chunk_info is NULL, an iterator to all chunks in the SNDFILE* handle +** is returned. +** The values of chunk_info->datalen and chunk_info->data are ignored. +** If no matching chunks are found in the sndfile, NULL is returned. +** The returned iterator will stay valid until one of the following occurs: +** a) The sndfile is closed. +** b) A new chunk is added using sf_set_chunk(). +** c) Another chunk iterator function is called on the same SNDFILE* handle +** that causes the iterator to be modified. +** The memory for the iterator belongs to the SNDFILE* handle and is freed when +** sf_close() is called. +*/ +SF_CHUNK_ITERATOR * +sf_get_chunk_iterator (SNDFILE * sndfile, const SF_CHUNK_INFO * chunk_info) ; + +/* Iterate through chunks by incrementing the iterator. +** Increments the iterator and returns a handle to the new one. +** After this call, iterator will no longer be valid, and you must use the +** newly returned handle from now on. +** The returned handle can be used to access the next chunk matching +** the criteria as defined in sf_get_chunk_iterator(). +** If iterator points to the last chunk, this will free all resources +** associated with iterator and return NULL. +** The returned iterator will stay valid until sf_get_chunk_iterator_next +** is called again, the sndfile is closed or a new chunk us added. +*/ +SF_CHUNK_ITERATOR * +sf_next_chunk_iterator (SF_CHUNK_ITERATOR * iterator) ; + + +/* Get the size of the specified chunk. +** If the specified chunk exists, the size will be returned in the +** datalen field of the SF_CHUNK_INFO struct. +** Additionally, the id of the chunk will be copied to the id +** field of the SF_CHUNK_INFO struct and it's id_size field will +** be updated accordingly. +** If the chunk doesn't exist chunk_info->datalen will be zero, and the +** id and id_size fields will be undefined. +** The function will return SF_ERR_NO_ERROR on success or non-zero on +** failure. +*/ +int +sf_get_chunk_size (const SF_CHUNK_ITERATOR * it, SF_CHUNK_INFO * chunk_info) ; + +/* Get the specified chunk data. +** If the specified chunk exists, up to chunk_info->datalen bytes of +** the chunk data will be copied into the chunk_info->data buffer +** (allocated by the caller) and the chunk_info->datalen field +** updated to reflect the size of the data. The id and id_size +** field will be updated according to the retrieved chunk +** If the chunk doesn't exist chunk_info->datalen will be zero, and the +** id and id_size fields will be undefined. +** The function will return SF_ERR_NO_ERROR on success or non-zero on +** failure. +*/ +int +sf_get_chunk_data (const SF_CHUNK_ITERATOR * it, SF_CHUNK_INFO * chunk_info) ; + + +#ifdef __cplusplus +} /* extern "C" */ +#endif /* __cplusplus */ + +#endif /* SNDFILE_H */ + diff --git a/libsndfile/include/sndfile.hh b/libsndfile/include/sndfile.hh new file mode 100644 index 00000000..0e1c1c20 --- /dev/null +++ b/libsndfile/include/sndfile.hh @@ -0,0 +1,446 @@ +/* +** Copyright (C) 2005-2012 Erik de Castro Lopo +** +** All rights reserved. +** +** Redistribution and use in source and binary forms, with or without +** modification, are permitted provided that the following conditions are +** met: +** +** * Redistributions of source code must retain the above copyright +** notice, this list of conditions and the following disclaimer. +** * Redistributions in binary form must reproduce the above copyright +** notice, this list of conditions and the following disclaimer in +** the documentation and/or other materials provided with the +** distribution. +** * Neither the author nor the names of any contributors may be used +** to endorse or promote products derived from this software without +** specific prior written permission. +** +** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +** "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED +** TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR +** PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR +** CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, +** EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, +** PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; +** OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, +** WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR +** OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF +** ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. +*/ + +/* +** The above modified BSD style license (GPL and LGPL compatible) applies to +** this file. It does not apply to libsndfile itself which is released under +** the GNU LGPL or the libsndfile test suite which is released under the GNU +** GPL. +** This means that this header file can be used under this modified BSD style +** license, but the LGPL still holds for the libsndfile library itself. +*/ + +/* +** sndfile.hh -- A lightweight C++ wrapper for the libsndfile API. +** +** All the methods are inlines and all functionality is contained in this +** file. There is no separate implementation file. +** +** API documentation is in the doc/ directory of the source code tarball +** and at http://www.mega-nerd.com/libsndfile/api.html. +*/ + +#ifndef SNDFILE_HH +#define SNDFILE_HH + +#include + +#include +#include // for std::nothrow + +class SndfileHandle +{ private : + struct SNDFILE_ref + { SNDFILE_ref (void) ; + ~SNDFILE_ref (void) ; + + SNDFILE *sf ; + SF_INFO sfinfo ; + int ref ; + } ; + + SNDFILE_ref *p ; + + public : + /* Default constructor */ + SndfileHandle (void) : p (NULL) {} ; + SndfileHandle (const char *path, int mode = SFM_READ, + int format = 0, int channels = 0, int samplerate = 0) ; + SndfileHandle (std::string const & path, int mode = SFM_READ, + int format = 0, int channels = 0, int samplerate = 0) ; + SndfileHandle (int fd, bool close_desc, int mode = SFM_READ, + int format = 0, int channels = 0, int samplerate = 0) ; + SndfileHandle (SF_VIRTUAL_IO &sfvirtual, void *user_data, int mode = SFM_READ, + int format = 0, int channels = 0, int samplerate = 0) ; + +#ifdef ENABLE_SNDFILE_WINDOWS_PROTOTYPES + SndfileHandle (LPCWSTR wpath, int mode = SFM_READ, + int format = 0, int channels = 0, int samplerate = 0) ; +#endif + + ~SndfileHandle (void) ; + + SndfileHandle (const SndfileHandle &orig) ; + SndfileHandle & operator = (const SndfileHandle &rhs) ; + + /* Mainly for debugging/testing. */ + int refCount (void) const { return (p == NULL) ? 0 : p->ref ; } + + operator bool () const { return (p != NULL) ; } + + bool operator == (const SndfileHandle &rhs) const { return (p == rhs.p) ; } + + sf_count_t frames (void) const { return p ? p->sfinfo.frames : 0 ; } + int format (void) const { return p ? p->sfinfo.format : 0 ; } + int channels (void) const { return p ? p->sfinfo.channels : 0 ; } + int samplerate (void) const { return p ? p->sfinfo.samplerate : 0 ; } + + int error (void) const ; + const char * strError (void) const ; + + int command (int cmd, void *data, int datasize) ; + + sf_count_t seek (sf_count_t frames, int whence) ; + + void writeSync (void) ; + + int setString (int str_type, const char* str) ; + + const char* getString (int str_type) const ; + + static int formatCheck (int format, int channels, int samplerate) ; + + sf_count_t read (short *ptr, sf_count_t items) ; + sf_count_t read (int *ptr, sf_count_t items) ; + sf_count_t read (float *ptr, sf_count_t items) ; + sf_count_t read (double *ptr, sf_count_t items) ; + + sf_count_t write (const short *ptr, sf_count_t items) ; + sf_count_t write (const int *ptr, sf_count_t items) ; + sf_count_t write (const float *ptr, sf_count_t items) ; + sf_count_t write (const double *ptr, sf_count_t items) ; + + sf_count_t readf (short *ptr, sf_count_t frames) ; + sf_count_t readf (int *ptr, sf_count_t frames) ; + sf_count_t readf (float *ptr, sf_count_t frames) ; + sf_count_t readf (double *ptr, sf_count_t frames) ; + + sf_count_t writef (const short *ptr, sf_count_t frames) ; + sf_count_t writef (const int *ptr, sf_count_t frames) ; + sf_count_t writef (const float *ptr, sf_count_t frames) ; + sf_count_t writef (const double *ptr, sf_count_t frames) ; + + sf_count_t readRaw (void *ptr, sf_count_t bytes) ; + sf_count_t writeRaw (const void *ptr, sf_count_t bytes) ; + + /**< Raw access to the handle. SndfileHandle keeps ownership. */ + SNDFILE * rawHandle (void) ; + + /**< Take ownership of handle, if reference count is 1. */ + SNDFILE * takeOwnership (void) ; +} ; + +/*============================================================================== +** Nothing but implementation below. +*/ + +inline +SndfileHandle::SNDFILE_ref::SNDFILE_ref (void) +: sf (NULL), sfinfo (), ref (1) +{} + +inline +SndfileHandle::SNDFILE_ref::~SNDFILE_ref (void) +{ if (sf != NULL) sf_close (sf) ; } + +inline +SndfileHandle::SndfileHandle (const char *path, int mode, int fmt, int chans, int srate) +: p (NULL) +{ + p = new (std::nothrow) SNDFILE_ref () ; + + if (p != NULL) + { p->ref = 1 ; + + p->sfinfo.frames = 0 ; + p->sfinfo.channels = chans ; + p->sfinfo.format = fmt ; + p->sfinfo.samplerate = srate ; + p->sfinfo.sections = 0 ; + p->sfinfo.seekable = 0 ; + + p->sf = sf_open (path, mode, &p->sfinfo) ; + } ; + + return ; +} /* SndfileHandle const char * constructor */ + +inline +SndfileHandle::SndfileHandle (std::string const & path, int mode, int fmt, int chans, int srate) +: p (NULL) +{ + p = new (std::nothrow) SNDFILE_ref () ; + + if (p != NULL) + { p->ref = 1 ; + + p->sfinfo.frames = 0 ; + p->sfinfo.channels = chans ; + p->sfinfo.format = fmt ; + p->sfinfo.samplerate = srate ; + p->sfinfo.sections = 0 ; + p->sfinfo.seekable = 0 ; + + p->sf = sf_open (path.c_str (), mode, &p->sfinfo) ; + } ; + + return ; +} /* SndfileHandle std::string constructor */ + +inline +SndfileHandle::SndfileHandle (int fd, bool close_desc, int mode, int fmt, int chans, int srate) +: p (NULL) +{ + if (fd < 0) + return ; + + p = new (std::nothrow) SNDFILE_ref () ; + + if (p != NULL) + { p->ref = 1 ; + + p->sfinfo.frames = 0 ; + p->sfinfo.channels = chans ; + p->sfinfo.format = fmt ; + p->sfinfo.samplerate = srate ; + p->sfinfo.sections = 0 ; + p->sfinfo.seekable = 0 ; + + p->sf = sf_open_fd (fd, mode, &p->sfinfo, close_desc) ; + } ; + + return ; +} /* SndfileHandle fd constructor */ + +inline +SndfileHandle::SndfileHandle (SF_VIRTUAL_IO &sfvirtual, void *user_data, int mode, int fmt, int chans, int srate) +: p (NULL) +{ + p = new (std::nothrow) SNDFILE_ref () ; + + if (p != NULL) + { p->ref = 1 ; + + p->sfinfo.frames = 0 ; + p->sfinfo.channels = chans ; + p->sfinfo.format = fmt ; + p->sfinfo.samplerate = srate ; + p->sfinfo.sections = 0 ; + p->sfinfo.seekable = 0 ; + + p->sf = sf_open_virtual (&sfvirtual, mode, &p->sfinfo, user_data) ; + } ; + + return ; +} /* SndfileHandle std::string constructor */ + +inline +SndfileHandle::~SndfileHandle (void) +{ if (p != NULL && --p->ref == 0) + delete p ; +} /* SndfileHandle destructor */ + + +inline +SndfileHandle::SndfileHandle (const SndfileHandle &orig) +: p (orig.p) +{ if (p != NULL) + ++p->ref ; +} /* SndfileHandle copy constructor */ + +inline SndfileHandle & +SndfileHandle::operator = (const SndfileHandle &rhs) +{ + if (&rhs == this) + return *this ; + if (p != NULL && --p->ref == 0) + delete p ; + + p = rhs.p ; + if (p != NULL) + ++p->ref ; + + return *this ; +} /* SndfileHandle assignment operator */ + +inline int +SndfileHandle::error (void) const +{ return sf_error (p->sf) ; } + +inline const char * +SndfileHandle::strError (void) const +{ return sf_strerror (p->sf) ; } + +inline int +SndfileHandle::command (int cmd, void *data, int datasize) +{ return sf_command (p->sf, cmd, data, datasize) ; } + +inline sf_count_t +SndfileHandle::seek (sf_count_t frame_count, int whence) +{ return sf_seek (p->sf, frame_count, whence) ; } + +inline void +SndfileHandle::writeSync (void) +{ sf_write_sync (p->sf) ; } + +inline int +SndfileHandle::setString (int str_type, const char* str) +{ return sf_set_string (p->sf, str_type, str) ; } + +inline const char* +SndfileHandle::getString (int str_type) const +{ return sf_get_string (p->sf, str_type) ; } + +inline int +SndfileHandle::formatCheck (int fmt, int chans, int srate) +{ + SF_INFO sfinfo ; + + sfinfo.frames = 0 ; + sfinfo.channels = chans ; + sfinfo.format = fmt ; + sfinfo.samplerate = srate ; + sfinfo.sections = 0 ; + sfinfo.seekable = 0 ; + + return sf_format_check (&sfinfo) ; +} + +/*---------------------------------------------------------------------*/ + +inline sf_count_t +SndfileHandle::read (short *ptr, sf_count_t items) +{ return sf_read_short (p->sf, ptr, items) ; } + +inline sf_count_t +SndfileHandle::read (int *ptr, sf_count_t items) +{ return sf_read_int (p->sf, ptr, items) ; } + +inline sf_count_t +SndfileHandle::read (float *ptr, sf_count_t items) +{ return sf_read_float (p->sf, ptr, items) ; } + +inline sf_count_t +SndfileHandle::read (double *ptr, sf_count_t items) +{ return sf_read_double (p->sf, ptr, items) ; } + +inline sf_count_t +SndfileHandle::write (const short *ptr, sf_count_t items) +{ return sf_write_short (p->sf, ptr, items) ; } + +inline sf_count_t +SndfileHandle::write (const int *ptr, sf_count_t items) +{ return sf_write_int (p->sf, ptr, items) ; } + +inline sf_count_t +SndfileHandle::write (const float *ptr, sf_count_t items) +{ return sf_write_float (p->sf, ptr, items) ; } + +inline sf_count_t +SndfileHandle::write (const double *ptr, sf_count_t items) +{ return sf_write_double (p->sf, ptr, items) ; } + +inline sf_count_t +SndfileHandle::readf (short *ptr, sf_count_t frame_count) +{ return sf_readf_short (p->sf, ptr, frame_count) ; } + +inline sf_count_t +SndfileHandle::readf (int *ptr, sf_count_t frame_count) +{ return sf_readf_int (p->sf, ptr, frame_count) ; } + +inline sf_count_t +SndfileHandle::readf (float *ptr, sf_count_t frame_count) +{ return sf_readf_float (p->sf, ptr, frame_count) ; } + +inline sf_count_t +SndfileHandle::readf (double *ptr, sf_count_t frame_count) +{ return sf_readf_double (p->sf, ptr, frame_count) ; } + +inline sf_count_t +SndfileHandle::writef (const short *ptr, sf_count_t frame_count) +{ return sf_writef_short (p->sf, ptr, frame_count) ; } + +inline sf_count_t +SndfileHandle::writef (const int *ptr, sf_count_t frame_count) +{ return sf_writef_int (p->sf, ptr, frame_count) ; } + +inline sf_count_t +SndfileHandle::writef (const float *ptr, sf_count_t frame_count) +{ return sf_writef_float (p->sf, ptr, frame_count) ; } + +inline sf_count_t +SndfileHandle::writef (const double *ptr, sf_count_t frame_count) +{ return sf_writef_double (p->sf, ptr, frame_count) ; } + +inline sf_count_t +SndfileHandle::readRaw (void *ptr, sf_count_t bytes) +{ return sf_read_raw (p->sf, ptr, bytes) ; } + +inline sf_count_t +SndfileHandle::writeRaw (const void *ptr, sf_count_t bytes) +{ return sf_write_raw (p->sf, ptr, bytes) ; } + +inline SNDFILE * +SndfileHandle::rawHandle (void) +{ return (p ? p->sf : NULL) ; } + +inline SNDFILE * +SndfileHandle::takeOwnership (void) +{ + if (p == NULL || (p->ref != 1)) + return NULL ; + + SNDFILE * sf = p->sf ; + p->sf = NULL ; + delete p ; + p = NULL ; + return sf ; +} + +#ifdef ENABLE_SNDFILE_WINDOWS_PROTOTYPES + +inline +SndfileHandle::SndfileHandle (LPCWSTR wpath, int mode, int fmt, int chans, int srate) +: p (NULL) +{ + p = new (std::nothrow) SNDFILE_ref () ; + + if (p != NULL) + { p->ref = 1 ; + + p->sfinfo.frames = 0 ; + p->sfinfo.channels = chans ; + p->sfinfo.format = fmt ; + p->sfinfo.samplerate = srate ; + p->sfinfo.sections = 0 ; + p->sfinfo.seekable = 0 ; + + p->sf = sf_wchar_open (wpath, mode, &p->sfinfo) ; + } ; + + return ; +} /* SndfileHandle const wchar_t * constructor */ + +#endif + +#endif /* SNDFILE_HH */ + diff --git a/libsndfile/lib/libsndfile-1.def b/libsndfile/lib/libsndfile-1.def new file mode 100644 index 00000000..4194ff3e --- /dev/null +++ b/libsndfile/lib/libsndfile-1.def @@ -0,0 +1,47 @@ +; Auto-generated by create_symbols_file.py + +LIBRARY libsndfile-1.dll +EXPORTS + +sf_command @1 +sf_open @2 +sf_close @3 +sf_seek @4 +sf_error @7 +sf_perror @8 +sf_error_str @9 +sf_error_number @10 +sf_format_check @11 +sf_read_raw @16 +sf_readf_short @17 +sf_readf_int @18 +sf_readf_float @19 +sf_readf_double @20 +sf_read_short @21 +sf_read_int @22 +sf_read_float @23 +sf_read_double @24 +sf_write_raw @32 +sf_writef_short @33 +sf_writef_int @34 +sf_writef_float @35 +sf_writef_double @36 +sf_write_short @37 +sf_write_int @38 +sf_write_float @39 +sf_write_double @40 +sf_strerror @50 +sf_get_string @60 +sf_set_string @61 +sf_version_string @68 +sf_open_fd @70 +sf_wchar_open @71 +sf_open_virtual @80 +sf_write_sync @90 +sf_set_chunk @100 +sf_get_chunk_size @101 +sf_get_chunk_data @102 +sf_get_chunk_iterator @103 +sf_next_chunk_iterator @104 +sf_current_byterate @110 + diff --git a/libsndfile/lib/libsndfile-1.lib b/libsndfile/lib/libsndfile-1.lib new file mode 100644 index 0000000000000000000000000000000000000000..cc266ecda61ed98652438b5ffaf7c265a0320ad4 GIT binary patch literal 9948 zcmcgxOK%iM5H8y!B!&dzw~Zg`2gW4C;Kw?E2r>yFAsDb0BSlf9@p>QjlJ%}NyM~Yh zxgwMkxpL%yBE&yPWO3xcfkO^CAWk`RLi)WG>ecO`V`)FL zdc65y!v0Op9GRS)nodq1viY((d1QK)_bfF7z(s&v&j4Cy0or_kj-#A<#{r1iA95Oe z1VGd|z-bT45_P^1bOWDAT}4j)697bmOPmIt0x-IUPokZi`fs5eQs1Va1$-jydCY0# zJ^<0!B~E*v12DRdPoj2Cqf-DxBPmY9PXHK|@QF0k$EoKy08!#Dry*Q3QSVJoLocz7 zv)AA!wPHbo>$3xney6Nx|9X$ zUG-p&`Y^l0o_2<3HYT2(U5!H623MEs9 zwH%3jv79z#MB9M5AR(D7E24Oh_?YIk{>fWv^Q>^~!CAJC|Io29+FJQtD62$+jb9EzQv=TZq)5 zn#cXdTuLrNiAjdSLod*tq8qAzC08ZiD3n&1VVX@PQ?X^trjogw^DBjN$(+k&DOm~& zUYK>Tg0RbspUY=dEe()U*;W9*4d7@8z<4jfL(Gtm1~J=qA|F%Q3w+){ zDs}-(^aCtm-_rqrYe+khZXs_Iv*iNPW0b!?0&r;z;Q3yF>qzZLQ=4p$EF5 z>mAJ4gxU9Pv$~PDoxH2^c!Z^>E;j}9G#kj7M)p-hYotwW>2Kf}YBD{FyQ9@1W0_(` zI|dIkN|=QaicB^~MHwowen>v48T3QrxShom7-zeB<6L_`oM&r}^IX*lE=vVAP>4dAa8RRy9kK+a zQw+sMnQNBGZnUM^S*K>(nPitLVr>V)ZtVmidB(~NTGGm1(ot}(P!~ZycMkDlC2Zvo z*eP8BUzyFy5=6FjiKPu+_E{yfTOK=Xu?vT6(x~no!9c#Y_{Xrdb)eW{dr% z!BUfzr^cE%L+_5anQbU>xj){gS18(6U82oU4mWqqM(8bzCZ93-)OOHG>#sebe=bk% zOU>qSa3WhQLi0g+kQYL)n=LsxBP5ra=Np>fyFZ_N-`N0|ZP~A3BAZ*@SQ)**n*gWq z(3>&PI^CpTpvaIIEJw_DRcZlAIZmL57w|Y7X(S zfKor23u`CUCafQ^_4c*KYiu#5^-Lv`hV?Wu>-h`U$JY&^){`}ML$8MQOv^5^o#*6a99^g4{_TWgmyMvMgJwet-W+33!Wypi3Dv06Le@3Ft*%n|V!6Le!r5rSip zwP0Z5SfbFVA1x`3#z7lHB)rJvXl^MJfQ_3aqV!2|RM$!YsMz{U%7ox%`nvIEYgp`l#99@2 zVW)-waBSO^H%hK0;gt@{T;wb4ToQnaYqL>t^_1A7yblO~#okv`)WLr^u`kHbO?>GpXKVsKLa?i`e0A3$MmUjExu-sj2p-9kQF4`oCU;F6p$#k>piR z050~TNT(|>_`?-znm0k&UIM*m=PNNMqnEEZS~_tL>Q_M z$zu2&oVd`dA2GuJ_F0JkM}(o%n%?6UMVJULOjvlKNh!V;Mrf4ou=M`6DxyXC{SP)G z-Q3o1GxBoFIW>(S7M+~b4r?dE_*#wd48k=qYZz+mcoX6Kbmle?Lk%@HUc?Tm9yRc4 G7|wr{PZzNO literal 0 HcmV?d00001 diff --git a/libsndfile/lib/pkgconfig/sndfile.pc b/libsndfile/lib/pkgconfig/sndfile.pc new file mode 100644 index 00000000..428d708a --- /dev/null +++ b/libsndfile/lib/pkgconfig/sndfile.pc @@ -0,0 +1,12 @@ +prefix=c:/devel/target/libsndfile +exec_prefix=${prefix} +libdir=${exec_prefix}/lib +includedir=${prefix}/include + +Name: sndfile +Description: A library for reading and writing audio files +Requires: +Version: 1.0.28 +Libs: -L${libdir} -lsndfile +Libs.private: Ext/libflac.la Ext/libvorbis.la Ext/libogg.la +Cflags: -I${includedir} diff --git a/mpg123/dist/libmpg123.dll b/mpg123/dist/libmpg123.dll new file mode 100644 index 0000000000000000000000000000000000000000..ccb429bfe781aad06c9d39d919e501346e7c85d4 GIT binary patch literal 150528 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 +#include + +/* Simplified large file handling. + I used to have a check here that prevents building for a library with conflicting large file setup + (application that uses 32 bit offsets with library that uses 64 bits). + While that was perfectly fine in an environment where there is one incarnation of the library, + it hurt GNU/Linux and Solaris systems with multilib where the distribution fails to provide the + correct header matching the 32 bit library (where large files need explicit support) or + the 64 bit library (where there is no distinction). + + New approach: When the app defines _FILE_OFFSET_BITS, it wants non-default large file support, + and thus functions with added suffix (mpg123_open_64). + Any mismatch will be caught at link time because of the _FILE_OFFSET_BITS setting used when + building libmpg123. Plus, there's dual mode large file support in mpg123 since 1.12 now. + Link failure is not the expected outcome of any half-sane usage anymore. + + More complication: What about client code defining _LARGEFILE64_SOURCE? It might want direct access to the _64 functions, along with the ones without suffix. Well, that's possible now via defining MPG123_NO_LARGENAME and MPG123_LARGESUFFIX, respectively, for disabling or enforcing the suffix names. +*/ + +/* + Now, the renaming of large file aware functions. + By default, it appends underscore _FILE_OFFSET_BITS (so, mpg123_seek_64 for mpg123_seek), if _FILE_OFFSET_BITS is defined. You can force a different suffix via MPG123_LARGESUFFIX (that must include the underscore), or you can just disable the whole mess by defining MPG123_NO_LARGENAME. +*/ +#if (!defined MPG123_NO_LARGENAME) && ((defined _FILE_OFFSET_BITS) || (defined MPG123_LARGESUFFIX)) + +/* Need some trickery to concatenate the value(s) of the given macro(s). */ +#define MPG123_MACROCAT_REALLY(a, b) a ## b +#define MPG123_MACROCAT(a, b) MPG123_MACROCAT_REALLY(a, b) +#ifndef MPG123_LARGESUFFIX +#define MPG123_LARGESUFFIX MPG123_MACROCAT(_, _FILE_OFFSET_BITS) +#endif +#define MPG123_LARGENAME(func) MPG123_MACROCAT(func, MPG123_LARGESUFFIX) + +#define mpg123_open MPG123_LARGENAME(mpg123_open) +#define mpg123_open_fd MPG123_LARGENAME(mpg123_open_fd) +#define mpg123_open_handle MPG123_LARGENAME(mpg123_open_handle) +#define mpg123_framebyframe_decode MPG123_LARGENAME(mpg123_framebyframe_decode) +#define mpg123_decode_frame MPG123_LARGENAME(mpg123_decode_frame) +#define mpg123_tell MPG123_LARGENAME(mpg123_tell) +#define mpg123_tellframe MPG123_LARGENAME(mpg123_tellframe) +#define mpg123_tell_stream MPG123_LARGENAME(mpg123_tell_stream) +#define mpg123_seek MPG123_LARGENAME(mpg123_seek) +#define mpg123_feedseek MPG123_LARGENAME(mpg123_feedseek) +#define mpg123_seek_frame MPG123_LARGENAME(mpg123_seek_frame) +#define mpg123_timeframe MPG123_LARGENAME(mpg123_timeframe) +#define mpg123_index MPG123_LARGENAME(mpg123_index) +#define mpg123_set_index MPG123_LARGENAME(mpg123_set_index) +#define mpg123_position MPG123_LARGENAME(mpg123_position) +#define mpg123_length MPG123_LARGENAME(mpg123_length) +#define mpg123_set_filesize MPG123_LARGENAME(mpg123_set_filesize) +#define mpg123_replace_reader MPG123_LARGENAME(mpg123_replace_reader) +#define mpg123_replace_reader_handle MPG123_LARGENAME(mpg123_replace_reader_handle) + +#endif /* largefile hackery */ + +#endif /* MPG123_NO_CONFIGURE */ + +#ifdef __cplusplus +extern "C" { +#endif + +/** \defgroup mpg123_init mpg123 library and handle setup + * + * Functions to initialise and shutdown the mpg123 library and handles. + * The parameters of handles have workable defaults, you only have to tune them when you want to tune something;-) + * Tip: Use a RVA setting... + * + * @{ + */ + +/** Opaque structure for the libmpg123 decoder handle. */ +struct mpg123_handle_struct; + +/** Opaque structure for the libmpg123 decoder handle. + * Most functions take a pointer to a mpg123_handle as first argument and operate on its data in an object-oriented manner. + */ +typedef struct mpg123_handle_struct mpg123_handle; + +/** Function to initialise the mpg123 library. + * This function is not thread-safe. Call it exactly once per process, before any other (possibly threaded) work with the library. + * + * \return MPG123_OK if successful, otherwise an error number. + */ +EXPORT int mpg123_init(void); + +/** Function to close down the mpg123 library. + * This function is not thread-safe. Call it exactly once per process, before any other (possibly threaded) work with the library. */ +EXPORT void mpg123_exit(void); + +/** Create a handle with optional choice of decoder (named by a string, see mpg123_decoders() or mpg123_supported_decoders()). + * and optional retrieval of an error code to feed to mpg123_plain_strerror(). + * Optional means: Any of or both the parameters may be NULL. + * + * \return Non-NULL pointer when successful. + */ +EXPORT mpg123_handle *mpg123_new(const char* decoder, int *error); + +/** Delete handle, mh is either a valid mpg123 handle or NULL. */ +EXPORT void mpg123_delete(mpg123_handle *mh); + +/** Enumeration of the parameters types that it is possible to set/get. */ +enum mpg123_parms +{ + MPG123_VERBOSE, /**< set verbosity value for enabling messages to stderr, >= 0 makes sense (integer) */ + MPG123_FLAGS, /**< set all flags, p.ex val = MPG123_GAPLESS|MPG123_MONO_MIX (integer) */ + MPG123_ADD_FLAGS, /**< add some flags (integer) */ + MPG123_FORCE_RATE, /**< when value > 0, force output rate to that value (integer) */ + MPG123_DOWN_SAMPLE, /**< 0=native rate, 1=half rate, 2=quarter rate (integer) */ + MPG123_RVA, /**< one of the RVA choices above (integer) */ + MPG123_DOWNSPEED, /**< play a frame N times (integer) */ + MPG123_UPSPEED, /**< play every Nth frame (integer) */ + MPG123_START_FRAME, /**< start with this frame (skip frames before that, integer) */ + MPG123_DECODE_FRAMES, /**< decode only this number of frames (integer) */ + MPG123_ICY_INTERVAL, /**< stream contains ICY metadata with this interval (integer) */ + MPG123_OUTSCALE, /**< the scale for output samples (amplitude - integer or float according to mpg123 output format, normally integer) */ + MPG123_TIMEOUT, /**< timeout for reading from a stream (not supported on win32, integer) */ + MPG123_REMOVE_FLAGS, /**< remove some flags (inverse of MPG123_ADD_FLAGS, integer) */ + MPG123_RESYNC_LIMIT, /**< Try resync on frame parsing for that many bytes or until end of stream (<0 ... integer). */ + MPG123_INDEX_SIZE /**< Set the frame index size (if supported). Values <0 mean that the index is allowed to grow dynamically in these steps (in positive direction, of course) -- Use this when you really want a full index with every individual frame. */ + ,MPG123_PREFRAMES /**< Decode/ignore that many frames in advance for layer 3. This is needed to fill bit reservoir after seeking, for example (but also at least one frame in advance is needed to have all "normal" data for layer 3). Give a positive integer value, please.*/ +}; + +/** Flag bits for MPG123_FLAGS, use the usual binary or to combine. */ +enum mpg123_param_flags +{ + MPG123_FORCE_MONO = 0x7 /**< 0111 Force some mono mode: This is a test bitmask for seeing if any mono forcing is active. */ + ,MPG123_MONO_LEFT = 0x1 /**< 0001 Force playback of left channel only. */ + ,MPG123_MONO_RIGHT = 0x2 /**< 0010 Force playback of right channel only. */ + ,MPG123_MONO_MIX = 0x4 /**< 0100 Force playback of mixed mono. */ + ,MPG123_FORCE_STEREO = 0x8 /**< 1000 Force stereo output. */ + ,MPG123_FORCE_8BIT = 0x10 /**< 00010000 Force 8bit formats. */ + ,MPG123_QUIET = 0x20 /**< 00100000 Suppress any printouts (overrules verbose). */ + ,MPG123_GAPLESS = 0x40 /**< 01000000 Enable gapless decoding (default on if libmpg123 has support). */ + ,MPG123_NO_RESYNC = 0x80 /**< 10000000 Disable resync stream after error. */ + ,MPG123_SEEKBUFFER = 0x100 /**< 000100000000 Enable small buffer on non-seekable streams to allow some peek-ahead (for better MPEG sync). */ + ,MPG123_FUZZY = 0x200 /**< 001000000000 Enable fuzzy seeks (guessing byte offsets or using approximate seek points from Xing TOC) */ + ,MPG123_FORCE_FLOAT = 0x400 /**< 010000000000 Force floating point output (32 or 64 bits depends on mpg123 internal precision). */ + ,MPG123_PLAIN_ID3TEXT = 0x800 /**< 100000000000 Do not translate ID3 text data to UTF-8. ID3 strings will contain the raw text data, with the first byte containing the ID3 encoding code. */ + ,MPG123_IGNORE_STREAMLENGTH = 0x1000 /**< 1000000000000 Ignore any stream length information contained in the stream, which can be contained in a 'TLEN' frame of an ID3v2 tag or a Xing tag */ + ,MPG123_SKIP_ID3V2 = 0x2000 /**< 10 0000 0000 0000 Do not parse ID3v2 tags, just skip them. */ +}; + +/** choices for MPG123_RVA */ +enum mpg123_param_rva +{ + MPG123_RVA_OFF = 0 /**< RVA disabled (default). */ + ,MPG123_RVA_MIX = 1 /**< Use mix/track/radio gain. */ + ,MPG123_RVA_ALBUM = 2 /**< Use album/audiophile gain */ + ,MPG123_RVA_MAX = MPG123_RVA_ALBUM /**< The maximum RVA code, may increase in future. */ +}; + +/* TODO: Assess the possibilities and troubles of changing parameters during playback. */ + +/** Set a specific parameter, for a specific mpg123_handle, using a parameter + * type key chosen from the mpg123_parms enumeration, to the specified value. */ +EXPORT int mpg123_param(mpg123_handle *mh, enum mpg123_parms type, long value, double fvalue); + +/** Get a specific parameter, for a specific mpg123_handle. + * See the mpg123_parms enumeration for a list of available parameters. */ +EXPORT int mpg123_getparam(mpg123_handle *mh, enum mpg123_parms type, long *val, double *fval); + +/** Feature set available for query with mpg123_feature. */ +enum mpg123_feature_set +{ + MPG123_FEATURE_ABI_UTF8OPEN = 0 /**< mpg123 expects path names to be given in UTF-8 encoding instead of plain native. */ + ,MPG123_FEATURE_OUTPUT_8BIT /**< 8bit output */ + ,MPG123_FEATURE_OUTPUT_16BIT /**< 16bit output */ + ,MPG123_FEATURE_OUTPUT_32BIT /**< 32bit output */ + ,MPG123_FEATURE_INDEX /**< support for building a frame index for accurate seeking */ + ,MPG123_FEATURE_PARSE_ID3V2 /**< id3v2 parsing */ + ,MPG123_FEATURE_DECODE_LAYER1 /**< mpeg layer-1 decoder enabled */ + ,MPG123_FEATURE_DECODE_LAYER2 /**< mpeg layer-2 decoder enabled */ + ,MPG123_FEATURE_DECODE_LAYER3 /**< mpeg layer-3 decoder enabled */ + ,MPG123_FEATURE_DECODE_ACCURATE /**< accurate decoder rounding */ + ,MPG123_FEATURE_DECODE_DOWNSAMPLE /**< downsample (sample omit) */ + ,MPG123_FEATURE_DECODE_NTOM /**< flexible rate decoding */ + ,MPG123_FEATURE_PARSE_ICY /**< ICY support */ + ,MPG123_FEATURE_TIMEOUT_READ /**< Reader with timeout (network). */ +}; + +/** Query libmpg123 feature, 1 for success, 0 for unimplemented functions. */ +EXPORT int mpg123_feature(const enum mpg123_feature_set key); + +/* @} */ + + +/** \defgroup mpg123_error mpg123 error handling + * + * Functions to get text version of the error numbers and an enumeration + * of the error codes returned by libmpg123. + * + * Most functions operating on a mpg123_handle simply return MPG123_OK on success and MPG123_ERR on failure (setting the internal error variable of the handle to the specific error code). + * Decoding/seek functions may also return message codes MPG123_DONE, MPG123_NEW_FORMAT and MPG123_NEED_MORE (please read up on these on how to react!). + * The positive range of return values is used for "useful" values when appropriate. + * + * @{ + */ + +/** Enumeration of the message and error codes and returned by libmpg123 functions. */ +enum mpg123_errors +{ + MPG123_DONE=-12, /**< Message: Track ended. Stop decoding. */ + MPG123_NEW_FORMAT=-11, /**< Message: Output format will be different on next call. Note that some libmpg123 versions between 1.4.3 and 1.8.0 insist on you calling mpg123_getformat() after getting this message code. Newer verisons behave like advertised: You have the chance to call mpg123_getformat(), but you can also just continue decoding and get your data. */ + MPG123_NEED_MORE=-10, /**< Message: For feed reader: "Feed me more!" (call mpg123_feed() or mpg123_decode() with some new input data). */ + MPG123_ERR=-1, /**< Generic Error */ + MPG123_OK=0, /**< Success */ + MPG123_BAD_OUTFORMAT, /**< Unable to set up output format! */ + MPG123_BAD_CHANNEL, /**< Invalid channel number specified. */ + MPG123_BAD_RATE, /**< Invalid sample rate specified. */ + MPG123_ERR_16TO8TABLE, /**< Unable to allocate memory for 16 to 8 converter table! */ + MPG123_BAD_PARAM, /**< Bad parameter id! */ + MPG123_BAD_BUFFER, /**< Bad buffer given -- invalid pointer or too small size. */ + MPG123_OUT_OF_MEM, /**< Out of memory -- some malloc() failed. */ + MPG123_NOT_INITIALIZED, /**< You didn't initialize the library! */ + MPG123_BAD_DECODER, /**< Invalid decoder choice. */ + MPG123_BAD_HANDLE, /**< Invalid mpg123 handle. */ + MPG123_NO_BUFFERS, /**< Unable to initialize frame buffers (out of memory?). */ + MPG123_BAD_RVA, /**< Invalid RVA mode. */ + MPG123_NO_GAPLESS, /**< This build doesn't support gapless decoding. */ + MPG123_NO_SPACE, /**< Not enough buffer space. */ + MPG123_BAD_TYPES, /**< Incompatible numeric data types. */ + MPG123_BAD_BAND, /**< Bad equalizer band. */ + MPG123_ERR_NULL, /**< Null pointer given where valid storage address needed. */ + MPG123_ERR_READER, /**< Error reading the stream. */ + MPG123_NO_SEEK_FROM_END,/**< Cannot seek from end (end is not known). */ + MPG123_BAD_WHENCE, /**< Invalid 'whence' for seek function.*/ + MPG123_NO_TIMEOUT, /**< Build does not support stream timeouts. */ + MPG123_BAD_FILE, /**< File access error. */ + MPG123_NO_SEEK, /**< Seek not supported by stream. */ + MPG123_NO_READER, /**< No stream opened. */ + MPG123_BAD_PARS, /**< Bad parameter handle. */ + MPG123_BAD_INDEX_PAR, /**< Bad parameters to mpg123_index() and mpg123_set_index() */ + MPG123_OUT_OF_SYNC, /**< Lost track in bytestream and did not try to resync. */ + MPG123_RESYNC_FAIL, /**< Resync failed to find valid MPEG data. */ + MPG123_NO_8BIT, /**< No 8bit encoding possible. */ + MPG123_BAD_ALIGN, /**< Stack aligmnent error */ + MPG123_NULL_BUFFER, /**< NULL input buffer with non-zero size... */ + MPG123_NO_RELSEEK, /**< Relative seek not possible (screwed up file offset) */ + MPG123_NULL_POINTER, /**< You gave a null pointer somewhere where you shouldn't have. */ + MPG123_BAD_KEY, /**< Bad key value given. */ + MPG123_NO_INDEX, /**< No frame index in this build. */ + MPG123_INDEX_FAIL, /**< Something with frame index went wrong. */ + MPG123_BAD_DECODER_SETUP, /**< Something prevents a proper decoder setup */ + MPG123_MISSING_FEATURE /**< This feature has not been built into libmpg123. */ + ,MPG123_BAD_VALUE /**< A bad value has been given, somewhere. */ + ,MPG123_LSEEK_FAILED /**< Low-level seek failed. */ + ,MPG123_BAD_CUSTOM_IO /**< Custom I/O not prepared. */ + ,MPG123_LFS_OVERFLOW /**< Offset value overflow during translation of large file API calls -- your client program cannot handle that large file. */ +}; + +/** Return a string describing that error errcode means. */ +EXPORT const char* mpg123_plain_strerror(int errcode); + +/** Give string describing what error has occured in the context of handle mh. + * When a function operating on an mpg123 handle returns MPG123_ERR, you should check for the actual reason via + * char *errmsg = mpg123_strerror(mh) + * This function will catch mh == NULL and return the message for MPG123_BAD_HANDLE. */ +EXPORT const char* mpg123_strerror(mpg123_handle *mh); + +/** Return the plain errcode intead of a string. */ +EXPORT int mpg123_errcode(mpg123_handle *mh); + +/*@}*/ + + +/** \defgroup mpg123_decoder mpg123 decoder selection + * + * Functions to list and select the available decoders. + * Perhaps the most prominent feature of mpg123: You have several (optimized) decoders to choose from (on x86 and PPC (MacOS) systems, that is). + * + * @{ + */ + +/** Return a NULL-terminated array of generally available decoder names (plain 8bit ASCII). */ +EXPORT const char **mpg123_decoders(void); + +/** Return a NULL-terminated array of the decoders supported by the CPU (plain 8bit ASCII). */ +EXPORT const char **mpg123_supported_decoders(void); + +/** Set the chosen decoder to 'decoder_name' */ +EXPORT int mpg123_decoder(mpg123_handle *mh, const char* decoder_name); + +/** Get the currently active decoder engine name. + The active decoder engine can vary depening on output constraints, + mostly non-resampling, integer output is accelerated via 3DNow & Co. but for other modes a fallback engine kicks in. + Note that this can return a decoder that is ony active in the hidden and not available as decoder choice from the outside. + \return The decoder name or NULL on error. */ +EXPORT const char* mpg123_current_decoder(mpg123_handle *mh); + +/*@}*/ + + +/** \defgroup mpg123_output mpg123 output audio format + * + * Functions to get and select the format of the decoded audio. + * + * @{ + */ + +/** An enum over all sample types possibly known to mpg123. + * The values are designed as bit flags to allow bitmasking for encoding families. + * + * Note that (your build of) libmpg123 does not necessarily support all these. + * Usually, you can expect the 8bit encodings and signed 16 bit. + * Also 32bit float will be usual beginning with mpg123-1.7.0 . + * What you should bear in mind is that (SSE, etc) optimized routines may be absent + * for some formats. We do have SSE for 16, 32 bit and float, though. + * 24 bit integer is done via postprocessing of 32 bit output -- just cutting + * the last byte, no rounding, even. If you want better, do it yourself. + * + * All formats are in native byte order. If you need different endinaness, you + * can simply postprocess the output buffers (libmpg123 wouldn't do anything else). + * mpg123_encsize() can be helpful there. + */ +enum mpg123_enc_enum +{ + MPG123_ENC_8 = 0x00f /**< 0000 0000 1111 Some 8 bit integer encoding. */ + ,MPG123_ENC_16 = 0x040 /**< 0000 0100 0000 Some 16 bit integer encoding. */ + ,MPG123_ENC_24 = 0x4000 /**< 0100 0000 0000 0000 Some 24 bit integer encoding. */ + ,MPG123_ENC_32 = 0x100 /**< 0001 0000 0000 Some 32 bit integer encoding. */ + ,MPG123_ENC_SIGNED = 0x080 /**< 0000 1000 0000 Some signed integer encoding. */ + ,MPG123_ENC_FLOAT = 0xe00 /**< 1110 0000 0000 Some float encoding. */ + ,MPG123_ENC_SIGNED_16 = (MPG123_ENC_16|MPG123_ENC_SIGNED|0x10) /**< 1101 0000 signed 16 bit */ + ,MPG123_ENC_UNSIGNED_16 = (MPG123_ENC_16|0x20) /**< 0110 0000 unsigned 16 bit */ + ,MPG123_ENC_UNSIGNED_8 = 0x01 /**< 0000 0001 unsigned 8 bit */ + ,MPG123_ENC_SIGNED_8 = (MPG123_ENC_SIGNED|0x02) /**< 1000 0010 signed 8 bit */ + ,MPG123_ENC_ULAW_8 = 0x04 /**< 0000 0100 ulaw 8 bit */ + ,MPG123_ENC_ALAW_8 = 0x08 /**< 0000 1000 alaw 8 bit */ + ,MPG123_ENC_SIGNED_32 = MPG123_ENC_32|MPG123_ENC_SIGNED|0x1000 /**< 0001 0001 1000 0000 signed 32 bit */ + ,MPG123_ENC_UNSIGNED_32 = MPG123_ENC_32|0x2000 /**< 0010 0001 0000 0000 unsigned 32 bit */ + ,MPG123_ENC_SIGNED_24 = MPG123_ENC_24|MPG123_ENC_SIGNED|0x1000 /**< 0101 0000 1000 0000 signed 24 bit */ + ,MPG123_ENC_UNSIGNED_24 = MPG123_ENC_24|0x2000 /**< 0110 0000 0000 0000 unsigned 24 bit */ + ,MPG123_ENC_FLOAT_32 = 0x200 /**< 0010 0000 0000 32bit float */ + ,MPG123_ENC_FLOAT_64 = 0x400 /**< 0100 0000 0000 64bit float */ + ,MPG123_ENC_ANY = ( MPG123_ENC_SIGNED_16 | MPG123_ENC_UNSIGNED_16 | MPG123_ENC_UNSIGNED_8 + | MPG123_ENC_SIGNED_8 | MPG123_ENC_ULAW_8 | MPG123_ENC_ALAW_8 + | MPG123_ENC_SIGNED_32 | MPG123_ENC_UNSIGNED_32 + | MPG123_ENC_SIGNED_24 | MPG123_ENC_UNSIGNED_24 + | MPG123_ENC_FLOAT_32 | MPG123_ENC_FLOAT_64 ) /**< Any encoding on the list. */ +}; + +/** They can be combined into one number (3) to indicate mono and stereo... */ +enum mpg123_channelcount +{ + MPG123_MONO = 1 + ,MPG123_STEREO = 2 +}; + +/** An array of supported standard sample rates + * These are possible native sample rates of MPEG audio files. + * You can still force mpg123 to resample to a different one, but by default you will only get audio in one of these samplings. + * \param list Store a pointer to the sample rates array there. + * \param number Store the number of sample rates there. */ +EXPORT void mpg123_rates(const long **list, size_t *number); + +/** An array of supported audio encodings. + * An audio encoding is one of the fully qualified members of mpg123_enc_enum (MPG123_ENC_SIGNED_16, not MPG123_SIGNED). + * \param list Store a pointer to the encodings array there. + * \param number Store the number of encodings there. */ +EXPORT void mpg123_encodings(const int **list, size_t *number); + +/** Return the size (in bytes) of one mono sample of the named encoding. + * \param encoding The encoding value to analyze. + * \return positive size of encoding in bytes, 0 on invalid encoding. */ +EXPORT int mpg123_encsize(int encoding); + +/** Configure a mpg123 handle to accept no output format at all, + * use before specifying supported formats with mpg123_format */ +EXPORT int mpg123_format_none(mpg123_handle *mh); + +/** Configure mpg123 handle to accept all formats + * (also any custom rate you may set) -- this is default. */ +EXPORT int mpg123_format_all(mpg123_handle *mh); + +/** Set the audio format support of a mpg123_handle in detail: + * \param mh audio decoder handle + * \param rate The sample rate value (in Hertz). + * \param channels A combination of MPG123_STEREO and MPG123_MONO. + * \param encodings A combination of accepted encodings for rate and channels, p.ex MPG123_ENC_SIGNED16 | MPG123_ENC_ULAW_8 (or 0 for no support). Please note that some encodings may not be supported in the library build and thus will be ignored here. + * \return MPG123_OK on success, MPG123_ERR if there was an error. */ +EXPORT int mpg123_format(mpg123_handle *mh, long rate, int channels, int encodings); + +/** Check to see if a specific format at a specific rate is supported + * by mpg123_handle. + * \return 0 for no support (that includes invalid parameters), MPG123_STEREO, + * MPG123_MONO or MPG123_STEREO|MPG123_MONO. */ +EXPORT int mpg123_format_support(mpg123_handle *mh, long rate, int encoding); + +/** Get the current output format written to the addresses givenr. */ +EXPORT int mpg123_getformat(mpg123_handle *mh, long *rate, int *channels, int *encoding); + +/*@}*/ + + +/** \defgroup mpg123_input mpg123 file input and decoding + * + * Functions for input bitstream and decoding operations. + * Decoding/seek functions may also return message codes MPG123_DONE, MPG123_NEW_FORMAT and MPG123_NEED_MORE (please read up on these on how to react!). + * @{ + */ + +/* reading samples / triggering decoding, possible return values: */ +/** Enumeration of the error codes returned by libmpg123 functions. */ + +/** Open and prepare to decode the specified file by filesystem path. + * This does not open HTTP urls; libmpg123 contains no networking code. + * If you want to decode internet streams, use mpg123_open_fd() or mpg123_open_feed(). + */ +EXPORT int mpg123_open(mpg123_handle *mh, const char *path); + +/** Use an already opened file descriptor as the bitstream input + * mpg123_close() will _not_ close the file descriptor. + */ +EXPORT int mpg123_open_fd(mpg123_handle *mh, int fd); + +/** Use an opaque handle as bitstream input. This works only with the + * replaced I/O from mpg123_replace_reader_handle()! + * mpg123_close() will call the cleanup callback for your handle (if you gave one). + */ +EXPORT int mpg123_open_handle(mpg123_handle *mh, void *iohandle); + +/** Open a new bitstream and prepare for direct feeding + * This works together with mpg123_decode(); you are responsible for reading and feeding the input bitstream. + */ +EXPORT int mpg123_open_feed(mpg123_handle *mh); + +/** Closes the source, if libmpg123 opened it. */ +EXPORT int mpg123_close(mpg123_handle *mh); + +/** Read from stream and decode up to outmemsize bytes. + * \param outmemory address of output buffer to write to + * \param outmemsize maximum number of bytes to write + * \param done address to store the number of actually decoded bytes to + * \return error/message code (watch out for MPG123_DONE and friends!) */ +EXPORT int mpg123_read(mpg123_handle *mh, unsigned char *outmemory, size_t outmemsize, size_t *done); + +/** Feed data for a stream that has been opened with mpg123_open_feed(). + * It's give and take: You provide the bytestream, mpg123 gives you the decoded samples. + * \param in input buffer + * \param size number of input bytes + * \return error/message code. */ +EXPORT int mpg123_feed(mpg123_handle *mh, const unsigned char *in, size_t size); + +/** Decode MPEG Audio from inmemory to outmemory. + * This is very close to a drop-in replacement for old mpglib. + * When you give zero-sized output buffer the input will be parsed until + * decoded data is available. This enables you to get MPG123_NEW_FORMAT (and query it) + * without taking decoded data. + * Think of this function being the union of mpg123_read() and mpg123_feed() (which it actually is, sort of;-). + * You can actually always decide if you want those specialized functions in separate steps or one call this one here. + * \param inmemory input buffer + * \param inmemsize number of input bytes + * \param outmemory output buffer + * \param outmemsize maximum number of output bytes + * \param done address to store the number of actually decoded bytes to + * \return error/message code (watch out especially for MPG123_NEED_MORE) + */ +EXPORT int mpg123_decode(mpg123_handle *mh, const unsigned char *inmemory, size_t inmemsize, unsigned char *outmemory, size_t outmemsize, size_t *done); + +/** Decode next MPEG frame to internal buffer + * or read a frame and return after setting a new format. + * \param num current frame offset gets stored there + * \param audio This pointer is set to the internal buffer to read the decoded audio from. + * \param bytes number of output bytes ready in the buffer + */ +EXPORT int mpg123_decode_frame(mpg123_handle *mh, off_t *num, unsigned char **audio, size_t *bytes); + +/** Decode current MPEG frame to internal buffer. + * Warning: This is experimental API that might change in future releases! + * Please watch mpg123 development closely when using it. + * \param num last frame offset gets stored there + * \param audio this pointer is set to the internal buffer to read the decoded audio from. + * \param bytes number of output bytes ready in the buffer + */ +EXPORT int mpg123_framebyframe_decode(mpg123_handle *mh, off_t *num, unsigned char **audio, size_t *bytes); + +/** Find, read and parse the next mp3 frame + * Warning: This is experimental API that might change in future releases! + * Please watch mpg123 development closely when using it. + */ +EXPORT int mpg123_framebyframe_next(mpg123_handle *mh); + +/*@}*/ + + +/** \defgroup mpg123_seek mpg123 position and seeking + * + * Functions querying and manipulating position in the decoded audio bitstream. + * The position is measured in decoded audio samples, or MPEG frame offset for the specific functions. + * If gapless code is in effect, the positions are adjusted to compensate the skipped padding/delay - meaning, you should not care about that at all and just use the position defined for the samples you get out of the decoder;-) + * The general usage is modelled after stdlib's ftell() and fseek(). + * Especially, the whence parameter for the seek functions has the same meaning as the one for fseek() and needs the same constants from stdlib.h: + * - SEEK_SET: set position to (or near to) specified offset + * - SEEK_CUR: change position by offset from now + * - SEEK_END: set position to offset from end + * + * Note that sample-accurate seek only works when gapless support has been enabled at compile time; seek is frame-accurate otherwise. + * Also, really sample-accurate seeking (meaning that you get the identical sample value after seeking compared to plain decoding up to the position) is only guaranteed when you do not mess with the position code by using MPG123_UPSPEED, MPG123_DOWNSPEED or MPG123_START_FRAME. The first two mainly should cause trouble with NtoM resampling, but in any case with these options in effect, you have to keep in mind that the sample offset is not the same as counting the samples you get from decoding since mpg123 counts the skipped samples, too (or the samples played twice only once)! + * Short: When you care about the sample position, don't mess with those parameters;-) + * Also, seeking is not guaranteed to work for all streams (underlying stream may not support it). + * + * @{ + */ + +/** Returns the current position in samples. + * On the next read, you'd get that sample. */ +EXPORT off_t mpg123_tell(mpg123_handle *mh); + +/** Returns the frame number that the next read will give you data from. */ +EXPORT off_t mpg123_tellframe(mpg123_handle *mh); + +/** Returns the current byte offset in the input stream. */ +EXPORT off_t mpg123_tell_stream(mpg123_handle *mh); + +/** Seek to a desired sample offset. + * Set whence to SEEK_SET, SEEK_CUR or SEEK_END. + * \return The resulting offset >= 0 or error/message code */ +EXPORT off_t mpg123_seek(mpg123_handle *mh, off_t sampleoff, int whence); + +/** Seek to a desired sample offset in data feeding mode. + * This just prepares things to be right only if you ensure that the next chunk of input data will be from input_offset byte position. + * \param input_offset The position it expects to be at the + * next time data is fed to mpg123_decode(). + * \return The resulting offset >= 0 or error/message code */ +EXPORT off_t mpg123_feedseek(mpg123_handle *mh, off_t sampleoff, int whence, off_t *input_offset); + +/** Seek to a desired MPEG frame index. + * Set whence to SEEK_SET, SEEK_CUR or SEEK_END. + * \return The resulting offset >= 0 or error/message code */ +EXPORT off_t mpg123_seek_frame(mpg123_handle *mh, off_t frameoff, int whence); + +/** Return a MPEG frame offset corresponding to an offset in seconds. + * This assumes that the samples per frame do not change in the file/stream, which is a good assumption for any sane file/stream only. + * \return frame offset >= 0 or error/message code */ +EXPORT off_t mpg123_timeframe(mpg123_handle *mh, double sec); + +/** Give access to the frame index table that is managed for seeking. + * You are asked not to modify the values... Use mpg123_set_index to set the + * seek index + * \param offsets pointer to the index array + * \param step one index byte offset advances this many MPEG frames + * \param fill number of recorded index offsets; size of the array */ +EXPORT int mpg123_index(mpg123_handle *mh, off_t **offsets, off_t *step, size_t *fill); + +/** Set the frame index table + * Setting offsets to NULL and fill > 0 will allocate fill entries. Setting offsets + * to NULL and fill to 0 will clear the index and free the allocated memory used by the index. + * \param offsets pointer to the index array + * \param step one index byte offset advances this many MPEG frames + * \param fill number of recorded index offsets; size of the array */ +EXPORT int mpg123_set_index(mpg123_handle *mh, off_t *offsets, off_t step, size_t fill); + +/** Get information about current and remaining frames/seconds. + * WARNING: This function is there because of special usage by standalone mpg123 and may be removed in the final version of libmpg123! + * You provide an offset (in frames) from now and a number of output bytes + * served by libmpg123 but not yet played. You get the projected current frame + * and seconds, as well as the remaining frames/seconds. This does _not_ care + * about skipped samples due to gapless playback. */ +EXPORT int mpg123_position( mpg123_handle *mh, off_t frame_offset, off_t buffered_bytes, off_t *current_frame, off_t *frames_left, double *current_seconds, double *seconds_left); + +/*@}*/ + + +/** \defgroup mpg123_voleq mpg123 volume and equalizer + * + * @{ + */ + +enum mpg123_channels +{ + MPG123_LEFT=0x1 /**< The Left Channel. */ + ,MPG123_RIGHT=0x2 /**< The Right Channel. */ + ,MPG123_LR=0x3 /**< Both left and right channel; same as MPG123_LEFT|MPG123_RIGHT */ +}; + +/** Set the 32 Band Audio Equalizer settings. + * \param channel Can be MPG123_LEFT, MPG123_RIGHT or MPG123_LEFT|MPG123_RIGHT for both. + * \param band The equaliser band to change (from 0 to 31) + * \param val The (linear) adjustment factor. */ +EXPORT int mpg123_eq(mpg123_handle *mh, enum mpg123_channels channel, int band, double val); + +/** Get the 32 Band Audio Equalizer settings. + * \param channel Can be MPG123_LEFT, MPG123_RIGHT or MPG123_LEFT|MPG123_RIGHT for (arithmetic mean of) both. + * \param band The equaliser band to change (from 0 to 31) + * \return The (linear) adjustment factor. */ +EXPORT double mpg123_geteq(mpg123_handle *mh, enum mpg123_channels channel, int band); + +/** Reset the 32 Band Audio Equalizer settings to flat */ +EXPORT int mpg123_reset_eq(mpg123_handle *mh); + +/** Set the absolute output volume including the RVA setting, + * vol<0 just applies (a possibly changed) RVA setting. */ +EXPORT int mpg123_volume(mpg123_handle *mh, double vol); + +/** Adjust output volume including the RVA setting by chosen amount */ +EXPORT int mpg123_volume_change(mpg123_handle *mh, double change); + +/** Return current volume setting, the actual value due to RVA, and the RVA + * adjustment itself. It's all as double float value to abstract the sample + * format. The volume values are linear factors / amplitudes (not percent) + * and the RVA value is in decibels. */ +EXPORT int mpg123_getvolume(mpg123_handle *mh, double *base, double *really, double *rva_db); + +/* TODO: Set some preamp in addition / to replace internal RVA handling? */ + +/*@}*/ + + +/** \defgroup mpg123_status mpg123 status and information + * + * @{ + */ + +/** Enumeration of the mode types of Variable Bitrate */ +enum mpg123_vbr { + MPG123_CBR=0, /**< Constant Bitrate Mode (default) */ + MPG123_VBR, /**< Variable Bitrate Mode */ + MPG123_ABR /**< Average Bitrate Mode */ +}; + +/** Enumeration of the MPEG Versions */ +enum mpg123_version { + MPG123_1_0=0, /**< MPEG Version 1.0 */ + MPG123_2_0, /**< MPEG Version 2.0 */ + MPG123_2_5 /**< MPEG Version 2.5 */ +}; + + +/** Enumeration of the MPEG Audio mode. + * Only the mono mode has 1 channel, the others have 2 channels. */ +enum mpg123_mode { + MPG123_M_STEREO=0, /**< Standard Stereo. */ + MPG123_M_JOINT, /**< Joint Stereo. */ + MPG123_M_DUAL, /**< Dual Channel. */ + MPG123_M_MONO /**< Single Channel. */ +}; + + +/** Enumeration of the MPEG Audio flag bits */ +enum mpg123_flags { + MPG123_CRC=0x1, /**< The bitstream is error protected using 16-bit CRC. */ + MPG123_COPYRIGHT=0x2, /**< The bitstream is copyrighted. */ + MPG123_PRIVATE=0x4, /**< The private bit has been set. */ + MPG123_ORIGINAL=0x8 /**< The bitstream is an original, not a copy. */ +}; + +/** Data structure for storing information about a frame of MPEG Audio */ +struct mpg123_frameinfo +{ + enum mpg123_version version; /**< The MPEG version (1.0/2.0/2.5). */ + int layer; /**< The MPEG Audio Layer (MP1/MP2/MP3). */ + long rate; /**< The sampling rate in Hz. */ + enum mpg123_mode mode; /**< The audio mode (Mono, Stereo, Joint-stero, Dual Channel). */ + int mode_ext; /**< The mode extension bit flag. */ + int framesize; /**< The size of the frame (in bytes). */ + enum mpg123_flags flags; /**< MPEG Audio flag bits. Just now I realize that it should be declared as int, not enum. It's a bitwise combination of the enum values. */ + int emphasis; /**< The emphasis type. */ + int bitrate; /**< Bitrate of the frame (kbps). */ + int abr_rate; /**< The target average bitrate. */ + enum mpg123_vbr vbr; /**< The VBR mode. */ +}; + +/** Get frame information about the MPEG audio bitstream and store it in a mpg123_frameinfo structure. */ +EXPORT int mpg123_info(mpg123_handle *mh, struct mpg123_frameinfo *mi); + +/** Get the safe output buffer size for all cases (when you want to replace the internal buffer) */ +EXPORT size_t mpg123_safe_buffer(void); + +/** Make a full parsing scan of each frame in the file. ID3 tags are found. An accurate length + * value is stored. Seek index will be filled. A seek back to current position + * is performed. At all, this function refuses work when stream is + * not seekable. + * \return MPG123_OK or MPG123_ERR. + */ +EXPORT int mpg123_scan(mpg123_handle *mh); + +/** Return, if possible, the full (expected) length of current track in samples. + * \return length >= 0 or MPG123_ERR if there is no length guess possible. */ +EXPORT off_t mpg123_length(mpg123_handle *mh); + +/** Override the value for file size in bytes. + * Useful for getting sensible track length values in feed mode or for HTTP streams. + * \return MPG123_OK or MPG123_ERR */ +EXPORT int mpg123_set_filesize(mpg123_handle *mh, off_t size); + +/** Returns the time (seconds) per frame; <0 is error. */ +EXPORT double mpg123_tpf(mpg123_handle *mh); + +/** Get and reset the clip count. */ +EXPORT long mpg123_clip(mpg123_handle *mh); + + +/** The key values for state information from mpg123_getstate(). */ +enum mpg123_state +{ + MPG123_ACCURATE = 1 /**< Query if positons are currently accurate (integer value, 0 if false, 1 if true) */ +}; + +/** Get various current decoder/stream state information. + * \param key the key to identify the information to give. + * \param val the address to return (long) integer values to + * \param fval the address to return floating point values to + * \return MPG123_OK or MPG123_ERR for success + */ +EXPORT int mpg123_getstate(mpg123_handle *mh, enum mpg123_state key, long *val, double *fval); + +/*@}*/ + + +/** \defgroup mpg123_metadata mpg123 metadata handling + * + * Functions to retrieve the metadata from MPEG Audio files and streams. + * Also includes string handling functions. + * + * @{ + */ + +/** Data structure for storing strings in a safer way than a standard C-String. + * Can also hold a number of null-terminated strings. */ +typedef struct +{ + char* p; /**< pointer to the string data */ + size_t size; /**< raw number of bytes allocated */ + size_t fill; /**< number of used bytes (including closing zero byte) */ +} mpg123_string; + +/** Create and allocate memory for a new mpg123_string */ +EXPORT void mpg123_init_string(mpg123_string* sb); + +/** Free-up mempory for an existing mpg123_string */ +EXPORT void mpg123_free_string(mpg123_string* sb); + +/** Change the size of a mpg123_string + * \return 0 on error, 1 on success */ +EXPORT int mpg123_resize_string(mpg123_string* sb, size_t news); + +/** Increase size of a mpg123_string if necessary (it may stay larger). + * Note that the functions for adding and setting in current libmpg123 use this instead of mpg123_resize_string(). + * That way, you can preallocate memory and safely work afterwards with pieces. + * \return 0 on error, 1 on success */ +EXPORT int mpg123_grow_string(mpg123_string* sb, size_t news); + +/** Copy the contents of one mpg123_string string to another. + * \return 0 on error, 1 on success */ +EXPORT int mpg123_copy_string(mpg123_string* from, mpg123_string* to); + +/** Append a C-String to an mpg123_string + * \return 0 on error, 1 on success */ +EXPORT int mpg123_add_string(mpg123_string* sb, const char* stuff); + +/** Append a C-substring to an mpg123 string + * \return 0 on error, 1 on success + * \param from offset to copy from + * \param count number of characters to copy (a null-byte is always appended) */ +EXPORT int mpg123_add_substring(mpg123_string *sb, const char *stuff, size_t from, size_t count); + +/** Set the conents of a mpg123_string to a C-string + * \return 0 on error, 1 on success */ +EXPORT int mpg123_set_string(mpg123_string* sb, const char* stuff); + +/** Set the contents of a mpg123_string to a C-substring + * \return 0 on error, 1 on success + * \param from offset to copy from + * \param count number of characters to copy (a null-byte is always appended) */ +EXPORT int mpg123_set_substring(mpg123_string *sb, const char *stuff, size_t from, size_t count); + +/** Count characters in a mpg123 string (non-null bytes or UTF-8 characters). + * \return character count + * \param sb the string + * \param utf8 a flag to tell if the string is in utf8 encoding + * Even with the fill property, the character count is not obvious as there could be multiple trailing null bytes. +*/ +EXPORT size_t mpg123_strlen(mpg123_string *sb, int utf8); + +/** The mpg123 text encodings. This contains encodings we encounter in ID3 tags or ICY meta info. */ +enum mpg123_text_encoding +{ + mpg123_text_unknown = 0 /**< Unkown encoding... mpg123_id3_encoding can return that on invalid codes. */ + ,mpg123_text_utf8 = 1 /**< UTF-8 */ + ,mpg123_text_latin1 = 2 /**< ISO-8859-1. Note that sometimes latin1 in ID3 is abused for totally different encodings. */ + ,mpg123_text_icy = 3 /**< ICY metadata encoding, usually CP-1252 but we take it as UTF-8 if it qualifies as such. */ + ,mpg123_text_cp1252 = 4 /**< Really CP-1252 without any guessing. */ + ,mpg123_text_utf16 = 5 /**< Some UTF-16 encoding. The last of a set of leading BOMs (byte order mark) rules. + * When there is no BOM, big endian ordering is used. Note that UCS-2 qualifies as UTF-8 when + * you don't mess with the reserved code points. If you want to decode little endian data + * without BOM you need to prepend 0xff 0xfe yourself. */ + ,mpg123_text_utf16bom = 6 /**< Just an alias for UTF-16, ID3v2 has this as distinct code. */ + ,mpg123_text_utf16be = 7 /**< Another alias for UTF16 from ID3v2. Note, that, because of the mess that is reality, + * BOMs are used if encountered. There really is not much distinction between the UTF16 types for mpg123 + * One exception: Since this is seen in ID3v2 tags, leading null bytes are skipped for all other UTF16 + * types (we expect a BOM before real data there), not so for utf16be!*/ + ,mpg123_text_max = 7 /**< Placeholder for the maximum encoding value. */ +}; + +/** The encoding byte values from ID3v2. */ +enum mpg123_id3_enc +{ + mpg123_id3_latin1 = 0 /**< Note: This sometimes can mean anything in practice... */ + ,mpg123_id3_utf16bom = 1 /**< UTF16, UCS-2 ... it's all the same for practical purposes. */ + ,mpg123_id3_utf16be = 2 /**< Big-endian UTF-16, BOM see note for mpg123_text_utf16be. */ + ,mpg123_id3_utf8 = 3 /**< Our lovely overly ASCII-compatible 8 byte encoding for the world. */ + ,mpg123_id3_enc_max = 3 /**< Placeholder to check valid range of encoding byte. */ +}; + +/** Convert ID3 encoding byte to mpg123 encoding index. */ +EXPORT enum mpg123_text_encoding mpg123_enc_from_id3(unsigned char id3_enc_byte); + +/** Store text data in string, after converting to UTF-8 from indicated encoding + * \return 0 on error, 1 on success (on error, mpg123_free_string is called on sb) + * \param sb target string + * \param enc mpg123 text encoding value + * \param source source buffer with plain unsigned bytes (you might need to cast from char *) + * \param source_size number of bytes in the source buffer + * + * A prominent error can be that you provided an unknown encoding value, or this build of libmpg123 lacks support for certain encodings (ID3 or ICY stuff missing). + * Also, you might want to take a bit of care with preparing the data; for example, strip leading zeroes (I have seen that). + */ +EXPORT int mpg123_store_utf8(mpg123_string *sb, enum mpg123_text_encoding enc, const unsigned char *source, size_t source_size); + +/** Sub data structure for ID3v2, for storing various text fields (including comments). + * This is for ID3v2 COMM, TXXX and all the other text fields. + * Only COMM and TXXX have a description, only COMM and USLT have a language. + * You should consult the ID3v2 specification for the use of the various text fields ("frames" in ID3v2 documentation, I use "fields" here to separate from MPEG frames). */ +typedef struct +{ + char lang[3]; /**< Three-letter language code (not terminated). */ + char id[4]; /**< The ID3v2 text field id, like TALB, TPE2, ... (4 characters, no string termination). */ + mpg123_string description; /**< Empty for the generic comment... */ + mpg123_string text; /**< ... */ +} mpg123_text; + +/** Data structure for storing IDV3v2 tags. + * This structure is not a direct binary mapping with the file contents. + * The ID3v2 text frames are allowed to contain multiple strings. + * So check for null bytes until you reach the mpg123_string fill. + * All text is encoded in UTF-8. */ +typedef struct +{ + unsigned char version; /**< 3 or 4 for ID3v2.3 or ID3v2.4. */ + mpg123_string *title; /**< Title string (pointer into text_list). */ + mpg123_string *artist; /**< Artist string (pointer into text_list). */ + mpg123_string *album; /**< Album string (pointer into text_list). */ + mpg123_string *year; /**< The year as a string (pointer into text_list). */ + mpg123_string *genre; /**< Genre String (pointer into text_list). The genre string(s) may very well need postprocessing, esp. for ID3v2.3. */ + mpg123_string *comment; /**< Pointer to last encountered comment text with empty description. */ + /* Encountered ID3v2 fields are appended to these lists. + There can be multiple occurences, the pointers above always point to the last encountered data. */ + mpg123_text *comment_list; /**< Array of comments. */ + size_t comments; /**< Number of comments. */ + mpg123_text *text; /**< Array of ID3v2 text fields (including USLT) */ + size_t texts; /**< Numer of text fields. */ + mpg123_text *extra; /**< The array of extra (TXXX) fields. */ + size_t extras; /**< Number of extra text (TXXX) fields. */ +} mpg123_id3v2; + +/** Data structure for ID3v1 tags (the last 128 bytes of a file). + * Don't take anything for granted (like string termination)! + * Also note the change ID3v1.1 did: comment[28] = 0; comment[19] = track_number + * It is your task to support ID3v1 only or ID3v1.1 ...*/ +typedef struct +{ + char tag[3]; /**< Always the string "TAG", the classic intro. */ + char title[30]; /**< Title string. */ + char artist[30]; /**< Artist string. */ + char album[30]; /**< Album string. */ + char year[4]; /**< Year string. */ + char comment[30]; /**< Comment string. */ + unsigned char genre; /**< Genre index. */ +} mpg123_id3v1; + +#define MPG123_ID3 0x3 /**< 0011 There is some ID3 info. Also matches 0010 or NEW_ID3. */ +#define MPG123_NEW_ID3 0x1 /**< 0001 There is ID3 info that changed since last call to mpg123_id3. */ +#define MPG123_ICY 0xc /**< 1100 There is some ICY info. Also matches 0100 or NEW_ICY.*/ +#define MPG123_NEW_ICY 0x4 /**< 0100 There is ICY info that changed since last call to mpg123_icy. */ + +/** Query if there is (new) meta info, be it ID3 or ICY (or something new in future). + The check function returns a combination of flags. */ +EXPORT int mpg123_meta_check(mpg123_handle *mh); /* On error (no valid handle) just 0 is returned. */ + +/** Point v1 and v2 to existing data structures wich may change on any next read/decode function call. + * v1 and/or v2 can be set to NULL when there is no corresponding data. + * \return Return value is MPG123_OK or MPG123_ERR, */ +EXPORT int mpg123_id3(mpg123_handle *mh, mpg123_id3v1 **v1, mpg123_id3v2 **v2); + +/** Point icy_meta to existing data structure wich may change on any next read/decode function call. + * \return Return value is MPG123_OK or MPG123_ERR, */ +EXPORT int mpg123_icy(mpg123_handle *mh, char **icy_meta); /* same for ICY meta string */ + +/** Decode from windows-1252 (the encoding ICY metainfo used) to UTF-8. + * Note that this is very similar to mpg123_store_utf8(&sb, mpg123_text_icy, icy_text, strlen(icy_text+1)) . + * \param icy_text The input data in ICY encoding + * \return pointer to newly allocated buffer with UTF-8 data (You free() it!) */ +EXPORT char* mpg123_icy2utf8(const char* icy_text); + + +/* @} */ + + +/** \defgroup mpg123_advpar mpg123 advanced parameter API + * + * Direct access to a parameter set without full handle around it. + * Possible uses: + * - Influence behaviour of library _during_ initialization of handle (MPG123_VERBOSE). + * - Use one set of parameters for multiple handles. + * + * The functions for handling mpg123_pars (mpg123_par() and mpg123_fmt() + * family) directly return a fully qualified mpg123 error code, the ones + * operating on full handles normally MPG123_OK or MPG123_ERR, storing the + * specific error code itseld inside the handle. + * + * @{ + */ + +/** Opaque structure for the libmpg123 decoder parameters. */ +struct mpg123_pars_struct; + +/** Opaque structure for the libmpg123 decoder parameters. */ +typedef struct mpg123_pars_struct mpg123_pars; + +/** Create a handle with preset parameters. */ +EXPORT mpg123_handle *mpg123_parnew(mpg123_pars *mp, const char* decoder, int *error); + +/** Allocate memory for and return a pointer to a new mpg123_pars */ +EXPORT mpg123_pars *mpg123_new_pars(int *error); + +/** Delete and free up memory used by a mpg123_pars data structure */ +EXPORT void mpg123_delete_pars(mpg123_pars* mp); + +/** Configure mpg123 parameters to accept no output format at all, + * use before specifying supported formats with mpg123_format */ +EXPORT int mpg123_fmt_none(mpg123_pars *mp); + +/** Configure mpg123 parameters to accept all formats + * (also any custom rate you may set) -- this is default. */ +EXPORT int mpg123_fmt_all(mpg123_pars *mp); + +/** Set the audio format support of a mpg123_pars in detail: + \param rate The sample rate value (in Hertz). + \param channels A combination of MPG123_STEREO and MPG123_MONO. + \param encodings A combination of accepted encodings for rate and channels, p.ex MPG123_ENC_SIGNED16|MPG123_ENC_ULAW_8 (or 0 for no support). + \return 0 on success, -1 if there was an error. / +*/ +EXPORT int mpg123_fmt(mpg123_pars *mh, long rate, int channels, int encodings); /* 0 is good, -1 is error */ + +/** Check to see if a specific format at a specific rate is supported + * by mpg123_pars. + * \return 0 for no support (that includes invalid parameters), MPG123_STEREO, + * MPG123_MONO or MPG123_STEREO|MPG123_MONO. */ +EXPORT int mpg123_fmt_support(mpg123_pars *mh, long rate, int encoding); + +/** Set a specific parameter, for a specific mpg123_pars, using a parameter + * type key chosen from the mpg123_parms enumeration, to the specified value. */ +EXPORT int mpg123_par(mpg123_pars *mp, enum mpg123_parms type, long value, double fvalue); + +/** Get a specific parameter, for a specific mpg123_pars. + * See the mpg123_parms enumeration for a list of available parameters. */ +EXPORT int mpg123_getpar(mpg123_pars *mp, enum mpg123_parms type, long *val, double *fval); + +/* @} */ + + +/** \defgroup mpg123_lowio mpg123 low level I/O + * You may want to do tricky stuff with I/O that does not work with mpg123's default file access or you want to make it decode into your own pocket... + * + * @{ */ + +/** Replace default internal buffer with user-supplied buffer. + * Instead of working on it's own private buffer, mpg123 will directly use the one you provide for storing decoded audio. */ +EXPORT int mpg123_replace_buffer(mpg123_handle *mh, unsigned char *data, size_t size); + +/** The max size of one frame's decoded output with current settings. + * Use that to determine an appropriate minimum buffer size for decoding one frame. */ +EXPORT size_t mpg123_outblock(mpg123_handle *mh); + +/** Replace low-level stream access functions; read and lseek as known in POSIX. + * You can use this to make any fancy file opening/closing yourself, + * using mpg123_open_fd() to set the file descriptor for your read/lseek (doesn't need to be a "real" file descriptor...). + * Setting a function to NULL means that the default internal read is + * used (active from next mpg123_open call on). + * Note: As it would be troublesome to mess with this while having a file open, + * this implies mpg123_close(). */ +EXPORT int mpg123_replace_reader(mpg123_handle *mh, ssize_t (*r_read) (int, void *, size_t), off_t (*r_lseek)(int, off_t, int)); + +/** Replace I/O functions with your own ones operating on some kind of handle instead of integer descriptors. + * The handle is a void pointer, so you can pass any data you want... + * mpg123_open_handle() is the call you make to use the I/O defined here. + * There is no fallback to internal read/seek here. + * Note: As it would be troublesome to mess with this while having a file open, + * this mpg123_close() is implied here. + * \param r_read The callback for reading (behaviour like posix read). + * \param r_lseek The callback for seeking (like posix lseek). + * \param cleanup A callback to clean up an I/O handle on mpg123_close, can be NULL for none (you take care of cleaning your handles). */ +EXPORT int mpg123_replace_reader_handle(mpg123_handle *mh, ssize_t (*r_read) (void *, void *, size_t), off_t (*r_lseek)(void *, off_t, int), void (*cleanup)(void*)); + +/* @} */ + + +#ifdef __cplusplus +} +#endif + +#endif diff --git a/mpg123/include/mpg123_pre.h b/mpg123/include/mpg123_pre.h new file mode 100644 index 00000000..9c668075 --- /dev/null +++ b/mpg123/include/mpg123_pre.h @@ -0,0 +1,40 @@ +/* + mpg123_msvc: MPEG Audio Decoder library wrapper header for MS VC++ 2005 + + copyright 2008 by the mpg123 project - free software under the terms of the LGPL 2.1 + initially written by Patrick Dehne and Thomas Orgis. +*/ +#ifndef MPG123_MSVC_H +#define MPG123_MSVC_H + +#include +#include +#include + +typedef long ssize_t; +typedef __int32 int32_t; +typedef unsigned __int32 uint32_t; + +#define PRIiMAX "I64i" +typedef __int64 intmax_t; +// ftell returns long, _ftelli64 returns __int64 +// off_t is long, not __int64, use ftell +#define ftello ftell + +#define MPG123_NO_CONFIGURE +#include "mpg123.h" /* Yes, .h.in; we include the configure template! */ + +#ifdef __cplusplus +extern "C" { +#endif + + // Wrapper around mpg123_open that supports path names with unicode + // characters + EXPORT int mpg123_topen(mpg123_handle *fr, const _TCHAR *path); + EXPORT int mpg123_tclose(mpg123_handle *fr); + +#ifdef __cplusplus +} +#endif + +#endif diff --git a/mpg123/lib/libmpg123.lib b/mpg123/lib/libmpg123.lib new file mode 100644 index 0000000000000000000000000000000000000000..e355565509bff4d699b55bd29de4d2456b362202 GIT binary patch literal 19996 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 fkxPT**vUL-O-jJ6VrK(DeTh!W#Y$1^c7Y literal 0 HcmV?d00001 diff --git a/src/audio/oal/channel.cpp b/src/audio/oal/channel.cpp index d8b50161..7742a06a 100644 --- a/src/audio/oal/channel.cpp +++ b/src/audio/oal/channel.cpp @@ -1,20 +1,21 @@ #include "channel.h" #ifdef AUDIO_OAL +#include "common.h" #include "sampman.h" extern bool IsFXSupported(); CChannel::CChannel() { - alChannel = AL_NONE; + alSource = AL_NONE; alFilter = AL_FILTER_NULL; SetDefault(); } void CChannel::SetDefault() { - Buffer = AL_NONE; + alBuffer = AL_NONE; Pitch = 1.0f; Gain = 1.0f; @@ -37,17 +38,17 @@ void CChannel::Reset() void CChannel::Init(bool Is2D) { ASSERT(!HasSource()); - alGenSources(1, &alChannel); + alGenSources(1, &alSource); if ( HasSource() ) { - alSourcei(alChannel, AL_SOURCE_RELATIVE, AL_TRUE); + alSourcei(alSource, AL_SOURCE_RELATIVE, AL_TRUE); if ( IsFXSupported() ) - alSource3i(alChannel, AL_AUXILIARY_SEND_FILTER, AL_EFFECTSLOT_NULL, 0, AL_FILTER_NULL); + alSource3i(alSource, AL_AUXILIARY_SEND_FILTER, AL_EFFECTSLOT_NULL, 0, AL_FILTER_NULL); if ( Is2D ) { - alSource3f(alChannel, AL_POSITION, 0.0f, 0.0f, 0.0f); - alSourcef (alChannel, AL_GAIN, 1.0f); + alSource3f(alSource, AL_POSITION, 0.0f, 0.0f, 0.0f); + alSourcef (alSource, AL_GAIN, 1.0f); } else { @@ -64,15 +65,15 @@ void CChannel::Term() { if ( IsFXSupported() ) { - alSource3i(alChannel, AL_AUXILIARY_SEND_FILTER, AL_EFFECTSLOT_NULL, 0, AL_FILTER_NULL); + alSource3i(alSource, AL_AUXILIARY_SEND_FILTER, AL_EFFECTSLOT_NULL, 0, AL_FILTER_NULL); if(alFilter != AL_FILTER_NULL) alDeleteFilters(1,&alFilter); } - alDeleteSources(1, &alChannel); + alDeleteSources(1, &alSource); } - alChannel = AL_NONE; + alSource = AL_NONE; alFilter = AL_FILTER_NULL; } @@ -81,22 +82,22 @@ void CChannel::Start() if ( !HasSource() ) return; if ( LoopPoints[0] != 0 && LoopPoints[0] != -1 ) - alBufferiv(Buffer, AL_LOOP_POINTS_SOFT, LoopPoints); - alSourcei (alChannel, AL_BUFFER, Buffer); - alSourcePlay(alChannel); + alBufferiv(alBuffer, AL_LOOP_POINTS_SOFT, LoopPoints); + alSourcei (alSource, AL_BUFFER, alBuffer); + alSourcePlay(alSource); } void CChannel::Stop() { if ( HasSource() ) - alSourceStop(alChannel); + alSourceStop(alSource); Reset(); } bool CChannel::HasSource() { - return alChannel != AL_NONE; + return alSource != AL_NONE; } bool CChannel::IsUsed() @@ -104,7 +105,7 @@ bool CChannel::IsUsed() if ( HasSource() ) { ALint sourceState; - alGetSourcei(alChannel, AL_SOURCE_STATE, &sourceState); + alGetSourcei(alSource, AL_SOURCE_STATE, &sourceState); return sourceState == AL_PLAYING; } return false; @@ -113,13 +114,13 @@ bool CChannel::IsUsed() void CChannel::SetPitch(float pitch) { if ( !HasSource() ) return; - alSourcef(alChannel, AL_PITCH, pitch); + alSourcef(alSource, AL_PITCH, pitch); } void CChannel::SetGain(float gain) { if ( !HasSource() ) return; - alSourcef(alChannel, AL_GAIN, gain); + alSourcef(alSource, AL_GAIN, gain); } void CChannel::SetVolume(int32 vol) @@ -145,7 +146,7 @@ void CChannel::SetCurrentFreq(uint32 freq) void CChannel::SetLoopCount(int32 loopCount) // fake. TODO: { if ( !HasSource() ) return; - alSourcei(alChannel, AL_LOOPING, loopCount == 1 ? AL_FALSE : AL_TRUE); + alSourcei(alSource, AL_LOOPING, loopCount == 1 ? AL_FALSE : AL_TRUE); } void CChannel::SetLoopPoints(ALint start, ALint end) @@ -157,33 +158,33 @@ void CChannel::SetLoopPoints(ALint start, ALint end) void CChannel::SetPosition(float x, float y, float z) { if ( !HasSource() ) return; - alSource3f(alChannel, AL_POSITION, x, y, z); + alSource3f(alSource, AL_POSITION, x, y, z); } void CChannel::SetDistances(float max, float min) { if ( !HasSource() ) return; - alSourcef (alChannel, AL_MAX_DISTANCE, max); - alSourcef (alChannel, AL_REFERENCE_DISTANCE, min); - alSourcef (alChannel, AL_MAX_GAIN, 1.0f); - alSourcef (alChannel, AL_ROLLOFF_FACTOR, 1.0f); + alSourcef (alSource, AL_MAX_DISTANCE, max); + alSourcef (alSource, AL_REFERENCE_DISTANCE, min); + alSourcef (alSource, AL_MAX_GAIN, 1.0f); + alSourcef (alSource, AL_ROLLOFF_FACTOR, 1.0f); } void CChannel::SetPan(uint32 pan) { - SetPosition((pan-63)/64.0f, 0.0f, sqrtf(1.0f-SQR((pan-63)/64.0f))); + SetPosition((pan-63)/64.0f, 0.0f, Sqrt(1.0f-SQR((pan-63)/64.0f))); } void CChannel::SetBuffer(ALuint buffer) { - Buffer = buffer; + alBuffer = buffer; } void CChannel::ClearBuffer() { if ( !HasSource() ) return; SetBuffer(AL_NONE); - alSourcei(alChannel, AL_BUFFER, AL_NONE); + alSourcei(alSource, AL_BUFFER, AL_NONE); } void CChannel::SetReverbMix(ALuint slot, float mix) @@ -194,7 +195,7 @@ void CChannel::SetReverbMix(ALuint slot, float mix) Mix = mix; EAX3_SetReverbMix(alFilter, mix); - alSource3i(alChannel, AL_AUXILIARY_SEND_FILTER, slot, 0, alFilter); + alSource3i(alSource, AL_AUXILIARY_SEND_FILTER, slot, 0, alFilter); } void CChannel::UpdateReverb(ALuint slot) @@ -203,7 +204,7 @@ void CChannel::UpdateReverb(ALuint slot) if ( !HasSource() ) return; if ( alFilter == AL_FILTER_NULL ) return; EAX3_SetReverbMix(alFilter, Mix); - alSource3i(alChannel, AL_AUXILIARY_SEND_FILTER, slot, 0, alFilter); + alSource3i(alSource, AL_AUXILIARY_SEND_FILTER, slot, 0, alFilter); } #endif \ No newline at end of file diff --git a/src/audio/oal/channel.h b/src/audio/oal/channel.h index d9ffea22..4dd09ca1 100644 --- a/src/audio/oal/channel.h +++ b/src/audio/oal/channel.h @@ -10,9 +10,9 @@ class CChannel { - ALuint alChannel; + ALuint alSource; ALuint alFilter; - ALuint Buffer; + ALuint alBuffer; float Pitch, Gain; float Mix; int32 Frequency; diff --git a/src/audio/oal/stream.cpp b/src/audio/oal/stream.cpp index a65c9794..9bca0546 100644 --- a/src/audio/oal/stream.cpp +++ b/src/audio/oal/stream.cpp @@ -1,48 +1,223 @@ #include "stream.h" -#include "common.h" #ifdef AUDIO_OAL +#include "common.h" +#include "sampman.h" + +typedef long ssize_t; + +#include +#include + +#pragma comment( lib, "libsndfile-1.lib" ) +#pragma comment( lib, "libmpg123.lib" ) + +class CSndFile : public IDecoder +{ + SNDFILE *m_pfSound; + SF_INFO m_soundInfo; +public: + CSndFile(const char *path) : + m_pfSound(nil) + { + memset(&m_soundInfo, 0, sizeof(m_soundInfo)); + m_pfSound = sf_open(path, SFM_READ, &m_soundInfo); + } + + ~CSndFile() + { + if ( m_pfSound ) + { + sf_close(m_pfSound); + m_pfSound = nil; + } + } + + bool IsOpened() + { + return m_pfSound != nil; + } + + uint32 GetSampleSize() + { + return sizeof(uint16); + } + + uint32 GetSampleCount() + { + return m_soundInfo.frames; + } + + uint32 GetSampleRate() + { + return m_soundInfo.samplerate; + } + + uint32 GetChannels() + { + return m_soundInfo.channels; + } + + void Seek(uint32 milliseconds) + { + if ( !IsOpened() ) return; + sf_seek(m_pfSound, ms2samples(milliseconds), SF_SEEK_SET); + } + + uint32 Tell() + { + if ( !IsOpened() ) return 0; + return samples2ms(sf_seek(m_pfSound, 0, SF_SEEK_CUR)); + } + + uint32 Decode(void *buffer) + { + if ( !IsOpened() ) return 0; + return sf_read_short(m_pfSound, (short *)buffer, GetBufferSamples()) * GetSampleSize(); + } +}; + +class CMP3File : public IDecoder +{ + mpg123_handle *m_pMH; + bool m_bOpened; + uint32 m_nRate; + uint32 m_nChannels; +public: + CMP3File(const char *path) : + m_pMH(nil), + m_bOpened(false), + m_nRate(0), + m_nChannels(0) + { + m_pMH = mpg123_new(nil, nil); + if ( m_pMH ) + { + long rate = 0; + int channels = 0; + int encoding = 0; + + m_bOpened = mpg123_open(m_pMH, path) == MPG123_OK + && mpg123_getformat(m_pMH, &rate, &channels, &encoding) == MPG123_OK; + m_nRate = rate; + m_nChannels = channels; + + if ( IsOpened() ) + { + mpg123_format_none(m_pMH); + mpg123_format(m_pMH, rate, channels, encoding); + } + } + } + + ~CMP3File() + { + if ( m_pMH ) + { + mpg123_close(m_pMH); + mpg123_delete(m_pMH); + m_pMH = nil; + } + } + + bool IsOpened() + { + return m_bOpened; + } + + uint32 GetSampleSize() + { + return sizeof(uint16); + } + + uint32 GetSampleCount() + { + if ( !IsOpened() ) return 0; + return mpg123_length(m_pMH); + } + + uint32 GetSampleRate() + { + return m_nRate; + } + + uint32 GetChannels() + { + return m_nChannels; + } + + void Seek(uint32 milliseconds) + { + if ( !IsOpened() ) return; + mpg123_seek(m_pMH, ms2samples(milliseconds)*GetSampleSize(), SEEK_SET); + } + + uint32 Tell() + { + if ( !IsOpened() ) return 0; + return samples2ms(mpg123_tell(m_pMH)/GetSampleSize()); + } + + uint32 Decode(void *buffer) + { + if ( !IsOpened() ) return 0; + + size_t size; + int err = mpg123_read(m_pMH, (unsigned char *)buffer, GetBufferSize(), &size); + if (err != MPG123_OK && err != MPG123_DONE) return 0; + return size; + } +}; void CStream::Initialise() { - //mpg123_init(); + mpg123_init(); } void CStream::Terminate() { - //mpg123_exit(); + mpg123_exit(); } CStream::CStream(char *filename, ALuint &source, ALuint (&buffers)[NUM_STREAMBUFFERS]) : m_alSource(source), m_alBuffers(buffers), - m_nBitRate(0), - m_nFormat(0), - m_nFreq(0), - m_nLength(0), - m_nLengthMS(0), - m_nBufferSize(0), - m_pBuffer(NULL), - m_bIsOpened(false), - m_bPaused(true) + m_pBuffer(nil), + m_bPaused(false), + m_bActive(false), + m_pSoundFile(nil), + m_bReset(false), + m_nVolume(0), + m_nPan(0), + m_nPosBeforeReset(0) { strcpy(m_aFilename, filename); - //DEV("Stream %s\n", m_aFilename); - - /* - if ( true ) - { - m_nBitRate = (wBitsPerSample * nChannels * wfex.nSamplesPerSec)/1000; - m_nLength = ulDataSize; - m_nLengthMS = m_nLength*8 / m_nBitRate; - m_nBufferSize = nAvgBytesPerSec >> 2; - m_nBufferSize -= (m_nLength % wfex.nBlockAlign); - m_pBuffer = malloc(m_nBufferSize); - m_bIsOpened = true; + DEV("Stream %s\n", m_aFilename); + + if (!strcasecmp(&m_aFilename[strlen(m_aFilename) - strlen(".mp3")], ".mp3")) + m_pSoundFile = new CMP3File(m_aFilename); + else if (!strcasecmp(&m_aFilename[strlen(m_aFilename) - strlen(".wav")], ".wav")) + m_pSoundFile = new CSndFile(m_aFilename); + else + m_pSoundFile = nil; + ASSERT(m_pSoundFile != nil); + if (m_pSoundFile && m_pSoundFile->IsOpened() ) + { + m_pBuffer = malloc(m_pSoundFile->GetBufferSize()); + ASSERT(m_pBuffer!=nil); + + DEV("AvgSamplesPerSec: %d\n", m_pSoundFile->GetAvgSamplesPerSec()); + DEV("SampleCount: %d\n", m_pSoundFile->GetSampleCount()); + DEV("SampleRate: %d\n", m_pSoundFile->GetSampleRate()); + DEV("Channels: %d\n", m_pSoundFile->GetChannels()); + DEV("Buffer Samples: %d\n", m_pSoundFile->GetBufferSamples()); + DEV("Buffer sec: %f\n", (float(m_pSoundFile->GetBufferSamples()) / float(m_pSoundFile->GetChannels())/ float(m_pSoundFile->GetSampleRate()))); + DEV("Length MS: %02d:%02d\n", (m_pSoundFile->GetLength() / 1000) / 60, (m_pSoundFile->GetLength() / 1000) % 60); + return; - }*/ + } } CStream::~CStream() @@ -51,68 +226,295 @@ CStream::~CStream() } void CStream::Delete() -{ +{ + Stop(); + ClearBuffers(); + + if ( m_pSoundFile ) + { + delete m_pSoundFile; + m_pSoundFile = nil; + } + if ( m_pBuffer ) { free(m_pBuffer); - m_pBuffer = NULL; + m_pBuffer = nil; } } +bool CStream::HasSource() +{ + return m_alSource != AL_NONE; +} + bool CStream::IsOpened() { - return m_bIsOpened; + return m_pSoundFile->IsOpened(); } bool CStream::IsPlaying() { + if ( !HasSource() || !IsOpened() ) return false; + + if ( m_pSoundFile->IsOpened() && !m_bPaused ) + { + ALint sourceState; + alGetSourcei(m_alSource, AL_SOURCE_STATE, &sourceState); + if ( m_bActive || sourceState == AL_PLAYING ) + return true; + } + return false; } +void CStream::Pause() +{ + if ( !HasSource() ) return; + ALint sourceState = AL_PAUSED; + alGetSourcei(m_alSource, AL_SOURCE_STATE, &sourceState); + if (sourceState != AL_PAUSED ) + alSourcePause(m_alSource); +} + void CStream::SetPause(bool bPause) { + if ( !HasSource() ) return; + if ( bPause ) + { + Pause(); + m_bPaused = true; + } + else + { + if (m_bPaused) + SetPlay(true); + m_bPaused = false; + } +} + +void CStream::SetPitch(float pitch) +{ + if ( !HasSource() ) return; + alSourcef(m_alSource, AL_PITCH, pitch); +} + +void CStream::SetGain(float gain) +{ + if ( !HasSource() ) return; + alSourcef(m_alSource, AL_GAIN, gain); +} + +void CStream::SetPosition(float x, float y, float z) +{ + if ( !HasSource() ) return; + alSource3f(m_alSource, AL_POSITION, x, y, z); } void CStream::SetVolume(uint32 nVol) { - + m_nVolume = nVol; + SetGain(ALfloat(nVol) / MAX_VOLUME); } void CStream::SetPan(uint8 nPan) { + m_nPan = nPan; + SetPosition((nPan - 63)/64.0f, 0.0f, Sqrt(1.0f-SQR((nPan-63)/64.0f))); } -void CStream::SetPos(uint32 nPos) +void CStream::SetPosMS(uint32 nPos) { + if ( !m_pSoundFile->IsOpened() ) return; + m_pSoundFile->Seek(nPos); + ClearBuffers(); } -uint32 CStream::GetPos() +uint32 CStream::GetPosMS() { - return 0; + if ( !HasSource() ) return 0; + if ( !m_pSoundFile->IsOpened() ) return 0; + + ALint offset; + //alGetSourcei(m_alSource, AL_SAMPLE_OFFSET, &offset); + alGetSourcei(m_alSource, AL_BYTE_OFFSET, &offset); + + return m_pSoundFile->Tell() + - m_pSoundFile->samples2ms(m_pSoundFile->GetBufferSamples() * (NUM_STREAMBUFFERS-1)) + + m_pSoundFile->samples2ms(offset/m_pSoundFile->GetSampleSize()); } -uint32 CStream::GetLength() +uint32 CStream::GetLengthMS() { - return m_nLengthMS; + if ( !m_pSoundFile->IsOpened() ) return 0; + return m_pSoundFile->GetLength(); } -bool CStream::Setup() +bool CStream::FillBuffer(ALuint alBuffer) { - if ( !IsOpened() ) + if ( !HasSource() ) return false; - + if ( !m_pSoundFile->IsOpened() ) + return false; + if ( !(alBuffer != AL_NONE && alIsBuffer(alBuffer)) ) + return false; + + uint32 size = m_pSoundFile->Decode(m_pBuffer); + if( size == 0 ) + return false; + + alBufferData(alBuffer, m_pSoundFile->GetChannels() == 1 ? AL_FORMAT_MONO16 : AL_FORMAT_STEREO16, + m_pBuffer, size, m_pSoundFile->GetSampleRate()); + + return true; +} + +int32 CStream::FillBuffers() +{ + int32 i = 0; + for ( i = 0; i < NUM_STREAMBUFFERS; i++ ) + { + if ( !FillBuffer(m_alBuffers[i]) ) + break; + alSourceQueueBuffers(m_alSource, 1, &m_alBuffers[i]); + } + + return i; +} + +void CStream::ClearBuffers() +{ + if ( !HasSource() ) return; + + ALint buffersQueued; + alGetSourcei(m_alSource, AL_BUFFERS_QUEUED, &buffersQueued); + + ALuint value; + while (buffersQueued--) + alSourceUnqueueBuffers(m_alSource, 1, &value); +} + +bool CStream::Setup() +{ + if ( m_pSoundFile->IsOpened() ) + { + m_pSoundFile->Seek(0); + alSourcei(m_alSource, AL_SOURCE_RELATIVE, AL_TRUE); + //SetPosition(0.0f, 0.0f, 0.0f); + SetPitch(1.0f); + //SetPan(m_nPan); + //SetVolume(100); + } + return IsOpened(); } +void CStream::SetPlay(bool state) +{ + if ( !HasSource() ) return; + if ( state ) + { + ALint sourceState = AL_PLAYING; + alGetSourcei(m_alSource, AL_SOURCE_STATE, &sourceState); + if (sourceState != AL_PLAYING ) + alSourcePlay(m_alSource); + m_bActive = true; + } + else + { + ALint sourceState = AL_STOPPED; + alGetSourcei(m_alSource, AL_SOURCE_STATE, &sourceState); + if (sourceState != AL_STOPPED ) + alSourceStop(m_alSource); + m_bActive = false; + } +} + void CStream::Start() { + if ( !HasSource() ) return; + if ( FillBuffers() != 0 ) + SetPlay(true); +} +void CStream::Stop() +{ + if ( !HasSource() ) return; + SetPlay(false); } void CStream::Update() { if ( !IsOpened() ) return; + + if ( !HasSource() ) + return; + + if ( m_bReset ) + return; + + if ( !m_bPaused ) + { + ALint sourceState; + ALint buffersProcessed = 0; + + alGetSourcei(m_alSource, AL_SOURCE_STATE, &sourceState); + alGetSourcei(m_alSource, AL_BUFFERS_PROCESSED, &buffersProcessed); + + ALint looping = AL_FALSE; + alGetSourcei(m_alSource, AL_LOOPING, &looping); + + if ( looping == AL_TRUE ) + { + TRACE("stream set looping"); + alSourcei(m_alSource, AL_LOOPING, AL_TRUE); + } + + while( buffersProcessed-- ) + { + ALuint buffer; + + alSourceUnqueueBuffers(m_alSource, 1, &buffer); + + if ( m_bActive && FillBuffer(buffer) ) + alSourceQueueBuffers(m_alSource, 1, &buffer); + } + + if ( sourceState != AL_PLAYING ) + { + alGetSourcei(m_alSource, AL_BUFFERS_PROCESSED, &buffersProcessed); + SetPlay(buffersProcessed!=0); + } + } } +void CStream::ProviderInit() +{ + if ( m_bReset ) + { + if ( Setup() ) + { + SetPan(m_nPan); + SetVolume(m_nVolume); + SetPosMS(m_nPosBeforeReset); + if (m_bActive) + FillBuffers(); + SetPlay(m_bActive); + if ( m_bPaused ) + Pause(); + } + + m_bReset = false; + } +} + +void CStream::ProviderTerm() +{ + m_bReset = true; + m_nPosBeforeReset = GetPosMS(); + + ClearBuffers(); +} + #endif \ No newline at end of file diff --git a/src/audio/oal/stream.h b/src/audio/oal/stream.h index 666d42e0..f1e5f458 100644 --- a/src/audio/oal/stream.h +++ b/src/audio/oal/stream.h @@ -4,8 +4,56 @@ #ifdef AUDIO_OAL #include -#define NUM_STREAMBUFFERS 5 -#define STREAMBUFFER_SIZE 0x4000 +#define NUM_STREAMBUFFERS 4 + +class IDecoder +{ +public: + virtual ~IDecoder() { } + + virtual bool IsOpened() = 0; + + virtual uint32 GetSampleSize() = 0; + virtual uint32 GetSampleCount() = 0; + virtual uint32 GetSampleRate() = 0; + virtual uint32 GetChannels() = 0; + + uint32 GetAvgSamplesPerSec() + { + return GetChannels() * GetSampleRate(); + } + + uint32 ms2samples(uint32 ms) + { + return float(ms) / 1000.0f * float(GetChannels()) * float(GetSampleRate()); + } + + uint32 samples2ms(uint32 sm) + { + return float(sm) * 1000.0f / float(GetChannels()) / float(GetSampleRate()); + } + + uint32 GetBufferSamples() + { + //return (GetAvgSamplesPerSec() >> 2) - (GetSampleCount() % GetChannels()); + return (GetAvgSamplesPerSec() / 4); // 250ms + } + + uint32 GetBufferSize() + { + return GetBufferSamples() * GetSampleSize(); + } + + virtual void Seek(uint32 milliseconds) = 0; + virtual uint32 Tell() = 0; + + uint32 GetLength() + { + return float(GetSampleCount()) * 1000.0f / float(GetSampleRate()); + } + + virtual uint32 Decode(void *buffer) = 0; +}; class CStream { @@ -13,30 +61,34 @@ class CStream ALuint &m_alSource; ALuint (&m_alBuffers)[NUM_STREAMBUFFERS]; - bool m_bIsOpened; bool m_bPaused; - - uint32 m_nLength; - uint32 m_nLengthMS; - uint32 m_nBitRate; - - unsigned long m_nFormat; - unsigned long m_nFreq; + bool m_bActive; - uint32 m_nBufferSize; void *m_pBuffer; - ALint iTotalBuffersProcessed; + bool m_bReset; + uint32 m_nVolume; + uint8 m_nPan; + uint32 m_nPosBeforeReset; + + IDecoder *m_pSoundFile; + + bool HasSource(); + void SetPosition(float x, float y, float z); + void SetPitch(float pitch); + void SetGain(float gain); + void Pause(); + void SetPlay(bool state); bool FillBuffer(ALuint alBuffer); int32 FillBuffers(); + void ClearBuffers(); public: static void Initialise(); static void Terminate(); CStream(char *filename, ALuint &source, ALuint (&buffers)[NUM_STREAMBUFFERS]); ~CStream(); - void Delete(); bool IsOpened(); @@ -44,14 +96,17 @@ public: void SetPause (bool bPause); void SetVolume(uint32 nVol); void SetPan (uint8 nPan); - void SetPos (uint32 nPos); - - uint32 GetPos(); - uint32 GetLength(); + void SetPosMS (uint32 nPos); + uint32 GetPosMS(); + uint32 GetLengthMS(); bool Setup(); void Start(); + void Stop(); void Update(void); + + void ProviderInit(); + void ProviderTerm(); }; #endif \ No newline at end of file diff --git a/src/audio/sampman_oal.cpp b/src/audio/sampman_oal.cpp index 6ae1bf79..ccddaa73 100644 --- a/src/audio/sampman_oal.cpp +++ b/src/audio/sampman_oal.cpp @@ -29,7 +29,6 @@ //TODO: fix eax3 reverb //TODO: max channals //TODO: loop count -//TODO: mp3/wav stream //TODO: mp3 player #pragma comment( lib, "OpenAL32.lib" ) @@ -179,9 +178,9 @@ add_providers() defaultProvider = pDeviceList->GetDefaultDevice(); if ( defaultProvider > MAXPROVIDERS ) defaultProvider = 0; - - delete pDeviceList; } + + delete pDeviceList; } static void @@ -211,6 +210,10 @@ release_existing() for ( int32 i = 0; i < MAX_STREAMS; i++ ) { + CStream *stream = aStream[i]; + if (stream) + stream->ProviderTerm(); + alDeleteSources(1, &ALStreamSources[i]); alDeleteBuffers(NUM_STREAMBUFFERS, ALStreamBuffers[i]); } @@ -298,6 +301,10 @@ set_new_provider(int index) { alGenSources(1, &ALStreamSources[i]); alGenBuffers(NUM_STREAMBUFFERS, ALStreamBuffers[i]); + + CStream *stream = aStream[i]; + if (stream) + stream->ProviderInit(); } for ( int32 i = 0; i < SAMPLEBANK_MAX; i++ ) @@ -523,6 +530,18 @@ cSampleManager::Initialise(void) nChannelVolume[i] = 0; } + { + for ( int32 i = 0; i < MAX_STREAMS; i++ ) + { + aStream[i] = NULL; + nStreamVolume[i] = 100; + nStreamPan[i] = 63; + } + + for ( int32 i = 0; i < TOTAL_STREAMED_SOUNDS; i++ ) + nStreamLength[i] = 0; + } + { add_providers(); @@ -545,17 +564,6 @@ cSampleManager::Initialise(void) ASSERT(nSampleBankMemoryStartAddress[SAMPLEBANK_PED] != NULL); } - { - for ( int32 i = 0; i < MAX_STREAMS; i++ ) - { - aStream[i] = NULL; - nStreamVolume[i] = 100; - nStreamPan[i] = 63; - } - - for ( int32 i = 0; i < TOTAL_STREAMED_SOUNDS; i++ ) - nStreamLength[i] = 3600000; - } { _bSampmanInitialised = true; @@ -571,6 +579,25 @@ cSampleManager::Initialise(void) } } + { + + for ( int32 i = 0; i < TOTAL_STREAMED_SOUNDS; i++ ) + { + aStream[0] = new CStream(StreamedNameTable[i], ALStreamSources[0], ALStreamBuffers[0]); + + if ( aStream[0] && aStream[0]->IsOpened() ) + { + uint32 tatalms = aStream[0]->GetLengthMS(); + delete aStream[0]; + aStream[0] = NULL; + + nStreamLength[i] = tatalms; + } + else + USERERROR("Can't open '%s'\n", StreamedNameTable[i]); + } + } + LoadSampleBank(SAMPLEBANK_MAIN); return true; @@ -653,7 +680,7 @@ cSampleManager::UpdateEffectsVolume(void) if ( GetChannelUsedFlag(i) ) { if ( nChannelVolume[i] != 0 ) - aChannel[i].SetVolume(m_nEffectsFadeVolume * nChannelVolume[i] * m_nEffectsVolume >> 14); + aChannel[i].SetVolume(m_nEffectsFadeVolume*nChannelVolume[i]*m_nEffectsVolume >> 14); } } } @@ -853,7 +880,7 @@ uint32 cSampleManager::GetSampleLength(uint32 nSample) { ASSERT( nSample < TOTAL_AUDIO_SAMPLES ); - return m_aSamples[nSample].nSize >> 1; + return m_aSamples[nSample].nSize / sizeof(uint16); } bool cSampleManager::UpdateReverb(void) @@ -1018,7 +1045,7 @@ cSampleManager::SetChannelEmittingVolume(uint32 nChannel, uint32 nVolume) && MusicManager.GetCurrentTrack() != STREAMED_SOUND_NEWS_INTRO && MusicManager.GetCurrentTrack() != STREAMED_SOUND_CUTSCENE_SAL4_BDBD ) { - nChannelVolume[nChannel] >>= 2; + nChannelVolume[nChannel] = vol / 4; } // no idea, does this one looks like a bug or it's SetChannelVolume ? @@ -1060,7 +1087,7 @@ cSampleManager::SetChannelVolume(uint32 nChannel, uint32 nVolume) && MusicManager.GetCurrentTrack() != STREAMED_SOUND_NEWS_INTRO && MusicManager.GetCurrentTrack() != STREAMED_SOUND_CUTSCENE_SAL4_BDBD ) { - nChannelVolume[nChannel] >>= 2; + nChannelVolume[nChannel] = vol / 4; } aChannel[nChannel].SetVolume(m_nEffectsFadeVolume*vol*m_nEffectsVolume >> 14); @@ -1209,11 +1236,11 @@ cSampleManager::StartStreamedFile(uint8 nFile, uint32 nPos, uint8 nStream) if ( stream->IsOpened() ) { - nStreamLength[nFile] = stream->GetLength(); + nStreamLength[nFile] = stream->GetLengthMS(); if ( stream->Setup() ) { if ( nPos != 0 ) - stream->SetPos(nPos); + stream->SetPosMS(nPos); stream->Start(); } @@ -1253,7 +1280,7 @@ cSampleManager::GetStreamedFilePosition(uint8 nStream) if ( stream ) { - return stream->GetPos(); + return stream->GetPosMS(); } return 0; @@ -1270,7 +1297,7 @@ cSampleManager::SetStreamedVolumeAndPan(uint8 nVolume, uint8 nPan, uint8 nEffect if ( nPan > MAX_VOLUME ) nPan = MAX_VOLUME; - nStreamVolume[nStream] = m_nMusicFadeVolume * nVolume; + nStreamVolume[nStream] = nVolume; nStreamPan [nStream] = nPan; CStream *stream = aStream[nStream]; diff --git a/src/core/common.h b/src/core/common.h index 18f4715c..66a3ad81 100644 --- a/src/core/common.h +++ b/src/core/common.h @@ -209,6 +209,7 @@ void mysrand(unsigned int seed); void re3_debug(const char *format, ...); void re3_trace(const char *filename, unsigned int lineno, const char *func, const char *format, ...); void re3_assert(const char *expr, const char *filename, unsigned int lineno, const char *func); +void re3_usererror(const char *format, ...); #define DEBUGBREAK() __debugbreak(); @@ -216,6 +217,7 @@ void re3_assert(const char *expr, const char *filename, unsigned int lineno, con #define DEV(f, ...) re3_debug("[DEV]: " f, ## __VA_ARGS__) #define TRACE(f, ...) re3_trace(__FILE__, __LINE__, __FUNCTION__, f, ## __VA_ARGS__) #define Error(f, ...) re3_debug("[ERROR]: " f, ## __VA_ARGS__) +#define USERERROR(f, ...) re3_usererror(f, ## __VA_ARGS__) #define assert(_Expression) (void)( (!!(_Expression)) || (re3_assert(#_Expression, __FILE__, __LINE__, __FUNCTION__), 0) ) #define ASSERT assert diff --git a/src/core/re3.cpp b/src/core/re3.cpp index 2a9cbc77..b7eb6480 100644 --- a/src/core/re3.cpp +++ b/src/core/re3.cpp @@ -456,6 +456,20 @@ void re3_trace(const char *filename, unsigned int lineno, const char *func, cons OutputDebugStringA(buff); } +void re3_usererror(const char *format, ...) +{ + va_list va; + va_start(va, format); + vsprintf_s(re3_buff, re3_buffsize, format, va); + va_end(va); + + ::MessageBoxA(nil, re3_buff, "RE3 Error!", + MB_OK|MB_ICONHAND|MB_SETFOREGROUND|MB_TASKMODAL); + + raise(SIGABRT); + _exit(3); +} + #ifdef VALIDATE_SAVE_SIZE int32 _saveBufCount; #endif