Compare commits

3 Commits

Author SHA1 Message Date
ae0d81599d docs: build notes
Some checks failed
macOS and iOS CI / build (push) Has been cancelled
Windows CI / build (push) Has been cancelled
2026-03-07 23:15:28 +01:00
3a3acae777 build: make Android NDK build happy
Some checks failed
macOS and iOS CI / build (push) Has been cancelled
Windows CI / build (push) Has been cancelled
2026-03-07 22:56:32 +01:00
3fb8edb23e build: reduce CMake version to 3.22.1 to build with Android NDK tools 2026-03-07 22:34:54 +01:00
5 changed files with 71 additions and 50 deletions

View File

@@ -1,61 +1,73 @@
cmake_minimum_required(VERSION 4.1) cmake_minimum_required(VERSION 3.22.1)
project(rubberband) project(rubberband)
set(CMAKE_CXX_STANDARD 20) set(CMAKE_CXX_STANDARD 20)
set(CMAKE_CXX_FLAGS "-DNOMINMAX -DUSE_BQRESAMPLER -DHAVE_KISSFFT") # -DNOMINMAX: for MSVCC to avoid defining max() as macro, breaking std::max()
# -DHAVE_UNISTD_H: for libsndfile access()
# -DUSE_PTHREADS: for Thread.h
set(CMAKE_CXX_FLAGS "-DNOMINMAX -DHAVE_UNISTD_H -DUSE_PTHREADS -DUSE_BQRESAMPLER -DHAVE_KISSFFT")
# TODO: see Android.mk in librubberband and copy options from LOCAL_CFLAGS
# disable libsndfile tests
set(BUILD_TESTING FALSE)
#include_directories(mpg123/lib/x86_64/include)
include_directories( include_directories(
./dotnet/rubberband-dll ./rubberband
./ladspa-lv2 ./src/common
./rubberband ./src/ext/float_cast
./src/common ./src/ext/kissfft
./src/ext/float_cast #./src/ext/pommier
./src/ext/getopt #./src/ext/speex
./src/ext/kissfft ./src/faster
./src/ext/pommier ./src/finer
./src/ext/speex
./src/faster
./src/finer
./vamp
) )
add_executable(rubberband if(CMAKE_SYSTEM_NAME STREQUAL "Windows")
./src/ext/getopt/getopt.c # only for WIN32 target system
./src/ext/getopt/getopt_long.c include_directories(
./src/ext/kissfft/kiss_fft.c ./src/ext/getopt
./src/ext/kissfft/kiss_fftr.c )
./src/ext/speex/resample.c endif()
./main/main.cpp
./src/common/Allocators.cpp set(RUBBERBAND_SRC
./src/common/BQResampler.cpp #./src/ext/getopt/getopt.c
./src/common/FFT.cpp #./src/ext/getopt/getopt_long.c
./src/common/Log.cpp ./src/ext/kissfft/kiss_fft.c
./src/common/mathmisc.cpp ./src/ext/kissfft/kiss_fftr.c
./src/common/Profiler.cpp ./src/ext/speex/resample.c
./src/common/Resampler.cpp ./main/main.cpp
./src/common/StretchCalculator.cpp ./src/common/Allocators.cpp
./src/common/sysutils.cpp ./src/common/BQResampler.cpp
./src/common/Thread.cpp ./src/common/FFT.cpp
./src/common/VectorOpsComplex.cpp ./src/common/Log.cpp
./src/faster/AudioCurveCalculator.cpp ./src/common/mathmisc.cpp
./src/faster/CompoundAudioCurve.cpp ./src/common/Profiler.cpp
./src/faster/HighFrequencyAudioCurve.cpp ./src/common/Resampler.cpp
./src/faster/PercussiveAudioCurve.cpp ./src/common/StretchCalculator.cpp
./src/faster/R2Stretcher.cpp ./src/common/sysutils.cpp
./src/faster/SilentAudioCurve.cpp ./src/common/Thread.cpp
./src/faster/StretcherChannelData.cpp ./src/common/VectorOpsComplex.cpp
./src/faster/StretcherProcess.cpp ./src/faster/AudioCurveCalculator.cpp
./src/finer/R3LiveShifter.cpp ./src/faster/CompoundAudioCurve.cpp
./src/finer/R3Stretcher.cpp ./src/faster/HighFrequencyAudioCurve.cpp
./src/rubberband-c.cpp ./src/faster/PercussiveAudioCurve.cpp
./src/RubberBandLiveShifter.cpp ./src/faster/R2Stretcher.cpp
./src/RubberBandStretcher.cpp ./src/faster/SilentAudioCurve.cpp
./src/faster/StretcherChannelData.cpp
./src/faster/StretcherProcess.cpp
./src/finer/R3LiveShifter.cpp
./src/finer/R3Stretcher.cpp
./src/rubberband-c.cpp
./src/RubberBandLiveShifter.cpp
./src/RubberBandStretcher.cpp
) )
#target_link_directories(rubberband PRIVATE mpg123/lib/x86_64)
#target_link_libraries(test_lockstep mpg123-0) add_executable(rubberband-main ${RUBBERBAND_SRC})
#target_link_libraries(rubberband ${CMAKE_SOURCE_DIR}/mpg123/lib/x86_64/libmpg123.dll.a)
add_library(rubberband SHARED ${RUBBERBAND_SRC})
add_subdirectory(src/ext/libsndfile) add_subdirectory(src/ext/libsndfile)
target_link_libraries(rubberband-main sndfile)
target_link_libraries(rubberband sndfile) target_link_libraries(rubberband sndfile)

View File

@@ -23,7 +23,7 @@
#include "VectorOpsComplex.h" #include "VectorOpsComplex.h"
#include "system/sysutils.h" //#include "system/sysutils.h"
#include <cassert> #include <cassert>

View File

@@ -31,6 +31,8 @@
* SUCH DAMAGE. * SUCH DAMAGE.
*/ */
#if OS_IS_WIN32
#include <stdio.h> #include <stdio.h>
#include <stdlib.h> #include <stdlib.h>
#include <string.h> #include <string.h>
@@ -114,3 +116,5 @@ getopt(nargc, nargv, ostr)
} }
return (optopt); /* dump back option letter */ return (optopt); /* dump back option letter */
} }
#endif

View File

@@ -61,6 +61,8 @@
# if !defined(GETOPT_API) # if !defined(GETOPT_API)
# define GETOPT_API __declspec(dllimport) # define GETOPT_API __declspec(dllimport)
# endif # endif
#else
# define GETOPT_API
#endif #endif
/* /*

View File

@@ -37,6 +37,7 @@
* POSSIBILITY OF SUCH DAMAGE. * POSSIBILITY OF SUCH DAMAGE.
*/ */
#if OS_IS_WIN32
#include <stdlib.h> #include <stdlib.h>
#include <string.h> #include <string.h>
@@ -549,3 +550,5 @@ getopt_long(nargc, nargv, options, long_options, idx)
return retval; return retval;
} }
#endif /* !GETOPT_LONG */ #endif /* !GETOPT_LONG */
#endif