From e182445593fa804b7998123d828ad9244151af02 Mon Sep 17 00:00:00 2001 From: Cameron Gutman Date: Fri, 5 Oct 2018 19:22:57 -0700 Subject: [PATCH] libsoundio audio renderer for Windows and Mac (#97) --- .gitmodules | 3 + app/app.pro | 51 +- app/streaming/audio/audio.cpp | 18 +- .../audio/renderers/portaudiorenderer.cpp | 141 -- .../audio/renderers/portaudiorenderer.h | 38 - app/streaming/audio/renderers/sdl.h | 5 - .../audio/renderers/soundioaudiorenderer.cpp | 436 ++++++ .../audio/renderers/soundioaudiorenderer.h | 36 + libs/mac/include/pa_asio.h | 150 -- libs/mac/include/pa_jack.h | 77 -- libs/mac/include/pa_linux_alsa.h | 107 -- libs/mac/include/pa_mac_core.h | 191 --- libs/mac/include/pa_win_ds.h | 95 -- libs/mac/include/pa_win_wasapi.h | 443 ------ libs/mac/include/pa_win_waveformat.h | 199 --- libs/mac/include/pa_win_wdmks.h | 137 -- libs/mac/include/pa_win_wmme.h | 185 --- libs/mac/include/portaudio.h | 1225 ----------------- libs/mac/lib/libportaudio.dylib | Bin 146896 -> 0 bytes libs/windows/include/pa_asio.h | 150 -- libs/windows/include/pa_jack.h | 77 -- libs/windows/include/pa_linux_alsa.h | 107 -- libs/windows/include/pa_mac_core.h | 191 --- libs/windows/include/pa_win_ds.h | 95 -- libs/windows/include/pa_win_wasapi.h | 443 ------ libs/windows/include/pa_win_waveformat.h | 199 --- libs/windows/include/pa_win_wdmks.h | 137 -- libs/windows/include/pa_win_wmme.h | 185 --- libs/windows/include/portaudio.h | 1225 ----------------- libs/windows/lib/x64/portaudio.dll | Bin 367616 -> 0 bytes libs/windows/lib/x64/portaudio.lib | Bin 9198 -> 0 bytes libs/windows/lib/x86/portaudio.dll | Bin 303104 -> 0 bytes libs/windows/lib/x86/portaudio.lib | Bin 9360 -> 0 bytes moonlight-qt.pro | 5 +- soundio/config.h | 0 soundio/libsoundio | 1 + soundio/soundio.pro | 101 ++ 37 files changed, 625 insertions(+), 5828 deletions(-) delete mode 100644 app/streaming/audio/renderers/portaudiorenderer.cpp delete mode 100644 app/streaming/audio/renderers/portaudiorenderer.h create mode 100644 app/streaming/audio/renderers/soundioaudiorenderer.cpp create mode 100644 app/streaming/audio/renderers/soundioaudiorenderer.h delete mode 100644 libs/mac/include/pa_asio.h delete mode 100644 libs/mac/include/pa_jack.h delete mode 100644 libs/mac/include/pa_linux_alsa.h delete mode 100644 libs/mac/include/pa_mac_core.h delete mode 100644 libs/mac/include/pa_win_ds.h delete mode 100644 libs/mac/include/pa_win_wasapi.h delete mode 100644 libs/mac/include/pa_win_waveformat.h delete mode 100644 libs/mac/include/pa_win_wdmks.h delete mode 100644 libs/mac/include/pa_win_wmme.h delete mode 100644 libs/mac/include/portaudio.h delete mode 100644 libs/mac/lib/libportaudio.dylib delete mode 100644 libs/windows/include/pa_asio.h delete mode 100644 libs/windows/include/pa_jack.h delete mode 100644 libs/windows/include/pa_linux_alsa.h delete mode 100644 libs/windows/include/pa_mac_core.h delete mode 100644 libs/windows/include/pa_win_ds.h delete mode 100644 libs/windows/include/pa_win_wasapi.h delete mode 100644 libs/windows/include/pa_win_waveformat.h delete mode 100644 libs/windows/include/pa_win_wdmks.h delete mode 100644 libs/windows/include/pa_win_wmme.h delete mode 100644 libs/windows/include/portaudio.h delete mode 100644 libs/windows/lib/x64/portaudio.dll delete mode 100644 libs/windows/lib/x64/portaudio.lib delete mode 100644 libs/windows/lib/x86/portaudio.dll delete mode 100644 libs/windows/lib/x86/portaudio.lib create mode 100644 soundio/config.h create mode 160000 soundio/libsoundio create mode 100644 soundio/soundio.pro diff --git a/.gitmodules b/.gitmodules index 2eeecaf9..42c885ce 100644 --- a/.gitmodules +++ b/.gitmodules @@ -7,3 +7,6 @@ [submodule "app/SDL_GameControllerDB"] path = app/SDL_GameControllerDB url = https://github.com/gabomdq/SDL_GameControllerDB.git +[submodule "soundio/libsoundio"] + path = soundio/libsoundio + url = https://github.com/andrewrk/libsoundio.git diff --git a/app/app.pro b/app/app.pro index fdab6e9a..e6d520c0 100644 --- a/app/app.pro +++ b/app/app.pro @@ -52,12 +52,15 @@ macx { } unix:!macx { - CONFIG += link_pkgconfig + CONFIG += link_pkgconfig soundio PKGCONFIG += openssl sdl2 opus - packagesExist(portaudio-2.0) { - PKGCONFIG += portaudio-2.0 - CONFIG += portaudio + # For libsoundio + packagesExist(libpulse) { + PKGCONFIG += libpulse + } + packagesExist(alsa) { + PKGCONFIG += alsa } packagesExist(libavcodec) { @@ -80,13 +83,17 @@ unix:!macx { } } win32 { - LIBS += -llibssl -llibcrypto -lSDL2 -lavcodec -lavutil -lopus -lportaudio - CONFIG += ffmpeg portaudio + LIBS += -llibssl -llibcrypto -lSDL2 -lavcodec -lavutil -lopus + CONFIG += ffmpeg soundio } macx { - LIBS += -lssl -lcrypto -lavcodec.58 -lavutil.56 -lopus -lportaudio -framework SDL2 + LIBS += -lssl -lcrypto -lavcodec.58 -lavutil.56 -lopus -framework SDL2 LIBS += -lobjc -framework VideoToolbox -framework AVFoundation -framework CoreVideo -framework CoreGraphics -framework CoreMedia -framework AppKit - CONFIG += ffmpeg portaudio + + # For libsoundio + LIBS += -framework CoreAudio -framework AudioUnit + + CONFIG += ffmpeg soundio } SOURCES += \ @@ -103,6 +110,7 @@ SOURCES += \ streaming/input.cpp \ streaming/session.cpp \ streaming/audio/audio.cpp \ + streaming/audio/renderers/sdlaud.cpp \ gui/computermodel.cpp \ gui/appmodel.cpp \ streaming/streamutils.cpp \ @@ -125,6 +133,7 @@ HEADERS += \ streaming/input.h \ streaming/session.h \ streaming/audio/renderers/renderer.h \ + streaming/audio/renderers/sdl.h \ gui/computermodel.h \ gui/appmodel.h \ streaming/video/decoder.h \ @@ -185,13 +194,8 @@ config_SLVideo { DEFINES += HAVE_SLVIDEO LIBS += -lSLVideo - SOURCES += \ - streaming/video/sl.cpp \ - streaming/audio/renderers/sdlaud.cpp - - HEADERS += \ - streaming/video/sl.h \ - streaming/audio/renderers/sdl.h + SOURCES += streaming/video/sl.cpp + HEADERS += streaming/video/sl.h } win32 { message(DXVA2 renderer selected) @@ -215,12 +219,12 @@ macx { streaming/video/ffmpeg-renderers/vt.h \ streaming/video/ffmpeg-renderers/pacer/displaylinkvsyncsource.h } -portaudio { - message(PortAudio audio renderer selected) +soundio { + message(libsoundio audio renderer selected) - DEFINES += HAVE_PORTAUDIO - SOURCES += streaming/audio/renderers/portaudiorenderer.cpp - HEADERS += streaming/audio/renderers/portaudiorenderer.h + DEFINES += HAVE_SOUNDIO SOUNDIO_STATIC_LIBRARY + SOURCES += streaming/audio/renderers/soundioaudiorenderer.cpp + HEADERS += streaming/audio/renderers/soundioaudiorenderer.h } RESOURCES += \ @@ -247,6 +251,13 @@ else:unix: LIBS += -L$$OUT_PWD/../qmdnsengine/ -lqmdnsengine INCLUDEPATH += $$PWD/../qmdnsengine/qmdnsengine/src/include $$PWD/../qmdnsengine DEPENDPATH += $$PWD/../qmdnsengine/qmdnsengine/src/include $$PWD/../qmdnsengine +win32:CONFIG(release, debug|release): LIBS += -L$$OUT_PWD/../soundio/release/ -lsoundio +else:win32:CONFIG(debug, debug|release): LIBS += -L$$OUT_PWD/../soundio/debug/ -lsoundio +else:unix: LIBS += -L$$OUT_PWD/../soundio/ -lsoundio + +INCLUDEPATH += $$PWD/../soundio/libsoundio +DEPENDPATH += $$PWD/../soundio/libsoundio + unix:!macx: { isEmpty(PREFIX) { PREFIX = /usr/local diff --git a/app/streaming/audio/audio.cpp b/app/streaming/audio/audio.cpp index 05587018..51aca09c 100644 --- a/app/streaming/audio/audio.cpp +++ b/app/streaming/audio/audio.cpp @@ -1,8 +1,8 @@ #include "../session.h" #include "renderers/renderer.h" -#ifdef HAVE_PORTAUDIO -#include "renderers/portaudiorenderer.h" +#ifndef Q_OS_LINUX +#include "renderers/soundioaudiorenderer.h" #else #include "renderers/sdl.h" #endif @@ -11,8 +11,8 @@ IAudioRenderer* Session::createAudioRenderer() { -#ifdef HAVE_PORTAUDIO - return new PortAudioRenderer(); +#ifndef Q_OS_LINUX + return new SoundIoAudioRenderer(); #else return new SdlAudioRenderer(); #endif @@ -101,6 +101,16 @@ void Session::arDecodeAndPlaySample(char* sampleData, int sampleLength) { int samplesDecoded; + // Set this thread to high priority to reduce + // the chance of missing our sample delivery time + if (s_ActiveSession->m_AudioSampleCount == 0) { + if (SDL_SetThreadPriority(SDL_THREAD_PRIORITY_HIGH) < 0) { + SDL_LogWarn(SDL_LOG_CATEGORY_APPLICATION, + "Unable to set audio thread to high priority: %s", + SDL_GetError()); + } + } + s_ActiveSession->m_AudioSampleCount++; if (s_ActiveSession->m_AudioRenderer != nullptr) { diff --git a/app/streaming/audio/renderers/portaudiorenderer.cpp b/app/streaming/audio/renderers/portaudiorenderer.cpp deleted file mode 100644 index fdd6b3dc..00000000 --- a/app/streaming/audio/renderers/portaudiorenderer.cpp +++ /dev/null @@ -1,141 +0,0 @@ -#include "portaudiorenderer.h" - -#include - -#include - -PortAudioRenderer::PortAudioRenderer() - : m_Stream(nullptr), - m_ChannelCount(0), - m_WriteIndex(0), - m_ReadIndex(0), - m_Started(false) -{ - PaError error = Pa_Initialize(); - if (error != paNoError) { - SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, - "Pa_Initialize() failed: %s", - Pa_GetErrorText(error)); - return; - } - - SDL_LogInfo(SDL_LOG_CATEGORY_APPLICATION, - "Initialized PortAudio: %s", - Pa_GetVersionText()); -} - -PortAudioRenderer::~PortAudioRenderer() -{ - if (m_Stream != nullptr) { - Pa_CloseStream(m_Stream); - } - - Pa_Terminate(); -} - -bool PortAudioRenderer::prepareForPlayback(const OPUS_MULTISTREAM_CONFIGURATION* opusConfig) -{ - PaStreamParameters params = {}; - - m_ChannelCount = opusConfig->channelCount; - - PaDeviceIndex outputDeviceIndex = Pa_GetDefaultOutputDevice(); - if (outputDeviceIndex == paNoDevice) { - SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, - "No output device available"); - return false; - } - - const PaDeviceInfo* deviceInfo = Pa_GetDeviceInfo(outputDeviceIndex); - if (deviceInfo == nullptr) { - SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, - "Pa_GetDeviceInfo() failed"); - return false; - } - - params.channelCount = opusConfig->channelCount; - params.sampleFormat = paInt16; - params.device = outputDeviceIndex; - params.suggestedLatency = deviceInfo->defaultLowOutputLatency; - - PaError error = Pa_OpenStream(&m_Stream, nullptr, ¶ms, - opusConfig->sampleRate, - SAMPLES_PER_FRAME, - paNoFlag, - paStreamCallback, this); - if (error != paNoError) { - m_Stream = nullptr; - SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, - "Pa_OpenStream() failed: %s", - Pa_GetErrorText(error)); - return false; - } - - return true; -} - -bool PortAudioRenderer::submitAudio(short* audioBuffer, int audioSize) -{ - SDL_assert(audioSize == SAMPLES_PER_FRAME * m_ChannelCount * 2); - - // Check if there is space for this sample in the buffer. Again, this can race - // but in the worst case, we'll not see the sample callback having consumed a sample. - if (((m_WriteIndex + 1) % CIRCULAR_BUFFER_SIZE) == m_ReadIndex) { - return true; - } - - SDL_memcpy(&m_AudioBuffer[m_WriteIndex * CIRCULAR_BUFFER_STRIDE], audioBuffer, audioSize); - - // Fence with release semantics ensures m_AudioBuffer[m_WriteIndex] is written before the - // consumer observes m_WriteIndex incrementing. - std::atomic_thread_fence(std::memory_order_release); - - // This can race with the reader in the sample callback, however this is a benign - // race since we'll either read the original value of m_WriteIndex (which is safe, - // we just won't consider this sample) or the new value of m_WriteIndex - m_WriteIndex = (m_WriteIndex + 1) % CIRCULAR_BUFFER_SIZE; - - // Start the stream after we've written the first sample to it - if (!m_Started) { - PaError error = Pa_StartStream(m_Stream); - if (error != paNoError) { - SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, - "Pa_StartStream() failed: %s", - Pa_GetErrorText(error)); - return false; - } - - m_Started = true; - } - - return true; -} - -int PortAudioRenderer::paStreamCallback(const void*, void* output, unsigned long frameCount, const PaStreamCallbackTimeInfo*, PaStreamCallbackFlags, void* userData) -{ - auto me = reinterpret_cast(userData); - - SDL_assert(frameCount == SAMPLES_PER_FRAME); - - // If the indexes aren't equal, we have a sample - if (me->m_WriteIndex != me->m_ReadIndex) { - // Copy data to the audio buffer - SDL_memcpy(output, - &me->m_AudioBuffer[me->m_ReadIndex * CIRCULAR_BUFFER_STRIDE], - frameCount * me->m_ChannelCount * sizeof(short)); - - // Fence with acquire semantics ensures m_AudioBuffer[m_ReadIndex] is read before the - // producer observes m_ReadIndex incrementing. - std::atomic_thread_fence(std::memory_order_acquire); - - // This can race with the reader in the submitAudio function. This is not a problem - // because at worst, it just won't see that we've consumed this sample yet. - me->m_ReadIndex = (me->m_ReadIndex + 1) % CIRCULAR_BUFFER_SIZE; - } - else { - // No data, so play silence - SDL_memset(output, 0, frameCount * me->m_ChannelCount * sizeof(short)); - } - - return paContinue; -} diff --git a/app/streaming/audio/renderers/portaudiorenderer.h b/app/streaming/audio/renderers/portaudiorenderer.h deleted file mode 100644 index 4288fff7..00000000 --- a/app/streaming/audio/renderers/portaudiorenderer.h +++ /dev/null @@ -1,38 +0,0 @@ -#pragma once - -#include - -#include "renderer.h" - -#define CIRCULAR_BUFFER_SIZE 16 -#define MAX_CHANNEL_COUNT 6 - -#define CIRCULAR_BUFFER_STRIDE (MAX_CHANNEL_COUNT * SAMPLES_PER_FRAME) - -class PortAudioRenderer : public IAudioRenderer -{ -public: - PortAudioRenderer(); - - virtual ~PortAudioRenderer(); - - virtual bool prepareForPlayback(const OPUS_MULTISTREAM_CONFIGURATION* opusConfig); - - virtual bool submitAudio(short* audioBuffer, int audioSize); - - static int paStreamCallback(const void *input, - void *output, - unsigned long frameCount, - const PaStreamCallbackTimeInfo *timeInfo, - PaStreamCallbackFlags statusFlags, - void *userData); - -private: - PaStream* m_Stream; - int m_ChannelCount; - int m_WriteIndex; - int m_ReadIndex; - bool m_Started; - short m_AudioBuffer[CIRCULAR_BUFFER_SIZE * CIRCULAR_BUFFER_STRIDE]; -}; - diff --git a/app/streaming/audio/renderers/sdl.h b/app/streaming/audio/renderers/sdl.h index ea8602e8..a9c4d62b 100644 --- a/app/streaming/audio/renderers/sdl.h +++ b/app/streaming/audio/renderers/sdl.h @@ -3,11 +3,6 @@ #include "renderer.h" #include -#ifndef HAVE_SLVIDEO -#error SDL audio backend is only available for Steam Link -#error Please install PortAudio to build for Linux -#endif - class SdlAudioRenderer : public IAudioRenderer { public: diff --git a/app/streaming/audio/renderers/soundioaudiorenderer.cpp b/app/streaming/audio/renderers/soundioaudiorenderer.cpp new file mode 100644 index 00000000..243445f6 --- /dev/null +++ b/app/streaming/audio/renderers/soundioaudiorenderer.cpp @@ -0,0 +1,436 @@ +#include "soundioaudiorenderer.h" + +#include + +#include + +SoundIoAudioRenderer::SoundIoAudioRenderer() + : m_OpusChannelCount(0), + m_SoundIo(nullptr), + m_Device(nullptr), + m_OutputStream(nullptr), + m_RingBuffer(nullptr), + m_Errored(false) +{ + +} + +SoundIoAudioRenderer::~SoundIoAudioRenderer() +{ + if (m_OutputStream != nullptr) { + soundio_outstream_destroy(m_OutputStream); + } + + // Must be destroyed after the stream is stopped + // or we could still get sioWriteCallback() calls. + if (m_RingBuffer != nullptr) { + soundio_ring_buffer_destroy(m_RingBuffer); + } + + if (m_Device != nullptr) { + soundio_device_unref(m_Device); + } + + if (m_SoundIo != nullptr) { + soundio_destroy(m_SoundIo); + } +} + +int SoundIoAudioRenderer::scoreChannelLayout(const struct SoundIoChannelLayout* layout, const OPUS_MULTISTREAM_CONFIGURATION* opusConfig) +{ + int score = 50; + + // Compute a score for this layout based on how many matching channels + // we find (or acceptable alternatives). + for (int i = 0; i < layout->channel_count; i++) { + if (opusConfig->channelCount >= 2) { + switch (layout->channels[i]) { + case SoundIoChannelIdFrontLeft: + case SoundIoChannelIdFrontRight: + score += 2; + break; + default: + break; + } + } + + if (opusConfig->channelCount >= 6) { + switch (layout->channels[i]) { + case SoundIoChannelIdFrontCenter: + case SoundIoChannelIdLfe: + score += 2; + break; + + case SoundIoChannelIdSideLeft: + case SoundIoChannelIdSideRight: + score++; + break; + + // Score layouts using the back L/R as higher + // value than those using side L/R. + case SoundIoChannelIdBackLeft: + case SoundIoChannelIdBackRight: + score += 2; + break; + + default: + break; + } + } + } + + // Now subtract the difference between the desired and actual channel count + // to punish layouts that have extra unused speakers. + if (opusConfig->channelCount < layout->channel_count) { + score -= layout->channel_count - opusConfig->channelCount; + } + + return score; +} + +bool SoundIoAudioRenderer::prepareForPlayback(const OPUS_MULTISTREAM_CONFIGURATION* opusConfig) +{ + m_SoundIo = soundio_create(); + if (m_SoundIo == nullptr) { + SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, + "soundio_create() failed"); + return false; + } + + m_SoundIo->app_name = "Moonlight"; + m_SoundIo->userdata = this; + m_SoundIo->on_backend_disconnect = sioBackendDisconnect; + m_SoundIo->on_devices_change = sioDevicesChanged; + + int err = soundio_connect(m_SoundIo); + if (err != SoundIoErrorNone) { + SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, + "soundio_connect() failed: %s", + soundio_strerror(err)); + return false; + } + + SDL_LogInfo(SDL_LOG_CATEGORY_APPLICATION, + "Audio backend: %s", + soundio_backend_name(m_SoundIo->current_backend)); + + // Don't continue if we could only open the dummy backend + if (m_SoundIo->current_backend == SoundIoBackendDummy) { + return false; + } + + // Flush events to update with new device arrivals + soundio_flush_events(m_SoundIo); + + // Remember the actual channel count for later + m_OpusChannelCount = opusConfig->channelCount; + + int outputDeviceIndex = soundio_default_output_device_index(m_SoundIo); + if (outputDeviceIndex < 0) { + SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, + "No output device found"); + return false; + } + + m_Device = soundio_get_output_device(m_SoundIo, outputDeviceIndex); + if (m_Device == nullptr) { + SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, + "soundio_get_output_device() failed"); + return false; + } + + SDL_LogInfo(SDL_LOG_CATEGORY_APPLICATION, + "Selected audio device: %s", + m_Device->name); + + m_OutputStream = soundio_outstream_create(m_Device); + if (m_OutputStream == nullptr) { + SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, + "soundio_outstream_create() failed"); + return false; + } + + m_OutputStream->format = SoundIoFormatS16NE; + m_OutputStream->sample_rate = opusConfig->sampleRate; + m_OutputStream->name = "Moonlight"; + m_OutputStream->userdata = this; + m_OutputStream->error_callback = sioErrorCallback; + m_OutputStream->write_callback = sioWriteCallback; + + // This determines the size of the buffers we'll + // get from CoreAudio. Since GFE sends us packets + // in 5 ms chunks, we'll give them to the OS in + // buffers of the same size. + m_OutputStream->software_latency = 0.005; + + SoundIoChannelLayout bestLayout = m_Device->current_layout; + for (int i = 0; i < m_Device->layout_count; i++) { + if (scoreChannelLayout(&bestLayout, opusConfig) < + scoreChannelLayout(&m_Device->layouts[i], opusConfig)) { + bestLayout = m_Device->layouts[i]; + } + } + + if (bestLayout.channel_count < opusConfig->channelCount) { + SDL_LogWarn(SDL_LOG_CATEGORY_APPLICATION, + "No compatible channel layouts found. Some channels may not be played!"); + } + + m_OutputStream->layout = bestLayout; + + SDL_LogInfo(SDL_LOG_CATEGORY_APPLICATION, + "Native layout: %s (%d channels)", + m_OutputStream->layout.name ? + m_OutputStream->layout.name : "", + m_OutputStream->layout.channel_count); + + err = soundio_outstream_open(m_OutputStream); + if (err != SoundIoErrorNone) { + SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, + "soundio_outstream_open() failed: %s", + soundio_strerror(err)); + return false; + } + + if (m_OutputStream->layout_error) { + SDL_LogWarn(SDL_LOG_CATEGORY_APPLICATION, + "Channel layout failed: %s", + soundio_strerror(m_OutputStream->layout_error)); + + // ALSA through PulseAudio appears to fail snd_pcm_set_chmap() + // even after claiming the layout is supported (and even on totally + // standard layouts like Stereo). We'll just ignore this for ALSA + // and only bail if we get an actual failure out of one of these APIs. + if (m_SoundIo->current_backend != SoundIoBackendAlsa) { + return false; + } + } + + m_EffectiveLayout = m_OutputStream->layout; + for (int i = 0; i < m_EffectiveLayout.channel_count; i++) { + // Fixup the layout to use back L/R so our channel position + // logic in sioWriteCallback() works. + if (m_EffectiveLayout.channels[i] == SoundIoChannelIdSideLeft) { + m_EffectiveLayout.channels[i] = SoundIoChannelIdBackLeft; + } + if (m_EffectiveLayout.channels[i] == SoundIoChannelIdSideRight) { + m_EffectiveLayout.channels[i] = SoundIoChannelIdBackRight; + } + } + + // Buffer up to 6 packets of audio (30 ms) to smooth + // out network packet delivery jitter + m_RingBuffer = soundio_ring_buffer_create(m_SoundIo, + m_OutputStream->bytes_per_sample * + m_OpusChannelCount * + SAMPLES_PER_FRAME * 6); + if (m_RingBuffer == nullptr) { + SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, + "soundio_ring_buffer_create() failed"); + return false; + } + + err = soundio_outstream_start(m_OutputStream); + if (err != SoundIoErrorNone) { + SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, + "soundio_outstream_start() failed: %s", + soundio_strerror(err)); + return false; + } + + return true; +} + +bool SoundIoAudioRenderer::submitAudio(short* audioBuffer, int audioSize) +{ + if (m_Errored) { + return false; + } + + // Flush events to update with new device arrivals + soundio_flush_events(m_SoundIo); + + // We must always write a full frame of audio. If we don't, + // the reader will get out of sync with the writer and our + // channels will get all mixed up. To ensure this is always + // the case, round our bytes free down to the next multiple + // of our frame size. + int bytesFree = soundio_ring_buffer_free_count(m_RingBuffer); + int bytesPerFrame = m_OpusChannelCount * m_OutputStream->bytes_per_sample; + int bytesToWrite = qMin(audioSize, (bytesFree / bytesPerFrame) * bytesPerFrame); + memcpy(soundio_ring_buffer_write_ptr(m_RingBuffer), audioBuffer, bytesToWrite); + soundio_ring_buffer_advance_write_ptr(m_RingBuffer, bytesToWrite); + + return true; +} + +void SoundIoAudioRenderer::sioErrorCallback(SoundIoOutStream* stream, int err) +{ + auto me = reinterpret_cast(stream->userdata); + + SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, + "Audio rendering error: %s", + soundio_strerror(err)); + + // Trigger reinitialization + me->m_Errored = true; +} + +void SoundIoAudioRenderer::sioBackendDisconnect(SoundIo* soundio, int err) +{ + auto me = reinterpret_cast(soundio->userdata); + + SDL_LogWarn(SDL_LOG_CATEGORY_APPLICATION, + "Audio backend disconnected: %s", + soundio_strerror(err)); + + // Trigger reinitialization + me->m_Errored = true; +} + +void SoundIoAudioRenderer::sioDevicesChanged(SoundIo* soundio) +{ + auto me = reinterpret_cast(soundio->userdata); + + if (me->m_Device == nullptr) { + // Ignore calls that take place during initialization + return; + } + + int outputDeviceIndex = soundio_default_output_device_index(soundio); + if (outputDeviceIndex >= 0) { + struct SoundIoDevice* outputDevice = soundio_get_output_device(soundio, outputDeviceIndex); + if (outputDevice == nullptr) { + SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, + "soundio_get_output_device() failed"); + return; + } + + if (!soundio_device_equal(outputDevice, me->m_Device)) { + SDL_LogInfo(SDL_LOG_CATEGORY_APPLICATION, + "Default audio output device changed"); + + // Trigger reinitialization + me->m_Errored = true; + } + + soundio_device_unref(outputDevice); + } +} + +// bytes_per_frame should never be used on the ring buffer! It's not always +// the same number of bytes per frames as the output stream! +void SoundIoAudioRenderer::sioWriteCallback(SoundIoOutStream* stream, int frameCountMin, int frameCountMax) +{ + auto me = reinterpret_cast(stream->userdata); + char* readPtr = soundio_ring_buffer_read_ptr(me->m_RingBuffer); + int framesLeft = soundio_ring_buffer_fill_count(me->m_RingBuffer) / + (me->m_OpusChannelCount * stream->bytes_per_sample); + int bytesRead = 0; + + // Clamp framesLeft to frameCountMax + framesLeft = qMin(framesLeft, frameCountMax); + + // Place an upper-bound on audio stream latency to + // avoid accumulating packets in queue-based backends + // like WASAPI. This bound was set by testing on several + // Windows machines. The highest latency was found on + // a XPS 9343 running Windows 7 in Steam Big Picture + // and the 5.1 audio test clip from Fraunhofer. + if (me->m_SoundIo->current_backend == SoundIoBackendWasapi) { + double latency; + if (soundio_outstream_get_latency(stream, &latency) == SoundIoErrorNone) { + if (latency > 0.050) { + // If our latency is higher than desired, drop these samples to gracefully lower + // the latency without glitching too much. Dropping the whole buffer causes + // a much more noticeable glitch. This approach also ensures that we don't + // accidentally underflow if the driver/kernel side is delayed and isn't + // consuming data fast enough. Dropping a frame at a time and re-evaluating + // each time ensures that we'll stop dropping if latency returns to normal. + readPtr += framesLeft * stream->bytes_per_sample * me->m_OpusChannelCount; + bytesRead += framesLeft * stream->bytes_per_sample * me->m_OpusChannelCount; + framesLeft = 0; + + SDL_LogInfo(SDL_LOG_CATEGORY_APPLICATION, + "Latency exceeded drop cap: %f", + latency); + } + } + } + + for (;;) { + int frameCount; + int err; + struct SoundIoChannelArea* areas; + + // Always meet the minimum but don't write more than that + // if we'll have to insert silence + frameCount = qMax(framesLeft, frameCountMin); + + if (frameCount == 0) { + // Nothing more to write + break; + } + + err = soundio_outstream_begin_write(stream, &areas, &frameCount); + if (err != SoundIoErrorNone) { + SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, + "soundio_outstream_begin_write() failed: %s", + soundio_strerror(err)); + break; + } + + for (int frame = 0; frame < frameCount; frame++) { + for (int ch = 0; ch < me->m_EffectiveLayout.channel_count; ch++) { + // SoundIoChannelId - 1 happens to match Moonlight's channel layout. + // For side L/R, this logic depends on us fixing those up + // in m_EffectiveLayout to back L/R. + int readPtrChannel = me->m_EffectiveLayout.channels[ch] - 1; + + if (frame >= framesLeft || readPtrChannel >= me->m_OpusChannelCount) { + // Write silence if we have no buffered frames left or + // nothing in the audio stream for this channel + memset(areas[ch].ptr, 0, stream->bytes_per_sample); + } + else { + // Write audio data from our ring buffer + memcpy(areas[ch].ptr, + &readPtr[readPtrChannel * stream->bytes_per_sample], + stream->bytes_per_sample); + } + + areas[ch].ptr += areas[ch].step; + } + + // Move on to the next frame if we aren't inserting silence + if (frame < framesLeft) { + readPtr += stream->bytes_per_sample * me->m_OpusChannelCount; + bytesRead += stream->bytes_per_sample * me->m_OpusChannelCount; + } + } + + err = soundio_outstream_end_write(stream); + if (err != SoundIoErrorNone && err != SoundIoErrorUnderflow) { + SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, + "soundio_outstream_end_write() failed: %s", + soundio_strerror(err)); + break; + } + + if (framesLeft >= frameCount) { + framesLeft -= frameCount; + } + else { + framesLeft = 0; + } + + if (frameCountMin >= frameCount) { + frameCountMin -= frameCount; + } + else { + frameCountMin = 0; + } + } + + soundio_ring_buffer_advance_read_ptr(me->m_RingBuffer, bytesRead); +} diff --git a/app/streaming/audio/renderers/soundioaudiorenderer.h b/app/streaming/audio/renderers/soundioaudiorenderer.h new file mode 100644 index 00000000..218afb06 --- /dev/null +++ b/app/streaming/audio/renderers/soundioaudiorenderer.h @@ -0,0 +1,36 @@ +#pragma once + +#include "renderer.h" + +#include + +class SoundIoAudioRenderer : public IAudioRenderer +{ +public: + SoundIoAudioRenderer(); + + ~SoundIoAudioRenderer(); + + virtual bool prepareForPlayback(const OPUS_MULTISTREAM_CONFIGURATION* opusConfig); + + virtual bool submitAudio(short* audioBuffer, int audioSize); + +private: + int scoreChannelLayout(const struct SoundIoChannelLayout* layout, const OPUS_MULTISTREAM_CONFIGURATION* opusConfig); + + static void sioErrorCallback(struct SoundIoOutStream* stream, int err); + + static void sioWriteCallback(struct SoundIoOutStream* stream, int frameCountMin, int frameCountMax); + + static void sioBackendDisconnect(struct SoundIo* soundio, int err); + + static void sioDevicesChanged(SoundIo* soundio); + + int m_OpusChannelCount; + struct SoundIo* m_SoundIo; + struct SoundIoDevice* m_Device; + struct SoundIoOutStream* m_OutputStream; + struct SoundIoRingBuffer* m_RingBuffer; + struct SoundIoChannelLayout m_EffectiveLayout; + bool m_Errored; +}; diff --git a/libs/mac/include/pa_asio.h b/libs/mac/include/pa_asio.h deleted file mode 100644 index 9c606a9c..00000000 --- a/libs/mac/include/pa_asio.h +++ /dev/null @@ -1,150 +0,0 @@ -#ifndef PA_ASIO_H -#define PA_ASIO_H -/* - * $Id$ - * PortAudio Portable Real-Time Audio Library - * ASIO specific extensions - * - * Copyright (c) 1999-2000 Ross Bencina and Phil Burk - * - * Permission is hereby granted, free of charge, to any person obtaining - * a copy of this software and associated documentation files - * (the "Software"), to deal in the Software without restriction, - * including without limitation the rights to use, copy, modify, merge, - * publish, distribute, sublicense, and/or sell copies of the Software, - * and to permit persons to whom the Software is furnished to do so, - * subject to the following conditions: - * - * The above copyright notice and this permission notice shall be - * included in all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, - * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF - * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. - * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR - * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF - * CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION - * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - */ - -/* - * The text above constitutes the entire PortAudio license; however, - * the PortAudio community also makes the following non-binding requests: - * - * Any person wishing to distribute modifications to the Software is - * requested to send the modifications to the original developer so that - * they can be incorporated into the canonical version. It is also - * requested that these non-binding requests be included along with the - * license above. - */ - - -/** @file - @ingroup public_header - @brief ASIO-specific PortAudio API extension header file. -*/ - -#include "portaudio.h" - -#ifdef __cplusplus -extern "C" -{ -#endif /* __cplusplus */ - - -/** Retrieve legal native buffer sizes for the specificed device, in sample frames. - - @param device The global index of the device about which the query is being made. - @param minBufferSizeFrames A pointer to the location which will receive the minimum buffer size value. - @param maxBufferSizeFrames A pointer to the location which will receive the maximum buffer size value. - @param preferredBufferSizeFrames A pointer to the location which will receive the preferred buffer size value. - @param granularity A pointer to the location which will receive the "granularity". This value determines - the step size used to compute the legal values between minBufferSizeFrames and maxBufferSizeFrames. - If granularity is -1 then available buffer size values are powers of two. - - @see ASIOGetBufferSize in the ASIO SDK. - - @note: this function used to be called PaAsio_GetAvailableLatencyValues. There is a - #define that maps PaAsio_GetAvailableLatencyValues to this function for backwards compatibility. -*/ -PaError PaAsio_GetAvailableBufferSizes( PaDeviceIndex device, - long *minBufferSizeFrames, long *maxBufferSizeFrames, long *preferredBufferSizeFrames, long *granularity ); - - -/** Backwards compatibility alias for PaAsio_GetAvailableBufferSizes - - @see PaAsio_GetAvailableBufferSizes -*/ -#define PaAsio_GetAvailableLatencyValues PaAsio_GetAvailableBufferSizes - - -/** Display the ASIO control panel for the specified device. - - @param device The global index of the device whose control panel is to be displayed. - @param systemSpecific On Windows, the calling application's main window handle, - on Macintosh this value should be zero. -*/ -PaError PaAsio_ShowControlPanel( PaDeviceIndex device, void* systemSpecific ); - - - - -/** Retrieve a pointer to a string containing the name of the specified - input channel. The string is valid until Pa_Terminate is called. - - The string will be no longer than 32 characters including the null terminator. -*/ -PaError PaAsio_GetInputChannelName( PaDeviceIndex device, int channelIndex, - const char** channelName ); - - -/** Retrieve a pointer to a string containing the name of the specified - input channel. The string is valid until Pa_Terminate is called. - - The string will be no longer than 32 characters including the null terminator. -*/ -PaError PaAsio_GetOutputChannelName( PaDeviceIndex device, int channelIndex, - const char** channelName ); - - -/** Set the sample rate of an open paASIO stream. - - @param stream The stream to operate on. - @param sampleRate The new sample rate. - - Note that this function may fail if the stream is alredy running and the - ASIO driver does not support switching the sample rate of a running stream. - - Returns paIncompatibleStreamHostApi if stream is not a paASIO stream. -*/ -PaError PaAsio_SetStreamSampleRate( PaStream* stream, double sampleRate ); - - -#define paAsioUseChannelSelectors (0x01) - -typedef struct PaAsioStreamInfo{ - unsigned long size; /**< sizeof(PaAsioStreamInfo) */ - PaHostApiTypeId hostApiType; /**< paASIO */ - unsigned long version; /**< 1 */ - - unsigned long flags; - - /* Support for opening only specific channels of an ASIO device. - If the paAsioUseChannelSelectors flag is set, channelSelectors is a - pointer to an array of integers specifying the device channels to use. - When used, the length of the channelSelectors array must match the - corresponding channelCount parameter to Pa_OpenStream() otherwise a - crash may result. - The values in the selectors array must specify channels within the - range of supported channels for the device or paInvalidChannelCount will - result. - */ - int *channelSelectors; -}PaAsioStreamInfo; - - -#ifdef __cplusplus -} -#endif /* __cplusplus */ - -#endif /* PA_ASIO_H */ diff --git a/libs/mac/include/pa_jack.h b/libs/mac/include/pa_jack.h deleted file mode 100644 index 99ef833d..00000000 --- a/libs/mac/include/pa_jack.h +++ /dev/null @@ -1,77 +0,0 @@ -#ifndef PA_JACK_H -#define PA_JACK_H - -/* - * $Id: - * PortAudio Portable Real-Time Audio Library - * JACK-specific extensions - * - * Copyright (c) 1999-2000 Ross Bencina and Phil Burk - * - * Permission is hereby granted, free of charge, to any person obtaining - * a copy of this software and associated documentation files - * (the "Software"), to deal in the Software without restriction, - * including without limitation the rights to use, copy, modify, merge, - * publish, distribute, sublicense, and/or sell copies of the Software, - * and to permit persons to whom the Software is furnished to do so, - * subject to the following conditions: - * - * The above copyright notice and this permission notice shall be - * included in all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, - * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF - * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. - * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR - * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF - * CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION - * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - */ - -/* - * The text above constitutes the entire PortAudio license; however, - * the PortAudio community also makes the following non-binding requests: - * - * Any person wishing to distribute modifications to the Software is - * requested to send the modifications to the original developer so that - * they can be incorporated into the canonical version. It is also - * requested that these non-binding requests be included along with the - * license above. - */ - -/** @file - * @ingroup public_header - * @brief JACK-specific PortAudio API extension header file. - */ - -#include "portaudio.h" - -#ifdef __cplusplus -extern "C" { -#endif - -/** Set the JACK client name. - * - * During Pa_Initialize, When PA JACK connects as a client of the JACK server, it requests a certain - * name, which is for instance prepended to port names. By default this name is "PortAudio". The - * JACK server may append a suffix to the client name, in order to avoid clashes among clients that - * try to connect with the same name (e.g., different PA JACK clients). - * - * This function must be called before Pa_Initialize, otherwise it won't have any effect. Note that - * the string is not copied, but instead referenced directly, so it must not be freed for as long as - * PA might need it. - * @sa PaJack_GetClientName - */ -PaError PaJack_SetClientName( const char* name ); - -/** Get the JACK client name used by PA JACK. - * - * The caller is responsible for freeing the returned pointer. - */ -PaError PaJack_GetClientName(const char** clientName); - -#ifdef __cplusplus -} -#endif - -#endif diff --git a/libs/mac/include/pa_linux_alsa.h b/libs/mac/include/pa_linux_alsa.h deleted file mode 100644 index 7ac67364..00000000 --- a/libs/mac/include/pa_linux_alsa.h +++ /dev/null @@ -1,107 +0,0 @@ -#ifndef PA_LINUX_ALSA_H -#define PA_LINUX_ALSA_H - -/* - * $Id$ - * PortAudio Portable Real-Time Audio Library - * ALSA-specific extensions - * - * Copyright (c) 1999-2000 Ross Bencina and Phil Burk - * - * Permission is hereby granted, free of charge, to any person obtaining - * a copy of this software and associated documentation files - * (the "Software"), to deal in the Software without restriction, - * including without limitation the rights to use, copy, modify, merge, - * publish, distribute, sublicense, and/or sell copies of the Software, - * and to permit persons to whom the Software is furnished to do so, - * subject to the following conditions: - * - * The above copyright notice and this permission notice shall be - * included in all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, - * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF - * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. - * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR - * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF - * CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION - * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - */ - -/* - * The text above constitutes the entire PortAudio license; however, - * the PortAudio community also makes the following non-binding requests: - * - * Any person wishing to distribute modifications to the Software is - * requested to send the modifications to the original developer so that - * they can be incorporated into the canonical version. It is also - * requested that these non-binding requests be included along with the - * license above. - */ - -/** @file - * @ingroup public_header - * @brief ALSA-specific PortAudio API extension header file. - */ - -#include "portaudio.h" - -#ifdef __cplusplus -extern "C" { -#endif - -typedef struct PaAlsaStreamInfo -{ - unsigned long size; - PaHostApiTypeId hostApiType; - unsigned long version; - - const char *deviceString; -} -PaAlsaStreamInfo; - -/** Initialize host API specific structure, call this before setting relevant attributes. */ -void PaAlsa_InitializeStreamInfo( PaAlsaStreamInfo *info ); - -/** Instruct whether to enable real-time priority when starting the audio thread. - * - * If this is turned on by the stream is started, the audio callback thread will be created - * with the FIFO scheduling policy, which is suitable for realtime operation. - **/ -void PaAlsa_EnableRealtimeScheduling( PaStream *s, int enable ); - -#if 0 -void PaAlsa_EnableWatchdog( PaStream *s, int enable ); -#endif - -/** Get the ALSA-lib card index of this stream's input device. */ -PaError PaAlsa_GetStreamInputCard( PaStream *s, int *card ); - -/** Get the ALSA-lib card index of this stream's output device. */ -PaError PaAlsa_GetStreamOutputCard( PaStream *s, int *card ); - -/** Set the number of periods (buffer fragments) to configure devices with. - * - * By default the number of periods is 4, this is the lowest number of periods that works well on - * the author's soundcard. - * @param numPeriods The number of periods. - */ -PaError PaAlsa_SetNumPeriods( int numPeriods ); - -/** Set the maximum number of times to retry opening busy device (sleeping for a - * short interval inbetween). - */ -PaError PaAlsa_SetRetriesBusy( int retries ); - -/** Set the path and name of ALSA library file if PortAudio is configured to load it dynamically (see - * PA_ALSA_DYNAMIC). This setting will overwrite the default name set by PA_ALSA_PATHNAME define. - * @param pathName Full path with filename. Only filename can be used, but dlopen() will lookup default - * searchable directories (/usr/lib;/usr/local/lib) then. - */ -void PaAlsa_SetLibraryPathName( const char *pathName ); - -#ifdef __cplusplus -} -#endif - -#endif diff --git a/libs/mac/include/pa_mac_core.h b/libs/mac/include/pa_mac_core.h deleted file mode 100644 index 83e40a6a..00000000 --- a/libs/mac/include/pa_mac_core.h +++ /dev/null @@ -1,191 +0,0 @@ -#ifndef PA_MAC_CORE_H -#define PA_MAC_CORE_H -/* - * PortAudio Portable Real-Time Audio Library - * Macintosh Core Audio specific extensions - * portaudio.h should be included before this file. - * - * Copyright (c) 2005-2006 Bjorn Roche - * - * Permission is hereby granted, free of charge, to any person obtaining - * a copy of this software and associated documentation files - * (the "Software"), to deal in the Software without restriction, - * including without limitation the rights to use, copy, modify, merge, - * publish, distribute, sublicense, and/or sell copies of the Software, - * and to permit persons to whom the Software is furnished to do so, - * subject to the following conditions: - * - * The above copyright notice and this permission notice shall be - * included in all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, - * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF - * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. - * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR - * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF - * CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION - * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - */ - -/* - * The text above constitutes the entire PortAudio license; however, - * the PortAudio community also makes the following non-binding requests: - * - * Any person wishing to distribute modifications to the Software is - * requested to send the modifications to the original developer so that - * they can be incorporated into the canonical version. It is also - * requested that these non-binding requests be included along with the - * license above. - */ - -/** @file - * @ingroup public_header - * @brief CoreAudio-specific PortAudio API extension header file. - */ - -#include "portaudio.h" - -#include -#include - -#ifdef __cplusplus -extern "C" { -#endif - - -/** - * A pointer to a paMacCoreStreamInfo may be passed as - * the hostApiSpecificStreamInfo in the PaStreamParameters struct - * when opening a stream or querying the format. Use NULL, for the - * defaults. Note that for duplex streams, flags for input and output - * should be the same or behaviour is undefined. - */ -typedef struct -{ - unsigned long size; /**size of whole structure including this header */ - PaHostApiTypeId hostApiType; /**host API for which this data is intended */ - unsigned long version; /**structure version */ - unsigned long flags; /** flags to modify behaviour */ - SInt32 const * channelMap; /** Channel map for HAL channel mapping , if not needed, use NULL;*/ - unsigned long channelMapSize; /** Channel map size for HAL channel mapping , if not needed, use 0;*/ -} PaMacCoreStreamInfo; - -/** - * Functions - */ - - -/** Use this function to initialize a paMacCoreStreamInfo struct - * using the requested flags. Note that channel mapping is turned - * off after a call to this function. - * @param data The datastructure to initialize - * @param flags The flags to initialize the datastructure with. -*/ -void PaMacCore_SetupStreamInfo( PaMacCoreStreamInfo *data, unsigned long flags ); - -/** call this after pa_SetupMacCoreStreamInfo to use channel mapping as described in notes.txt. - * @param data The stream info structure to assign a channel mapping to - * @param channelMap The channel map array, as described in notes.txt. This array pointer will be used directly (ie the underlying data will not be copied), so the caller should not free the array until after the stream has been opened. - * @param channelMapSize The size of the channel map array. - */ -void PaMacCore_SetupChannelMap( PaMacCoreStreamInfo *data, const SInt32 * const channelMap, unsigned long channelMapSize ); - -/** - * Retrieve the AudioDeviceID of the input device assigned to an open stream - * - * @param s The stream to query. - * - * @return A valid AudioDeviceID, or NULL if an error occurred. - */ -AudioDeviceID PaMacCore_GetStreamInputDevice( PaStream* s ); - -/** - * Retrieve the AudioDeviceID of the output device assigned to an open stream - * - * @param s The stream to query. - * - * @return A valid AudioDeviceID, or NULL if an error occurred. - */ -AudioDeviceID PaMacCore_GetStreamOutputDevice( PaStream* s ); - -/** - * Returns a statically allocated string with the device's name - * for the given channel. NULL will be returned on failure. - * - * This function's implemenation is not complete! - * - * @param device The PortAudio device index. - * @param channel The channel number who's name is requested. - * @return a statically allocated string with the name of the device. - * Because this string is statically allocated, it must be - * coppied if it is to be saved and used by the user after - * another call to this function. - * - */ -const char *PaMacCore_GetChannelName( int device, int channelIndex, bool input ); - - -/** Retrieve the range of legal native buffer sizes for the specificed device, in sample frames. - - @param device The global index of the PortAudio device about which the query is being made. - @param minBufferSizeFrames A pointer to the location which will receive the minimum buffer size value. - @param maxBufferSizeFrames A pointer to the location which will receive the maximum buffer size value. - - @see kAudioDevicePropertyBufferFrameSizeRange in the CoreAudio SDK. - */ -PaError PaMacCore_GetBufferSizeRange( PaDeviceIndex device, - long *minBufferSizeFrames, long *maxBufferSizeFrames ); - - -/** - * Flags - */ - -/** - * The following flags alter the behaviour of PA on the mac platform. - * they can be ORed together. These should work both for opening and - * checking a device. - */ - -/** Allows PortAudio to change things like the device's frame size, - * which allows for much lower latency, but might disrupt the device - * if other programs are using it, even when you are just Querying - * the device. */ -#define paMacCoreChangeDeviceParameters (0x01) - -/** In combination with the above flag, - * causes the stream opening to fail, unless the exact sample rates - * are supported by the device. */ -#define paMacCoreFailIfConversionRequired (0x02) - -/** These flags set the SR conversion quality, if required. The wierd ordering - * allows Maximum Quality to be the default.*/ -#define paMacCoreConversionQualityMin (0x0100) -#define paMacCoreConversionQualityMedium (0x0200) -#define paMacCoreConversionQualityLow (0x0300) -#define paMacCoreConversionQualityHigh (0x0400) -#define paMacCoreConversionQualityMax (0x0000) - -/** - * Here are some "preset" combinations of flags (above) to get to some - * common configurations. THIS IS OVERKILL, but if more flags are added - * it won't be. - */ - -/**This is the default setting: do as much sample rate conversion as possible - * and as little mucking with the device as possible. */ -#define paMacCorePlayNice (0x00) -/**This setting is tuned for pro audio apps. It allows SR conversion on input - and output, but it tries to set the appropriate SR on the device.*/ -#define paMacCorePro (0x01) -/**This is a setting to minimize CPU usage and still play nice.*/ -#define paMacCoreMinimizeCPUButPlayNice (0x0100) -/**This is a setting to minimize CPU usage, even if that means interrupting the device. */ -#define paMacCoreMinimizeCPU (0x0101) - - -#ifdef __cplusplus -} -#endif /** __cplusplus */ - -#endif /** PA_MAC_CORE_H */ diff --git a/libs/mac/include/pa_win_ds.h b/libs/mac/include/pa_win_ds.h deleted file mode 100644 index 5d386416..00000000 --- a/libs/mac/include/pa_win_ds.h +++ /dev/null @@ -1,95 +0,0 @@ -#ifndef PA_WIN_DS_H -#define PA_WIN_DS_H -/* - * $Id: $ - * PortAudio Portable Real-Time Audio Library - * DirectSound specific extensions - * - * Copyright (c) 1999-2007 Ross Bencina and Phil Burk - * - * Permission is hereby granted, free of charge, to any person obtaining - * a copy of this software and associated documentation files - * (the "Software"), to deal in the Software without restriction, - * including without limitation the rights to use, copy, modify, merge, - * publish, distribute, sublicense, and/or sell copies of the Software, - * and to permit persons to whom the Software is furnished to do so, - * subject to the following conditions: - * - * The above copyright notice and this permission notice shall be - * included in all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, - * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF - * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. - * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR - * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF - * CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION - * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - */ - -/* - * The text above constitutes the entire PortAudio license; however, - * the PortAudio community also makes the following non-binding requests: - * - * Any person wishing to distribute modifications to the Software is - * requested to send the modifications to the original developer so that - * they can be incorporated into the canonical version. It is also - * requested that these non-binding requests be included along with the - * license above. - */ - -/** @file - @ingroup public_header - @brief DirectSound-specific PortAudio API extension header file. -*/ - -#include "portaudio.h" -#include "pa_win_waveformat.h" - -#ifdef __cplusplus -extern "C" -{ -#endif /* __cplusplus */ - - -#define paWinDirectSoundUseLowLevelLatencyParameters (0x01) -#define paWinDirectSoundUseChannelMask (0x04) - - -typedef struct PaWinDirectSoundStreamInfo{ - unsigned long size; /**< sizeof(PaWinDirectSoundStreamInfo) */ - PaHostApiTypeId hostApiType; /**< paDirectSound */ - unsigned long version; /**< 2 */ - - unsigned long flags; /**< enable other features of this struct */ - - /** - low-level latency setting support - Sets the size of the DirectSound host buffer. - When flags contains the paWinDirectSoundUseLowLevelLatencyParameters - this size will be used instead of interpreting the generic latency - parameters to Pa_OpenStream(). If the flag is not set this value is ignored. - - If the stream is a full duplex stream the implementation requires that - the values of framesPerBuffer for input and output match (if both are specified). - */ - unsigned long framesPerBuffer; - - /** - support for WAVEFORMATEXTENSIBLE channel masks. If flags contains - paWinDirectSoundUseChannelMask this allows you to specify which speakers - to address in a multichannel stream. Constants for channelMask - are specified in pa_win_waveformat.h - - */ - PaWinWaveFormatChannelMask channelMask; - -}PaWinDirectSoundStreamInfo; - - - -#ifdef __cplusplus -} -#endif /* __cplusplus */ - -#endif /* PA_WIN_DS_H */ diff --git a/libs/mac/include/pa_win_wasapi.h b/libs/mac/include/pa_win_wasapi.h deleted file mode 100644 index 1d86896c..00000000 --- a/libs/mac/include/pa_win_wasapi.h +++ /dev/null @@ -1,443 +0,0 @@ -#ifndef PA_WIN_WASAPI_H -#define PA_WIN_WASAPI_H -/* - * $Id: $ - * PortAudio Portable Real-Time Audio Library - * DirectSound specific extensions - * - * Copyright (c) 1999-2007 Ross Bencina and Phil Burk - * - * Permission is hereby granted, free of charge, to any person obtaining - * a copy of this software and associated documentation files - * (the "Software"), to deal in the Software without restriction, - * including without limitation the rights to use, copy, modify, merge, - * publish, distribute, sublicense, and/or sell copies of the Software, - * and to permit persons to whom the Software is furnished to do so, - * subject to the following conditions: - * - * The above copyright notice and this permission notice shall be - * included in all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, - * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF - * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. - * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR - * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF - * CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION - * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - */ - -/* - * The text above constitutes the entire PortAudio license; however, - * the PortAudio community also makes the following non-binding requests: - * - * Any person wishing to distribute modifications to the Software is - * requested to send the modifications to the original developer so that - * they can be incorporated into the canonical version. It is also - * requested that these non-binding requests be included along with the - * license above. - */ - -/** @file - @ingroup public_header - @brief WASAPI-specific PortAudio API extension header file. -*/ - -#include "portaudio.h" -#include "pa_win_waveformat.h" - -#ifdef __cplusplus -extern "C" -{ -#endif /* __cplusplus */ - - -/* Setup flags */ -typedef enum PaWasapiFlags -{ - /* puts WASAPI into exclusive mode */ - paWinWasapiExclusive = (1 << 0), - - /* allows to skip internal PA processing completely */ - paWinWasapiRedirectHostProcessor = (1 << 1), - - /* assigns custom channel mask */ - paWinWasapiUseChannelMask = (1 << 2), - - /* selects non-Event driven method of data read/write - Note: WASAPI Event driven core is capable of 2ms latency!!!, but Polling - method can only provide 15-20ms latency. */ - paWinWasapiPolling = (1 << 3), - - /* forces custom thread priority setting, must be used if PaWasapiStreamInfo::threadPriority - is set to a custom value */ - paWinWasapiThreadPriority = (1 << 4) -} -PaWasapiFlags; -#define paWinWasapiExclusive (paWinWasapiExclusive) -#define paWinWasapiRedirectHostProcessor (paWinWasapiRedirectHostProcessor) -#define paWinWasapiUseChannelMask (paWinWasapiUseChannelMask) -#define paWinWasapiPolling (paWinWasapiPolling) -#define paWinWasapiThreadPriority (paWinWasapiThreadPriority) - - -/* Host processor. Allows to skip internal PA processing completely. - You must set paWinWasapiRedirectHostProcessor flag to PaWasapiStreamInfo::flags member - in order to have host processor redirected to your callback. - Use with caution! inputFrames and outputFrames depend solely on final device setup. - To query maximal values of inputFrames/outputFrames use PaWasapi_GetFramesPerHostBuffer. -*/ -typedef void (*PaWasapiHostProcessorCallback) (void *inputBuffer, long inputFrames, - void *outputBuffer, long outputFrames, - void *userData); - -/* Device role. */ -typedef enum PaWasapiDeviceRole -{ - eRoleRemoteNetworkDevice = 0, - eRoleSpeakers, - eRoleLineLevel, - eRoleHeadphones, - eRoleMicrophone, - eRoleHeadset, - eRoleHandset, - eRoleUnknownDigitalPassthrough, - eRoleSPDIF, - eRoleHDMI, - eRoleUnknownFormFactor -} -PaWasapiDeviceRole; - - -/* Jack connection type. */ -typedef enum PaWasapiJackConnectionType -{ - eJackConnTypeUnknown, - eJackConnType3Point5mm, - eJackConnTypeQuarter, - eJackConnTypeAtapiInternal, - eJackConnTypeRCA, - eJackConnTypeOptical, - eJackConnTypeOtherDigital, - eJackConnTypeOtherAnalog, - eJackConnTypeMultichannelAnalogDIN, - eJackConnTypeXlrProfessional, - eJackConnTypeRJ11Modem, - eJackConnTypeCombination -} -PaWasapiJackConnectionType; - - -/* Jack geometric location. */ -typedef enum PaWasapiJackGeoLocation -{ - eJackGeoLocUnk = 0, - eJackGeoLocRear = 0x1, /* matches EPcxGeoLocation::eGeoLocRear */ - eJackGeoLocFront, - eJackGeoLocLeft, - eJackGeoLocRight, - eJackGeoLocTop, - eJackGeoLocBottom, - eJackGeoLocRearPanel, - eJackGeoLocRiser, - eJackGeoLocInsideMobileLid, - eJackGeoLocDrivebay, - eJackGeoLocHDMI, - eJackGeoLocOutsideMobileLid, - eJackGeoLocATAPI, - eJackGeoLocReserved5, - eJackGeoLocReserved6, -} -PaWasapiJackGeoLocation; - - -/* Jack general location. */ -typedef enum PaWasapiJackGenLocation -{ - eJackGenLocPrimaryBox = 0, - eJackGenLocInternal, - eJackGenLocSeparate, - eJackGenLocOther -} -PaWasapiJackGenLocation; - - -/* Jack's type of port. */ -typedef enum PaWasapiJackPortConnection -{ - eJackPortConnJack = 0, - eJackPortConnIntegratedDevice, - eJackPortConnBothIntegratedAndJack, - eJackPortConnUnknown -} -PaWasapiJackPortConnection; - - -/* Thread priority. */ -typedef enum PaWasapiThreadPriority -{ - eThreadPriorityNone = 0, - eThreadPriorityAudio, //!< Default for Shared mode. - eThreadPriorityCapture, - eThreadPriorityDistribution, - eThreadPriorityGames, - eThreadPriorityPlayback, - eThreadPriorityProAudio, //!< Default for Exclusive mode. - eThreadPriorityWindowManager -} -PaWasapiThreadPriority; - - -/* Stream descriptor. */ -typedef struct PaWasapiJackDescription -{ - unsigned long channelMapping; - unsigned long color; /* derived from macro: #define RGB(r,g,b) ((COLORREF)(((BYTE)(r)|((WORD)((BYTE)(g))<<8))|(((DWORD)(BYTE)(b))<<16))) */ - PaWasapiJackConnectionType connectionType; - PaWasapiJackGeoLocation geoLocation; - PaWasapiJackGenLocation genLocation; - PaWasapiJackPortConnection portConnection; - unsigned int isConnected; -} -PaWasapiJackDescription; - - -/** Stream category. - Note: - - values are equal to WASAPI AUDIO_STREAM_CATEGORY enum - - supported since Windows 8.0, noop on earler versions - - values 1,2 are deprecated on Windows 10 and not included into enumeration - - @version Available as of 19.6.0 -*/ -typedef enum PaWasapiStreamCategory -{ - eAudioCategoryOther = 0, - eAudioCategoryCommunications = 3, - eAudioCategoryAlerts = 4, - eAudioCategorySoundEffects = 5, - eAudioCategoryGameEffects = 6, - eAudioCategoryGameMedia = 7, - eAudioCategoryGameChat = 8, - eAudioCategorySpeech = 9, - eAudioCategoryMovie = 10, - eAudioCategoryMedia = 11 -} -PaWasapiStreamCategory; - - -/** Stream option. - Note: - - values are equal to WASAPI AUDCLNT_STREAMOPTIONS enum - - supported since Windows 8.1, noop on earler versions - - @version Available as of 19.6.0 -*/ -typedef enum PaWasapiStreamOption -{ - eStreamOptionNone = 0, //!< default - eStreamOptionRaw = 1, //!< bypass WASAPI Audio Engine DSP effects, supported since Windows 8.1 - eStreamOptionMatchFormat = 2 //!< force WASAPI Audio Engine into a stream format, supported since Windows 10 -} -PaWasapiStreamOption; - - -/* Stream descriptor. */ -typedef struct PaWasapiStreamInfo -{ - unsigned long size; /**< sizeof(PaWasapiStreamInfo) */ - PaHostApiTypeId hostApiType; /**< paWASAPI */ - unsigned long version; /**< 1 */ - - unsigned long flags; /**< collection of PaWasapiFlags */ - - /** Support for WAVEFORMATEXTENSIBLE channel masks. If flags contains - paWinWasapiUseChannelMask this allows you to specify which speakers - to address in a multichannel stream. Constants for channelMask - are specified in pa_win_waveformat.h. Will be used only if - paWinWasapiUseChannelMask flag is specified. - */ - PaWinWaveFormatChannelMask channelMask; - - /** Delivers raw data to callback obtained from GetBuffer() methods skipping - internal PortAudio processing inventory completely. userData parameter will - be the same that was passed to Pa_OpenStream method. Will be used only if - paWinWasapiRedirectHostProcessor flag is specified. - */ - PaWasapiHostProcessorCallback hostProcessorOutput; - PaWasapiHostProcessorCallback hostProcessorInput; - - /** Specifies thread priority explicitly. Will be used only if paWinWasapiThreadPriority flag - is specified. - - Please note, if Input/Output streams are opened simultaniously (Full-Duplex mode) - you shall specify same value for threadPriority or othervise one of the values will be used - to setup thread priority. - */ - PaWasapiThreadPriority threadPriority; - - /** Stream category. - @see PaWasapiStreamCategory - @version Available as of 19.6.0 - */ - PaWasapiStreamCategory streamCategory; - - /** Stream option. - @see PaWasapiStreamOption - @version Available as of 19.6.0 - */ - PaWasapiStreamOption streamOption; -} -PaWasapiStreamInfo; - - -/** Returns default sound format for device. Format is represented by PaWinWaveFormat or - WAVEFORMATEXTENSIBLE structure. - - @param pFormat Pointer to PaWinWaveFormat or WAVEFORMATEXTENSIBLE structure. - @param nFormatSize Size of PaWinWaveFormat or WAVEFORMATEXTENSIBLE structure in bytes. - @param nDevice Device index. - - @return Non-negative value indicating the number of bytes copied into format decriptor - or, a PaErrorCode (which are always negative) if PortAudio is not initialized - or an error is encountered. -*/ -int PaWasapi_GetDeviceDefaultFormat( void *pFormat, unsigned int nFormatSize, PaDeviceIndex nDevice ); - - -/** Returns device role (PaWasapiDeviceRole enum). - - @param nDevice device index. - - @return Non-negative value indicating device role or, a PaErrorCode (which are always negative) - if PortAudio is not initialized or an error is encountered. -*/ -int/*PaWasapiDeviceRole*/ PaWasapi_GetDeviceRole( PaDeviceIndex nDevice ); - - -/** Boost thread priority of calling thread (MMCSS). Use it for Blocking Interface only for thread - which makes calls to Pa_WriteStream/Pa_ReadStream. - - @param hTask Handle to pointer to priority task. Must be used with PaWasapi_RevertThreadPriority - method to revert thread priority to initial state. - - @param nPriorityClass Id of thread priority of PaWasapiThreadPriority type. Specifying - eThreadPriorityNone does nothing. - - @return Error code indicating success or failure. - @see PaWasapi_RevertThreadPriority -*/ -PaError PaWasapi_ThreadPriorityBoost( void **hTask, PaWasapiThreadPriority nPriorityClass ); - - -/** Boost thread priority of calling thread (MMCSS). Use it for Blocking Interface only for thread - which makes calls to Pa_WriteStream/Pa_ReadStream. - - @param hTask Task handle obtained by PaWasapi_BoostThreadPriority method. - @return Error code indicating success or failure. - @see PaWasapi_BoostThreadPriority -*/ -PaError PaWasapi_ThreadPriorityRevert( void *hTask ); - - -/** Get number of frames per host buffer. This is maximal value of frames of WASAPI buffer which - can be locked for operations. Use this method as helper to findout maximal values of - inputFrames/outputFrames of PaWasapiHostProcessorCallback. - - @param pStream Pointer to PaStream to query. - @param nInput Pointer to variable to receive number of input frames. Can be NULL. - @param nOutput Pointer to variable to receive number of output frames. Can be NULL. - @return Error code indicating success or failure. - @see PaWasapiHostProcessorCallback -*/ -PaError PaWasapi_GetFramesPerHostBuffer( PaStream *pStream, unsigned int *nInput, unsigned int *nOutput ); - - -/** Get number of jacks associated with a WASAPI device. Use this method to determine if - there are any jacks associated with the provided WASAPI device. Not all audio devices - will support this capability. This is valid for both input and output devices. - @param nDevice device index. - @param jcount Number of jacks is returned in this variable - @return Error code indicating success or failure - @see PaWasapi_GetJackDescription - */ -PaError PaWasapi_GetJackCount(PaDeviceIndex nDevice, int *jcount); - - -/** Get the jack description associated with a WASAPI device and jack number - Before this function is called, use PaWasapi_GetJackCount to determine the - number of jacks associated with device. If jcount is greater than zero, then - each jack from 0 to jcount can be queried with this function to get the jack - description. - @param nDevice device index. - @param jindex Which jack to return information - @param KSJACK_DESCRIPTION This structure filled in on success. - @return Error code indicating success or failure - @see PaWasapi_GetJackCount - */ -PaError PaWasapi_GetJackDescription(PaDeviceIndex nDevice, int jindex, PaWasapiJackDescription *pJackDescription); - - -/* - IMPORTANT: - - WASAPI is implemented for Callback and Blocking interfaces. It supports Shared and Exclusive - share modes. - - Exclusive Mode: - - Exclusive mode allows to deliver audio data directly to hardware bypassing - software mixing. - Exclusive mode is specified by 'paWinWasapiExclusive' flag. - - Callback Interface: - - Provides best audio quality with low latency. Callback interface is implemented in - two versions: - - 1) Event-Driven: - This is the most powerful WASAPI implementation which provides glitch-free - audio at around 3ms latency in Exclusive mode. Lowest possible latency for this mode is - 3 ms for HD Audio class audio chips. For the Shared mode latency can not be - lower than 20 ms. - - 2) Poll-Driven: - Polling is another 2-nd method to operate with WASAPI. It is less efficient than Event-Driven - and provides latency at around 10-13ms. Polling must be used to overcome a system bug - under Windows Vista x64 when application is WOW64(32-bit) and Event-Driven method simply - times out (event handle is never signalled on buffer completion). Please note, such WOW64 bug - does not exist in Vista x86 or Windows 7. - Polling can be setup by speciying 'paWinWasapiPolling' flag. Our WASAPI implementation detects - WOW64 bug and sets 'paWinWasapiPolling' automatically. - - Thread priority: - - Normally thread priority is set automatically and does not require modification. Although - if user wants some tweaking thread priority can be modified by setting 'paWinWasapiThreadPriority' - flag and specifying 'PaWasapiStreamInfo::threadPriority' with value from PaWasapiThreadPriority - enum. - - Blocking Interface: - - Blocking interface is implemented but due to above described Poll-Driven method can not - deliver lowest possible latency. Specifying too low latency in Shared mode will result in - distorted audio although Exclusive mode adds stability. - - Pa_IsFormatSupported: - - To check format with correct Share Mode (Exclusive/Shared) you must supply - PaWasapiStreamInfo with flags paWinWasapiExclusive set through member of - PaStreamParameters::hostApiSpecificStreamInfo structure. - - Pa_OpenStream: - - To set desired Share Mode (Exclusive/Shared) you must supply - PaWasapiStreamInfo with flags paWinWasapiExclusive set through member of - PaStreamParameters::hostApiSpecificStreamInfo structure. -*/ - -#ifdef __cplusplus -} -#endif /* __cplusplus */ - -#endif /* PA_WIN_WASAPI_H */ diff --git a/libs/mac/include/pa_win_waveformat.h b/libs/mac/include/pa_win_waveformat.h deleted file mode 100644 index 2c002671..00000000 --- a/libs/mac/include/pa_win_waveformat.h +++ /dev/null @@ -1,199 +0,0 @@ -#ifndef PA_WIN_WAVEFORMAT_H -#define PA_WIN_WAVEFORMAT_H - -/* - * PortAudio Portable Real-Time Audio Library - * Windows WAVEFORMAT* data structure utilities - * portaudio.h should be included before this file. - * - * Copyright (c) 2007 Ross Bencina - * - * Permission is hereby granted, free of charge, to any person obtaining - * a copy of this software and associated documentation files - * (the "Software"), to deal in the Software without restriction, - * including without limitation the rights to use, copy, modify, merge, - * publish, distribute, sublicense, and/or sell copies of the Software, - * and to permit persons to whom the Software is furnished to do so, - * subject to the following conditions: - * - * The above copyright notice and this permission notice shall be - * included in all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, - * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF - * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. - * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR - * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF - * CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION - * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - */ - -/* - * The text above constitutes the entire PortAudio license; however, - * the PortAudio community also makes the following non-binding requests: - * - * Any person wishing to distribute modifications to the Software is - * requested to send the modifications to the original developer so that - * they can be incorporated into the canonical version. It is also - * requested that these non-binding requests be included along with the - * license above. - */ - -/** @file - @ingroup public_header - @brief Windows specific PortAudio API extension and utilities header file. -*/ - -#ifdef __cplusplus -extern "C" { -#endif - -/* - The following #defines for speaker channel masks are the same - as those in ksmedia.h, except with PAWIN_ prepended, KSAUDIO_ removed - in some cases, and casts to PaWinWaveFormatChannelMask added. -*/ - -typedef unsigned long PaWinWaveFormatChannelMask; - -/* Speaker Positions: */ -#define PAWIN_SPEAKER_FRONT_LEFT ((PaWinWaveFormatChannelMask)0x1) -#define PAWIN_SPEAKER_FRONT_RIGHT ((PaWinWaveFormatChannelMask)0x2) -#define PAWIN_SPEAKER_FRONT_CENTER ((PaWinWaveFormatChannelMask)0x4) -#define PAWIN_SPEAKER_LOW_FREQUENCY ((PaWinWaveFormatChannelMask)0x8) -#define PAWIN_SPEAKER_BACK_LEFT ((PaWinWaveFormatChannelMask)0x10) -#define PAWIN_SPEAKER_BACK_RIGHT ((PaWinWaveFormatChannelMask)0x20) -#define PAWIN_SPEAKER_FRONT_LEFT_OF_CENTER ((PaWinWaveFormatChannelMask)0x40) -#define PAWIN_SPEAKER_FRONT_RIGHT_OF_CENTER ((PaWinWaveFormatChannelMask)0x80) -#define PAWIN_SPEAKER_BACK_CENTER ((PaWinWaveFormatChannelMask)0x100) -#define PAWIN_SPEAKER_SIDE_LEFT ((PaWinWaveFormatChannelMask)0x200) -#define PAWIN_SPEAKER_SIDE_RIGHT ((PaWinWaveFormatChannelMask)0x400) -#define PAWIN_SPEAKER_TOP_CENTER ((PaWinWaveFormatChannelMask)0x800) -#define PAWIN_SPEAKER_TOP_FRONT_LEFT ((PaWinWaveFormatChannelMask)0x1000) -#define PAWIN_SPEAKER_TOP_FRONT_CENTER ((PaWinWaveFormatChannelMask)0x2000) -#define PAWIN_SPEAKER_TOP_FRONT_RIGHT ((PaWinWaveFormatChannelMask)0x4000) -#define PAWIN_SPEAKER_TOP_BACK_LEFT ((PaWinWaveFormatChannelMask)0x8000) -#define PAWIN_SPEAKER_TOP_BACK_CENTER ((PaWinWaveFormatChannelMask)0x10000) -#define PAWIN_SPEAKER_TOP_BACK_RIGHT ((PaWinWaveFormatChannelMask)0x20000) - -/* Bit mask locations reserved for future use */ -#define PAWIN_SPEAKER_RESERVED ((PaWinWaveFormatChannelMask)0x7FFC0000) - -/* Used to specify that any possible permutation of speaker configurations */ -#define PAWIN_SPEAKER_ALL ((PaWinWaveFormatChannelMask)0x80000000) - -/* DirectSound Speaker Config */ -#define PAWIN_SPEAKER_DIRECTOUT 0 -#define PAWIN_SPEAKER_MONO (PAWIN_SPEAKER_FRONT_CENTER) -#define PAWIN_SPEAKER_STEREO (PAWIN_SPEAKER_FRONT_LEFT | PAWIN_SPEAKER_FRONT_RIGHT) -#define PAWIN_SPEAKER_QUAD (PAWIN_SPEAKER_FRONT_LEFT | PAWIN_SPEAKER_FRONT_RIGHT | \ - PAWIN_SPEAKER_BACK_LEFT | PAWIN_SPEAKER_BACK_RIGHT) -#define PAWIN_SPEAKER_SURROUND (PAWIN_SPEAKER_FRONT_LEFT | PAWIN_SPEAKER_FRONT_RIGHT | \ - PAWIN_SPEAKER_FRONT_CENTER | PAWIN_SPEAKER_BACK_CENTER) -#define PAWIN_SPEAKER_5POINT1 (PAWIN_SPEAKER_FRONT_LEFT | PAWIN_SPEAKER_FRONT_RIGHT | \ - PAWIN_SPEAKER_FRONT_CENTER | PAWIN_SPEAKER_LOW_FREQUENCY | \ - PAWIN_SPEAKER_BACK_LEFT | PAWIN_SPEAKER_BACK_RIGHT) -#define PAWIN_SPEAKER_7POINT1 (PAWIN_SPEAKER_FRONT_LEFT | PAWIN_SPEAKER_FRONT_RIGHT | \ - PAWIN_SPEAKER_FRONT_CENTER | PAWIN_SPEAKER_LOW_FREQUENCY | \ - PAWIN_SPEAKER_BACK_LEFT | PAWIN_SPEAKER_BACK_RIGHT | \ - PAWIN_SPEAKER_FRONT_LEFT_OF_CENTER | PAWIN_SPEAKER_FRONT_RIGHT_OF_CENTER) -#define PAWIN_SPEAKER_5POINT1_SURROUND (PAWIN_SPEAKER_FRONT_LEFT | PAWIN_SPEAKER_FRONT_RIGHT | \ - PAWIN_SPEAKER_FRONT_CENTER | PAWIN_SPEAKER_LOW_FREQUENCY | \ - PAWIN_SPEAKER_SIDE_LEFT | PAWIN_SPEAKER_SIDE_RIGHT) -#define PAWIN_SPEAKER_7POINT1_SURROUND (PAWIN_SPEAKER_FRONT_LEFT | PAWIN_SPEAKER_FRONT_RIGHT | \ - PAWIN_SPEAKER_FRONT_CENTER | PAWIN_SPEAKER_LOW_FREQUENCY | \ - PAWIN_SPEAKER_BACK_LEFT | PAWIN_SPEAKER_BACK_RIGHT | \ - PAWIN_SPEAKER_SIDE_LEFT | PAWIN_SPEAKER_SIDE_RIGHT) -/* - According to the Microsoft documentation: - The following are obsolete 5.1 and 7.1 settings (they lack side speakers). Note this means - that the default 5.1 and 7.1 settings (KSAUDIO_SPEAKER_5POINT1 and KSAUDIO_SPEAKER_7POINT1 are - similarly obsolete but are unchanged for compatibility reasons). -*/ -#define PAWIN_SPEAKER_5POINT1_BACK PAWIN_SPEAKER_5POINT1 -#define PAWIN_SPEAKER_7POINT1_WIDE PAWIN_SPEAKER_7POINT1 - -/* DVD Speaker Positions */ -#define PAWIN_SPEAKER_GROUND_FRONT_LEFT PAWIN_SPEAKER_FRONT_LEFT -#define PAWIN_SPEAKER_GROUND_FRONT_CENTER PAWIN_SPEAKER_FRONT_CENTER -#define PAWIN_SPEAKER_GROUND_FRONT_RIGHT PAWIN_SPEAKER_FRONT_RIGHT -#define PAWIN_SPEAKER_GROUND_REAR_LEFT PAWIN_SPEAKER_BACK_LEFT -#define PAWIN_SPEAKER_GROUND_REAR_RIGHT PAWIN_SPEAKER_BACK_RIGHT -#define PAWIN_SPEAKER_TOP_MIDDLE PAWIN_SPEAKER_TOP_CENTER -#define PAWIN_SPEAKER_SUPER_WOOFER PAWIN_SPEAKER_LOW_FREQUENCY - - -/* - PaWinWaveFormat is defined here to provide compatibility with - compilation environments which don't have headers defining - WAVEFORMATEXTENSIBLE (e.g. older versions of MSVC, Borland C++ etc. - - The fields for WAVEFORMATEX and WAVEFORMATEXTENSIBLE are declared as an - unsigned char array here to avoid clients who include this file having - a dependency on windows.h and mmsystem.h, and also to to avoid having - to write separate packing pragmas for each compiler. -*/ -#define PAWIN_SIZEOF_WAVEFORMATEX 18 -#define PAWIN_SIZEOF_WAVEFORMATEXTENSIBLE (PAWIN_SIZEOF_WAVEFORMATEX + 22) - -typedef struct{ - unsigned char fields[ PAWIN_SIZEOF_WAVEFORMATEXTENSIBLE ]; - unsigned long extraLongForAlignment; /* ensure that compiler aligns struct to DWORD */ -} PaWinWaveFormat; - -/* - WAVEFORMATEXTENSIBLE fields: - - union { - WORD wValidBitsPerSample; - WORD wSamplesPerBlock; - WORD wReserved; - } Samples; - DWORD dwChannelMask; - GUID SubFormat; -*/ - -#define PAWIN_INDEXOF_WVALIDBITSPERSAMPLE (PAWIN_SIZEOF_WAVEFORMATEX+0) -#define PAWIN_INDEXOF_DWCHANNELMASK (PAWIN_SIZEOF_WAVEFORMATEX+2) -#define PAWIN_INDEXOF_SUBFORMAT (PAWIN_SIZEOF_WAVEFORMATEX+6) - - -/* - Valid values to pass for the waveFormatTag PaWin_InitializeWaveFormatEx and - PaWin_InitializeWaveFormatExtensible functions below. These must match - the standard Windows WAVE_FORMAT_* values. -*/ -#define PAWIN_WAVE_FORMAT_PCM (1) -#define PAWIN_WAVE_FORMAT_IEEE_FLOAT (3) -#define PAWIN_WAVE_FORMAT_DOLBY_AC3_SPDIF (0x0092) -#define PAWIN_WAVE_FORMAT_WMA_SPDIF (0x0164) - - -/* - returns PAWIN_WAVE_FORMAT_PCM or PAWIN_WAVE_FORMAT_IEEE_FLOAT - depending on the sampleFormat parameter. -*/ -int PaWin_SampleFormatToLinearWaveFormatTag( PaSampleFormat sampleFormat ); - -/* - Use the following two functions to initialize the waveformat structure. -*/ - -void PaWin_InitializeWaveFormatEx( PaWinWaveFormat *waveFormat, - int numChannels, PaSampleFormat sampleFormat, int waveFormatTag, double sampleRate ); - - -void PaWin_InitializeWaveFormatExtensible( PaWinWaveFormat *waveFormat, - int numChannels, PaSampleFormat sampleFormat, int waveFormatTag, double sampleRate, - PaWinWaveFormatChannelMask channelMask ); - - -/* Map a channel count to a speaker channel mask */ -PaWinWaveFormatChannelMask PaWin_DefaultChannelMask( int numChannels ); - - -#ifdef __cplusplus -} -#endif /* __cplusplus */ - -#endif /* PA_WIN_WAVEFORMAT_H */ \ No newline at end of file diff --git a/libs/mac/include/pa_win_wdmks.h b/libs/mac/include/pa_win_wdmks.h deleted file mode 100644 index 35929625..00000000 --- a/libs/mac/include/pa_win_wdmks.h +++ /dev/null @@ -1,137 +0,0 @@ -#ifndef PA_WIN_WDMKS_H -#define PA_WIN_WDMKS_H -/* - * $Id$ - * PortAudio Portable Real-Time Audio Library - * WDM/KS specific extensions - * - * Copyright (c) 1999-2007 Ross Bencina and Phil Burk - * - * Permission is hereby granted, free of charge, to any person obtaining - * a copy of this software and associated documentation files - * (the "Software"), to deal in the Software without restriction, - * including without limitation the rights to use, copy, modify, merge, - * publish, distribute, sublicense, and/or sell copies of the Software, - * and to permit persons to whom the Software is furnished to do so, - * subject to the following conditions: - * - * The above copyright notice and this permission notice shall be - * included in all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, - * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF - * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. - * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR - * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF - * CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION - * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - */ - -/* - * The text above constitutes the entire PortAudio license; however, - * the PortAudio community also makes the following non-binding requests: - * - * Any person wishing to distribute modifications to the Software is - * requested to send the modifications to the original developer so that - * they can be incorporated into the canonical version. It is also - * requested that these non-binding requests be included along with the - * license above. - */ - -/** @file - @ingroup public_header - @brief WDM Kernel Streaming-specific PortAudio API extension header file. -*/ - - -#include "portaudio.h" - -#include - -#ifdef __cplusplus -extern "C" -{ -#endif /* __cplusplus */ - - /** Flags to indicate valid fields in PaWinWDMKSInfo. - @see PaWinWDMKSInfo - @version Available as of 19.5.0. - */ - typedef enum PaWinWDMKSFlags - { - /** Makes WDMKS use the supplied latency figures instead of relying on the frame size reported - by the WaveCyclic device. Use at own risk! - */ - paWinWDMKSOverrideFramesize = (1 << 0), - - /** Makes WDMKS (output stream) use the given channelMask instead of the default. - @version Available as of 19.5.0. - */ - paWinWDMKSUseGivenChannelMask = (1 << 1), - - } PaWinWDMKSFlags; - - typedef struct PaWinWDMKSInfo{ - unsigned long size; /**< sizeof(PaWinWDMKSInfo) */ - PaHostApiTypeId hostApiType; /**< paWDMKS */ - unsigned long version; /**< 1 */ - - /** Flags indicate which fields are valid. - @see PaWinWDMKSFlags - @version Available as of 19.5.0. - */ - unsigned long flags; - - /** The number of packets to use for WaveCyclic devices, range is [2, 8]. Set to zero for default value of 2. */ - unsigned noOfPackets; - - /** If paWinWDMKSUseGivenChannelMask bit is set in flags, use this as channelMask instead of default. - @see PaWinWDMKSFlags - @version Available as of 19.5.0. - */ - unsigned channelMask; - } PaWinWDMKSInfo; - - typedef enum PaWDMKSType - { - Type_kNotUsed, - Type_kWaveCyclic, - Type_kWaveRT, - Type_kCnt, - } PaWDMKSType; - - typedef enum PaWDMKSSubType - { - SubType_kUnknown, - SubType_kNotification, - SubType_kPolled, - SubType_kCnt, - } PaWDMKSSubType; - - typedef struct PaWinWDMKSDeviceInfo { - wchar_t filterPath[MAX_PATH]; /**< KS filter path in Unicode! */ - wchar_t topologyPath[MAX_PATH]; /**< Topology filter path in Unicode! */ - PaWDMKSType streamingType; - GUID deviceProductGuid; /**< The product GUID of the device (if supported) */ - } PaWinWDMKSDeviceInfo; - - typedef struct PaWDMKSDirectionSpecificStreamInfo - { - PaDeviceIndex device; - unsigned channels; /**< No of channels the device is opened with */ - unsigned framesPerHostBuffer; /**< No of frames of the device buffer */ - int endpointPinId; /**< Endpoint pin ID (on topology filter if topologyName is not empty) */ - int muxNodeId; /**< Only valid for input */ - PaWDMKSSubType streamingSubType; /**< Not known until device is opened for streaming */ - } PaWDMKSDirectionSpecificStreamInfo; - - typedef struct PaWDMKSSpecificStreamInfo { - PaWDMKSDirectionSpecificStreamInfo input; - PaWDMKSDirectionSpecificStreamInfo output; - } PaWDMKSSpecificStreamInfo; - -#ifdef __cplusplus -} -#endif /* __cplusplus */ - -#endif /* PA_WIN_DS_H */ diff --git a/libs/mac/include/pa_win_wmme.h b/libs/mac/include/pa_win_wmme.h deleted file mode 100644 index f84b68b8..00000000 --- a/libs/mac/include/pa_win_wmme.h +++ /dev/null @@ -1,185 +0,0 @@ -#ifndef PA_WIN_WMME_H -#define PA_WIN_WMME_H -/* - * $Id$ - * PortAudio Portable Real-Time Audio Library - * MME specific extensions - * - * Copyright (c) 1999-2000 Ross Bencina and Phil Burk - * - * Permission is hereby granted, free of charge, to any person obtaining - * a copy of this software and associated documentation files - * (the "Software"), to deal in the Software without restriction, - * including without limitation the rights to use, copy, modify, merge, - * publish, distribute, sublicense, and/or sell copies of the Software, - * and to permit persons to whom the Software is furnished to do so, - * subject to the following conditions: - * - * The above copyright notice and this permission notice shall be - * included in all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, - * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF - * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. - * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR - * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF - * CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION - * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - */ - -/* - * The text above constitutes the entire PortAudio license; however, - * the PortAudio community also makes the following non-binding requests: - * - * Any person wishing to distribute modifications to the Software is - * requested to send the modifications to the original developer so that - * they can be incorporated into the canonical version. It is also - * requested that these non-binding requests be included along with the - * license above. - */ - -/** @file - @ingroup public_header - @brief WMME-specific PortAudio API extension header file. -*/ - -#include "portaudio.h" -#include "pa_win_waveformat.h" - -#ifdef __cplusplus -extern "C" -{ -#endif /* __cplusplus */ - - -/* The following are flags which can be set in - PaWinMmeStreamInfo's flags field. -*/ - -#define paWinMmeUseLowLevelLatencyParameters (0x01) -#define paWinMmeUseMultipleDevices (0x02) /* use mme specific multiple device feature */ -#define paWinMmeUseChannelMask (0x04) - -/* By default, the mme implementation drops the processing thread's priority - to THREAD_PRIORITY_NORMAL and sleeps the thread if the CPU load exceeds 100% - This flag disables any priority throttling. The processing thread will always - run at THREAD_PRIORITY_TIME_CRITICAL. -*/ -#define paWinMmeDontThrottleOverloadedProcessingThread (0x08) - -/* Flags for non-PCM spdif passthrough. -*/ -#define paWinMmeWaveFormatDolbyAc3Spdif (0x10) -#define paWinMmeWaveFormatWmaSpdif (0x20) - - -typedef struct PaWinMmeDeviceAndChannelCount{ - PaDeviceIndex device; - int channelCount; -}PaWinMmeDeviceAndChannelCount; - - -typedef struct PaWinMmeStreamInfo{ - unsigned long size; /**< sizeof(PaWinMmeStreamInfo) */ - PaHostApiTypeId hostApiType; /**< paMME */ - unsigned long version; /**< 1 */ - - unsigned long flags; - - /* low-level latency setting support - These settings control the number and size of host buffers in order - to set latency. They will be used instead of the generic parameters - to Pa_OpenStream() if flags contains the PaWinMmeUseLowLevelLatencyParameters - flag. - - If PaWinMmeStreamInfo structures with PaWinMmeUseLowLevelLatencyParameters - are supplied for both input and output in a full duplex stream, then the - input and output framesPerBuffer must be the same, or the larger of the - two must be a multiple of the smaller, otherwise a - paIncompatibleHostApiSpecificStreamInfo error will be returned from - Pa_OpenStream(). - */ - unsigned long framesPerBuffer; - unsigned long bufferCount; /* formerly numBuffers */ - - /* multiple devices per direction support - If flags contains the PaWinMmeUseMultipleDevices flag, - this functionality will be used, otherwise the device parameter to - Pa_OpenStream() will be used instead. - If devices are specified here, the corresponding device parameter - to Pa_OpenStream() should be set to paUseHostApiSpecificDeviceSpecification, - otherwise an paInvalidDevice error will result. - The total number of channels accross all specified devices - must agree with the corresponding channelCount parameter to - Pa_OpenStream() otherwise a paInvalidChannelCount error will result. - */ - PaWinMmeDeviceAndChannelCount *devices; - unsigned long deviceCount; - - /* - support for WAVEFORMATEXTENSIBLE channel masks. If flags contains - paWinMmeUseChannelMask this allows you to specify which speakers - to address in a multichannel stream. Constants for channelMask - are specified in pa_win_waveformat.h - - */ - PaWinWaveFormatChannelMask channelMask; - -}PaWinMmeStreamInfo; - - -/** Retrieve the number of wave in handles used by a PortAudio WinMME stream. - Returns zero if the stream is output only. - - @return A non-negative value indicating the number of wave in handles - or, a PaErrorCode (which are always negative) if PortAudio is not initialized - or an error is encountered. - - @see PaWinMME_GetStreamInputHandle -*/ -int PaWinMME_GetStreamInputHandleCount( PaStream* stream ); - - -/** Retrieve a wave in handle used by a PortAudio WinMME stream. - - @param stream The stream to query. - @param handleIndex The zero based index of the wave in handle to retrieve. This - should be in the range [0, PaWinMME_GetStreamInputHandleCount(stream)-1]. - - @return A valid wave in handle, or NULL if an error occurred. - - @see PaWinMME_GetStreamInputHandle -*/ -HWAVEIN PaWinMME_GetStreamInputHandle( PaStream* stream, int handleIndex ); - - -/** Retrieve the number of wave out handles used by a PortAudio WinMME stream. - Returns zero if the stream is input only. - - @return A non-negative value indicating the number of wave out handles - or, a PaErrorCode (which are always negative) if PortAudio is not initialized - or an error is encountered. - - @see PaWinMME_GetStreamOutputHandle -*/ -int PaWinMME_GetStreamOutputHandleCount( PaStream* stream ); - - -/** Retrieve a wave out handle used by a PortAudio WinMME stream. - - @param stream The stream to query. - @param handleIndex The zero based index of the wave out handle to retrieve. - This should be in the range [0, PaWinMME_GetStreamOutputHandleCount(stream)-1]. - - @return A valid wave out handle, or NULL if an error occurred. - - @see PaWinMME_GetStreamOutputHandleCount -*/ -HWAVEOUT PaWinMME_GetStreamOutputHandle( PaStream* stream, int handleIndex ); - - -#ifdef __cplusplus -} -#endif /* __cplusplus */ - -#endif /* PA_WIN_WMME_H */ diff --git a/libs/mac/include/portaudio.h b/libs/mac/include/portaudio.h deleted file mode 100644 index 8a94aafb..00000000 --- a/libs/mac/include/portaudio.h +++ /dev/null @@ -1,1225 +0,0 @@ -#ifndef PORTAUDIO_H -#define PORTAUDIO_H -/* - * $Id$ - * PortAudio Portable Real-Time Audio Library - * PortAudio API Header File - * Latest version available at: http://www.portaudio.com/ - * - * Copyright (c) 1999-2002 Ross Bencina and Phil Burk - * - * Permission is hereby granted, free of charge, to any person obtaining - * a copy of this software and associated documentation files - * (the "Software"), to deal in the Software without restriction, - * including without limitation the rights to use, copy, modify, merge, - * publish, distribute, sublicense, and/or sell copies of the Software, - * and to permit persons to whom the Software is furnished to do so, - * subject to the following conditions: - * - * The above copyright notice and this permission notice shall be - * included in all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, - * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF - * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. - * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR - * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF - * CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION - * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - */ - -/* - * The text above constitutes the entire PortAudio license; however, - * the PortAudio community also makes the following non-binding requests: - * - * Any person wishing to distribute modifications to the Software is - * requested to send the modifications to the original developer so that - * they can be incorporated into the canonical version. It is also - * requested that these non-binding requests be included along with the - * license above. - */ - -/** @file - @ingroup public_header - @brief The portable PortAudio API. -*/ - - -#ifdef __cplusplus -extern "C" -{ -#endif /* __cplusplus */ - -/** Retrieve the release number of the currently running PortAudio build. - For example, for version "19.5.1" this will return 0x00130501. - - @see paMakeVersionNumber -*/ -int Pa_GetVersion( void ); - -/** Retrieve a textual description of the current PortAudio build, - e.g. "PortAudio V19.5.0-devel, revision 1952M". - The format of the text may change in the future. Do not try to parse the - returned string. - - @deprecated As of 19.5.0, use Pa_GetVersionInfo()->versionText instead. -*/ -const char* Pa_GetVersionText( void ); - -/** - Generate a packed integer version number in the same format used - by Pa_GetVersion(). Use this to compare a specified version number with - the currently running version. For example: - - @code - if( Pa_GetVersion() < paMakeVersionNumber(19,5,1) ) {} - @endcode - - @see Pa_GetVersion, Pa_GetVersionInfo - @version Available as of 19.5.0. -*/ -#define paMakeVersionNumber(major, minor, subminor) \ - (((major)&0xFF)<<16 | ((minor)&0xFF)<<8 | ((subminor)&0xFF)) - - -/** - A structure containing PortAudio API version information. - @see Pa_GetVersionInfo, paMakeVersionNumber - @version Available as of 19.5.0. -*/ -typedef struct PaVersionInfo { - int versionMajor; - int versionMinor; - int versionSubMinor; - /** - This is currently the Git revision hash but may change in the future. - The versionControlRevision is updated by running a script before compiling the library. - If the update does not occur, this value may refer to an earlier revision. - */ - const char *versionControlRevision; - /** Version as a string, for example "PortAudio V19.5.0-devel, revision 1952M" */ - const char *versionText; -} PaVersionInfo; - -/** Retrieve version information for the currently running PortAudio build. - @return A pointer to an immutable PaVersionInfo structure. - - @note This function can be called at any time. It does not require PortAudio - to be initialized. The structure pointed to is statically allocated. Do not - attempt to free it or modify it. - - @see PaVersionInfo, paMakeVersionNumber - @version Available as of 19.5.0. -*/ -const PaVersionInfo* Pa_GetVersionInfo(); - - -/** Error codes returned by PortAudio functions. - Note that with the exception of paNoError, all PaErrorCodes are negative. -*/ - -typedef int PaError; -typedef enum PaErrorCode -{ - paNoError = 0, - - paNotInitialized = -10000, - paUnanticipatedHostError, - paInvalidChannelCount, - paInvalidSampleRate, - paInvalidDevice, - paInvalidFlag, - paSampleFormatNotSupported, - paBadIODeviceCombination, - paInsufficientMemory, - paBufferTooBig, - paBufferTooSmall, - paNullCallback, - paBadStreamPtr, - paTimedOut, - paInternalError, - paDeviceUnavailable, - paIncompatibleHostApiSpecificStreamInfo, - paStreamIsStopped, - paStreamIsNotStopped, - paInputOverflowed, - paOutputUnderflowed, - paHostApiNotFound, - paInvalidHostApi, - paCanNotReadFromACallbackStream, - paCanNotWriteToACallbackStream, - paCanNotReadFromAnOutputOnlyStream, - paCanNotWriteToAnInputOnlyStream, - paIncompatibleStreamHostApi, - paBadBufferPtr -} PaErrorCode; - - -/** Translate the supplied PortAudio error code into a human readable - message. -*/ -const char *Pa_GetErrorText( PaError errorCode ); - - -/** Library initialization function - call this before using PortAudio. - This function initializes internal data structures and prepares underlying - host APIs for use. With the exception of Pa_GetVersion(), Pa_GetVersionText(), - and Pa_GetErrorText(), this function MUST be called before using any other - PortAudio API functions. - - If Pa_Initialize() is called multiple times, each successful - call must be matched with a corresponding call to Pa_Terminate(). - Pairs of calls to Pa_Initialize()/Pa_Terminate() may overlap, and are not - required to be fully nested. - - Note that if Pa_Initialize() returns an error code, Pa_Terminate() should - NOT be called. - - @return paNoError if successful, otherwise an error code indicating the cause - of failure. - - @see Pa_Terminate -*/ -PaError Pa_Initialize( void ); - - -/** Library termination function - call this when finished using PortAudio. - This function deallocates all resources allocated by PortAudio since it was - initialized by a call to Pa_Initialize(). In cases where Pa_Initialise() has - been called multiple times, each call must be matched with a corresponding call - to Pa_Terminate(). The final matching call to Pa_Terminate() will automatically - close any PortAudio streams that are still open. - - Pa_Terminate() MUST be called before exiting a program which uses PortAudio. - Failure to do so may result in serious resource leaks, such as audio devices - not being available until the next reboot. - - @return paNoError if successful, otherwise an error code indicating the cause - of failure. - - @see Pa_Initialize -*/ -PaError Pa_Terminate( void ); - - - -/** The type used to refer to audio devices. Values of this type usually - range from 0 to (Pa_GetDeviceCount()-1), and may also take on the PaNoDevice - and paUseHostApiSpecificDeviceSpecification values. - - @see Pa_GetDeviceCount, paNoDevice, paUseHostApiSpecificDeviceSpecification -*/ -typedef int PaDeviceIndex; - - -/** A special PaDeviceIndex value indicating that no device is available, - or should be used. - - @see PaDeviceIndex -*/ -#define paNoDevice ((PaDeviceIndex)-1) - - -/** A special PaDeviceIndex value indicating that the device(s) to be used - are specified in the host api specific stream info structure. - - @see PaDeviceIndex -*/ -#define paUseHostApiSpecificDeviceSpecification ((PaDeviceIndex)-2) - - -/* Host API enumeration mechanism */ - -/** The type used to enumerate to host APIs at runtime. Values of this type - range from 0 to (Pa_GetHostApiCount()-1). - - @see Pa_GetHostApiCount -*/ -typedef int PaHostApiIndex; - - -/** Retrieve the number of available host APIs. Even if a host API is - available it may have no devices available. - - @return A non-negative value indicating the number of available host APIs - or, a PaErrorCode (which are always negative) if PortAudio is not initialized - or an error is encountered. - - @see PaHostApiIndex -*/ -PaHostApiIndex Pa_GetHostApiCount( void ); - - -/** Retrieve the index of the default host API. The default host API will be - the lowest common denominator host API on the current platform and is - unlikely to provide the best performance. - - @return A non-negative value ranging from 0 to (Pa_GetHostApiCount()-1) - indicating the default host API index or, a PaErrorCode (which are always - negative) if PortAudio is not initialized or an error is encountered. -*/ -PaHostApiIndex Pa_GetDefaultHostApi( void ); - - -/** Unchanging unique identifiers for each supported host API. This type - is used in the PaHostApiInfo structure. The values are guaranteed to be - unique and to never change, thus allowing code to be written that - conditionally uses host API specific extensions. - - New type ids will be allocated when support for a host API reaches - "public alpha" status, prior to that developers should use the - paInDevelopment type id. - - @see PaHostApiInfo -*/ -typedef enum PaHostApiTypeId -{ - paInDevelopment=0, /* use while developing support for a new host API */ - paDirectSound=1, - paMME=2, - paASIO=3, - paSoundManager=4, - paCoreAudio=5, - paOSS=7, - paALSA=8, - paAL=9, - paBeOS=10, - paWDMKS=11, - paJACK=12, - paWASAPI=13, - paAudioScienceHPI=14 -} PaHostApiTypeId; - - -/** A structure containing information about a particular host API. */ - -typedef struct PaHostApiInfo -{ - /** this is struct version 1 */ - int structVersion; - /** The well known unique identifier of this host API @see PaHostApiTypeId */ - PaHostApiTypeId type; - /** A textual description of the host API for display on user interfaces. */ - const char *name; - - /** The number of devices belonging to this host API. This field may be - used in conjunction with Pa_HostApiDeviceIndexToDeviceIndex() to enumerate - all devices for this host API. - @see Pa_HostApiDeviceIndexToDeviceIndex - */ - int deviceCount; - - /** The default input device for this host API. The value will be a - device index ranging from 0 to (Pa_GetDeviceCount()-1), or paNoDevice - if no default input device is available. - */ - PaDeviceIndex defaultInputDevice; - - /** The default output device for this host API. The value will be a - device index ranging from 0 to (Pa_GetDeviceCount()-1), or paNoDevice - if no default output device is available. - */ - PaDeviceIndex defaultOutputDevice; - -} PaHostApiInfo; - - -/** Retrieve a pointer to a structure containing information about a specific - host Api. - - @param hostApi A valid host API index ranging from 0 to (Pa_GetHostApiCount()-1) - - @return A pointer to an immutable PaHostApiInfo structure describing - a specific host API. If the hostApi parameter is out of range or an error - is encountered, the function returns NULL. - - The returned structure is owned by the PortAudio implementation and must not - be manipulated or freed. The pointer is only guaranteed to be valid between - calls to Pa_Initialize() and Pa_Terminate(). -*/ -const PaHostApiInfo * Pa_GetHostApiInfo( PaHostApiIndex hostApi ); - - -/** Convert a static host API unique identifier, into a runtime - host API index. - - @param type A unique host API identifier belonging to the PaHostApiTypeId - enumeration. - - @return A valid PaHostApiIndex ranging from 0 to (Pa_GetHostApiCount()-1) or, - a PaErrorCode (which are always negative) if PortAudio is not initialized - or an error is encountered. - - The paHostApiNotFound error code indicates that the host API specified by the - type parameter is not available. - - @see PaHostApiTypeId -*/ -PaHostApiIndex Pa_HostApiTypeIdToHostApiIndex( PaHostApiTypeId type ); - - -/** Convert a host-API-specific device index to standard PortAudio device index. - This function may be used in conjunction with the deviceCount field of - PaHostApiInfo to enumerate all devices for the specified host API. - - @param hostApi A valid host API index ranging from 0 to (Pa_GetHostApiCount()-1) - - @param hostApiDeviceIndex A valid per-host device index in the range - 0 to (Pa_GetHostApiInfo(hostApi)->deviceCount-1) - - @return A non-negative PaDeviceIndex ranging from 0 to (Pa_GetDeviceCount()-1) - or, a PaErrorCode (which are always negative) if PortAudio is not initialized - or an error is encountered. - - A paInvalidHostApi error code indicates that the host API index specified by - the hostApi parameter is out of range. - - A paInvalidDevice error code indicates that the hostApiDeviceIndex parameter - is out of range. - - @see PaHostApiInfo -*/ -PaDeviceIndex Pa_HostApiDeviceIndexToDeviceIndex( PaHostApiIndex hostApi, - int hostApiDeviceIndex ); - - - -/** Structure used to return information about a host error condition. -*/ -typedef struct PaHostErrorInfo{ - PaHostApiTypeId hostApiType; /**< the host API which returned the error code */ - long errorCode; /**< the error code returned */ - const char *errorText; /**< a textual description of the error if available, otherwise a zero-length string */ -}PaHostErrorInfo; - - -/** Return information about the last host error encountered. The error - information returned by Pa_GetLastHostErrorInfo() will never be modified - asynchronously by errors occurring in other PortAudio owned threads - (such as the thread that manages the stream callback.) - - This function is provided as a last resort, primarily to enhance debugging - by providing clients with access to all available error information. - - @return A pointer to an immutable structure constraining information about - the host error. The values in this structure will only be valid if a - PortAudio function has previously returned the paUnanticipatedHostError - error code. -*/ -const PaHostErrorInfo* Pa_GetLastHostErrorInfo( void ); - - - -/* Device enumeration and capabilities */ - -/** Retrieve the number of available devices. The number of available devices - may be zero. - - @return A non-negative value indicating the number of available devices or, - a PaErrorCode (which are always negative) if PortAudio is not initialized - or an error is encountered. -*/ -PaDeviceIndex Pa_GetDeviceCount( void ); - - -/** Retrieve the index of the default input device. The result can be - used in the inputDevice parameter to Pa_OpenStream(). - - @return The default input device index for the default host API, or paNoDevice - if no default input device is available or an error was encountered. -*/ -PaDeviceIndex Pa_GetDefaultInputDevice( void ); - - -/** Retrieve the index of the default output device. The result can be - used in the outputDevice parameter to Pa_OpenStream(). - - @return The default output device index for the default host API, or paNoDevice - if no default output device is available or an error was encountered. - - @note - On the PC, the user can specify a default device by - setting an environment variable. For example, to use device #1. -
- set PA_RECOMMENDED_OUTPUT_DEVICE=1
-
- The user should first determine the available device ids by using - the supplied application "pa_devs". -*/ -PaDeviceIndex Pa_GetDefaultOutputDevice( void ); - - -/** The type used to represent monotonic time in seconds. PaTime is - used for the fields of the PaStreamCallbackTimeInfo argument to the - PaStreamCallback and as the result of Pa_GetStreamTime(). - - PaTime values have unspecified origin. - - @see PaStreamCallback, PaStreamCallbackTimeInfo, Pa_GetStreamTime -*/ -typedef double PaTime; - - -/** A type used to specify one or more sample formats. Each value indicates - a possible format for sound data passed to and from the stream callback, - Pa_ReadStream and Pa_WriteStream. - - The standard formats paFloat32, paInt16, paInt32, paInt24, paInt8 - and aUInt8 are usually implemented by all implementations. - - The floating point representation (paFloat32) uses +1.0 and -1.0 as the - maximum and minimum respectively. - - paUInt8 is an unsigned 8 bit format where 128 is considered "ground" - - The paNonInterleaved flag indicates that audio data is passed as an array - of pointers to separate buffers, one buffer for each channel. Usually, - when this flag is not used, audio data is passed as a single buffer with - all channels interleaved. - - @see Pa_OpenStream, Pa_OpenDefaultStream, PaDeviceInfo - @see paFloat32, paInt16, paInt32, paInt24, paInt8 - @see paUInt8, paCustomFormat, paNonInterleaved -*/ -typedef unsigned long PaSampleFormat; - - -#define paFloat32 ((PaSampleFormat) 0x00000001) /**< @see PaSampleFormat */ -#define paInt32 ((PaSampleFormat) 0x00000002) /**< @see PaSampleFormat */ -#define paInt24 ((PaSampleFormat) 0x00000004) /**< Packed 24 bit format. @see PaSampleFormat */ -#define paInt16 ((PaSampleFormat) 0x00000008) /**< @see PaSampleFormat */ -#define paInt8 ((PaSampleFormat) 0x00000010) /**< @see PaSampleFormat */ -#define paUInt8 ((PaSampleFormat) 0x00000020) /**< @see PaSampleFormat */ -#define paCustomFormat ((PaSampleFormat) 0x00010000) /**< @see PaSampleFormat */ - -#define paNonInterleaved ((PaSampleFormat) 0x80000000) /**< @see PaSampleFormat */ - -/** A structure providing information and capabilities of PortAudio devices. - Devices may support input, output or both input and output. -*/ -typedef struct PaDeviceInfo -{ - int structVersion; /* this is struct version 2 */ - const char *name; - PaHostApiIndex hostApi; /**< note this is a host API index, not a type id*/ - - int maxInputChannels; - int maxOutputChannels; - - /** Default latency values for interactive performance. */ - PaTime defaultLowInputLatency; - PaTime defaultLowOutputLatency; - /** Default latency values for robust non-interactive applications (eg. playing sound files). */ - PaTime defaultHighInputLatency; - PaTime defaultHighOutputLatency; - - double defaultSampleRate; -} PaDeviceInfo; - - -/** Retrieve a pointer to a PaDeviceInfo structure containing information - about the specified device. - @return A pointer to an immutable PaDeviceInfo structure. If the device - parameter is out of range the function returns NULL. - - @param device A valid device index in the range 0 to (Pa_GetDeviceCount()-1) - - @note PortAudio manages the memory referenced by the returned pointer, - the client must not manipulate or free the memory. The pointer is only - guaranteed to be valid between calls to Pa_Initialize() and Pa_Terminate(). - - @see PaDeviceInfo, PaDeviceIndex -*/ -const PaDeviceInfo* Pa_GetDeviceInfo( PaDeviceIndex device ); - - -/** Parameters for one direction (input or output) of a stream. -*/ -typedef struct PaStreamParameters -{ - /** A valid device index in the range 0 to (Pa_GetDeviceCount()-1) - specifying the device to be used or the special constant - paUseHostApiSpecificDeviceSpecification which indicates that the actual - device(s) to use are specified in hostApiSpecificStreamInfo. - This field must not be set to paNoDevice. - */ - PaDeviceIndex device; - - /** The number of channels of sound to be delivered to the - stream callback or accessed by Pa_ReadStream() or Pa_WriteStream(). - It can range from 1 to the value of maxInputChannels in the - PaDeviceInfo record for the device specified by the device parameter. - */ - int channelCount; - - /** The sample format of the buffer provided to the stream callback, - a_ReadStream() or Pa_WriteStream(). It may be any of the formats described - by the PaSampleFormat enumeration. - */ - PaSampleFormat sampleFormat; - - /** The desired latency in seconds. Where practical, implementations should - configure their latency based on these parameters, otherwise they may - choose the closest viable latency instead. Unless the suggested latency - is greater than the absolute upper limit for the device implementations - should round the suggestedLatency up to the next practical value - ie to - provide an equal or higher latency than suggestedLatency wherever possible. - Actual latency values for an open stream may be retrieved using the - inputLatency and outputLatency fields of the PaStreamInfo structure - returned by Pa_GetStreamInfo(). - @see default*Latency in PaDeviceInfo, *Latency in PaStreamInfo - */ - PaTime suggestedLatency; - - /** An optional pointer to a host api specific data structure - containing additional information for device setup and/or stream processing. - hostApiSpecificStreamInfo is never required for correct operation, - if not used it should be set to NULL. - */ - void *hostApiSpecificStreamInfo; - -} PaStreamParameters; - - -/** Return code for Pa_IsFormatSupported indicating success. */ -#define paFormatIsSupported (0) - -/** Determine whether it would be possible to open a stream with the specified - parameters. - - @param inputParameters A structure that describes the input parameters used to - open a stream. The suggestedLatency field is ignored. See PaStreamParameters - for a description of these parameters. inputParameters must be NULL for - output-only streams. - - @param outputParameters A structure that describes the output parameters used - to open a stream. The suggestedLatency field is ignored. See PaStreamParameters - for a description of these parameters. outputParameters must be NULL for - input-only streams. - - @param sampleRate The required sampleRate. For full-duplex streams it is the - sample rate for both input and output - - @return Returns 0 if the format is supported, and an error code indicating why - the format is not supported otherwise. The constant paFormatIsSupported is - provided to compare with the return value for success. - - @see paFormatIsSupported, PaStreamParameters -*/ -PaError Pa_IsFormatSupported( const PaStreamParameters *inputParameters, - const PaStreamParameters *outputParameters, - double sampleRate ); - - - -/* Streaming types and functions */ - - -/** - A single PaStream can provide multiple channels of real-time - streaming audio input and output to a client application. A stream - provides access to audio hardware represented by one or more - PaDevices. Depending on the underlying Host API, it may be possible - to open multiple streams using the same device, however this behavior - is implementation defined. Portable applications should assume that - a PaDevice may be simultaneously used by at most one PaStream. - - Pointers to PaStream objects are passed between PortAudio functions that - operate on streams. - - @see Pa_OpenStream, Pa_OpenDefaultStream, Pa_OpenDefaultStream, Pa_CloseStream, - Pa_StartStream, Pa_StopStream, Pa_AbortStream, Pa_IsStreamActive, - Pa_GetStreamTime, Pa_GetStreamCpuLoad - -*/ -typedef void PaStream; - - -/** Can be passed as the framesPerBuffer parameter to Pa_OpenStream() - or Pa_OpenDefaultStream() to indicate that the stream callback will - accept buffers of any size. -*/ -#define paFramesPerBufferUnspecified (0) - - -/** Flags used to control the behavior of a stream. They are passed as - parameters to Pa_OpenStream or Pa_OpenDefaultStream. Multiple flags may be - ORed together. - - @see Pa_OpenStream, Pa_OpenDefaultStream - @see paNoFlag, paClipOff, paDitherOff, paNeverDropInput, - paPrimeOutputBuffersUsingStreamCallback, paPlatformSpecificFlags -*/ -typedef unsigned long PaStreamFlags; - -/** @see PaStreamFlags */ -#define paNoFlag ((PaStreamFlags) 0) - -/** Disable default clipping of out of range samples. - @see PaStreamFlags -*/ -#define paClipOff ((PaStreamFlags) 0x00000001) - -/** Disable default dithering. - @see PaStreamFlags -*/ -#define paDitherOff ((PaStreamFlags) 0x00000002) - -/** Flag requests that where possible a full duplex stream will not discard - overflowed input samples without calling the stream callback. This flag is - only valid for full duplex callback streams and only when used in combination - with the paFramesPerBufferUnspecified (0) framesPerBuffer parameter. Using - this flag incorrectly results in a paInvalidFlag error being returned from - Pa_OpenStream and Pa_OpenDefaultStream. - - @see PaStreamFlags, paFramesPerBufferUnspecified -*/ -#define paNeverDropInput ((PaStreamFlags) 0x00000004) - -/** Call the stream callback to fill initial output buffers, rather than the - default behavior of priming the buffers with zeros (silence). This flag has - no effect for input-only and blocking read/write streams. - - @see PaStreamFlags -*/ -#define paPrimeOutputBuffersUsingStreamCallback ((PaStreamFlags) 0x00000008) - -/** A mask specifying the platform specific bits. - @see PaStreamFlags -*/ -#define paPlatformSpecificFlags ((PaStreamFlags)0xFFFF0000) - -/** - Timing information for the buffers passed to the stream callback. - - Time values are expressed in seconds and are synchronised with the time base used by Pa_GetStreamTime() for the associated stream. - - @see PaStreamCallback, Pa_GetStreamTime -*/ -typedef struct PaStreamCallbackTimeInfo{ - PaTime inputBufferAdcTime; /**< The time when the first sample of the input buffer was captured at the ADC input */ - PaTime currentTime; /**< The time when the stream callback was invoked */ - PaTime outputBufferDacTime; /**< The time when the first sample of the output buffer will output the DAC */ -} PaStreamCallbackTimeInfo; - - -/** - Flag bit constants for the statusFlags to PaStreamCallback. - - @see paInputUnderflow, paInputOverflow, paOutputUnderflow, paOutputOverflow, - paPrimingOutput -*/ -typedef unsigned long PaStreamCallbackFlags; - -/** In a stream opened with paFramesPerBufferUnspecified, indicates that - input data is all silence (zeros) because no real data is available. In a - stream opened without paFramesPerBufferUnspecified, it indicates that one or - more zero samples have been inserted into the input buffer to compensate - for an input underflow. - @see PaStreamCallbackFlags -*/ -#define paInputUnderflow ((PaStreamCallbackFlags) 0x00000001) - -/** In a stream opened with paFramesPerBufferUnspecified, indicates that data - prior to the first sample of the input buffer was discarded due to an - overflow, possibly because the stream callback is using too much CPU time. - Otherwise indicates that data prior to one or more samples in the - input buffer was discarded. - @see PaStreamCallbackFlags -*/ -#define paInputOverflow ((PaStreamCallbackFlags) 0x00000002) - -/** Indicates that output data (or a gap) was inserted, possibly because the - stream callback is using too much CPU time. - @see PaStreamCallbackFlags -*/ -#define paOutputUnderflow ((PaStreamCallbackFlags) 0x00000004) - -/** Indicates that output data will be discarded because no room is available. - @see PaStreamCallbackFlags -*/ -#define paOutputOverflow ((PaStreamCallbackFlags) 0x00000008) - -/** Some of all of the output data will be used to prime the stream, input - data may be zero. - @see PaStreamCallbackFlags -*/ -#define paPrimingOutput ((PaStreamCallbackFlags) 0x00000010) - -/** - Allowable return values for the PaStreamCallback. - @see PaStreamCallback -*/ -typedef enum PaStreamCallbackResult -{ - paContinue=0, /**< Signal that the stream should continue invoking the callback and processing audio. */ - paComplete=1, /**< Signal that the stream should stop invoking the callback and finish once all output samples have played. */ - paAbort=2 /**< Signal that the stream should stop invoking the callback and finish as soon as possible. */ -} PaStreamCallbackResult; - - -/** - Functions of type PaStreamCallback are implemented by PortAudio clients. - They consume, process or generate audio in response to requests from an - active PortAudio stream. - - When a stream is running, PortAudio calls the stream callback periodically. - The callback function is responsible for processing buffers of audio samples - passed via the input and output parameters. - - The PortAudio stream callback runs at very high or real-time priority. - It is required to consistently meet its time deadlines. Do not allocate - memory, access the file system, call library functions or call other functions - from the stream callback that may block or take an unpredictable amount of - time to complete. - - In order for a stream to maintain glitch-free operation the callback - must consume and return audio data faster than it is recorded and/or - played. PortAudio anticipates that each callback invocation may execute for - a duration approaching the duration of frameCount audio frames at the stream - sample rate. It is reasonable to expect to be able to utilise 70% or more of - the available CPU time in the PortAudio callback. However, due to buffer size - adaption and other factors, not all host APIs are able to guarantee audio - stability under heavy CPU load with arbitrary fixed callback buffer sizes. - When high callback CPU utilisation is required the most robust behavior - can be achieved by using paFramesPerBufferUnspecified as the - Pa_OpenStream() framesPerBuffer parameter. - - @param input and @param output are either arrays of interleaved samples or; - if non-interleaved samples were requested using the paNonInterleaved sample - format flag, an array of buffer pointers, one non-interleaved buffer for - each channel. - - The format, packing and number of channels used by the buffers are - determined by parameters to Pa_OpenStream(). - - @param frameCount The number of sample frames to be processed by - the stream callback. - - @param timeInfo Timestamps indicating the ADC capture time of the first sample - in the input buffer, the DAC output time of the first sample in the output buffer - and the time the callback was invoked. - See PaStreamCallbackTimeInfo and Pa_GetStreamTime() - - @param statusFlags Flags indicating whether input and/or output buffers - have been inserted or will be dropped to overcome underflow or overflow - conditions. - - @param userData The value of a user supplied pointer passed to - Pa_OpenStream() intended for storing synthesis data etc. - - @return - The stream callback should return one of the values in the - ::PaStreamCallbackResult enumeration. To ensure that the callback continues - to be called, it should return paContinue (0). Either paComplete or paAbort - can be returned to finish stream processing, after either of these values is - returned the callback will not be called again. If paAbort is returned the - stream will finish as soon as possible. If paComplete is returned, the stream - will continue until all buffers generated by the callback have been played. - This may be useful in applications such as soundfile players where a specific - duration of output is required. However, it is not necessary to utilize this - mechanism as Pa_StopStream(), Pa_AbortStream() or Pa_CloseStream() can also - be used to stop the stream. The callback must always fill the entire output - buffer irrespective of its return value. - - @see Pa_OpenStream, Pa_OpenDefaultStream - - @note With the exception of Pa_GetStreamCpuLoad() it is not permissible to call - PortAudio API functions from within the stream callback. -*/ -typedef int PaStreamCallback( - const void *input, void *output, - unsigned long frameCount, - const PaStreamCallbackTimeInfo* timeInfo, - PaStreamCallbackFlags statusFlags, - void *userData ); - - -/** Opens a stream for either input, output or both. - - @param stream The address of a PaStream pointer which will receive - a pointer to the newly opened stream. - - @param inputParameters A structure that describes the input parameters used by - the opened stream. See PaStreamParameters for a description of these parameters. - inputParameters must be NULL for output-only streams. - - @param outputParameters A structure that describes the output parameters used by - the opened stream. See PaStreamParameters for a description of these parameters. - outputParameters must be NULL for input-only streams. - - @param sampleRate The desired sampleRate. For full-duplex streams it is the - sample rate for both input and output - - @param framesPerBuffer The number of frames passed to the stream callback - function, or the preferred block granularity for a blocking read/write stream. - The special value paFramesPerBufferUnspecified (0) may be used to request that - the stream callback will receive an optimal (and possibly varying) number of - frames based on host requirements and the requested latency settings. - Note: With some host APIs, the use of non-zero framesPerBuffer for a callback - stream may introduce an additional layer of buffering which could introduce - additional latency. PortAudio guarantees that the additional latency - will be kept to the theoretical minimum however, it is strongly recommended - that a non-zero framesPerBuffer value only be used when your algorithm - requires a fixed number of frames per stream callback. - - @param streamFlags Flags which modify the behavior of the streaming process. - This parameter may contain a combination of flags ORed together. Some flags may - only be relevant to certain buffer formats. - - @param streamCallback A pointer to a client supplied function that is responsible - for processing and filling input and output buffers. If this parameter is NULL - the stream will be opened in 'blocking read/write' mode. In blocking mode, - the client can receive sample data using Pa_ReadStream and write sample data - using Pa_WriteStream, the number of samples that may be read or written - without blocking is returned by Pa_GetStreamReadAvailable and - Pa_GetStreamWriteAvailable respectively. - - @param userData A client supplied pointer which is passed to the stream callback - function. It could for example, contain a pointer to instance data necessary - for processing the audio buffers. This parameter is ignored if streamCallback - is NULL. - - @return - Upon success Pa_OpenStream() returns paNoError and places a pointer to a - valid PaStream in the stream argument. The stream is inactive (stopped). - If a call to Pa_OpenStream() fails, a non-zero error code is returned (see - PaError for possible error codes) and the value of stream is invalid. - - @see PaStreamParameters, PaStreamCallback, Pa_ReadStream, Pa_WriteStream, - Pa_GetStreamReadAvailable, Pa_GetStreamWriteAvailable -*/ -PaError Pa_OpenStream( PaStream** stream, - const PaStreamParameters *inputParameters, - const PaStreamParameters *outputParameters, - double sampleRate, - unsigned long framesPerBuffer, - PaStreamFlags streamFlags, - PaStreamCallback *streamCallback, - void *userData ); - - -/** A simplified version of Pa_OpenStream() that opens the default input - and/or output devices. - - @param stream The address of a PaStream pointer which will receive - a pointer to the newly opened stream. - - @param numInputChannels The number of channels of sound that will be supplied - to the stream callback or returned by Pa_ReadStream. It can range from 1 to - the value of maxInputChannels in the PaDeviceInfo record for the default input - device. If 0 the stream is opened as an output-only stream. - - @param numOutputChannels The number of channels of sound to be delivered to the - stream callback or passed to Pa_WriteStream. It can range from 1 to the value - of maxOutputChannels in the PaDeviceInfo record for the default output device. - If 0 the stream is opened as an output-only stream. - - @param sampleFormat The sample format of both the input and output buffers - provided to the callback or passed to and from Pa_ReadStream and Pa_WriteStream. - sampleFormat may be any of the formats described by the PaSampleFormat - enumeration. - - @param sampleRate Same as Pa_OpenStream parameter of the same name. - @param framesPerBuffer Same as Pa_OpenStream parameter of the same name. - @param streamCallback Same as Pa_OpenStream parameter of the same name. - @param userData Same as Pa_OpenStream parameter of the same name. - - @return As for Pa_OpenStream - - @see Pa_OpenStream, PaStreamCallback -*/ -PaError Pa_OpenDefaultStream( PaStream** stream, - int numInputChannels, - int numOutputChannels, - PaSampleFormat sampleFormat, - double sampleRate, - unsigned long framesPerBuffer, - PaStreamCallback *streamCallback, - void *userData ); - - -/** Closes an audio stream. If the audio stream is active it - discards any pending buffers as if Pa_AbortStream() had been called. -*/ -PaError Pa_CloseStream( PaStream *stream ); - - -/** Functions of type PaStreamFinishedCallback are implemented by PortAudio - clients. They can be registered with a stream using the Pa_SetStreamFinishedCallback - function. Once registered they are called when the stream becomes inactive - (ie once a call to Pa_StopStream() will not block). - A stream will become inactive after the stream callback returns non-zero, - or when Pa_StopStream or Pa_AbortStream is called. For a stream providing audio - output, if the stream callback returns paComplete, or Pa_StopStream() is called, - the stream finished callback will not be called until all generated sample data - has been played. - - @param userData The userData parameter supplied to Pa_OpenStream() - - @see Pa_SetStreamFinishedCallback -*/ -typedef void PaStreamFinishedCallback( void *userData ); - - -/** Register a stream finished callback function which will be called when the - stream becomes inactive. See the description of PaStreamFinishedCallback for - further details about when the callback will be called. - - @param stream a pointer to a PaStream that is in the stopped state - if the - stream is not stopped, the stream's finished callback will remain unchanged - and an error code will be returned. - - @param streamFinishedCallback a pointer to a function with the same signature - as PaStreamFinishedCallback, that will be called when the stream becomes - inactive. Passing NULL for this parameter will un-register a previously - registered stream finished callback function. - - @return on success returns paNoError, otherwise an error code indicating the cause - of the error. - - @see PaStreamFinishedCallback -*/ -PaError Pa_SetStreamFinishedCallback( PaStream *stream, PaStreamFinishedCallback* streamFinishedCallback ); - - -/** Commences audio processing. -*/ -PaError Pa_StartStream( PaStream *stream ); - - -/** Terminates audio processing. It waits until all pending - audio buffers have been played before it returns. -*/ -PaError Pa_StopStream( PaStream *stream ); - - -/** Terminates audio processing immediately without waiting for pending - buffers to complete. -*/ -PaError Pa_AbortStream( PaStream *stream ); - - -/** Determine whether the stream is stopped. - A stream is considered to be stopped prior to a successful call to - Pa_StartStream and after a successful call to Pa_StopStream or Pa_AbortStream. - If a stream callback returns a value other than paContinue the stream is NOT - considered to be stopped. - - @return Returns one (1) when the stream is stopped, zero (0) when - the stream is running or, a PaErrorCode (which are always negative) if - PortAudio is not initialized or an error is encountered. - - @see Pa_StopStream, Pa_AbortStream, Pa_IsStreamActive -*/ -PaError Pa_IsStreamStopped( PaStream *stream ); - - -/** Determine whether the stream is active. - A stream is active after a successful call to Pa_StartStream(), until it - becomes inactive either as a result of a call to Pa_StopStream() or - Pa_AbortStream(), or as a result of a return value other than paContinue from - the stream callback. In the latter case, the stream is considered inactive - after the last buffer has finished playing. - - @return Returns one (1) when the stream is active (ie playing or recording - audio), zero (0) when not playing or, a PaErrorCode (which are always negative) - if PortAudio is not initialized or an error is encountered. - - @see Pa_StopStream, Pa_AbortStream, Pa_IsStreamStopped -*/ -PaError Pa_IsStreamActive( PaStream *stream ); - - - -/** A structure containing unchanging information about an open stream. - @see Pa_GetStreamInfo -*/ - -typedef struct PaStreamInfo -{ - /** this is struct version 1 */ - int structVersion; - - /** The input latency of the stream in seconds. This value provides the most - accurate estimate of input latency available to the implementation. It may - differ significantly from the suggestedLatency value passed to Pa_OpenStream(). - The value of this field will be zero (0.) for output-only streams. - @see PaTime - */ - PaTime inputLatency; - - /** The output latency of the stream in seconds. This value provides the most - accurate estimate of output latency available to the implementation. It may - differ significantly from the suggestedLatency value passed to Pa_OpenStream(). - The value of this field will be zero (0.) for input-only streams. - @see PaTime - */ - PaTime outputLatency; - - /** The sample rate of the stream in Hertz (samples per second). In cases - where the hardware sample rate is inaccurate and PortAudio is aware of it, - the value of this field may be different from the sampleRate parameter - passed to Pa_OpenStream(). If information about the actual hardware sample - rate is not available, this field will have the same value as the sampleRate - parameter passed to Pa_OpenStream(). - */ - double sampleRate; - -} PaStreamInfo; - - -/** Retrieve a pointer to a PaStreamInfo structure containing information - about the specified stream. - @return A pointer to an immutable PaStreamInfo structure. If the stream - parameter is invalid, or an error is encountered, the function returns NULL. - - @param stream A pointer to an open stream previously created with Pa_OpenStream. - - @note PortAudio manages the memory referenced by the returned pointer, - the client must not manipulate or free the memory. The pointer is only - guaranteed to be valid until the specified stream is closed. - - @see PaStreamInfo -*/ -const PaStreamInfo* Pa_GetStreamInfo( PaStream *stream ); - - -/** Returns the current time in seconds for a stream according to the same clock used - to generate callback PaStreamCallbackTimeInfo timestamps. The time values are - monotonically increasing and have unspecified origin. - - Pa_GetStreamTime returns valid time values for the entire life of the stream, - from when the stream is opened until it is closed. Starting and stopping the stream - does not affect the passage of time returned by Pa_GetStreamTime. - - This time may be used for synchronizing other events to the audio stream, for - example synchronizing audio to MIDI. - - @return The stream's current time in seconds, or 0 if an error occurred. - - @see PaTime, PaStreamCallback, PaStreamCallbackTimeInfo -*/ -PaTime Pa_GetStreamTime( PaStream *stream ); - - -/** Retrieve CPU usage information for the specified stream. - The "CPU Load" is a fraction of total CPU time consumed by a callback stream's - audio processing routines including, but not limited to the client supplied - stream callback. This function does not work with blocking read/write streams. - - This function may be called from the stream callback function or the - application. - - @return - A floating point value, typically between 0.0 and 1.0, where 1.0 indicates - that the stream callback is consuming the maximum number of CPU cycles possible - to maintain real-time operation. A value of 0.5 would imply that PortAudio and - the stream callback was consuming roughly 50% of the available CPU time. The - return value may exceed 1.0. A value of 0.0 will always be returned for a - blocking read/write stream, or if an error occurs. -*/ -double Pa_GetStreamCpuLoad( PaStream* stream ); - - -/** Read samples from an input stream. The function doesn't return until - the entire buffer has been filled - this may involve waiting for the operating - system to supply the data. - - @param stream A pointer to an open stream previously created with Pa_OpenStream. - - @param buffer A pointer to a buffer of sample frames. The buffer contains - samples in the format specified by the inputParameters->sampleFormat field - used to open the stream, and the number of channels specified by - inputParameters->numChannels. If non-interleaved samples were requested using - the paNonInterleaved sample format flag, buffer is a pointer to the first element - of an array of buffer pointers, one non-interleaved buffer for each channel. - - @param frames The number of frames to be read into buffer. This parameter - is not constrained to a specific range, however high performance applications - will want to match this parameter to the framesPerBuffer parameter used - when opening the stream. - - @return On success PaNoError will be returned, or PaInputOverflowed if input - data was discarded by PortAudio after the previous call and before this call. -*/ -PaError Pa_ReadStream( PaStream* stream, - void *buffer, - unsigned long frames ); - - -/** Write samples to an output stream. This function doesn't return until the - entire buffer has been written - this may involve waiting for the operating - system to consume the data. - - @param stream A pointer to an open stream previously created with Pa_OpenStream. - - @param buffer A pointer to a buffer of sample frames. The buffer contains - samples in the format specified by the outputParameters->sampleFormat field - used to open the stream, and the number of channels specified by - outputParameters->numChannels. If non-interleaved samples were requested using - the paNonInterleaved sample format flag, buffer is a pointer to the first element - of an array of buffer pointers, one non-interleaved buffer for each channel. - - @param frames The number of frames to be written from buffer. This parameter - is not constrained to a specific range, however high performance applications - will want to match this parameter to the framesPerBuffer parameter used - when opening the stream. - - @return On success PaNoError will be returned, or paOutputUnderflowed if - additional output data was inserted after the previous call and before this - call. -*/ -PaError Pa_WriteStream( PaStream* stream, - const void *buffer, - unsigned long frames ); - - -/** Retrieve the number of frames that can be read from the stream without - waiting. - - @return Returns a non-negative value representing the maximum number of frames - that can be read from the stream without blocking or busy waiting or, a - PaErrorCode (which are always negative) if PortAudio is not initialized or an - error is encountered. -*/ -signed long Pa_GetStreamReadAvailable( PaStream* stream ); - - -/** Retrieve the number of frames that can be written to the stream without - waiting. - - @return Returns a non-negative value representing the maximum number of frames - that can be written to the stream without blocking or busy waiting or, a - PaErrorCode (which are always negative) if PortAudio is not initialized or an - error is encountered. -*/ -signed long Pa_GetStreamWriteAvailable( PaStream* stream ); - - -/* Miscellaneous utilities */ - - -/** Retrieve the size of a given sample format in bytes. - - @return The size in bytes of a single sample in the specified format, - or paSampleFormatNotSupported if the format is not supported. -*/ -PaError Pa_GetSampleSize( PaSampleFormat format ); - - -/** Put the caller to sleep for at least 'msec' milliseconds. This function is - provided only as a convenience for authors of portable code (such as the tests - and examples in the PortAudio distribution.) - - The function may sleep longer than requested so don't rely on this for accurate - musical timing. -*/ -void Pa_Sleep( long msec ); - - - -#ifdef __cplusplus -} -#endif /* __cplusplus */ -#endif /* PORTAUDIO_H */ diff --git a/libs/mac/lib/libportaudio.dylib b/libs/mac/lib/libportaudio.dylib deleted file mode 100644 index 38ebd36a819e453b1591c85b84241c9240c96b70..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 146896 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 F{{yuTGzkCz diff --git a/libs/windows/include/pa_asio.h b/libs/windows/include/pa_asio.h deleted file mode 100644 index 9c606a9c..00000000 --- a/libs/windows/include/pa_asio.h +++ /dev/null @@ -1,150 +0,0 @@ -#ifndef PA_ASIO_H -#define PA_ASIO_H -/* - * $Id$ - * PortAudio Portable Real-Time Audio Library - * ASIO specific extensions - * - * Copyright (c) 1999-2000 Ross Bencina and Phil Burk - * - * Permission is hereby granted, free of charge, to any person obtaining - * a copy of this software and associated documentation files - * (the "Software"), to deal in the Software without restriction, - * including without limitation the rights to use, copy, modify, merge, - * publish, distribute, sublicense, and/or sell copies of the Software, - * and to permit persons to whom the Software is furnished to do so, - * subject to the following conditions: - * - * The above copyright notice and this permission notice shall be - * included in all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, - * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF - * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. - * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR - * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF - * CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION - * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - */ - -/* - * The text above constitutes the entire PortAudio license; however, - * the PortAudio community also makes the following non-binding requests: - * - * Any person wishing to distribute modifications to the Software is - * requested to send the modifications to the original developer so that - * they can be incorporated into the canonical version. It is also - * requested that these non-binding requests be included along with the - * license above. - */ - - -/** @file - @ingroup public_header - @brief ASIO-specific PortAudio API extension header file. -*/ - -#include "portaudio.h" - -#ifdef __cplusplus -extern "C" -{ -#endif /* __cplusplus */ - - -/** Retrieve legal native buffer sizes for the specificed device, in sample frames. - - @param device The global index of the device about which the query is being made. - @param minBufferSizeFrames A pointer to the location which will receive the minimum buffer size value. - @param maxBufferSizeFrames A pointer to the location which will receive the maximum buffer size value. - @param preferredBufferSizeFrames A pointer to the location which will receive the preferred buffer size value. - @param granularity A pointer to the location which will receive the "granularity". This value determines - the step size used to compute the legal values between minBufferSizeFrames and maxBufferSizeFrames. - If granularity is -1 then available buffer size values are powers of two. - - @see ASIOGetBufferSize in the ASIO SDK. - - @note: this function used to be called PaAsio_GetAvailableLatencyValues. There is a - #define that maps PaAsio_GetAvailableLatencyValues to this function for backwards compatibility. -*/ -PaError PaAsio_GetAvailableBufferSizes( PaDeviceIndex device, - long *minBufferSizeFrames, long *maxBufferSizeFrames, long *preferredBufferSizeFrames, long *granularity ); - - -/** Backwards compatibility alias for PaAsio_GetAvailableBufferSizes - - @see PaAsio_GetAvailableBufferSizes -*/ -#define PaAsio_GetAvailableLatencyValues PaAsio_GetAvailableBufferSizes - - -/** Display the ASIO control panel for the specified device. - - @param device The global index of the device whose control panel is to be displayed. - @param systemSpecific On Windows, the calling application's main window handle, - on Macintosh this value should be zero. -*/ -PaError PaAsio_ShowControlPanel( PaDeviceIndex device, void* systemSpecific ); - - - - -/** Retrieve a pointer to a string containing the name of the specified - input channel. The string is valid until Pa_Terminate is called. - - The string will be no longer than 32 characters including the null terminator. -*/ -PaError PaAsio_GetInputChannelName( PaDeviceIndex device, int channelIndex, - const char** channelName ); - - -/** Retrieve a pointer to a string containing the name of the specified - input channel. The string is valid until Pa_Terminate is called. - - The string will be no longer than 32 characters including the null terminator. -*/ -PaError PaAsio_GetOutputChannelName( PaDeviceIndex device, int channelIndex, - const char** channelName ); - - -/** Set the sample rate of an open paASIO stream. - - @param stream The stream to operate on. - @param sampleRate The new sample rate. - - Note that this function may fail if the stream is alredy running and the - ASIO driver does not support switching the sample rate of a running stream. - - Returns paIncompatibleStreamHostApi if stream is not a paASIO stream. -*/ -PaError PaAsio_SetStreamSampleRate( PaStream* stream, double sampleRate ); - - -#define paAsioUseChannelSelectors (0x01) - -typedef struct PaAsioStreamInfo{ - unsigned long size; /**< sizeof(PaAsioStreamInfo) */ - PaHostApiTypeId hostApiType; /**< paASIO */ - unsigned long version; /**< 1 */ - - unsigned long flags; - - /* Support for opening only specific channels of an ASIO device. - If the paAsioUseChannelSelectors flag is set, channelSelectors is a - pointer to an array of integers specifying the device channels to use. - When used, the length of the channelSelectors array must match the - corresponding channelCount parameter to Pa_OpenStream() otherwise a - crash may result. - The values in the selectors array must specify channels within the - range of supported channels for the device or paInvalidChannelCount will - result. - */ - int *channelSelectors; -}PaAsioStreamInfo; - - -#ifdef __cplusplus -} -#endif /* __cplusplus */ - -#endif /* PA_ASIO_H */ diff --git a/libs/windows/include/pa_jack.h b/libs/windows/include/pa_jack.h deleted file mode 100644 index 99ef833d..00000000 --- a/libs/windows/include/pa_jack.h +++ /dev/null @@ -1,77 +0,0 @@ -#ifndef PA_JACK_H -#define PA_JACK_H - -/* - * $Id: - * PortAudio Portable Real-Time Audio Library - * JACK-specific extensions - * - * Copyright (c) 1999-2000 Ross Bencina and Phil Burk - * - * Permission is hereby granted, free of charge, to any person obtaining - * a copy of this software and associated documentation files - * (the "Software"), to deal in the Software without restriction, - * including without limitation the rights to use, copy, modify, merge, - * publish, distribute, sublicense, and/or sell copies of the Software, - * and to permit persons to whom the Software is furnished to do so, - * subject to the following conditions: - * - * The above copyright notice and this permission notice shall be - * included in all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, - * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF - * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. - * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR - * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF - * CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION - * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - */ - -/* - * The text above constitutes the entire PortAudio license; however, - * the PortAudio community also makes the following non-binding requests: - * - * Any person wishing to distribute modifications to the Software is - * requested to send the modifications to the original developer so that - * they can be incorporated into the canonical version. It is also - * requested that these non-binding requests be included along with the - * license above. - */ - -/** @file - * @ingroup public_header - * @brief JACK-specific PortAudio API extension header file. - */ - -#include "portaudio.h" - -#ifdef __cplusplus -extern "C" { -#endif - -/** Set the JACK client name. - * - * During Pa_Initialize, When PA JACK connects as a client of the JACK server, it requests a certain - * name, which is for instance prepended to port names. By default this name is "PortAudio". The - * JACK server may append a suffix to the client name, in order to avoid clashes among clients that - * try to connect with the same name (e.g., different PA JACK clients). - * - * This function must be called before Pa_Initialize, otherwise it won't have any effect. Note that - * the string is not copied, but instead referenced directly, so it must not be freed for as long as - * PA might need it. - * @sa PaJack_GetClientName - */ -PaError PaJack_SetClientName( const char* name ); - -/** Get the JACK client name used by PA JACK. - * - * The caller is responsible for freeing the returned pointer. - */ -PaError PaJack_GetClientName(const char** clientName); - -#ifdef __cplusplus -} -#endif - -#endif diff --git a/libs/windows/include/pa_linux_alsa.h b/libs/windows/include/pa_linux_alsa.h deleted file mode 100644 index 7ac67364..00000000 --- a/libs/windows/include/pa_linux_alsa.h +++ /dev/null @@ -1,107 +0,0 @@ -#ifndef PA_LINUX_ALSA_H -#define PA_LINUX_ALSA_H - -/* - * $Id$ - * PortAudio Portable Real-Time Audio Library - * ALSA-specific extensions - * - * Copyright (c) 1999-2000 Ross Bencina and Phil Burk - * - * Permission is hereby granted, free of charge, to any person obtaining - * a copy of this software and associated documentation files - * (the "Software"), to deal in the Software without restriction, - * including without limitation the rights to use, copy, modify, merge, - * publish, distribute, sublicense, and/or sell copies of the Software, - * and to permit persons to whom the Software is furnished to do so, - * subject to the following conditions: - * - * The above copyright notice and this permission notice shall be - * included in all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, - * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF - * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. - * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR - * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF - * CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION - * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - */ - -/* - * The text above constitutes the entire PortAudio license; however, - * the PortAudio community also makes the following non-binding requests: - * - * Any person wishing to distribute modifications to the Software is - * requested to send the modifications to the original developer so that - * they can be incorporated into the canonical version. It is also - * requested that these non-binding requests be included along with the - * license above. - */ - -/** @file - * @ingroup public_header - * @brief ALSA-specific PortAudio API extension header file. - */ - -#include "portaudio.h" - -#ifdef __cplusplus -extern "C" { -#endif - -typedef struct PaAlsaStreamInfo -{ - unsigned long size; - PaHostApiTypeId hostApiType; - unsigned long version; - - const char *deviceString; -} -PaAlsaStreamInfo; - -/** Initialize host API specific structure, call this before setting relevant attributes. */ -void PaAlsa_InitializeStreamInfo( PaAlsaStreamInfo *info ); - -/** Instruct whether to enable real-time priority when starting the audio thread. - * - * If this is turned on by the stream is started, the audio callback thread will be created - * with the FIFO scheduling policy, which is suitable for realtime operation. - **/ -void PaAlsa_EnableRealtimeScheduling( PaStream *s, int enable ); - -#if 0 -void PaAlsa_EnableWatchdog( PaStream *s, int enable ); -#endif - -/** Get the ALSA-lib card index of this stream's input device. */ -PaError PaAlsa_GetStreamInputCard( PaStream *s, int *card ); - -/** Get the ALSA-lib card index of this stream's output device. */ -PaError PaAlsa_GetStreamOutputCard( PaStream *s, int *card ); - -/** Set the number of periods (buffer fragments) to configure devices with. - * - * By default the number of periods is 4, this is the lowest number of periods that works well on - * the author's soundcard. - * @param numPeriods The number of periods. - */ -PaError PaAlsa_SetNumPeriods( int numPeriods ); - -/** Set the maximum number of times to retry opening busy device (sleeping for a - * short interval inbetween). - */ -PaError PaAlsa_SetRetriesBusy( int retries ); - -/** Set the path and name of ALSA library file if PortAudio is configured to load it dynamically (see - * PA_ALSA_DYNAMIC). This setting will overwrite the default name set by PA_ALSA_PATHNAME define. - * @param pathName Full path with filename. Only filename can be used, but dlopen() will lookup default - * searchable directories (/usr/lib;/usr/local/lib) then. - */ -void PaAlsa_SetLibraryPathName( const char *pathName ); - -#ifdef __cplusplus -} -#endif - -#endif diff --git a/libs/windows/include/pa_mac_core.h b/libs/windows/include/pa_mac_core.h deleted file mode 100644 index 83e40a6a..00000000 --- a/libs/windows/include/pa_mac_core.h +++ /dev/null @@ -1,191 +0,0 @@ -#ifndef PA_MAC_CORE_H -#define PA_MAC_CORE_H -/* - * PortAudio Portable Real-Time Audio Library - * Macintosh Core Audio specific extensions - * portaudio.h should be included before this file. - * - * Copyright (c) 2005-2006 Bjorn Roche - * - * Permission is hereby granted, free of charge, to any person obtaining - * a copy of this software and associated documentation files - * (the "Software"), to deal in the Software without restriction, - * including without limitation the rights to use, copy, modify, merge, - * publish, distribute, sublicense, and/or sell copies of the Software, - * and to permit persons to whom the Software is furnished to do so, - * subject to the following conditions: - * - * The above copyright notice and this permission notice shall be - * included in all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, - * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF - * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. - * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR - * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF - * CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION - * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - */ - -/* - * The text above constitutes the entire PortAudio license; however, - * the PortAudio community also makes the following non-binding requests: - * - * Any person wishing to distribute modifications to the Software is - * requested to send the modifications to the original developer so that - * they can be incorporated into the canonical version. It is also - * requested that these non-binding requests be included along with the - * license above. - */ - -/** @file - * @ingroup public_header - * @brief CoreAudio-specific PortAudio API extension header file. - */ - -#include "portaudio.h" - -#include -#include - -#ifdef __cplusplus -extern "C" { -#endif - - -/** - * A pointer to a paMacCoreStreamInfo may be passed as - * the hostApiSpecificStreamInfo in the PaStreamParameters struct - * when opening a stream or querying the format. Use NULL, for the - * defaults. Note that for duplex streams, flags for input and output - * should be the same or behaviour is undefined. - */ -typedef struct -{ - unsigned long size; /**size of whole structure including this header */ - PaHostApiTypeId hostApiType; /**host API for which this data is intended */ - unsigned long version; /**structure version */ - unsigned long flags; /** flags to modify behaviour */ - SInt32 const * channelMap; /** Channel map for HAL channel mapping , if not needed, use NULL;*/ - unsigned long channelMapSize; /** Channel map size for HAL channel mapping , if not needed, use 0;*/ -} PaMacCoreStreamInfo; - -/** - * Functions - */ - - -/** Use this function to initialize a paMacCoreStreamInfo struct - * using the requested flags. Note that channel mapping is turned - * off after a call to this function. - * @param data The datastructure to initialize - * @param flags The flags to initialize the datastructure with. -*/ -void PaMacCore_SetupStreamInfo( PaMacCoreStreamInfo *data, unsigned long flags ); - -/** call this after pa_SetupMacCoreStreamInfo to use channel mapping as described in notes.txt. - * @param data The stream info structure to assign a channel mapping to - * @param channelMap The channel map array, as described in notes.txt. This array pointer will be used directly (ie the underlying data will not be copied), so the caller should not free the array until after the stream has been opened. - * @param channelMapSize The size of the channel map array. - */ -void PaMacCore_SetupChannelMap( PaMacCoreStreamInfo *data, const SInt32 * const channelMap, unsigned long channelMapSize ); - -/** - * Retrieve the AudioDeviceID of the input device assigned to an open stream - * - * @param s The stream to query. - * - * @return A valid AudioDeviceID, or NULL if an error occurred. - */ -AudioDeviceID PaMacCore_GetStreamInputDevice( PaStream* s ); - -/** - * Retrieve the AudioDeviceID of the output device assigned to an open stream - * - * @param s The stream to query. - * - * @return A valid AudioDeviceID, or NULL if an error occurred. - */ -AudioDeviceID PaMacCore_GetStreamOutputDevice( PaStream* s ); - -/** - * Returns a statically allocated string with the device's name - * for the given channel. NULL will be returned on failure. - * - * This function's implemenation is not complete! - * - * @param device The PortAudio device index. - * @param channel The channel number who's name is requested. - * @return a statically allocated string with the name of the device. - * Because this string is statically allocated, it must be - * coppied if it is to be saved and used by the user after - * another call to this function. - * - */ -const char *PaMacCore_GetChannelName( int device, int channelIndex, bool input ); - - -/** Retrieve the range of legal native buffer sizes for the specificed device, in sample frames. - - @param device The global index of the PortAudio device about which the query is being made. - @param minBufferSizeFrames A pointer to the location which will receive the minimum buffer size value. - @param maxBufferSizeFrames A pointer to the location which will receive the maximum buffer size value. - - @see kAudioDevicePropertyBufferFrameSizeRange in the CoreAudio SDK. - */ -PaError PaMacCore_GetBufferSizeRange( PaDeviceIndex device, - long *minBufferSizeFrames, long *maxBufferSizeFrames ); - - -/** - * Flags - */ - -/** - * The following flags alter the behaviour of PA on the mac platform. - * they can be ORed together. These should work both for opening and - * checking a device. - */ - -/** Allows PortAudio to change things like the device's frame size, - * which allows for much lower latency, but might disrupt the device - * if other programs are using it, even when you are just Querying - * the device. */ -#define paMacCoreChangeDeviceParameters (0x01) - -/** In combination with the above flag, - * causes the stream opening to fail, unless the exact sample rates - * are supported by the device. */ -#define paMacCoreFailIfConversionRequired (0x02) - -/** These flags set the SR conversion quality, if required. The wierd ordering - * allows Maximum Quality to be the default.*/ -#define paMacCoreConversionQualityMin (0x0100) -#define paMacCoreConversionQualityMedium (0x0200) -#define paMacCoreConversionQualityLow (0x0300) -#define paMacCoreConversionQualityHigh (0x0400) -#define paMacCoreConversionQualityMax (0x0000) - -/** - * Here are some "preset" combinations of flags (above) to get to some - * common configurations. THIS IS OVERKILL, but if more flags are added - * it won't be. - */ - -/**This is the default setting: do as much sample rate conversion as possible - * and as little mucking with the device as possible. */ -#define paMacCorePlayNice (0x00) -/**This setting is tuned for pro audio apps. It allows SR conversion on input - and output, but it tries to set the appropriate SR on the device.*/ -#define paMacCorePro (0x01) -/**This is a setting to minimize CPU usage and still play nice.*/ -#define paMacCoreMinimizeCPUButPlayNice (0x0100) -/**This is a setting to minimize CPU usage, even if that means interrupting the device. */ -#define paMacCoreMinimizeCPU (0x0101) - - -#ifdef __cplusplus -} -#endif /** __cplusplus */ - -#endif /** PA_MAC_CORE_H */ diff --git a/libs/windows/include/pa_win_ds.h b/libs/windows/include/pa_win_ds.h deleted file mode 100644 index 5d386416..00000000 --- a/libs/windows/include/pa_win_ds.h +++ /dev/null @@ -1,95 +0,0 @@ -#ifndef PA_WIN_DS_H -#define PA_WIN_DS_H -/* - * $Id: $ - * PortAudio Portable Real-Time Audio Library - * DirectSound specific extensions - * - * Copyright (c) 1999-2007 Ross Bencina and Phil Burk - * - * Permission is hereby granted, free of charge, to any person obtaining - * a copy of this software and associated documentation files - * (the "Software"), to deal in the Software without restriction, - * including without limitation the rights to use, copy, modify, merge, - * publish, distribute, sublicense, and/or sell copies of the Software, - * and to permit persons to whom the Software is furnished to do so, - * subject to the following conditions: - * - * The above copyright notice and this permission notice shall be - * included in all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, - * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF - * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. - * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR - * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF - * CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION - * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - */ - -/* - * The text above constitutes the entire PortAudio license; however, - * the PortAudio community also makes the following non-binding requests: - * - * Any person wishing to distribute modifications to the Software is - * requested to send the modifications to the original developer so that - * they can be incorporated into the canonical version. It is also - * requested that these non-binding requests be included along with the - * license above. - */ - -/** @file - @ingroup public_header - @brief DirectSound-specific PortAudio API extension header file. -*/ - -#include "portaudio.h" -#include "pa_win_waveformat.h" - -#ifdef __cplusplus -extern "C" -{ -#endif /* __cplusplus */ - - -#define paWinDirectSoundUseLowLevelLatencyParameters (0x01) -#define paWinDirectSoundUseChannelMask (0x04) - - -typedef struct PaWinDirectSoundStreamInfo{ - unsigned long size; /**< sizeof(PaWinDirectSoundStreamInfo) */ - PaHostApiTypeId hostApiType; /**< paDirectSound */ - unsigned long version; /**< 2 */ - - unsigned long flags; /**< enable other features of this struct */ - - /** - low-level latency setting support - Sets the size of the DirectSound host buffer. - When flags contains the paWinDirectSoundUseLowLevelLatencyParameters - this size will be used instead of interpreting the generic latency - parameters to Pa_OpenStream(). If the flag is not set this value is ignored. - - If the stream is a full duplex stream the implementation requires that - the values of framesPerBuffer for input and output match (if both are specified). - */ - unsigned long framesPerBuffer; - - /** - support for WAVEFORMATEXTENSIBLE channel masks. If flags contains - paWinDirectSoundUseChannelMask this allows you to specify which speakers - to address in a multichannel stream. Constants for channelMask - are specified in pa_win_waveformat.h - - */ - PaWinWaveFormatChannelMask channelMask; - -}PaWinDirectSoundStreamInfo; - - - -#ifdef __cplusplus -} -#endif /* __cplusplus */ - -#endif /* PA_WIN_DS_H */ diff --git a/libs/windows/include/pa_win_wasapi.h b/libs/windows/include/pa_win_wasapi.h deleted file mode 100644 index 1d86896c..00000000 --- a/libs/windows/include/pa_win_wasapi.h +++ /dev/null @@ -1,443 +0,0 @@ -#ifndef PA_WIN_WASAPI_H -#define PA_WIN_WASAPI_H -/* - * $Id: $ - * PortAudio Portable Real-Time Audio Library - * DirectSound specific extensions - * - * Copyright (c) 1999-2007 Ross Bencina and Phil Burk - * - * Permission is hereby granted, free of charge, to any person obtaining - * a copy of this software and associated documentation files - * (the "Software"), to deal in the Software without restriction, - * including without limitation the rights to use, copy, modify, merge, - * publish, distribute, sublicense, and/or sell copies of the Software, - * and to permit persons to whom the Software is furnished to do so, - * subject to the following conditions: - * - * The above copyright notice and this permission notice shall be - * included in all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, - * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF - * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. - * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR - * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF - * CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION - * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - */ - -/* - * The text above constitutes the entire PortAudio license; however, - * the PortAudio community also makes the following non-binding requests: - * - * Any person wishing to distribute modifications to the Software is - * requested to send the modifications to the original developer so that - * they can be incorporated into the canonical version. It is also - * requested that these non-binding requests be included along with the - * license above. - */ - -/** @file - @ingroup public_header - @brief WASAPI-specific PortAudio API extension header file. -*/ - -#include "portaudio.h" -#include "pa_win_waveformat.h" - -#ifdef __cplusplus -extern "C" -{ -#endif /* __cplusplus */ - - -/* Setup flags */ -typedef enum PaWasapiFlags -{ - /* puts WASAPI into exclusive mode */ - paWinWasapiExclusive = (1 << 0), - - /* allows to skip internal PA processing completely */ - paWinWasapiRedirectHostProcessor = (1 << 1), - - /* assigns custom channel mask */ - paWinWasapiUseChannelMask = (1 << 2), - - /* selects non-Event driven method of data read/write - Note: WASAPI Event driven core is capable of 2ms latency!!!, but Polling - method can only provide 15-20ms latency. */ - paWinWasapiPolling = (1 << 3), - - /* forces custom thread priority setting, must be used if PaWasapiStreamInfo::threadPriority - is set to a custom value */ - paWinWasapiThreadPriority = (1 << 4) -} -PaWasapiFlags; -#define paWinWasapiExclusive (paWinWasapiExclusive) -#define paWinWasapiRedirectHostProcessor (paWinWasapiRedirectHostProcessor) -#define paWinWasapiUseChannelMask (paWinWasapiUseChannelMask) -#define paWinWasapiPolling (paWinWasapiPolling) -#define paWinWasapiThreadPriority (paWinWasapiThreadPriority) - - -/* Host processor. Allows to skip internal PA processing completely. - You must set paWinWasapiRedirectHostProcessor flag to PaWasapiStreamInfo::flags member - in order to have host processor redirected to your callback. - Use with caution! inputFrames and outputFrames depend solely on final device setup. - To query maximal values of inputFrames/outputFrames use PaWasapi_GetFramesPerHostBuffer. -*/ -typedef void (*PaWasapiHostProcessorCallback) (void *inputBuffer, long inputFrames, - void *outputBuffer, long outputFrames, - void *userData); - -/* Device role. */ -typedef enum PaWasapiDeviceRole -{ - eRoleRemoteNetworkDevice = 0, - eRoleSpeakers, - eRoleLineLevel, - eRoleHeadphones, - eRoleMicrophone, - eRoleHeadset, - eRoleHandset, - eRoleUnknownDigitalPassthrough, - eRoleSPDIF, - eRoleHDMI, - eRoleUnknownFormFactor -} -PaWasapiDeviceRole; - - -/* Jack connection type. */ -typedef enum PaWasapiJackConnectionType -{ - eJackConnTypeUnknown, - eJackConnType3Point5mm, - eJackConnTypeQuarter, - eJackConnTypeAtapiInternal, - eJackConnTypeRCA, - eJackConnTypeOptical, - eJackConnTypeOtherDigital, - eJackConnTypeOtherAnalog, - eJackConnTypeMultichannelAnalogDIN, - eJackConnTypeXlrProfessional, - eJackConnTypeRJ11Modem, - eJackConnTypeCombination -} -PaWasapiJackConnectionType; - - -/* Jack geometric location. */ -typedef enum PaWasapiJackGeoLocation -{ - eJackGeoLocUnk = 0, - eJackGeoLocRear = 0x1, /* matches EPcxGeoLocation::eGeoLocRear */ - eJackGeoLocFront, - eJackGeoLocLeft, - eJackGeoLocRight, - eJackGeoLocTop, - eJackGeoLocBottom, - eJackGeoLocRearPanel, - eJackGeoLocRiser, - eJackGeoLocInsideMobileLid, - eJackGeoLocDrivebay, - eJackGeoLocHDMI, - eJackGeoLocOutsideMobileLid, - eJackGeoLocATAPI, - eJackGeoLocReserved5, - eJackGeoLocReserved6, -} -PaWasapiJackGeoLocation; - - -/* Jack general location. */ -typedef enum PaWasapiJackGenLocation -{ - eJackGenLocPrimaryBox = 0, - eJackGenLocInternal, - eJackGenLocSeparate, - eJackGenLocOther -} -PaWasapiJackGenLocation; - - -/* Jack's type of port. */ -typedef enum PaWasapiJackPortConnection -{ - eJackPortConnJack = 0, - eJackPortConnIntegratedDevice, - eJackPortConnBothIntegratedAndJack, - eJackPortConnUnknown -} -PaWasapiJackPortConnection; - - -/* Thread priority. */ -typedef enum PaWasapiThreadPriority -{ - eThreadPriorityNone = 0, - eThreadPriorityAudio, //!< Default for Shared mode. - eThreadPriorityCapture, - eThreadPriorityDistribution, - eThreadPriorityGames, - eThreadPriorityPlayback, - eThreadPriorityProAudio, //!< Default for Exclusive mode. - eThreadPriorityWindowManager -} -PaWasapiThreadPriority; - - -/* Stream descriptor. */ -typedef struct PaWasapiJackDescription -{ - unsigned long channelMapping; - unsigned long color; /* derived from macro: #define RGB(r,g,b) ((COLORREF)(((BYTE)(r)|((WORD)((BYTE)(g))<<8))|(((DWORD)(BYTE)(b))<<16))) */ - PaWasapiJackConnectionType connectionType; - PaWasapiJackGeoLocation geoLocation; - PaWasapiJackGenLocation genLocation; - PaWasapiJackPortConnection portConnection; - unsigned int isConnected; -} -PaWasapiJackDescription; - - -/** Stream category. - Note: - - values are equal to WASAPI AUDIO_STREAM_CATEGORY enum - - supported since Windows 8.0, noop on earler versions - - values 1,2 are deprecated on Windows 10 and not included into enumeration - - @version Available as of 19.6.0 -*/ -typedef enum PaWasapiStreamCategory -{ - eAudioCategoryOther = 0, - eAudioCategoryCommunications = 3, - eAudioCategoryAlerts = 4, - eAudioCategorySoundEffects = 5, - eAudioCategoryGameEffects = 6, - eAudioCategoryGameMedia = 7, - eAudioCategoryGameChat = 8, - eAudioCategorySpeech = 9, - eAudioCategoryMovie = 10, - eAudioCategoryMedia = 11 -} -PaWasapiStreamCategory; - - -/** Stream option. - Note: - - values are equal to WASAPI AUDCLNT_STREAMOPTIONS enum - - supported since Windows 8.1, noop on earler versions - - @version Available as of 19.6.0 -*/ -typedef enum PaWasapiStreamOption -{ - eStreamOptionNone = 0, //!< default - eStreamOptionRaw = 1, //!< bypass WASAPI Audio Engine DSP effects, supported since Windows 8.1 - eStreamOptionMatchFormat = 2 //!< force WASAPI Audio Engine into a stream format, supported since Windows 10 -} -PaWasapiStreamOption; - - -/* Stream descriptor. */ -typedef struct PaWasapiStreamInfo -{ - unsigned long size; /**< sizeof(PaWasapiStreamInfo) */ - PaHostApiTypeId hostApiType; /**< paWASAPI */ - unsigned long version; /**< 1 */ - - unsigned long flags; /**< collection of PaWasapiFlags */ - - /** Support for WAVEFORMATEXTENSIBLE channel masks. If flags contains - paWinWasapiUseChannelMask this allows you to specify which speakers - to address in a multichannel stream. Constants for channelMask - are specified in pa_win_waveformat.h. Will be used only if - paWinWasapiUseChannelMask flag is specified. - */ - PaWinWaveFormatChannelMask channelMask; - - /** Delivers raw data to callback obtained from GetBuffer() methods skipping - internal PortAudio processing inventory completely. userData parameter will - be the same that was passed to Pa_OpenStream method. Will be used only if - paWinWasapiRedirectHostProcessor flag is specified. - */ - PaWasapiHostProcessorCallback hostProcessorOutput; - PaWasapiHostProcessorCallback hostProcessorInput; - - /** Specifies thread priority explicitly. Will be used only if paWinWasapiThreadPriority flag - is specified. - - Please note, if Input/Output streams are opened simultaniously (Full-Duplex mode) - you shall specify same value for threadPriority or othervise one of the values will be used - to setup thread priority. - */ - PaWasapiThreadPriority threadPriority; - - /** Stream category. - @see PaWasapiStreamCategory - @version Available as of 19.6.0 - */ - PaWasapiStreamCategory streamCategory; - - /** Stream option. - @see PaWasapiStreamOption - @version Available as of 19.6.0 - */ - PaWasapiStreamOption streamOption; -} -PaWasapiStreamInfo; - - -/** Returns default sound format for device. Format is represented by PaWinWaveFormat or - WAVEFORMATEXTENSIBLE structure. - - @param pFormat Pointer to PaWinWaveFormat or WAVEFORMATEXTENSIBLE structure. - @param nFormatSize Size of PaWinWaveFormat or WAVEFORMATEXTENSIBLE structure in bytes. - @param nDevice Device index. - - @return Non-negative value indicating the number of bytes copied into format decriptor - or, a PaErrorCode (which are always negative) if PortAudio is not initialized - or an error is encountered. -*/ -int PaWasapi_GetDeviceDefaultFormat( void *pFormat, unsigned int nFormatSize, PaDeviceIndex nDevice ); - - -/** Returns device role (PaWasapiDeviceRole enum). - - @param nDevice device index. - - @return Non-negative value indicating device role or, a PaErrorCode (which are always negative) - if PortAudio is not initialized or an error is encountered. -*/ -int/*PaWasapiDeviceRole*/ PaWasapi_GetDeviceRole( PaDeviceIndex nDevice ); - - -/** Boost thread priority of calling thread (MMCSS). Use it for Blocking Interface only for thread - which makes calls to Pa_WriteStream/Pa_ReadStream. - - @param hTask Handle to pointer to priority task. Must be used with PaWasapi_RevertThreadPriority - method to revert thread priority to initial state. - - @param nPriorityClass Id of thread priority of PaWasapiThreadPriority type. Specifying - eThreadPriorityNone does nothing. - - @return Error code indicating success or failure. - @see PaWasapi_RevertThreadPriority -*/ -PaError PaWasapi_ThreadPriorityBoost( void **hTask, PaWasapiThreadPriority nPriorityClass ); - - -/** Boost thread priority of calling thread (MMCSS). Use it for Blocking Interface only for thread - which makes calls to Pa_WriteStream/Pa_ReadStream. - - @param hTask Task handle obtained by PaWasapi_BoostThreadPriority method. - @return Error code indicating success or failure. - @see PaWasapi_BoostThreadPriority -*/ -PaError PaWasapi_ThreadPriorityRevert( void *hTask ); - - -/** Get number of frames per host buffer. This is maximal value of frames of WASAPI buffer which - can be locked for operations. Use this method as helper to findout maximal values of - inputFrames/outputFrames of PaWasapiHostProcessorCallback. - - @param pStream Pointer to PaStream to query. - @param nInput Pointer to variable to receive number of input frames. Can be NULL. - @param nOutput Pointer to variable to receive number of output frames. Can be NULL. - @return Error code indicating success or failure. - @see PaWasapiHostProcessorCallback -*/ -PaError PaWasapi_GetFramesPerHostBuffer( PaStream *pStream, unsigned int *nInput, unsigned int *nOutput ); - - -/** Get number of jacks associated with a WASAPI device. Use this method to determine if - there are any jacks associated with the provided WASAPI device. Not all audio devices - will support this capability. This is valid for both input and output devices. - @param nDevice device index. - @param jcount Number of jacks is returned in this variable - @return Error code indicating success or failure - @see PaWasapi_GetJackDescription - */ -PaError PaWasapi_GetJackCount(PaDeviceIndex nDevice, int *jcount); - - -/** Get the jack description associated with a WASAPI device and jack number - Before this function is called, use PaWasapi_GetJackCount to determine the - number of jacks associated with device. If jcount is greater than zero, then - each jack from 0 to jcount can be queried with this function to get the jack - description. - @param nDevice device index. - @param jindex Which jack to return information - @param KSJACK_DESCRIPTION This structure filled in on success. - @return Error code indicating success or failure - @see PaWasapi_GetJackCount - */ -PaError PaWasapi_GetJackDescription(PaDeviceIndex nDevice, int jindex, PaWasapiJackDescription *pJackDescription); - - -/* - IMPORTANT: - - WASAPI is implemented for Callback and Blocking interfaces. It supports Shared and Exclusive - share modes. - - Exclusive Mode: - - Exclusive mode allows to deliver audio data directly to hardware bypassing - software mixing. - Exclusive mode is specified by 'paWinWasapiExclusive' flag. - - Callback Interface: - - Provides best audio quality with low latency. Callback interface is implemented in - two versions: - - 1) Event-Driven: - This is the most powerful WASAPI implementation which provides glitch-free - audio at around 3ms latency in Exclusive mode. Lowest possible latency for this mode is - 3 ms for HD Audio class audio chips. For the Shared mode latency can not be - lower than 20 ms. - - 2) Poll-Driven: - Polling is another 2-nd method to operate with WASAPI. It is less efficient than Event-Driven - and provides latency at around 10-13ms. Polling must be used to overcome a system bug - under Windows Vista x64 when application is WOW64(32-bit) and Event-Driven method simply - times out (event handle is never signalled on buffer completion). Please note, such WOW64 bug - does not exist in Vista x86 or Windows 7. - Polling can be setup by speciying 'paWinWasapiPolling' flag. Our WASAPI implementation detects - WOW64 bug and sets 'paWinWasapiPolling' automatically. - - Thread priority: - - Normally thread priority is set automatically and does not require modification. Although - if user wants some tweaking thread priority can be modified by setting 'paWinWasapiThreadPriority' - flag and specifying 'PaWasapiStreamInfo::threadPriority' with value from PaWasapiThreadPriority - enum. - - Blocking Interface: - - Blocking interface is implemented but due to above described Poll-Driven method can not - deliver lowest possible latency. Specifying too low latency in Shared mode will result in - distorted audio although Exclusive mode adds stability. - - Pa_IsFormatSupported: - - To check format with correct Share Mode (Exclusive/Shared) you must supply - PaWasapiStreamInfo with flags paWinWasapiExclusive set through member of - PaStreamParameters::hostApiSpecificStreamInfo structure. - - Pa_OpenStream: - - To set desired Share Mode (Exclusive/Shared) you must supply - PaWasapiStreamInfo with flags paWinWasapiExclusive set through member of - PaStreamParameters::hostApiSpecificStreamInfo structure. -*/ - -#ifdef __cplusplus -} -#endif /* __cplusplus */ - -#endif /* PA_WIN_WASAPI_H */ diff --git a/libs/windows/include/pa_win_waveformat.h b/libs/windows/include/pa_win_waveformat.h deleted file mode 100644 index 2c002671..00000000 --- a/libs/windows/include/pa_win_waveformat.h +++ /dev/null @@ -1,199 +0,0 @@ -#ifndef PA_WIN_WAVEFORMAT_H -#define PA_WIN_WAVEFORMAT_H - -/* - * PortAudio Portable Real-Time Audio Library - * Windows WAVEFORMAT* data structure utilities - * portaudio.h should be included before this file. - * - * Copyright (c) 2007 Ross Bencina - * - * Permission is hereby granted, free of charge, to any person obtaining - * a copy of this software and associated documentation files - * (the "Software"), to deal in the Software without restriction, - * including without limitation the rights to use, copy, modify, merge, - * publish, distribute, sublicense, and/or sell copies of the Software, - * and to permit persons to whom the Software is furnished to do so, - * subject to the following conditions: - * - * The above copyright notice and this permission notice shall be - * included in all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, - * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF - * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. - * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR - * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF - * CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION - * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - */ - -/* - * The text above constitutes the entire PortAudio license; however, - * the PortAudio community also makes the following non-binding requests: - * - * Any person wishing to distribute modifications to the Software is - * requested to send the modifications to the original developer so that - * they can be incorporated into the canonical version. It is also - * requested that these non-binding requests be included along with the - * license above. - */ - -/** @file - @ingroup public_header - @brief Windows specific PortAudio API extension and utilities header file. -*/ - -#ifdef __cplusplus -extern "C" { -#endif - -/* - The following #defines for speaker channel masks are the same - as those in ksmedia.h, except with PAWIN_ prepended, KSAUDIO_ removed - in some cases, and casts to PaWinWaveFormatChannelMask added. -*/ - -typedef unsigned long PaWinWaveFormatChannelMask; - -/* Speaker Positions: */ -#define PAWIN_SPEAKER_FRONT_LEFT ((PaWinWaveFormatChannelMask)0x1) -#define PAWIN_SPEAKER_FRONT_RIGHT ((PaWinWaveFormatChannelMask)0x2) -#define PAWIN_SPEAKER_FRONT_CENTER ((PaWinWaveFormatChannelMask)0x4) -#define PAWIN_SPEAKER_LOW_FREQUENCY ((PaWinWaveFormatChannelMask)0x8) -#define PAWIN_SPEAKER_BACK_LEFT ((PaWinWaveFormatChannelMask)0x10) -#define PAWIN_SPEAKER_BACK_RIGHT ((PaWinWaveFormatChannelMask)0x20) -#define PAWIN_SPEAKER_FRONT_LEFT_OF_CENTER ((PaWinWaveFormatChannelMask)0x40) -#define PAWIN_SPEAKER_FRONT_RIGHT_OF_CENTER ((PaWinWaveFormatChannelMask)0x80) -#define PAWIN_SPEAKER_BACK_CENTER ((PaWinWaveFormatChannelMask)0x100) -#define PAWIN_SPEAKER_SIDE_LEFT ((PaWinWaveFormatChannelMask)0x200) -#define PAWIN_SPEAKER_SIDE_RIGHT ((PaWinWaveFormatChannelMask)0x400) -#define PAWIN_SPEAKER_TOP_CENTER ((PaWinWaveFormatChannelMask)0x800) -#define PAWIN_SPEAKER_TOP_FRONT_LEFT ((PaWinWaveFormatChannelMask)0x1000) -#define PAWIN_SPEAKER_TOP_FRONT_CENTER ((PaWinWaveFormatChannelMask)0x2000) -#define PAWIN_SPEAKER_TOP_FRONT_RIGHT ((PaWinWaveFormatChannelMask)0x4000) -#define PAWIN_SPEAKER_TOP_BACK_LEFT ((PaWinWaveFormatChannelMask)0x8000) -#define PAWIN_SPEAKER_TOP_BACK_CENTER ((PaWinWaveFormatChannelMask)0x10000) -#define PAWIN_SPEAKER_TOP_BACK_RIGHT ((PaWinWaveFormatChannelMask)0x20000) - -/* Bit mask locations reserved for future use */ -#define PAWIN_SPEAKER_RESERVED ((PaWinWaveFormatChannelMask)0x7FFC0000) - -/* Used to specify that any possible permutation of speaker configurations */ -#define PAWIN_SPEAKER_ALL ((PaWinWaveFormatChannelMask)0x80000000) - -/* DirectSound Speaker Config */ -#define PAWIN_SPEAKER_DIRECTOUT 0 -#define PAWIN_SPEAKER_MONO (PAWIN_SPEAKER_FRONT_CENTER) -#define PAWIN_SPEAKER_STEREO (PAWIN_SPEAKER_FRONT_LEFT | PAWIN_SPEAKER_FRONT_RIGHT) -#define PAWIN_SPEAKER_QUAD (PAWIN_SPEAKER_FRONT_LEFT | PAWIN_SPEAKER_FRONT_RIGHT | \ - PAWIN_SPEAKER_BACK_LEFT | PAWIN_SPEAKER_BACK_RIGHT) -#define PAWIN_SPEAKER_SURROUND (PAWIN_SPEAKER_FRONT_LEFT | PAWIN_SPEAKER_FRONT_RIGHT | \ - PAWIN_SPEAKER_FRONT_CENTER | PAWIN_SPEAKER_BACK_CENTER) -#define PAWIN_SPEAKER_5POINT1 (PAWIN_SPEAKER_FRONT_LEFT | PAWIN_SPEAKER_FRONT_RIGHT | \ - PAWIN_SPEAKER_FRONT_CENTER | PAWIN_SPEAKER_LOW_FREQUENCY | \ - PAWIN_SPEAKER_BACK_LEFT | PAWIN_SPEAKER_BACK_RIGHT) -#define PAWIN_SPEAKER_7POINT1 (PAWIN_SPEAKER_FRONT_LEFT | PAWIN_SPEAKER_FRONT_RIGHT | \ - PAWIN_SPEAKER_FRONT_CENTER | PAWIN_SPEAKER_LOW_FREQUENCY | \ - PAWIN_SPEAKER_BACK_LEFT | PAWIN_SPEAKER_BACK_RIGHT | \ - PAWIN_SPEAKER_FRONT_LEFT_OF_CENTER | PAWIN_SPEAKER_FRONT_RIGHT_OF_CENTER) -#define PAWIN_SPEAKER_5POINT1_SURROUND (PAWIN_SPEAKER_FRONT_LEFT | PAWIN_SPEAKER_FRONT_RIGHT | \ - PAWIN_SPEAKER_FRONT_CENTER | PAWIN_SPEAKER_LOW_FREQUENCY | \ - PAWIN_SPEAKER_SIDE_LEFT | PAWIN_SPEAKER_SIDE_RIGHT) -#define PAWIN_SPEAKER_7POINT1_SURROUND (PAWIN_SPEAKER_FRONT_LEFT | PAWIN_SPEAKER_FRONT_RIGHT | \ - PAWIN_SPEAKER_FRONT_CENTER | PAWIN_SPEAKER_LOW_FREQUENCY | \ - PAWIN_SPEAKER_BACK_LEFT | PAWIN_SPEAKER_BACK_RIGHT | \ - PAWIN_SPEAKER_SIDE_LEFT | PAWIN_SPEAKER_SIDE_RIGHT) -/* - According to the Microsoft documentation: - The following are obsolete 5.1 and 7.1 settings (they lack side speakers). Note this means - that the default 5.1 and 7.1 settings (KSAUDIO_SPEAKER_5POINT1 and KSAUDIO_SPEAKER_7POINT1 are - similarly obsolete but are unchanged for compatibility reasons). -*/ -#define PAWIN_SPEAKER_5POINT1_BACK PAWIN_SPEAKER_5POINT1 -#define PAWIN_SPEAKER_7POINT1_WIDE PAWIN_SPEAKER_7POINT1 - -/* DVD Speaker Positions */ -#define PAWIN_SPEAKER_GROUND_FRONT_LEFT PAWIN_SPEAKER_FRONT_LEFT -#define PAWIN_SPEAKER_GROUND_FRONT_CENTER PAWIN_SPEAKER_FRONT_CENTER -#define PAWIN_SPEAKER_GROUND_FRONT_RIGHT PAWIN_SPEAKER_FRONT_RIGHT -#define PAWIN_SPEAKER_GROUND_REAR_LEFT PAWIN_SPEAKER_BACK_LEFT -#define PAWIN_SPEAKER_GROUND_REAR_RIGHT PAWIN_SPEAKER_BACK_RIGHT -#define PAWIN_SPEAKER_TOP_MIDDLE PAWIN_SPEAKER_TOP_CENTER -#define PAWIN_SPEAKER_SUPER_WOOFER PAWIN_SPEAKER_LOW_FREQUENCY - - -/* - PaWinWaveFormat is defined here to provide compatibility with - compilation environments which don't have headers defining - WAVEFORMATEXTENSIBLE (e.g. older versions of MSVC, Borland C++ etc. - - The fields for WAVEFORMATEX and WAVEFORMATEXTENSIBLE are declared as an - unsigned char array here to avoid clients who include this file having - a dependency on windows.h and mmsystem.h, and also to to avoid having - to write separate packing pragmas for each compiler. -*/ -#define PAWIN_SIZEOF_WAVEFORMATEX 18 -#define PAWIN_SIZEOF_WAVEFORMATEXTENSIBLE (PAWIN_SIZEOF_WAVEFORMATEX + 22) - -typedef struct{ - unsigned char fields[ PAWIN_SIZEOF_WAVEFORMATEXTENSIBLE ]; - unsigned long extraLongForAlignment; /* ensure that compiler aligns struct to DWORD */ -} PaWinWaveFormat; - -/* - WAVEFORMATEXTENSIBLE fields: - - union { - WORD wValidBitsPerSample; - WORD wSamplesPerBlock; - WORD wReserved; - } Samples; - DWORD dwChannelMask; - GUID SubFormat; -*/ - -#define PAWIN_INDEXOF_WVALIDBITSPERSAMPLE (PAWIN_SIZEOF_WAVEFORMATEX+0) -#define PAWIN_INDEXOF_DWCHANNELMASK (PAWIN_SIZEOF_WAVEFORMATEX+2) -#define PAWIN_INDEXOF_SUBFORMAT (PAWIN_SIZEOF_WAVEFORMATEX+6) - - -/* - Valid values to pass for the waveFormatTag PaWin_InitializeWaveFormatEx and - PaWin_InitializeWaveFormatExtensible functions below. These must match - the standard Windows WAVE_FORMAT_* values. -*/ -#define PAWIN_WAVE_FORMAT_PCM (1) -#define PAWIN_WAVE_FORMAT_IEEE_FLOAT (3) -#define PAWIN_WAVE_FORMAT_DOLBY_AC3_SPDIF (0x0092) -#define PAWIN_WAVE_FORMAT_WMA_SPDIF (0x0164) - - -/* - returns PAWIN_WAVE_FORMAT_PCM or PAWIN_WAVE_FORMAT_IEEE_FLOAT - depending on the sampleFormat parameter. -*/ -int PaWin_SampleFormatToLinearWaveFormatTag( PaSampleFormat sampleFormat ); - -/* - Use the following two functions to initialize the waveformat structure. -*/ - -void PaWin_InitializeWaveFormatEx( PaWinWaveFormat *waveFormat, - int numChannels, PaSampleFormat sampleFormat, int waveFormatTag, double sampleRate ); - - -void PaWin_InitializeWaveFormatExtensible( PaWinWaveFormat *waveFormat, - int numChannels, PaSampleFormat sampleFormat, int waveFormatTag, double sampleRate, - PaWinWaveFormatChannelMask channelMask ); - - -/* Map a channel count to a speaker channel mask */ -PaWinWaveFormatChannelMask PaWin_DefaultChannelMask( int numChannels ); - - -#ifdef __cplusplus -} -#endif /* __cplusplus */ - -#endif /* PA_WIN_WAVEFORMAT_H */ \ No newline at end of file diff --git a/libs/windows/include/pa_win_wdmks.h b/libs/windows/include/pa_win_wdmks.h deleted file mode 100644 index 35929625..00000000 --- a/libs/windows/include/pa_win_wdmks.h +++ /dev/null @@ -1,137 +0,0 @@ -#ifndef PA_WIN_WDMKS_H -#define PA_WIN_WDMKS_H -/* - * $Id$ - * PortAudio Portable Real-Time Audio Library - * WDM/KS specific extensions - * - * Copyright (c) 1999-2007 Ross Bencina and Phil Burk - * - * Permission is hereby granted, free of charge, to any person obtaining - * a copy of this software and associated documentation files - * (the "Software"), to deal in the Software without restriction, - * including without limitation the rights to use, copy, modify, merge, - * publish, distribute, sublicense, and/or sell copies of the Software, - * and to permit persons to whom the Software is furnished to do so, - * subject to the following conditions: - * - * The above copyright notice and this permission notice shall be - * included in all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, - * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF - * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. - * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR - * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF - * CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION - * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - */ - -/* - * The text above constitutes the entire PortAudio license; however, - * the PortAudio community also makes the following non-binding requests: - * - * Any person wishing to distribute modifications to the Software is - * requested to send the modifications to the original developer so that - * they can be incorporated into the canonical version. It is also - * requested that these non-binding requests be included along with the - * license above. - */ - -/** @file - @ingroup public_header - @brief WDM Kernel Streaming-specific PortAudio API extension header file. -*/ - - -#include "portaudio.h" - -#include - -#ifdef __cplusplus -extern "C" -{ -#endif /* __cplusplus */ - - /** Flags to indicate valid fields in PaWinWDMKSInfo. - @see PaWinWDMKSInfo - @version Available as of 19.5.0. - */ - typedef enum PaWinWDMKSFlags - { - /** Makes WDMKS use the supplied latency figures instead of relying on the frame size reported - by the WaveCyclic device. Use at own risk! - */ - paWinWDMKSOverrideFramesize = (1 << 0), - - /** Makes WDMKS (output stream) use the given channelMask instead of the default. - @version Available as of 19.5.0. - */ - paWinWDMKSUseGivenChannelMask = (1 << 1), - - } PaWinWDMKSFlags; - - typedef struct PaWinWDMKSInfo{ - unsigned long size; /**< sizeof(PaWinWDMKSInfo) */ - PaHostApiTypeId hostApiType; /**< paWDMKS */ - unsigned long version; /**< 1 */ - - /** Flags indicate which fields are valid. - @see PaWinWDMKSFlags - @version Available as of 19.5.0. - */ - unsigned long flags; - - /** The number of packets to use for WaveCyclic devices, range is [2, 8]. Set to zero for default value of 2. */ - unsigned noOfPackets; - - /** If paWinWDMKSUseGivenChannelMask bit is set in flags, use this as channelMask instead of default. - @see PaWinWDMKSFlags - @version Available as of 19.5.0. - */ - unsigned channelMask; - } PaWinWDMKSInfo; - - typedef enum PaWDMKSType - { - Type_kNotUsed, - Type_kWaveCyclic, - Type_kWaveRT, - Type_kCnt, - } PaWDMKSType; - - typedef enum PaWDMKSSubType - { - SubType_kUnknown, - SubType_kNotification, - SubType_kPolled, - SubType_kCnt, - } PaWDMKSSubType; - - typedef struct PaWinWDMKSDeviceInfo { - wchar_t filterPath[MAX_PATH]; /**< KS filter path in Unicode! */ - wchar_t topologyPath[MAX_PATH]; /**< Topology filter path in Unicode! */ - PaWDMKSType streamingType; - GUID deviceProductGuid; /**< The product GUID of the device (if supported) */ - } PaWinWDMKSDeviceInfo; - - typedef struct PaWDMKSDirectionSpecificStreamInfo - { - PaDeviceIndex device; - unsigned channels; /**< No of channels the device is opened with */ - unsigned framesPerHostBuffer; /**< No of frames of the device buffer */ - int endpointPinId; /**< Endpoint pin ID (on topology filter if topologyName is not empty) */ - int muxNodeId; /**< Only valid for input */ - PaWDMKSSubType streamingSubType; /**< Not known until device is opened for streaming */ - } PaWDMKSDirectionSpecificStreamInfo; - - typedef struct PaWDMKSSpecificStreamInfo { - PaWDMKSDirectionSpecificStreamInfo input; - PaWDMKSDirectionSpecificStreamInfo output; - } PaWDMKSSpecificStreamInfo; - -#ifdef __cplusplus -} -#endif /* __cplusplus */ - -#endif /* PA_WIN_DS_H */ diff --git a/libs/windows/include/pa_win_wmme.h b/libs/windows/include/pa_win_wmme.h deleted file mode 100644 index f84b68b8..00000000 --- a/libs/windows/include/pa_win_wmme.h +++ /dev/null @@ -1,185 +0,0 @@ -#ifndef PA_WIN_WMME_H -#define PA_WIN_WMME_H -/* - * $Id$ - * PortAudio Portable Real-Time Audio Library - * MME specific extensions - * - * Copyright (c) 1999-2000 Ross Bencina and Phil Burk - * - * Permission is hereby granted, free of charge, to any person obtaining - * a copy of this software and associated documentation files - * (the "Software"), to deal in the Software without restriction, - * including without limitation the rights to use, copy, modify, merge, - * publish, distribute, sublicense, and/or sell copies of the Software, - * and to permit persons to whom the Software is furnished to do so, - * subject to the following conditions: - * - * The above copyright notice and this permission notice shall be - * included in all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, - * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF - * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. - * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR - * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF - * CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION - * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - */ - -/* - * The text above constitutes the entire PortAudio license; however, - * the PortAudio community also makes the following non-binding requests: - * - * Any person wishing to distribute modifications to the Software is - * requested to send the modifications to the original developer so that - * they can be incorporated into the canonical version. It is also - * requested that these non-binding requests be included along with the - * license above. - */ - -/** @file - @ingroup public_header - @brief WMME-specific PortAudio API extension header file. -*/ - -#include "portaudio.h" -#include "pa_win_waveformat.h" - -#ifdef __cplusplus -extern "C" -{ -#endif /* __cplusplus */ - - -/* The following are flags which can be set in - PaWinMmeStreamInfo's flags field. -*/ - -#define paWinMmeUseLowLevelLatencyParameters (0x01) -#define paWinMmeUseMultipleDevices (0x02) /* use mme specific multiple device feature */ -#define paWinMmeUseChannelMask (0x04) - -/* By default, the mme implementation drops the processing thread's priority - to THREAD_PRIORITY_NORMAL and sleeps the thread if the CPU load exceeds 100% - This flag disables any priority throttling. The processing thread will always - run at THREAD_PRIORITY_TIME_CRITICAL. -*/ -#define paWinMmeDontThrottleOverloadedProcessingThread (0x08) - -/* Flags for non-PCM spdif passthrough. -*/ -#define paWinMmeWaveFormatDolbyAc3Spdif (0x10) -#define paWinMmeWaveFormatWmaSpdif (0x20) - - -typedef struct PaWinMmeDeviceAndChannelCount{ - PaDeviceIndex device; - int channelCount; -}PaWinMmeDeviceAndChannelCount; - - -typedef struct PaWinMmeStreamInfo{ - unsigned long size; /**< sizeof(PaWinMmeStreamInfo) */ - PaHostApiTypeId hostApiType; /**< paMME */ - unsigned long version; /**< 1 */ - - unsigned long flags; - - /* low-level latency setting support - These settings control the number and size of host buffers in order - to set latency. They will be used instead of the generic parameters - to Pa_OpenStream() if flags contains the PaWinMmeUseLowLevelLatencyParameters - flag. - - If PaWinMmeStreamInfo structures with PaWinMmeUseLowLevelLatencyParameters - are supplied for both input and output in a full duplex stream, then the - input and output framesPerBuffer must be the same, or the larger of the - two must be a multiple of the smaller, otherwise a - paIncompatibleHostApiSpecificStreamInfo error will be returned from - Pa_OpenStream(). - */ - unsigned long framesPerBuffer; - unsigned long bufferCount; /* formerly numBuffers */ - - /* multiple devices per direction support - If flags contains the PaWinMmeUseMultipleDevices flag, - this functionality will be used, otherwise the device parameter to - Pa_OpenStream() will be used instead. - If devices are specified here, the corresponding device parameter - to Pa_OpenStream() should be set to paUseHostApiSpecificDeviceSpecification, - otherwise an paInvalidDevice error will result. - The total number of channels accross all specified devices - must agree with the corresponding channelCount parameter to - Pa_OpenStream() otherwise a paInvalidChannelCount error will result. - */ - PaWinMmeDeviceAndChannelCount *devices; - unsigned long deviceCount; - - /* - support for WAVEFORMATEXTENSIBLE channel masks. If flags contains - paWinMmeUseChannelMask this allows you to specify which speakers - to address in a multichannel stream. Constants for channelMask - are specified in pa_win_waveformat.h - - */ - PaWinWaveFormatChannelMask channelMask; - -}PaWinMmeStreamInfo; - - -/** Retrieve the number of wave in handles used by a PortAudio WinMME stream. - Returns zero if the stream is output only. - - @return A non-negative value indicating the number of wave in handles - or, a PaErrorCode (which are always negative) if PortAudio is not initialized - or an error is encountered. - - @see PaWinMME_GetStreamInputHandle -*/ -int PaWinMME_GetStreamInputHandleCount( PaStream* stream ); - - -/** Retrieve a wave in handle used by a PortAudio WinMME stream. - - @param stream The stream to query. - @param handleIndex The zero based index of the wave in handle to retrieve. This - should be in the range [0, PaWinMME_GetStreamInputHandleCount(stream)-1]. - - @return A valid wave in handle, or NULL if an error occurred. - - @see PaWinMME_GetStreamInputHandle -*/ -HWAVEIN PaWinMME_GetStreamInputHandle( PaStream* stream, int handleIndex ); - - -/** Retrieve the number of wave out handles used by a PortAudio WinMME stream. - Returns zero if the stream is input only. - - @return A non-negative value indicating the number of wave out handles - or, a PaErrorCode (which are always negative) if PortAudio is not initialized - or an error is encountered. - - @see PaWinMME_GetStreamOutputHandle -*/ -int PaWinMME_GetStreamOutputHandleCount( PaStream* stream ); - - -/** Retrieve a wave out handle used by a PortAudio WinMME stream. - - @param stream The stream to query. - @param handleIndex The zero based index of the wave out handle to retrieve. - This should be in the range [0, PaWinMME_GetStreamOutputHandleCount(stream)-1]. - - @return A valid wave out handle, or NULL if an error occurred. - - @see PaWinMME_GetStreamOutputHandleCount -*/ -HWAVEOUT PaWinMME_GetStreamOutputHandle( PaStream* stream, int handleIndex ); - - -#ifdef __cplusplus -} -#endif /* __cplusplus */ - -#endif /* PA_WIN_WMME_H */ diff --git a/libs/windows/include/portaudio.h b/libs/windows/include/portaudio.h deleted file mode 100644 index 8a94aafb..00000000 --- a/libs/windows/include/portaudio.h +++ /dev/null @@ -1,1225 +0,0 @@ -#ifndef PORTAUDIO_H -#define PORTAUDIO_H -/* - * $Id$ - * PortAudio Portable Real-Time Audio Library - * PortAudio API Header File - * Latest version available at: http://www.portaudio.com/ - * - * Copyright (c) 1999-2002 Ross Bencina and Phil Burk - * - * Permission is hereby granted, free of charge, to any person obtaining - * a copy of this software and associated documentation files - * (the "Software"), to deal in the Software without restriction, - * including without limitation the rights to use, copy, modify, merge, - * publish, distribute, sublicense, and/or sell copies of the Software, - * and to permit persons to whom the Software is furnished to do so, - * subject to the following conditions: - * - * The above copyright notice and this permission notice shall be - * included in all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, - * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF - * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. - * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR - * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF - * CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION - * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - */ - -/* - * The text above constitutes the entire PortAudio license; however, - * the PortAudio community also makes the following non-binding requests: - * - * Any person wishing to distribute modifications to the Software is - * requested to send the modifications to the original developer so that - * they can be incorporated into the canonical version. It is also - * requested that these non-binding requests be included along with the - * license above. - */ - -/** @file - @ingroup public_header - @brief The portable PortAudio API. -*/ - - -#ifdef __cplusplus -extern "C" -{ -#endif /* __cplusplus */ - -/** Retrieve the release number of the currently running PortAudio build. - For example, for version "19.5.1" this will return 0x00130501. - - @see paMakeVersionNumber -*/ -int Pa_GetVersion( void ); - -/** Retrieve a textual description of the current PortAudio build, - e.g. "PortAudio V19.5.0-devel, revision 1952M". - The format of the text may change in the future. Do not try to parse the - returned string. - - @deprecated As of 19.5.0, use Pa_GetVersionInfo()->versionText instead. -*/ -const char* Pa_GetVersionText( void ); - -/** - Generate a packed integer version number in the same format used - by Pa_GetVersion(). Use this to compare a specified version number with - the currently running version. For example: - - @code - if( Pa_GetVersion() < paMakeVersionNumber(19,5,1) ) {} - @endcode - - @see Pa_GetVersion, Pa_GetVersionInfo - @version Available as of 19.5.0. -*/ -#define paMakeVersionNumber(major, minor, subminor) \ - (((major)&0xFF)<<16 | ((minor)&0xFF)<<8 | ((subminor)&0xFF)) - - -/** - A structure containing PortAudio API version information. - @see Pa_GetVersionInfo, paMakeVersionNumber - @version Available as of 19.5.0. -*/ -typedef struct PaVersionInfo { - int versionMajor; - int versionMinor; - int versionSubMinor; - /** - This is currently the Git revision hash but may change in the future. - The versionControlRevision is updated by running a script before compiling the library. - If the update does not occur, this value may refer to an earlier revision. - */ - const char *versionControlRevision; - /** Version as a string, for example "PortAudio V19.5.0-devel, revision 1952M" */ - const char *versionText; -} PaVersionInfo; - -/** Retrieve version information for the currently running PortAudio build. - @return A pointer to an immutable PaVersionInfo structure. - - @note This function can be called at any time. It does not require PortAudio - to be initialized. The structure pointed to is statically allocated. Do not - attempt to free it or modify it. - - @see PaVersionInfo, paMakeVersionNumber - @version Available as of 19.5.0. -*/ -const PaVersionInfo* Pa_GetVersionInfo(); - - -/** Error codes returned by PortAudio functions. - Note that with the exception of paNoError, all PaErrorCodes are negative. -*/ - -typedef int PaError; -typedef enum PaErrorCode -{ - paNoError = 0, - - paNotInitialized = -10000, - paUnanticipatedHostError, - paInvalidChannelCount, - paInvalidSampleRate, - paInvalidDevice, - paInvalidFlag, - paSampleFormatNotSupported, - paBadIODeviceCombination, - paInsufficientMemory, - paBufferTooBig, - paBufferTooSmall, - paNullCallback, - paBadStreamPtr, - paTimedOut, - paInternalError, - paDeviceUnavailable, - paIncompatibleHostApiSpecificStreamInfo, - paStreamIsStopped, - paStreamIsNotStopped, - paInputOverflowed, - paOutputUnderflowed, - paHostApiNotFound, - paInvalidHostApi, - paCanNotReadFromACallbackStream, - paCanNotWriteToACallbackStream, - paCanNotReadFromAnOutputOnlyStream, - paCanNotWriteToAnInputOnlyStream, - paIncompatibleStreamHostApi, - paBadBufferPtr -} PaErrorCode; - - -/** Translate the supplied PortAudio error code into a human readable - message. -*/ -const char *Pa_GetErrorText( PaError errorCode ); - - -/** Library initialization function - call this before using PortAudio. - This function initializes internal data structures and prepares underlying - host APIs for use. With the exception of Pa_GetVersion(), Pa_GetVersionText(), - and Pa_GetErrorText(), this function MUST be called before using any other - PortAudio API functions. - - If Pa_Initialize() is called multiple times, each successful - call must be matched with a corresponding call to Pa_Terminate(). - Pairs of calls to Pa_Initialize()/Pa_Terminate() may overlap, and are not - required to be fully nested. - - Note that if Pa_Initialize() returns an error code, Pa_Terminate() should - NOT be called. - - @return paNoError if successful, otherwise an error code indicating the cause - of failure. - - @see Pa_Terminate -*/ -PaError Pa_Initialize( void ); - - -/** Library termination function - call this when finished using PortAudio. - This function deallocates all resources allocated by PortAudio since it was - initialized by a call to Pa_Initialize(). In cases where Pa_Initialise() has - been called multiple times, each call must be matched with a corresponding call - to Pa_Terminate(). The final matching call to Pa_Terminate() will automatically - close any PortAudio streams that are still open. - - Pa_Terminate() MUST be called before exiting a program which uses PortAudio. - Failure to do so may result in serious resource leaks, such as audio devices - not being available until the next reboot. - - @return paNoError if successful, otherwise an error code indicating the cause - of failure. - - @see Pa_Initialize -*/ -PaError Pa_Terminate( void ); - - - -/** The type used to refer to audio devices. Values of this type usually - range from 0 to (Pa_GetDeviceCount()-1), and may also take on the PaNoDevice - and paUseHostApiSpecificDeviceSpecification values. - - @see Pa_GetDeviceCount, paNoDevice, paUseHostApiSpecificDeviceSpecification -*/ -typedef int PaDeviceIndex; - - -/** A special PaDeviceIndex value indicating that no device is available, - or should be used. - - @see PaDeviceIndex -*/ -#define paNoDevice ((PaDeviceIndex)-1) - - -/** A special PaDeviceIndex value indicating that the device(s) to be used - are specified in the host api specific stream info structure. - - @see PaDeviceIndex -*/ -#define paUseHostApiSpecificDeviceSpecification ((PaDeviceIndex)-2) - - -/* Host API enumeration mechanism */ - -/** The type used to enumerate to host APIs at runtime. Values of this type - range from 0 to (Pa_GetHostApiCount()-1). - - @see Pa_GetHostApiCount -*/ -typedef int PaHostApiIndex; - - -/** Retrieve the number of available host APIs. Even if a host API is - available it may have no devices available. - - @return A non-negative value indicating the number of available host APIs - or, a PaErrorCode (which are always negative) if PortAudio is not initialized - or an error is encountered. - - @see PaHostApiIndex -*/ -PaHostApiIndex Pa_GetHostApiCount( void ); - - -/** Retrieve the index of the default host API. The default host API will be - the lowest common denominator host API on the current platform and is - unlikely to provide the best performance. - - @return A non-negative value ranging from 0 to (Pa_GetHostApiCount()-1) - indicating the default host API index or, a PaErrorCode (which are always - negative) if PortAudio is not initialized or an error is encountered. -*/ -PaHostApiIndex Pa_GetDefaultHostApi( void ); - - -/** Unchanging unique identifiers for each supported host API. This type - is used in the PaHostApiInfo structure. The values are guaranteed to be - unique and to never change, thus allowing code to be written that - conditionally uses host API specific extensions. - - New type ids will be allocated when support for a host API reaches - "public alpha" status, prior to that developers should use the - paInDevelopment type id. - - @see PaHostApiInfo -*/ -typedef enum PaHostApiTypeId -{ - paInDevelopment=0, /* use while developing support for a new host API */ - paDirectSound=1, - paMME=2, - paASIO=3, - paSoundManager=4, - paCoreAudio=5, - paOSS=7, - paALSA=8, - paAL=9, - paBeOS=10, - paWDMKS=11, - paJACK=12, - paWASAPI=13, - paAudioScienceHPI=14 -} PaHostApiTypeId; - - -/** A structure containing information about a particular host API. */ - -typedef struct PaHostApiInfo -{ - /** this is struct version 1 */ - int structVersion; - /** The well known unique identifier of this host API @see PaHostApiTypeId */ - PaHostApiTypeId type; - /** A textual description of the host API for display on user interfaces. */ - const char *name; - - /** The number of devices belonging to this host API. This field may be - used in conjunction with Pa_HostApiDeviceIndexToDeviceIndex() to enumerate - all devices for this host API. - @see Pa_HostApiDeviceIndexToDeviceIndex - */ - int deviceCount; - - /** The default input device for this host API. The value will be a - device index ranging from 0 to (Pa_GetDeviceCount()-1), or paNoDevice - if no default input device is available. - */ - PaDeviceIndex defaultInputDevice; - - /** The default output device for this host API. The value will be a - device index ranging from 0 to (Pa_GetDeviceCount()-1), or paNoDevice - if no default output device is available. - */ - PaDeviceIndex defaultOutputDevice; - -} PaHostApiInfo; - - -/** Retrieve a pointer to a structure containing information about a specific - host Api. - - @param hostApi A valid host API index ranging from 0 to (Pa_GetHostApiCount()-1) - - @return A pointer to an immutable PaHostApiInfo structure describing - a specific host API. If the hostApi parameter is out of range or an error - is encountered, the function returns NULL. - - The returned structure is owned by the PortAudio implementation and must not - be manipulated or freed. The pointer is only guaranteed to be valid between - calls to Pa_Initialize() and Pa_Terminate(). -*/ -const PaHostApiInfo * Pa_GetHostApiInfo( PaHostApiIndex hostApi ); - - -/** Convert a static host API unique identifier, into a runtime - host API index. - - @param type A unique host API identifier belonging to the PaHostApiTypeId - enumeration. - - @return A valid PaHostApiIndex ranging from 0 to (Pa_GetHostApiCount()-1) or, - a PaErrorCode (which are always negative) if PortAudio is not initialized - or an error is encountered. - - The paHostApiNotFound error code indicates that the host API specified by the - type parameter is not available. - - @see PaHostApiTypeId -*/ -PaHostApiIndex Pa_HostApiTypeIdToHostApiIndex( PaHostApiTypeId type ); - - -/** Convert a host-API-specific device index to standard PortAudio device index. - This function may be used in conjunction with the deviceCount field of - PaHostApiInfo to enumerate all devices for the specified host API. - - @param hostApi A valid host API index ranging from 0 to (Pa_GetHostApiCount()-1) - - @param hostApiDeviceIndex A valid per-host device index in the range - 0 to (Pa_GetHostApiInfo(hostApi)->deviceCount-1) - - @return A non-negative PaDeviceIndex ranging from 0 to (Pa_GetDeviceCount()-1) - or, a PaErrorCode (which are always negative) if PortAudio is not initialized - or an error is encountered. - - A paInvalidHostApi error code indicates that the host API index specified by - the hostApi parameter is out of range. - - A paInvalidDevice error code indicates that the hostApiDeviceIndex parameter - is out of range. - - @see PaHostApiInfo -*/ -PaDeviceIndex Pa_HostApiDeviceIndexToDeviceIndex( PaHostApiIndex hostApi, - int hostApiDeviceIndex ); - - - -/** Structure used to return information about a host error condition. -*/ -typedef struct PaHostErrorInfo{ - PaHostApiTypeId hostApiType; /**< the host API which returned the error code */ - long errorCode; /**< the error code returned */ - const char *errorText; /**< a textual description of the error if available, otherwise a zero-length string */ -}PaHostErrorInfo; - - -/** Return information about the last host error encountered. The error - information returned by Pa_GetLastHostErrorInfo() will never be modified - asynchronously by errors occurring in other PortAudio owned threads - (such as the thread that manages the stream callback.) - - This function is provided as a last resort, primarily to enhance debugging - by providing clients with access to all available error information. - - @return A pointer to an immutable structure constraining information about - the host error. The values in this structure will only be valid if a - PortAudio function has previously returned the paUnanticipatedHostError - error code. -*/ -const PaHostErrorInfo* Pa_GetLastHostErrorInfo( void ); - - - -/* Device enumeration and capabilities */ - -/** Retrieve the number of available devices. The number of available devices - may be zero. - - @return A non-negative value indicating the number of available devices or, - a PaErrorCode (which are always negative) if PortAudio is not initialized - or an error is encountered. -*/ -PaDeviceIndex Pa_GetDeviceCount( void ); - - -/** Retrieve the index of the default input device. The result can be - used in the inputDevice parameter to Pa_OpenStream(). - - @return The default input device index for the default host API, or paNoDevice - if no default input device is available or an error was encountered. -*/ -PaDeviceIndex Pa_GetDefaultInputDevice( void ); - - -/** Retrieve the index of the default output device. The result can be - used in the outputDevice parameter to Pa_OpenStream(). - - @return The default output device index for the default host API, or paNoDevice - if no default output device is available or an error was encountered. - - @note - On the PC, the user can specify a default device by - setting an environment variable. For example, to use device #1. -
- set PA_RECOMMENDED_OUTPUT_DEVICE=1
-
- The user should first determine the available device ids by using - the supplied application "pa_devs". -*/ -PaDeviceIndex Pa_GetDefaultOutputDevice( void ); - - -/** The type used to represent monotonic time in seconds. PaTime is - used for the fields of the PaStreamCallbackTimeInfo argument to the - PaStreamCallback and as the result of Pa_GetStreamTime(). - - PaTime values have unspecified origin. - - @see PaStreamCallback, PaStreamCallbackTimeInfo, Pa_GetStreamTime -*/ -typedef double PaTime; - - -/** A type used to specify one or more sample formats. Each value indicates - a possible format for sound data passed to and from the stream callback, - Pa_ReadStream and Pa_WriteStream. - - The standard formats paFloat32, paInt16, paInt32, paInt24, paInt8 - and aUInt8 are usually implemented by all implementations. - - The floating point representation (paFloat32) uses +1.0 and -1.0 as the - maximum and minimum respectively. - - paUInt8 is an unsigned 8 bit format where 128 is considered "ground" - - The paNonInterleaved flag indicates that audio data is passed as an array - of pointers to separate buffers, one buffer for each channel. Usually, - when this flag is not used, audio data is passed as a single buffer with - all channels interleaved. - - @see Pa_OpenStream, Pa_OpenDefaultStream, PaDeviceInfo - @see paFloat32, paInt16, paInt32, paInt24, paInt8 - @see paUInt8, paCustomFormat, paNonInterleaved -*/ -typedef unsigned long PaSampleFormat; - - -#define paFloat32 ((PaSampleFormat) 0x00000001) /**< @see PaSampleFormat */ -#define paInt32 ((PaSampleFormat) 0x00000002) /**< @see PaSampleFormat */ -#define paInt24 ((PaSampleFormat) 0x00000004) /**< Packed 24 bit format. @see PaSampleFormat */ -#define paInt16 ((PaSampleFormat) 0x00000008) /**< @see PaSampleFormat */ -#define paInt8 ((PaSampleFormat) 0x00000010) /**< @see PaSampleFormat */ -#define paUInt8 ((PaSampleFormat) 0x00000020) /**< @see PaSampleFormat */ -#define paCustomFormat ((PaSampleFormat) 0x00010000) /**< @see PaSampleFormat */ - -#define paNonInterleaved ((PaSampleFormat) 0x80000000) /**< @see PaSampleFormat */ - -/** A structure providing information and capabilities of PortAudio devices. - Devices may support input, output or both input and output. -*/ -typedef struct PaDeviceInfo -{ - int structVersion; /* this is struct version 2 */ - const char *name; - PaHostApiIndex hostApi; /**< note this is a host API index, not a type id*/ - - int maxInputChannels; - int maxOutputChannels; - - /** Default latency values for interactive performance. */ - PaTime defaultLowInputLatency; - PaTime defaultLowOutputLatency; - /** Default latency values for robust non-interactive applications (eg. playing sound files). */ - PaTime defaultHighInputLatency; - PaTime defaultHighOutputLatency; - - double defaultSampleRate; -} PaDeviceInfo; - - -/** Retrieve a pointer to a PaDeviceInfo structure containing information - about the specified device. - @return A pointer to an immutable PaDeviceInfo structure. If the device - parameter is out of range the function returns NULL. - - @param device A valid device index in the range 0 to (Pa_GetDeviceCount()-1) - - @note PortAudio manages the memory referenced by the returned pointer, - the client must not manipulate or free the memory. The pointer is only - guaranteed to be valid between calls to Pa_Initialize() and Pa_Terminate(). - - @see PaDeviceInfo, PaDeviceIndex -*/ -const PaDeviceInfo* Pa_GetDeviceInfo( PaDeviceIndex device ); - - -/** Parameters for one direction (input or output) of a stream. -*/ -typedef struct PaStreamParameters -{ - /** A valid device index in the range 0 to (Pa_GetDeviceCount()-1) - specifying the device to be used or the special constant - paUseHostApiSpecificDeviceSpecification which indicates that the actual - device(s) to use are specified in hostApiSpecificStreamInfo. - This field must not be set to paNoDevice. - */ - PaDeviceIndex device; - - /** The number of channels of sound to be delivered to the - stream callback or accessed by Pa_ReadStream() or Pa_WriteStream(). - It can range from 1 to the value of maxInputChannels in the - PaDeviceInfo record for the device specified by the device parameter. - */ - int channelCount; - - /** The sample format of the buffer provided to the stream callback, - a_ReadStream() or Pa_WriteStream(). It may be any of the formats described - by the PaSampleFormat enumeration. - */ - PaSampleFormat sampleFormat; - - /** The desired latency in seconds. Where practical, implementations should - configure their latency based on these parameters, otherwise they may - choose the closest viable latency instead. Unless the suggested latency - is greater than the absolute upper limit for the device implementations - should round the suggestedLatency up to the next practical value - ie to - provide an equal or higher latency than suggestedLatency wherever possible. - Actual latency values for an open stream may be retrieved using the - inputLatency and outputLatency fields of the PaStreamInfo structure - returned by Pa_GetStreamInfo(). - @see default*Latency in PaDeviceInfo, *Latency in PaStreamInfo - */ - PaTime suggestedLatency; - - /** An optional pointer to a host api specific data structure - containing additional information for device setup and/or stream processing. - hostApiSpecificStreamInfo is never required for correct operation, - if not used it should be set to NULL. - */ - void *hostApiSpecificStreamInfo; - -} PaStreamParameters; - - -/** Return code for Pa_IsFormatSupported indicating success. */ -#define paFormatIsSupported (0) - -/** Determine whether it would be possible to open a stream with the specified - parameters. - - @param inputParameters A structure that describes the input parameters used to - open a stream. The suggestedLatency field is ignored. See PaStreamParameters - for a description of these parameters. inputParameters must be NULL for - output-only streams. - - @param outputParameters A structure that describes the output parameters used - to open a stream. The suggestedLatency field is ignored. See PaStreamParameters - for a description of these parameters. outputParameters must be NULL for - input-only streams. - - @param sampleRate The required sampleRate. For full-duplex streams it is the - sample rate for both input and output - - @return Returns 0 if the format is supported, and an error code indicating why - the format is not supported otherwise. The constant paFormatIsSupported is - provided to compare with the return value for success. - - @see paFormatIsSupported, PaStreamParameters -*/ -PaError Pa_IsFormatSupported( const PaStreamParameters *inputParameters, - const PaStreamParameters *outputParameters, - double sampleRate ); - - - -/* Streaming types and functions */ - - -/** - A single PaStream can provide multiple channels of real-time - streaming audio input and output to a client application. A stream - provides access to audio hardware represented by one or more - PaDevices. Depending on the underlying Host API, it may be possible - to open multiple streams using the same device, however this behavior - is implementation defined. Portable applications should assume that - a PaDevice may be simultaneously used by at most one PaStream. - - Pointers to PaStream objects are passed between PortAudio functions that - operate on streams. - - @see Pa_OpenStream, Pa_OpenDefaultStream, Pa_OpenDefaultStream, Pa_CloseStream, - Pa_StartStream, Pa_StopStream, Pa_AbortStream, Pa_IsStreamActive, - Pa_GetStreamTime, Pa_GetStreamCpuLoad - -*/ -typedef void PaStream; - - -/** Can be passed as the framesPerBuffer parameter to Pa_OpenStream() - or Pa_OpenDefaultStream() to indicate that the stream callback will - accept buffers of any size. -*/ -#define paFramesPerBufferUnspecified (0) - - -/** Flags used to control the behavior of a stream. They are passed as - parameters to Pa_OpenStream or Pa_OpenDefaultStream. Multiple flags may be - ORed together. - - @see Pa_OpenStream, Pa_OpenDefaultStream - @see paNoFlag, paClipOff, paDitherOff, paNeverDropInput, - paPrimeOutputBuffersUsingStreamCallback, paPlatformSpecificFlags -*/ -typedef unsigned long PaStreamFlags; - -/** @see PaStreamFlags */ -#define paNoFlag ((PaStreamFlags) 0) - -/** Disable default clipping of out of range samples. - @see PaStreamFlags -*/ -#define paClipOff ((PaStreamFlags) 0x00000001) - -/** Disable default dithering. - @see PaStreamFlags -*/ -#define paDitherOff ((PaStreamFlags) 0x00000002) - -/** Flag requests that where possible a full duplex stream will not discard - overflowed input samples without calling the stream callback. This flag is - only valid for full duplex callback streams and only when used in combination - with the paFramesPerBufferUnspecified (0) framesPerBuffer parameter. Using - this flag incorrectly results in a paInvalidFlag error being returned from - Pa_OpenStream and Pa_OpenDefaultStream. - - @see PaStreamFlags, paFramesPerBufferUnspecified -*/ -#define paNeverDropInput ((PaStreamFlags) 0x00000004) - -/** Call the stream callback to fill initial output buffers, rather than the - default behavior of priming the buffers with zeros (silence). This flag has - no effect for input-only and blocking read/write streams. - - @see PaStreamFlags -*/ -#define paPrimeOutputBuffersUsingStreamCallback ((PaStreamFlags) 0x00000008) - -/** A mask specifying the platform specific bits. - @see PaStreamFlags -*/ -#define paPlatformSpecificFlags ((PaStreamFlags)0xFFFF0000) - -/** - Timing information for the buffers passed to the stream callback. - - Time values are expressed in seconds and are synchronised with the time base used by Pa_GetStreamTime() for the associated stream. - - @see PaStreamCallback, Pa_GetStreamTime -*/ -typedef struct PaStreamCallbackTimeInfo{ - PaTime inputBufferAdcTime; /**< The time when the first sample of the input buffer was captured at the ADC input */ - PaTime currentTime; /**< The time when the stream callback was invoked */ - PaTime outputBufferDacTime; /**< The time when the first sample of the output buffer will output the DAC */ -} PaStreamCallbackTimeInfo; - - -/** - Flag bit constants for the statusFlags to PaStreamCallback. - - @see paInputUnderflow, paInputOverflow, paOutputUnderflow, paOutputOverflow, - paPrimingOutput -*/ -typedef unsigned long PaStreamCallbackFlags; - -/** In a stream opened with paFramesPerBufferUnspecified, indicates that - input data is all silence (zeros) because no real data is available. In a - stream opened without paFramesPerBufferUnspecified, it indicates that one or - more zero samples have been inserted into the input buffer to compensate - for an input underflow. - @see PaStreamCallbackFlags -*/ -#define paInputUnderflow ((PaStreamCallbackFlags) 0x00000001) - -/** In a stream opened with paFramesPerBufferUnspecified, indicates that data - prior to the first sample of the input buffer was discarded due to an - overflow, possibly because the stream callback is using too much CPU time. - Otherwise indicates that data prior to one or more samples in the - input buffer was discarded. - @see PaStreamCallbackFlags -*/ -#define paInputOverflow ((PaStreamCallbackFlags) 0x00000002) - -/** Indicates that output data (or a gap) was inserted, possibly because the - stream callback is using too much CPU time. - @see PaStreamCallbackFlags -*/ -#define paOutputUnderflow ((PaStreamCallbackFlags) 0x00000004) - -/** Indicates that output data will be discarded because no room is available. - @see PaStreamCallbackFlags -*/ -#define paOutputOverflow ((PaStreamCallbackFlags) 0x00000008) - -/** Some of all of the output data will be used to prime the stream, input - data may be zero. - @see PaStreamCallbackFlags -*/ -#define paPrimingOutput ((PaStreamCallbackFlags) 0x00000010) - -/** - Allowable return values for the PaStreamCallback. - @see PaStreamCallback -*/ -typedef enum PaStreamCallbackResult -{ - paContinue=0, /**< Signal that the stream should continue invoking the callback and processing audio. */ - paComplete=1, /**< Signal that the stream should stop invoking the callback and finish once all output samples have played. */ - paAbort=2 /**< Signal that the stream should stop invoking the callback and finish as soon as possible. */ -} PaStreamCallbackResult; - - -/** - Functions of type PaStreamCallback are implemented by PortAudio clients. - They consume, process or generate audio in response to requests from an - active PortAudio stream. - - When a stream is running, PortAudio calls the stream callback periodically. - The callback function is responsible for processing buffers of audio samples - passed via the input and output parameters. - - The PortAudio stream callback runs at very high or real-time priority. - It is required to consistently meet its time deadlines. Do not allocate - memory, access the file system, call library functions or call other functions - from the stream callback that may block or take an unpredictable amount of - time to complete. - - In order for a stream to maintain glitch-free operation the callback - must consume and return audio data faster than it is recorded and/or - played. PortAudio anticipates that each callback invocation may execute for - a duration approaching the duration of frameCount audio frames at the stream - sample rate. It is reasonable to expect to be able to utilise 70% or more of - the available CPU time in the PortAudio callback. However, due to buffer size - adaption and other factors, not all host APIs are able to guarantee audio - stability under heavy CPU load with arbitrary fixed callback buffer sizes. - When high callback CPU utilisation is required the most robust behavior - can be achieved by using paFramesPerBufferUnspecified as the - Pa_OpenStream() framesPerBuffer parameter. - - @param input and @param output are either arrays of interleaved samples or; - if non-interleaved samples were requested using the paNonInterleaved sample - format flag, an array of buffer pointers, one non-interleaved buffer for - each channel. - - The format, packing and number of channels used by the buffers are - determined by parameters to Pa_OpenStream(). - - @param frameCount The number of sample frames to be processed by - the stream callback. - - @param timeInfo Timestamps indicating the ADC capture time of the first sample - in the input buffer, the DAC output time of the first sample in the output buffer - and the time the callback was invoked. - See PaStreamCallbackTimeInfo and Pa_GetStreamTime() - - @param statusFlags Flags indicating whether input and/or output buffers - have been inserted or will be dropped to overcome underflow or overflow - conditions. - - @param userData The value of a user supplied pointer passed to - Pa_OpenStream() intended for storing synthesis data etc. - - @return - The stream callback should return one of the values in the - ::PaStreamCallbackResult enumeration. To ensure that the callback continues - to be called, it should return paContinue (0). Either paComplete or paAbort - can be returned to finish stream processing, after either of these values is - returned the callback will not be called again. If paAbort is returned the - stream will finish as soon as possible. If paComplete is returned, the stream - will continue until all buffers generated by the callback have been played. - This may be useful in applications such as soundfile players where a specific - duration of output is required. However, it is not necessary to utilize this - mechanism as Pa_StopStream(), Pa_AbortStream() or Pa_CloseStream() can also - be used to stop the stream. The callback must always fill the entire output - buffer irrespective of its return value. - - @see Pa_OpenStream, Pa_OpenDefaultStream - - @note With the exception of Pa_GetStreamCpuLoad() it is not permissible to call - PortAudio API functions from within the stream callback. -*/ -typedef int PaStreamCallback( - const void *input, void *output, - unsigned long frameCount, - const PaStreamCallbackTimeInfo* timeInfo, - PaStreamCallbackFlags statusFlags, - void *userData ); - - -/** Opens a stream for either input, output or both. - - @param stream The address of a PaStream pointer which will receive - a pointer to the newly opened stream. - - @param inputParameters A structure that describes the input parameters used by - the opened stream. See PaStreamParameters for a description of these parameters. - inputParameters must be NULL for output-only streams. - - @param outputParameters A structure that describes the output parameters used by - the opened stream. See PaStreamParameters for a description of these parameters. - outputParameters must be NULL for input-only streams. - - @param sampleRate The desired sampleRate. For full-duplex streams it is the - sample rate for both input and output - - @param framesPerBuffer The number of frames passed to the stream callback - function, or the preferred block granularity for a blocking read/write stream. - The special value paFramesPerBufferUnspecified (0) may be used to request that - the stream callback will receive an optimal (and possibly varying) number of - frames based on host requirements and the requested latency settings. - Note: With some host APIs, the use of non-zero framesPerBuffer for a callback - stream may introduce an additional layer of buffering which could introduce - additional latency. PortAudio guarantees that the additional latency - will be kept to the theoretical minimum however, it is strongly recommended - that a non-zero framesPerBuffer value only be used when your algorithm - requires a fixed number of frames per stream callback. - - @param streamFlags Flags which modify the behavior of the streaming process. - This parameter may contain a combination of flags ORed together. Some flags may - only be relevant to certain buffer formats. - - @param streamCallback A pointer to a client supplied function that is responsible - for processing and filling input and output buffers. If this parameter is NULL - the stream will be opened in 'blocking read/write' mode. In blocking mode, - the client can receive sample data using Pa_ReadStream and write sample data - using Pa_WriteStream, the number of samples that may be read or written - without blocking is returned by Pa_GetStreamReadAvailable and - Pa_GetStreamWriteAvailable respectively. - - @param userData A client supplied pointer which is passed to the stream callback - function. It could for example, contain a pointer to instance data necessary - for processing the audio buffers. This parameter is ignored if streamCallback - is NULL. - - @return - Upon success Pa_OpenStream() returns paNoError and places a pointer to a - valid PaStream in the stream argument. The stream is inactive (stopped). - If a call to Pa_OpenStream() fails, a non-zero error code is returned (see - PaError for possible error codes) and the value of stream is invalid. - - @see PaStreamParameters, PaStreamCallback, Pa_ReadStream, Pa_WriteStream, - Pa_GetStreamReadAvailable, Pa_GetStreamWriteAvailable -*/ -PaError Pa_OpenStream( PaStream** stream, - const PaStreamParameters *inputParameters, - const PaStreamParameters *outputParameters, - double sampleRate, - unsigned long framesPerBuffer, - PaStreamFlags streamFlags, - PaStreamCallback *streamCallback, - void *userData ); - - -/** A simplified version of Pa_OpenStream() that opens the default input - and/or output devices. - - @param stream The address of a PaStream pointer which will receive - a pointer to the newly opened stream. - - @param numInputChannels The number of channels of sound that will be supplied - to the stream callback or returned by Pa_ReadStream. It can range from 1 to - the value of maxInputChannels in the PaDeviceInfo record for the default input - device. If 0 the stream is opened as an output-only stream. - - @param numOutputChannels The number of channels of sound to be delivered to the - stream callback or passed to Pa_WriteStream. It can range from 1 to the value - of maxOutputChannels in the PaDeviceInfo record for the default output device. - If 0 the stream is opened as an output-only stream. - - @param sampleFormat The sample format of both the input and output buffers - provided to the callback or passed to and from Pa_ReadStream and Pa_WriteStream. - sampleFormat may be any of the formats described by the PaSampleFormat - enumeration. - - @param sampleRate Same as Pa_OpenStream parameter of the same name. - @param framesPerBuffer Same as Pa_OpenStream parameter of the same name. - @param streamCallback Same as Pa_OpenStream parameter of the same name. - @param userData Same as Pa_OpenStream parameter of the same name. - - @return As for Pa_OpenStream - - @see Pa_OpenStream, PaStreamCallback -*/ -PaError Pa_OpenDefaultStream( PaStream** stream, - int numInputChannels, - int numOutputChannels, - PaSampleFormat sampleFormat, - double sampleRate, - unsigned long framesPerBuffer, - PaStreamCallback *streamCallback, - void *userData ); - - -/** Closes an audio stream. If the audio stream is active it - discards any pending buffers as if Pa_AbortStream() had been called. -*/ -PaError Pa_CloseStream( PaStream *stream ); - - -/** Functions of type PaStreamFinishedCallback are implemented by PortAudio - clients. They can be registered with a stream using the Pa_SetStreamFinishedCallback - function. Once registered they are called when the stream becomes inactive - (ie once a call to Pa_StopStream() will not block). - A stream will become inactive after the stream callback returns non-zero, - or when Pa_StopStream or Pa_AbortStream is called. For a stream providing audio - output, if the stream callback returns paComplete, or Pa_StopStream() is called, - the stream finished callback will not be called until all generated sample data - has been played. - - @param userData The userData parameter supplied to Pa_OpenStream() - - @see Pa_SetStreamFinishedCallback -*/ -typedef void PaStreamFinishedCallback( void *userData ); - - -/** Register a stream finished callback function which will be called when the - stream becomes inactive. See the description of PaStreamFinishedCallback for - further details about when the callback will be called. - - @param stream a pointer to a PaStream that is in the stopped state - if the - stream is not stopped, the stream's finished callback will remain unchanged - and an error code will be returned. - - @param streamFinishedCallback a pointer to a function with the same signature - as PaStreamFinishedCallback, that will be called when the stream becomes - inactive. Passing NULL for this parameter will un-register a previously - registered stream finished callback function. - - @return on success returns paNoError, otherwise an error code indicating the cause - of the error. - - @see PaStreamFinishedCallback -*/ -PaError Pa_SetStreamFinishedCallback( PaStream *stream, PaStreamFinishedCallback* streamFinishedCallback ); - - -/** Commences audio processing. -*/ -PaError Pa_StartStream( PaStream *stream ); - - -/** Terminates audio processing. It waits until all pending - audio buffers have been played before it returns. -*/ -PaError Pa_StopStream( PaStream *stream ); - - -/** Terminates audio processing immediately without waiting for pending - buffers to complete. -*/ -PaError Pa_AbortStream( PaStream *stream ); - - -/** Determine whether the stream is stopped. - A stream is considered to be stopped prior to a successful call to - Pa_StartStream and after a successful call to Pa_StopStream or Pa_AbortStream. - If a stream callback returns a value other than paContinue the stream is NOT - considered to be stopped. - - @return Returns one (1) when the stream is stopped, zero (0) when - the stream is running or, a PaErrorCode (which are always negative) if - PortAudio is not initialized or an error is encountered. - - @see Pa_StopStream, Pa_AbortStream, Pa_IsStreamActive -*/ -PaError Pa_IsStreamStopped( PaStream *stream ); - - -/** Determine whether the stream is active. - A stream is active after a successful call to Pa_StartStream(), until it - becomes inactive either as a result of a call to Pa_StopStream() or - Pa_AbortStream(), or as a result of a return value other than paContinue from - the stream callback. In the latter case, the stream is considered inactive - after the last buffer has finished playing. - - @return Returns one (1) when the stream is active (ie playing or recording - audio), zero (0) when not playing or, a PaErrorCode (which are always negative) - if PortAudio is not initialized or an error is encountered. - - @see Pa_StopStream, Pa_AbortStream, Pa_IsStreamStopped -*/ -PaError Pa_IsStreamActive( PaStream *stream ); - - - -/** A structure containing unchanging information about an open stream. - @see Pa_GetStreamInfo -*/ - -typedef struct PaStreamInfo -{ - /** this is struct version 1 */ - int structVersion; - - /** The input latency of the stream in seconds. This value provides the most - accurate estimate of input latency available to the implementation. It may - differ significantly from the suggestedLatency value passed to Pa_OpenStream(). - The value of this field will be zero (0.) for output-only streams. - @see PaTime - */ - PaTime inputLatency; - - /** The output latency of the stream in seconds. This value provides the most - accurate estimate of output latency available to the implementation. It may - differ significantly from the suggestedLatency value passed to Pa_OpenStream(). - The value of this field will be zero (0.) for input-only streams. - @see PaTime - */ - PaTime outputLatency; - - /** The sample rate of the stream in Hertz (samples per second). In cases - where the hardware sample rate is inaccurate and PortAudio is aware of it, - the value of this field may be different from the sampleRate parameter - passed to Pa_OpenStream(). If information about the actual hardware sample - rate is not available, this field will have the same value as the sampleRate - parameter passed to Pa_OpenStream(). - */ - double sampleRate; - -} PaStreamInfo; - - -/** Retrieve a pointer to a PaStreamInfo structure containing information - about the specified stream. - @return A pointer to an immutable PaStreamInfo structure. If the stream - parameter is invalid, or an error is encountered, the function returns NULL. - - @param stream A pointer to an open stream previously created with Pa_OpenStream. - - @note PortAudio manages the memory referenced by the returned pointer, - the client must not manipulate or free the memory. The pointer is only - guaranteed to be valid until the specified stream is closed. - - @see PaStreamInfo -*/ -const PaStreamInfo* Pa_GetStreamInfo( PaStream *stream ); - - -/** Returns the current time in seconds for a stream according to the same clock used - to generate callback PaStreamCallbackTimeInfo timestamps. The time values are - monotonically increasing and have unspecified origin. - - Pa_GetStreamTime returns valid time values for the entire life of the stream, - from when the stream is opened until it is closed. Starting and stopping the stream - does not affect the passage of time returned by Pa_GetStreamTime. - - This time may be used for synchronizing other events to the audio stream, for - example synchronizing audio to MIDI. - - @return The stream's current time in seconds, or 0 if an error occurred. - - @see PaTime, PaStreamCallback, PaStreamCallbackTimeInfo -*/ -PaTime Pa_GetStreamTime( PaStream *stream ); - - -/** Retrieve CPU usage information for the specified stream. - The "CPU Load" is a fraction of total CPU time consumed by a callback stream's - audio processing routines including, but not limited to the client supplied - stream callback. This function does not work with blocking read/write streams. - - This function may be called from the stream callback function or the - application. - - @return - A floating point value, typically between 0.0 and 1.0, where 1.0 indicates - that the stream callback is consuming the maximum number of CPU cycles possible - to maintain real-time operation. A value of 0.5 would imply that PortAudio and - the stream callback was consuming roughly 50% of the available CPU time. The - return value may exceed 1.0. A value of 0.0 will always be returned for a - blocking read/write stream, or if an error occurs. -*/ -double Pa_GetStreamCpuLoad( PaStream* stream ); - - -/** Read samples from an input stream. The function doesn't return until - the entire buffer has been filled - this may involve waiting for the operating - system to supply the data. - - @param stream A pointer to an open stream previously created with Pa_OpenStream. - - @param buffer A pointer to a buffer of sample frames. The buffer contains - samples in the format specified by the inputParameters->sampleFormat field - used to open the stream, and the number of channels specified by - inputParameters->numChannels. If non-interleaved samples were requested using - the paNonInterleaved sample format flag, buffer is a pointer to the first element - of an array of buffer pointers, one non-interleaved buffer for each channel. - - @param frames The number of frames to be read into buffer. This parameter - is not constrained to a specific range, however high performance applications - will want to match this parameter to the framesPerBuffer parameter used - when opening the stream. - - @return On success PaNoError will be returned, or PaInputOverflowed if input - data was discarded by PortAudio after the previous call and before this call. -*/ -PaError Pa_ReadStream( PaStream* stream, - void *buffer, - unsigned long frames ); - - -/** Write samples to an output stream. This function doesn't return until the - entire buffer has been written - this may involve waiting for the operating - system to consume the data. - - @param stream A pointer to an open stream previously created with Pa_OpenStream. - - @param buffer A pointer to a buffer of sample frames. The buffer contains - samples in the format specified by the outputParameters->sampleFormat field - used to open the stream, and the number of channels specified by - outputParameters->numChannels. If non-interleaved samples were requested using - the paNonInterleaved sample format flag, buffer is a pointer to the first element - of an array of buffer pointers, one non-interleaved buffer for each channel. - - @param frames The number of frames to be written from buffer. This parameter - is not constrained to a specific range, however high performance applications - will want to match this parameter to the framesPerBuffer parameter used - when opening the stream. - - @return On success PaNoError will be returned, or paOutputUnderflowed if - additional output data was inserted after the previous call and before this - call. -*/ -PaError Pa_WriteStream( PaStream* stream, - const void *buffer, - unsigned long frames ); - - -/** Retrieve the number of frames that can be read from the stream without - waiting. - - @return Returns a non-negative value representing the maximum number of frames - that can be read from the stream without blocking or busy waiting or, a - PaErrorCode (which are always negative) if PortAudio is not initialized or an - error is encountered. -*/ -signed long Pa_GetStreamReadAvailable( PaStream* stream ); - - -/** Retrieve the number of frames that can be written to the stream without - waiting. - - @return Returns a non-negative value representing the maximum number of frames - that can be written to the stream without blocking or busy waiting or, a - PaErrorCode (which are always negative) if PortAudio is not initialized or an - error is encountered. -*/ -signed long Pa_GetStreamWriteAvailable( PaStream* stream ); - - -/* Miscellaneous utilities */ - - -/** Retrieve the size of a given sample format in bytes. - - @return The size in bytes of a single sample in the specified format, - or paSampleFormatNotSupported if the format is not supported. -*/ -PaError Pa_GetSampleSize( PaSampleFormat format ); - - -/** Put the caller to sleep for at least 'msec' milliseconds. This function is - provided only as a convenience for authors of portable code (such as the tests - and examples in the PortAudio distribution.) - - The function may sleep longer than requested so don't rely on this for accurate - musical timing. -*/ -void Pa_Sleep( long msec ); - - - -#ifdef __cplusplus -} -#endif /* __cplusplus */ -#endif /* PORTAUDIO_H */ diff --git a/libs/windows/lib/x64/portaudio.dll b/libs/windows/lib/x64/portaudio.dll deleted file mode 100644 index 2aa127eb8ea5dc96beeb5eeb4fb6b6d681ce0f29..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 367616 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 diff --git a/libs/windows/lib/x64/portaudio.lib b/libs/windows/lib/x64/portaudio.lib deleted file mode 100644 index 43dded0c7ecfb29a6c27a33d0c8085f3ea7bafb9..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 9198 zcmcIp&2JM&6n{zhDCQ#}-=D-uCv+?w>Ub@Cjc5-P zap2TH0C6jamNVjj)C-565KX9?@(fFqLA1jKxd%~(&<+>0F~sD( zkl`%=E^n|z89_T-USNrG4C`E;Vu><3Ddho{D9MDBJ6JM#D`adPfD86*3}yVhl*d@2 zOms`Ri{;&1E`9a->RL8;@ls}KEqy(^x|S=O6-%oX3=?v>Yd2O_{1EuX!3acl`Np*? zxr>Y0MYyiz7V~H!V^wr*8%-G7<(x-})up0Y)x8*1iI{J7>!QA?)r!`#S+y3+hHK5= zMDXcSxrWc)GB)&}XVhl$+-l8=e2}!;PcoJzvsSV^RIXk{rc0Y_V&$yxaWEiP3*4nj z#jIrY+ti+`6(~6+eqz!-Tl5W8B|OETbyHg|;nCW#LMN*yAY(|Hk!4iOn$M#{@Z$*6AWg(a<6%xfDz zy4>Lq_Iy#-%Lfj!lQ#|EylwHcFbMOtGs%3*6(qCRAnPd-#mA zho8Vr{9!x5%cB5$x&ZRHbG<^j&;#%U<#aE=Bb3fQfO{zKQ1bl%uTho<0G^?o9z+`` zokNI0d5^L+4DbeJc?94E%JMOQrzn%701r?SNq{>jZ&B9A&>qV9ae&7t-4g(JQ82lH zJ+K${!G8Dz4nP79!XY>eN1z=#;3#xL7j#1p^g!vGAz5Ddcz9D`9v!WfLh1RRG? z;RLim>n>Sp^X|R)g6i(5h;jGQc>ALLNW}goAdy>^fH?64H$|a|vBwCYaJ$egLj~1| z{VFsvh6`YHTt-ZjVHGXZi;fIZH`F1hUf4oN+;D_Y5o_2FCAjcvaLm9aH5TkJ*K~5F zz_e0za0lsnw0sqAfOMNwXAgLiqa0s~VK2c#@7R~MCnhU*U#IyA)i_*oo+qt82cW_6gF4Ks!opb6tQz#a3Yp-`APo15T zXY-qh!u>Y*?XTazZ*KwIF~#RhLC@EIIG&MJSi&E_+7($YK*u*{jDluq$EWQkOakC< zl>eln4a)^M`&{DYq#Ac)fEMJlaZJAe$>*(DcH^$iK8MMmPC{45e$?Ux0spZ5d~>Vw zsOjvrres$pYUjB>lz`};PUB>=yZnd<0_@F+6 zU`z>^*u!1`;9cIbHGF`ANn&Oh1|I?klX5joKhD17hgk>sO4eA>3hVg2!vG!OFbOi~ z7#=g7npQlfm3z#eyo0Qp06`v85KYdv;xRL}l6lM@c14!VV?L56#Cf}zdE$(RT(C4e zZ}avon7h*cMFR1vgXb+`rKRktVk?!cH1)Fp3-(Hzwe<}5k6n=^!+nJLjWf5H#Yf#y zH9EVq&W$6xS!Bz#aG%98_6pfT$3#a>PKbGEcnw6cwFovf>uHiLm68iCNyj#UBV#8M z9Gjan+38fXoFVgh5;@zvoNAudB=4NPNIYYmJr09svI>aUBhuM zH5>dM$8nU0Tt0G!p_HT+XI>-L#bFO)z-w%Hgi-P4h=-3Jy2!|O^-Z>Wc==(D(ltKL zka<0YZ?eO~=Q$-d$vhjfQt)~YZ{h4%U>`pz8L7qbo`@*W>E#M=pWWo^^78THGGS=g zYux`;X(lj*bJ;EU>K(&r2O9UIkX+<*>_HFdLE!nmN%kmT>J{wD#Q`NFwK%>MGE$ax z^+_(@g#;nl-CeBT<|H>Al#tZoj4@)L9-w^o4GN*y!3ZN}bx<(+uV$L$jPjZxms8&P zP%=`BF{4pj!-7k>OCr`Aj|L%c?=$q!5y2IHM@6X{jsvqH-1r9%{)57!y10vOmM7#K z!p?Q0l1I5!YnClyuS(i%&P_TcBegi5axOTx!oR;@OmMl^fW&y?t1jxiIxe`>`$Z4i E|6S$=$p8QV diff --git a/libs/windows/lib/x86/portaudio.dll b/libs/windows/lib/x86/portaudio.dll deleted file mode 100644 index ed09b0527739d8c7437aceec17512e2c0fe7cc55..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 303104 zcmeFaeSB2awKqPKOkmW3GiuOLM@`$&22H(5jcrnb9Z7&F5k`oRmRQqDxv{32${EO2 zgwQjCIo%GXSF3nyy;ALS_10Uw6)}o069NqJr3Gv?5h7^cW(+Dwg@7;f`+oO6XI=u> z_CCLt=Z_yB%{hDTwbx#It+m%)d+mMpT=~szN1?;vaN+-S+TrNIlmCM9?`Qw%MDh4@ zpBe91cfu>5>v1-`^0~&=>lc-@-+a?Q-~8?Gmt6Pl8*jWxFZs@QOKuL|SaSW1C3Umr zlzjiD1>e1B+_)117V6MchoixHLS93A9OJ)mlC$6p$H4-J<9<+fqQl`W28fscliHRx z`Ho`J?Zp3l%76RthX20RSS0)9aFnQetibyCryefH{8dPFyBsa2%IstR+2(SzoqOye z=DOl8hwm80Rd=}@t3luK{#~Shw?ju^_g?`-g4owgCseH#N2ukZ1>e@cjbvE^{;=;e z@jQ}`IOu4PUv#qqyqkS$0bDnp_2gCdAK-!)eP_`k=CqOJ`|`_e$WG$>uEHmIM8b$~ zARj*HC=XtAy@HcG1TP(wQ)_-l02jZgc6KB2m+{ZzC}$Uz9s^Eqlk}Ak4!o6c%Z>qe z^LN{Bx(@xIY#<|w+0l6v+!W;g|NlON19ObMzJx2#36SK2+X@_JpXmxD7p^OCM0Y+E zI(%K*Lk;+&k4s3=8=HI;@%ept^l;G4@9Um77Z|*vF%XFE2;aQMvG2OJXk1%00mVkr zS+P@G;<DP?Cu4jnD9N4G*_k>0?5{-x7TGNCVW28Wf`~hVE zrg)P}K$vXM*yNr6t!p=W9Ol8;vtLA!!#LuUCE-6VSi^BxaZoh5#AG%)d^*~z9?&8l zv}3pXI@&e&p~K0zibUT z&a7?7GW(2SSM{4qG;wNlhkgKw^p5H`7wik?*$` zv7h^!Ms{<|}jOmw)OBvB_`lgHl}6C+SblNBvlB znkdZXfD6@)5$BR;lXE@+>|PI)ELd@H_=WD+y7MLaEL`%z7p-P;Dksmf>&cl>tJ^nh zSJdWK)`UQ^mEheqwy=AV>lakM~C6CS*4K^ul%H2w@5(@&## z$D;&#o}TcCEOeV2q2eb%y@(^dqyIqP!fv2}WV8RSo);_IOcYR}E#|A{Z=ptJSs?lF zzhZdC_4AESou0?x*e(a*WKhA(WP`$cmf7wywzv~=sy5r*iJ*sAjZLNB>cdbp>jM7dWdH?} z{KKh=`0$@B{?I%Y3q4RGrlIrtslq3ME)MQfiFl_u5PsK0sj;be{QImKn3XwLD#IM46Pj5jgIB?>G0lbawo zR5*G27tC6h5qFys->bvF0^;EhVJI#6&z%EVd(omN+ArpK^jQ#zulfpCc--)G+K1|T zmwuMHQ50Yx9WWaL9*|uRV(jrG%FQo}IpB{Pyk4|pL46)j3%looU)#hfpmTVD__F-@ zmM6M1>>4gJ`$Vne(0;faqA*b_F`>CXi)n7NP)zeArb*_T)7+A6x$4no>)K+KKcm!8=#Qpj)6=msnbyBLxHM3pJ%vB!M^AYcn*KnBe}hg; zW6u2p{exwJoo5cV1qz(+7$fQMUxo&T3x@`}jZH4g_$Yg#+V`M|GPGZg_DeW;hKfRL zU$sZ#RQrk^eKy)3!}iCh_F=bdek#HTP8jUpxqq<#jo!hcCLm(!jozU_(v|{IE=k%L z=LaP1Wsv3`8c@U9*aQhla17&lT*ryeLBaLcy+0X)VCSHRrd`-$5e#$&|S`-!*f%&sW~=5W_Hoz5f1;dHnU zgcS@8WJ!YjZGQbtdVcU3^hn`?m}B!u(fSWj`Y0$Z0t**ogddB4$I!3lW9rvg`b9_S zR<26z9;H%}JxZe#zptM6oTD?H<}mR{fss*AXy{OBtma9oGej0jV+Mh~1!9$7e<8gb z26h&jJyCnAE^wj}pWCuWgGD5C;3Tlay%Tzd=ZTQ1YcgwTvl5fpn%1z{c*j}j4=gmH z`^J%Uc&p6^IlSD|0#FkGB|bFk2Q?UCEx@c)D3sPGA6s67g~04Qfbj&a-Q650z!R!p z7bxg*IuEm{A@KeL@LuVwvB?en&Dt~Y0|ZKbkO~g6Qcyt(0$@btbL0s4@dCQz&}&B% z(XFVI{deumD6TQG9DO%NI#th|2fCbvU^2=1jiTV1J|&O8yZ^z_O{@CH@4pf6v{~>5 zSTF`G!1y@2{}u0289ux7X?FgKqbLBr3%URYwsTlqG{c?uzP0#ZPW*l_ZiMXTBrBWw-aGFE%{QoiZihnK!Ahz zsouJ5qZs(T5VJ4#jWji@pO)zh!fgyYdk?$2P89Cm!``kdoWkwg*L&F4bwvRz%}3B7 zqLu#Ofj+AtYknhs;)XMWet4%Lw@Ht zKP78_lP^EpF4*#9`(Ox-k&hD#xeA8(bDJ&wTaAuUO%0%z719xM< zAFEl6W_*~qr11RO`Y8q4`tLb8OC3SiPDm=*VG8=ALWzNpi;s+=kJSKtKt!CDe=uJ^ zMO*((sl)GdodH`&4bCO&IP#Y^Iaaw?p8&2FP=)sAh;NwUQ(Av4{XA-XwaW2z7W1-c zP6g+;ATD>HE96|*d&J!pDsYa_10ehD;jY&2$Kjtn5GQC)sqwS0cf@ULzha+Ki(~Qc z*yB;^hA$Uijzp4@F!b*j_^@n|+D6Tw#&NcR`5P>1%boAOsN}IwdtNb*K2yPN{Ewk? zmNFcFz|hG|@Y(qU$ki~h>=BUrbA(~x>)qqa7l!J;91lu=eL$qB!}x&y&chg=ub%-y zYzaCY&_QiIG`Op&z?q~O`ioTKEdPtqIcX2A_9ee2*xkV}${4_0{@e9)Y#)@#FZEwP zP1%=G+CSQU{(byCU-6fwg9aJ0GhKn5u0WQ(f6QmE;*U)q%}{>-l(L_mgD{81DO(>{ zU+H^B*U2BK`W0!8Z@zr}C`8YrQ?bgrCX&;IozzqF}rBwm@ zU{O0}w`aI0c$(@kpkXy}4i{?Ys0F3}&0Z|s{8&T!@H_{U`i#sfVk1`(y^wHm*BJ1j zj%58JLso9QaWsA8Z(E=qB<0XJD?2{e`_Bx`;Eh;`fY4Dvhlx)aQviNWF z=etMq$CqjUndRgU7o>j|f4IurC|8-Ic=M=DkrlsEz;LRyb-hD3h7&_}? z(+RujQTEqvpR%Ft14B4`U;-MsJG27&0L$K>Y*TUX+XdJb@|xJJ`NLR;W2mTuL>yx% zsrcK@{W}rV%MbB^An)jbX7+ORd!++U1lq6yo?6g#rIQ1Ir2p6^o%ZlE>DB-F*tCB2 zShSLm_>;H46Wy*KG`Ah-o6O@5`Ux0>z50RS_q%%z4y4n4S$hD5bV(e>NQrj) zLr}+bAXh^y@Ve{TD&h#%sQGYB0Q-75{aNE1l`bBY_Kr$>My1`O(ymcy$Eftj-u(7Q zMy3BcD!ng1eXuUzDOi(4rdC(9mt`tvkIMNYbJqA}n{palvx_-d`K=ikmHu6RT48$` znZUn|Wh!Tr%GsLDc~<4bnUjORWK@59MwPG2Pb=(?DO``UOyxYRavsU%+^=#TWKOm{ z1%0}QxPt`>v_s`A&E~YKoHpi+?thaiYtBN~tDFW2o#Suj zj$b*{Her0M@e)kNGuJp|jm&(w#xpAI9+h_Gr#aMe|G~K}9jXgd!uXXBzQ-Mup~1yx z4orRo6V=dJgYON^_hOTCenwtH@b|EH>%J5M!PC_VIP8_K#v{4su>uEh`G(`!{B5*X+gbh4T{(8#Z50n8pc==yW{s_=R*hSRknE<)-_hxE0wl8*_ z^ycAR;~poWMLqbtYlipDUP&+ZQtf36+aC&gGo5BS0op-*(Dj?Se7LXM+~~-_Hw0YQ zU*)OFFbd6~O+Hgn^JC!0>QSOzl2#nB04lPg0j>gA@NMB1(<)d&-R>fA_wc#arX4~nAw`sMTHic3Ox zpA$W}?0hk~5wAiM-|$xSR}b9g89rP1?-cXB)qTrPHF}*B2deiYBHn{(FU^=e`chyP z%s00pAu~tu*P6TB`uU5CF~#ZUstM6&jCl1^q1>1@Zyvz`qQzs35m)%VZh7)0XFTHk z$?th|fTvI5+TC@5leG2t6WsyDEob^fZdYsT8v-W|`2!Ig1Nt}cE7Gq;e~x7_q*1ql zq$V8vE2cV(kx#WKPZ)@)J{}rcN~j5B1@`%)JG98HGK2h3tiYKUc!bL?656E8+*)J| z4nyIbN^!*wj6m5$olid3^`?RiQsJKQ7WTs2htVVZ&(SEZ^TNNgi)7;6Q zNl+~^L8j3o-6NK}t2y)AAD4a((hm9G<~>iUick zt99`#pK86PhfSMRVk!0ARGwerQL4ItafDW-aj;;-F_?5hw1`V`>>eRqVtieh{K3ix%4k$sMbXL zwa7GNYU`T=C!N@gUDN1Skp$;FkYDsdyc^bW5tubGO^TWGjW}D1x!#2UN|l%_MLdDb zji#5KDGDlfPO5i@PaG~6u7AUu{!OFLS^ZIXzZB&L%5nIVh228d=!svKPH)%;S5CMJ zB$FvPI-`jK@FZ=H)gl5f;95O~wwKDMR50}yWOHApU)cwc+VfZ7QE?Q|E61P2&x*1M z&sd4aLCjJP?$jE*%lW0pK?OSrB?@29As|bAgkmdAe={|lNh7{Q{iIHZA01xN-SZ*K zU&@pZ4fGsf&eP1ndZg!5rhb_z@A-h~pCV22z*R@;S~Q-GNA2~mA!noUWdYV#{6dWE zA<1vo4^12(3YAze%lAnA!cjO>Au=3~%e-+^Fb_)YMy=$JZ)75k`%SzbN#pGUbB@m`Q5u__&Ml^dG!o892>5A{eXKlA+Mo$UVQw{F zO}JJg*Aa957<$CBKk4GZgA;li@@@j?r>+6SRUJNAgcMWTd74SFVg~ zrM2aeRp{Yg%ke}t%h6Zr;wNy4ii`LV?CU!ql#U|$C52@>3al}oG9%Af!CP~W6@h;0$`;<@5f3WUD&qP>v zgI!mZ)8O?qprUR(Q^opAEb^s2TycaZv*#UB7`YbmUU6hUGh9RxnTZV0A4iMNJZ3f9 zb2f@H{<`z?LJQp4UdDTM3=jpPm;-rOi?BO=uY!9EI;R*1iA- z9LKBqz{2Mng)d{jX&X&1wcTptZOd?3{xbB{0~q&(1s%ncrg(4DsK90cJUMH=q3B2V zHyW4pYEz{#vlkFAKvf))eo*dP!_gXzcbqdx0zD&##FZNr6@3}{}7(qrzHT1&M<6)HW515S(!1;MXE-B;8T1QRx3LLJE{-o~$^j)wb-rgV7BCT8 zPGVgEXFMI^{=nUM3`GK*24Kc3@xbJTw<>l7&l*0p2&bVKQbWaoihg8!2#6=wG!F9( z7+)WXtFTBd#d|T{EAjN2`;sn6Yxw5qK{)!QdIvgDH8jnOegpv>0#pzubn&R;DO0#v zaP;tK!erA7*qWhQZ>%BE0@!wBxA2H+U0?wY&*IT4Y6(l6l>qQy1>v?QvQX)YP3$l9 zU-4td@MG|avW__kPrnk`~Vf9>+TvMRN#7aV&#T&*Bk{i^l>l z;{^<;!-LOyi(d_jUtfmRje>7q!4u4A5O)MN0TArNk#J9jVfCQ83Oyjh>hSc6NMI}A z@ahKdwthf4YtiSCCHYsSMTiFdtyeq@0YM9(LyCuuiib^#hph~ZKdj&z6d&7%?hkY# z2UXe?D|N-n4ze;5=pyv}fo*(%Bw+V~1(GD}Rda=gHB$f(B!g}Z*zGo#O5Xt`zH|tO z0mCPY)5W+T)Emwi|6bu*v5A~jzVW*A@#?79k)jWgu?LXHN?ShLAs@VRejDCwnJtE| zH+4cRmc~8^9H4`W3kr#yyadlzQCE}S=PCS=H2N9TB5~xHI3>F@P#1%154!7=D|;#ebgQSS~sq6&+X9dKWay`5lFUw1_s(!28qU=c?0&lh(0 zq{)r9GW@dEy0n@*^v}ca23Ax}{mK`8@|eG5omRIo$9^e$CJXv#A7s2osX9(zq5h@O zow8JSub4zcdb^S#OzG*>FNNL1H&(x@Pc*lStI%Tj0BW3X@bJ7nU&xX5a+bb1Fz1Nd zgx?U0+=zgr=Xx1g9}o4|DwF&ovNzn{F|08*@!tt{6bs{UwuKSyTpBLEdt zAd_~0{GIwl#h=GN)=x5ce{D!nYAUnJbV=7?QBCsdF z=CaI>b)ErD<%;9n(c(BqHkRQpQj)@Bw6Ajy1C4H7SZFs+em)n2djD}(Fk4HsIfxf1- zG*GUVp6h4j$z9gT=qKTTA10Hg6IxiJu!0&HPlZ)m-NQx6@Q>yA`2U=~z-QBUe10o2 zLOxp# zZxPc=#gazgi%bPRF+G4vZ^iCKW>_+TXOm7kQ(ly`PR_+}wHyPzL%v->?38%*N^v`V4gtSUFGbfH*tOf( zwOQ zD0dKd^j-arvhi?q_*E%?t~0B}?UJeS@IS#KwBt}(Mcl&YpC;xlF#QEsbz#A}56o(y zfQB!!%CD`d*nxl*5la?0fA4(5EL*7-rF+pX7`q@fhaI0D0OeUd`hl3G zW1|0_xVIBn(W>WXcsj%>Fnw1OD=ODhp{)5zG*5Mic}*FD-WSuGB!21~1a9e~m-^8K zKT3XUYim{N*C3rp%@6R|VI1|!p{JF@mr1;s_ z={3N}>XpNHpdam%>aktH?_Y(qI;1Ey4@o&+DO&+X=>fn>(b85-YC@ftK4Kjps!F|# zSLwf@4C;lc17F6En1{?Qs8wR(tKvQ<$A;wD+;SX_DX;#Pf63eCp;R1IGxkNwfB3mf zTG`83Cru-)Ci>q%n+eVZkt5p{W5v8?L}58#(HrNs>aE&JS|xMq#BCFigOYMFt5i&H zq{VxY)wUq74!SL7`AuqfskZhV;H@-Y($=P&A7XT0FID28REZDGEgAVyXBz{Rln2#9 z$-$ddkD35zbfL_ho?FIZbQRdAMHnPxKhR3K zvk@CkP|-6mw;(TLA#(J8Rshq0`HHp{h7z4{ZpKuA4=D97gWHuA2P^t9YDz&;-SAi` z&*_aAj?R6~_e|H1u%B2xi17kQv<7}O+2aCq)uj${{DTr?wp+|DPd%YB8w7@|?nz8< zW=U!W34|@alcs&}y^5W%z#yYo%p&(0v7)kLt^x1y85G%rygD;u<~67cM-ru53d>$< z766|z?7JL8zTuy!@sO_%4WjjB^o`SK6-k%)!SgJCu>BQ15xPJM1gy3e{VxECc|jVS z-?8A@N^v^meUVsF1I5Ky*4BQIt&hP9d+LNvm>xv3oS5|Xg3JC4*7CA3mocG zdUVu^S06Q(asN^L6G)ab88FexaYD0tET=H@rq<}Y;aQwp4?-KOAg310u@`V0{e5!` zX7LuxE|utgrLn0&&MvS(lYq#4Pn)g-UmWH@i~NFu;l_5Em|lsov=Oh++Lz3&LYtVP zdL;{QYB9G}>_7#Of^%jg=IiE0?zfkd9_&}ZEacj!QYm;D_sO?U`*85CEZ;ueLi_Z( zxTzIi$yQGMa3Tmp=e6jiP`1?9p<5YyAWjF`$JU};tmPO_-tD*lamQ{lHrFg~k`CD=6#Mia8hYOdrATt0S z_UjAGedc>|t|=r+&gLlNtRqdm%}Nd-RDpJR#0>8A;0<$*GW7eDX&GhceJMy9V z8jSX}6O-mjrp4UWiSJ-DeQv9Mnph<}Ec0cDqdX>HY^t%{4|fVf6^wRu!iR+puf~Hz zBl)EtVUMVg10Z!Jsx0iD_$#6sUSspOdb@aFHFC7+FPg7_N#IK~Nt1D@m`M{5py+IF zXluu#Kc!-3rQDXKeaiaB!H&Y|OR?MDD6M@Rs?pllgijD-5edL+ojH>H5>dnQRX4~v zJxD0ccm$2aq@!kj3cv>CS>vrzOl!s5`+aC_y>tw(izz1XlOq0)NR%EFO>Qx*vf^E^ z?*a;hV@;ZSOONLw*onzCk)2;}gg?jn>ZFW;H-@uIVAC7I{~^YUY0cGJ(bFo;_y7co znH^&8Qlv|q+qK9Z=AaD2s$^m>V}Dd{X=5JfL|OHA^76N0ZYlNkEke%>m@lGwxtIyd zj~9%lcQ`_CY&5rWgi7uD)E=Mo?Y$hIkQ#W9~m@BxaSF)!QN6cv*=;p+wff^@bbP3u*gUjT*>8$ zS=*wHBZym})>`yguAv)nc)nljqAdm9Q12ej49V@_0V+s#X^}6murUydxwe^-mobC$ z8P*p7Js&}7NZW_n`oLtp4c6U|x`)WPX-H+=H}q3#m|=ZlWZQQ%07|2msHWR0b{xWI ztXS`ZyX3hCRj>=akjzHoC|dPRzBdH0$*M&b@qKBa4ehp>`?a;74i}i)fn&e96~XDh zas_s1KP*R^X2_K~s=+S|R`5oiIymYtb<@BdI#~U>Hsy$Ou=dq|{40 zM@RtpO$vUgOfImK-=!v$g~U^(fJwMaGlHK!S}k8+EdSkc9<9i$~` z>FRk3Tyj>6EP*IuuB0hVL254Mh>X8?%mJP{o2ye9kIWzWDHjTitp(^l*0gnCM(PvV zLfG0_XdX}7quBtDCVA}&+{o32C2`ijdtRQ$nt@6c>C_`A!sMB~TMH}~KSZ5Ua9gz> zb8$W4Fi~>V<%$JOTC^DDP%5ch=zH|%K$KdCKi#9z)ezlMmr1 zO=_P2j@sz<=ODz4@ovs(HfvkM7ef6%FKTPVoECUVKKx%v=1W##GZpekP66{JHc=Z8 za~dr$Ml|!l&H|XIZ5{rV;s>;fm@#N$mmm+UpUVi zW^3*Q$6i)5dZ`&xm!nn5v;=9+c3bYhVPfQM7y(8wB#LeMD0UG=0a2{%L}k!Z8gmVp z{7$ya3}IgC5T?TL?_W&Uv z&Qk$6biWc2+L&u&toR)nfAR6=t+?CyQuVg*2iPc+E`3(N#S*{y0a4%l3-nO>Yk2OwlZHnLTo+|40QvY!*k@I&3GL9y%EJLrx8l(D+#q(mW za}jB%3;35T7Aw0z5v>3&!^1%p{d3)ny}(6sF}%7Is|ZZR6EPMGZ>*}uXa3r{;k&WlVcUal#w{}Uu^wCgT!I`&{^4V^;YAy^{1@k!EBSZ)A143X^NCdQ2a!k1 zzbhY7$)Au%$=}R}RPtZ)cgz3Y{OU^nsQ!=0|DJptO8&q>`Om?H5%MxHFGmgT+vPT7 zee+P~BapQjYBN0nQQx{7kr5OR^dq_Jf}t~!ezSkq6z|YCIfwfa!KHw9Bs!@>{AY&R z4P3m&`!}UQX#lwkFqT_5hD0q~4Q#;H!a`}$U6`v->NlziwA(KNrJ@!`YV;-I281QF z=w4tG#vS}CI*FP7j$G2AVZVt0;6SnmU%rYN*tp=5s$HU3Dp3edDXNC0x>k*qs9|hs zaBiM&CgmMbnRup{gS%P6m)lKR7SF17XA=JJW?`_KXy7y<^3mReawl$~XfS!-3a*~w z`4RRqvKYOr=r?Y47wSb%bFwD&1eAAFrB2&x`?uoON*=h2k}Im)8`v5S-?t%Fn1D?y z8NPrq650I$6JIw!y(gWXIM!Jg2uvI^5$-A0582w1X`+IA&~kk>rz3W22YTock~w0| z(%7wFmiQ%m8he6_4xb`^Df=b+8GC~5S8vm%Z9}yv?a7(=d>K!B>2NKV%k<S7kv zcBFm?H1>L*u2Mxmj^A<5u*Uo#6___+zv6bRH(q_Hf{Pw1b8>20L#W-1Er`!h!2rDL>XxB5&2fp(25ks959^|-!YTs+zvZRZcXC?p<)j2w-kYhV7x9#x9{6#LR)Y8~Qi@`dyUf4jVKCE7 zf~+i2tYm(KJF_o?Cd%_UqxpZ2G%YiOYS#j4o-2a2mIx{ltIrj|IULQ$5&_0LB*7Rt z1LXFm1^cLYe$4%8Zd;&h_O^wXQh5yi*NA^5rTHRoQUtOGwiLR_e^?y-kH_PG@zatP z@E?3uegm1rJ-R$u*s*<_XRbM#|5ZovzY_eHq{ujGhVk48wIT!Ze7)j7*LUR@DwV1V zNVfR@du{qVpuW1oUjNgd<9-9e^&ClZUmyDobFts>du{C;mlGd6LHgWpkgeykM6LDY zXQr7y=sZoQTP{95@L`egnmF`?dCv@a@PK2>NzHGDcsXE+8RC6@0W%~oYd1qBNMX@R zoh&y)ydb#J43*`sxADC)a@|8A)Foa|!okyeSfxRLm>Ss#)@)vtDjo`z4mFkA=RZlG za>>5~!(-=&Iee>m4fq23F%@uJxv+HkpR&4ln5udh^9`2xGHx{gE0|}q@gnSv zxvEn4^xC5Y=YJuO5+fdB&0is&SrIqzX`wy;*zLt?CBQfUUZTfRZ8*oxrP7c(&W!`-ok-#MKWz%OHiDc9*U)QlL-L}7g120$IS~GjAbjo4&(X7@ z0%*~N0ELxvVJp-P49Ug#s2St42_9SIMxvSOl3V7DVk*r_z5TK8IYco7in3x-$gAD? zTY_Hc<4#mDUjb=htKS`XkiCio z9>xQqH`q6PKh2VeEHV1Z;4jgUMUgvs6{3s?`UhiEt76yi3k11qaN!FOokGDvxyFJ$ zN3kCahRrMoaype&7FN7g;*}l~Ub%Bvilm&K>u@*~dq~LQ&O$w&oCq56^y0})6Hik7 zNyW1Dx%A~GqetdGV^f>$KjKvm9y<*Jn#l4O_y_U)AHn@VUNe(;)?3d;BpsRH;Zo`DwiED0(&|Kq5i{PtlfrSg3WS=k=-EZwG_fw+2>Jg6$m zO2;D&`JQ7DMR6Y<;o>J~j?gqq`B%_rSQ&YA*KcUAi(HTLxny*IN z$A2`f?BU91ZF`t{3B={tODICAz+EG1l{kH;(TJuKMi>6#KgX^`<(UiJtjneb#wBmW zjrZ!VIo?-(jxd%27NSc}sNq!=SpSOE$iXp`^C&%e|DN&SD459w$j~A`r3xC|1doS* zAnxLzzLx-h*+rzI*hkuiqF9rIO=)41{h%NOThh6Uc z$N7P`Su}`F(vNS{D&Y(IKx6~%m&BP0G>BI$7QFJ;Pt48XuSxy`aN?lW#rqS)J?t)4 zhqJ}=KD=G{0IhkIWwNw)&&xw0}O+mt7j$^O;yF>mr(ItgJ*WCjcwWkIa=s zG2GuRRtE5L(#jJ2)gO%U5Csk$fT;9@J?bYxRGX;AbBHx&?}e*)Uc`L$tOv^YTq#rc z$akJJU~ODDz&@A*7p^QP48jju7uQ?B&6R7hIdY%*fGom#8~g~ETXDVxaNGohuMPt) zPsNsEIns+P@1ef{su%!XaSsU=l3*M)W1c+0O(+mpY=WOyz9*kRu<=4hL(t@XhxmQm zD*na>nsN4}p2>(w@wRXk`O1yue?y5n9JEe;e}=;){?t@R-&%jka7&QK2?mSyLhpCo z*@~JN6BlVu)den6W1lX2J#W5RT4%v-IGK`q0Y9i$)^D^PR!G>?{awhHrw876fSo!VVm~hT%d14@&uoghLYPCOr9} zZV2S5p?DXK3-wjp<>ecGaVu12>@9)Hwu8LnSMlwNm;-Vs7W^ki9@SPD_4tdsb{YZ= z+S)CJlFNsl2+1N+XWm7=OEJ;Z)G0A}@LJE-@eC@lp}FD|FWUg8n-C?b2^@NYJ(27< z{m)VYA#}vUj^GJ7qEH2JlCP`sX3$$Xy6%ODK>{b4aLl?tMR`niOkr~+zwwTA-UBKM zW^R$XVl;u6X#dbp`P8C+M(f}R&oGR@0!gnJqFuEPjb)TKT8mYPwJ>qXlNeg0oG~#8 zkvb2r-BRD;_laL}-aNE{?2NvP1GZbV$g?O<-7MkB%9tK#fQUgIrF`%TYr$uf@0mNJ-HgvNk zAlwHl#E_ zS95S<;G*@oH5M@>&cVCkUdTBZQDs=s+iygV%qQ4Cb057KY&W{iyJUKsB&1pP5FFPc zX99oL2~<}uEk;*XgI4zS6Ncr{3G|WFCI9s)iqngC@MpXbReZzB`yD*RUF>+)ZKbCn z4QY<9#_>*yt`iZQ|Aud2pGIo>nC${)s8d<5p6l@|E~^dB^IK)G?A z4hfszxFL*oP5MhHWp~t4G~2E8>~h?V!PdVHgh~_yO?`qvoApmvv-c#$5X+(Qejg6a z!}GD<@jgHaAVsgjGenWR_eoe*Ue|^Fi0tYkH3m7RTt=ksq-~b#ajqXy6-X-oKn+i_ z3ma{_588amj#^Uu1qdN^H5$+KH_9uaw?80Ki}>~CezBm@mWIgA0XAbOBp3%oQ+~nZn0&vY;>i{im|3*6W|Gw zK^H_KA02Zt#qOhunPU}O6XSfuL`|&1PvxwO=Zw#Da23lNZXjl^$5!kmkz$?vu45=7 zzllSvt_+#*9qYN5cLYcgqA4NVc-)~Og8n!A5wsKjE_H`&Rig!GD#kh-owv3-!jr8_>)O$pQRUNT44;)*U*b12 z#;afS86HFZ!F?Bu`mWf-E=U(vV1Aoa>sj{9a1r{4a$e6g{HC=YFgn}?;g?0ob8w?m ziyCTYu@y8}{;Bb{ON*pQTCfuAW2|6Z9hB6dW{Ra z^nJcLu>5l`$qqJhYLp#h7%|m?WOltIJ4h}tSVF2+TXlgh9^6|vOD|%V4H&t-pm*Q@G?0}+({0`amXCGY#K3|8`3RFHsLgeNYQC4_PD zfDkw&(&OM!2b3M1``|HiY5D+bn={0nER&fvXaA>KM?`h;p?p}zqerm)PSaR^HrK*5 zBr;a1&Qn+-f=-52Tq?p_c!KU#m(wOQ^>0E0O>wsPco`4p7 zdP1vI1h^OYkO7F`SK=>J=d)VL;HR2sk$U{arJ&0l;gj%KhMYgc&xC0tzrdnasy{TG zie8;Cdv}c+f!C^C`P<%i3SK~-!xW8pSe&xC)SGe{&&oQk?5v_qdHt9ZOZAHw-JDvq zDcfq7)P7xGUZZETPtJ4#z>)Q(3R9yy@9`zVLP=K4r40PR`CmH4n|} zeHj6Hm~#y3)|8HS&TmKi*Dugxg1A^a`K8CC2c}R>B&yF+&s3T%sA(JoNCkl68*y$K zxss3Llv3)?*ey|;B#(?>ziL2jklc@V>95J%kqq&#sL%}q2QvJGzIU;6nRs-fLrRGx%EDf{yU)3*4{1g z;BZ2$#%pdp^sr2t+hvTj)p-~J7Fa(Qnsg^O;Ae$Qql8V|MV`@{ITud|uLF%HH*BEr zra^dA+g#y=m|nRSsw;)3txTeAyX#Vvsi(lK7kI;Ds*IBsy4s>&%KdZH$ zrE(Y-ccY!5B9004Ac$ZEz72n~|FbHY39yF4iQX{>EPB^ctqcZ!D6#f#xf^TZTd0ES z-X$kgk7(0Ipk|EQVjIS}73WZwO>RXilq7MvNUuSQ#0U$IFp4L@y6}K7*wUin3)Kr|=oT2JS{kMn zOL&$^bZ*5UZmI6oYI_S6Fiamzqiy|^lzM>8f%>>?VM=dCpeY|lWJX7&W}b?n%hqf{ z>_&%8k|@6omUaq+gv3-ASqjV?uT3$7g2S5&l{tjO)o>fJosPR0Ll`{i30wb)d%^fC z^;)zEEvF}h5HP?Ng{&yopKi-IhjVM-{LIfi1X8Vk=EO2W&#d#@G%PQTdGL=#z{egLRo?{ao<Ty8x|!aZSrI5lvN~O(E^zGEQldL&2@p7`H0Bt2vNwOcnHr9cGq+lw` zCVBOQ{MOKtY|w703+1XMcyYOHApSZ^CG`7Kap=D}l6soM09_Rb?}9}O*ebfyf*k|& zx&;liB+mt6yUX<1(B&2$2m^b!DR7S@#O^jC(n}>RR4nM3t&WJtU3FEsJ$AQbc|}|) z`0Gj#rn&?(CTN;+q=MHt8gXJUavmg(xp| zprj~LadD#VYf>OeZqa%ag3;s_dhbY{v`jHtiwvP;3x@LV31OeV#ZefZr@`cyLN?C- zTi;9K1D{LPi8ajl@(kP0fhc>1O}`CRO&-q%>)4Q#>dcezf|c4zM9K|*75VOXJ8)y2 z&qFv1J;^;^I2mWm7WqYoi{YxuRa)dxVC!6lIMX6gkF#L9->CMvhOqg1refy z2QTwD!#6MN#!(Ag6~{AV-()05cvk3bo&SQ+P0^%pc$a@g%=Q7|YsS|UhVb*oEvVgt zA8eT7aq5p7w|H?fQJzc0w^W>OCN1+U>rx@9e`R{~`9yKKTna3L8VnnVUn%!{0g@^{ zieOz5^v7^p4@BTD!8;iA37j4ip^Nl{Zpt%>(cm#g&RKj}tS-<1xQ4p{XL7>sQSt_l zLioWEJvdb4gL7((6b%)X;Dx{Ewqg@on6J*)klXQTaG?=4$3~rh*El+}Hps$mV`-qd zV5rE8Ooic%{wxO2pWW|)#J`U17|0S5zXXz2Z0a{a)@7L?-=lAS)k@F zK*qixU1q}Ncpmoz!r3dQ79y|8^vHol(tyOBe84JKs4?4N`xT?N3in5i9A}S^d%yDX zG?2uwHWxx_Zx9Vs!oR61G-PN={vAFKVfK#Qk_nNYVT5LnHlk6JMx^-WFkM;+3@$+Lc8-ZagYo}*D4z7zW!mScPgExPH$A;6QdZo@@xnInK; zANjEq4>F;XPyDm2asH`5W&Z#b0fd`SP?|k_stE~7(ZPOk;!uQWk=-cH)ayoq|A4~g zBwoqGV_{RiZx$i>0~eac1`VOj_MhOajhwIsq{HcssVaFzFRLQV7E3X)N86zuSXYq} zCcn+3x_-Lw*+3_A)6035RS8Us)WAp26$ppm*~kOk1mQo)?bIYNA+vCEqGm^6Cl`^#X1l#j4!NOM>~LUk-2$zc5HgkoE{S6 z%~`ku#%0c`6EofBta>riW6o*-o9T>FHr!EGtj_rM`q%MQhXK6)>c;||0MS;>1!jSq zLd6_0!z|m#Es#WV+}J9Ur_pkh0|cpYtwlaos-#Rn8rN^ZogG3RK&VQnL`eRV8U>+8U&VM& z6>{+bd0~YuM-4>MKqy)xISSFF6r!w4i_XA^PD~9E_3*v1X9Ex7sJ;p#W3cA#n#ppP1_9fY~zj2PCR3hOG{u;<}B}D~ZPE&FjFg zr9+_fQAXTLP7$tX5C#+68Ea1UqN3AMH7qR}mFTE$ID~?OR`|<>s?uM%Rz>E})%2-D z6>(+^7vQ+KYjY=1?%aQ~cksoXA85u4z%%s5VE?ddXkf4(nq`cP3%@=zfYf_KSNm|h zJoyXmG=t)yt4pMU;<&lgx2rIu5C}1+y24|inz-4>sP#HiH_;RU+*Zp_>Kf)yK|Zg7 z0UTimH{p)XMPS^)O+hW%ftN>u_ysjkGgwrvMn>u_s-Ei5!A;o3uan@NTJ&;)cZPre z2r^&CJG@r6LyPvbJ^A5_AQVnmP{Eg# zt7mD6dIr4enK^6zKWZ1#cMR>MYOvHFEGo5lv>XD-SfbPqvf@EpgQ``%71y;vfk0j( zk`Ad?4cW9h*UFz}TU^ev!J-;q9_*Jn=UAApsY*Q#69N5)e5n7<)JKpF;fGLmH_Bi} zr)Ht~jprjSef(firA6oKh)6-mE{7I93(Axw`FRvjS&3){?a(M4 zjUI=6-nqvabR3;_k18LX9$kNQc{a`U9L!u0ok&l3SuHN`GhT7{1X_eA*u~k8AQ#Ma z%>WEX)vM2x`~nKbi3Jzmv*a3-JhTZ_*07#}DIW!M6Jcl%b6|p_V4{SfJCXwv8U^!H z!feZjX&D8xjxd~tbMUl}g4s?OdPO-fojEWM?LwJ>HEN%=g;PZ0*{ehmNhIxwA`(Ih z6Gd!}bR>$1l&vL-h(h8d8nynDt-)G0;lr(jL`j`hDAgNLsyCukZ$zoyh>~w)@`R;I zUWp>Iow>#)|EL?&t?$DqV%Czr;IpzCexLxKiCN{K$Rkn46-rsg_3h~IF)Vlq>yZby zajS>FFSDL7_Ljw9Z)AC9J19IpQIyP(Sk{MO#;w!-fGFKHPNA;Br;PLFRvd)Rmtz%H zml*pBF8Bg#Km<1Gyy~pn@xxV~(~N8=r1JLSDndMnVEfdJ0E^e&36 zr}_y#9BN@WNU3Lh7?^@srPd+ZND(H#^&m*YrNRr%MFr-5K;R~-t-X5+ z7n-O3t>cLc&D!x5@rC9LoFKx)`+>R0g^TYIUqct%DJ<6TeM2(}yr2nw!J0rj zOjoUcO{sjAtSOUEe4Niu1`te9^a7hJ7UD;iN5(E0D_lQu04!(BP4;8jFgNPAEWc#M zku&h#a~lA3|FXF&j-1KlY9`06IC2&fk0TMj{6Nn4tt*b4!-A$C0O~J2ems`$L4?Y^ z;>d&3>%Sg8yC;Y$dGJ2M*AwegJyF2-_3V)#7QOhMm^4Rs#5^JW)Nbu5{PaMa7dS(5K<|(7O7-=LO1R4#e$61$WFp+u4Vfi?#J$ZGC-#5ijhj|D-FF<_*paE**vc ziZt*GuaR;h0E(Y5)Lt}0A0LgMpM(zd?32R|)pPWhNE zSn)E@aym`ZN7K7W_L$!^@w(<5!uU z=+4-Tw7Er}p{>W&lcBLj+|90Uadm}8x|-6+`czxrbhs;YxT^_op-+%H(iJ+=)r7au z$4GtD75b>F>Eof`$l$j=2E)Qn;y$iX=O0NHZtll9AjFuoh22B0jf4Il!Ux8W6C8lv z!Jh4y10b%=yyi=Xc1HVSde_J1?pWQ{5&iP+LDxO}O^u`*KYk4{;{PVCt6uApsS}VI z-&H@ps|j!QCn7bjtA1Qp6W;3aJH<_&u6j>b(@E7w!aZ`x>b!ppV^sFv{2s8tjM?E*#KM*I+z@>gb*u3;@>v+0 z#j*Gzcrk15k=v1Ihx%>00=ydl3Yc_$xxi8VJeyelsG)AATG*YvUr7dxFfYpB_U3KS-#$Q(8$i%s@p2EcL`p}xNK|pdQTtS%s5**;1 z|E*Lf{9M(4t}TpsfYWp8%qpzwvhh*LA5|Wd1K0Nj zd5EzNx8Yz~xD;MP$(#Gt$8R+_a9^_837Kw>~NzgPud?P12Q+t?{SyxV`Jevk^}Zo(*`qlP97fG}35O_|AVz**1U) z9&!p#H8QM^h5qx`vb>2QwR14_0*MQClLh>CM=f2BS?^|)r{2Y64f>l?Kfw#_f$Ux< z$1L%khg{|)WDZ-0pnLdxu&^)kyx!0NbNCysGN)TP-^mGBAF+UEr&NJG|4<{mJ)a<- zA0cc4TH zHX|~5>}SkB|0bN)C~Z1u)>J$zPg*KIo#jz%0g`!5^79woV5BVV%5~W&@G? zTzz~NUvcE>W6dR?(bC61pu-t`yzAo8`shZ88$IGd0O+G~>2vk*EtFaMco45r;pp0C z^s&y;$9hX2X}{db3o0d->TP}e(J!S=1dpeWXX1z)_}DO7AHVZoGQaM4^?r_WsgF_! z)>MLDcFL$AEkFMmo0@wHZH1%$HTRrgCvE-v2@E$2{+9mzh59#?qko9_;l7SP-)8Us zVf~a@#>inrp1|C=ca19za~XqQ1y}Bv`h7e(A8y!&qxEt^Y@>=zmJ6?uv|h5X8&;d$ zfP<5MUEITBgjo5z*!Y$B;$6;hWzyBZi>6n7ZpV#M-0LMR4nOxH zT7K@sfN90M2zY_IE%LmJbJvVgSk7~3DbG-in#0IwVmpH%G+Xe+r5V-7h#s=kk{FM3PV1cu8I zrd2Rws&|`1i%Xn4C&}W)e;zItk5YPoNXm=Lqm$5I9tXJ?&pbkGe^0`vnounF&k6IP zeTyE{(sfeq{YehlQPsDeXAe)Eg`1|KV z9y|kZ^lqf0_@Mzg{U)Zlk#r=csmXPkSEl5(0P0PSb3%+^IvkpG_FoYfQRh3$#>pwo zwHoU`ScE6>NNzl@z#3PwzQJ)tinkbY$R!If6R7dXLxL5Mp5Hn)FQ!T7!|u~ds1&;~ z0K1-i;7g!?8ZI=Dx5>fsx`>fO0k?jU59${frZrnrPV(%FaG=B|g|C(Y{E6NSzsRK^ zxin4U4FWIc%6z;{67Oo{XE+zxg3*+^nrJQm;6sec=s|h3T8pk=>6cK7`B0V1g5)*; z4aahGo<~lq1dthhI+i6;wfTDn_Q1D%<>ZaaP+#7fW1pAFtRF1Jy8j{6LSVab9Tkk6 z7V=}ZMCXI(5n8s?j-A9OYt&V#N_vG6mkKl=2y6wy{UI6Uc~~-p@MPd6dx?nCHB(=d zDS4U!sWW7%%qlwxDH2qOXYyO{4UZvsvnq~J$BX)2JzbXg5g&DWyWJsl>VN3;3FVBBt+^kOE;Djg_@`4ZX zfE?9veaaztbaWu~6V=&HH0FriAhk7q0SxNM(xs?eiPeVNR!TRuO&)}co=w{BQNvT8 zMqKm+i0l6%?p@%ctgij<1O^;6I#GkhHmy;oHfXeoMw99n3L znkZJp;7owWhrv{^+M{iywLNXcqdnRh@D?s+(0W0pYr%iNv&TR~dbS%B!!9P>Gq?V!N_{?{~(A zJxy8M3?n$1lC!nSkmEn$x{j3N8l$mAmx}(4Y-(`A#JMw4abv;_IoUQ+4AzxOMFilW zqX2s#QPaAG$wGq{i7nbd$MPG?!fPtnA_3B3xIuV#lVXVef?6>rd16_|zp=5ZxZ~pU zCun0;M}x2ZHU|><4Zo&q`&@3s;bQmW8rEI?1ujV4+poB`Yt!s_!ym53u~~7$wvIR5 zaYx1r|J+jL^$zS`ZR3e;#lp^z)Awy7Sb=>E`?Ur2KkU$g;Oqn2eKZ-2;xx$R&$@Tq*A-vB&g`hsy|AMWz0Wq^|J|@r9Nhl}CuTcNXT&*% zWy=4Z%2OsYZ~;ESE%cb27{b_0^SOC@@amOFx1U`w!TW=^3Qq!FSv)udRh#~l>g}k4 z@1ol@I#7SLS}xaea+y{ulZ4EiI=GkLyrX%HZQjX@6kU)T(4f*wO85kq(2W>CGVPxZ zMhhu152fTFpDTQBPbZfvBc-O3g67fb*D)w4W5*fkq_h=cOVUZx3dx^NN)>TA)GL(Z z1V_Y7$C%(K^W@d>#lB=Ok;U02asSRBrQ@-~Fjzku5w{5}shiW>zrMz0V_Cxvz~}r8 zS5vJf^t2ZAh6I*nO*U>^#fW_)%4CWSvwx;6&O((JweRJh*iawq(r6kwK8$sJkq^Hr z`4K+wq#jtpSZWn{%CM`B%CY@;h2GtN9v%sqms zW(0fR#)owNHF>|%qXinhaQIej0*3vK1MSgq_qUPvnrAm7*5^RmlVlQZ|J+Hs<)i(x z`K+seK+A?%L;3p9yFl;1EiXT6w>#{+PJ^zDpAJ#911u0-8gbc`koML7S|jiyzw+<6 zl@G3g_3f4%$qU`*-qmXc`qYtR*}T#2H?;m5dwVb5d|kW_gpS=e8+gSqk+k3l^7}QzQ>ZL zN(gEZxMOcog~cJmhd^aqY6;u_+#~wf;*uK=-F`XoG)Avpk-?pbV#m}v1>R~~^Px?G zb$ux<`YTxCPd;=T0nqYBCJoCp=wf2DGdd&D|I|A}9d7SS(cyM|TIXP5H}*0UxN%jg z*Ly0KI)#j4$)AahMmC(zdh@>#M2FGw4_0^Dc5!x@PdQTr5zW3Qp`epS&Ve~~s`DS` zmHRCv>C+?W<%Xr2?HuN~8pBQkFtpJzsKwx_^Lu)7;w#~fKrP~Hw`n# zojmwbLf_d2DRzptGlf#T5!t~u>dkDso}rEG!f2{LQU|MLv|7cb9HdB(?;^9|I0435 z$f3G)Vhi4E`!#CWF*L_WJB)!nqUB!6~n*#vaFF{)o`dbV}#Z-!dHvrPvaE@Pu<5 z?r$xIWltL9wpOHV9{oxEm2*fN7sC#>Oo6!Xv zT%?}Z=sZIzmiqFZMoMTNTf7FKWSPbOt=Vj!U1SXFv$q{P*BmTp{fGJ$KfqVq>f%ho zQ6d4dNY~!dhSy`MIlOi~nn`@9nsq$umG(ae_EY!}=_ZBGiF#(WP0Y!kdMPrf^^e} zNbQFHLsi~Cs7m_*Rt>@L;4+;47cD&?kl53a0@||2N>B@hOyMZnM$*|KG}w6lTa1ou z2_;G<(2|??W37`W|@%SVhOhc?`Z}xwvS>iZckHu2o6JVue)g+&rT3AkN zFy+0$@~U=-5OR=O^=_ZBMjCE#*&nTqjnz0=hp~o>c3+Auo}#3j>ERy0=lb{Wwp#-^ z#G)cC?TlyY{OiT3#p}J7R=pbWTlb52Q5WQw?T1HZL4U4Fh_|l-rMB9w52>kxOXxik zcdDqn7CT(wU@bFhF z1wJqs$etq^%pM}I-&UDRaLZtVwyC+m`GbMbOO^rCd8o)tVzljcsW8~yF~v9ff=g7@ zJlpcAx8_2|TZnpXF62l;=$64@f`kF-U)eDgbU>f%MZ7seP;qU5*7$CM0oVgM7XsXA z9WFkY(-otQCS_HOxYN4RUv5J(29GRdytV0FXc!)v_E?S1X2wL=NGLctQ4)$CwMe?T zTKp4ya66D*05i3QkjmbR%=I?rTJer8e95d#p4v@01m*{yXAN-aG15aId{W{MKlRzd)J1l5PZ2!|NSS3ISSl@rA%wS+Hcg zzd+>|zmzW7n2vO>dM)C;$ExbpnT2T;_!koPC=SK?oHd@1#JTg+nFURN&|hr9a#RGS zMU`kCnFR@g*WWQ^rcnPHz-9or4r63-(MSUug4-hmXP{d1pk_Hx-3F>91eIP;!JAq= zy`Wrgv`5L|rY|GEQrD4(_N^i&IDM0ACUwkM>I~X3Jg3Eedm$^Iy!NPY50ko?#1#9o zc{{8o2?({PA`~ZS7=jWtN`RRg?$B{zrI?497`SF0LlD2Rb#)@SAf_|`SMMgm08HIYgdx5=P)3|%^EqnrWmv?) zyNR&Ei*^%Xh5waFnnQOGlokGDKB7%zdN}{tt510m30pz5*PV|J3SULp8~Akc*SUiD zHkR&?jgX-^K^sA#E@ZBJME_3Yrekwc-@e=yb_{n5M2*U@&H)E&r&vKZkmE`WRR3dF zm`bX$;ay@9frEWv*}{BZkh7JpzfmdIXC?*5U(Z=@6CxnpDty$*$v)_-{Ogq@4k|36 zn$kZ-FoMOO5S3>pRb93X2BGG`Nx~S z^|x?=1Q$u$y!p5B4gJ>g@ambY_P>j8F-Lo~TWh!1ZVH-Tp}A-VX&>3EcNDf=?WXLr z41gIMX8=GE8c+0>{T&T9*ysS5Wx-#u^cpzym$89FZ`rp<9}1&T{?%Iw8Yp~foD*f@ z$X?f^$S){VMMb6}1Irl>CFayr(iA1QhP0B?os!O0{nq?~7Ms;^IFr$dd3~y*S$fR_ z6ewIEd3GTp#^rxdXqeV!QVy*@^+Qo*m`axYuD1FARD%MNb2`!LTPi`FPfx@p&u~X) z=ryCU+-1=MD!GzZl{2J_qQcZ=qTqyg+dlm){M9(sC3Y#Nl5&;Pey1E|>}G36%&r#nbUY00ApK=8+Fv4rESIIILrL zNdcI`jo%b)#eDdTDpi@U)GWWTQsnIy4PARqA^&vHw02E5Cdg_!b?pI0(phR7$T7+3 zSvl%Y`e&(MR!IFx$*ans=>lNpZhlq4&|`ujIwg-NDW{NfFH(YE%TYI}5BCTc)a5U) z4)r~zPFfHR=_TqrdU>ml3SSy0Tc+aPhSjc3@XbNRTY?b`wZq!vt?OKys3>cb$@w;E z$(1pzO{N0NTno82sZyI%bwKmgG(=0TRk(UaEn*e@_6D^`MZTg_-2G;8YYoz*za&+m z#j#I>&}i@=|yowbd+HEYM747Bbel!nW9| z?wO+FcI`%(<&Tj(^{*8c^b*g#tZfZfO7i-(_kQsA7X}6lUT2R)Dl^+nbivr~yH)kn zhW41>JyB5JFODtVpKhG&D_)6w9mti)e#hCr=-O@|VqJ}-An$a`+i_cx6Z~-7pD%(u z^c2>Fxw;3d0@D~Qe+r_5Y5zb4OI92AsmI8r2v@)E1W**;wc!=KUL}ac&{)HEwoRSt z#~a_?_&Vca)uv8y&?|4hvWly)QOD(w4@rv6b9XW;&HZf25$X zO)je96%4AbGB+Deo93PXMzvdW?dg}@Ob);7HwgZSD;#1(gB1K!h{FrR;4Y;%Ik=P|e;V01J&>9-X^Ka-mpjM2_mQ#dB1m1xB*7cptLYG%_i>r&YK1FdNaC}#M4~r5N!C9Xz9$| z6tIp2FTPp3b@N5_`1>H>ah2Fux;e77m+A86GWoD64=V5%*6E;sM-#npm^Moq-nQCq!RC7XXfa_Jn`AuFkhkr{)HkNp2 zCua24sha+RMT&zmGfp&}s=3WwUE@!X_oc-*Dt2}4*8UiUj+;>uOD6^L{I(fS)D=JG z9ho^TB8KoVTdf3RYi4(iu#AiZ+#g2YExIiaJPe>sN{VkNpjnw-Kg3 z)cVa$hK?E!h%KPxQ}2+t^VU{F>u^1aiqvlH>b)k`-{JQA2))v)r{nRsIG}PPo7=pq zj5E-xdZMRc_k5O;IlrAFS$#-D5X^7s+W593I7Lhf9(*hW*9JWRc_+F3 zP9Xxp4g-;V!At6mNw_B_$H^CeF&CoFNcux?jmP%se3ouZJAj=Gm|*RGc-ElAkT)~= zee}81YKveO=#Z*aIgX{Kyie47GnC-HZQfc@*6qc(S5k;Y6cw(&;F1%_Fj;H8p6%?9 zrM}KENr7;)5m3|#Hh~E4Eube#h(yrjU>%CFGE%~1T)-3jbM5knVb!4tZOwE_(&#VK zc^kiK3U35#FOaNKh^FjdEaH5EPp}HiH<|On#wLeWf3aYDw%01Sr@}f4MaCA-a8r_y zwt0$3<(y0hrN>T9*L4Y~?G$K_PY>c$mWpa}kh+E9!GAJkOkMTbD35I{8u5xn4`wVR z8`0ie`zY$%WbgU@5&mfJu~n~*!u}pvjH{xCzjtg^9sPyEPDSPsph@_i;?V+eXr!ZQ zDMu4#7*-=2g~4K~KVNK-&qAH<0z<`Dz_CadY zu~NF_Aqy($Bo$H7DLwX#Y*}f~AqUopcQqfcnYSyprt~gLSY6|uRlV*RpY>lBZim)RFs^2CsUgZKo=8;+MoY^2cwO?hukWcy+`DB=vp=> zJ+nV0F~PFHOyoIR{g~%0gy;cS3ED@*_U6+Br(ZIn2)oOaV$Ri(n(~Yg9>~?~G^sd| z!DKm&)*V`fuyZzcb>jLLVkJg5k6A8_NZMSsRxH^bo3~c6h-kO}B0X#@ei=2Ke%;r8gk)3* zAQ=6Klt5*4r(_G}Q@P>Vtw2j)0MbV6;tL(9j^9y%@?_6#WFKhXj8n!SvX)@`BM%XV93ncEMfC$gJl+X^=56?yUs7_JD|Rm4@+6`lGRoQ+Tb`%Fhu zZ~(S{y|z~c8^J!eS82!=u0tj=Vjs!UcQ&T6yOK9A<870xcyr3OGx%{q)*Lai6X3b8 z3oZ1U@ccDR6ERX#g&$2aN~6wj?X0Q}Q9h>5{K*ob&Jb@(j3Y$XqkdVp?XjEP>z`H9 zfO>QFeKW8h){Q)^jlrTm*<0p~V7=;R;d<3>%0Kv@DSzreQ+}x{9~>#ZMB3y~Bz|oE z>FSZG3G{MziWz&%Iy6gI4FYh24Q`Nt$y4X53l!P$8bGUY;FoTxZg`BVt9mCltnN6> z?Xm9paO1#0$117%+Pd+hP1+G8P|&+)Z;U4WzsTQ$$oWY8xI>we^jBELJak>h(cWI^ z);$LpSIRS|X^<%LE-dxVlAo_q?^43t-25y~1TvrLp&bYM|CYCh04d@l=+BCdU3d6t zB~nKt+N07E9sAhfcn>TZyFPbd#Ln+3e&{xcTy*X{i4ZI$S($%M#J?o!A3XM*!_O)4 zUK#s50bDBc<-WtuDNTtlN@O>S2PR!T#@7GjbvPKM(S!XjVhT}hd)S?ga}9R zXZ^k*jHiI{rn-|kc9$cYqeKDlR&w^Q&3C_U|4fw|Y4i6RIJabVgcHGo-=*OO54F3u~P zaQ+1bOS?K(m*U(dZy#hQFX<(EXd-Rriw?|+4AiK4HOaMQ6dg8X&YoCMpE~OE5AxUV zF8{~zA3p^DLV6~E|MB!qpP0Ud^#8d2tskqu%A>ArIr@j+6La4mFMra<$|wKiTzbym zA^oFQNri<^Ix*ogj^4o|_yIRq!8=tMNvEQo5s9MCIilcwUheMv9#LO4La|CI^nP0BVG)J2*{nq7O zk52QNOZuAkE#gie;Q7V=lG}NDxc6);K^bB!o#a4d8mj~^(^zf!8*7w5(^&VfmsXyh zX{^8W((hf`*Ek*sbn*eF8&)n5{NjPOGOsbBjkg;22KhZqvZjhW739HBjBurRsbM|Z z+1&pJ_gJg(!{`A*pT}dWzmKNj!NCkNgSk{h$)J2Lj8L(zJj}>@P|ZZez!rl&n0{z{ z<;UXThkTO5CAq;{L$>6y=%wrI;0M^x*&k@nxMMKhDnnMYTD|D(W&Z;_uKN9d4DUFw zsy6&ec+*8RQJyjv4B}hOD(NtMtMmAVUE`DM@QC>nvQ|c9RYKO7UyRN)&{h-T&G~+- z?YlX8SYi?$C`uNCkE0t`z?owq*BpcVk*D`C`1PLvKcAi=cGo`RKarje&)0_gleH28s(5l!UaN6{^-B5|t~EE!J*iIhosP|C~S?A}bmhK$D*{;4Hhy;mM6a`v&liF`3}ANFq;SOZKY6cTBr zjs<{lmnN>4r6Pp62yNy=Jc24_w?KPU$3)kHlR`9N|)>EYu+ywok77d2h&K$ti}rdEoc4 zwEuX^pF_jut3o6ARIWB1y6Hy8{ezp{C}wWkez;J4JJ{2q^~k)n0_m*q`SCD~M?LTD zJ}pBl=bh3cn>DC#z@&X2QS9wtx)A0@^Jd4|R9ZuT5g~X0;ZB25+85dO+*Tmy+ppJ> zr8hnvL=Bx->MB~3LV$Rn+Lb-5-%`leN*rc3RvT3c?t?xr`NkwPEv=c>nGK!=s zxpvZ5*XaCyDOAd33TA%5^#L-AmnjIXp(ywfRzv`og z1pQQvTgG@LDt7_B{JM%a_63C`&hFmLk9Us0=DqQTDsgMPh{BkFjm3Ko5YlH#F$kDl zbFZWV=B-saZ=+fT5aQoRd|4A_T9)kUsaVOuc=Y87hmcM)XgV1GH3`D`IBE`a`4u!y zf<)s*KAwppr+rx_z9aW`z)otDypc%Lvhf6!Kxi#UE^DDozN-YY90M&ya7EnF^#q4W z?96xeEO1XRif^GLzahDbovj1AcJ12n!l64q*U4Y|>lkntbyvMr`s>b4b|N%o(pQd% zH9b|-8y22?apc%lDzQ~Judwb9o2E?1XTtFpOztV*9nJ)U;;pxER~Bgd`=lp16JYN-Nw@<#MZBI1K@2ND+E-1x6-wB4O(GtYe!O8 zKQSt%Y@(=dDR6I7A8I zz z_sG+)D$`L(fs+_Y;;7iXPL^M0trVOgPMC_LXCP>sm#DtmP67hC&OwsMqahv1R@h0P zC+cX}J32m_E@HNeo7l78>vb zKp8Kn@xYjubDfMMzRDT`6h#U=F|wkMY^4lZpZ)uP*&}%Hj(F` zA&m)HhWFx*YX4|;Owg*dD+raZq?3G%uhCFPQx8?Ym8Wf-p@-f&C62_KI!Qf&JBZj> z<=-Ga#|K0R(^$2<9f=2OYF@t(`ykn<;Wn4S*a2(b?i38J_fcZ8f{tsw58 zMgwD_Ld(X5C;S7wB^tT<*YsQgg#HJ@`%Df7nM%+o=|9@fm4En<^0}p4z;q$70O$|8 zGt{BpNVm!BbEtFLXW9<)(ZA?}Rk~1YKI#2p2v^d7t{X>b!j^HR9q*)Xww}V+c^ZmA z!_G?+=`%jGHaF)2(O?F_eN88Scnm)u9aG!OW0&3s7-&mnE-A^8BmC0tI_dRc{-elG zN>js>)+)Xsuiv`)L5MExG0o6Cp#O|qdze@Q+Y=1iNo5-5Z^9QF%Y#*y9W$)3hlofz z2NJTIFn)(k#dLyzzR_X%Z#p#o3jKWyX^<*Plb;fj=$Jf-;#Mf;ZUpK`EX0y$r{S$L z>SHEu#4)05JywLhSl!+$&|bQ`^NbqmyRttaQz*66?`}aG@h^=~?L(5QqqUFHj14b& z>#+q~6>T`Ny@b{7z>%KG_S@-__&jD8MK$gmJphI3_rZ#yg%{we^tx67E+C zL9~A!$Yt^Nw>YwUTC^h=M`yqKFfYKvY=zQf!jfK0uEi=csQ>s8Jdo;Mn@}I3U`^Je zvHLifyFbSN;qz0)cTR#weGPk2kCu0ial`$F7Qd99!rrH)y-2lO_biOR*~Q=Z@%Wxy zXlo)wNYCNl!~F#h|2F*F#wTALnJzmw)70IfuH?5>v1QF`t0ML8>hr%y@7hQAU9};B ztNo+=s}lZ=+STI!&i0=Eb)@7wO~C+B@${PmH%t|+(u(u%oULEN8Ez{48P)!^lNHI3 z%6Z>2{Rs(geR4~&e^k2Un)LWbggIyzXVR_yEdS1h2XySF-u_?Y{1FV|f1E!f;s4O^f5`Cv z^AP;s3h~!!-D0bQq0GuewUsenHBu>lqYUm9{I5m~UFoemYW^akYB!LyB00aC_u?II zH@t8~E1X#on}55SWn_Bdci7&enk9Q#rC2iCd%w2Vvz+Os?=Z$CXK{s<#}(GpuQ5^V zYML={MxK0~^Y*U^iF7MKj}p1SJr&(3 z;~yYI{2PR$H!(Te+gZCI%R+C?e@v3bo}QgnLx9bKvUmJ~R|HeYzjS6TR8`9NN;s&7 zzES)}89Ln<5(a5%Be_;EpK|h303<^XX!x&A5V_*BjNs9wY~$n^DZ1Q7{y2}|=$Dx; z9^f}79LDLo?cS<%**l2QO97F-Dk6RFB^H~KVe>nA$$ehs=o{%&yh;y- z6@#w14ho2$iqrl@p4-McFlHwu5LT%$mU7U_IFGNCk>Kz;ZD|lJx3C=Yr|7Sx#F~8N z+x&ZaK$}4eFGYIOpQ{ROEpN5EZIxVG47N{lZQQjA5+IYj6-WXmWD3Z;)HF=lTlSi# zB~p^KU*&LdTNg;)?igJAO357!+?}MN?I$BdlMS}gAWmwpsRiwo!!ghQM%{edh1`?p zk#_0v|EO)V0zSO|)+!{CG}e?m2# zc~2gkW$^f2TZdiM>>=)`#z}vM!P=j&!MA@MP@_K^Dr}aEU3*_(lGUgR7sxwrjZN9w ztB`M?5cKa$M{uvb`!KBqFnGFkA(I<|K53}L=n?d90KI>ut=bmo1H-@Fcx>J#8ILRc z8@FN_thd>P22EhE@|-^>kDLSbvPgw(8ts}33ILC zSNNax?-#luq9K|Kq!nn~1X;h8=pFY6;TJ|EFhx|2X~#8Y4uxO^E3Aokc|nzDvc$JU`a?2=1j` z17oIG$73e#jqLEvB zRr|M-_2nJsC1>OD?90qICY9`1gQ;Vn<5&*Or)TX-?izhLpgIl*)N3Q!IZf1oMYim7 zMMWQ8gLAQidv~n2D<{?Go%6Ey^73yt{>_GtM|pk5w=++9v6g8{&Zag+12H`48%x^k zDxB|fmZJSUiHtR+Tr9LIc~x}4d#U5i{=eqt!&V&7$~#?Qx=wd*^~E(&w!!V2%Nk2< zhuFz+%H2P1Mx^5}%nlRx{}slxxnY;CBh!*kdHZZ!;|(wu!%f>2{`^+WNn2#JsmJwn z9g7?l_-~~^yOm7U=-tGw@xADp<+z_nH$|gxXwdqMtg1{^%G*y(_H&)rAut@X9A)Iq zT*eJN2Y0UK;1J)yUYI=572EFNMQnzDS_uR(TKF;#GDB)dJS%^g?{O{Gw8opjZBIX; z4Qx%GwhFhvLB7u|!8-h1+~27(8+JqUnx`3$76`~`m`+?#ZfyYo(|lh&pMzuL{iM7N z5ytWY;&N2Lfxv;}9VQs)Dbm#Uw_a(=rwv$072`;g7wMt$qWB8h``-1)i(fiO?55ZPp@ey`l2jbcLl)Ir?01{>l;TXrx2 z*~znZJJIp{4Ya#WuXLBboKAK++5|s28#;{X1YM)l?M{m0zmRlLg7YT!EQQ^qke7%$ z>%V>ROr8qLS>I8pQQYY~Hepz){oL(W8^mouOy{agu9AiB(6n)cv<7GL#SLwpO)g}@ z{Vp=T;|!<8tDtohRG@K7nRTBmp;#dwn`6<|Yb(9=^wl*2P!5Arj^;7JOwQ&Kxl$h& zdFz$JreRc=$v!bIFh8CkPoF@Zu6anSkZ^kJzCEYW?~mxiyw}OkSd5SHBlUCCZ}_P$ z^47uEm9>vf!+o2aYR3sZx}Kk7Zi%ISLNUC4;S$g?%Qrop*K)b%gM3gtmXiC!+U@0vt++FnHE~~n9K5Or@F6$mHu9D$DpO@m)jzRwuDl*n}5ge7is-`e|uH_4utY0eqr8e6V8%|AUd zuCWz3<#Iz9Tl5Mk$2GRauGe;O1=DCnWGzRqI2&Q?zSH+5|JA+Wc%?+o9&!KlN*-1I>8fXS_AI3voG&>2U6a-nMQu*mp)mpdZ}v<>GIc^zI=nU zP;&y|&#O_2@!dTP3q}4-Z6xY?rsJ66O=v0|?@_VHhqI0Gi7pB*+m?4^I@1m4Chw9T zL^}3Kt|$Z4h*)a1Fs05OBj&L`WK?8g-WLQovtm1uW)LM7%dSigG010Ksix`9lpYD% zZls-Vsu!{g>iA`2f$n=3SG>R|gnNtBS5-hN-U&wAPv5K9Kd;EY8tZih2MS_clSq_& zA3FHFjGJ8=yM8J!{=aaEd8|t_Yj^nDY2t-6s19jxV@QLG3TRMw-r|VC$epHWD{EiSaSw?+wyL(INYP}j{IFwb>`96;^z3F{g>L42;BLmT*>zdOnu0<^+OGmhx$-ZV|7`Bb3A-Ctc~8Vr#q_;t^FAmV8Jn-U1g`_UMihGVe}8(~ zN&Ah8EhyrPb>kWi*;kT=dLF|=hlrQ!$)BxpA45cGV!)2Mm0U|G-%$>E>lx{t2Pa12 z)4=tZU?Qv6>Hw>W#KidB@K7t-+BbD?+`Rtc(aQUMq>efmvTi*o=~wqMv1!Cu-JO;lyE+|d=G*CtZbltiWo-TiHM%fM4Wzpd z`4g-+@BLjks{0TE-anFIAzMUL>^{McECe>a!>o`rPw0JMZu-MTliUaEVzdmI5Gnl6ELTWb z9C~WJtO#zRee8r3>$|cywk!(^tS3n&1xkHlM26&UdyAD1Wh$4cSR$<*c-9Fap5v96 z1o357I)n8xD-^^~)}+Toaj!1fgA%oOa&1d)8H3(x+wT5$9fC$4I(xn1_LD(fp|04C zz<2sOY$ybS7bJ8!6VICTy#QzQ+boA(F9H2Fr8FslZ$3gIeA zXN}1-QUW+f6=TjS!m2{lYJ^&?P&-zr9VgW4gxc{!?F6CrMWLp#+!#_1TxQBhi{w^Q3L@ZkNcYv_s0NI!!N_2*X;AG>c-E7IXC@5P=@ zQuptbtFQO8*4@2zm?r;*6Wa}|w(POvZM;nB;3hlS%JCG(n9b@RZL1{n=Z;59-(@XSo0&vOhOVa zScqFO?u}6jV0;@G)TZ1s$m!D(-V%#SitgU`6AqETP{=SQ0z?Q)>*_#lQ zI$*}`Yu?viqHNPv1tX`$?rI(pyRX;7P-%rp&0$tf(b|F)T>4jperN*%cyEXiz0D;E zE#T4j5Y%+%QWpw&x_(6RWRIqpQ0NPS=(M5?;h?;+zza$Dy!%BDQLg=n9z7n^&%^sG zA!z?gDkNZ+ZWYRo0hq;Q57O`rJ=N}a4z*v_e&5C%4T9y|KM5@*o%qOp0T{u*zYZ7d zI?yfb#Zr$`QgYV?rr);j*PZi1#EMIHqS!l!y7cZL>R8@h6TNF_`DamnFp+YdG4oEL zxO`|5nONaYhvL{m6g%O6hB}GnNI9sj&`_}Q?pH`3iTfjiH{4)QPkrjVWDB&*YE!)p z!P!$l*tu&zo;Mqh4F|hPB3u?hWC->w!ImMR0Cu;*j&=PD0IBz_#D+zTBgExTzR}wA z>F<(lJ${8Wdy>8(A)XgjGMq`S9fL@#64J=yT;Hv_?KcCbBeiNC;HUN-evWPOWg$CG zp>-4ZIesEPCn)TTYTWuz3d@dL6rBB@*r8)D#+pi6b)v?Y*4%NO8lA@+&sd z%$3PZq#@H@;vdp~M^3&&f163-ecZL5|{Y_V?%a2B$nL-&&W+Jtv~i08wPnhQp5C78m6l?OdqXb`WOwN4^_F7-tq_gGsGg6&aTXkxl;Be4(iQxC7 zwCe-yywb=*Zgg_h4F*XTMYBi#8QSOJ4c~tX{2Aa(b;|;50jLui+z6Ga-|mz1=hqj6 zOrA@cW-UB_-akJIZMd@pjv>&kx&-%|09;F;7K{ky~WQv&D! ze_Pz^;Zj&060)uxdoJZVQ`tnDa6HT9W)nrfyF7r;$}%H+?Lpg*{JY;N%QGPr&;nf z{l5i`TQ9ZTiY)n$>cNk6Tf&=NlS$MmD3hq?H<3x0O6J*oB9lm*OCbBdZ0><$Kc&ol zs8@y`)V2%^4_x7}E4{d5>SdhH?tJk4H8^ig91J?2;{T_A)0e2=`I-8@#Ak2mOB}*Q zpEhst+OW&E9I^6A(J)ad&hJZ9b*_*S(3fCwHo@9#f~DC+HBZ)I6UUJK3xnBD$Ruj! z{dCeO?|smy>r2!>+?Qx5?n|6V@^NGv&-0}7`VuF9r7v;Hh3RCC2xEG-DgmF+jP|t7 zr#>+{=-~_~oery9tV>ELV*7;Z7Sm)!a0pZqx_we2cX5@i& zT%Lw4ozJ{?RMH-Hzo;vz<16rO0({2Hn#t-S#aA=dpH{mS309S!9rgOzO(X4Ua9Q^S zdNGSvHE5A&(R+^jUTG|qrECOzGE?60ZpYI|;i_L66{r-d%UVXVRx1MsQSDbs*>d>pAMcFcECN(=C%+Er3@`o(^(dxS3$3C29X!Vcgx} zZh)V-xYG*ba=Qqwb#X_ePd8Jm2@Z<1tq(NcH(kkH3sth#^Q}|x;ck=sEwvhF^`AT1 zv!{Q0Q*vkYnzH28EqmasnfRnHT9jHuX>9Sg6tuHEw)k{=sf;bQ_4upt&EAji?&9Rm zecC_cmvv2Hov7jcIa|k_*LF<+<5zLJ*x5R&UN!PNa>CB84HoSi-t!{{(X%E>CleGda;PReBYJ^d5dvpon8`JEn;<@HbGqY36Wz-9K+f{EEDH2yN0QX`@sk z#rj@YiPR!VNP1fOs=OIbFr+Q5(AeR^&W2Zv|2Osx)2=B zCMwpnnzACnN>YTeu_mOicTXks`IwMnizGYiu9h%GhFOEyh70_GCg(|H6=x4YoWM1Q z#1_9r|45%cgw2hW;m2njLSJ%BRh(T*QZgMh_YoHofz7hNRDQP~ulAs7PFzMo@Q&AzI~)X0tlCLuxOj!u(wVN?6pyFRFt27b%4`9wpb)j&QUEh1jMp6~K6cq@^o#GG5=%*Q@J*TW=esFa zEOirM$zF|c@?B|Qwz3URRW=pV?3HeY7Cf*a&sSaL)I}G}*>8;NL7#Z9jtjnI;VsZB)IFfT;Uzn)Tf0(@lDl-GSJf8(w@_{ z$Dr<_9f)4Z=OiqWyAti3BvRYjO&cxhr2ayYfI7E;5^tbl3+z!K#)IN#1!F*K5+{&Y zl(a5*S&4VQSe&%M@BYKlNjJY)zX%uTe?fS5r-odO%NoD4m+WL8h!#}*k!G%uIb;s~ zX}U}zb3q_4iiAmlIYSeL91UliB_|c{BuRH)Dn5_rIXtiBc`(l;&*?l$;S(*-dCN zXaqTCgMf7ald@HRbUh>cC6eW?d7&@N`i`+nVJq%ABMc)T)Gp_elTM z1=Rgy4t>X@K)rW&DWv!(xwUw(0x8uR&-sYHYJ7@T#gZ>0E&R*Wx2wX-JBxSuqqRiv zeJbHE5u^Io8GCk@@IETak9sIMw1-ER%hzrQzWTJ|Q6{8y@F;bO{vI`v=aAj!N8AoO z&Jo934=}0kI<#_#63QWp`V%64*@<2m;{nR@$sB5Nqe#bzsGU{C*)Ia*;mKssg5meG zzjaIz)t4~1f+hPfq9XaA21QovPQh^Ctv200I}YQ3Lll^9 z?0$du?Fe)P=G=lZ$Ezg<$?v`GBxV1mu=7-iEUx=TW)JppDq~76gpUSuGYGQrSbRx% zq3TL&1S_~1I(ssFQP@Lst?a!mJ!pQekUboeM*jBk0)j&Y{Et{}!<7_UZ;(BI-Ww%o zbCgvF zXe#*6>vA6YvWuSnc-fNSXF}&( zn%&{YoNr9NTJ3vLrPR4(!5#+{inGnUA2pe^r^t`3bgtD^pFCuG$ilN@sa7XuS``nL zHF|QF+;4c~0kf}>P9l0$saJ*iY0i(kI{IeAL~D{t~B#J=C=QvrXj7Mh7I;770=&4*GmOBHIy6+p-y$_Fk4N{nr)t=bX5c7iaZE8(GMWFN7; zQ=9zHbdt>I^o)6aA%3dTu_})?MrQT0Pt3ghW0|MB%$L%0{h3^P!L_b`hLwF>v8ZU_ z;Ll&guLomoe`c4)nGEH(#8Uf_CtV?#hz%-2Rd6@x4i!yigve)FvFn%*kyv3QF%AJ-V|*e@%|(mn31sP{}P^(iISRX-hX!c(e= z8cBT&aa*k>nqYO10>i~XF16RfsbvkXx{S&O%+C!yxBDG8kF5@Vc?$-4dZunVT4c!R z7~5|^1=ZYcdPdlalQiB{`GFB>A;wccAO@b+DNw8eJ-K@fU~L3iPwjP_eYU`8TM@Kq0As>ym{%ZHUs{P z$E>PP^}sV+!>aT|_LC=*lw16M!~2(O+f=>xO#dFq{t*oyTz*gvKgm4GQT+@$Hl{&3m9s1QLUXnSETRIUIdR z8?0vbPLT4Dh_i~Zu5VLa-!|Lm8Vz|CcWi|NCeTQa@3xi4n18Ojubf0p&lEqM?2R<+ z?D&%~EpBDU>YR9c13Vc^pCJHnDj~DQ2wuqo%rz8Nlf4^t7PN$^8bGuY30j9WKv#>C zZ>kCLXH5)1SaULSX_5uDMPG-FLY*7X6CuG#@8W2{5|67izo z@NierXxMDB95&QvVyTZbQ*%6(OUW~m5UbkJ8;u#lkCF?K7#P!Pr@1tIq`roZQTu3Z z?=;VGbM`KvvdOBwIQvT`+W<5w26B-V9@%6cB&2*K4Tu4bGA zx9BgLD={32^6yFX@D93~3e~}^p7v@y>w36(7$R;Gak4XLrhWS?m3W0r0Xx1qRwYjr&`Oz#lpw0Z4-*2XktX)fV0Q})v4sOj0@-n6-DkJs|5IEJ)rF7JoKZ9Xr=6G4MyK&GNs15zg6k4)hyOa+Da-G@@+q~Sb?r# z{cq2e)MlxZ(i=Js&VGk1d3~0xfNIaL5H=3KQrnW>j}-g+Xe<8Zbori0EhiOHHx3mSuGKjI+zm?p5~oGC|~tBc%;1CBpKiAB{3OVlU?!C_MECZaDoKoWNwtJ7x^Q z2na4wPcj4}c5=JBkhbxGyO-TGb?iEhqGr=Bq=9RWKs4oaH)MXdohU!vvDSS z3xkfsSNlB}xhwr8&;-4VQIbqKXFjnm4WxtTmA|_mB~`G0=P;fdgNHX#wPd|AN@PN# zlc13c(N}EUE^OzD*PoxXT~5927X>G5QbyYj)!Tk@@Ok?TWA~=x&@#b0g=unun+X&G zfBp(%g7X291KW}5|1A%PLUxa*><@o|an(L&xA3(?hLhk(U zp$UE~N*|yEvc?bJKQDX38>(I^9;K$6Q}I$BsG%vVH6eKKk-XK8gD{a!pC%-9!~n|W zBOf?#xR7hxPe_L$IEnfucTk4uoLwwY9@ITxQ)^dBtZTbet&}M=D(VPV zl=K^|B{C?5k*-t?>lWuq{o&A3xqw$*V5u z6Ggarjju@XtwZdvTO!>!9nxwz51L;E_V(Cf8>g_7ZNCsUL9&t4sLRFAVS{MfFrEh; zM0fDD@Kh_AX1jyE%wr~TD%QJai?BfNCTgbNsg+5UIC1l?fs+JG=AdR>Cb%=wv7b+; z3-_$VQioztN`6!sTM%G8fZryHNa+XSJ$kr?18xf{jONj8u0Q&&JVx1fARoeJGRGY? z(rT<}v15)Ju4KHxkApC|kglLP%38p(q6)U8oG79`4X&~KG*aHA!5?5P(~wG!k&q;9 zWacp`@YYic>o$-@OzYkAC!n09d&khV7~W39Aw$Ua7RvSXj7utFAFAdr(4eTf<==Qd z{bsuTgb{q5u`R1z&mrBlr15a4fTMeUo)dG3k4_d$hKi3}YYWB4dKU0^BR)n2JDyj@ zP<)IE0zM@a)}KePs{)R?Da(}Ij3wkN6!v<1kp3YWOrZ{ozaj;Dk?Rnb7)kGg^pJcq z`#1L5-dw`KeLS0!0BxOy{_zi(si#RTV9tvC1==4$8_U=6bTN}3fT z3mEF|JVV|1j~J@{Nio!PWy~?u8+V+J96vofjGwfu zCe9t?=Nu0|@`Q>MN92pl^KdM627|hw>oRLhT)|B+N@2H>254PN-HI-?K#a88a=tpe zoNPbSoZ_wO=kpW1`o6Ix){3_z(j-oL)F&~^ENm8fCPg&B<+iZKQkSB;1xtQ6M6y21 zU@yra2oGs*zq=$HgAEtn`3nrdby~7;VEh|2C1wp~ky(jXRKnlhQnMqk)bRifdjw$? zSQ@{TXWGSS6of@JTHVY;rvavU_r`z1yT>7&r54IE;B5pvz;hYTcXph9|G&I43SdA*lc{RMkGLc2It39DwCoq}t6AgBu$ z*IcGfX!P~XIhnRx?=V@#o2hU9ycS^Z*zVag`zbYu+A+_rUMTZ!WFhjCSTvUUw~$}H zE`Fis{M&?K{6dc@1 zkKRe09n6$q-hb!rVCLs{DtqTOro?N!NZ;QHkYGNUvima)@6MPUAPniNI@ud?PGx~u zlpyuYTLwSXF*helUz`)4tHEpT#z*fh(Th{HlNn6j-p4u^lCS_% zjRgN|Oxww{drYT652vdRVtTH^+?bOw4?{yRHSszW(^(EvDN!^_4UZz%9-*u=Ym!jV zR4yrG8q6LLYqSR(tpiY+`jop=RlHWXSE&jbPs({t=UL__1I5hbC^~azLZ|ZNCY$^;8Eq|PeUbIln@Nzqoea~jn ze=lanj9f+MO#YoQxfB4gyOv10rWcuQ7MZe0fcWE8mQDS6C2`^x@|LdKKfNR&wC}a= zVAt9qLicEOJ(slMZ5F&j_lD`ZB5xf+#Tid*l<|BG^GQ2gGXe>YaLaT~2j6Xb;GL;+ zrkbkg;+g)vhR}*x_+neRg(#HNrl-M1($?#qLNbJ`nP5w_{`wHRZVL$Z9oL|WcdVJC zlxJR)3!F3>#YC%@8!MqwfxXRC4y_w}QPf|eR?k6k4EGP|T@_31OFpCbg}gv-_2T~x zy=NBCd-2fvO&m^dC-w657P29d{w&_}^ge}*j^0zCvZMEuy`lHgL3(#>Sh*gG|3iA8 zy?O|}KVL|1b+8=Z?e>qwXwTq z>TYJI52=?UP}Xsx!%IMg4Qk~q#okFHLZYf6Bi0;j$ z1Q&VDRhi~8y%n$X&aU*%p6)fza>GQXd8Q?AZgJ^VD%pf}$b1Y4$H9E*?n(4rdhE=H zhj7qxA!`yM(>awCQ}Ag59x^XaWb|oVl};56pzC_8pMHJM_1@}Lua9t#hw zrR|gNBfi^gG!XQEqFt>~g)pp-+gTF~OC(t`g)JL4Yi3CEdFRvI)`G>Wz2-`~Im390m+W7(HOPpU{duVWxj`-a`u5O1%($tfnyx$DA^RmV4azsku(jxg z7T%@`VemWh>W6uQ7qfLL(k)fk6|&C;@8Wt&mX$f697lhWZ&?Qm+7iuZvm@A%3} z#aFs_*{~jPud-o@uEO_QKcm9$z3J%j;E>9`vXvHHWa^h2svAr}(s&YUv{x;!lcIw9 zp|8nTO%?KGidJoSm(!2wn#c2;>Ms#%AW-EJR8D%zeB&VDADwGWKwva@aT)mhYlu%l z`)AJ~43EIldOyGh%}#jWWw-G<$PZzB*L#ZZRQ&gO9gJ6DcRGG~4}J+|Qdp1PvR?r@ z{!XpgpiEKr99R;<=PY%D>;+k6{R*vbg814X2ND?#4pbF>2JwiD?(bY&<{H)37S7|; zPbimNL+F@q;kYBHk3$srT2ThI_coxm3TjfK#*nPoY3!()hPu#jcD(SnjvbXHmbwD* z97>vdq{29MTt6bmj@_eS#|$+W=9hqZ_EdVXuo>a%X#T)X02Aj+>~L4f60>8@mo?I{ zp>iyTDZ_plHlt{0ReA5HRAnB1!<4Sj)7Z;IILMC@n;W_&i!1rdK1gFK%c3D&_CEye zxDeW}9Mx1*u$YK~qO&o<^hGSqY#(Prh)tu#_a*hcZM7R>cYRd5wSTm4!$!K~*Xj1H zMbNX2B8O;B>AG$3un5x?Au>3<&^Sbt5KY>zqa_Oi2xrCX{Jf%h=K?@~B z;u;%GWW!LM0pM{ddH92~uo_r^9q`G$zsm{SuQ z(Go>Czq=C7@jEr{coQajjZ?F;SZV@fRI!?X7U>0tlXX2g_-6{f4D86pCteVImO%eR zvP`4xy7wCKxGaJ0x5+E-{{G@teUx42-yj2+H=)JEo(rawxZky~TIxO^v z4ybSa`2&!-Lt=~>XzH6ZnbR!Ai`>;PhpXsb@Uq@}V#&#*N|&ri*D3oDZWMWmWIE}% za)|mVZWJd<+_yEWgac3$A;fvf11EWuo<4f(&opGBm@bWN?HH4SleP=B2On-ua4Ca_){_ zEVn4uGD`|qemeGLFO||F;XV`MHl={!<_{KS47Z1hT4E$A^7jw+VDCx6G}nwj*23A_ z#el|2pM+D}=LT{5=_lcIJeD=J(z*hi-ud@@^$n-XIJV_4ktFhk(`7do;MDPjP!Mbl zD_2th=-0yl9SI;6wzMEk*RV9BNh8biXHFSrNgQT*-iLTwvdJyfWZOAPC>!K!ClAXx z%m(=k@k4Wd8xhfc-UYS2=TBI1BuzE%4eLbr!esF717-mM@3@+g=dAGAuIIaVd~3dx z?DfnSHaFK~=J)WSztD2Rpi+sErZSiRTk~7O)Y$F5yYX$s3!Cpc+uh6;N0nl`dwG@e zyz=fVt2ezJn|}$Nck_$b?Pg-no5J(Ebbu-8ibqsV&s2VrA54v%w$Yz2Nj-ADb&Fd~ zqe@4*7*|c3x_=z>c?7{C1CQUMDryVl=Ve;xbR4J2Lm1y}Bp7NoI}?r3_VzyvLZU>K z>gwMufu`L$v!zjXI!5uD_8Ekw1Wt9&8w>x7*-iS2;&jP_fY6q*O22bC$t>SehvT(Y zooiJcW@+O@scUVU(zS+sZ+l%Z-x#~28GD9R%VL~C%=rptwsI3wO?vFzlq0*8Q8l#e=9y^i<+8+OqRaGrkjEF2rgMb)K1nSr$HJRd0Hon+&dZ6DX&-*byA;*FP8^S!9 zPUX>Grc){PH*c+|dQok!u9uD!ZQeMX;j-7s%D+AI- z=*_=2WQs_9nJ5g?SIeLydRVi$8!m=&n+UW_EkSCi#A(kmXh1`D0#ScbxBD~`T^jG? zlTmVNC(1fv*lyh=TMcu*~VdbdXJfMA;oy3qn!qv03jm!37UPIO#G3MRPM`oV*i+{X{^Ytf= zg7242cLW6pt(xl}!l9lHlR#Oh^RG32gzdF{N!=w6ho}n7zBGE~-RtZ82pb~4L{(23 zL3z9)T^f)%u?43BgSWcNkAi>1aO}&f#Y4BZ9l-0v2K23MgGc2>;VRbXr6y1tEooRzZD+@TY*b1#0ttf9F0knFMg%-FM$N?Ps3* zJon$Z_nvd^x#ymHu7mAIgc~@X?=2naLgT!p<{-P!ZkbMLhIO1tjUam?V zd`Zc%pnJxZL07A_1K(2{^Yovr9lv;853TVlYr}zyKs5(DY@vlaYji0|3&$p|W=pI6 zV>IDWTGHTXxcvzAzw0TpbJTc7$P_FyOx>LPfV-xM$*qE<;sW*0qVl_Hy}u*Xb3P!2 zk36t{AWR=;6Xj~+`>u1lNl+nxckxARFDf?`b|}vuU&pS-0W-k?Lq{vK{+G zEDh`zddm;wyLSpfxX^sHisu4*4$iDaQxJ8wWZaby%(I%9@)%Pur`qM5_nc1}ITT)? zc?Ife;k`mohjE6TKAswN2{hUgTyIZ_Z7mB-R3*~sXKV3HSy7`oBeZ(4)J{ou`Dq}*o%2<$1y^R>yPs8uywZyDl zy8<@}Rp<*{Q2rVBjPsBx&`n0;ZAPs0*XJGp>+3f^6s4|Hs@#ab6!E`;V3Ru$B^CCS zh#z9~kc8t!ku;}C|J$UYzO$@P8_KBvg5+ zdnnpT9f3cah)m_~fSI zsSS^Noib;qyqPKwDwxhX;4JDBUkjEkAd<@qQ*Y|FPX3$Q=_ zoGT>WedG`^!Bn&Neho3fb&U8U?xY=~6YmZG%FZF5@MY|!526qfs^*A^aS)m=h*}?f z*QOni?s!3EQo2DoxH!37sq?axmu}-V<7y6P{@l$Ib%NC8AXJi@T9jsNl;+23yF=ij zr2kEMnq3_5BzGr2aG={LvWTf(^D=5MIz8%_9L`|!`zbJ+++(iDn{&PwvjB}ZxI+Z>=f3QJNlma$XH-BIgC%=ORQ z-|$HLUl{u7newCiHwV`aDLymqdZuvs2Ar-6G8Y%*!+iO7LR6GLy)^R`d8KX%sNzOC z84+>z_hLwL4X;x?x;oWK`3~?7tL3yhIHinSre|V}JZ7gtZD_Y@zINp&6IQl&*Fl-D zmw9)cS?b+&(THSY*-R9OA+*|3pnw1MW$|ULrOT#s)}@TKeoOnyj9hDG=E#!%J23u| zDYoX$T$#AQi~T`1wJ+Ry|`B|)F71XD=h z7*oXmqWhAZi^uzGJE%HO-8@@)g~PCZbKhgPYU#-=_Mz3R!gSm#p6ADeNwdKuTQpzKjW$e?aeLcdvdP-;cQd+kxY6SZHXVqEv^hYYTmf? z%wUt|;cR0CzdS1G0}k?5xkt4=W*`ZmLC7D~V^wVAu2KwtPy88!y zYvY+(Kbxr9Iqp+Un|7O;YpXllvuc&QXr;2lJuB9fS$z4}k@k$QVvCgYv0YPHR0GJh zuVRNyRl8jJF+1I}Zi{=?_PA%wDp%kCtR9AOEcN8Z3Fl+AcMlsh;hER@Lx@C>^*FQ~ zc;Y50Ps|x9sHvEpg&3)piepNmv!z1fnFNMs3qj+G4;}Hm`3@Ll|Y@Kj+mPeTo=t0G((eRCv$_*TOQu)>41um<4r9n8WO^T&W;UEyk^D4UeJOk;_O<^O$HNq% z=4bIOnA$K=ZkXW*grYOEkhzJ<{ZAFjXS_8YQ8(Gh>i(#4KRZ>A&pmcn)Jby~#_>z} zDIRI!MCN1p{5MCOl7@^n@3M!{=)1u{x+m-gLE0jXu#Io>!%Q?|VlpUj*937Yl&)W2 zfZuifONDpW-?Pb;wDYn@?M`hR0S9Ivz0S+Uq`@?mCK#gUd)`Kj9PNbsIR;O)^KR8S zo?=)aP0hQy<-pA^Z7eC%M%PRK1w>~wrc!e=UiVh~fp>O#5A9;OCd}hYC-=dYn43`l zMIXm7du7X95?)9-yrz5Zp^g%w_Ik~Tf8i{LD{CpUj#+eS``xMM|H}HO{dVe9S8DQU zWQ)PM=OkY!$8BKB$CW^2_l^YrWC_p>X`UG@Wx7g1DQC5Z6Qe}UBmyvV|1Yq}U_%<- zCyAQ{!pBIU78~Pel?z8}`&gU^P!?(i9pT2o8t4A{hB|FLmkP-h3+q_zu)bN4IlG49 z3l1CG6c4?;&qbeI9M=)Wy?mBsJzra0{Eu}R~lM`w2I8`u<1A)034W6|6`E3C*=J`fJ z{@XA+e|=V${@kAK*MgP`{QaH7Zq>`WVKx@Da=TUXbHV&_|CP0W92vZSck^c|N|VPS zzQt<$D~smq*bjC$k0q)~GTk%nuLkH8aFPG(_J>TL+do1VU*SU?MqnS_dH>Bi)mToA zK}%)OR!+Ug;zs+iwSOA9yLo&?X*a`Hg8Pdrc(DE*vt)PkBJx4 zfNHQdcI@QphQAuIGTd>m>BWXzavBAGDmc=A)e1bGtP^NOd2RoprvE9wW_NP~ACJky zUoQB|D69d#Z)JH?UZg$Urr%0!D36$0d7i1cg=l_#OU9sM9te-iboem?#CzM&cU$Ud zD}7`+5xKpLTYh}H-?wdGpvd36FG*$p47w`uvreo!(*;Q zlqm={do!$VFkVW@9sLJuki!79AfM{~?8PssB96AGUc}MoMMBT|A^7WNvcBN6n^1ak zokESjzJJspK4|Q3RklmMBV?~3V-Sp2VPB;a-Fhh z4J*Y9B@so^>VZ+KOu?!{($yMRSc$PGxd=NLb01fufYZ+MrAz$2Al*nY(qxom)6y~M zPpXdeL|(81^(_ItTfKOL+G>NEZ(e`TAU_9J{(w&_$tCS^f7XUzT6wT!0XeoUe9BMs zaG&Z^J1*?$J!JKjU!AAT*2I(BE_`yw!cE&Qd@6X*nwZ$cW!{O~yiPIU;D#TIM-P0WdX}spdos4PX&R~heqGN3b z*+wR@ML6^OZQ#tTp8B4(zaQz(x<9zakYQ``N;+84+7u|&6A~5P6+0k=AaQ5rYk#)kGkQzhX60C~QYT)dOxYG^?rhJJ za!_jGzKBC@cA*cFKkdIOcu?z~Or>odXC@z=+PN$I6kRiVLwyhO(}z>f?_wa&exd!) z+=)~i@$0i+;6#)^u`GobmUZpBa$^)lHKI!g)e!#R?i$F`S0%k5`uY=7`4X z2wiUG*1Vzgblpbq_C z(bvyd??Yc@L+PuQVvk*-E-J$DU$7fDguVo6m(0{;z$)7R*TzBEt13w@nF13J=WF{y50VQKr}{U5>i3PJc(X8J(GGnX6& z;kO$fO#UGy(S#KWJ}TWcFL?KejnAEa^ZtmwbN_bKu=!E5<3!41D{Q(REA=ZCj2)u5 zZvk)hFK5llo1j*Y)$H^CgNHTFKRhVaxL;Wdx2y^#i8Eo4Q*~!~?;*D_eQ41;2J?t9 z&$0=|^B*9cx=G67P1~gfm@dALNBh=aRXt4Vs@=xH-2$&y{Yi$i8CLA2gAYM4jwq1( z60T!mVJ#5)5AR|Jpy3Y1Tykc9MqXpZ-EZtbLUcCyOo3;hAkmJI_-ZsKYjsRn`HSqs z%YF*4uoB5sW%Kb*kXEY#<3)l-f*g)G1af)WuE&s3JiTKxW zc=}fh9+fy0o~#+C@|lwWZF=w**{ZmE{UZKuM>^cuNu@GaWNbnQYe)tMU~p{G=YgXS z*~Y|d5m8|r4yOcn(1(T5KLvKAw0>*mR!IPR?hsOC=9hMBz!wkvNyC21UbJJ!Ot7d+ zN2{BIloA^hgA-fwPz_2Lei~&qV$@^x1GxcawqT_u_RPtgL5I@77NlMjAyuQ-A=0yU z#=q+0@C*~zXiIJVZZu?H^8f0L`w_Nk%gS|IPkws0BTC-wSq^~M^j=C|$4dVS*2V+I z8lb`qOwEn{rS~{LI>%Zr<9kt>FKvha^oHMO6UjthpxptquD{*-nSB#M3{|BAIz2G6 zvCNqRskcg#7yA#deSRcpWBNtzs@V8^-ox?K*Koc3zg5eA<3->zP5iddUcrB#n zI#P}amdrPh+eZgxvMAtBKqU|?8EfA;Nke7fO3sleDp1svitLg+(J^xI;PgtkBAc{; zO0D7P+~G%f%;F8|S9Lt5V|jSThbOwS(vMLVyBWq!P1fcrW$mg>R~=4pe$WshFE}5M z;QZIMe_&x*ClOhG5lu5t!xAQ%-zFkIe_D~FR5)u)$ zk&@p)8c93J8XkEB^udcps+=f0dSZTBVgsXAJHah{?QkqqT{*!iGlLt1r9jdd0)KEsn`_legElnr1&9LVMiXTkxolO^g626Z98(mS9PYQu-+muQK&Ffm^xZxwRi zg4zlu>!*=j$z2uE^AZz&;8JDfy2UKGpd2p4lFNxc4|7RpTUn_%Vd<-?+rR*%%12;4 zH>iS3?`OCw3fQM*XaS5ve=RUX?tn3eykp-12G^?*4f7igfI7;%9RQX@%Dh5l2bTPxj$U>?MwMA3Dgq*KBkSPj z*25Uk|45KpJaI<+%qt%%5abbD9!H7>*LR(AtlJgbU`Y8aF5mKWdyFe0xJI)D+uLrP z6>r$$U2z;)cy`X<+3{ejpg=y2$h`f~d=XwJw-^A)9II_MzsZjZA%Z2-3HxFrGMRD- z5Mlf!N>eE3vV1x1-=^Q|;Be_@w5uMqGdVACLi&R>$`uLeUgv8{Q$)|nW-cT-$QHn# zM4|IJN4&4*Hj}O(PeOj_#Rz|pWBOlsO8+k5?a%DI=FU@z#z^eW0o!wepQP9DogN+w z#~_rwhZHt3_7mLN;w+ zVl>_5m~O>;%_I!0?Ww7?6(i`_y4(R&X8h3KWlZT|TXzsOB#$Uvd1A(`EThcrzw<+jX@<&L44(d$5a=7(5# z_LKVu$_$|#dNpiu%XlySGYKe~7`}sbK@v2|Gp>>C^1G#PM(fS$S)dp-Ry6%q#!P zOW;nFq@5w-Qz*Ae*a#aKHQy=y=_KXN3)m#(yj?UuTF*b}q|wxd@n@~?3R=n~A-qZ@ zZfh;|(ik}%Lnh%O%oimuRC&v!*367c)8c_3R&SkG9Zfp_Sdm%D=L3^?L)Ou41}j_Y{pCwTIgeW~-;aH1%>#>g@q8eN2e6zLHv4K9JlA?s&V)N=~jULa!o}TikllfC;l2R;@Aam&&n@gz*wdSQw z18jt#!C$;VCE7*8EE3&Ye!UpQ={O*9bGxEJhW4CBJk^vUD08 z*|3pmHOjAbljZ+kwx@G=dzzR3AG9aG^cvQlHs-T;w#VP-KaqN=GQD+vMbL2-gHX0a zD$#~@3+!&D5zrUC725=$SrCjz`2G_xQCe~>sdTle?kz3cM+%bvR@zzoCo_Uo$uCaO zMdwd>OQlZ*Yg(A##|nEg%?AwZ+0FWjm#Gbpd6VD7yD#w*>Mr>V7?j@>(WeK6D%leK zTF&{N@~nL|rp1EGnaYm5@8e(kKKo{So*(`6P$+dT2T0^X0Tf<>XEzX(Ug(yFnRm z>y7Thr18r(Jv7A#xP+#z6Zng4OtR`5$wf{hC z?}_EvnDDPe`#+DcpF~~kf1g<4#L_Xm*ZJV##ppG>+dEC?<8Op%%%l|W_GB1K?}nhs<3~!ULBv>bq^jNQKa-8wYAdz2hWcI)&M1$3=R+8?S%g39 z$8PDLl-~~`b8Qf-0D^&0%Z!-WC~5yzR6hc8YGX~%9LD@9FHK-e$LrLp7?_QTe%PS! z4@k;WQ+0MqIpZ?mPmytQE5K+hYe+7pWW2fkd!PZ;#jU#Te09n1q5dAL)W*Wxri>UD zbCgRX?BPTFKJhK6*5=5m%>Nf+L(@OrC`& z?bts|lGd#MFowmg11_2462i8W8x@fhY7Zx$1LT_G4mFVT(*hl-=`!laaP&3%-O9UY zr)qG%%rCc253bQnhe~a#0Fk<^{|Nl!b0MTHi!T1GlUx5jP&BTl;c!QLDfK(SiUpKk z|13(4qv>LtE;JKBmx+LRk91a2a1^UDt5IxJqspw}c{B)E20&j+L!-?FpV3D3nK*jaD9AVetae{Oq47$IV2X+9n;ud2*6Y2gdtwR~)3`P~wpdoQcC z`znZ(%Hd^T3ht=pjbSwjHJGFw935cPhEfpN=pdT?P;c{U>*{x-i0JnU3QuoIhhkDy zlo3>}DSa_@ZqaTI!t@Y*D5wM@NUjBurWYd;5I!g(98R91iXr=^PvE+F@dhRycMAEAH2SsX zDejW54ACz;Qb_I;{QkqmEhr|1d{c(d!%@Q_kGv*C{Z3i7OcrPx4A8g(G>sHN{|Xp@ z&yR-owRX2T+w$BZt2!e0)tyrOV2N%3Osvfjn3J50RT6?_X$n7dM?$Y-CpT}q;QnLUJJ#9FFgd67%I`*=?8&CG5OA|*Wmiti@@{M;>lvDid1aw&iHka(RZcj*=KIcsGper=UalafIV_VI2HUpb z@Ce_ssX6qZj*MngT3qW-{bPqn^Qse8+`?8FX$6+vx$??ysw7X#^Os}`*XCAQgAu<_O(H38$HI$uj-Z+q<|VvtnzpGFCsww)qlDmKcUFWjQcAIWCI!xVtY0Gpu-s9-Jw@WAZ`B= zg^i)lQV+-d#9m&e4`%2%y>Z-NZ0j2Jj6K{R~de(0pv>--)sXo~BC&e{%wtXxGhrmqlMlhLFs<&ni8K!@j$Rnnu+ zy)91z_F-6oM=PmlSc?i&A!Hm$a`?w2hv_^V-0+k=;d=cxiphSCpJI2qan?fII;p!Mg!FUI5H7uQRRJ z9)7xbZ}d9b^}fcvpFsTA^u9{(dHTTomQIFXnW-a_pW)<=MyC{;vbXSK1 zldyA)U#HK&D;?EFaH@Lo9|br!OGH^Bz%`=@@Z|--Pg8U8H zr&-lERjIeRDZAR=Lk(l>h%rl{U2LTecq{O@Kj6RGKbJL63{beRD*}ObTHQL6IRhK; zPsU&m)_38A2$mF0knnVIwYTI9!m8`b)tQ-f@nCW+IJ^{&6_kIEsRSPAtvE}75z37D z3&56i{0qb9H=Iz;t`0G|%RpzxuWd+AuVl<&hU%lJai&B8fY?jwZN zeo3UR{mYf!wf|!gOi}x75u9(ox8hf(KV|cJE``M@?7iE5ytQ2e5`K~CK;y7fq#d>W zSA^B}X|#QOQQIe~?F-a)d5N~RPmJ20u(nrt%M-*{+W{hlcG*rG5WZC5KM^^%i`{PU zK{ocB9OX-Q3H&s77$MhR-ESaF=Sm0PrRmGP#vn!gS&V^KE+QS}zhC9ctp)zo7$=QL zo}cAwYrlrmg5M`eK7p|;?I&yf0V!Zkk5;R%bv$I%s6lr1^~L%c;Wao(+7)m~I=M{; z%Bn;J2U1mpZ?e2*M-ho6d3ay1R0MAy(w=Ym2BoA(GAewd_&R?l9bokL`?c+?tk`HOeR>+*EOLR zDd_87Y=3pnMhV{3Hck^dBC^22krod=j#bsZ1Co2^1Y`z|b^1OAZDRe);f3<<#FB;A zu~3YuNdx|UXmIG+jbaGKv z70o>36kw|(j#ZfaQq~lsgn?0!nqJeR>|Nv>?QWi_y$3`+%f*xwpW1t%9j;5B!fhv> zc?v*EYfFnJi*$2iC6ci}N(qA$CI^-1=S}#|lNn4S{1slyGI zYp{Ynd+Luh? z6elTCioyIHRV6x5C>wd93;LlY(tlkM_B@;G8NTO-oFg@Nc2Xms$Hl?J1ny5iIOM8{dCu zs)w@}mf#d6s0ylY=(r4t;(ZM#BT*dBHz~{CYJWONTpRUZpxhc@?w3Y-O)cd7cUn?- zHr>iEU^AYwX_G+lCXGU%07qZ7=GFL?D3>LEV`5EdHnB_@x@-6eZ$X%|ruuKGvBD?e zRn*|ba@9$b!*!8S&?E}UVq{L592PMH*~F6s`P8dNkY2zyI%UN=4M3s;hI`QN#&SmF z+w>A<=)ts(;Of~Vf-+s|@bmCS_2chhM1AQw#BE!+5zGILnfC2=P^vGnN`tU{^ESII zA+cfGg&TG(?A~_aMoiU%Sy;+<`0F!?o&K!OzL7nezhMg9B^@Ot|N7kKJquq5X4MpO zxb}3b_C!Zm{Rda|KT~y(SdBN9Nx`)3LE=g5*^bN1da~hlFZFe`WZF(Yv0eK=2M_Fd z&0OuUyOiSgyD8wr&I0~2Tpe^x7{lKOoOYwv`97%AyDPCKIJ+*pL{p6ZvZhvcA?XoZ zNP?gXN$KN4nws>tY)LC21|n;AU;30aOB)v&U&t^q3T38`VOg7gHfw5jmuh+x=Oxw! zv&KZLOpv)em{rFk9=?3%{sB5WGiAKV&v4&gT}nd+*!lOfL88)si*dR-u?F)Fn&h14 z%i`)EglA_zN!PKplsb+#5Pp+?{Y=Jk&l?g`{_;Lj*t=@Jp%zGV24h7t0SzzO-$WNM zj0Y6zmgMComznsXx?1HBIfjAcQ5VdT`9p1lM>^(t^*ooNGPqg@NNh!LwdjKot-F>- zJeakbM=acQy^Rfis`iL*t$#8Ps-tOK=Wm6k*Jz*w)2uZG$;4!UeLLX4i8Uq!gs<{q zyxpP>lLw5%8vEel2e34ulf$R)fVcAWUgFuCKThG+&#yRw?6CoIbeT;o*IWIwFt}{u zS{Jk09!ByCF%|;$dcY*8wVn~4h2wr&y+N3JM$okMT`!UX8xtK~=L8TvH6B*^IkIvK zVyRS?pHwl8<=$P>)~t@h?LMk-U|;hQrRo>Hx}=aaUG zb)Jb8ZZNG9mLk?^-Cmhm8>9VVpy~O7%zpEXyI`H@KazxqS#k{QSjfC*xA=QC=~RW5F;<0fYEGD_H}h=$ z%6|s7+(rC!ZF?naO;TTGty^74-C&_ahaPT-vNmq^*+$ca)KG=?Bx(^ju+cbISevK~ z+E=GGmF>1d$8y@JmNjC6v#8&|T1tG@q5n2v@viX6-?>h{oF$Rkc{2sNcG`YPlVQ`x zs419%=Rww_1pQf0`ib7$Xv!PpZ-q9v*<)S>qdhAc?fl%4IVn~cYd6Xr#%|-`LNgTd z(tGJf*D>@P7ZXb6FneR?fq0vGIkG=q03>~hE@p)K%`ghajfp`sf%l`eskI~QOxT7@ zqE`(5fff=oD~SDP5>N7oyIH`^3d{u0ZGMlrAg!$7Av>&_IzP)AFE>L#Cbp~Zvx%L0 zt9(7z)TG%`Ue zUG6B7xVEa1VBNGQw@+K;npl{?nDR2srJ9A9iDg17TSm=7y}3nzE$IVx0PEiJBJ9S^ z{J%!-%-HP1*|*$hcni+%(o$vKk5JGjp3Ek06OhPNJ1$(ky?s^RIkKt=&mlILwKIwh zrqyBL_iEOWQ-I)sR(j60 zEts~f&uoEgN|jKMxE2nzfVlw43$YDdTCi|Ak9e3e*-g$0ze9QMlpuZMW&;?8tgi~J zAGTh+sw8;_ouyx{J8h?Gd5+urYZ9`>N!<#vOI&Wrt*4b;38N;$Ex z;TtU93sR?(LUZ#-=cR4~G+ME1kKpgz#e|r9%qV6);6+$@d?>6mbpIrH=-LDq`QNu` z4IR!bx1Q?^RULGYkpvLT>diAI!H;Zb%;?&%rq89vH|xSRxe+2yH{oPNy25)c`$QJj zm*m_|PDb`m+oOs)FD>f4YjY35TwQw}QF{{G5s9J^UYi@~JZ!~xAP7-#-T!*^V`ruUFXp+U&JnAm(f zb=$FUbxE?ZNM;0c)CKvj5ag7TH}JzPYeC&$a+K5N28nWiEDE^8qBd_E+U8y?n!+D{ zKy4l*g4}aROG9|8VcW0H7q$sq1cu|Pxz`{E`fIRl5_)Ml%@gA+G|~0KyEfFVT^QgS zknW4dW0hb#K(Mt7w%n%}QzzNxngB4;G^Kwlo+FXbOme6?WR%kDMv4^QXii zG(mm7I)$eMJe&!cQe>!WA*8T5Su=IBq)TKGs6X2+qWNn2s2T%LWekk!FioF~>(7gJ zTl1Bir}%t&21oV|`ZO@=HkW5$)B*xVf-7bKedheqfl)WRPi&|xl9pp;X5PrsNF^0` zl+tKKX>CT4I9=>=&nZkh3ZGCN9EdZ0O_?8{#hK=pIf*Nc52o+xBqe@?#8k8!^*bp~Y&jOupEM+^hon3Vq+l)zstzkMTnHCy2imy5Su zNbWCJ{8p`N8hAjhr|Q<6+^ z;~o5=S6#a{SMk%14(e)Nn>lF&H+hxx09i8iOxfsl$dy{G47T(4)2yBAyiU)xAjzHv zNoK1%!sV4ADEh7Ie-gluk%83;?HCbmkFpHE3D`--y@D;@vFN?YPeOJYOIjslUCdp zQw>%c3>+hfnyMvetl&y z?(TTTDz4R_nyS6fQAtBMOwSJV(!O}5p##&lxnuYNT{YNo7fglHSbcpDMU&Cn;tirl zw+;F~8=8ZL4$X32zT8sff^RLKKZP2Mr-J+OovnD|_6tqV31_UcSo3$2)FzrX0I|!4B0S91Lcx zR9gk0@Eo(#<*VyjX79DT0(%y`as7|#`S+V-oh3BL8zx8l>4A(QAaG8#I_l0zF+8Xb zg%u5@?{5(OKSQEn^gZIFJQ97HDQ6IgT8+MML!Y*`S2_BgOisx5Jg-vVt>U>knG;UA;l;q5{3Tu0DYgS67Q(KNW@VNdlcC+AoV}+mmhWbN#6!;yHw2h_=eC z3qTXUsY0wPw=kmDzL7f%6G#|MAh~-Hmh<*(3u+gPNFMcW^Gt3f$@)faDddl)qL$ou zit@iy4Xib^p*-AWf?#_kAIgL8N~A{PaX@f|RzoS7XVQP>zb486uGfb5xlEr3C?Wl9 zV6JoKABCmis0r69J~B_<=st& z5lr!O{gd{2cem_sSWjqw`=1Ks7t${y{iuNCxaf@gC+!Vd_BE_0S9^Z}UcvMCrw5!k z$;$yJmMLG>uqioe8#)0MzwOMu+Zy*Ztlf4d#dCVc^eLy$AZ2-wnQK86KHWM`jpb%$M-h8zHIV9dng;KC_O7nrO%9;OopSphxmU2Egpel&oVqU*PpBg zpR>OIkiyuw@sS2l3sHc~RA15X3@&(2h?P-WEVVXHT~GLv_qD%7?;3oPmq}VlmTHEj zDl=v=KBh(&D_qJe&Neu-rZynz6eiR_P4)UL{F~#LVDqg2hXzs z1yfq~wZHba%KtCZ7x#zj32z&&TZJ!R3XOj)k11|{S{?yDeNikM73D2@cMu-4%}weP1;!zHQk1 zs$uEdhP{_;9a`R&VfotxN>Tk|hrMqZR$k+<_g%x%uNwO9>u1s|6L-`sF(&*77(sz!M;AzuQ1Bn9|JPr1;|BIqR%{=Tq>3)Z3VpJ)$5Nip8!) zL*Fnt=3OZv9Jg#pyWdWYuWO$pEq?o%srj)(OfAi7BIQgEXeKkjg54(^RN8)ea2OV9 z$;+*%E@bkC6JnR28l0eFKB;1kvSN-|wok_k5YF#5yP|7=gbHpB3Qa{PhK{0fm5)RQ{Hvv;UnF8^QPN*vLA0v>r^Dt8@qd54q>9N^tpCPppwusv zpl#%sm)4RLN-@M+%&x}3<(Y2}r1pQo<+~C5XgK1m;xY zMkLPjNNmO8{+s?~F>mP;6yfig>tB56+_kTkdAIMK>t9yx-OU-cH_^xYm&Gqnzw2ae=ru0LU}|BZ@>SF+!92Oqi77HEmP_;99Z?49qCMh9T3 zH#XID%=J$`dSlZ^xIATJ(??m!f9#fxG-YGc$H#AMI_BRtHhtpT@PhBe;+Gyo3t+v= zVZAtbrUX_w{iBRtncB+xdI#wZxzH_yqiOD;8msWKLmyJN=cM0(S7-^6!&YpdOZbFK zXR<{LCqP!O=Cpl6vGqMbThZ-WQ8t(?zn%r2FQQigp0vTkyDCCgsO>WB`I>~wdOtV+ zez1E#E&qO;d!L+tpWxm$9XN_AD?^bD+T{kAAF49puCW$ zk7}SO;JTfdO6imSj6iDN8Lv-;__}w->r)}V=AH5SREQt*&Uk$)#E*Svygo(ogYvqg zCT=}wRtAno$^I$mGWy$^oCA4j5iAvAoc`jFEX$I0 zK}ygJ&pj*$Y0)TsSL)E-kOepAoNREZFXc{};;#V!1oR*P>ZYLujS@5z*5A$e;mH)9 z9||#LVpl#)KFi0)-Xs2u)3?3C8mJM2&N{@nIho7G%dQjaEtGuY!)a%5`Ai%?BaScf zZ7f(YI;g;-yAHj`YI5MTs_3}Ls{r0-M@_cFsz^+~h*STKEYez%g+x&n`7Wr-Ts&PJ zppH<}rL8&wTj1d2c??4<@Md|!$z-4@${+sZbTX3$Kn@=q z!co!T%G8EN&4WgNq^f1A!plU4|bJ2cu+94jUfy3lJA}mBroX^yMg=JFz`i8U6 z3~WtcxF&VYnE)7Isbk|(G-2zD{*0dYx?wAh=1U>k%~!?Ky}k@azoT%?dWC46K4B<| z3fGsxXfS?QG+zqQabAMYiU;|Q4$Juf(Dvr{5(=k4WA08_K87KuqIshVy**=ZyMRY; z%Q<2Zr2ZVeEwZ;=QOY(K7rmX!TV&sQMhB?HcChz7_dJm(C|EPVdPw_PYR~=9jkkAq z#oW|eSe~u~enR_`llU!79*8(uiqBr}?&*i}0oC#^NZ`)k^Ip}hK~2U9)~p%Pz7^zj z%dXRBWZJ4E5LAjlG#m1ajX};6kvxSRA3b+`aoofx?q1^jbyh9H^%;)iblJ>QB>&G% zU3Pel?dV!cP963C79iqg-Qe`Oc4KuO9^DOCQk37jdxo_q`T0v~2ix&|*N)_Ot1vgSzu=HAfhv0{O;iIAMQtc{n;PMBn0F7j0 zFL&eMgDg%6lKKDL%6aJ)#I>+J3tB7{b0UxF&}V!u|3zr?@y~(` zOS_0?&*u;xM$iMBjOB!%C-;qw2!v#I`{oPWeoA(vzLFe0bod~HzpX6u9AL$o#! zp46P;CN4o0trfI*c#l1OZV9;$uarfi9EU&@Z+7buKzgI|2|7U%FW;(O`z#nR$>txSGI?-{QBclzk2jO+L}x%wxf$i{Cy< z-{$MvL)~Z7n0}mpyYXH8cBSI}B=By!w@2W`)k%PNmBh5gZy&7qEdnRieU~6vJ|E&) z{C2s%|5+b8Wq#HF6NAq>dRg~?`lR#Ae82a11iL@vnvk2sm+mZIa$Gp4`Kr5)+Hza~ zkzcR=2oQ2d7QK@*hu?=NUR#spyxEC1<-cF~xr8d8|9GW;YVf^M}l0%@&yeQIMbu1>6xY}cltD}zq66v493FzwG zN9zx*tPl(+$!61_OA;CU@e@H;i3@!S;w%rfk;MXSEQ!mJ;tTw^yOcG1|KR-<-TSou z?<=fF!(Z*AN9~-$CXJWs>(JuXwIXn)(?EWz6QbG=l@vEvKH=Olipb*wvYOlKMZN&}Om@00%R~(dl+eh!3sF+brDhg;JX(UuFa^XyL;9MzBkY1{)A4Mx*%P( zAHdW$B6+zffcn1^bk?pC^Z>)r4GYBxt+tSSLfvK|-M6*ILKTGWv`{4>HQi5C5xU<( z)r5L1R6}Tkg=zs|q7N$No1*cn?^(P-BjxnK_`Ai`PidypE}5li)n4aGzzd~B1NbmY z`s(^;@4;-p#P3xfWUeyE-?)|HH8%L*pXj^R@THlcnnQ3ZLA8S5bb@LI!I=cr4uY)& z)ewTS392PQ>}NHSPh3xA2H^_Jbbt|b;zZPD?X5%LUh@tOIXc74b*=&Un9wE372-M) zA=!~j{k6q=p0dEXRY3;|2%@7E~xQZ?t*OuB?gfo zN$@HcoKNst7hFK_It2?Oy^J^7v55yDREI|uwMDnT)J4PnH^%zM zkU8iQ&2#aaz#pEmd58zdoHz3bzx8Jhttbg=)uZ>kk)09;q7p2mAn6kPE;$)rxo;er z`%2}mCwG6(aD8Lp_KCCOL3?>NAu84R7Cqb=(r@n;y-81%pL5{7_9i8WHBGK?ut7$= zzV|IMhEnSVP4k&SzYttD%q@Gv^Z0??0GIzn>UX;FU|M(bD8$;hqt|KO!NddniKXnx z=)Qx&$?T%HZPPlj!Ar~PFqma_+Aq`4`rY+~`I2KYMM|6e`oGqTg`F>uRQjUC$HA~j(Ttiin z=qv+H3@sN?kyABUFH3)6b2a^(KSiMx{(+><^RL9t`rT~DO~6(&vC~Vx1h0yWw}bW< za(%o8!;-L=<=YEUDh)NhM|3*L-#;)a?{*Wr6sIPf^(a?kWD}z167NI>MP|D6tdiqG z*@Q?9{1Kh$V?}1xCMYsSuskzs3y=8VkpAc`)>sR-_#4v$$u9+oO_|H4=QTKg{x(rf zTCjj)O9)m-DBs>&@mB$4xvvSwE-4B7F`U)`5Q(@ZWSB&pyO2UncFcWMeN&LX z-wAGN0B=5fwtQR#< zzFIX5atDLuE-d3zxP-x=)e5VK!x}bvQ#OYGj2!!T=qEO`uY%a3$_hl;9t=_&X>$J} zTF>8y*Rbo7k$(G=oW5VFR%RA%2@aCIzJS!Eb1LkjTA&&>^L(?SupL^hGjaW%u@wA)wh-JL|)jpRoKbv9jJ9Q259ixIN?l1mslvTcAB<9$MY{_(QpLa) z+&$d2W$xNsJoVNA$*);)7geR+I;cI-xw-v>>`0Z*3AK`L{jhp|W4+U6vI$laet~fW z;I#CJ^;^5`+b5%MSMiPgHY-387E1yB4|H%Tz3Fc+y13)b5y>+<-Yjc>+9ixBp?=WD z7~7&$EuF$AVPvZ58=$$JOLCPxV4vI9*@0R2=@yr=a~3IGp&H(9{p2PVzG)auSDUNj z+aN!6Ip8+V%Fzy@M-22KKB8|Z50}wG4)7ZommKP|6^YC*7ob<%9sNXgpyXc=U~V5ESb9kBN` z|C#XeJ~s$YQxK}u3t8}q*}ceXaDI8}52Y8BNj03|=xo_isf)w20Y=02OOmi$s-vDN z{~5fW08T*plpMZ^dl~LC;tgfX5qW*GLtF!ZL-@Vz?6-TJH>jp5R%uGX*7DTzr57A9 ztkTdhu)VoZ;Wq#E;tH1)SD3dOh*P28+m(v$Y0c}0!n0mvaJZ~hb|p3+*T0+_C6saN z+4^VAfTJ+Kz#i`}#uumG%{Cg_4)=qbHa1PM%nWgZxW;2txwA&)K4%&Qk(n{1E1&z2 zcH8y@d#d1U)(k_GijYv+LQ>R3Az?0m%#}@<4&?~HV?&^m;u0M*rqyC-V+%kh>y^|# zk`>^{+N;U{)!m*f!!jjfyR+e^tg!YkQ4F=KnB{}TPV`*9T+6v$TAi zA?2s!QVr3-s46!;OdcEC4=uF8_!EMQ4ppKHqnBPNM&2ejQx|}B<7xXZHIUiZ;0{xb zGG%|Arbatqzs6G-MLxB|4#JcRLi)!_Qa@>&qX{aQq?1uLJpq?(qkEklB;eK{hDH*Z z&>}yAUgt%;QAVLmD{E+(h0-MQalMMm&o6B|`R~oEHLKUT8%PVbIbPH+bp9n+MXuHIb1f;y`t^<^h_azS4AKTl5qgF}|VA_&I6w z@OtT8dRu9Yf{sq6&V0iG(Zb#>eadnu3^ZIqQg0eUWTF7crkscXpo( zP^K?HsoutO5mR`Z=F3HxCgJQ{YUST%t}-2?|Eq8lrzXK%RHVs9wB4#PTVgK0`4oQr zdD?@uk7jIBoqMN}bHYLu_Op{wYsafawk0I5z;1glm%%}*74lJ+2%E$$a zWXaURc?f_bfGt=!la&dl)EV0#(JD#dR~Ez^6LswQu;242cMcnL@0#6QyU6V$ z3~e%6-iA%yLVJ*;}~+438l6NcgUeoIHv5tJ$`o8PNp zUFDSCFsnJ}P&Hnr56Re1G}6ZLmQCslsXu2m1HyPSoSCRrM@1{0hdJsZ#kynd2yTA| zoPaaJfs>N({YOS2tp5wl5wY{aAiY{B;Iz$z6qJfte+0F_7pc-@(?O?&0c7+#j{|y? zbnSY7N1G?b=I!_J8^cV+}t|OAzC7Q8N zB{A~ZHJ<6RB_I`qUqfDL;;ZS3a^msb*b0J0dsp#+$JyLuH~qj4p^caRkUE`u5{;?1 zO1$OG47j)AIDYf=IkM-0T?1~!NV8Sa+4%p%L0I@ifw&;7Ba7vQK~5lyiKsQKMnfsG zxJnKA|ETLwgwaET-FD^Eu)_rhPima(acos<_lRpSE_1RaVoOX$pV`3!hLL+n6HZ>= z@>AG8Z2ObUDs*dKV!q+@dBSNMp$M7h^o-(6L?`}IllX_xf)M&VN7dsi-}g2Q-LTE4zzR?K!o)4BYIix=hsM+)u z@CwXlf|?0;dyQZRzN1UL^dChJ`I%DKmwRS!G~QAF(x=%{&7t8Zw!?c&oGtEr02xeSDd z{>e>c3~x#9JU$mXO=AVuTJQ`Hajo|u6d}*3zmf-K)7rfhNP|d`dmC)(LcSRf0Zk;z zq%d`rx=fJS%v`@!pZ>17nR|ZDM-DTz!)Y$X=jQVxe9j$9K>Q?ofE1?pl{J=hPp)0DJGPx7>1zzh%$OCUmTQafI*0k6b&E3(6P2HH!-&y`{AND^Num&k&6&K0j@H_^o5 zM2(80LK90Qq7XNc{;DKgHB?Lysmsu!*1Dmyl`$wFW;C5X|8#_yZAbu%7aEy*OHP!_ zo5^4{UqlezlF#Z(FJFS|9H%dHtl%c{7dZVG%1~DbOLJd>Od_^}H@u@*Y|`U?GY^Pbg*vg(e_ccSW_bK&mDqmx zo=!6ikjpW11(d9GYYS7d70PG5HXSAqR$gzr)A$oQC{F3i&Ab5RQO8tbMW~YVTjWTv zx%TT4w=;Z%d$%Bbj7Nj)l!Vc2NWaV^OG(+{RTSn#{%!ZyYTrrc-}Q7dwfLMvL@=~* z+if`In$7aS<dm(~nZViz2$p5W8GV2bwR&Wn(zY?(R(wQn{h`vLtyHdEy^L?*GEExfmm zZ<$-Wi1nu6C|_#3RxhP@6rq(IxLy|MWj6vLlkG3*_8@f~AF`H4x&2$0@xHp$w>vz% zPVEh>uE?f@UVukR)y@AB&KIX{BY^u8woEQPz_&Erl5_pk93mpHgN~a48%&px%T6+C z|B~xb4%nS2kGCHP3VZ{-QP#2$TM`_J06Ir~?5}K7F{j7;;Cuz#aQG{e_BHOWoNs}0 zf8_!TRQM}9EKupM?6g3Yzf#S?OGn?o^$_p_wTFTP2h!1Wf8}yMAd9EA@Jw&cxV4?G zg}&oa#ccLhZsM6SC5VqQv^Sbb1!{PV9P{^hopvA0a$6Sa?9Vymc*yt{YW=N<0Fky} zuhF!VhvL2s1#Go7m|C&VpE_z^Cb)`>{)?&K?Hm0F1KT!wi~qP1ls=OB{XT}%yF%_s z2*XK}8e3R?wN8Au`PGMU&Y3#{TQ7PUcAKR%>sDgl$% zO|iyIrv+~|C8Ia}y3p;fv}&?tcIf}coPIXE#^y6v^J927z_SUD?ze^64*lKO>Mdk9-l)s=za1{vGENfLiTU z)M^1ys|7@@77(>sK-6jhQL6&?JL9?37G5%uzonJBIRm7)uiK^A2?$v6a<7hvcI74| zHMP2b-=l!RVQ3FfS<$G3|M@}oBC;9*#JXw@ z#|o_)EB(|s718NT_)_EbVw*!5Q^pUXm8px1(P|AKTR(c8QeewVy2LtBy0$A0CoJBm z8ol%fK|AV|_eAV> z9z!`I!d5+D0dGp4uYZ{@b3j|gNQtNCJf+ATsQB>t!7j{F2p5k4MKUWwX zDgH&R;$FW2r5BXGK6+Q4Z%w2O!mv|!Gkh>k&K(x`;||8hM8o43y^7SfOqCr$!iS>j z+oI=ufk8*_>?uR`+=Nb3uCyQAZ9$2n@v^lD+;27F&rMGbWP#ljd+Qn`vNv{og<|vo$ejlu2?DO zkcgw%h7x2*-NvVJgync+KF{2)zoCnKMer?3qI^(<{jH};)1 zR=1Pp7N8L2u^WlHAb-|x&V9M~Jwo-ud_kf5dzblQ1|v#6(R@MQ!jJiN1r(*v&levX zOwW8lN}6C&>ah7@I`f5sg(e$ zMFca=f2F&*4(~1RZo456VY`~fNCVdz{`h+~4rZv9ye!ia%UVmbja7QqZxz08O7&Ey zcJ9l@xbPZ`!{f-hi(dEchM@gj-t97dYxOzZbw*T_tj4&wUSG9LlBE-7G=sKqKiZ-y zz0M2+|ByL$xC6p|NK5tHPYH=7vzm+V2f{=4=f*QI^_%n9OWCYN=|n#e_EJMJ<~obx zBFqIJ$C73U*2+70WTc$OTD*gk>c7U?C%LBwsT8a&0Z^giMJ?}+wcB3F>0a|e{h>(8 z(X)n#Q5X3a(RB}Rcv=UHSokx}59j`YF?Fo*4`_38&%l@JH>d9FWxR2N|5un@uu`+s zf0l}^${cI$i-)IPFZCZ!{jStZRO!Tu{Q>NYjy!UI?wY;m2wus(pj9LTB3ZE{g0Hlv zVar8ty-~1laqB&;^#SyJ9@-czy9Sf2QI9%vqjb+rI+W*i-bgVdij@-!76c!X?a{y! zCLY~1&XO!5i5=`yx=*@v`4nROzW}ho-2p6tcIyQ9uhnMF}?wKE2$l7lERepYalWO4Vw1(|NdHlB$rkneJz!vsN>_ zVPb`$3$|z{vlz)NjQKg-MBtCC+dN zdf6t$EG|}i9Z>_L;$~-2Ni&vxoQjE`r})51$s}1AR=_lDyI5u9^V8UY)6hrBcCK?I z87Fnc4(v!Cyf*wWdwuC=kR$(|q71C!qCWhNqOO!k>Y!n>z?k?DXdpVLWX6hA&@4Mg z8R-2?M)N=s*C#<-2_})?g0v!S@e8y3B&M_+Bmx}k-)^DxvN$+kyJSRCN z&p$Fscfsq*jf1Vy*E0VS%c>5+h+r&? zF&5bH)34#9NJ;(_9gkW?nOK;$aLt_8d9{}82KL&W2M7}fbNrAT8i;YRYV8SXFr(>p*^{KBxHi(p2k0ONv^uY}m$MM04X3YnNtDmdd}Y$B z=ripXe6}U;u)?ayXOSr#!`SW(_RsVRTx^mNaNb$Pd!(;&fS2|L6(eKRh)FVC>dPG2 zonrKsjS~1)x6y$$k@=I>ke;d{ytOXLsR(E%OP|v@Ct8Z^i8NJj<$72LS?=w>j~0J) zl;ytFc@5L~U% zMuu2W`V7bR=GTEpGc#9I(FlKIcO3wFQvjN6Yr~h|gnm8P$$%4sYEV_9Asw&azV8Lo1)fXFIygQy-H{Ktu;SaY_oPQkicw1EX zL8ZN*(nt-b(8^5QMOkfsvvmKh(%$d}Yz9PRKQIKa?xS4r^dL&itkDkV$aqw)#JPb} zYps5)4VUd#^IR>%j5>{0wLjOOVr^7PpFpL9NY7QnDsCpbX;TbQvr}wx(TD^oH9-PB z?$6E{?{$8I8n8oXAG70D0YQ@+5oA9=uy16X?G9by;7=~^JF{-btpfGA&3$L;$mc4C zn#9dkp?shD+@I(^%SYkHM(S^-IgLSy+zvMw6Z4jyik!vbZFaV?X4MY1aPurN+gQ8n zediXx*RA;rPHhuo7_WDAYU>a6Xj`()JkC~ExM$U_-`acS7Wb^^dB)z$ce-c1=1qH# z?c9z>+X<+~GKtx$s^kUxK4y)3)~$Ng-fJuR?OE_>`#-4%ki#ugO`^5ogJjJRzu3rp z^AN#FzW=|#0ORo+xi16WP=@6FNWk+tYc%{0Lk2-%-^8ONm7^( zBDPIa6Aw7hRAv77uL>*%Vzq$!uPX7DorN^?E){`~6drEB|G%#2yRM>{i`R)bf)X5B za()FvD-d`l+Jzu_=srIg-^Zt!{!?^utG{ma>!TkpL*brRM4T+-Me!?TL=O{h3&~~% z)uqrut6x2W8E^v2O;e(_fcn#OA5exois$02SpFuJRrH-Xc96EfF@iUCjmirRC3;)nJ4t6CT%GH9fFK{1}O|A)GF zkB_Q2AOEw-0t>912tlJniEYrJQIm?Akf@OmL;hKMjk^n+p01|# zZncV9tJTk^ULzNUgg^pnEkea8N-0`B$3;a^2|>y4{mh)R*#xxG58pq2yfo+RoVh&n z%rnnzW}Z<}#67M)a0XJtStEb0iuk$iY|B()sIN696PNgauM_9` z#lC)JXseIaxUZwT{nriTNf?%jVzZ(o+UzgeeBBP#tL5~8+R5+ggSb(*8TG0*ai#VR zZ8pT#!_FJ9$6S|OzqlP^I{8Y&bUwHe`I_vMBs$ZR+k`{E{FVoK# zOr*h)3|KxL78OQx;Uf20>^_IN&r4S;8p?&3KA3ojhlT&-6IB*cv`7_9 zX@t^uG3n4qC8KP$Cu0#Ai_`dcK7+}1fxRLkYh)XO=qkU_d5g(Ath3T7UGyWfY0gyY z8%CZ|l}A}|W5^?r3d9P4Vakdla~YXS$y|}vxVGT-Xm15zW!r=q<-slnq@@!p@*c=Bo3-k;PE^Qm<2PioZJ>GJy*5U{I8b~}HuT$byS zAExHxvdl_$nv4<)UY&1PuI6h?>iak$#%c8QJBf?$m4bN#JI_^4o;V7}0b2ebsu!X>JovqevoCjm!5X zI~7u&9(1J;fs@A5$xiKTNhcFA6FV;KLUymXWXHt|LZY2iqG-80*%=Ezp&9a3(0Jwd zAU$Itnurvrq`*j3K;m(S07TT8bZBqa8AtM2c3G-TWagQ|{l=hJMcew!?q%h~D~Yi| z(i~G+*W>Zy%C}7QZM%4P)HiX@*SOz;>RX0ePHH!6f_$GsBWKF~+{tNGyzf>41t=oN z7$(PoC1xtD*qhE3SL0LV-k&PLjGULa^*ND~LzpP~*3zjnUXP}K*&?GQ)jzuN zf2A)J!{IB@rbaU+Mf6n9St7x>M|Fh<22c<*xxgr3W1+*W+onLfvgbNEWFAfb3iW&gK4ek!Tel zxQ4aJ@i;rgd#OmtLv&(#K~eH5&;J#DpNS{P+`XFsBW*ogNF6LJmQ^;|64HYVmK|%W!EF@vOdWH!&WjDNQ3sY=Y_!;@hABK?%CwU zt)KF)&fY;Yh3X`Cj%21#wmeOucFU*<_yU(m$y_w7%dFeB0VvD)xiAgKATSOQ0PCbCi=ea9U5FFCx3OP6`deQA;F6S!9i^4;`c( z(gMj!w$!xQyPE0RN(gg(_;tOfGRx=S`z@bz-qzS4SOnB>4t7^ZT_FY7K@BPWL(XPIs- z7^8pr6AMPm8-vt>O=2y`rV~Oc??|)S*wyFaSP7M+1=-S-hR{*g11c+>TCsOlOJyyf z=9UFH{H0Q9W05)#hJ5N+NB2oYX%)ZhJn_=HH5;*C$uBx;egn9Li-gX38AehePn^8@ z8e)83=tcqeu+=ZcM@=b4WQ>dm&l>kR-hEDXpHt)sSsy`uaSy7AEs+}}+!0Bf&8G#N z1rn~T2AY(4)SvoGzH){Eb)6MgOe{pmGuQ*zIL3G(-i2Q_mB%%|yjI3P?lQsg)*UjB zXtsudzfubEGc}KzDa3DM{$L83>RoqOaTkW@k^d36&A9wFVrn5*S2%_RSh$WmbvxG6 zB3US0gVu7TeBywcVzRJilEy;>0q}RZ28|vZOb%sAitq0Z)xCHISV#-^AUocLDQJz@ zh+{`*3>EKrTs-9vONxoRjO!dB6{v6oGhKXEG6PPLcU1sK{AAcr4F%^CHfAo~Hr6=Z zA=2zfLSl4fMXYQ}TkMrCqeA26W?-N?87}+|ig~I?jS5gL^EhuMZN8-B9wzlzSiIfm zf3U)mAZdG%UC52O|3Ab#128Ug69&iQKSD|s6gz}hz?Dahz7!`jtI5Tp3XS_{; zn@@_@M_yF{<|=R!=Bt3475XNG)9vy1GAOH)neVoitY-p`{Kz?z-f%ub8u;8E_#|*D zj)5+uf(aO-)@kO!c;yTFBtEz!hbi?4tNR?M*4gEhbY=)cRr&<9L%lBT$Q!gXjd&A^ zcKB_?e*3Y-WDGmUp01^3Ktfv!WO7S>maCb?aL5G@!Xex2h6f0u zHn-p;8uy*3*f8sd& zQ2XaNtOJO1R0H7BsT9YLpbS0dRa`GJfu{n8P~*=anQt9YedLF_0_h|Aj=H-Qg-@bi z?>(&Z?xyBV=4ux93t{HmpUg;rec?rlScGt-7;`L@rU+>B+U`v~7nF>6N(w5v(oU{4 z^08dMwvw?E7QK{b*=pk~8;fOz`H_7m8V}Xw3l^M>vTemX|6~vPOGihF`8sFFe7H+7 za+vRU@S}KL8-*2Xw5LE$g0gkgWO;KV4)HRaBFbQtQ;hjRHM~-d^NskuXj%$Q;oZ57 zCb($nteS8yLKXA_((i?j{hd%*cR^9B9fF2Q^HT&X5^$Kd0wCpbcp0yL`&D+H%eV9R zW*d(K-$>p%2Iiv$I6nqBC1ga(67=PAk-`)kCj87=uuoxgkPN}c;X`S3j*i5Y5*?^I zU`envDY{Z}Xz}sC4#Ymr7gPl2m34c&Y z(!-(a%2oo~6l1}qd=W10wP5d%ibDUePb89uGestVi;-cH6O4E{m#dsmDe1{|GJhC& zHFv$XY;M!E#H3oNzo zP;w~drgtIU=BieOdzg{$d-zMT2UHjhGUzRzQ9sbL3Qd=eGv| zQiBShp2x;h!M@V{pa37IAe)Y`vMo!hr4eOxTqr6L@Wo$IS%s8LwK-2Fgpjr0UjCV& z&WJyrs;rx$SEoJ{P^-pgOJ~3X82(1i=<`XKzCIEs)^{%B8q7Y1#-^(qQ)yPopN@gU z)M{$B*(@VZDxLGDRF}Yg;X|W)*yu|<^9DbSPycL`x|Db4n?3LmsY*(;_&ncD#aho){+kU&}9lOF$wZRrHiSJ z$7gqY%_g5r<=1F&W-?P0eNpK$Q7>fS2zK>D3p0v$tLo%O4*V4@i>l1yq-WcN{Qb9cYrM2_SOAU9vlPl8rClW3oWLN}qvnWhtz zcESgY0;R2};YgW863N55O=t;+qp8MNAjk$Vq4xk!>o%qHlR8_v*ttQ#Bf5zST*>6f zCOB{Y(`J{pr?L-_w7uI`Eeid85YVarhJcu!nxFw(}J}Ed2vo+yLnzf z+znIfE-oQtmN+iFcz2V`HzdXjkqK1Hu*#rOpOLIewHI3-9#L^_cuuq`=!1d@+f-HD zGrIMg=*lBY)_P8rR{Kk^iwf5>G%_)Rz{gTa#dU1Fu9#@t-WXmgr7>Omdo}b{HRL5< ztc$G;J=Qh#h~%TuRUC0wrgmMtBYaxLsBl@?m*KqRN!&luHYijcZ96R7tED<4kM2cR z`^&z>d2}@gHd*aHJp3*nj_^K&Kcp@d-o%aP#>XT1m|Wx9_p0yf;273SfIcMBejxxy z+RqR5A-va*C`>dS-U{h<*3x{bw%O-(yV0B(WFE>sX`KKDBQ6;YRF50b^xeZTrZ_ub3X@v_^DQP+?1k^`cBFHkM!HOPsqdva9#3 z-jUsx8SxXLdwGe?r7T}c*7I%l@l)#(!S#tT*1EEnXD_DB$ncEN@rfV%R27F)AatVn zvRly`iE~#(b{#g`EwVQGilWa==F7=cvt zdoa1IQha+#|G(Iu{KR6lvaCnAXSA1(SF@d^c|5Hh*03h~GemijM_r z$t_un{gD@qur!Gz6aI2dhc&*bC^j$A#}4xlV|k4abUt^qfN0g^l-K0W zJARxsIy;efA**Dv9W3u2)&d8%WSvQlXhYDRB?Sqh&MgMAps6O0E@ClxT^{#mw+at{;WX7W$?g?6JXzg*Ten_GDL3beO`E(RaLxX zAPp=nq4sFQAw##DRk*$FY1Ep0OxyR!t3~{OuP0yQ>!m|s4#or{r5WKK8b38Yh6eJA zwoeNkA8nr%wiB?@?e>i#yY&celo8xcHv1|PlZHp84EJQoRYiT5g`d)(E9@r!1pL-Q zr3b7HoyIMvR)4D!jZ^MdJTW|k2q!o7O%9ZISvk+;Tl6Czg7)JbO`$$+{g9ef>2GR@ zHALTjf$6zb1+mGEkAd5KWhMje>51;^PSLW+wF}I85Q@|+@MuBv4`X2gFVA<+^)AX&}``Pd{36);JsZZ-t)Z<>hvewxntx-WbbC5TB%AZ1xte)ae z5T41@7eAPND)eFX^tEM;@;B3q8(Dr=x4#H}CI;~nzX*@&g(qj$QO{=jHc@xGSYTF9 zDg5?5ie&nkJ^0q*>Set83>*LOwUX^a(_IR*A5 zy7KAPErQ%cQC4!0`FEz1C`c-4Vb1Ag$%S_cn1dv> zxLu07seLYijyq-JbacLAYwFmUoTwd~d?dQ6Nb3^9kGW6cZ$go^+r+`cSzbcu7_pvo z(o#b%*2fyYSSO`6v8<1+4mCsPi)VfYbR+IH?5v^Fu z3i*rt#g%wtVR_Oy7B(?zJp6 zNQsiKY(GjllcSOuWyF^qLM^xDQA5)3W_jpPnQZ-q32Y1ZWsb{8|DKGPs(q-H({R$C z7In;&myC4Go$c31UH&G7U{4k#s3A@M&=lq=NKn5Q=Jc)I^H1_DyiG=wb&$c{xYr*N z-he4hDny*u9PLWN+79ker-`HLtdURgw34+##Cgg4trQ4z{s;(f2%f$jgn8ugK)Ctv z0|mkbpxWN8e3s0;d>K^GlFwoA5=L3`FNOa`zFDLFVq(_ID~xufFxstFwH!UqXXpz+ zc|Kd;rpczX0*zhsSs5~W7Z*&HeQDe>>M)9`S+e3_P?|hO<}YV-kf1H@^jYZdTiY=} z@U3PLXCx_8+pZ>BeXsC(j7C8?qq`4;%Q{0k!d2W}K{(ly_i5}d-}(S8A1{ns^Rs=7 z_t#|ckUf_6^*sN-j<*`zYvb09~p}QYQB-eg-fB%@)^rOTGK9EgM{kHzj zNNY3uCC-f>Wj`K?z|=;rOiao&Mz&`(ME{vJ^iv~tH~OC*zml(#gZG*tWqZ8Y@hdXA z9T|UeM)-{sKiqFpeZZxcS7dtbYkvGIZBky1(t2R3%v3+rS6sf8p6?E1{_hwOm#jcpmT0&m{xu=~c3@xv*U;+{OP+s`0rpd{%jbcB%9ai0FY*J#x4IXaEBDi4@&NNapw zoe&C9lE>nld$ zSplkckLW$df)mjJv;-S6wa)w;WkKYZ%CgWupsV~U7x}ekAM#5bPu>SZ?=Hkj2pyy4 z7X%Uxq`~-55ilxjxzt;GRGK2HI`SFn=nbAadV@Wqdx^u-OOSV-)*Q%N}#(UI`+o`Kp5dFPtE=T`MSb8Tp00vW zmS_DZdhVSzzOs9LA5(q*$G1}tbe6D0XPp^{mJT=K@5)Y;nm}}TxeCAAC+xvPS3lGw@vsdK#JCpH^U8 z=SwxM_6~x8DJFu#thmV5W5FJZlX$$31|&*|NxzIT&LRBP@;VJ}p9gm-@%seU>;2Yj zKl*u|bx7pbzAKE_mp`ORen-!M|NP0I-HoajD~bVf$D^ol7%^p8+-?Ev?jW8^d-O@? zJBfT28o2bjzqyfa-qmQnX8gX<++MndaP;s;jh2mWl}0=dH;`4Wj1=6SbfCRlRTwQT zG2-X3{s&5q?lSg>*mNKpPYJ^v>GNb+dZw0-cqpYhF; zKz=&85Bm6T^c4v-gEcc!@Pbqw4RA92l}f6rFf@9t%sN}R{1|$gPX`#m(P+X4DQpTy zKUXJKnyQF1Mkr&M)UE27u8wu+x@C10D@C=ti(!-~B$WgpQFaTKERAsRlo=(WB_nDd zhJkM^h>>8f(a{a2vzG()J9%iQKFjD?_?Zvm?!eg>K-oA4Mn?B!84FHD99eArfL%3i z^(V&URGQOsDy?aL6Q(;YU|tpAN(1w%pgEURtViFQrUJXAQp|8p;n2&6&>NIhYqnyS z+WCd5{{^}a8WUU(&7zZ9Uu%WC2sPsM5p`pWpVGOBxxK!yjOZsm^CJ!%e41?!q7t%) zKN6jUyLo6#aG4k@o)7SO9M*%=lR7z#n453JH;65GCe~i4ucTBG!9#kMRxm)p=+*}) zdn<;W^RirIlaj8}p?v2BNz#Ni=s(*7MQN%>%|Qo@-jtl{@ooCf;c1Ny>VIGx{Q`aQ zJL~~}TGNSx4{X!_lBV~iPwYsuaC;o!MmKzSf48JHJv;lr_V@X3>+j#v8l7?An3y7} zC%?PD&!siJwcmm5?}Ojg-zU-<{qccq)K!0Wz!=i~a5s92kA(ij4;Qd!ARe7%vOVH# zXaBt0fc*9WX?{i5*QtM*R_B7Hl*)B3rVj49dk=6`SdEOJ@Vl5gV$FQ-k&4Z#CD zVE0R--|Y{1Caw8KqHU!5{D1O)Y4#iawm#pN)@a!QZgjdd`tAOZo70+pf>4?VvcHqR zt-rraYxIW)xY5zy-QP)RP2bV`!1nj}Z|m<_X^mdUYTE%pvM2<8lmm9eGfk{HXzDVf z*Vvx8{|__z0Wzil`9IC*Gi7a|w1*L!ByF=U_Cp*3=nmx*GK|>kyhPjaj-Q10Nh^n` z{TWJ26g@CqQ`E|h(hEf^#2i!VCh-bH^&y&>^s*1L1RboBr2v(m_-P-~w$d@h6Yez1 zPo>l0*11c+Nx??eM9g;A-)o(NjTs&&i{`x(*M1n?lR3K|VNzpPBN(mzXp@`SnLdeS zA)*sdslvFa!$XSEpjvKGe?@=BwF1ETp=|3%1aj%aGD=T2lj81E@h)Xm;~lnkM3#wj zowb!EqT8jLw7CPi^7IOir&oA9{k~NB(~a1)?&Tjwb4r&9r)zukbg+`2(pu5Mr7O;& z52RP3fTnfedg(v`dle>Wy_}ddUtuK_O1IQlNw3AE%SN%b4mDT13jG{EinE}=934!Y z^L}&}cSWod@NPoLg!)7qSa0&1ABCIJ47_{+0HaP}fRTy6$82047E|cE{6E*H*+cLC zJB@-n`SbqU%L%nOa3hyii+x%TWU>+vyB^VPJuBoS2Cj7o*A($CgJJgAo;H|%=li%V2--q{G;{zY~aTu+kUl4l$ikX__4WS; zRA23)`pA9xd;VWx`*SpeePa9GEnqwBH|qN(E_fi)ewZ=;gr2f(Br^B(j(m1w4&`R; zS(3+N9N)DaZ|B2~T8B}tZ!oW*b`Ds>~lV?Pl==hh60a$ZsPQhb96dH_8LhV z&?V`4Ny_Mw^pGTdEYcxG8n;T)+a$SoT7qLC9Zx4{PJ9AO8__dHaZ3>ziqa%^p^056 zh3}X8lsbfiEmv>ChOt)QW-R3xNvSLE$Fl#?PpE9a3`~Km0iYIDl2@X0;Qf?TYMt^9 z6+SEa6*|{Q(M{z8$3>+fj%Vs!8qN^a4-Y3TsC`cV^dxIpKE>?+(te)NTdYnGzoZi8=o(Ip+ke8EUELLHXs) z>LK556IkJ{%cY3zD572-4i*`%-ppxQXJh(trr*Fua8pKWobN>})*N$8549DZ|&cDiT65U%4L%cXoq!!to&7y{e zP?weQkvKaL{onx^lU5FDzA6^pShe-W2dHxH-hK=P%h~akN36@g5hMHC{TZ2Q-ThIz z4%^w?{pR8KGk5b=97D}&J;>EgCAdQVjz?vu9E(hY>3y`V)QClSu~G}*D~_d!S316nJ52j^1x4)4a=`JKKWibrBZR+!AV`lDsL+ z_UTr^pyFQc@_@&@G$X?>EO)k z22P>0sX;2#@L;8>Zl@!|gXb1D!gd1ErQ$ETfsjITw#ag|QLfp4k`BL-SD+59xm%Z7 z6ntVUyF2BaKgy`5q}mb&(D6%0^cKKFy)A%jm1GFj4z+>u!dAfdjd&j!R=pkYLY9r3 zc1otLk6r7>{`2iD+jHHC&R?ZFo!AM5_ul-0sa3Yqm>(yn*~WnqLfyAz-S~2({j%`t z$c?_s!Yd*-W=;q%NnDdv_UWu=O4cU_MD1c$*rKa_zLjO)5VaAE8_TQNSfb8v{3|h< zV;4P)1%Jlt6}3-IcFw}@!*tX}*pdd>MVRZawXm_D1OE=vEX`k`?(^K=hL2?$?l-hAap+JNLTB5L znITNf8IGvj?-nysE$+u`Dqa6yw6yMZDda76cX9Q)8xCasT4zvRUzj1&O7III zVcEved(JyjdNeXhI=(N=c}UUjTEUtTe+`!BH1mh^T;G>?^-kLLPVpwh$LI$X%l-+D zfT%smIij6D!r<9-qd zh6@C2YLOv6K^nZC1|h!!XFRNnn4Y-F3XRxPbd*geM*JmStn&lWG7QY?#X$5$?L2i? z^23q^@`?oY9h7T*HUHjHS0S6iaQY&OF&D8sHi2ftdbh9 zAeolluZ79FSHafrI!{I)%WkOsE;LYkjTI5aTc{v?S5}CT@aSk7ADxSYManYB zT&#PEg#?N56?;@>&su*{ex?ql945Kcl{zUbat9&Cv2#8&F4X5DFkhT6 z>%?wJr^=T}g-yxcw+>too{{v{rDZ~r^Wh|XC{Q2nk!rpGx8EB>1l8Rv9)RyV z4CFuC+iW*f?ySp&i1;s~b01NT0I^D05Z_axQt3PU3BsfHGsw1WzrF~AvLC=t10z2-FEPdROeoZFg^Qm6x6EOKC}1SADRUj)6gueYJaqp z#gEMb_yo3L4mC#F&N}(EA7izR{3RW%ORm6CzVtH2$&n3}YD+KCGcb9b*}M5IREHpy zE!-3E3PDhLil7#As7#Rm*n_>xap`AA*{8<*QxU(M z+Kivb)7@LU;D_>_8a;Dk_@w{bf@@H9Hl)Xo)1#lH#&BUUYoX<5Y@KXI&=V~qo9MyV zfb-9tJV)RS&!{L49ah1f&JLL3(hD_NeIlIXDulw)F*@O0NtjH6w_kmnL|M$WBFd!X z*fOjp2&)OCZ0mC2u_Wq*sDudCo;Q6yQ=K=YiV90EZO)C_S<$v*XP0n>ZwAVV$aA4* z*VfK~CnsjOd$BR~JyI6EN13pS5$V<2BA_TtLGirsOF4?Bvbk|PDfB8>oELkY) z6RX|TpmyzStlcx6PYZL7^LC`}h8wze$?4(O^$>}`FZuX;Xq8Io5V}m>=dH(|?RP2} zc@Lj1JVgS}x9pESSpag+tNnNfbimv1vfq6Rd&Kv(-`%Ch^W}5e(a@u{qvhyy`sz|&`?u7${H*Wj@7Zbnl~5=L z6yNT;`A1(fKhme#%5GgdR(I`Kry-To`ATs?nV(L%B4N(^x%7L^cl77NwEkR2Z3nbJ zZu{fDqy0=>ws-^#; zZ@0oKzITfrm_e}Vis!U=0Ix*1jlu37&%J@uxsrFfwJ=xk-OOpFVDeJyPWi>wvGGT~5;gCO*>(ycBBE_WTdMR)gXL;_(Vg-)G!$tcs^;KB=qFHr4xt#5 zC?uxJVhtkd!9&qiV^lN%D@!s&8)f%D*>1-U)7iRbQ0EG^+Z&j2-7@^I>ye?Emih87 z|Ii}sQ)v@MnBzBfmifZd!ZTiyEldPj$W0ce_V4NS^VL36e;`%_W|QH926RB8>|7 zP5#7#wuak|$i)bK`^Hor%E$;YHE=Lke>xA|!PUE*O#^sgc`+Dg{(hp2NvM(jZ$XF137 zDa@_Xi+Uw1il?N6w#$i6hN#jxv8PFU2mOQ!(iNYJwfMi-GMMv*TDiUadH`K6Q*iO=xOk$msAA}~Sbmtw&ZVdVQN z-a0tL;N*jX9`kb#L9OB1y)%{ij1g;|%33ZGEj9>fR9vs!-=NAaICxui~}5DP~~>>%BGN z0Desfa}=_{h&SFN1`I%h>ejd(#Ft;T`Wr12%n;OZOo;eST*8BiURj@ zG}{Fx8g~8D?VUS`&Cfh~l11KDyQ$4Xj5nv`j_`E4D)g3R$Aa-tiMuS@j;NR2$6f8$ zFBel=%6{#lTlSG^JtM@FBf&$>c3t&Qg82KzGS9Gw2{;0oa;$p>3ifp;7GdsNzlpRH zZ(jNT(yf7i2n~2`&_bd4nZ|(I1v3p1UD5EO_!rWvsskFT(nv`K)$!&ScS(FN`gLj6 zoiEN~0$)8f!&CNiL|5%kd)}lz{lC%XX3G3f@xr3pilb#Ep_5W>lf4Jr|3dnJcivwi zXGP}(tQoS)+|h{T&_h9rU+lHN&)d%wTINdUL&BT>d)E15`>r_|#1X|@sXk+Fsem(OS zMntj6+Kj&JHqr)8Mukw)NwmmLYbE!&Z5vL!a;@%q=$QN_*=c;$Bc@m=wU zJX$R`u#B-L2hkrZ&=-D)`XwmHC>;Qw%`;-F#Flv5cmS4;d;HOlp@b3|sCSCt^CdigcvFOc;{~_zjTD<-pHz6?i z8ybNDVok^?pO8E6RBJ539aTum2|0=2(+JUm7N0EJaZ8jFBs*2yC)>q9L^BPskS^D+ zg9!=nr~5&cdr*$eM(o>5hG|HWTRQa}zMBF?V{)^O7sw#0Eo?%A*`TVB-Ad-h#OOV~ zvBlnIw=O{y-li|$k9-)xgp?MUW!!Q&f91S?EU8|yjQGz0SV;O3o+?0v8{9!Q&(%{$ zWcW2kTwKKp!>Abfd@O)OuYR~d1M zaj)nz{+W!fZJ)&lHLaJH>oMB+DCwUG$qm;Dt4Z*vuuLaCBY7Gfk)I`B#n9Kd0zNhL zORLFbi*H6(Q>@F}sLRxm)AN6WPq7IEGZNe1xb+e~il#V$r!?tN?a8`|a$SX7#3B5F z5h$PsLu8+WJ4+xsA)fv^V*weXE4iHzf^=5WLW(+T*>|S!6&UQ|OHGzLg+$=hF34I$rg0-#5Vq3X$_McMLws-PaS}I^rPa_HQslpK>tWHMw z25Pc&zpaeO9Et3)L&1zhEwZIqtj!{!Efs|$jSl`uwiSc1hf-;w^H%(z%kR@^Znl8Y ztmzeDszJfFwe4>n=^V#XHJ&~qiSB(3bdWuHc5&p6`$45kXNOmiu!cFMhtWmt3sR(+ zP_!z48M_soi!h;NJk-EbCdPCnON3Y9EDFzC{>+SkxGYF|;oriPsi z7tBKt@h>*kd5Ca6SLya?0?IBSOc#_Q0mWb72tA0jS*y9*B``ymaO~b>am29&>(Jm; z3#;6U<>EX9m;|WP)Uk^^%nN47TlB`G6HUs`N$yr%32e&wDFvBJu^gVxVf=CFS>&@= z<};92M5ji8{8Q#`J4|h>dYLJAI}T!iBJD_#{{a&!9PjL7uo-URh@Ein-w4YXCrnGY zx5F=NXg4Z$r2SW%Pf=ANZI~x{B5iIIX>%~C)FM%M;OVQmEl28s%@8f-0~(5otofzX zCbDLTd{j|cAwOO647iDqtfM7OtNq$TGK$WPq`Up2r5WLS6QeQ-K+DcZy7d=bc7U*T zaSx@lYi@KBY95zUJ}%ctJS*?#dOUj^LC~KT>+n93TY4(KJ<9L&r!Av?loBciRm)sE zhO}sNCT@qBLHk}tx|>jGwTEax-{6~7?bi%ixU&R})!g~qeRJne1q&*l=FW24hH=Yy zKvLZKNBoq{&hee#Pv-8YJk!DlNeG?T8Zs&Fyq=Hg+<7IxHFs{cXNq65nc?Zf;T9QO zk30Ka?ktzv2zO3UNOR{XZxnc(i6W!2OLON|yL1r=o!q(AK1LE8@+?)nxz#>I5}KW6 zN|tn>j~xs4H0di8ekkriHH#EqZnZynQ02c;ZQfypRI)ix<%r<|6JyAy38N-H=N=9t~Zqn0x2%9L3yIzj3~4l9RatIrD(Ha5SmM0Aw!6+*-F%D&87R%3uhhuVq{@ZP9cCt z+F{e1giUYZkH?=!2dz0pMtwd=*lgV6amz7%Pn z94-Yw>zBh?s+6fgn-pslR~n4rm%}2%t3!Q6N7aFl!3z^*mUUq#&aU=6GA@{D>E+3IJARhH%fwl_ZD??A`#dD8%#5MOEzIftNS%CX(Gd8 z?4`mVm`aMYpQjyxRKlUNBDLpT*L8$O-RjVbVmES?N{~U9%EeHtKYVIkY*T1%WcNr+ zD}YE;5y;+{KS#YjP{C2ot9gy=u97<;c27V&1~A7iQfWxy8udbldI4i(H#29mN*TQ>?caKXaL*rxCT_*si6w$elAFokcrw^nww>HeQ>#0Qcr zGQ14}w?^fck18+{VnkUJ^US=PWq3yAQz#@v{uVPqD>B>dEB-)2le3YmsDzPtENRk%3bzN&Y`UrRZ~D((E6HCAUUa=8tZ1!H zRUX+rE>sA9gs3l&d`qM*x8DEhRxkM&X6F!+wLLE4G`i)V730nA;bZLA7%$>=-y`U5 zp~CQAm&tfIJHUs|Z?+_Fu}=k}{K*yM~MH3dqW0)_iRNnFC@&R9A`lh26&FU(uKE<_HWmx0bn9%N4*Y_KmZrwC73 zkzCR|3ei-}ACBsx@R3E~_qa@^+=ck4n~3_BLI%IrOd)v!l$`P?astC$lF@ZfmU4#QFbV6`lyOxV?kdMjrs;Q z7*2mg?tt)cE#7(Qju9)PS?d0&O5hN+{8Sp{ak|kZcep@Dq<*jbNnPM8&{=QsvWhc9 z!{_DC>XQElI{&3!{vmti-@ruc?Eeql{(Jeqq&8K*^i<83-m?s@T*0h96S=q`iC9CR zwAy)$nkX6ISM=rh9;zkz-&h1p<03k$1yZZM{&rNRob(~c{sVcNr6?t;q#!*Ux+!KLX1r+7&9Q*eox z7E4P-y0zLDNH0IxMRip<aMN-hu*7TuCrL@6d(re>9QHW>A5VhvNx za{{42g8Oc!!IfD0mRWKH)o~w&Fk-x%LQ@tglBr5ERRy`&t286jPu8!-sUI^De3E^t zS<}b4oXi*?(q6_Qfz{|s+%a#Q8rr;ZI+jngHu!h+;3r^`_mhx`@G}YY5B4~k$526;)@2sjq>z6s!4f)i>{-a_Zvbz2J=hT51 zEjv3j7HD(jX0>1Dm}DcrWT`5aPB@oH2M`PTpV60g6JxVHvquTJm$v~g;50iw6AFU~ z$vqTT(l<}0O_ukWd1mlV>H4^Q=RyHa>u;VtH!bKHYDWD8d~4O10NiF{c+2~TC_7t|-&aJBZJ-LGDmq9GHR0R#O^>}HxhjCY+F?_64GDL2g>%paS z;hud-(?F?^>K4?osvuL%Os5kAr3c^yLb$~83q;^15K*V(<SO^emmLQ6Wx}hu3tJQR8sO4`|3()MHn%4o@6RXG?aoQo(Sa8RXN;Ll;XEa?+|P9 zVK}i(=zo$HC?(1*C@lPG4`)E9B(8TzQ)rls^^`x=pbE2%ABC&Qt1 z_=BRWxE;^i#ji$$RiVJeo%iKQ4ZXmJ?<4W|b$gZ<+1}d=4H|;wyS(Wb42eq{) zH)HuiS1ChT79($8$r2`}8_UQyQh>uy^gMUz6+|I@`{>I#L*ZN7*B- zw%8Y%eIX45O@UhkP1=^WW^rwjyDxDEF23-Q*2Dmns~vQ+`_)mE_iNS;b7FvUuH#h? zlXY%!;({D=T(L5a$A@l;w4W6!PaAuEy73Ny3XlV{&x^M8nt5K-_K6#8!8`@6L~Z`p zGd|~hk*;dyWAbH$mLzI2;Q~he9A9G6ib#9O>_2OTxA;$2On2!$+BPg)Ub0>bX69#S zalFE+I$cF2`c75FNydVokf`;YHfpI;#c0K3NvY&3t{xlYj1?iCx_`x}_n*pQa^H%AP%k-a|H<5s z*(2~7qq6n4G0<}QvOV7|lSWRZd%~-Czm2B~kZ;DG+ zZz`XzvmHq`=UN$mPyeK$p`WG;9!x`_i7za2o+UY<4>Bl+mjNO)|R`6`iC9?jd}Ctd~gF4wJg3lWplNoluBi6VWq~ zGzEfaQ=K4W>s(uZL$Q;|LKR;j5jr#AN053OB}0zRP));~8N@~;!-JAx2X!xnBF?uJ0{sqRN4CIY!dIh6K0}dNNvwcHg#(?{?aZP z4$>KJmkb{QDVcM-WMEH*)G$*rH0umIIoa9S1j}iX;X=vqCo*uwpRZzE=z7%oYbuCr zbSr5~#K6#M&%B?D%A?o8MU#FCF)?23$s2;vk26~`D#;mb$z+B(4+wsk!Oly(C~S{K z+IO}*TDRP~kd}{=R!$%xdG`|W9VUOrrLdWf94K%(hj4T5XH)B4Qmc|#P`*jB>?;t~ zGzsd*6sspn%;%EKZZnU`Rr<{KNc$`wkt}>l+-6#Gj>@cZ(w| zK;7eL#Og>EH~T`K#_}-*gUk^Db6rd3kE9}}*gVIdyiVjnGu3l7=CadBr^izYa+2BR z?$WnzJR6X6%GpvLlC$R~z-` z`ATWch}}ko!+E>u1^OxVgco;8flmIX+D}Fza|;H|GU8#lXr%oLBR*YmTJ|AWGsSR0 z$EYf$QR;P?3CZxiF3r}H|GC|yoqx-C6ABQQSUFw z8T9%0qav$SPO(4m5F7DNc`@p1*pW340b{sg2sp;WcQl0uKMkZiTl9j$bgcFmo--SrIh2DD^;>E1b!54=!HQbhv}QN#BHXuM!wq8)N21MM#5_65$VaK z07k#k9RcpQfE(F0(uiFqycA5?NqoPNL|q zg0xp98NFY+-oU#_*dcyGK>_&{M%y2q>Ab-Z>+xP9#!B)L1%C4WB?#?|aDfnEzHYxOUr%z{7f-dB=Fcd7_5D z6_+iHpU=~XZKGr6<`r`7>=Ho)V{_L^jQ|5h5ge;R*V;&KnJ63cf?=Pi*FCv%3G5OxQmMjObs&{n!P;ojZvH zVRul=&{f<%VkYL0m;HZ1Galp3h;;~dZVu8db$dz{FOeJiUY59_ulbUI8156fA;^x( z0iuU;G4FT;ZsHEA2OZ9V-&{Dlv9_9yT z^^;ay2D7EQK~h?(SLw%#`mshHX7y8v>MbqRLjB}eryu{&k5>H#zd^9yUjQ_Zm+(&r3hvs^qG0Cyb| zp0p;sSkj=RWa4LEsC}XkXzz-%u@qS*{iS%9KA0*~csDmTelWOk&tR7O z9hp;+8+<=jX9JCR4}LnOlJ=6!1+Jy0R+oPz;xfYa&p)Jw7RwthXAFr_L--AyA=;Fw z*NyZLH`(g`8b$X$vnAZGvt)ltT6f5>o10}@!3mtNr)gQ$QbA`Br}IIX_}<0V)efb4 zt^s4+%cBSSN{QxexsiwWJb$H4+7I4EkvhqkahX+h}6Z9}(YV#9jcp z7IBH=d-8;}_Lq+-$X=R1>ZjAOJcasXJzne)d9n#YJ(WdjXQG*kvGErYWwi@Nn=LX< z)Wng~3v%%^RMYG=GMne;t30F2GcnDPZ*w6xefG#x>_-TVMeU4UT{| zMSP_7WygDHa!VHDng+1aKZX_9cTbNR zIw6ngEt^>6UdmjVu>e*q)ove5fhK`r!LT==VP|U-ytJHY3rP_QHCe)T))3x5HePc{B@ zx{Yp#nnUc0l1<4>Jc(64D<>|w@Z@aAg_rVoEE@Txv=HjGL;J&8dPsthVe)nv1lL|# zlt1N)y-51B^FF9t7BY6Od$@qF-ZTKaLLnUkpS%r>Y?Fha*(YJgbPSAp3Q1BB>xtjpS-#JpI4GB`De+V+C8d~Tyy)*b>_(eMVH3v7C&{^ijm9D2M~5a zqwkZe(~ zeUbFYtp1{7V1|tAHoug6_KN8p0}J)%~n)K=*rNR2jB z(p1pS0CB3lDJm|DUzL-O;AA{y?aTPnjlU>!zSufBmx+nae9K!jVV#!8uaZrPN&Y$s z**3eM^=p6D`2p??x%nAERFf~dGFY}Fyp@{GCVMm*tulLJqG}}aW?3go1&!}z`Zk-R z0{TLF`v-8Eth0iwjzF2_XPI7k)ELLQI9TmEo&J-qUzK(9)9Xcgy zS4Ow22%SJ$e%29ELaL~As~|N8V?U^BC{i_KE1Kyc9rL;8sR$`_4imd$;N3!d{(`w6 zPXMs*gz>@B1viQ@v1eA!+thervK?ltcZr)XUvZp!IRipS1LlFG2?P z9L7H3uT1#kFh0?*?1|u_MS(_w*02VX{;+gw@$H{nG5vV?gD2Uz#*1nOEO z$?!n6X>`%u?vDsrtkdq}*RlsC2`%$@GB1|5nw1q>MYQTn$Y%=GLCHX8NrG z(WXGwovHye9vYbNs;xp4RKKdTnJW3Z4U1%iN;btCZt9nOTJ)RpBP3^R81}V)C)O4>sVwU5(u;l8rkoI=;HF zXYwUWa;xvhWqA#a;5)lV7Fh=g)%ZT+q@e2MnF01drxWiI6ea06X^+U@Jol1zNJ@#9WMv8R-r%Fz-0>!&Ra8416rxXctg|i- z5W`_ps@Es-3m6YJ6_~cF2XOI>mn~?*wqkHGC+QNH`-N70yWjSS&X4~Z1TX5%>(g{Se#t+k@aKVWsLn0p z)!91mqDV8;-;=L()dwezL*fTTC(638!g%4jp2iC!a^hblMrP)Q29>PE9~CTndv>p^nn2lx z>w*#=qM@+tv#>1&pVTk(&XPJ>J3uj4z)~%YC6&cM-4-EBx~5 z_9&nSdmk>U;8&tf(u@}(IqLC?o{1@$x$%#~{gN%%XWSm$R9N;&=xAY5qFgIu1D`-U z9t#L&vsAv>t)BcGqx3f0i~co^y|mi`ov=Wk1numkPYsW(oB_{!U@IGp3p|QD$TYX# z;-i$3Er(4d4V`smp`+^ZBF`xQsp=0s=}84zf1OzJRjR-^&>RdMB(SFDhc17LF8^aH*C3%^THAioWQ7 zs{IhL{g}aO1Xe*r@dov7z{g3~@~2Dxs1M}n0=KCGSe;0Ly--xIKlZmO3wEw+vmmo-Av9(B4WiEU)Tteh>Xju_3@*eG-alAa$huO)YjU-IIh+@n>*FMQ(q=(V73gZ2g zg0W&@$I?gS06TBS{dCw z*z^~Ke^ySo!C5^^J}&!wX1y}>lYgCB2ip27U0vK#RJmO}In97PQgB#1-`YvDw6k-Q zQ_Vcy*(#mmr6amNW9Qq>5Z)LFPya3|Se!2%bcWg+wrbzshL3u`ZLy2`4Q^|AYr}_T z9n!v|!TTM*ok?7hQm-T5V0Y1(;ZL9lG2`Q~+aZ-NE%IIv-B*~*#zvOS>z z=DRK`l%=oz9aX9IxYf=(OskY+)-ST!RzO?D&{F`*f0*hpq6D^EzzkCMh&nqUzoyo0 zk5>78p`qw^CkK(;n5*x(ZFX!VaL_hC1ojC|hrhdQl|jtw7+)}~B}-U2L!Xy?G@bsX zees}Y0|O>#uBg^+9id#aC&ZmY>Fnq#|HYR&ejz&e*CNpsR8ohsCp+!;j)8efFBb@U zi`OSl__3QmkKBr0q&?b^S~&26_-E)l28tR29I!OBjDc-hv~b_F+6&`?tL;12UKB={ zDqWyTBdtR{b-SI7*3n!pUCY-#7$`#&5izm?;(r!OQNQ&`>W+a|s;0A1LzH$Q{6_gF zJS}vx22FKN^~bA!do;@z?&T^QQmqi6s7=zniWGpGw?~ijxwdQW#f+y+8KuLNtle%r z-A8e&bbFEZm#C_Up1j>?6iRS>bB>V?xE)c}qTG2eE!he_xQv##3eGP677tz*A62^h zRbFM^6FcxOpci^j<0%Ms-4@M)h)`KsRUkB~6AjvKOQ9iL-U1Z^zd4f)IbHTUnNJGz`kmZuYLGXVeD`4_m*R6?#E#-+05E{IZz=g?@HMQD-rALft~B zE`LY|3|=PRy5LXffuV^0f?4QNTgwQAJ-3-g_8$4>{Cn>K(l|&TAVx=NMT(Hz_EYqx zv%B=B$yzuD@ekhgR&@I$N7S(dRi@UGxPBqa8s~>yiJ_d$zI`zW6q2D8Tqi-a`nF!7 z(@}=PLkXfi!ZNJhro?|5RDN!@byaToSt=`1akAy2s0=o)BfnM^EoLnx!_)8OH|_xa z+y0~vT%kLDI=P7GNQ%Iq&4)*#eA+Lur^O@Aha2$H2!(2Pko-{b7xC6GlYg!V^@zpt zYg6d3MUpq(a6RrEc>@3-g9PD+JzgZi7aC<9B$=%v6kA*y{+nhS9&_Aa4V2HqAlHXJ zO8zxv52WhT`jK7EY-{Nuc?EaL`Q7LX`(L9!+Zrg4SjF-6b4I|12bd?17PDi3bxwix zi+t;+g&qGgLpVRA-)e3On~FDFcwu;x?r@i^w)lv3mC2_C5iULGco*gdIl(o9Gj7>d zCbbqKel^<7fvVLkE5pQdWyD?tXlq6;WRR;E_;fgXHPHjq&5MkdXM~Ax7oxC678G`@ z6PLqQK4R;YeXn928^w7MTTU71$%y|+n$5DZ-Eo>TM_{>}F6r*W*Iw48MJzYWVbCzm1kL6V>TecA>$PW{CgW?JECQ`#qq!QBqf?x)X(_Ky+#3xx4MAx*K@{IM5$F-hmq+uew0sL#vDVLy}xH5F0ln% zdoLi$rP4ig%|Z98(vS98e>SZIV58;;e|P?_+NXY$3&l3Om*3yt+CQp?n`@k*%!T42 z<$#r%&f&|s0*|fVp)vSl**RKgRpx@6Vl_$TGPe%3&R0`Qn1#o0K_~1th!eT3XNdix zf$;T!T_k8_+7*SDE$%^X*Jo*+ECl3gL|Xsxw4r8`s=H3EOgq*8e3zFAy|0Jf*DGod zp9Hj`{S4z!Cp*A}SCpDn*)%bgCPbK=7hRRFYEIEtm+rJEb*{5JGB-rIGq*Dpl8c1? z?7qO`^1TH(j`Qq$N$8~4eZcn<558h{tjiv70TYAZb5v);-qfZ+3)&YTdh8deE%_-6 zrB%{SI<7l`o5*I-PS7SLAG2qHP8X=(ca?80JYb6b%}~OLIvZ#Udtg;4bSao@In5x5 z%C(yq1-iwM+6!S%F5>D`m;X$2ZZqEkqOgv1AO(MSEBw7ee>Duw4GgHOpD5=Qrag?; zrAnv~QR}T&=@PKkO8g`vSy5dW6{>d!{v5$51fQ2Y6n^X%G89fLwsszZhQIv!clsyU zk>xUB-aLvUzJPT^8hNi)1ntp7Q;IvH>C>OzsQ&C``@P$rtLcwY)?_ir{n!1s@ax)b z6{slIeFfurh`_Jp*K-9m{IXx<4@NG*Gq%#fsnPO`#s25m{x`B!b`W8!lXiN>;#`%s zJu$aH`E^7&m5TT$z3doxpQl%cZnR9wn*UrN%X=Cd>* z9T3-+oPTx%Ny`O%=M3KJmdQtT(#}?=cl-s1P`RDZ9THApOIQ)LbVTa`sqYbrxXVa? zBA=bhA5R`@d02#Hs@MCuH^dAUz~1uggUOZ{nUQJYZq7@mHFK&E4Mu&AFSb7XnUC~CO4d#_gM@M5d;h8C_-Z+fPKKUj*zUuVKw1wO zhk&36uUvXs$B?g4!|LifhP1iQFWl#L_qok| z+V1mx_qoM=zT-aExzAVK=Nk99%6&Gt&llb2V)yx+`+UlMKIuLmbDxj6&j;P-eeUya z_j$YftaG2gb)O5}XUu&@+~-{PImdm5+~+j+dAa+X;y%Z_&l>e~p0MFfFlx_#0;$9H z0?q(QpT+smuKuY>6U{eqz?Q6a`I#EZ8n(Vf-@9qUd(p;Ty*J0!&vBx=2G8yn-C7yy zy%ehL*s!(tM)OpWB-)Sa$}RPd;t7O)3e z@NhSnEYZkLP-a&sAk1I~=YuTSjve-yS^CHm>x8m9)TsZ6{cW~=l+0Hw#Lvu}0uBM$ z_Bxrg%`8rETBN`W_30dlaibtCR1cYE@4M*~|1;wR5M%kQYO zE|8g2+)}CZo8-fEoBqCm!PO#iErds3_5yCqni2HIr(}J}T72?E7$Vw2ipJiKHOz4^ z^o~R|`iKD&cd7Z2eHpX@a$kwM`a4fC@g)w9_m6feItXLFWkyAQ=)zgW6_ufiikeVv zMRB+YyxC8(3z%Xl`p}knr@lh<+bXg{w!Hyb6?spY$!-~$M)G@(R|k!Xe$Qo0`9An$ z!R%wUN3Uw|g$G$@{v&ZwKE&@g-|AS0n1R@HFLoY)nJJy$I`bWq`5^qy1KfRT`Y>OE zIx1?!z|%&W*%sYmR0NF$Pbz|ty-DqT42;L)9>q zhE;y8ww0CU`;{oJ9QeUcr<+%D4eQ8)3emF!WqESY1$zq8&%iHwxqY1Ig(F#cL}v4p z%_g!yC&=%G2@)Fg|FQQb@G)NP-}ni!)S9u>-rfjeA4?UrOk^j^5V31!l1vyTnUR?g zbQwZPgQl&es2WP`M5_y>hEgrcL^su9?4!2OqPp<^UiXsRIil_JKF{y@{onVKo9~=+ zo#i^$xz4`ackq%U4d;mKtS*k=0{RK&`x$dKVgx($wWMu$EV+pjU40O!Q$rL-1>Z9$ zY+psZQ6m))nm3XS@C|-UazTB=cod6>lN`MpUbP^Bl1(ykEHOYvGYUW*Qmpj z&*lB_DG}a4;kU@)C#l1e&*cS5c$D8*l#KyOD=NP%x%>hyKU{vJa4FH*yD@Gbv6?gg zfbKu5K!l&K3sg+gtZk% zeD%MBT2PQh_j0r{52`enuKj|Rquj}{VEV1x!$A!gC0?U&3`0GjV{fG%_(m(iNF=I1 zFvT5EuxqhItgd2Mg>7A0#Sl9O)oii0`nKYBF4Zs8D_?c^U)fwFV3U#@zlMNH>I%nC zF|YRZp~`39On|mG%s+?Ol1rrVu12HPot8XwB6%CP-B+bq3 zrxQ!*77ch}B+12}I8!P&;UUTHA4of1k_P;JXGpB)Ftl7AgtGU&izcE7=QEM>GjK-x zL6J~x@ij%=Il!oTlSKMUV&~$2_`JBC=gY>`Xw-OB_?xKH2N+dv3h$J|AD6?&OW`q= zp>M8(ky@aZbP_XitbOoFw@N7Ppz;%IX457&7Cg#&kp4^teQySnYjJ{52m5DA7^Gjc zKQszuh|JGX7-HUphzCNdQ47GXHtr~~oZ8gNRjVm6eo(F-#Gyrg00c)*ChDc=QZ6|l zX<8}Jg)Wv`n*;%KZBCuQ2m1Qx(ZoNeP$&Cr#q8fIW>R+7!Fq3Fs#fB3&{Y&+M^OZQ z;_qp2Tj;@@WSuOYZfSj1~m|fC3gO(h=r8K`3 z=VW!{+v-#}#rqv$=jl&^`{f{FX0;qJ(bbp3J@7&Xg+Km&c(vRFFh5QSJzpm`Q^*PX zF*mF}l$ev?&B0y$u*NxI=Y5BeS5XVNyN{2^hy92NZy#K$%QAIx`~BWy^m*ijvVqU< z6y0-&PL%QYndi?t2H+-?Bvhu5n|VG5sXhNAM9V??nT>NZzs`BST23ZDrP#Pg(xUM^ z`}g~qYYv2q8o%-u&Zi()%yE*C+OJx+C6Eob|HPSFvBnc}4vKHA&>Q2UtL0|ap}%VR zd_a#=$eW{CZhuKtxzC@^$*hCV59d4&g$YGs;JyH^YUAyM{Z!!8E=UVsz@P4Xic8^= z#h3R{3i>+LnEBCcj^54D0!QbUq|u&HWdzD?up|S9WmSvmyip3Zj+Z9E-MN~5Q(R`r= zl>|*gA2nadqw%*RazMSzUCN1gT!QhPd@j>Vv}%6eh#^YhC#U!RU-+-6Mt6asFad+W zipn5VPVn;MZpAS7ZhIlAzfjgV-#;YF4D~dq! zcro?5`~xNoD*w{vi-&RV8@-#(SorXK<0@VqfeZ%ti=!~{jf65#WHe_G=aj>+6h@f( z+53i#{*=0Lq5>%fO)?Mz)4;A*FyuTy=d6;2tnpF-ONZ2Wb0YLO6<9?GjV-nYsd>ID z=zlOM*Tymc9@p?{J1E?D$LvoTsIpKQ4lpWLq*|aKlBo?KDjMyg|`KtfVbyVlWm}G=I;n zD<0?_!+k0Lz&a>fMUlR}UNI{*d^woQ6!ky3bv-y$!*aoMr3S^v4X*-U_C3KdWUXK3 zEm2utc^}(5*FPsm42d_DDzHJQe-LVgbap5mJgJhSS%dFAF}a#ELTT&|N0QR{f$tEO zhq?G0wp3(jsX;got%M_XN4c6+>7`EpqH;tbS}!ARPq6zNeRh}iIrHa-^||zdRH3rn z1~4bFef9B{uy{03$DxHc2;_^wLP>qr_#|NKb(CY_e`+ZxTX zNWariYz#Tbt$P@Ho@C4Mbo$~-o#OGVRDJI`^B7bf}2JRTS$R+r8Ka2=JZ95lU{2+-LpgzTn9Xn6`&~^YzYY zU+rAK^`q?H*`x~eCAT^_mF=0+U0mT8t=Ds7&(Hi~?r^`XdO6RY&mQaV*W))wg`6SY zobI{d;;pNX(U@54Lsz`Mtyser-5k|sxIxB1D589z8W&MNf(k66egS1GqUf5GmNH8mO^`SjOE828f{9~K zY4vLqSHI%SaykE|SVC=R(o)6{wT?nza?F}?+U9(|g^ zA6_E26G#T!+Mo)G)An(wUZEGUd>sU;kYW3mhYuf~_LJD7d+wh32zBm3PQjkb6~A&ftw1A#-0L`&syK<-{z~NJ z$VMp$qC*lEo9G`Q*A8OZo_O9p`!L7LG1R0>jsT)+Yu2nv%tSdapnW_v92n3leQi(%~Ij3cPqHmS;Nt&fbXqX%6LZk6Dpq+MErPmN#RH@RR7O6H> zr4Ui%r0*rwI!U$Bfd(<>xG{=^_FR69^hqOtqR+Qf(M9!Ti_sk~73s4UQ~-TGlGEj3 z|3Ht+FtK?^kM++&kLR!t2R$O+c;(~QqB&h@`Ye>^Yni`2tj}JjXn)8bb&}d+{e8${ zW+O#=Ti}TVq=}j|{;y!FIY|yG@W}7v!MJ|r=guHkzM~^LJAW|}1x^-_z&)2uDM z&wE1B-`o*e8fF(DQ8HAq<957BlC64 zntYoPwnTE``T4Y~w2PiQBk*%F<_8{z0i_Id{2=KcVwcLuuQVh*amV(1$PjqC{1_K^VMhCImn=r|jH z2Gg(PoTTPUM-d9#_ra)$g=KeysVV+FHOTIPW3G;-3p7EHD4I%Wi>P13D&MZ=j5iSU z&J2+au6n&k5wW#Imj?RLKqke8)F4FZb?6AFPF052*KneY?vq5P*|fN+$9b=oyxYOq zUlr>*oDoB)1TNyAr_RGPtL7r)<8mOhLCNG??;JvRL z>g~Z&M-{}^ho(J}kmM%Hjkt@DteAOi%^8g1VzWyQHg`@S&EJ&JJ_{;6gcfRkFeC6y zc%V8^mVMhW*5*hvwz()zE?*ZhSfRN+=Z8UF7K^Y_{WBcXu8x#-IQPSNaG&rUI+JGLLxKl@XnLetEKtl0)q0=>-ztM4hi6g&n z=*W)_1nK+roS%3ch}R-A_u<>VIKf1A@u6bU@{B;LX;3!)R$_Pj(FJ$~IkIU}e~#o$ z6&bR0U4_Y9wzo3;yJvP$^569%xMmhrW+|K5ZsATvKS%l8aN1p|v9uTyl#f_=dr6yJPz)6aWS z>zZ|yd}jpChjI59orC*%9#+A(q#iLEeK};F6orzdycWPLkK`dj(B;vnlEqcLBh)Wu zx8_XxU<}pmnG-Poxa*mK{s#-A68ZA$fZLhw?|;BA-e zRR=HIJ%-?4C`zU-*8nDkfDZE<8$kLYchO`TKY!-uN3X9u4+q-S!UYVPqOu39IxK!K zlAYWU1a6NNxsm(Bv>1niiVyK1{?yIW^FU6of*%84N>O@<4~3IbllcB?bX~+pE+DYN z^$*Cb@Gmp}I~oXRVX)``8;}na0{=?Np2rcsy}_cd2OjMZAEvjh!Q!lMuxMdw8-Q;c zgT)0i0H(H~!IIY+ZZH{4Z6kyY0u9sK3Up)m174sIaKcU3#9$F%I$^p251@YnaR66K z@OcvPVCrBxfjpp)+yu~o8}I-DO~D6n0&ajcLma>fcmbg~@&M!mg@85?G~fmvr4yxH zIt!C6bhVBq9rWnTsLLjx{-(Vl?;g>tUB%WjOISIM_OtCbTJn}cwv&*dUXsQ8oKZ}x z@O#Lx39@|x*}pMZHliP(wCE8VJJOISsb3HiE&D0cK$!;0G*G62G7XezpiBd08Yt61 znFh)fiex0X`oC4 zWf~~cK$!;0G*G62G7XezpiBd08Yt61nFh)fiex0X`oC4Wf~~cK$!;0G*G62G7XezpiBd08u-6P19|xK zJYM{z1YY3Si@J}uHrO4?yO+`bZ)m_`P8yRuu6?I29a1b7me_w{;vmx)v)y6J2(cLL zc9UJs=FATGMj6loAiGXB$xcY%XvJMIZGYphgnN`(h;Pi1Um@U?d3iXVZjR=8<^PR8 zAD*XOa{N4)tdk^&rpu$d3F99e?B}< z3v&Dbm`t`8b}XrfuQ{6MvG;HM`S3iQFUNPm%#-a-j;Dj8c^*lBo#HQ<{N)A?o648Dw_@WGe8e?24P(^!|;%I&5k7e8fjL5hryOZhV&T zbTI5k+5HFMjNR`CJN-$E?m#cb{^-a4Aa|!2&YqFnG1;1yW=-#CGbSe6GA&kPN{3`- zH>TMvra?xBN$4X`Z077M{tmkK)y+4y_oY8!aQN`mzW7cl@%=x3^wtbVaAu0xDh%n= zqeHh2+V&}?i6%=sA;UD$Y&Toeg)Tk1rJA}Xb?ernhtbrdbB~lR#%|r8O6p=t?QVS9 z)Z=ORck0r^*p-#cN@|8R-GPkY8EdsWf^FvZeaz{p)($DARAZ*a5tVMsbc7<2WRuWK z;DeBJh&40a@yPgbnT~(PAU-oW*<`n~;+&>i9fCRC>@XWG<|(EWmXK~tcbJpSHfTFV z6h$y)WLPs;RQf~&NfFXB(~?XXf;Cl09&1cbH(BgOUQ#&;8Hifs1`R^|A~Mxt9K+(p z@)T078EHm`KoZz9Z8j($=|@>CrZGl~fO?Q*PB%J8>qslAW1JwdqU7wEsi~0BlnbGk{e+f2#kR5K+i=gscO zFd5SXo7J3-L5~eJnjM0}oCZZ83PQm#9kLZ`Pg0Fsa+&GIiAJ-^L^CK! zjludTCCOw#PKhc3i@p*&t7`i>MsgRjeg~b)qRF)nc85U{bLQndvD-PLZfy z0;NO|Q&DM(Ge^~myci2HrnhpSQX5kQ)XX%&SgadKE>tur%%lu68lA&hYLJKdps2)} zC|J`iljS^?!Yds$4)wJ}s1o{;wNoTRhU##co0nTry3< z7-SZOCpb`Lg(;>CYinvt{NvC3*`4F%0s2=?HYMuLaX*e$+!fQ0{o~$&5_WzZ$=H+< zbLo`6(VssdVroDyOgy?7%Ble6*HtJWPS~;B9Ye;>j z+*r}Qlp2VonltQ5v_}Sl*d@ZXRr&xapq@X zq5dvE4~JqU)WgXwDWQ}|T)5KnS4uo36LDhoe?$&T^JGCvR8cqK8OAiJuOF!$EwmNY zS)@3XXQ$Dvh2Fh|qR0|!Re%z)AM!iAWll%SdG0yk zFN4v@j4tA@g9Rs{b7!fPIs0I%UaHtscWE$p_O*{UfeAW#GjU5pw=VYkB;vpHQ2QZm z8Exi{DR%1oXdW@ioSv9M%}B~^`#zJjPk&V)^et-o zRJ=bxb~5Q3*z{372b^qTPEXQ@0!DlrX99of5+EELlv?_P&3tyLl`oNl$Z2z}ffez>l7od8ME) z{SN%-6Pe!AmxZ>AV9sYESm?%Z*u&A6M=*UzgjDCm#dD~|5@B+P%jUSGai~~KrNa<$ zG*Y{SVOC|LdDGBRU4zxGa;11!Vot{#B?4wEmq7R!JY~W)24LdlVrl&6oRE; zR*9)11T2wHOg*OEfyg(6UCS%gi4AN{bMkW(z3y9RGbk#&1}jr zvEUSI5`L+0L(OB%DJHvlOu7<^3hm!`sL!SLOYN8-{xKDp%A>d|rsA%c|89Irk9aHN zfYe{muLN>eLvdHke?2}Ja?gKb{80K!X&e#93UR+#s#or#~qrZM2fR+{KFRYFN-Fnafi$U!_7xA9`%)l-NF3mJ@lc(T-c8pROpu<*nFfEYrGBlH$p zq%fP9fW+FGG)|dJvcHlqS(=ZP5HQtjLC?*?gQMfau(%u$v+= zr^TL8ytH4DENwR^l(a=c!%*=iO6k0mC9^atD+|J8X=jPj5H}7aRYTHLE4MZCaK3_M zjkXq2#i699V9)5?BC}ocSo%#eJM1w3N+0sPpj3q@;>uw-c^}eokW~AMMS%q3e@2@> z{7gjVX2-ytN~88a$y>TraA1U%g%vkfnwAoem!s5ZEQ+P0l;T(>qiwwwjLudB*~H8- z7E_&Y?9GH=nlT0&Ts<+LNg6CpF^raogs4zz1=_B|1Vm#)Q_|umrzb~QlO2|xf>b@C zth9v7uv&zO=r9De~{r z3y9P+TQi$EJt_tLfYNS2OB3a&g*YpcHgq;sz6O6`*9y0~KbnEGTi5oJ}q_sr(cwoMkXGGr>QF zS=eM2%Zw}yG*)32v`831k$*mPjAB_cOkXR3BiLPbllq`9Bu@^*f z7%dVd@!5oAtp%{6hQ&6V0ku)psk1mgLR)29xT6W|}ELGdu;Nt=DN zqbzoP7TU>W{b+(tJ+rb2TGT5FlT8k$Pe_ap2@VfxF|1vSVM<>?Qe%Z7?uiuF2e~fF zT^!YjQoFZy*cBg>F7|UaRQSKHi$%K)syc7AVfDe)GIg7v##-c^mYD^OVYBlQ8Id|m z%S;lZr`pDnMI}3?J=SDeX-O3_N!$Zg`BR%!dkH~9v8y;} zaBJ+{PsGOcWSa>cmC(1ZDoznkd0>&5qO}$4jQE!D7J??39b>7o;=}+FVP@4@6+S~g zC&!9V+VW8c6tHQVLT3WS{KZLw61Hf`S;QqMDlTMjG*=&se5I14I$mlj52d4&yt1+_ zVx%M^cQ9DBT9cDAZDKp3NnE5Tw_U)#E?NjWP-$+^zK<-qdLo6*$`V1OM7a>1S~FB4 zK|Et)C4$QnJaL~;n%cGR6Nv)~OeaI-eQqrqZ^xoOLtK~*uuJE!J2>h^e@OEHK(-!s?*vfiRiuX@{{mR84^<<1fR*X<%@tZD=KL0fSzaOq# zxlp8NXX7!eAsGbr-Q3_NGlf~L#N8Z!fm`9Yv|BPII<>OKROvvqcxjy_)=b7hU zu6(4JKIUUZZBe;F#fSZ$q01LZKyAQ^-YFgR(1bops+o33W)bT{$-e79Cyjr3zCS2g zD*w5Z9>u9b`9a9J6)jRgFRiW-kBaf1cCT1IL`*+T)Iasl#-iTfzavwn^3g1ug*~K! z|6XnMs~9ZzeOB}X{~J%aiqsd60UXf(Lswh>3nG=T7%ldLv>yE5dHhid#WR%u4H+s_ zjAwd`iczSK|9j8WI-4WTOqt(TGH3K%efH|7V~)Qs)2sTn4{3bmY`2E;Ip9B+)0H}_ z;gO`Hn$_P1{oua`EBW^#BGk0RsrdZNPjo1zY42WrzGlo!K@%u>n5HY7w*yeQhUkR$gIO8Ui#=dF?_V?ol* z3#3ImIBGwk1#W=Rtqj>u#Z%rQD;Zbi&qr0WmE*?5gfUzz7!(!~2WxC-SZHEYtUh6I zVrbZqsE~*J;t~d{JpZDeKgx^FmZ%L?0O$<6Do`EJ0JVX7KofwLRajmzT3}Vk}fcppH9fSyySGmW4b17tDN~lC%?kkz!_pS2X+qT|S z4#?(*vild*&xw!zn9NeXN7Udbc#Q}PRrv%*4+;wo9sUU4p@ZULBNEYKMgEC{ zhwH;sai!KM@PpEMW7OC6{#%*{04_5 zh6hJQmtYhhHi)`EDW!ziSWb?xAz`tDBZFf@qop8W!}K^8Ex~~kB`!94cu5(M-_V4j ztPYBblkycdFd;Zvm1RDu_^`nx`9#Hr#0^6KJvdR;Ag6JaYhu`-L2>F54ACbf#0N)& zB|_S;Fm(Q^gyncrl!x6Z6;VB?w-K?Tf{V*ZDSWxKQKZOT5s!F9(y$o)U}!~&7oRAX zuTt|%DdTvwr+Bm$)Q|YVC|gQ6Bu;8as%F$vm~71y(r}_H-kTOeti?O!L9KBc2q%Ol zL2pcq!_I!Zcyb-onkB>zh>aT>E68~+F-I}l>B^#fS8>b=xK4rz;3+D?tjz+No&oFj01-bOpAm><#2&qw*v-TAom(tTCCtPkzd{+oNW z!SQs%J<2}RI;mS%`M`qVS{UYdxHN!==G@9WL2c*#{NX_J2)eUKa|ybe@)%GBpm{|# zfaVtJN6qi=;;Z8+c0pkEVGodL{`yX3Y2Q3VI%2?;Kx~?uaXW%;c|_18j_EDN$@GeY zYL{KQ!YRZU({ZICLrLk;rfX5MJ#TOU5U_OE}wx9$a9r8bLF>i1tXtMlEZp6_2t*|q8O zCoZ`nSDmUqs>i6W>iw~C{;lv%*`aH8Z~Ae~Uc=c1c&^dZ**52D=*OY%3!uEA8tUrLHj@q(w$*u3E^kMo>#d%buLX)TJu{%$-dHA6U4F>lmk=dGE3umDLBc(`V~V1 zJGl|OGSvS6s-5TmSMhHnJ%SRZw77*Te|0#LRiXbCQ^_mEA>L|~mOh0`jEIiw7aX0) zf{f|b^vP+~Ox#$b4j3nwCM+s%he3B7SUB`a}$)+mTgp3(unllX8&%?2Qa7Ko4G8;LXO%z|-5HC-&A%h1? z7WAPQ2Q$UX;(|IvdtAm~bOV46nx(Ks6qOd|l$tI%phVj%{gY#CX8L$sz7W{MF3Hx3 z#tbuFmPC(=w>)r#qbTq=+-euZyZ;i)F`2j!FNneEZ9q&91vWT39vv&*FH|nN7dubN zFybvh+_I3bz)LQ?qnIjX?h#&z@pu=LB?jXLKpIQLE)(8aXeTh-PQhg@y#J|K1ZGTOW9%4waQBp% zv)F`8CiE0ox@nTYGA#@*TjEwUlP;*DU`$L@2TfZuGax;B`DBZDF(Zg|=+FT-&CPZ; z6&JYDnzJz$YZ8Wqq9V0s*oE{^Yei)0W;_rn8)==maZvDmXR~wB+D+~ z`B>x;m>Yw<0L!8!UO_M;;lFM`lI7$6$QST_RFb96q$Epu;MT+>%Nd{r?5OoL{X``Z zCR#1H5Q7UYQo*s7Et&LgLzcksQqmYqKTucEzS}S%F>xZcK&=@l30$LaLe3Ze^RR($ zAz+&ZsO*KHb<>k9PNeCDSvMQ`0JK0pz{{eYA-Q=GUI=0-4rX(p-qSKju;9hm45NkS zV9c255N}p{-bu3j6L?o6{YL>j$WONhG67__!F0;@hvLDV(iGOBi~;g@!psNq)}h=0 zJ`RQF-4t4f@c#r9o)4$+Q2RNM79Wo2Up72i1~nhv{sz+J-Tsa~rAlix>^bY9D}dtF zgL$eH9a-c!5vsT~U{})Li+BO=CRtkM|9d#IRf^w5=H-^@f0yq+jqip0HdQ|AyeG-? zGu)E4C0T-jzvCq!%sn~YF_>Fr``^V={4J$~f2tHWCH!BRJ0Z8l%-F*1NtXM-T_6ys zumgPp%r-D*1Ji&hfSo`KC;3_+M!I5~yx_B&lM|(8kF5k1A$rRm4+ZUoE9M#P1ks(W zi5PcrAzpOuBfA%+B)JNGs5|M|lNR>)4uM2SDauZN$rRB`1eW6C#7AU?{#GTU?E266 zDJ&%66siP2^S{JU3C%6z=q7yEx05Zjx1g9x5F;$VzLRXJp)xD2Nw(0QOcJ1hoz8g_ zvpHzmqoF$vTG(mNrWZ^)cUJsRO<1-ZE)QlW(0gIhz7BQh9@)<;`_)=2`K7>5knLKS zok1tVB-xCytYvRzjK@Ke(a2gdBd&bm#sS?C#`2jNr?BK?43C(zCMM$oIK$3havEy~ zC-wqM8NxdD#+&Q%N_gaG%$AZ_%4E!DPzA;Cxcb|MrC8(;@VB!LZCD4EG7-mEra1O& zZ)UQxXPIdN>)o4;F|j`Qb+A6n63=?|>di1r<5!u?HESj?e88huFJ^JDUMww&weQW+ zqFEdKnpu06W?^Y*tbKcyZlnnw=HTfj*0eXnOPTl_NmG_SiJX~r5PJ?xt?aqy7#h%X z%ofes_GUHkAi=nbwGSYBD zmtluLv(uZ~m|(~Xu;W~nG-;p09Q2+d_9>VH|H&et0RD|9bX~F~0-*gtLVws}0NUFk zI*$BT7W=nyC0ho`{uE{~>DCv$WvXfr_jFce-3eh$!NCrpBU3ZSI_ z9PBU3G`UTKeFmU}p9TBN0JRD7pAY*YfZ73tSq1wVfcyySVBZMP{wC4eVE+(M_&tfX zxC1o#k=st#cdO_cPp^$$d!hy4=dRE>`wr+Z%i@0u=fB!ro6shru2RP+SVrANClPzaI8@m45>4!vIBpqhL=26#0{2SHcs|W+;D? z>`!63p*+TdCO_ga4)!#azYTUfpzxmr`xJmSv?+cr?DGIc-aOb}2gr}G5cb6Yl^@aV zk=|<1O8wjfyPD1i{T@L2re{0sI|16Wr!@G7UbV%lkVa#cWVKqv9}{|L$z?J=Ta;qW zq|f(Y#XLrk?fBRZdhoLgCvy5rYMvsr|5)LHP%{qZ<*HDWb4*du~B+s@kYIv%}(7Cv2ce5x^#v` zS&IjyW6f@JWVGg0_Ak-i%~IJZCPlsqH##%836si^a8Gu-FPm^;<+n)XrkK=cR)HJU z1;r${$Kgiht(fH27;e;uDkizLf*XzFiU})w3T{+46_e^n54chP7!H%-QN1heiGx4o zLotcZV7O5lib?)SG9Sf+6B`dVnwuylx&1rO^WaB1P)y>L4L6#9C?>g;_PmC0B&TB1 zSg{Ch>T;oY%i%_TN`5K5b#SYtGO3+SKpQ1pC?>3IryN%?$?Y@QO)<&M12-x+#U!^M z;70N(CY6a7ZfcXlU6$PxliY5>jr6RT%)&f6GcKE)mj7WtFf;}DU)5xj65b1zpV5SK>AJW@W;s#s` ze8&pij9tK98xAF9E+k`792{CYz(2w$GNp~Rq{#6{jq$|*rN(tLbyrn!Iw{@)ylRHctrEh=)VEi^t7}zK8vKygy@A+>WQ#Ps{kowbWUuY5tcv9?h1@ z%=JZ!FCVYHap(EPFIJ9PGS6{tci;zSs%clr*;3ZRonJQ+iXqBzw>>> z{2>c(wTrE~EIW2<T?1NwTU$^CF^SC>yr$@b;c)j+40^PD=IT=Z<%dzCZ3V!dwty8OA1M_=xKOt&a1?&TWGQ)&+U{?yK?^((~e zJbd>;1H;~7`wEY}_~HGxW2V(R_xrVdrs+p}8STIQFu7m$kf^8b>`wamyW^=#?#A7V zeShVM&X$#{%u9A;PYbwwB660w&gQf|^{T9V&Q)p4rtft5lj3`By4L8ocfQ#&?Bw2K z5zBYqupJ&X+!XBGv}VM%&C#>ozJ6%i*mY;-`uDulYIm);MV)emiN2gChb*{g?Qe5M zyb`!~?(5bQ5iM*hKQv$18@}4V?ZSh{TC8aJ;rh4>ueFSLzf-fY;bYo2nEvdwO^*PueSS{u+)B;OHtGoprfeOp9|zG`sgyW^K=uuWz`2xQ%wtF-`t-DgCNk z`05;8jib+W9@k?@)VsP@1J{kaZ<{!##%Jf8^FKb`|6_0UP77{)mb|To_0!p{ZT;t6 zuRPZ+kI!dk6G>O*MI9cukMmLGd<#ZEf$-2N>UbuVsevjtmw$z`D*wZ)fMemU?(n`}S%3n>C*N#>lw0b6PD<`!Oh>!|ePKj*Q2{W<4K! zeesSs&zngXZ`_?Wt>3O!zxdXF-H1DrpY*%IbZNR-TXz56_tRxV^P)93ntT}>x$wec zN4LD%rfIv^``oDd^}x6}NBh2U^W9~mU+aDF#_`h`;qR1p2sr~by%8||&l8%VuMSv# z?(WDbXD9ET@a!8m4t(=)XiFU{)HE!X3ritqC#Qwl;fR74eWZi z_v5ZVHLf|Y`fjeD+;(5j^#dZ;z0&UIHtVVcX*Grp1LK#)%=2&2I(3I<@R%-ZM}?&? z4_i4kVtf<7FS=a{c(8bD^Gea{3PyFV_+9X}n3{cd)ca_@Ze_tY$&)X-e*R(nMtL z+qGjF>bLZ39lE?=ZPPg|=Lv7$h@AN5$v&~~r|R#u?w;ffo;f-&q(`&R{1&y>%(yf8 z!#}_Ff962r=5ZSu7j(&Lu(h)s@c(!HvpIh&s?T<`ajjW|z^!+P3O=a_o^+n%Eh$o}Pcc z_UPa0RWCSw<(rdXv!*QRda_{D^vM-JIZ!Xi9J8$4z$Ni7cs>hmUFY=A!s*y0{ol;~ z>brUcGe(?jKVifRA+NUiq3WEhS)Drx6@Thl<7V8_v?~F_yXb--x~dbU^o>#Z%3uRIyK^D}m`RloHWhkf_jfWQ$0BUjm`jn3M9roq9L6Gyv!9d#?Z zG#wVze%Pk$$YxUyzc)E%+VX5i-FBZmSK)HVV(pSWu}c?+o_uEF-Ibjh58JmPXHnR^ zwr{?jrJ0uzF?aLchDWo*CG6>-t(lRtMhstlz2-`yx+@JI?;jQ+HDZXPj&Q z$?Mf_?jC*Msf^IM!^yP$tMV+4ub9c|^^2zk-;lb++ zaZg8mZ95R^-WfLY_}P$`DqOGe+2!%W58U`&x2!{pm=!at{W;UIYbNTSd^SAbgPsu^ zhOvT5&+n^Wb)B8jehNy=r^uCGdpzcy?!r!G4=NPPN$ny&VI9T zsB3cd^GDg6QwRCAjT!ZPZq)3vUAxA=wsQZ#&hdjknI0Iqa8JYsRUOsY-R}CG-sXm= zg(tdf*fRX7tMjh+&biUn8=Ujm`=cLgy)fF}UT)}}{{F$Q8P0t_DDsbPHTKSE+kDgM znAd-(@L<;qf2@uStJ$lsJ0^Pjt>!PB8k;=PJ$~^*{idrCuRUW8o)z=`6>sM+r*+Bt zIds<3wrM}lebTme`JCpPs$2`s{$K059H{q=rZvxB!*9idtDc2-KWWef6Fe7ikr%j-LRGdFb^+5YGc z)5mj@=viNoJfj^pn|ZK0AB=6~FeMgm2p3h4w>?<8 za(%s!-1!66-+$^(%=(+xo4Tv^TKjpW*md^tbq*bB`$FRO$1^A1O$nV7U-9u5b%z)0 z{iNQ-Eg9hhIa*+}BE*{l;xD~&Rg#Y6!bfm)O^$BC(evB>H2?5rZtX5e*q`Y5zfC2N9(#2HhX?>qkwrP%zxSzG^pS&?OrJI)!^ug99@&6133Q9=mPV+ zJs!=vBh0X9esfI?&OiINC9S4K9nq|Aiu_i+V0ek6XK?iEFI3sT;ODN9Z{2xu-Leah zrOxF1qgJ&T8<;sg=CzvobK~CI@WeE3{WYDVf2qEheOx^wGP_TjwvTi32UDUCUE6Tt z@qVj1SoFiwer%G>g?}w3tw#4TM>Pv8qrApe-^RH7H|6rzmZO_-^r^hb^Mei_)41+3 zXX4CPwz5;ZY-)X#=faocXn&5bz|qfebPtZEy(fCy;x7xw0#JMunsKy0mtSG)t;Xv5 zqdVBDQ+ntT&9tYWp8+2YY#^~K;;-ZAfWm`|pA9~$nOz6r-#6b5wUZ3+Am{P=!Y!1ey!Vv51hAp_C4g$8NIl4ASH{j^H9Nn0sn{ae3j;_PeT|aLyck=84P4;EfzrCM*?J?i}=9%FQ1Ku~I zzi+>LN<%JuHIA;z(O+=&qYCH$7)KxM+3|;$I$}KZ7su-*M>zU0M}N9<&@ip3K=Z-d zIIGW`dhf*MCHfviK(CPKgzDWh+RlADWM=KQ=|9)$difhJJ=d`B*3}C?s#)-d+&{Nz zm2jwEaevg43*Vii-Q$**9Xyuphe&DQx?uUG$kHyg6GMO{CSW_NYS_tEKNQC#|=9Nl$X zNq&EDbc30$VV?&+6}4@8-{Z}@^o(oC#aCVgQRKsXq?&p@(uWJbM>jC7o8ySa*%k5` z9{X+2+>u+)9Pnsfa)RD{TO^z<)XkEzJp(FpO z6}~ztV{60Kr#Jt``QPB^Nu2zDa`Il|U*P=t{ayb}^UXJ2_h{ZejPavcr-j6m8C6X?%a#O#a( zTb5Sq`juwGkMOUu)%shfx8G{C{nxP9X6|ZxV9Fn-*n<(3)!z^4J;`Sp@(TEEm-smY z>&3qs;VJswNV^kFj)p9P|8>dVZ|&kWX{)63nLxiEzh+;|c*6EVad=^K(^hKQ^+J9J zHGOC4*akB`{WEgYz`P4{Cf}{PcJt4Uv5PPts09Ac?(OjGwVD%$s`A&KOTPn0-wLgg z-Tv+I5uYsTH)DwXy%Fq9=cd_Hi{<(1%;+gA{Mvt!9)yiEHS>4!{D zJu|4=g?R;uBe~zQSt(Q`>{-++zs=kuGyc65pt#ZYq*?1mv zjKh!bm{IV?rcc+yzp>=+S^dm%g+fD^9O7 z=ijXV-1KUlJem)eKz~n8LHC1D{)1;`(3WquX-wwB%^IbE3}wSx)~eb`HI?u?O16ZK-|Cc_ZOt6q!oFVL*dg1$a& zVn{QW{Qi`{$=i&hn{%|`s}`3ItGuIQ>7zDB*W&1Gu6!I>_zMH-{B!!7$jR>v z92^RRulLY^7gxVk+#cKw+tq1PsW|@Z$!`W6 zdJpY+9@^`BJsRn@PY=KGnMbqmIP^L2LX!yz-)Hth_!UN}{R^ieeh9jQ@(f1(tKPQ4 zK<<9Tyy5$W&%g3$=KcYBzH{gLEgf|ANmco`d)+!`!X=O9qX$y`)m^FGbB(rG9{&4d zI%i&m@Xp2l{P)PN)}6B=uV^`Y#6y2?K|B>m{Dt4B2}@NskM{|=V-n3~r;rg?XYl-`w2H-4=2y+^Yk zThhOCRJ#_JRr)t{_~IqHpR-#2o|-e{XbrW0w@JFEg>D6!nO|YN%M5Y455)FR`?Jv< zQ`GY#e!i49tlQGW$5B2DB>9{Tt##Dl8&+&uG4r}dv%Rh)@5Lu?ovwKobUlf_#LE;AJKB&4=gYKg;=_bHM@YXrb{|r}NJ}&)>TzF@@#@XupzPsPyOznmKafCKY+fL9Ha`A6+v^S{y4R!nr zoW8Dc;V*FdKEs7S$Camd`-jWa?Qvt)*e!ik^_#tMah*DSL&MM$YJIvl*)OQ$yKXE! zq@HiP9G&}3%PpRN|IEpImeZ&6LZyl7^1I4~e@Nf0OVG?de@E>eZiKuKPue3h%nsKL~52@)x}C zSayYYG`q&Jrz-3zzpg{4b(1#_&kuQ9pIad)dP881x;rXuJ&XCf+~2xa)jC~oWAS(( zd@-!aQWdSM@^XzE<2;(TJXoI{Z1A3I^ZmZpaXze!ADXUHLku3QM`*mkdZZ3VpPbvS z;~T*n<94(*eq7&Med+vaTtP!s{^zVpSew7(YZay{D8nx-g_6MH{|FHhS{QC#%&XUU8 zeQn1lhId-;Jcs$qTW09*yFDWrH{Z!09Q#_$Er-i_8+yc@k6z`N1fgm(9H-_#+$D((HAFQ&(cFmvS#s`2SRW1Yg7 zg7CF^FWn^xm{)s;{_J=CUwZs#!zo_}T#CEjJ+krLfw6BLo}pc{G1}5&*OYI6o%U@1 zX@fG(J@G}Y>si*7XDe;?#=c$i$l%)}=6^ZprGgjlS39Q5Us1K*Yafh_g43KacBRJUdyWy^8Q;Nzc~Kc#qr-xiQ1mk?d@u@w&jn4hCyWhmmOfiNA_2TE%Ii^`WS*mY&RqXG#Yj{*M zr#b5P__1{gzv<-)(}E6_=rfk6rH!V6o+Qx~xb=mt%bCwMqP;2iwRN0-DCd80^R9*; zjLnXFeZscddCyHMxr;l0&?sQy2RDT2XePr+7yX)fd@BTJ25#Mf!b&T1z<3 zKz(suHCWt0Az=8)V6g#CAP;Z>`G6bn0_=*xq6G|q4R8T&zylNl3_P@e4$uQOphSWk zu?p!cPP*UmO)Ku9y6w4$?|T6H>-gRa;QR^SqPT+ZfWUOZECje{MdU|+!`}^m;S%Bl zJpX{J_*Mj9xb|rNhY??oxLUxY3U?gtPPiEWugd*A+&##H8z@w{7s8$0Kv=jlg8Wc> z7T_L0P`NAq)F0^Jrv()G1%%T95g{Qxg`kMogw{gW4m~=E*M-X57%S63nGUG^l+}YW z9sK{T9w_~Knfc$*K=WHIhEYm}R{rAk;j36Y5rUXMJ6_YD&3+P>0qd1xUR-)F1larK zSpXmaT0jTr0RvzIoIoDn0`dVj-~qfqAyDl$czggJfBZ~}RN3&;oDfCumbg#h~q@c{wQ0y;ns7yujK1o8kE zkPo;458wp~0k$3S0RhkgIzSH?02|;0@&Ff*54Zsj-~|c+wgd420nh?EKo1xI8{h=; z02h!CxB(B~1quQ7G2#OPpapb*9xwnlzzO65E+8Lp10KK&6as7~;sXMp1$2NOFaS2d z3FHATARll89>5C}0&ExJ0|KB0bbuZ(05-r0=VQX1V9Vu06ky; zY=9HU16)8p;08Q^7bpbSZo~%!Knv&qJzxNAfD_0ATtGhH20VZlC5C}0&G9x0|KB0bbuZ(05-r0@&m% z1V9Vu06ky;Y=9HU16)8p;08Q^7bpbS0mKIcKnv&qJzxNAfD_0ATtGhH20VZlC^&6zyo-JLVz7dd_VxSfDX_D2EYb5fjqzk3IX;b;sXMp1$2NOFaS2d3FHATARll89>5C} z0_-H>0|KB0bbuZ(05-r0=fby0-yzSfF3XaHoytw0WKgPa04E| z3lswEG~xpSpapb*9xwnlzzO65E+8Lp10KK&6avhP_<#Ut0Ue+R41f*z|JZvQIH|_} z|NlDYti&fQLLd4N`Vhjonfu#jXJ&V&W_QNS>~1Ayx82!xwY#%sX1gIoNeD}!2vGKt6__lVBr*Qv4nScrXkEK|SaMQ$aUa0G5ItumNlZy8!uwBmKb; zU;{zW1SWx5U;$VT)`2Zx7a-e^b}$I=U>FF3de8}`f^M(?ECoGa1K0|70kR$UgF%1? z!$1(!gHF)Bg^>DBQAD8h1N{CBZ<*PKzj%3P&ko2y=e_tn4u5grgC9@GQq0~hg^b`_ z&Qcr-smI@`c(Kp|ykv7K=mzzm6AWs>HSVkb9Bw#3){Xm0aZeCT#kw0^d)o^4QrzE( z^5x-=N1Vf`fBJhd!bSL{xOW3aGFx#!f&Z;Y=h6ZRgH3QZ!;Pko`o+D&;BNzdcY^M7 z;Ro?91;ac@3)0IYElUTpr03tr1M<;%GV04I0AnkH-@`!nt+@AY#6|Of!@wI}WzhFA z=nEOxRQQd&2Jb_7Qy9{NHQa9eF2&!e_}gY#qUmpu>gMS0q;iKF351t0x$d^ zy`?m6z~j0U;S4(ic^itneh)vp5&t*vkKd(W(6@*Sbbbf$w{#c$gQ=)%yCCC153W1G zE)b;mevNeEZ#U%!+ykcm2!9B#TV*N!Qg;1@yzhk^Y^8sHhyOp2hF=wW;4bqe!rh6u z!B+g{zrua^P4Kr9*Y)%-mMT8XE)jv z{tg1^ztd^E0`tKxuov|Elp}+|P_Xh!h&H(kZuqMMJQxawfI(nbDcbm< zXxE5`;5UKnN{r>_frr6!;7#x~*nda~IT2KVF(3(Mf`#BI@CNu2FsGD|e*!%Sfia*H zTnX+1kAbz|Bk%(_@YE7=0;mLIz$7pW+ykBi?|>cPz|%^|sbDxb4_pQA1M9%&pwG|} z@^9b)jo>n{2s{bi0=q%K(@Tf}G=ZsLE?5R$0-pf(j1qDzr~olA1>6W$fKA{BaP*la zL;zKw9&~{#!L48kSPk9*-+@E;5^_55f_iWPmI=O5$pnon()lQ7;rJT1v~>j1^b&z$PiEg zTEI-O7_0@`z#rg93(5g_z$nlGt^#+19cy7X96Fn1x;WAxE3r1E5KT?8GH*$94I?*3b29zs0S0k zbTAJ*2v&o)z!%_8aEP;n90z#d15IE8xCYz}o(AuOU%?T>O2|-927;g-OaL>$?cfQp z9((}40mM~827uFn15|@3=meL5Yrx&$G4K-j80-cImz9v?feuuHF`xrn3T^_6z>{DT z_yHW?Mjn6}gh4y#1`mRl!AIa1aF_?}5tu*)2!pX84lV+-!9Cznum)@dTfvWj^WuJR zGOz$YXaN_2+2CIAEO-li0=@&J9Q6|n0S+(%i~*fsI=C6!4OW2X!4~i%IH&?`9*DpV z&IX;}B5(~@40^z3@CEo299fBS1~%Xa^&knZ26uqR!K>h7@DteIhdKs^038?(Mu9k( z3T^>Q!CLSE_z@g39OVZj-~l1f06M@Fa1FQx+yfp1Yr(r<7uatE@&wKV6<`dAgFC=8 zU^h6{kFY@n7z3t&tHB*$1$Y6x3%&y-RnX~RC@2SKg9Nw|+y$Ni?|`oWQ;jwVP6NY0 z9T*R$gFC>ZU_JO8{0;^Lpf|v9Fb+%u^T2Yj5o`my!GS^a6Tk*)!FVtY+yb5iuYhe} z4>;_s5;7PVK_wUuE&=nv3h)~E81xB2UjhrL0T+T<$A?irfESDcG2jYtH&_ck2M5%mtU&-Iz_s8$ z@FMse98ib)2mD|hxD?z5R)E*Q*P!1>JOeNSj0fG|F|YxA1Nx4F{sJSwcrXh*2-bmZ zfE|sp0cH>aZD0mi1XhDjz=3C@K7(_?Ot1`W0=vLJ#-P4~;h+V~0Jno@z&7wJIPx6y z$6zGr1T(=3um!N^qRjviRDyai3Csl#fak$G;0I6|MR|a7FcwS#*Ms{&4|osk0{hn^ zOke`F;CwIx%ma^u*T83hX+V7kIuHPD;39ApmtOau3V)!;4gCpfqT&lEU8H5dz0 z;0ka%coaMjJ^dj)+ykBfo51IQX@edD{|08@2Q6SamA3plDBdI$^$V?h#J z3GM{T!8))7{0I*0K>Yxx0xPHk?cic?Gq?{t4c-Oc0xpg`0s*+e*#O9FjzO zKmfFZtHFI>9oPo`1c#=ehkyr+22;QtU&D z$ABG-2IqsT!EInQ_#7NQ5q$;-fdse)JPck3--E*^Aq-##5zqx@fd|1$;7d?C8G0X_ z4bBJGfcwC!U_00Y4!Z#L64ZbxU=er~>;Qc(gpCO-AOa?WTfyVtC9nlBQ(&6_Cm0Pb z0C#|A!4~iX*zY3LJzxW4KmuF~?gGz(55O+a|6-&U)PPCgX7Chv9ef7<1czUO=Ky@5 z1Kb3j0~^3cU^h5uD$)eZU^o~J+QB8@X0RBn0lQ12+hQC`f=AU@mwNya3(8788m=d z;3@Dq(9eXv19QO(;5%^ImFSbeP2hP@auv!5j0F#aO<*@T>T1+Q&XMt;4Jj5 zpc=G;E5RIa7kCt`0b9XW;1_Vhx=kB5@O$l;_vCe)53N8zKv|0G9~W5_`AFLEq7 zjtnBllM~2^WH8>AeG)ktYxk$%qcNwEq4=W98Td>LPXtVfNkm8V#6XP1M9g?sw-q0N zvEzN;PD~TINEvYx5Al+6Qb8(-j|?Xx@V4$MQcVJQ%lBD$-*%WpNDZmQ+qXxOQDihZ zn~Wjn;L9^nQcoJlSWKEVkr-(v<46l>CFhaxcvE;g-q#(+`@PS{8@`hSpF1EE@ILQJ zWHPycT!`<+T!fF{TtcRjOUY$q8ktTmCo{+uWG1RBH$nE3~vVh!4?jj4xB62sm2a{)u$$i)m{Qy})9wZNuhsjd% z2w6rRCCkYQ@)&uXtRzp6C&^P}6?vLGL!Ko)D~*G8|LF?8o$B z_GkJs2QUXR|6uwt2QddThcKngq0C{-;Y@$#2XPO7(HWPjEspfGZx0m*cdzG zV4Tb_#>JE|ZpOoSnR2FrsbqZ2aApMKXR4TLCcp%lvzQPQW+F@tQ_IvbBbiamXy$BY z408^1E)!+ynFeMo)5tV2F{YUr$Fwl5%z4asrj2Q5I+!@q$(+w5m?V>8x|j*fL}n5* znYnf>PFq@fonfI9YnJvr*%!kZJ%vR=O<`ZTc zvz_^r`HcCT*};6le93&p>}0-XzG1#)b}`>E-!nfjyO|%EpO~MSJ;U$k z?9uEo>_GNk?6K@|>>&1d_5}7sb};*I_9XUXb_jb4dn$VxJCr@0J%c@y?C$FdjWePJB7W7y_mg(oyuOyUdB#ir?Z!{GuSKGne3J9RqWO5 zEcP1qTJ}1&o4uaBft}6HVQ*w_VsB>Wvh&zm*jw58>}~Ar>>ca^_D=RLb|Jfny_>y< zy_a3g-pAh0KEN(vA7me5A7+=bkFd+wN7?1<3idJfadsv91p6fW6uXLjntg_SmhEAm zV^_1!vuoHF*caKg>^k-(_GR`Jc0Kzl`x^T?yMf)vZerhH-(=rn-)7%oH?!}u@3HT* zTi6fS5802{t?b9_C+s$MJNqg78T&cAgZ+a2lKqO^$$rg#!+y)|V!va*XMbRKvp=#w zu|KnW*k9OR+27c`?C+w2Xg=5`f&$w2XlvTrQD(1 zVcg+df9?qGNbV?Z0QXPsXzmzpAonlsSnfD(5O+Lx0(T-enEN+(5_d8;ggb>hl{<|a z%AL-g!JWzRoWO~k#OXLaXW)#Si8FH+&dS+1JLlk>+%V3?m2qy)!+E)Ku7a!NeB5wu z1n1|fxN0uI1-Y}h5EtemTn$&t)o~-aQQTOY&n37dm*Tp(3EV_(5;vK?|?rLrpcMW$fcOBQwUC-UX&F1ECH*z;|H*<5jdE71Bt=xR>Htu%r z4sHQ=CwCXOkXyvv&E3P@%Pr>a7k;FfR?au0D2b4$5LxMkd<+;VOO_Zas$w~~8; zdy;#KTg5%iJ;OcA^>EK|tGVa7HQWo_i`-gn9rqIVGWQC%o_m#hjeDKjz-{CU(2 zQ+N$SYy9+9gULX@FLF9Q&pvLVB%YysLP@P@+f zN^g}n9IdGFd5GH|_IaY7R(#Pt6^?gxH1(F4dW+l*o%mdFtf)hQTgvfqAWv6kTWpeg z*NCLAjD85wMRVe#Uv6v0m#-@uI-1&I3E~cTylz*}7e%te-bln(T@ls@YdpR{)LTt` zg|cFIrK`Ha>-U8t8o%zEP{>;y$+~6zBVYvY@s_)4{MuW>HNjvY6bXB4aib=vTA#<8 zjn)(Pcp-^;V$BU*ZK-sb#{E^4fT7W30$MvRn4Xwzd(;nj{JZ8Ag!= zT_IOhw9FR?xgy>|vS<~GCC4G?b&bg0A?L~)LDJo!Ksa3H3K1ozvMf?ljWX2;hRpSeJJzD>vh&x*6 z8j((c>^~fFReQ=tMe#S{4QqXeM};Has{DY02)(A-T^TK_i9`a`>J4pe(ZJaA&{UF& zpv>hSL6ckUiAG%E5z*>E#8>WfyCS~yEoH7q#2XqFMS4*KLls^W6m^aA=@5#z3xDA* z{)M|#%)Q+2st6a4UU4oOyW(6la>co5+JU{FNmhLhVfoeBWp2;hIMO`_1$rGqkn?Ci1 zG={>FD7w`^$QzARhP>g*fL~QTvIlp-<@bi&sAG!8qxVN6zAA5^CSA@n9J!A47Ryzn z$St|G)Dw1>kBqwgu5dW&^19XhX@u43DkaORdijDR*NdtJ^8!<)S+9sy)}*cwI*-ag zs3sFnjtgoQ3MZU-j$y4UN(zrs({OTJy$Cj)AMIVxEa=@AJ~e_oaiH3V%A($pR<+d#G1E|e)xny) zg08Od`;}mWZl8CgToUe+!Dlq$ z-@Q3cIsMgbbza&N{Z$e(DbjXtMS{-w{d+0NdWW)93prDcIpyT5R*U6tBqHPY?<-FJJ|Ha#i)+4I(Lq0Sm zuaec?jfE;EMUNDIu(IM(T2vTDSb@4K`|xMGL%8 zX437cpj)QN?;{}@Kl@Hd)?2ZJ_|d`B{~ zrsm8Ds6sWyyiki zWz3Uw+2s%4^1Pv0&~a)sU5k|Zk?)Dx9a+0mb*-)rjB>%0%uS}^m^Q)u)E>(zN!4AM z979u9?5x76q{GhwHy0VNC?RJagO5%QB`0?@`dm#DT9dJGYsYv}NGNKgRhUp~JTGnkG<0;t+RD0`n=?*bsTPFLijOPD zRL>fTcakD2!<&8FctH@ICk(}!BpM0l5naa)s;*KR!pvq z7zL$z!#AL5vH9^wkIu_yW{PV7R*03 zA-S3uQ4v}@y3~SJ<|n<0L_DGKB2QXI@Uo<0GPO1+cT4K*MOcBbH3UbD%fSODmSHzXQhe}`<1<`efBNYYY`NCXZsYIq>((rTC z9~IQPLOvJl2qgu%wOp?B{oR_6SBGTo@JkPEtj#_`!F zkoL0AlxG~rCBkToN@-{BOwztKSE%UV@Wj?kLrr@h9q)+c6winxveX$%q$Y>c55V6r zIo_2Dqc1>Lssx-@`>LSuh_5=H6Jek&)?4dC=x%6iQL~c1QWKTF%&|$RQ0eY6II&gnmtvJ^YBzz zZiGrG+By(y?Tk_7riP3wPrNImrl_kwp05RN4#U=>%@X{b8* zout|*=P9dlTDR4R6Y+5g_|*1Y>DE!!pla>30L>*gTj^$`Z8sSEQ5!=EJ``(=Cp0Q8 z6l;q$B+(q@7NZoun&eQt4eRZ-VYj!vs|}jCNl=5xm#ejys-v9L6t;TvrRlr#Ok`D| z!*^w@tux)d;xebJz%|NZ(qwJDfh?Tr8k;YgjD|BQuUkP6*FhDbwzg6k)Po|@bX4Kk z`CZgnZ)nrj8v2xDiL`c93P^qONEp5kkxqFy-i#WPOrgV7eWjYzQqOAmoZ`!grmK@~ z?8q}%!(Hgw$7MRn%%z$DH6DyeS`x5PE>Np>I4j6Odx1mv|>0NO5HM0~)ygMJoolZO|M_MrvDQ6SdVMd#wgl*U*}hN21uaqTB){ z=j({2s5a6*J5@|glWdYTLRvKF>(q>^4mm!dd&}bqYKx#^)+hsCUtOZ1voqF&TBeTj zlAhSuu5lQ62BAOj^rB=$*yXPXU@@~2v(0qM1oHstNfLLUCX5y9C|y#Ex~Y?YpZ+V{ z`*N=GVYf)IGEj}xp->20FEW#U`?{+-;KLFI-B5$s@-X#T<0-FpVQy5y3L<7au%wqO z^mv1j$~+l%XoS20ttf^{!xiNb|cN^u& zFty+NUii(A1ft&lFcpQ30@d0eRZ%g|`N7KGdk0*F)kCZ%d-3&$O;AT@#O~T@f8abF1-VVut2DR>Oi#0m-Bove^q`!6gghf8~HRr)9DCzb|*%j3)W4F zx)qE9OBeDEKutK<>f*w-46L_dc_2d56!nC#-7hE4zV~C#`k@sJ zTJo>F6bmLWa+J1I&Z<#15@^a8djODfEN$h;s_DL0jigXzL!qa8u1vW^upL-?UnGF_ zov>yg=%7~EyKhbDv>s{v^K~@SL+K!kfj_y!790H&iJYGR3SdC7ezw% z$wY%FTWT#(XS!Xj8WsZ<0BW#lRc)fQmMb%MR13SY{SqCZ%PnPk?ZO_gV0AwA0XrQd5Q{NxJu{aOF)qdr-zj?)1Crinz%2y|9~`w&4Ql@W@?EAqTqa zut4)u6X=0+p(m4ej_mVppVx~mPyT?5>Zt;e7p-Ax@R*{Ci9(c4^8_1O6GZ}1JXK&n zE9OZtAz3ggs{f0-&>gEqT+w8Uy9oP?lIoCP!{oMjL(@KjsKum1ytsQ|eW4am@urjZ zP*b!TVJ{@kLli75*(q8scL)U@TY=W7Mn^ZbU?+d!P>WXekgLvA_?D2byu7$e@n=f! zqm8rhyA58diPWa4KGTiz`P(Gs;@5K$&S=3*`A9`&$P=hJRaI7RYk@{8%QFujkFJWIiNHVzqX}=p=rf*aj-zyAnQU-so^@`R$fR62-aNIf`YIAj z?;0fg?^SseDLs8fOUjEP!^h*~(@I$A>S$_6P-Uq(vLv4=Q>P%6iN{=bH(j2{6J=LN zbAobDZft99%=L?U4}(97T?p-nJ=e`2$1+!wGC4?BaB~7v#4ft3CGUaAaYW6fqe1Mf zqrHwMH;O|vYnN-?g6b+l?j5xKWgIeNEv3ll^y1cE!LENtK|_?w7e=j zs#>18?B%33;9m0ZSw(LN*A;c5N-`qvUmX#aXHvDfkOk@LEnlcBo~mDZUQhiQiFd}a zx;42PyKATnqdED(2$ESB^|-RSAs! zOL?w2dnqe+IuBHh8*ywz>s4`+5BO-rZuwY-JS@!^qnYq9>q<8)%1=EjRL-kt!_ZEw zXeRM8w|HDRsfPB8;@qjnSK-6KQ6*X&{KLs3O`sk(Mi5y~bl8dw{Fr|aqvpvo(AnU< zis7RXD1&2-AUpzNbWBC0C*O0T@+z*`=||0tcudN8I5!J9Y0qeYoKWeZC3%8bp6$yDr(E6i2oSX*QS7*{nr3E}Rqb-5A>|lYVc73p;&fdEsiU zoK~be*~@U^jqb8lmr9hwvzkQ6kD_4H@CRx<^6^2fZyY%(r{|F5t;T9gOqa4YZ-uK= zR;sM>qmS^t8URwD`PO*FBH7r`HIUzwxZLuI-d&&l-Y_O*FFPnhgB?B`K(@E$L z=&Wj95oFx56R4TsVaGsKAd_Bo)-=yWHvg*9)5uvzW%HRPo${{#0%{W%F#UP%7V8VtuHSY z#Ef(Gb@XI|CQo6UtjM{j;5gyI2>$X)DavN9)mjz$IoZ&wE`?QLG(Ulna0q$G3>mXgq>bgAu+u`-g3kKJ=nF$Rx$U0CHVX ziyIZoJimx*gBZ9rx8|0+JfTuRPDdm;NumN}N0U;<)S_3KV79{0c@le+W0xuJ`d_0?RTUQamBt1@Yl>r0u^ zEF1z>0Be2Ty1YrpNNc?4NR9+mGI;f1+LE4sI% zsWXnfi#T+Xj5lI`HQlxw?Cq>hj|3ZVWF?55v6;PW1^i-H8y)sW(Qe8o6$%V{m)e!x zTLoS5?w=6d{uS>MQ6!y2-1MbFgJHULu4Yd;17FtZc1IM&<2i zog^ivR%x9S&(ZP(j;u7bDLYt$IAu-`fMNm- zFPgzPI^t4mx7I;DET8Lwxnt~0zyc?%P4CF!Zc0hf)9kR=uwzC3E610;hdLEZLdKz2 z60$Cy0DV(RFAuPypfmg!iqK66Fc`DZsZQ$o`rJFSMgY#kW7!wS`O~{tvO1Bzrb=Bz z&lSohuu}aq0a0Z`+YXFcd0sMmhq6qay+-4qideD8ddHe}PVb)Rbt8_`27_LYtp1=f zGAU4R%os+!T+)+uy&UA`oZfmtUmjD;hqBM7uxomlQP?#-&?xK*DT*UVf(UCA}e>1M_t>VS8$@p|B76a8a%o zWePS{6>F!5+teG&V$cCfpwNbNGdJy=wT|x2EK9(qiKQ5iB}Gusg6+H6*zsi$J-XuRY*mz2PHD&orBD&n+-1V1=cgd11)QlP`Hphg7Ivlg<#?Cm(5G}%w+TGDOSw57JNe4YMB_9n{>sFi&WA@=W?`hz6^$CVz zoyzuKwQpA{4&0USE}ebAX8 zX~j-Ag1qNLoq9jEtS-na$8?Zc56TEnO}s{&(|j|JI_n`@OufU*A7%6kUGY%(>13nG zuWwi~kyWAG`hCf~tSOJw+un&$lNupyR=v|1!iMnt`jx!{Zn-TgllL$bZDR`Mm5f0> zqwX&2*&(meQg{<$4OYa(r-a)<%q2sX1gjh}p znOfM(mr^=v-<0RAI*zUS1;fitQLew75OY2LrBlIdWmR_i)rp!=iSrlZxrs|E7_bxYNAl&y-OhyOWL0~|FpC0AKXOI!W$A`2x-#Z$f&ob{?&HCaI~1Bp7-((|ZvDn>3W^-7aw zRg%uCnkkL79*Ju%XfUc5`Dk2I#=cKm_L{0gJ^PYM{ZQvZV$?E+P|2HevREs@F-3ax zjEVxCu?|&zWh(&{X0K@3WUtUoD;MQx7|E7c=G`VVv~XK2M#nQz*ge`xMkCAyk? zr(B$AxAY-fD2KFGR76VkQf1N60`J1Ri^{v`d#c-l69^!(By=e9OhJ z5e2DVQBeIV$qUAl(68~1pdiZ?A?}q6h&Db{B^)D-j+WEtoz$A5DV8s&%2o?kdFW~? zWk*`&s82a%2qPiiSB+RQbtEb9w9+W|dgU6E=dK%vE}qUPCg|Kq(i;pm(k$fpGGnqJ zJ|U(K{?*`U+`0Zl9--xUqJb8Q*DZK^-|iL*2t9>-deT01*}T$qDM4yL-tm;GyV{{` z)Zp?x>8K}JEyx-7wg%+}R*hPmDLFYbJ@qJeA8M9cD$vE#8KTA_(*; zD|P@XOk0?z?YFw9@3=foAZsDzffVy8HY%sC6N#=OoXG!Q}Q%fF@ z(RE30XoOPt&|HQI;=amI*Oa4y_x&uX3eqTHl(?c*l^UjMyrLP>AwwDk?3J}wv7*w` zs5A;Z6IWIyYw)76(EwzVt_riOSani$Te0{I@UA>Z)jZmFNf_Zhx6eQV|Dw|b;6$E0R2250JQZe^cd40xGcDAw$qFif|P8ewRbEg7$3$`nhpQGM6PUj&xv z8qmkg$SmDK}! zKjtB@q7qZa`~{rpyDkD9MVw*I?IUW9YkD$)bT+_DMqh_CB6$s&AzFH%EKB8Cf!=cg zoej#IB0lcc5_4q=2A{P1&%ginC9t5IetS^)H-7=XsXH6ri`2*#-HGoQLbmeytiPta zN=R@HzTbF5RyGH+k{j`@Lyc?|WJ4iau90nq%n#WbjV!Vd-`0ez(7z3ke+YJhU%`Pl z;hWch{uA-H64ZibkODKo0K+d=Yh+>4PXIS0#<|9zz$F{58uKDCjkQ}10m21rh~cQA@CS@8EgSN!1sXM zf^YMJQ-KZmK{L1v%mquqi-7*yguh$CH}v{ed}i4z$)+|U~fm60{U+_{*D2i>h;C=+YJ_gWuOOa z0$aguaNr%NGvEwh10hfkI=~EY6IcS)fX(0=K+qNr2FC&eCc|sh9t$m;W8> zrHREdt~`Vv5t~eE=oNkaC@x%N9KE83ihR|gx$;hOkuG{IkASe6(iNj3G9h19NAP7> zW&ba=K}`#4QghoW?yH08wuxkNj zB8xZDw{Bz9M#zO!g1vxvM`C@VkN4MyxPXl=pagFI0C3s>` zuH@irIQi{v^j!gwcpZ)A(md zUrTJltI(B^3lfbQOFF1)PQ@oAQ4($)hd1IXFTBHh`lvfel_>M^mz6})%c|)rOQvOI zYQ4ImB+`~t%W)?CEtlez^cQ`kw3U;q=oO+@u5KzRnn?0kNo{K)g&pCDF@;u0$P;Oa zT8<{AbCm|vmRYPlIqsfj=jMP%i(2e*#QN17@Zfp|U^6>`ja*j?OVw_59 zx#niN`-zaTTr(Cx8cC!4H%Z2E&2oF`@a7i_p>p7*E2zgEZ zMZ|Dy4=(O+_Wo%B~nBZN1XL?>hlmONAvRZF5Tk!OL+6Y=(N ziVl$R9dvhG={@8(%%g=vV?c%qotd~pYe_d~<&DDly184s9E@+BYp-c7905t@<)5ep zN)yTi=}WJkodr9vqEs zZ9{uW_3{Hd0I9-u0QKFqb>!x>A9)o)>3GwhfQ4^rYT(QBR2}={6JrTF0gUwhMv!3S zcs!=vFn2)TS4^H_)PA@uKB*30bx)x~lJ{{!XSc?i@RfHe!Hz=p`Ud%04rc;hV2?b_ zNlWA&>}E0%or__ z|L>&ES6x+gh6hKB{)hc5t(V&wP4(92$F_BY|6w`!Pjde&CD7BKpZVzD$W$25RcHEr5mej(M{1^uDen9g`w4WmvNc#0Mk6vi>9|tKJ)ix zzvX+2-}=4PYx~-Mx04Kl?TR>U!hG>)(~~BP`DOU{(h|2`X}!^UjO_v23$~3mtNl~^ zevacE2FF>BX2+$D>m7GG9&tS9*y#A!@tuQl9_l>aDL7ruTIV^=7H8bq<-F8+z4K1z zW6r0Y>zuDU-*bNK{LV>uLLv+y41Xwp5`Q{x;+_0({w%(kZ|9Tz_557^5q>4Vk>AXJ z&F|(968Z}#38xDt!6^(E&Jvo1c43lmiEyWIkMM}_oUl>&SQsD<6D!2$#I@oq>2B!> zX^+%jH&{19SBEmF)sNG+>)+Dvv0J&Z$A`eeHu#mS(Na5 zj_r=4or9f2ogtKM%K3=%S?4B{=U2|%PCU3_g!u7?MVTJM59Z7H$^5Ot$KvN=nQn&e zZru_3lk|eVOdrv=>L=^Aj3JJt0%^=UD#VsEr@;MA%GmM3 zgY`%1k465@&>Qp)eYrlYKU?3ZAFog9FVs)dU#*|5zg52wIbLLV*09acWxUWd-^^ML zx14Bcv~*b>uq?BD?xY!`<#!GL5WklHj2|S#g&Txhgg=ET(lqHt$*3D??l4a`3)Tkf z+tzB^_qJbcuh~DauW)?nxY&8QbCL4_=gZEG&Rx!*oftyV$3c$fkLRxw76|)G2OHKJ zg2p4wgUrLsA@kYh%gi^MZ!`a7KG8PZHqUmKt;0Uaex-djp7=J$Lrx5FNGaOKN&HfN zJ^u~=hH#R&PV6I{BAF$h6p_ZDOykl-=@RJ*={o6V=?>|Bl<>3CTIqG^9qA+KbLm^@ zXX#IAf88M{^;2~wT}n4ycZ04+w@LSv?q>aM`g>98Pw8Jkt9VcUk^T$)FZw_9oZ%qD zzYHfBPBsVzm!aG+!cb#~8O}4r4U-L58m=|WHr!^o->|~)6iV?0!%K$O4R4?=eSi}E z-0-#GI|E}p*f_v=f^n$PU>s(wGS(WW8y6VY8+RIiG5*7Jgy|TQ&g3vfOs%E~rdv&W zOoPlO^Eh+De2e8S%l(#(&_;~)VC%`&GpsIao%LL6leHZ>AEWo`@6e=a~y4s%N@5n9(QbTeBof7$2fIPH;rQhq0NQd&;Q2XtlzBvRX@Zq-te$t zrD46nY-}`MZhYGKf$?CI*L1DvA=783z0fg7n@=%&&DWdnMf}SxL+p~>VK+P8aU6u! zO}5g}G$G^Bey8)-@Hg`J^Uv{b@n7(NpiaIkd?EZI>?a;19wGiq93t|fRdkCZ#ISg_ z*eFgBr;D@1IpTcrUh!e^aq(HS!`H=k#H*#HhU;uM*?7=F z*=y{h?N``ew*P5A!68AbpX+FKT;{mJvCQ$7OT)iV4x63+a~Vmg`pO-qyMGI%t)}s3AuiC8Ni9vGF=%yXgv(-8|B~!W_5U2Yq>< z^(bq#b*lA!Yr=-G2_yG)3&qF8AH-jwzh_Guq@#2K`mg!AM|3N7f9RU^OZ9K+f7aI+ zCK-ARhZxI@^~Q0=XN)fxx0tt?_n2)Kw`Hc~am%yTGi~QU*G{v&Y;)Up*?+cI;i)AZ zvmCQglS-Un=Pc)J=L=5SxM*LO;xFRw;veT<=YQc(5OhLBaG?L3EZ!)-Dee-hbZ6jxVSFn(togql0Xbb)EE=|b~t^IG%!=5Nir&3~9jTVAtlw;W)dVZG1#y!9>X&(=XU z7uxhk(Cq{4$J-IfAcpAh=Q+_Yg{Ae<8)%z9Nhj$p(+xD(3?akWhL=s%mi??pS_fK( zSoKz`^&T7H88Q<0wDG?R&xoIhe~3q;DDM?$%`fRg=3mij;?@b) z^;U!ZX8U1|0ggsTr{gKdddEkOoes`f>b%K$uk#7$CImQ)k=sK*z708_%`f7gLEbsx zRAHPjLApr#UFxH|Sbv3nBXq$KwEty>9mWBsX7eobqvn3-`8q8QD9A~%n zX6tI}Lfieer)@j!KcKDjcaR`Mh9IhyhJHq!@it?HX_#fWrPgw`WvTT^>xAcoC*Lja~sdI(12hV|8LA1YN2(A8$_(%B};*ruS=>v(?C3UlP59?mjeW~;6 z?>8Q4dcqV!d%3{+Punv4PRAaH#d)Rke)KPl+`s&jxA1rKrwLod>m>>O-DYUCC(Qq_ zO4hrqUs*4)b=y9*1?=_q74`!hrH*5fp7G8lRG%(jQ|uKh(VILk zeJOD|zb>X*ud7D?us<}}TGLk3;pV9MQuC|kkIaYJLa<_b?BkH@J+w@hGGr+JoG3gY zd@Gp5X7Ltrvv`1%l0K1sLJL}{FEdOxY%}Sszc@$_Bij$t_%ns8r0dZ?ou#`Nb^1%) z(fZ?In=IF#V5l`j4GF_hcotUUp{BK_)#kU*!jH2Iu?QBM#bfbXMq9>O&V#nUz;c=8 zD$5O)ThMzfvpi{8ZFw1W^F7Nauv)*j{AyvX-&yaqCG1n|^Xv=l%j~P{WCJ7X>OXj& zSTCM0PJpd^y?Cei2rS2q;>Y55A|o9t9WP;5ymXfIq3&y)553z?quyL&?lRv94fdA# zWXlT6@75>mFFHPPkgZA`9t{h<6V~}f!nMK+!rQ_&p|5xdY;u$66g}cZ@nZ36@doJR zhr~yrkzW%(5`Pw1X@9A|8drmKzH}+d<3LzIml^G*Hdx+MERR@LTE4aXWT~@$Ykk_r z+t)iTbZ&8yT@1n0I5~me!FNLgyTq|#yVxbp5NC_$OEaWdum=`MJ<>+$Fr8J`ty`p9 ztvg=t)VuYS`jEaBmXY3gKl-Haj3p+6DFmH%jp;4Zc=Jr_7VBqLGoJ2b+d|uew%=^8 zp@x?@tlk+*rrQ_<-#gq4Mt3F3SSA|344Y9(DHWa8z~Cw=r;6Oj~Jdb zJa5=#7=W?C(a`j(OxIfuu^O#+TA#MQYbCZ%9fW7)HhTg;Pk2>0PiHe6X?)5!#3Y)$ z=34aSzrm^;VVz}NY<0Z#iqkqi!Ec&l9 zOS8pb4O^F5-$4IW3GMT|?Kq4H=D-Fy#4*G%-4TGjPl7DLq7@m-Pvbx0_waQ>QrIIL zE`BA7=vUsB7~MV48^7r4VD~I^9J=jHN2Ozt<9Ww%PLq?=E6;hXI8C%5d3hG$IM&=x;4du@%l z_g36D-LcT|yFAgQi0N_kjV-!Ib-x==G?ic+)@452!dn`x)2yVMB?FQ7BMcJ_ zmzZXo7MdQj9$~9TKR4Au7O+_5AY`rBM?XjZzAC7itKD1m;>rxL(yDah+>UBQ>AD<8=V^sOP@Vf9BdL&jHC<ka#3kZW;)mikv9B}$Hsu+TBw3|lQYG}o*;0dao^+w~ne+qN-T>X{78=c00 zvBubJY%?ZdM_y-q!nncsrE$0M2-C@EMFBkFDW>^&$}gKfH2rEK=04^_%tzpPSDPE4 ztrnT@GcQAbu-g17#!v@X4zcJkf^EQPYNF+K%X6??Hd}tM{BG$BtNVECX;!z@XZ_uJ zsO>o0zimTpSK98ht*||5d&~B*?OW93KCouaL~XX&XJDLi2Ws^i`(})Pj&TSMr^D-r z!0xz#_Ujv1vK@b3;g1tsXou$uR|q$u{k@6uJP!J>3);_)vYH}&B~3+N7t>#$pQXPE z*8IchD^}~@&~Jf0`AvTq#vy*g81w}f8m>U;Y%g>^9$Oe$2eVyu&P5%oZ1(Y^&vb%SQXh_V4VB<50&Aj8Y=b2I%ig zVFS`RnC&#}yI8UqfBNzL`GIO$4ib(K{v{-Yi-fym{rG{fQ#ePALBnqnKM)U;Y*Lvt zLK-dI0Ne8}-81?f`d#`x`lw-`aWF=El}PDCr1T!+D&un)@BNC=PMax(l+HEXC2MrX z+|PWdd7ya&wB#!D8uNPSk#Eh1TFNnpvfQ!?vnU_IiVeWZ83WDKW_!W;K2pjlx&r;E zAeN(-YZiB7e9%WaN;($v3LYsSMWu_SInrEdzTD$&mS#~yyOg8DXF~WAzAxX8FXe~v z9=?+I^FclWyKf9%&o}Wcuz)-H6hDcd!cWCGYbHMnGi-A(^E97d0K0fGzXW6N<(P$9 z#rN=Q_;nbEZ{Xj=jMNr>E599m?@oRf=BD=Wdoc@ABJ>sd38k2)8XyeB{M=xnQW%N4 zKNbDYO!PqA!d&!03(yJ{3na*qen?(lTR$7A=g0t-kRkj~p67L#2ebVjN$n8yojiI^ z6Z+3#=s_#dhX&D$(md3oCv8Dr+9{+k>o!G`r#YHjEfJQYe_e?lwg-LeI@F>KXz`nc zEy7k|yRZZGX_v4Y{ncK9h$UiQv7cCq=Q;q|b&xn1J(e7HO-rUD_e-ly*tGF)O)OBDxY?UtK?4sjffzh=IC6n5P_~8;ZFx9p-6lx?wtx zj&yQlChACj8UAlCtErqk7m=( z+f3Umj9cc|=Gx}l7Qhx-Y+GVmYFlnwXWp=AnRaQenYLiRcAF>ZPsB{kG0b3w+5{d z>qzSuYdz-MTC8oD!%kTzS*KurX1aAIY}sz>9N1CwF{`}@cI^^asmsxauCo4js0-_C z>unosZ(@9~#kSS99V7Ogwq3T}wmr7JHexTa_qF%4m)iSd6h9C>`(S&e-ER-tBd~hM zU{u_MnZ7oAr#*!pe~NvoeY$<7eU`l&cK2NSeES0XBKu~F&E*<#;n-)`Sw--%hK-S$29y>{X#arAZc!#KM?=3oXo1~~@9b|32C9Xf}}VRH<_ z9Ac%z?+C(D8tEA0sCP6uS};4+=}5tb<*<8;kiYI%(k=1-oTmQ&M-TsZ(7KhF_Xz4D zx{>k^x>!m$-|Ry%Y%u|BaI_WxcT(U<7^>ig+S_5Jk&^aJ&S^n>+7^h2=*qSKr7 zHvKTY2jg?UK8W?1k@_+EdVLdCN80qA`jmc>eu{o7W+G?8PVUASXRdy}et~|GelgZg zmSWCirGAyZ2P2Dh`t|w^m?zx~OL8l0$sMpJcjdJVn3ouq8kS?GdlhD7*I?wb!SJSGGuCjn8nzpD74<2 zRi-tj^`_0R(RY}3V;;Q3TxuSG6_KIPaW*s6S5#L~JwJ6$hsJ>gQHP(49)1l12zH&DGmbpq7~R2NV^Ky?6Z|FrGXc2C

O_-@QcF2G28sbjgL2O|oyl#}PfhQU6Kz%p%tO*#eEXgBQ8MX*3u z!uDJbt8**t&E2px2g0)CVWrVIj*+m;7Q^bIa~j)WU+sZq)ekn+AXrm6*in_RpvJ&< z>V(xqR|V$6Qd$BVsRz~(k!>LKp<6k5toHv!-7YcqHTE->8vA1&XrOTrMg~JLHsCP_ zY%3G*lBAAn<1 z$hDw?g$i)o$i>3L!p9;2I1Zm+kz$bn>|s;@`xp(t^fkd^3b3!S1enU!0MpqK;C${G miwhQ4fNAZH1;Yjw;QCZhe@6n?N&qqrK=>@s-T_c#&;bDW)iZzq diff --git a/libs/windows/lib/x86/portaudio.lib b/libs/windows/lib/x86/portaudio.lib deleted file mode 100644 index cc883f0339d4c116f9f8e518b8d594ceb18f2968..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 9360 zcmcIqO>7fK6n;)9Kjtsw|CcyF4FOeY2(ck*RV59iu`mgW4MnPi*~FV>RoiRXYec#9 z%ArD>df<%cjUxwoL8$j0Dp83OQYB8DIU&(EJF~m<_Rs6swe&KcH{Z-RKkv=F8E4{a zrMk2CP5jFQ{hUu;xR^>Nmy(yLeqLnHFD;3ZJ8=L=19Z&*bl(E#c?8h=j!Rz-z?4^* zqV%VPJi`=aU{=UuOi>20EmQ7e%H%zlq1ynayv7t|cumL)Oi@P833-Ak%4n~UhnO|Y#+{)!IU&*d+rLX5UxAGOeYAE%Brb9lzaU+xQLf{u0!x6dl8yi>imsfHt zkiV|vSGKWU8ZGCd{Wow4a@h~XYbL5q3Rj=mM zd#*MmHOGnR@u8qp+29Su-@HNR38TGE8kvua*=eTd%N^-r_8Lu4Pj-+(C*61nXb_S37a+a zO2ySS2iqlx-mIu)u|e@dX{yO zJ3mQ12*I!ximF;$Ct4GwS3JFBlVd3nlT)iDt*jXGq)R$Pm`-8Uum>w^ zn~ek(=I8B5UCIFtI3{L<&K>2`D#q;(J%K8+* zbCk(xGem&{@EIJ0LvR?5Kpc+3F*pt<;3RaxDd>hC=!HJ$hXELbAsB`c7=V;K1V`d(&a(Dpy51o;Z{n zVaQn{!x|nLGPuFU&!LUBazwSf4`UmRH&X_RurDI4@eYTe==&Ce#h%2z$$OBQ587C; zP~I-~8Pqy)n1B3Ae8AqP9Ge$wBkiY78Sw|7x-^`m0LeGJ1>S%_@)H>@dKVlXdRy}G z9Jxg~j3fF+!JLVGfA1}z?Hq!Mux->4#pit$bRdfq_DtNN`Zi_lRY`)o@w7e=L*Fl z1_+H_2a@yW#XG^BcqY~fzy102hm$eDbJzUD<_hX|{m1Dn&jPICmtU=nNSC4O+c~YE z7|Qg5RfORL{DtzbP;_Ft4D&AqE+y1>rUS%~&%!bNG9+GhVA_jkKl>afgE|8}U58N1 zT4Wy<73}VHU(XlF$Ql3)4cIq~f-u-%-v|#Z@93op z_IGzL7W?$cB4l;ghjp+6tYI$$m|fnpH0A&qQ>Ud_WEfO{jY&Ehrk`Yg#D}#G@Ri81 zqyui^-+k`kAqEpCgN|S^3&{n^VmeHV`NQlW>n8YGOu;O2{zw*c!O}8|`Q6Hhlv&LG zWC>AL7h_nQ@qovkrswUFJa637{y_r1)c*4p;%P~1s+d7CPm@2Ar{TL8|1jL&Rz{?4 zp5G{QiuZu9cd}+@HEBI_CfMsHbJI+W?O}NBz|Ub%)K1!`4j;kx!`NbiO^%0JWJ?K0 zbB%2pN7f9d%GKEfDN0sg`Eo)d09dK)8D?H%b!H?w)oql6?E zWuyVtgFnh)7;NtZ{1W84J`%2`PtL^ve_p(C^Hf1eNiM?thD9cWHYa%kAr$-Ak3vrFAs3_dwn8aMF3K1~=5<&wdf#jaOIs~x zMB)^0L6od%%L&{0Mg^Pn$kZZRDqsb_Ksy~1Y{9Qrl$_)utmR?=H~wsdzs>N|g}-By zmYZI`uv^%;#Us78wZ;~