react-native-audio-api 0.11.0-alpha.0 → 0.11.0-alpha.10
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +13 -11
- package/RNAudioAPI.podspec +25 -18
- package/android/build.gradle +41 -5
- package/android/src/main/cpp/audioapi/CMakeLists.txt +6 -3
- package/android/src/main/cpp/audioapi/android/AudioAPIModule.cpp +10 -16
- package/android/src/main/cpp/audioapi/android/OnLoad.cpp +1 -2
- package/android/src/main/cpp/audioapi/android/core/AndroidAudioRecorder.cpp +353 -74
- package/android/src/main/cpp/audioapi/android/core/AndroidAudioRecorder.h +32 -19
- package/android/src/main/cpp/audioapi/android/core/AudioPlayer.cpp +13 -20
- package/android/src/main/cpp/audioapi/android/core/utils/AndroidFileWriterBackend.h +15 -15
- package/android/src/main/cpp/audioapi/android/core/utils/AndroidRecorderCallback.cpp +170 -0
- package/android/src/main/cpp/audioapi/android/core/utils/AndroidRecorderCallback.h +46 -0
- package/android/src/main/cpp/audioapi/android/core/utils/AudioDecoder.cpp +46 -58
- package/android/src/main/cpp/audioapi/android/core/utils/FileOptions.cpp +83 -0
- package/android/src/main/cpp/audioapi/android/core/utils/FileOptions.h +22 -0
- package/android/src/main/cpp/audioapi/android/core/utils/MiniaudioImplementation.cpp +5 -0
- package/android/src/main/cpp/audioapi/android/core/utils/ffmpegBackend/FFmpegFileWriter.cpp +366 -304
- package/android/src/main/cpp/audioapi/android/core/utils/ffmpegBackend/FFmpegFileWriter.h +49 -91
- package/android/src/main/cpp/audioapi/android/core/utils/ffmpegBackend/ptrs.hpp +56 -0
- package/android/src/main/cpp/audioapi/android/core/utils/ffmpegBackend/utils.cpp +114 -0
- package/android/src/main/cpp/audioapi/android/core/utils/ffmpegBackend/utils.h +34 -0
- package/android/src/main/cpp/audioapi/android/core/utils/miniaudioBackend/MiniAudioFileWriter.cpp +154 -95
- package/android/src/main/cpp/audioapi/android/core/utils/miniaudioBackend/MiniAudioFileWriter.h +10 -16
- package/android/src/main/cpp/audioapi/android/system/NativeFileInfo.hpp +2 -1
- package/android/src/main/java/com/swmansion/audioapi/AudioAPIModule.kt +189 -14
- package/android/src/main/java/com/swmansion/audioapi/core/NativeAudioPlayer.kt +10 -8
- package/android/src/main/java/com/swmansion/audioapi/core/NativeAudioRecorder.kt +10 -8
- package/android/src/main/java/com/swmansion/audioapi/system/AudioFocusListener.kt +5 -2
- package/android/src/main/java/com/swmansion/audioapi/system/CentralizedForegroundService.kt +128 -0
- package/android/src/main/java/com/swmansion/audioapi/system/ForegroundServiceManager.kt +116 -0
- package/android/src/main/java/com/swmansion/audioapi/system/MediaSessionManager.kt +115 -107
- package/android/src/main/java/com/swmansion/audioapi/system/PermissionRequestListener.kt +2 -1
- package/android/src/main/java/com/swmansion/audioapi/system/notification/BaseNotification.kt +47 -0
- package/android/src/main/java/com/swmansion/audioapi/system/notification/NotificationRegistry.kt +191 -0
- package/android/src/main/java/com/swmansion/audioapi/system/notification/PlaybackNotification.kt +669 -0
- package/android/src/main/java/com/swmansion/audioapi/system/notification/PlaybackNotificationReceiver.kt +33 -0
- package/android/src/main/java/com/swmansion/audioapi/system/notification/RecordingNotification.kt +303 -0
- package/android/src/main/java/com/swmansion/audioapi/system/notification/RecordingNotificationReceiver.kt +45 -0
- package/android/src/main/java/com/swmansion/audioapi/system/notification/SimpleNotification.kt +119 -0
- package/android/src/main/jniLibs/arm64-v8a/libavcodec.so +0 -0
- package/android/src/main/jniLibs/arm64-v8a/libavformat.so +0 -0
- package/android/src/main/jniLibs/arm64-v8a/libavutil.so +0 -0
- package/android/src/main/jniLibs/arm64-v8a/libswresample.so +0 -0
- package/android/src/main/jniLibs/armeabi-v7a/libavcodec.so +0 -0
- package/android/src/main/jniLibs/armeabi-v7a/libavformat.so +0 -0
- package/android/src/main/jniLibs/armeabi-v7a/libavutil.so +0 -0
- package/android/src/main/jniLibs/armeabi-v7a/libswresample.so +0 -0
- package/android/src/main/jniLibs/x86/libavcodec.so +0 -0
- package/android/src/main/jniLibs/x86/libavformat.so +0 -0
- package/android/src/main/jniLibs/x86/libavutil.so +0 -0
- package/android/src/main/jniLibs/x86/libswresample.so +0 -0
- package/android/src/main/jniLibs/x86_64/libavcodec.so +0 -0
- package/android/src/main/jniLibs/x86_64/libavformat.so +0 -0
- package/android/src/main/jniLibs/x86_64/libavutil.so +0 -0
- package/android/src/main/jniLibs/x86_64/libswresample.so +0 -0
- package/android/src/oldarch/NativeAudioAPIModuleSpec.java +100 -76
- package/common/cpp/audioapi/AudioAPIModuleInstaller.h +45 -70
- package/common/cpp/audioapi/HostObjects/AudioContextHostObject.cpp +20 -22
- package/common/cpp/audioapi/HostObjects/AudioNodeHostObject.cpp +3 -4
- package/common/cpp/audioapi/HostObjects/AudioParamHostObject.cpp +6 -8
- package/common/cpp/audioapi/HostObjects/AudioParamHostObject.h +2 -2
- package/common/cpp/audioapi/HostObjects/BaseAudioContextHostObject.cpp +102 -63
- package/common/cpp/audioapi/HostObjects/BaseAudioContextHostObject.h +4 -1
- package/common/cpp/audioapi/HostObjects/OfflineAudioContextHostObject.cpp +25 -31
- package/common/cpp/audioapi/HostObjects/OfflineAudioContextHostObject.h +3 -3
- package/common/cpp/audioapi/HostObjects/WorkletNodeHostObject.h +1 -2
- package/common/cpp/audioapi/HostObjects/WorkletProcessingNodeHostObject.h +1 -2
- package/common/cpp/audioapi/HostObjects/analysis/AnalyserNodeHostObject.cpp +10 -18
- package/common/cpp/audioapi/HostObjects/destinations/AudioDestinationNodeHostObject.h +2 -3
- package/common/cpp/audioapi/HostObjects/effects/BiquadFilterNodeHostObject.cpp +18 -30
- package/common/cpp/audioapi/HostObjects/effects/BiquadFilterNodeHostObject.h +1 -2
- package/common/cpp/audioapi/HostObjects/effects/ConvolverNodeHostObject.cpp +50 -0
- package/common/cpp/audioapi/HostObjects/effects/ConvolverNodeHostObject.h +20 -0
- package/common/cpp/audioapi/HostObjects/effects/DelayNodeHostObject.cpp +27 -0
- package/common/cpp/audioapi/HostObjects/effects/DelayNodeHostObject.h +21 -0
- package/common/cpp/audioapi/HostObjects/effects/GainNodeHostObject.cpp +2 -2
- package/common/cpp/audioapi/HostObjects/effects/IIRFilterNodeHostObject.cpp +33 -0
- package/common/cpp/audioapi/HostObjects/effects/IIRFilterNodeHostObject.h +20 -0
- package/common/cpp/audioapi/HostObjects/effects/PeriodicWaveHostObject.h +1 -2
- package/common/cpp/audioapi/HostObjects/effects/StereoPannerNodeHostObject.cpp +2 -2
- package/common/cpp/audioapi/HostObjects/effects/StereoPannerNodeHostObject.h +1 -2
- package/common/cpp/audioapi/HostObjects/events/AudioEventHandlerRegistryHostObject.cpp +6 -12
- package/common/cpp/audioapi/HostObjects/events/AudioEventHandlerRegistryHostObject.h +7 -7
- package/common/cpp/audioapi/HostObjects/inputs/AudioRecorderHostObject.cpp +109 -44
- package/common/cpp/audioapi/HostObjects/inputs/AudioRecorderHostObject.h +8 -2
- package/common/cpp/audioapi/HostObjects/sources/AudioBufferBaseSourceNodeHostObject.cpp +27 -22
- package/common/cpp/audioapi/HostObjects/sources/AudioBufferBaseSourceNodeHostObject.h +12 -10
- package/common/cpp/audioapi/HostObjects/sources/AudioBufferHostObject.cpp +17 -22
- package/common/cpp/audioapi/HostObjects/sources/AudioBufferHostObject.h +5 -7
- package/common/cpp/audioapi/HostObjects/sources/AudioBufferQueueSourceNodeHostObject.cpp +25 -11
- package/common/cpp/audioapi/HostObjects/sources/AudioBufferQueueSourceNodeHostObject.h +8 -8
- package/common/cpp/audioapi/HostObjects/sources/AudioBufferSourceNodeHostObject.cpp +19 -30
- package/common/cpp/audioapi/HostObjects/sources/AudioBufferSourceNodeHostObject.h +2 -4
- package/common/cpp/audioapi/HostObjects/sources/AudioScheduledSourceNodeHostObject.cpp +7 -11
- package/common/cpp/audioapi/HostObjects/sources/ConstantSourceNodeHostObject.cpp +2 -2
- package/common/cpp/audioapi/HostObjects/sources/ConstantSourceNodeHostObject.h +1 -2
- package/common/cpp/audioapi/HostObjects/sources/OscillatorNodeHostObject.cpp +6 -8
- package/common/cpp/audioapi/HostObjects/sources/OscillatorNodeHostObject.h +1 -2
- package/common/cpp/audioapi/HostObjects/sources/RecorderAdapterNodeHostObject.h +4 -5
- package/common/cpp/audioapi/HostObjects/sources/StreamerNodeHostObject.cpp +6 -2
- package/common/cpp/audioapi/HostObjects/sources/StreamerNodeHostObject.h +5 -6
- package/common/cpp/audioapi/HostObjects/sources/WorkletSourceNodeHostObject.h +1 -2
- package/common/cpp/audioapi/HostObjects/utils/AudioDecoderHostObject.cpp +39 -60
- package/common/cpp/audioapi/HostObjects/utils/AudioStretcherHostObject.cpp +15 -30
- package/common/cpp/audioapi/core/AudioContext.cpp +23 -28
- package/common/cpp/audioapi/core/AudioContext.h +6 -3
- package/common/cpp/audioapi/core/AudioNode.cpp +17 -19
- package/common/cpp/audioapi/core/AudioNode.h +19 -8
- package/common/cpp/audioapi/core/AudioParam.cpp +68 -100
- package/common/cpp/audioapi/core/AudioParam.h +20 -12
- package/common/cpp/audioapi/core/BaseAudioContext.cpp +52 -34
- package/common/cpp/audioapi/core/BaseAudioContext.h +26 -14
- package/common/cpp/audioapi/core/OfflineAudioContext.cpp +12 -17
- package/common/cpp/audioapi/core/OfflineAudioContext.h +10 -5
- package/common/cpp/audioapi/core/analysis/AnalyserNode.cpp +13 -21
- package/common/cpp/audioapi/core/analysis/AnalyserNode.h +8 -6
- package/common/cpp/audioapi/core/destinations/AudioDestinationNode.cpp +1 -0
- package/common/cpp/audioapi/core/destinations/AudioDestinationNode.h +5 -3
- package/common/cpp/audioapi/core/effects/BiquadFilterNode.cpp +96 -74
- package/common/cpp/audioapi/core/effects/BiquadFilterNode.h +44 -15
- package/common/cpp/audioapi/core/effects/ConvolverNode.cpp +201 -0
- package/common/cpp/audioapi/core/effects/ConvolverNode.h +64 -0
- package/common/cpp/audioapi/core/effects/DelayNode.cpp +101 -0
- package/common/cpp/audioapi/core/effects/DelayNode.h +39 -0
- package/common/cpp/audioapi/core/effects/GainNode.cpp +1 -0
- package/common/cpp/audioapi/core/effects/GainNode.h +3 -1
- package/common/cpp/audioapi/core/effects/IIRFilterNode.cpp +166 -0
- package/common/cpp/audioapi/core/effects/IIRFilterNode.h +74 -0
- package/common/cpp/audioapi/core/effects/PeriodicWave.cpp +22 -35
- package/common/cpp/audioapi/core/effects/PeriodicWave.h +4 -9
- package/common/cpp/audioapi/core/effects/StereoPannerNode.cpp +4 -5
- package/common/cpp/audioapi/core/effects/StereoPannerNode.h +4 -2
- package/common/cpp/audioapi/core/effects/WorkletNode.cpp +11 -13
- package/common/cpp/audioapi/core/effects/WorkletNode.h +15 -12
- package/common/cpp/audioapi/core/effects/WorkletProcessingNode.cpp +4 -4
- package/common/cpp/audioapi/core/effects/WorkletProcessingNode.h +15 -14
- package/common/cpp/audioapi/core/inputs/AudioRecorder.cpp +39 -108
- package/common/cpp/audioapi/core/inputs/AudioRecorder.h +47 -46
- package/common/cpp/audioapi/core/sources/AudioBuffer.cpp +4 -6
- package/common/cpp/audioapi/core/sources/AudioBuffer.h +4 -7
- package/common/cpp/audioapi/core/sources/AudioBufferBaseSourceNode.cpp +48 -57
- package/common/cpp/audioapi/core/sources/AudioBufferBaseSourceNode.h +37 -34
- package/common/cpp/audioapi/core/sources/AudioBufferQueueSourceNode.cpp +55 -17
- package/common/cpp/audioapi/core/sources/AudioBufferQueueSourceNode.h +35 -28
- package/common/cpp/audioapi/core/sources/AudioBufferSourceNode.cpp +41 -49
- package/common/cpp/audioapi/core/sources/AudioBufferSourceNode.h +8 -6
- package/common/cpp/audioapi/core/sources/AudioScheduledSourceNode.cpp +29 -24
- package/common/cpp/audioapi/core/sources/AudioScheduledSourceNode.h +6 -6
- package/common/cpp/audioapi/core/sources/ConstantSourceNode.cpp +3 -4
- package/common/cpp/audioapi/core/sources/ConstantSourceNode.h +3 -1
- package/common/cpp/audioapi/core/sources/OscillatorNode.cpp +12 -23
- package/common/cpp/audioapi/core/sources/OscillatorNode.h +6 -4
- package/common/cpp/audioapi/core/sources/RecorderAdapterNode.cpp +43 -16
- package/common/cpp/audioapi/core/sources/RecorderAdapterNode.h +22 -17
- package/common/cpp/audioapi/core/sources/StreamerNode.cpp +105 -87
- package/common/cpp/audioapi/core/sources/StreamerNode.h +67 -33
- package/common/cpp/audioapi/core/sources/WorkletSourceNode.cpp +5 -7
- package/common/cpp/audioapi/core/sources/WorkletSourceNode.h +15 -13
- package/common/cpp/audioapi/core/types/AudioFormat.h +1 -11
- package/common/cpp/audioapi/core/utils/AudioDecoder.h +15 -6
- package/common/cpp/audioapi/core/utils/AudioFileWriter.cpp +41 -0
- package/common/cpp/audioapi/core/utils/AudioFileWriter.h +44 -0
- package/common/cpp/audioapi/core/utils/AudioNodeDestructor.cpp +5 -6
- package/common/cpp/audioapi/core/utils/AudioNodeDestructor.h +7 -10
- package/common/cpp/audioapi/core/utils/AudioNodeManager.cpp +17 -19
- package/common/cpp/audioapi/core/utils/AudioNodeManager.h +8 -11
- package/common/cpp/audioapi/core/utils/AudioParamEventQueue.cpp +3 -3
- package/common/cpp/audioapi/core/utils/AudioParamEventQueue.h +5 -5
- package/common/cpp/audioapi/core/utils/AudioRecorderCallback.cpp +101 -0
- package/common/cpp/audioapi/core/utils/AudioRecorderCallback.h +52 -0
- package/common/cpp/audioapi/core/utils/AudioStretcher.cpp +6 -6
- package/common/cpp/audioapi/core/utils/Constants.h +7 -3
- package/common/cpp/audioapi/core/utils/ParamChangeEvent.cpp +1 -0
- package/common/cpp/audioapi/core/utils/ParamChangeEvent.h +9 -9
- package/common/cpp/audioapi/core/utils/worklets/SafeIncludes.h +33 -34
- package/common/cpp/audioapi/core/utils/worklets/WorkletsRunner.cpp +17 -19
- package/common/cpp/audioapi/core/utils/worklets/WorkletsRunner.h +23 -19
- package/common/cpp/audioapi/dsp/AudioUtils.cpp +4 -10
- package/common/cpp/audioapi/dsp/AudioUtils.h +1 -1
- package/common/cpp/audioapi/dsp/Convolver.cpp +201 -0
- package/common/cpp/audioapi/dsp/Convolver.h +47 -0
- package/common/cpp/audioapi/dsp/FFT.cpp +1 -27
- package/common/cpp/audioapi/dsp/FFT.h +19 -3
- package/common/cpp/audioapi/dsp/VectorMath.cpp +24 -58
- package/common/cpp/audioapi/dsp/VectorMath.h +35 -8
- package/common/cpp/audioapi/dsp/Windows.cpp +4 -9
- package/common/cpp/audioapi/dsp/Windows.h +24 -23
- package/common/cpp/audioapi/events/AudioEventHandlerRegistry.cpp +12 -17
- package/common/cpp/audioapi/events/AudioEventHandlerRegistry.h +45 -40
- package/common/cpp/audioapi/events/IAudioEventHandlerRegistry.h +15 -7
- package/common/cpp/audioapi/external/ffmpeg_include/libavcodec/avcodec.h +4 -4
- package/common/cpp/audioapi/external/ffmpeg_include/libavcodec/codec.h +1 -1
- package/common/cpp/audioapi/external/ffmpeg_include/libavcodec/codec_desc.h +1 -1
- package/common/cpp/audioapi/external/ffmpeg_include/libavcodec/codec_id.h +3 -1
- package/common/cpp/audioapi/external/ffmpeg_include/libavcodec/codec_par.h +2 -2
- package/common/cpp/audioapi/external/ffmpeg_include/libavcodec/defs.h +3 -0
- package/common/cpp/audioapi/external/ffmpeg_include/libavcodec/packet.h +1 -1
- package/common/cpp/audioapi/external/ffmpeg_include/libavcodec/smpte_436m.h +254 -0
- package/common/cpp/audioapi/external/ffmpeg_include/libavcodec/version.h +1 -1
- package/common/cpp/audioapi/external/ffmpeg_include/libavformat/avformat.h +6 -6
- package/common/cpp/audioapi/external/ffmpeg_include/libavformat/version.h +2 -2
- package/common/cpp/audioapi/external/ffmpeg_include/libavformat/version_major.h +2 -0
- package/common/cpp/audioapi/external/ffmpeg_include/libavutil/avassert.h +5 -2
- package/common/cpp/audioapi/external/ffmpeg_include/libavutil/avutil.h +2 -2
- package/common/cpp/audioapi/external/ffmpeg_include/libavutil/channel_layout.h +2 -2
- package/common/cpp/audioapi/external/ffmpeg_include/libavutil/csp.h +1 -1
- package/common/cpp/audioapi/external/ffmpeg_include/libavutil/dict.h +1 -1
- package/common/cpp/audioapi/external/ffmpeg_include/libavutil/ffversion.h +1 -1
- package/common/cpp/audioapi/external/ffmpeg_include/libavutil/film_grain_params.h +1 -1
- package/common/cpp/audioapi/external/ffmpeg_include/libavutil/frame.h +1 -1
- package/common/cpp/audioapi/external/ffmpeg_include/libavutil/hdr_dynamic_vivid_metadata.h +3 -3
- package/common/cpp/audioapi/external/ffmpeg_include/libavutil/hwcontext.h +1 -1
- package/common/cpp/audioapi/external/ffmpeg_include/libavutil/hwcontext_opencl.h +1 -1
- package/common/cpp/audioapi/external/ffmpeg_include/libavutil/hwcontext_qsv.h +0 -1
- package/common/cpp/audioapi/external/ffmpeg_include/libavutil/hwcontext_vulkan.h +1 -1
- package/common/cpp/audioapi/external/ffmpeg_include/libavutil/iamf.h +2 -2
- package/common/cpp/audioapi/external/ffmpeg_include/libavutil/lfg.h +2 -2
- package/common/cpp/audioapi/external/ffmpeg_include/libavutil/log.h +2 -2
- package/common/cpp/audioapi/external/ffmpeg_include/libavutil/mathematics.h +1 -1
- package/common/cpp/audioapi/external/ffmpeg_include/libavutil/opt.h +4 -4
- package/common/cpp/audioapi/external/ffmpeg_include/libavutil/rational.h +1 -1
- package/common/cpp/audioapi/external/ffmpeg_include/libavutil/rc4.h +1 -1
- package/common/cpp/audioapi/external/ffmpeg_include/libavutil/refstruct.h +1 -1
- package/common/cpp/audioapi/external/ffmpeg_include/libavutil/spherical.h +6 -0
- package/common/cpp/audioapi/external/ffmpeg_include/libavutil/tdrdi.h +1 -1
- package/common/cpp/audioapi/external/ffmpeg_include/libavutil/tx.h +1 -1
- package/common/cpp/audioapi/external/ffmpeg_include/libavutil/version.h +3 -3
- package/common/cpp/audioapi/external/ffmpeg_include/libavutil/video_hint.h +1 -1
- package/common/cpp/audioapi/external/ffmpeg_include/libswresample/swresample.h +1 -1
- package/common/cpp/audioapi/external/ffmpeg_include/libswresample/version.h +1 -1
- package/common/cpp/audioapi/external/{libavcodec.xcframework → ffmpeg_ios/libavcodec.xcframework}/ios-arm64/libavcodec.framework/libavcodec +0 -0
- package/common/cpp/audioapi/external/{libavcodec.xcframework → ffmpeg_ios/libavcodec.xcframework}/ios-arm64_x86_64-simulator/libavcodec.framework/libavcodec +0 -0
- package/common/cpp/audioapi/external/{libavformat.xcframework → ffmpeg_ios/libavformat.xcframework}/ios-arm64/libavformat.framework/libavformat +0 -0
- package/common/cpp/audioapi/external/{libavformat.xcframework → ffmpeg_ios/libavformat.xcframework}/ios-arm64_x86_64-simulator/libavformat.framework/libavformat +0 -0
- package/common/cpp/audioapi/external/{libavutil.xcframework → ffmpeg_ios/libavutil.xcframework}/ios-arm64/libavutil.framework/libavutil +0 -0
- package/common/cpp/audioapi/external/{libavutil.xcframework → ffmpeg_ios/libavutil.xcframework}/ios-arm64_x86_64-simulator/libavutil.framework/libavutil +0 -0
- package/common/cpp/audioapi/external/{libswresample.xcframework → ffmpeg_ios/libswresample.xcframework}/ios-arm64/libswresample.framework/libswresample +0 -0
- package/common/cpp/audioapi/external/{libswresample.xcframework → ffmpeg_ios/libswresample.xcframework}/ios-arm64_x86_64-simulator/libswresample.framework/libswresample +0 -0
- package/common/cpp/audioapi/jsi/AudioArrayBuffer.h +4 -5
- package/common/cpp/audioapi/jsi/JsiHostObject.cpp +11 -13
- package/common/cpp/audioapi/jsi/JsiHostObject.h +26 -33
- package/common/cpp/audioapi/jsi/JsiPromise.cpp +34 -67
- package/common/cpp/audioapi/jsi/JsiPromise.h +65 -26
- package/common/cpp/audioapi/jsi/RuntimeLifecycleMonitor.cpp +7 -10
- package/common/cpp/audioapi/jsi/RuntimeLifecycleMonitor.h +1 -3
- package/common/cpp/audioapi/libs/ffmpeg/FFmpegDecoding.cpp +4 -3
- package/common/cpp/audioapi/libs/ffmpeg/relinking.md +24 -0
- package/common/cpp/audioapi/utils/AlignedAllocator.hpp +53 -0
- package/common/cpp/audioapi/utils/AudioArray.cpp +3 -8
- package/common/cpp/audioapi/utils/AudioArray.h +3 -11
- package/common/cpp/audioapi/utils/AudioBus.cpp +79 -149
- package/common/cpp/audioapi/utils/AudioBus.h +17 -14
- package/common/cpp/audioapi/utils/AudioFileProperties.cpp +92 -0
- package/common/cpp/audioapi/utils/AudioFileProperties.h +76 -0
- package/common/cpp/audioapi/utils/Benchmark.hpp +50 -47
- package/common/cpp/audioapi/utils/CircularAudioArray.cpp +6 -18
- package/common/cpp/audioapi/utils/CircularOverflowableAudioArray.cpp +6 -10
- package/common/cpp/audioapi/utils/CircularOverflowableAudioArray.h +2 -2
- package/common/cpp/audioapi/utils/CrossThreadEventScheduler.hpp +12 -9
- package/common/cpp/audioapi/utils/MoveOnlyFunction.hpp +17 -15
- package/common/cpp/audioapi/utils/Result.hpp +323 -0
- package/common/cpp/audioapi/utils/RingBiDirectionalBuffer.hpp +22 -28
- package/common/cpp/audioapi/utils/SpscChannel.hpp +329 -305
- package/common/cpp/audioapi/utils/ThreadPool.hpp +104 -20
- package/common/cpp/audioapi/utils/UnitConversion.h +9 -0
- package/common/cpp/test/CMakeLists.txt +15 -15
- package/common/cpp/test/src/AudioParamTest.cpp +4 -3
- package/common/cpp/test/src/AudioScheduledSourceTest.cpp +113 -0
- package/common/cpp/test/src/ConstantSourceTest.cpp +5 -7
- package/common/cpp/test/src/DelayTest.cpp +108 -0
- package/common/cpp/test/src/GainTest.cpp +4 -5
- package/common/cpp/test/src/IIRFilterTest.cpp +153 -0
- package/common/cpp/test/src/MockAudioEventHandlerRegistry.h +19 -11
- package/common/cpp/test/src/OscillatorTest.cpp +2 -1
- package/common/cpp/test/src/StereoPannerTest.cpp +6 -9
- package/common/cpp/test/src/biquad/BiquadFilterChromium.cpp +372 -0
- package/common/cpp/test/src/biquad/BiquadFilterChromium.h +65 -0
- package/common/cpp/test/src/biquad/BiquadFilterTest.cpp +272 -0
- package/common/cpp/test/src/biquad/BiquadFilterTest.h +47 -0
- package/ios/audioapi/ios/AudioAPIModule.h +4 -3
- package/ios/audioapi/ios/AudioAPIModule.mm +148 -34
- package/ios/audioapi/ios/core/IOSAudioPlayer.h +2 -2
- package/ios/audioapi/ios/core/IOSAudioPlayer.mm +7 -6
- package/ios/audioapi/ios/core/IOSAudioRecorder.h +28 -11
- package/ios/audioapi/ios/core/IOSAudioRecorder.mm +280 -45
- package/ios/audioapi/ios/core/NativeAudioPlayer.m +17 -14
- package/ios/audioapi/ios/core/NativeAudioRecorder.h +6 -3
- package/ios/audioapi/ios/core/NativeAudioRecorder.m +74 -6
- package/ios/audioapi/ios/core/utils/AudioDecoder.mm +22 -4
- package/ios/audioapi/ios/core/utils/FileOptions.h +33 -0
- package/ios/audioapi/ios/core/utils/FileOptions.mm +195 -0
- package/ios/audioapi/ios/core/utils/IOSFileWriter.h +53 -0
- package/ios/audioapi/ios/core/utils/IOSFileWriter.mm +239 -0
- package/ios/audioapi/ios/core/utils/IOSRecorderCallback.h +47 -0
- package/ios/audioapi/ios/core/utils/IOSRecorderCallback.mm +185 -0
- package/ios/audioapi/ios/system/AudioEngine.h +21 -16
- package/ios/audioapi/ios/system/AudioEngine.mm +153 -132
- package/ios/audioapi/ios/system/AudioSessionManager.h +25 -11
- package/ios/audioapi/ios/system/AudioSessionManager.mm +277 -203
- package/ios/audioapi/ios/system/NotificationManager.mm +47 -53
- package/ios/audioapi/ios/system/notification/BaseNotification.h +58 -0
- package/ios/audioapi/ios/system/notification/NotificationRegistry.h +70 -0
- package/ios/audioapi/ios/system/notification/NotificationRegistry.mm +172 -0
- package/ios/audioapi/ios/system/notification/PlaybackNotification.h +27 -0
- package/ios/audioapi/ios/system/notification/PlaybackNotification.mm +427 -0
- package/lib/commonjs/AudioAPIModule/AudioAPIModule.js +90 -0
- package/lib/commonjs/AudioAPIModule/AudioAPIModule.js.map +1 -0
- package/lib/commonjs/AudioAPIModule/globals.d.js +6 -0
- package/lib/commonjs/AudioAPIModule/globals.d.js.map +1 -0
- package/lib/commonjs/AudioAPIModule/index.js +14 -0
- package/lib/commonjs/AudioAPIModule/index.js.map +1 -0
- package/lib/commonjs/api.js +89 -12
- package/lib/commonjs/api.js.map +1 -1
- package/lib/commonjs/api.web.js +35 -14
- package/lib/commonjs/api.web.js.map +1 -1
- package/lib/commonjs/core/AudioBufferBaseSourceNode.js +3 -0
- package/lib/commonjs/core/AudioBufferBaseSourceNode.js.map +1 -1
- package/lib/commonjs/core/AudioBufferQueueSourceNode.js +5 -2
- package/lib/commonjs/core/AudioBufferQueueSourceNode.js.map +1 -1
- package/lib/commonjs/core/AudioContext.js +5 -8
- package/lib/commonjs/core/AudioContext.js.map +1 -1
- package/lib/commonjs/core/AudioNode.js +1 -1
- package/lib/commonjs/core/AudioNode.js.map +1 -1
- package/lib/commonjs/core/AudioParam.js +18 -11
- package/lib/commonjs/core/AudioParam.js.map +1 -1
- package/lib/commonjs/core/AudioRecorder.js +56 -55
- package/lib/commonjs/core/AudioRecorder.js.map +1 -1
- package/lib/commonjs/core/BaseAudioContext.js +61 -30
- package/lib/commonjs/core/BaseAudioContext.js.map +1 -1
- package/lib/commonjs/core/ConvolverNode.js +37 -0
- package/lib/commonjs/core/ConvolverNode.js.map +1 -0
- package/lib/commonjs/core/DelayNode.js +17 -0
- package/lib/commonjs/core/DelayNode.js.map +1 -0
- package/lib/commonjs/core/IIRFilterNode.js +19 -0
- package/lib/commonjs/core/IIRFilterNode.js.map +1 -0
- package/lib/commonjs/core/OfflineAudioContext.js +3 -6
- package/lib/commonjs/core/OfflineAudioContext.js.map +1 -1
- package/lib/commonjs/plugin/withAudioAPI.js +46 -0
- package/lib/commonjs/plugin/withAudioAPI.js.map +1 -1
- package/lib/commonjs/specs/NativeAudioAPIModule.js.map +1 -1
- package/lib/commonjs/system/AudioManager.js +9 -15
- package/lib/commonjs/system/AudioManager.js.map +1 -1
- package/lib/commonjs/system/index.js +13 -0
- package/lib/commonjs/system/index.js.map +1 -1
- package/lib/commonjs/system/notification/PlaybackNotificationManager.js +138 -0
- package/lib/commonjs/system/notification/PlaybackNotificationManager.js.map +1 -0
- package/lib/commonjs/system/notification/RecordingNotificationManager.js +185 -0
- package/lib/commonjs/system/notification/RecordingNotificationManager.js.map +1 -0
- package/lib/commonjs/system/notification/SimpleNotificationManager.js +125 -0
- package/lib/commonjs/system/notification/SimpleNotificationManager.js.map +1 -0
- package/lib/commonjs/system/notification/index.js +45 -0
- package/lib/commonjs/system/notification/index.js.map +1 -0
- package/lib/commonjs/system/notification/types.js +6 -0
- package/lib/commonjs/system/notification/types.js.map +1 -0
- package/lib/commonjs/types.js +28 -35
- package/lib/commonjs/types.js.map +1 -1
- package/lib/commonjs/utils/filePresets.js +43 -0
- package/lib/commonjs/utils/filePresets.js.map +1 -0
- package/lib/commonjs/utils/index.js +12 -27
- package/lib/commonjs/utils/index.js.map +1 -1
- package/lib/commonjs/web-core/AudioContext.js +21 -1
- package/lib/commonjs/web-core/AudioContext.js.map +1 -1
- package/lib/commonjs/web-core/ConvolverNode.js +40 -0
- package/lib/commonjs/web-core/ConvolverNode.js.map +1 -0
- package/lib/commonjs/web-core/ConvolverNodeOptions.js +6 -0
- package/lib/commonjs/web-core/ConvolverNodeOptions.js.map +1 -0
- package/lib/commonjs/web-core/DelayNode.js +17 -0
- package/lib/commonjs/web-core/DelayNode.js.map +1 -0
- package/lib/commonjs/web-core/IIRFilterNode.js +19 -0
- package/lib/commonjs/web-core/IIRFilterNode.js.map +1 -0
- package/lib/commonjs/web-core/OfflineAudioContext.js +20 -0
- package/lib/commonjs/web-core/OfflineAudioContext.js.map +1 -1
- package/lib/commonjs/web-system/index.js +17 -0
- package/lib/commonjs/web-system/index.js.map +1 -0
- package/lib/commonjs/web-system/notification/PlaybackNotificationManager.js +37 -0
- package/lib/commonjs/web-system/notification/PlaybackNotificationManager.js.map +1 -0
- package/lib/commonjs/web-system/notification/RecordingNotificationManager.js +37 -0
- package/lib/commonjs/web-system/notification/RecordingNotificationManager.js.map +1 -0
- package/lib/commonjs/web-system/notification/index.js +21 -0
- package/lib/commonjs/web-system/notification/index.js.map +1 -0
- package/lib/module/AudioAPIModule/AudioAPIModule.js +87 -0
- package/lib/module/AudioAPIModule/AudioAPIModule.js.map +1 -0
- package/lib/module/AudioAPIModule/globals.d.js +4 -0
- package/lib/module/AudioAPIModule/globals.d.js.map +1 -0
- package/lib/module/AudioAPIModule/index.js +4 -0
- package/lib/module/AudioAPIModule/index.js.map +1 -0
- package/lib/module/api.js +7 -12
- package/lib/module/api.js.map +1 -1
- package/lib/module/api.web.js +4 -1
- package/lib/module/api.web.js.map +1 -1
- package/lib/module/core/AudioBufferBaseSourceNode.js +3 -0
- package/lib/module/core/AudioBufferBaseSourceNode.js.map +1 -1
- package/lib/module/core/AudioBufferQueueSourceNode.js +5 -2
- package/lib/module/core/AudioBufferQueueSourceNode.js.map +1 -1
- package/lib/module/core/AudioContext.js +5 -8
- package/lib/module/core/AudioContext.js.map +1 -1
- package/lib/module/core/AudioNode.js +1 -1
- package/lib/module/core/AudioNode.js.map +1 -1
- package/lib/module/core/AudioParam.js +18 -11
- package/lib/module/core/AudioParam.js.map +1 -1
- package/lib/module/core/AudioRecorder.js +57 -56
- package/lib/module/core/AudioRecorder.js.map +1 -1
- package/lib/module/core/BaseAudioContext.js +63 -32
- package/lib/module/core/BaseAudioContext.js.map +1 -1
- package/lib/module/core/ConvolverNode.js +31 -0
- package/lib/module/core/ConvolverNode.js.map +1 -0
- package/lib/module/core/DelayNode.js +11 -0
- package/lib/module/core/DelayNode.js.map +1 -0
- package/lib/module/core/IIRFilterNode.js +13 -0
- package/lib/module/core/IIRFilterNode.js.map +1 -0
- package/lib/module/core/OfflineAudioContext.js +3 -6
- package/lib/module/core/OfflineAudioContext.js.map +1 -1
- package/lib/module/plugin/withAudioAPI.js +47 -1
- package/lib/module/plugin/withAudioAPI.js.map +1 -1
- package/lib/module/specs/NativeAudioAPIModule.js.map +1 -1
- package/lib/module/system/AudioManager.js +9 -15
- package/lib/module/system/AudioManager.js.map +1 -1
- package/lib/module/system/index.js +1 -0
- package/lib/module/system/index.js.map +1 -1
- package/lib/module/system/notification/PlaybackNotificationManager.js +134 -0
- package/lib/module/system/notification/PlaybackNotificationManager.js.map +1 -0
- package/lib/module/system/notification/RecordingNotificationManager.js +181 -0
- package/lib/module/system/notification/RecordingNotificationManager.js.map +1 -0
- package/lib/module/system/notification/SimpleNotificationManager.js +121 -0
- package/lib/module/system/notification/SimpleNotificationManager.js.map +1 -0
- package/lib/module/system/notification/index.js +7 -0
- package/lib/module/system/notification/index.js.map +1 -0
- package/lib/module/system/notification/types.js +4 -0
- package/lib/module/system/notification/types.js.map +1 -0
- package/lib/module/types.js +27 -34
- package/lib/module/types.js.map +1 -1
- package/lib/module/utils/filePresets.js +39 -0
- package/lib/module/utils/filePresets.js.map +1 -0
- package/lib/module/utils/index.js +10 -10
- package/lib/module/utils/index.js.map +1 -1
- package/lib/module/web-core/AudioContext.js +21 -1
- package/lib/module/web-core/AudioContext.js.map +1 -1
- package/lib/module/web-core/ConvolverNode.js +34 -0
- package/lib/module/web-core/ConvolverNode.js.map +1 -0
- package/lib/module/web-core/ConvolverNodeOptions.js +4 -0
- package/lib/module/web-core/ConvolverNodeOptions.js.map +1 -0
- package/lib/module/web-core/DelayNode.js +11 -0
- package/lib/module/web-core/DelayNode.js.map +1 -0
- package/lib/module/web-core/IIRFilterNode.js +13 -0
- package/lib/module/web-core/IIRFilterNode.js.map +1 -0
- package/lib/module/web-core/OfflineAudioContext.js +20 -0
- package/lib/module/web-core/OfflineAudioContext.js.map +1 -1
- package/lib/module/web-system/index.js +4 -0
- package/lib/module/web-system/index.js.map +1 -0
- package/lib/module/web-system/notification/PlaybackNotificationManager.js +33 -0
- package/lib/module/web-system/notification/PlaybackNotificationManager.js.map +1 -0
- package/lib/module/web-system/notification/RecordingNotificationManager.js +33 -0
- package/lib/module/web-system/notification/RecordingNotificationManager.js.map +1 -0
- package/lib/module/web-system/notification/index.js +5 -0
- package/lib/module/web-system/notification/index.js.map +1 -0
- package/lib/typescript/AudioAPIModule/AudioAPIModule.d.ts +36 -0
- package/lib/typescript/AudioAPIModule/AudioAPIModule.d.ts.map +1 -0
- package/lib/typescript/AudioAPIModule/index.d.ts +2 -0
- package/lib/typescript/AudioAPIModule/index.d.ts.map +1 -0
- package/lib/typescript/api.d.ts +5 -9
- package/lib/typescript/api.d.ts.map +1 -1
- package/lib/typescript/api.web.d.ts +4 -1
- package/lib/typescript/api.web.d.ts.map +1 -1
- package/lib/typescript/core/AudioBufferBaseSourceNode.d.ts +1 -0
- package/lib/typescript/core/AudioBufferBaseSourceNode.d.ts.map +1 -1
- package/lib/typescript/core/AudioBufferQueueSourceNode.d.ts +1 -1
- package/lib/typescript/core/AudioBufferQueueSourceNode.d.ts.map +1 -1
- package/lib/typescript/core/AudioContext.d.ts +1 -1
- package/lib/typescript/core/AudioContext.d.ts.map +1 -1
- package/lib/typescript/core/AudioNode.d.ts +2 -1
- package/lib/typescript/core/AudioNode.d.ts.map +1 -1
- package/lib/typescript/core/AudioParam.d.ts.map +1 -1
- package/lib/typescript/core/AudioRecorder.d.ts +16 -6
- package/lib/typescript/core/AudioRecorder.d.ts.map +1 -1
- package/lib/typescript/core/BaseAudioContext.d.ts +9 -3
- package/lib/typescript/core/BaseAudioContext.d.ts.map +1 -1
- package/lib/typescript/core/ConvolverNode.d.ts +12 -0
- package/lib/typescript/core/ConvolverNode.d.ts.map +1 -0
- package/lib/typescript/core/DelayNode.d.ts +9 -0
- package/lib/typescript/core/DelayNode.d.ts.map +1 -0
- package/lib/typescript/core/IIRFilterNode.d.ts +5 -0
- package/lib/typescript/core/IIRFilterNode.d.ts.map +1 -0
- package/lib/typescript/core/OfflineAudioContext.d.ts +1 -1
- package/lib/typescript/core/OfflineAudioContext.d.ts.map +1 -1
- package/lib/typescript/events/types.d.ts +6 -2
- package/lib/typescript/events/types.d.ts.map +1 -1
- package/lib/typescript/interfaces.d.ts +36 -34
- package/lib/typescript/interfaces.d.ts.map +1 -1
- package/lib/typescript/plugin/withAudioAPI.d.ts +1 -0
- package/lib/typescript/plugin/withAudioAPI.d.ts.map +1 -1
- package/lib/typescript/specs/NativeAudioAPIModule.d.ts +18 -6
- package/lib/typescript/specs/NativeAudioAPIModule.d.ts.map +1 -1
- package/lib/typescript/system/AudioManager.d.ts +5 -5
- package/lib/typescript/system/AudioManager.d.ts.map +1 -1
- package/lib/typescript/system/index.d.ts +1 -0
- package/lib/typescript/system/index.d.ts.map +1 -1
- package/lib/typescript/system/notification/PlaybackNotificationManager.d.ts +23 -0
- package/lib/typescript/system/notification/PlaybackNotificationManager.d.ts.map +1 -0
- package/lib/typescript/system/notification/RecordingNotificationManager.d.ts +24 -0
- package/lib/typescript/system/notification/RecordingNotificationManager.d.ts.map +1 -0
- package/lib/typescript/system/notification/SimpleNotificationManager.d.ts +21 -0
- package/lib/typescript/system/notification/SimpleNotificationManager.d.ts.map +1 -0
- package/lib/typescript/system/notification/index.d.ts +5 -0
- package/lib/typescript/system/notification/index.d.ts.map +1 -0
- package/lib/typescript/system/notification/types.d.ts +65 -0
- package/lib/typescript/system/notification/types.d.ts.map +1 -0
- package/lib/typescript/system/types.d.ts +0 -16
- package/lib/typescript/system/types.d.ts.map +1 -1
- package/lib/typescript/types.d.ts +58 -45
- package/lib/typescript/types.d.ts.map +1 -1
- package/lib/typescript/utils/filePresets.d.ts +9 -0
- package/lib/typescript/utils/filePresets.d.ts.map +1 -0
- package/lib/typescript/utils/index.d.ts +1 -8
- package/lib/typescript/utils/index.d.ts.map +1 -1
- package/lib/typescript/web-core/AudioContext.d.ts +9 -2
- package/lib/typescript/web-core/AudioContext.d.ts.map +1 -1
- package/lib/typescript/web-core/BaseAudioContext.d.ts +7 -1
- package/lib/typescript/web-core/BaseAudioContext.d.ts.map +1 -1
- package/lib/typescript/web-core/ConvolverNode.d.ts +11 -0
- package/lib/typescript/web-core/ConvolverNode.d.ts.map +1 -0
- package/lib/typescript/web-core/ConvolverNodeOptions.d.ts +6 -0
- package/lib/typescript/web-core/ConvolverNodeOptions.d.ts.map +1 -0
- package/lib/typescript/web-core/DelayNode.d.ts +8 -0
- package/lib/typescript/web-core/DelayNode.d.ts.map +1 -0
- package/lib/typescript/web-core/IIRFilterNode.d.ts +5 -0
- package/lib/typescript/web-core/IIRFilterNode.d.ts.map +1 -0
- package/lib/typescript/web-core/OfflineAudioContext.d.ts +8 -1
- package/lib/typescript/web-core/OfflineAudioContext.d.ts.map +1 -1
- package/lib/typescript/web-system/index.d.ts +2 -0
- package/lib/typescript/web-system/index.d.ts.map +1 -0
- package/lib/typescript/web-system/notification/PlaybackNotificationManager.d.ts +20 -0
- package/lib/typescript/web-system/notification/PlaybackNotificationManager.d.ts.map +1 -0
- package/lib/typescript/web-system/notification/RecordingNotificationManager.d.ts +20 -0
- package/lib/typescript/web-system/notification/RecordingNotificationManager.d.ts.map +1 -0
- package/lib/typescript/web-system/notification/index.d.ts +3 -0
- package/lib/typescript/web-system/notification/index.d.ts.map +1 -0
- package/package.json +11 -5
- package/scripts/download-prebuilt-binaries.sh +61 -0
- package/scripts/rnaa_utils.rb +8 -0
- package/scripts/validate-worklets-version.js +27 -0
- package/src/AudioAPIModule/AudioAPIModule.ts +122 -0
- package/src/AudioAPIModule/globals.d.ts +33 -0
- package/src/AudioAPIModule/index.ts +1 -0
- package/src/api.ts +21 -52
- package/src/api.web.ts +8 -2
- package/src/core/AudioBufferBaseSourceNode.ts +8 -0
- package/src/core/AudioBufferQueueSourceNode.ts +8 -2
- package/src/core/AudioContext.ts +5 -8
- package/src/core/AudioNode.ts +4 -3
- package/src/core/AudioParam.ts +18 -11
- package/src/core/AudioRecorder.ts +86 -84
- package/src/core/BaseAudioContext.ts +120 -54
- package/src/core/ConvolverNode.ts +35 -0
- package/src/core/DelayNode.ts +13 -0
- package/src/core/IIRFilterNode.ts +25 -0
- package/src/core/OfflineAudioContext.ts +4 -7
- package/src/events/types.ts +7 -3
- package/src/interfaces.ts +55 -34
- package/src/plugin/withAudioAPI.ts +61 -0
- package/src/specs/NativeAudioAPIModule.ts +26 -9
- package/src/system/AudioManager.ts +13 -32
- package/src/system/index.ts +1 -0
- package/src/system/notification/PlaybackNotificationManager.ts +197 -0
- package/src/system/notification/RecordingNotificationManager.ts +247 -0
- package/src/system/notification/SimpleNotificationManager.ts +175 -0
- package/src/system/notification/index.ts +4 -0
- package/src/system/notification/types.ts +111 -0
- package/src/system/types.ts +0 -18
- package/src/types.ts +61 -46
- package/src/utils/filePresets.ts +47 -0
- package/src/utils/index.ts +13 -19
- package/src/web-core/AudioContext.tsx +40 -1
- package/src/web-core/BaseAudioContext.tsx +11 -1
- package/src/web-core/ConvolverNode.tsx +43 -0
- package/src/web-core/ConvolverNodeOptions.tsx +6 -0
- package/src/web-core/DelayNode.tsx +12 -0
- package/src/web-core/IIRFilterNode.tsx +25 -0
- package/src/web-core/OfflineAudioContext.tsx +39 -0
- package/src/web-system/index.ts +1 -0
- package/src/web-system/notification/PlaybackNotificationManager.ts +64 -0
- package/src/web-system/notification/RecordingNotificationManager.ts +64 -0
- package/src/web-system/notification/index.ts +2 -0
- package/android/src/main/cpp/audioapi/android/core/utils/FileUtils.h +0 -34
- package/android/src/main/cpp/audioapi/android/core/utils/FileUtilts.cpp +0 -133
- package/android/src/main/cpp/audioapi/android/core/utils/ffmpegBackend/FFmpegAudioFileOptions.cpp +0 -154
- package/android/src/main/cpp/audioapi/android/core/utils/ffmpegBackend/FFmpegAudioFileOptions.h +0 -41
- package/android/src/main/cpp/audioapi/android/core/utils/miniaudioBackend/MiniAudioFileOptions.cpp +0 -47
- package/android/src/main/cpp/audioapi/android/core/utils/miniaudioBackend/MiniAudioFileOptions.h +0 -28
- package/android/src/main/java/com/swmansion/audioapi/system/LockScreenManager.kt +0 -325
- package/android/src/main/java/com/swmansion/audioapi/system/MediaNotificationManager.kt +0 -262
- package/android/src/main/java/com/swmansion/audioapi/system/MediaReceiver.kt +0 -57
- package/android/src/main/java/com/swmansion/audioapi/system/MediaSessionCallback.kt +0 -61
- package/common/cpp/audioapi/libs/ffmpeg/INSTRUCTIONS.md +0 -32
- package/common/cpp/audioapi/libs/ffmpeg/create_xcframework.sh +0 -111
- package/common/cpp/audioapi/libs/ffmpeg/ffmpeg_setup.sh +0 -391
- package/ios/audioapi/ios/core/IOSAudioFileOptions.h +0 -35
- package/ios/audioapi/ios/core/IOSAudioFileOptions.mm +0 -135
- package/ios/audioapi/ios/core/IOSAudioFileWriter.h +0 -38
- package/ios/audioapi/ios/core/IOSAudioFileWriter.mm +0 -187
- package/ios/audioapi/ios/system/LockScreenManager.h +0 -24
- package/ios/audioapi/ios/system/LockScreenManager.mm +0 -310
- package/lib/commonjs/utils/bitEnums.js +0 -33
- package/lib/commonjs/utils/bitEnums.js.map +0 -1
- package/lib/module/utils/bitEnums.js +0 -27
- package/lib/module/utils/bitEnums.js.map +0 -1
- package/lib/typescript/utils/bitEnums.d.ts +0 -4
- package/lib/typescript/utils/bitEnums.d.ts.map +0 -1
- package/metro-config/index.d.ts +0 -5
- package/metro-config/index.js +0 -41
- package/metro-config/tsconfig.json +0 -3
- package/src/utils/bitEnums.ts +0 -51
- package/common/cpp/audioapi/external/{libavcodec.xcframework → ffmpeg_ios/libavcodec.xcframework}/Info.plist +5 -5
- package/common/cpp/audioapi/external/{libavcodec.xcframework → ffmpeg_ios/libavcodec.xcframework}/ios-arm64/libavcodec.framework/Info.plist +0 -0
- package/common/cpp/audioapi/external/{libavcodec.xcframework → ffmpeg_ios/libavcodec.xcframework}/ios-arm64_x86_64-simulator/libavcodec.framework/Info.plist +0 -0
- package/common/cpp/audioapi/external/{libavformat.xcframework → ffmpeg_ios/libavformat.xcframework}/Info.plist +0 -0
- package/common/cpp/audioapi/external/{libavformat.xcframework → ffmpeg_ios/libavformat.xcframework}/ios-arm64/libavformat.framework/Info.plist +0 -0
- package/common/cpp/audioapi/external/{libavformat.xcframework → ffmpeg_ios/libavformat.xcframework}/ios-arm64_x86_64-simulator/libavformat.framework/Info.plist +0 -0
- package/common/cpp/audioapi/external/{libavutil.xcframework → ffmpeg_ios/libavutil.xcframework}/Info.plist +5 -5
- package/common/cpp/audioapi/external/{libavutil.xcframework → ffmpeg_ios/libavutil.xcframework}/ios-arm64/libavutil.framework/Info.plist +0 -0
- package/common/cpp/audioapi/external/{libavutil.xcframework → ffmpeg_ios/libavutil.xcframework}/ios-arm64_x86_64-simulator/libavutil.framework/Info.plist +0 -0
- package/common/cpp/audioapi/external/{libswresample.xcframework → ffmpeg_ios/libswresample.xcframework}/Info.plist +5 -5
- /package/common/cpp/audioapi/external/{libswresample.xcframework → ffmpeg_ios/libswresample.xcframework}/ios-arm64/libswresample.framework/Info.plist +0 -0
- /package/common/cpp/audioapi/external/{libswresample.xcframework → ffmpeg_ios/libswresample.xcframework}/ios-arm64_x86_64-simulator/libswresample.framework/Info.plist +0 -0
|
@@ -1,8 +1,10 @@
|
|
|
1
1
|
#pragma once
|
|
2
|
-
#include <thread>
|
|
3
|
-
#include <vector>
|
|
4
2
|
#include <functional>
|
|
3
|
+
#include <memory>
|
|
4
|
+
#include <thread>
|
|
5
|
+
#include <utility>
|
|
5
6
|
#include <variant>
|
|
7
|
+
#include <vector>
|
|
6
8
|
|
|
7
9
|
#include <audioapi/utils/MoveOnlyFunction.hpp>
|
|
8
10
|
#include <audioapi/utils/SpscChannel.hpp>
|
|
@@ -17,32 +19,78 @@ namespace audioapi {
|
|
|
17
19
|
/// @note IMPORTANT: ThreadPool is not thread-safe and events should be scheduled from a single thread only.
|
|
18
20
|
class ThreadPool {
|
|
19
21
|
struct StopEvent {};
|
|
20
|
-
struct TaskEvent {
|
|
22
|
+
struct TaskEvent {
|
|
23
|
+
audioapi::move_only_function<void()> task;
|
|
24
|
+
};
|
|
21
25
|
using Event = std::variant<TaskEvent, StopEvent>;
|
|
22
26
|
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
27
|
+
struct Cntrl {
|
|
28
|
+
std::atomic<bool> waitingForTasks{false};
|
|
29
|
+
std::atomic<size_t> tasksScheduled{0};
|
|
30
|
+
};
|
|
31
|
+
|
|
32
|
+
using Sender = channels::spsc::Sender<
|
|
33
|
+
Event,
|
|
34
|
+
channels::spsc::OverflowStrategy::WAIT_ON_FULL,
|
|
35
|
+
channels::spsc::WaitStrategy::ATOMIC_WAIT>;
|
|
36
|
+
using Receiver = channels::spsc::Receiver<
|
|
37
|
+
Event,
|
|
38
|
+
channels::spsc::OverflowStrategy::WAIT_ON_FULL,
|
|
39
|
+
channels::spsc::WaitStrategy::ATOMIC_WAIT>;
|
|
40
|
+
|
|
41
|
+
public:
|
|
26
42
|
/// @brief Construct a new ThreadPool
|
|
27
43
|
/// @param numThreads The number of worker threads to create
|
|
28
44
|
/// @param loadBalancerQueueSize The size of the load balancer's queue
|
|
29
45
|
/// @param workerQueueSize The size of each worker thread's queue
|
|
30
|
-
ThreadPool(
|
|
31
|
-
|
|
46
|
+
explicit ThreadPool(
|
|
47
|
+
size_t numThreads,
|
|
48
|
+
size_t loadBalancerQueueSize = 32,
|
|
49
|
+
size_t workerQueueSize = 32) {
|
|
50
|
+
auto [sender, receiver] = channels::spsc::channel<
|
|
51
|
+
Event,
|
|
52
|
+
channels::spsc::OverflowStrategy::WAIT_ON_FULL,
|
|
53
|
+
channels::spsc::WaitStrategy::ATOMIC_WAIT>(loadBalancerQueueSize);
|
|
32
54
|
loadBalancerSender = std::move(sender);
|
|
33
55
|
std::vector<Sender> workerSenders;
|
|
34
56
|
workerSenders.reserve(numThreads);
|
|
35
57
|
for (size_t i = 0; i < numThreads; ++i) {
|
|
36
|
-
auto [workerSender, workerReceiver] = channels::spsc::channel<
|
|
58
|
+
auto [workerSender, workerReceiver] = channels::spsc::channel<
|
|
59
|
+
Event,
|
|
60
|
+
channels::spsc::OverflowStrategy::WAIT_ON_FULL,
|
|
61
|
+
channels::spsc::WaitStrategy::ATOMIC_WAIT>(workerQueueSize);
|
|
37
62
|
workers.emplace_back(&ThreadPool::workerThreadFunc, this, std::move(workerReceiver));
|
|
38
63
|
workerSenders.emplace_back(std::move(workerSender));
|
|
39
64
|
}
|
|
40
|
-
loadBalancerThread = std::thread(
|
|
65
|
+
loadBalancerThread = std::thread(
|
|
66
|
+
&ThreadPool::loadBalancerThreadFunc, this, std::move(receiver), std::move(workerSenders));
|
|
67
|
+
controlBlock_ = std::make_unique<Cntrl>();
|
|
68
|
+
}
|
|
69
|
+
ThreadPool(const ThreadPool &) = delete;
|
|
70
|
+
ThreadPool &operator=(const ThreadPool &) = delete;
|
|
71
|
+
ThreadPool(ThreadPool &&other)
|
|
72
|
+
: loadBalancerThread(std::move(other.loadBalancerThread)),
|
|
73
|
+
workers(std::move(other.workers)),
|
|
74
|
+
loadBalancerSender(std::move(other.loadBalancerSender)),
|
|
75
|
+
controlBlock_(std::move(other.controlBlock_)) {}
|
|
76
|
+
ThreadPool &operator=(ThreadPool &&other) {
|
|
77
|
+
if (this != &other) {
|
|
78
|
+
loadBalancerThread = std::move(other.loadBalancerThread);
|
|
79
|
+
workers = std::move(other.workers);
|
|
80
|
+
loadBalancerSender = std::move(other.loadBalancerSender);
|
|
81
|
+
controlBlock_ = std::move(other.controlBlock_);
|
|
82
|
+
other.movedFrom_ = true;
|
|
83
|
+
}
|
|
84
|
+
return *this;
|
|
41
85
|
}
|
|
86
|
+
|
|
42
87
|
~ThreadPool() {
|
|
88
|
+
if (movedFrom_) {
|
|
89
|
+
return;
|
|
90
|
+
}
|
|
43
91
|
loadBalancerSender.send(StopEvent{});
|
|
44
92
|
loadBalancerThread.join();
|
|
45
|
-
for (auto&
|
|
93
|
+
for (auto &worker : workers) {
|
|
46
94
|
worker.join();
|
|
47
95
|
}
|
|
48
96
|
}
|
|
@@ -57,18 +105,54 @@ public:
|
|
|
57
105
|
/// @note The task should not throw exceptions, as they will not be caught.
|
|
58
106
|
/// @note The task should end at some point, otherwise the thread pool will never be able to shut down.
|
|
59
107
|
/// @note IMPORTANT: This function is not thread-safe and should be called from a single thread only.
|
|
60
|
-
template
|
|
61
|
-
|
|
62
|
-
|
|
108
|
+
template <
|
|
109
|
+
typename Func,
|
|
110
|
+
typename... Args,
|
|
111
|
+
typename = std::enable_if_t<std::is_invocable_r_v<void, Func, Args...>>>
|
|
112
|
+
void schedule(Func &&task, Args &&...args) noexcept {
|
|
113
|
+
controlBlock_->tasksScheduled.fetch_add(1, std::memory_order_release);
|
|
114
|
+
|
|
115
|
+
/// We know that lifetime of each worker thus spsc thus lambda is strongly bounded by ThreadPool lifetime
|
|
116
|
+
/// so we can safely capture control block pointer unsafely here
|
|
117
|
+
Cntrl *cntrl = controlBlock_.get();
|
|
118
|
+
auto boundTask = [cntrl,
|
|
119
|
+
f = std::forward<Func>(task),
|
|
120
|
+
... capturedArgs = std::forward<Args>(args)]() mutable {
|
|
63
121
|
f(std::forward<Args>(capturedArgs)...);
|
|
122
|
+
size_t left = cntrl->tasksScheduled.fetch_sub(1, std::memory_order_acq_rel) - 1;
|
|
123
|
+
if (left == 0) {
|
|
124
|
+
cntrl->waitingForTasks.store(false, std::memory_order_release);
|
|
125
|
+
cntrl->waitingForTasks.notify_one();
|
|
126
|
+
}
|
|
64
127
|
};
|
|
65
128
|
loadBalancerSender.send(TaskEvent{audioapi::move_only_function<void()>(std::move(boundTask))});
|
|
66
129
|
}
|
|
67
130
|
|
|
68
|
-
|
|
131
|
+
/// @brief Waits for all scheduled tasks to complete
|
|
132
|
+
void wait() {
|
|
133
|
+
/// This logic might seem incorrect at first glance
|
|
134
|
+
/// Main principle for this is that there is only one thread scheduling tasks
|
|
135
|
+
/// If he is waiting for the tasks he CANNOT schedule new tasks so we can assume partial
|
|
136
|
+
/// synchronization here.
|
|
137
|
+
/// We first store true so if any task finishes at this moment he will flip it
|
|
138
|
+
/// Then we check if there are any tasks scheduled
|
|
139
|
+
/// If there are none we can return immediately
|
|
140
|
+
/// If there are some we wait until the last task flips the flag to false
|
|
141
|
+
controlBlock_->waitingForTasks.store(true, std::memory_order_release);
|
|
142
|
+
if (controlBlock_->tasksScheduled.load(std::memory_order_acquire) == 0) {
|
|
143
|
+
controlBlock_->waitingForTasks.store(false, std::memory_order_release);
|
|
144
|
+
return;
|
|
145
|
+
}
|
|
146
|
+
controlBlock_->waitingForTasks.wait(true, std::memory_order_acquire);
|
|
147
|
+
return;
|
|
148
|
+
}
|
|
149
|
+
|
|
150
|
+
private:
|
|
69
151
|
std::thread loadBalancerThread;
|
|
70
152
|
std::vector<std::thread> workers;
|
|
71
153
|
Sender loadBalancerSender;
|
|
154
|
+
std::unique_ptr<Cntrl> controlBlock_;
|
|
155
|
+
bool movedFrom_ = false;
|
|
72
156
|
|
|
73
157
|
void workerThreadFunc(Receiver &&receiver) {
|
|
74
158
|
Receiver localReceiver = std::move(receiver);
|
|
@@ -77,9 +161,9 @@ private:
|
|
|
77
161
|
/// We use [[unlikely]] and [[likely]] attributes to help the compiler optimize the branching.
|
|
78
162
|
/// we expect most of the time to receive TaskEvent, and rarely StopEvent.
|
|
79
163
|
/// and whenever we receive StopEvent we can burn some cycles as it will not be expected to execute fast.
|
|
80
|
-
if (std::holds_alternative<StopEvent>(event)) [[
|
|
164
|
+
if (std::holds_alternative<StopEvent>(event)) [[unlikely]] {
|
|
81
165
|
break;
|
|
82
|
-
} else if (std::holds_alternative<TaskEvent>(event)) [[
|
|
166
|
+
} else if (std::holds_alternative<TaskEvent>(event)) [[likely]] {
|
|
83
167
|
std::get<TaskEvent>(event).task();
|
|
84
168
|
}
|
|
85
169
|
}
|
|
@@ -94,15 +178,15 @@ private:
|
|
|
94
178
|
/// We use [[unlikely]] and [[likely]] attributes to help the compiler optimize the branching.
|
|
95
179
|
/// we expect most of the time to receive TaskEvent, and rarely StopEvent.
|
|
96
180
|
/// and whenever we receive StopEvent we can burn some cycles as it will not be expected to execute fast.
|
|
97
|
-
if (std::holds_alternative<StopEvent>(event)) [[
|
|
181
|
+
if (std::holds_alternative<StopEvent>(event)) [[unlikely]] {
|
|
98
182
|
// Propagate stop event to all workers
|
|
99
183
|
for (size_t i = 0; i < localWorkerSenders.size(); ++i) {
|
|
100
184
|
localWorkerSenders[i].send(StopEvent{});
|
|
101
185
|
}
|
|
102
186
|
break;
|
|
103
|
-
} else if (std::holds_alternative<TaskEvent>(event)) [[
|
|
187
|
+
} else if (std::holds_alternative<TaskEvent>(event)) [[likely]] {
|
|
104
188
|
// Dispatch task to the next worker in round-robin fashion
|
|
105
|
-
auto&
|
|
189
|
+
auto &taskEvent = std::get<TaskEvent>(event);
|
|
106
190
|
localWorkerSenders[nextWorker].send(std::move(taskEvent));
|
|
107
191
|
nextWorker = (nextWorker + 1) % localWorkerSenders.size();
|
|
108
192
|
}
|
|
@@ -12,41 +12,39 @@ FetchContent_Declare(
|
|
|
12
12
|
googletest
|
|
13
13
|
URL https://github.com/google/googletest/archive/3983f67e32fb3e9294487b9d4f9586efa6e5d088.zip
|
|
14
14
|
)
|
|
15
|
+
|
|
15
16
|
# For Windows: Prevent overriding the parent project's compiler/linker settings
|
|
16
17
|
set(gtest_force_shared_crt ON CACHE BOOL "" FORCE)
|
|
17
18
|
FetchContent_MakeAvailable(googletest)
|
|
18
19
|
|
|
19
20
|
enable_testing()
|
|
20
21
|
|
|
22
|
+
set(REACT_NATIVE_AUDIO_API_DIR "${ROOT}/node_modules/react-native-audio-api")
|
|
23
|
+
|
|
21
24
|
file(GLOB_RECURSE RNAUDIOAPI_SRC
|
|
22
25
|
CONFIGURE_DEPENDS
|
|
23
|
-
"${
|
|
24
|
-
"${ROOT}/node_modules/react-native-audio-api/android/src/main/cpp/audioapi/android/core/utils/AudioDecoder.cpp"
|
|
26
|
+
"${REACT_NATIVE_AUDIO_API_DIR}/common/cpp/audioapi/*.cpp"
|
|
25
27
|
)
|
|
26
28
|
|
|
27
29
|
# exclude HostObjects from tests
|
|
28
30
|
list(FILTER RNAUDIOAPI_SRC EXCLUDE REGEX ".*/audioapi/HostObjects/.*\\.cpp$")
|
|
31
|
+
# exclude worklet nodes
|
|
32
|
+
list(FILTER RNAUDIOAPI_SRC EXCLUDE REGEX ".*/Worklet.*Node\\.cpp$")
|
|
29
33
|
|
|
30
34
|
list(REMOVE_ITEM RNAUDIOAPI_SRC
|
|
31
|
-
"${
|
|
32
|
-
"${
|
|
33
|
-
"${ROOT}/node_modules/react-native-audio-api/common/cpp/audioapi/core/effects/WorkletProcessingNode.cpp"
|
|
34
|
-
"${ROOT}/node_modules/react-native-audio-api/common/cpp/audioapi/core/sources/WorkletSourceNode.cpp"
|
|
35
|
-
"${ROOT}/node_modules/react-native-audio-api/common/cpp/audioapi/core/sources/StreamerNode.cpp"
|
|
36
|
-
"${ROOT}/node_modules/react-native-audio-api/common/cpp/audioapi/core/sources/StreamerNode.h"
|
|
37
|
-
"${ROOT}/node_modules/react-native-audio-api/common/cpp/audioapi/libs/ffmpeg/FFmpegDecoding.cpp"
|
|
38
|
-
"${ROOT}/node_modules/react-native-audio-api/common/cpp/audioapi/libs/ffmpeg/FFmpegDecoding.h"
|
|
35
|
+
"${REACT_NATIVE_AUDIO_API_DIR}/common/cpp/audioapi/core/AudioContext.cpp"
|
|
36
|
+
"${REACT_NATIVE_AUDIO_API_DIR}/common/cpp/audioapi/libs/ffmpeg/FFmpegDecoding.cpp"
|
|
39
37
|
)
|
|
40
38
|
|
|
41
39
|
file(GLOB_RECURSE RNAUDIOAPI_LIBS
|
|
42
40
|
CONFIGURE_DEPENDS
|
|
43
|
-
"${
|
|
44
|
-
"${
|
|
41
|
+
"${REACT_NATIVE_AUDIO_API_DIR}/common/cpp/audioapi/libs/*.c"
|
|
42
|
+
"${REACT_NATIVE_AUDIO_API_DIR}/common/cpp/audioapi/libs/*.h"
|
|
45
43
|
)
|
|
46
44
|
|
|
47
45
|
list(REMOVE_ITEM RNAUDIOAPI_LIBS
|
|
48
|
-
"${
|
|
49
|
-
"${
|
|
46
|
+
"${REACT_NATIVE_AUDIO_API_DIR}/common/cpp/audioapi/libs/miniaudio/decoders/libopus/miniaudio_libopus.c"
|
|
47
|
+
"${REACT_NATIVE_AUDIO_API_DIR}/common/cpp/audioapi/libs/miniaudio/decoders/libvorbis/miniaudio_libvorbis.c"
|
|
50
48
|
)
|
|
51
49
|
|
|
52
50
|
add_library(rnaudioapi STATIC ${RNAUDIOAPI_SRC})
|
|
@@ -57,6 +55,8 @@ target_include_directories(rnaudioapi PUBLIC
|
|
|
57
55
|
${JSI_DIR}
|
|
58
56
|
"${REACT_NATIVE_DIR}/ReactCommon"
|
|
59
57
|
"${REACT_NATIVE_DIR}/ReactCommon/callinvoker"
|
|
58
|
+
${gtest_SOURCE_DIR}/include
|
|
59
|
+
${gmock_SOURCE_DIR}/include
|
|
60
60
|
)
|
|
61
61
|
|
|
62
62
|
target_include_directories(rnaudioapi_libs PUBLIC
|
|
@@ -73,9 +73,9 @@ add_executable(
|
|
|
73
73
|
${test_src}
|
|
74
74
|
)
|
|
75
75
|
|
|
76
|
-
add_compile_definitions(AUDIO_API_TEST_SUITE)
|
|
77
76
|
add_compile_definitions(RN_AUDIO_API_ENABLE_WORKLETS=0)
|
|
78
77
|
add_compile_definitions(RN_AUDIO_API_TEST=1)
|
|
78
|
+
add_compile_definitions(RN_AUDIO_API_FFMPEG_DISABLED=1)
|
|
79
79
|
|
|
80
80
|
target_link_libraries(tests
|
|
81
81
|
rnaudioapi
|
|
@@ -3,12 +3,14 @@
|
|
|
3
3
|
#include <audioapi/core/utils/worklets/SafeIncludes.h>
|
|
4
4
|
#include <gtest/gtest.h>
|
|
5
5
|
#include <test/src/MockAudioEventHandlerRegistry.h>
|
|
6
|
+
#include <memory>
|
|
7
|
+
#include <vector>
|
|
6
8
|
|
|
7
9
|
using namespace audioapi;
|
|
8
10
|
|
|
9
11
|
class AudioParamTest : public ::testing::Test {
|
|
10
12
|
protected:
|
|
11
|
-
std::shared_ptr<
|
|
13
|
+
std::shared_ptr<MockAudioEventHandlerRegistry> eventRegistry;
|
|
12
14
|
std::unique_ptr<OfflineAudioContext> context;
|
|
13
15
|
static constexpr int sampleRate = 44100;
|
|
14
16
|
|
|
@@ -119,8 +121,7 @@ TEST_F(AudioParamTest, SetTargetAtTime) {
|
|
|
119
121
|
TEST_F(AudioParamTest, SetValueCurveAtTime) {
|
|
120
122
|
AudioParam param = AudioParam(0.0, 0.0, 1.0, context.get());
|
|
121
123
|
param.setValue(0.5);
|
|
122
|
-
auto curve = std::make_shared<std::vector<float>>(
|
|
123
|
-
std::vector<float>{0.1, 0.4, 0.2, 0.8, 0.5});
|
|
124
|
+
auto curve = std::make_shared<std::vector<float>>(std::vector<float>{0.1, 0.4, 0.2, 0.8, 0.5});
|
|
124
125
|
param.setValueCurveAtTime(curve, curve->size(), 0.1, 0.2);
|
|
125
126
|
// 5 elements over 0.2s => each element is 0.04s apart
|
|
126
127
|
|
|
@@ -0,0 +1,113 @@
|
|
|
1
|
+
#include <audioapi/core/OfflineAudioContext.h>
|
|
2
|
+
#include <audioapi/core/destinations/AudioDestinationNode.h>
|
|
3
|
+
#include <audioapi/core/sources/AudioScheduledSourceNode.h>
|
|
4
|
+
#include <audioapi/core/utils/worklets/SafeIncludes.h>
|
|
5
|
+
#include <audioapi/utils/AudioBus.h>
|
|
6
|
+
#include <gtest/gtest.h>
|
|
7
|
+
#include <test/src/MockAudioEventHandlerRegistry.h>
|
|
8
|
+
#include <memory>
|
|
9
|
+
|
|
10
|
+
using namespace audioapi;
|
|
11
|
+
static constexpr int SAMPLE_RATE = 44100;
|
|
12
|
+
static constexpr int RENDER_QUANTUM = 128;
|
|
13
|
+
static constexpr double RENDER_QUANTUM_TIME = static_cast<double>(RENDER_QUANTUM) / SAMPLE_RATE;
|
|
14
|
+
|
|
15
|
+
class AudioScheduledSourceTest : public ::testing::Test {
|
|
16
|
+
protected:
|
|
17
|
+
std::shared_ptr<MockAudioEventHandlerRegistry> eventRegistry;
|
|
18
|
+
std::unique_ptr<OfflineAudioContext> context;
|
|
19
|
+
|
|
20
|
+
void SetUp() override {
|
|
21
|
+
eventRegistry = std::make_shared<MockAudioEventHandlerRegistry>();
|
|
22
|
+
context = std::make_unique<OfflineAudioContext>(
|
|
23
|
+
2, 5 * SAMPLE_RATE, SAMPLE_RATE, eventRegistry, RuntimeRegistry{});
|
|
24
|
+
}
|
|
25
|
+
};
|
|
26
|
+
|
|
27
|
+
class TestableAudioScheduledSourceNode : public AudioScheduledSourceNode {
|
|
28
|
+
public:
|
|
29
|
+
explicit TestableAudioScheduledSourceNode(BaseAudioContext *context)
|
|
30
|
+
: AudioScheduledSourceNode(context) {
|
|
31
|
+
isInitialized_ = true;
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
void updatePlaybackInfo(
|
|
35
|
+
const std::shared_ptr<AudioBus> &processingBus,
|
|
36
|
+
int framesToProcess,
|
|
37
|
+
size_t &startOffset,
|
|
38
|
+
size_t &nonSilentFramesToProcess) {
|
|
39
|
+
AudioScheduledSourceNode::updatePlaybackInfo(
|
|
40
|
+
processingBus, framesToProcess, startOffset, nonSilentFramesToProcess);
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
std::shared_ptr<AudioBus> processNode(const std::shared_ptr<AudioBus> &, int) override {
|
|
44
|
+
return nullptr;
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
PlaybackState getPlaybackState() const {
|
|
48
|
+
return playbackState_;
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
void playFrames(int frames) {
|
|
52
|
+
size_t startOffset = 0;
|
|
53
|
+
size_t nonSilentFramesToProcess = 0;
|
|
54
|
+
auto processingBus = std::make_shared<AudioBus>(128, 2, static_cast<float>(SAMPLE_RATE));
|
|
55
|
+
updatePlaybackInfo(processingBus, frames, startOffset, nonSilentFramesToProcess);
|
|
56
|
+
context_->getDestination()->renderAudio(processingBus, frames);
|
|
57
|
+
}
|
|
58
|
+
};
|
|
59
|
+
|
|
60
|
+
TEST_F(AudioScheduledSourceTest, IsUnscheduledStateSetCorrectly) {
|
|
61
|
+
auto sourceNode = TestableAudioScheduledSourceNode(context.get());
|
|
62
|
+
EXPECT_EQ(sourceNode.getPlaybackState(), AudioScheduledSourceNode::PlaybackState::UNSCHEDULED);
|
|
63
|
+
|
|
64
|
+
sourceNode.start(RENDER_QUANTUM_TIME);
|
|
65
|
+
EXPECT_NE(sourceNode.getPlaybackState(), AudioScheduledSourceNode::PlaybackState::UNSCHEDULED);
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
TEST_F(AudioScheduledSourceTest, IsScheduledStateSetCorrectly) {
|
|
69
|
+
auto sourceNode = TestableAudioScheduledSourceNode(context.get());
|
|
70
|
+
sourceNode.start(RENDER_QUANTUM_TIME);
|
|
71
|
+
EXPECT_EQ(sourceNode.getPlaybackState(), AudioScheduledSourceNode::PlaybackState::SCHEDULED);
|
|
72
|
+
|
|
73
|
+
sourceNode.playFrames(RENDER_QUANTUM);
|
|
74
|
+
EXPECT_EQ(sourceNode.getPlaybackState(), AudioScheduledSourceNode::PlaybackState::SCHEDULED);
|
|
75
|
+
|
|
76
|
+
sourceNode.playFrames(1);
|
|
77
|
+
EXPECT_NE(sourceNode.getPlaybackState(), AudioScheduledSourceNode::PlaybackState::SCHEDULED);
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
TEST_F(AudioScheduledSourceTest, IsPlayingStateSetCorrectly) {
|
|
81
|
+
auto sourceNode = TestableAudioScheduledSourceNode(context.get());
|
|
82
|
+
sourceNode.start(0);
|
|
83
|
+
sourceNode.stop(RENDER_QUANTUM_TIME);
|
|
84
|
+
|
|
85
|
+
sourceNode.playFrames(RENDER_QUANTUM);
|
|
86
|
+
EXPECT_EQ(sourceNode.getPlaybackState(), AudioScheduledSourceNode::PlaybackState::PLAYING);
|
|
87
|
+
|
|
88
|
+
sourceNode.playFrames(1);
|
|
89
|
+
EXPECT_NE(sourceNode.getPlaybackState(), AudioScheduledSourceNode::PlaybackState::PLAYING);
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
TEST_F(AudioScheduledSourceTest, IsStopScheduledStateSetCorrectly) {
|
|
93
|
+
auto sourceNode = TestableAudioScheduledSourceNode(context.get());
|
|
94
|
+
sourceNode.start(0);
|
|
95
|
+
sourceNode.stop(RENDER_QUANTUM_TIME);
|
|
96
|
+
sourceNode.playFrames(1); // start playing
|
|
97
|
+
sourceNode.playFrames(RENDER_QUANTUM);
|
|
98
|
+
EXPECT_EQ(sourceNode.getPlaybackState(), AudioScheduledSourceNode::PlaybackState::STOP_SCHEDULED);
|
|
99
|
+
|
|
100
|
+
sourceNode.playFrames(1);
|
|
101
|
+
EXPECT_NE(sourceNode.getPlaybackState(), AudioScheduledSourceNode::PlaybackState::STOP_SCHEDULED);
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
TEST_F(AudioScheduledSourceTest, IsFinishedStateSetCorrectly) {
|
|
105
|
+
auto sourceNode = TestableAudioScheduledSourceNode(context.get());
|
|
106
|
+
sourceNode.start(0);
|
|
107
|
+
sourceNode.stop(RENDER_QUANTUM_TIME);
|
|
108
|
+
sourceNode.playFrames(1); // start playing
|
|
109
|
+
|
|
110
|
+
sourceNode.playFrames(RENDER_QUANTUM);
|
|
111
|
+
sourceNode.playFrames(1);
|
|
112
|
+
EXPECT_TRUE(sourceNode.isFinished());
|
|
113
|
+
}
|
|
@@ -5,12 +5,13 @@
|
|
|
5
5
|
#include <audioapi/utils/AudioBus.h>
|
|
6
6
|
#include <gtest/gtest.h>
|
|
7
7
|
#include <test/src/MockAudioEventHandlerRegistry.h>
|
|
8
|
+
#include <memory>
|
|
8
9
|
|
|
9
10
|
using namespace audioapi;
|
|
10
11
|
|
|
11
12
|
class ConstantSourceTest : public ::testing::Test {
|
|
12
13
|
protected:
|
|
13
|
-
std::shared_ptr<
|
|
14
|
+
std::shared_ptr<MockAudioEventHandlerRegistry> eventRegistry;
|
|
14
15
|
std::unique_ptr<OfflineAudioContext> context;
|
|
15
16
|
static constexpr int sampleRate = 44100;
|
|
16
17
|
|
|
@@ -23,8 +24,7 @@ class ConstantSourceTest : public ::testing::Test {
|
|
|
23
24
|
|
|
24
25
|
class TestableConstantSourceNode : public ConstantSourceNode {
|
|
25
26
|
public:
|
|
26
|
-
explicit TestableConstantSourceNode(BaseAudioContext *context)
|
|
27
|
-
: ConstantSourceNode(context) {}
|
|
27
|
+
explicit TestableConstantSourceNode(BaseAudioContext *context) : ConstantSourceNode(context) {}
|
|
28
28
|
|
|
29
29
|
void setOffsetParam(float value) {
|
|
30
30
|
getOffsetParam()->setValue(value);
|
|
@@ -45,10 +45,8 @@ TEST_F(ConstantSourceTest, ConstantSourceCanBeCreated) {
|
|
|
45
45
|
TEST_F(ConstantSourceTest, ConstantSourceOutputsConstantValue) {
|
|
46
46
|
static constexpr int FRAMES_TO_PROCESS = 4;
|
|
47
47
|
|
|
48
|
-
auto bus =
|
|
49
|
-
|
|
50
|
-
auto constantSource =
|
|
51
|
-
std::make_shared<TestableConstantSourceNode>(context.get());
|
|
48
|
+
auto bus = std::make_shared<audioapi::AudioBus>(FRAMES_TO_PROCESS, 1, sampleRate);
|
|
49
|
+
auto constantSource = std::make_shared<TestableConstantSourceNode>(context.get());
|
|
52
50
|
constantSource->start(context->getCurrentTime());
|
|
53
51
|
auto resultBus = constantSource->processNode(bus, FRAMES_TO_PROCESS);
|
|
54
52
|
|
|
@@ -0,0 +1,108 @@
|
|
|
1
|
+
#include <audioapi/core/OfflineAudioContext.h>
|
|
2
|
+
#include <audioapi/core/effects/DelayNode.h>
|
|
3
|
+
#include <audioapi/core/utils/worklets/SafeIncludes.h>
|
|
4
|
+
#include <audioapi/utils/AudioArray.h>
|
|
5
|
+
#include <audioapi/utils/AudioBus.h>
|
|
6
|
+
#include <gtest/gtest.h>
|
|
7
|
+
#include <test/src/MockAudioEventHandlerRegistry.h>
|
|
8
|
+
#include <memory>
|
|
9
|
+
|
|
10
|
+
using namespace audioapi;
|
|
11
|
+
|
|
12
|
+
class DelayTest : public ::testing::Test {
|
|
13
|
+
protected:
|
|
14
|
+
std::shared_ptr<MockAudioEventHandlerRegistry> eventRegistry;
|
|
15
|
+
std::unique_ptr<OfflineAudioContext> context;
|
|
16
|
+
static constexpr int sampleRate = 44100;
|
|
17
|
+
|
|
18
|
+
void SetUp() override {
|
|
19
|
+
eventRegistry = std::make_shared<MockAudioEventHandlerRegistry>();
|
|
20
|
+
context = std::make_unique<OfflineAudioContext>(
|
|
21
|
+
2, 5 * sampleRate, sampleRate, eventRegistry, RuntimeRegistry{});
|
|
22
|
+
}
|
|
23
|
+
};
|
|
24
|
+
|
|
25
|
+
class TestableDelayNode : public DelayNode {
|
|
26
|
+
public:
|
|
27
|
+
explicit TestableDelayNode(BaseAudioContext *context) : DelayNode(context, 1) {}
|
|
28
|
+
|
|
29
|
+
void setDelayTimeParam(float value) {
|
|
30
|
+
getDelayTimeParam()->setValue(value);
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
std::shared_ptr<AudioBus> processNode(
|
|
34
|
+
const std::shared_ptr<AudioBus> &processingBus,
|
|
35
|
+
int framesToProcess) override {
|
|
36
|
+
return DelayNode::processNode(processingBus, framesToProcess);
|
|
37
|
+
}
|
|
38
|
+
};
|
|
39
|
+
|
|
40
|
+
TEST_F(DelayTest, DelayCanBeCreated) {
|
|
41
|
+
auto delay = context->createDelay(1.0f);
|
|
42
|
+
ASSERT_NE(delay, nullptr);
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
TEST_F(DelayTest, DelayWithZeroDelayOutputsInputSignal) {
|
|
46
|
+
static constexpr float DELAY_TIME = 0.0f;
|
|
47
|
+
static constexpr int FRAMES_TO_PROCESS = 4;
|
|
48
|
+
auto delayNode = std::make_shared<TestableDelayNode>(context.get());
|
|
49
|
+
delayNode->setDelayTimeParam(DELAY_TIME);
|
|
50
|
+
|
|
51
|
+
auto bus = std::make_shared<audioapi::AudioBus>(FRAMES_TO_PROCESS, 1, sampleRate);
|
|
52
|
+
for (size_t i = 0; i < bus->getSize(); ++i) {
|
|
53
|
+
bus->getChannel(0)->getData()[i] = i + 1;
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
auto resultBus = delayNode->processNode(bus, FRAMES_TO_PROCESS);
|
|
57
|
+
for (size_t i = 0; i < FRAMES_TO_PROCESS; ++i) {
|
|
58
|
+
EXPECT_FLOAT_EQ((*resultBus->getChannel(0))[i], static_cast<float>(i + 1));
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
TEST_F(DelayTest, DelayAppliesTimeShiftCorrectly) {
|
|
63
|
+
float DELAY_TIME = (128.0 / context->getSampleRate()) * 0.5;
|
|
64
|
+
static constexpr int FRAMES_TO_PROCESS = 128;
|
|
65
|
+
auto delayNode = std::make_shared<TestableDelayNode>(context.get());
|
|
66
|
+
delayNode->setDelayTimeParam(DELAY_TIME);
|
|
67
|
+
|
|
68
|
+
auto bus = std::make_shared<audioapi::AudioBus>(FRAMES_TO_PROCESS, 1, sampleRate);
|
|
69
|
+
for (size_t i = 0; i < bus->getSize(); ++i) {
|
|
70
|
+
bus->getChannel(0)->getData()[i] = i + 1;
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
auto resultBus = delayNode->processNode(bus, FRAMES_TO_PROCESS);
|
|
74
|
+
for (size_t i = 0; i < FRAMES_TO_PROCESS; ++i) {
|
|
75
|
+
if (i < FRAMES_TO_PROCESS / 2) { // First 64 samples should be zero due to delay
|
|
76
|
+
EXPECT_FLOAT_EQ((*resultBus->getChannel(0))[i], 0.0f);
|
|
77
|
+
} else {
|
|
78
|
+
EXPECT_FLOAT_EQ(
|
|
79
|
+
(*resultBus->getChannel(0))[i],
|
|
80
|
+
static_cast<float>(
|
|
81
|
+
i + 1 - FRAMES_TO_PROCESS / 2)); // Last 64 samples should be 1st part of bus
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
TEST_F(DelayTest, DelayHandlesTailCorrectly) {
|
|
87
|
+
float DELAY_TIME = (128.0 / context->getSampleRate()) * 0.5;
|
|
88
|
+
static constexpr int FRAMES_TO_PROCESS = 128;
|
|
89
|
+
auto delayNode = std::make_shared<TestableDelayNode>(context.get());
|
|
90
|
+
delayNode->setDelayTimeParam(DELAY_TIME);
|
|
91
|
+
|
|
92
|
+
auto bus = std::make_shared<audioapi::AudioBus>(FRAMES_TO_PROCESS, 1, sampleRate);
|
|
93
|
+
for (size_t i = 0; i < bus->getSize(); ++i) {
|
|
94
|
+
bus->getChannel(0)->getData()[i] = i + 1;
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
delayNode->processNode(bus, FRAMES_TO_PROCESS);
|
|
98
|
+
auto resultBus = delayNode->processNode(bus, FRAMES_TO_PROCESS);
|
|
99
|
+
for (size_t i = 0; i < FRAMES_TO_PROCESS; ++i) {
|
|
100
|
+
if (i < FRAMES_TO_PROCESS / 2) { // First 64 samples should be 2nd part of bus
|
|
101
|
+
EXPECT_FLOAT_EQ(
|
|
102
|
+
(*resultBus->getChannel(0))[i], static_cast<float>(i + 1 + FRAMES_TO_PROCESS / 2));
|
|
103
|
+
} else {
|
|
104
|
+
EXPECT_FLOAT_EQ((*resultBus->getChannel(0))[i],
|
|
105
|
+
0.0f); // Last 64 samples should be zero
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
}
|
|
@@ -5,12 +5,13 @@
|
|
|
5
5
|
#include <audioapi/utils/AudioBus.h>
|
|
6
6
|
#include <gtest/gtest.h>
|
|
7
7
|
#include <test/src/MockAudioEventHandlerRegistry.h>
|
|
8
|
+
#include <memory>
|
|
8
9
|
|
|
9
10
|
using namespace audioapi;
|
|
10
11
|
|
|
11
12
|
class GainTest : public ::testing::Test {
|
|
12
13
|
protected:
|
|
13
|
-
std::shared_ptr<
|
|
14
|
+
std::shared_ptr<MockAudioEventHandlerRegistry> eventRegistry;
|
|
14
15
|
std::unique_ptr<OfflineAudioContext> context;
|
|
15
16
|
static constexpr int sampleRate = 44100;
|
|
16
17
|
|
|
@@ -47,8 +48,7 @@ TEST_F(GainTest, GainModulatesVolumeCorrectly) {
|
|
|
47
48
|
auto gainNode = std::make_shared<TestableGainNode>(context.get());
|
|
48
49
|
gainNode->setGainParam(GAIN_VALUE);
|
|
49
50
|
|
|
50
|
-
auto bus =
|
|
51
|
-
std::make_shared<audioapi::AudioBus>(FRAMES_TO_PROCESS, 1, sampleRate);
|
|
51
|
+
auto bus = std::make_shared<audioapi::AudioBus>(FRAMES_TO_PROCESS, 1, sampleRate);
|
|
52
52
|
for (size_t i = 0; i < bus->getSize(); ++i) {
|
|
53
53
|
bus->getChannel(0)->getData()[i] = i + 1;
|
|
54
54
|
}
|
|
@@ -65,8 +65,7 @@ TEST_F(GainTest, GainModulatesVolumeCorrectlyMultiChannel) {
|
|
|
65
65
|
auto gainNode = std::make_shared<TestableGainNode>(context.get());
|
|
66
66
|
gainNode->setGainParam(GAIN_VALUE);
|
|
67
67
|
|
|
68
|
-
auto bus =
|
|
69
|
-
std::make_shared<audioapi::AudioBus>(FRAMES_TO_PROCESS, 2, sampleRate);
|
|
68
|
+
auto bus = std::make_shared<audioapi::AudioBus>(FRAMES_TO_PROCESS, 2, sampleRate);
|
|
70
69
|
for (size_t i = 0; i < bus->getSize(); ++i) {
|
|
71
70
|
bus->getChannel(0)->getData()[i] = i + 1;
|
|
72
71
|
bus->getChannel(1)->getData()[i] = -i - 1;
|