A portable collection of audio codecs as set of dependencies for SDL Mixer X audio library
  • C 72.2%
  • C++ 23%
  • Assembly 1.9%
  • Objective-C 1.4%
  • Java 0.4%
  • Other 0.7%
Find a file
Wohlstand 08f5b4af9d
Disable OPUS' RTCD on armv6 and armv5
Since asm optimisations are incompatible to these architectures
2026-02-17 02:03:02 +03:00
.semaphore Update Semaphore configuration 2023-08-08 08:12:58 +00:00
_common Updated SDL2 to 2.3.10 2025-09-22 04:36:28 +03:00
FluidLite FluidLite: Fixed sprintf truncation warning 2025-04-04 20:57:44 +03:00
libADLMIDI Updated libADLMIDI 2026-02-09 15:11:54 +03:00
libEDMIDI Updated libraries for 2026 copyright 2026-01-01 03:25:39 +03:00
libFLAC libFLAC: Fixed build for 3DS compatibility 2025-01-29 08:42:56 +03:00
libgme Updated GME 2026-02-09 14:41:41 +03:00
libmodplug CMake: fixed warning at newer CMake versions 2024-12-30 23:42:32 +03:00
libmpg123 CMake: Added PSP specific conditions 2025-09-24 00:58:32 +03:00
libogg CMake: fixed warning at newer CMake versions 2024-12-30 23:42:32 +03:00
libopenmpt CMake: Tweaked CMake minimum version to tweak the range 2023-08-16 20:49:05 +03:00
libOPNMIDI Updated libraries for 2026 copyright 2026-01-01 03:25:39 +03:00
libopus Disable OPUS' RTCD on armv6 and armv5 2026-02-17 02:03:02 +03:00
libopusfile CMake: fixed warning at newer CMake versions 2024-12-30 23:42:32 +03:00
libtimidity-sdl CMake: fixed warning at newer CMake versions 2024-12-30 23:42:32 +03:00
libvorbis CMake: fixed warning at newer CMake versions 2024-12-30 23:42:32 +03:00
libxmp Updated libxmp 2026-02-09 15:11:38 +03:00
SDL2 SDL2: Apply the same fix for PSP as for Vita 2026-02-06 15:34:10 +03:00
tremor Tremor: Fixed build on some toolchains where int32 is long 2025-09-24 00:58:19 +03:00
vgmstream Dummy changes 2017-09-27 23:12:48 +03:00
WavPack WavPack: Fixed build on some toolchains where int32 is long 2025-09-24 00:58:12 +03:00
zlib Updated zlib to version 1.3.1 2025-08-28 23:49:56 +03:00
.appveyor.yml AppVeyor: Use local SDL2 during the build 2023-06-03 10:16:40 +03:00
.gitattributes Make all CMake files to be LF 2024-11-14 04:02:47 +03:00
.gitignore Ignore VS Code related directory 2022-11-19 07:39:16 +03:00
.travis.yml Don't use Ninja on OSX 2018-04-03 22:34:45 +03:00
audio_codec_common.cmake CMake: Added PSP specific conditions 2025-09-24 00:58:32 +03:00
CMakeLists.txt Added an option to disable RTCD for libopus 2026-02-16 09:22:33 +03:00
download_sdl2_hg.cmake Added workaround for local SDL2 built for Vita 2025-04-14 08:18:55 +03:00
README.md Updated ReadMe to clarify requirements 2024-03-16 18:59:09 +03:00

AudioCodecs collection

A collection of various audio codecs and their dependencies.

This is a set of dependencies required for SDL Mixer X audio library, except of SDL2 which is updating offten.

This set of libraries is designed to be buildable through CMake building system.

Note: to build libtimidity-sdl, you need to have the latest libSDL2 being installed, or enable the local SDL2 build. (This library was being modified to support files through SDL_RWops() API)

CI Badges

Operating system Badge
Linux: Build Status
Windows: Build status
macOS Build Status

How to build

Linux

You will need:

  • CMake >= 3.2
  • GCC and G++ >= 4.8
  • libSDL2 library package installed, OR you can use -DUSE_LOCAL_SDL2=ON to use the vendored copy of SDL2 instead, or use the -DDOWNLOAD_SDL2_DEPENDENCY=ON CMake flag to automatically download from official GitHub repository using SDL2 branch and build this.

System install (will be installed with /usr/local/ prefix)

# Step 1: Download repository
git clone https://github.com/WohlSoft/AudioCodecs.git
cd AudioCodecs

# Step 2: PRepare build directory
mkdir build
cd build

# Step 3: Configure project ()
cmake ..

# Step 4: Build
make
# Hint: to speed-up build use -j <num jobs> flag. Count of jobs should be equal number of CPU cores

# Step 5: Install
sudo make install

Custom install (You can install result into any folder and you don't need to have root to install)

# Step 1: Download repository
git clone https://github.com/WohlSoft/AudioCodecs.git
cd AudioCodecs

# Step 2: PRepare build directory
mkdir build
cd build

# Step 3: Configure project ()
cmake -DUSE_LOCAL_SDL2=ON -DCMAKE_INSTALL_PREFIX=~/AudioCodecs/ ..

# Step 4: Build and install
cmake -build . -config release -target install -- -j 2
#   Tip: instead of "release" you can have "debug" to build debug versions. Instead of "2" put your actual count of CPU cores

macOS

The build for macOS is very similar to Linux way, you just can follow Linux way to build libraries.

If you want to use the system-wide SDL2 instead of local, you should install it via Homebrew or by any other way.

Windows

You will need:

  • CMake >= 3.2
  • MinGW >= 4.8, MinGW-w64 >= 5, or MSVC >=2015 (on your taste).
  • The local or downloaded SDL2 will require the MinGW-w64 or MSVC instead of vanilla MinGW as current version is incompatible to the vanilla MinGW.

Build with MinGW

rem Step 1: Download repository
git clone https://github.com/WohlSoft/AudioCodecs.git
cd AudioCodecs

rem Step 2: PRepare build directory
mkdir build
cd build

rem Step 3: Configure project
cmake -G "MinGW Makefiles" -DUSE_LOCAL_SDL2=ON -DCMAKE_INSTALL_PREFIX=%UserProfile%\MyLibs\ ..

rem Step 4: Build and install
cmake -build . -config release -target install -- -j 2
rem Tip: instead of "release" you can have "debug" to build debug versions. Instead of "2" put your actual count of CPU cores

Build with MinGW-w64 (A way to get 64-bit Windows assemblies)

rem Step 1: Download repository
git clone https://github.com/WohlSoft/AudioCodecs.git
cd AudioCodecs

rem Step 2: PRepare build directory
mkdir build
cd build
rem Important: You must to set the MinGW-w64 path first, also you must to remove a git from PATH if it is set
rem Full path may be different in dependence of version. Please fix this to match with your
set PATH=C:\mingw-w64\x86_64-6.3.0-posix-seh-rt_v5-rev1\mingw64\bin;%PATH:C:\Program Files\Git\usr\bin;=%

rem Step 3: Configure project
cmake -G "MinGW Makefiles" -DUSE_LOCAL_SDL2=ON -DCMAKE_INSTALL_PREFIX=%UserProfile%\MyLibs\ ..

rem Step 4: Build and install
cmake -build . -config release -target install -- -j 2
rem Tip: instead of "release" you can have "debug" to build debug versions. Instead of "2" put your actual count of CPU cores

Build with MSVC

rem Step 1: Download repository
git clone https://github.com/WohlSoft/AudioCodecs.git
cd AudioCodecs

rem Step 2: PRepare build directory
mkdir build
cd build

rem Step 3: Configure project
cmake -G "Visual Studio 14 2015" -DDOWNLOAD_SDL2_DEPENDENCY=ON -DCMAKE_INSTALL_PREFIX=%UserProfile%\MyLibs\ ..
rem HINT: If you want to have 64-bit build, use "Visual Studio 14 2015 Win64" generator
rem HINT: You can take full list of available generators by requesting of "cmake --help"

rem Step 4: Build and install
cmake -build . -config release -target install -- -j 2
rem Tip: instead of "release" you can have "debug" to build debug versions. Instead of "2" put your actual count of CPU cores

Licenses

  • libADLMIDI: GNU LGPLv3+ or GNU GPLv3+
  • libFLAC: Multiple: BSD 3-clause "New" or "Revised" License (libFLAC, libFLAC++), GNU GPL (extra plugins and tools)
  • libFluidLite: GNU LGPLv2.1+
  • libEDMIDI: ZLib license
  • libGME: GNU LGPLv2.1+
  • libModPlug: Public Domain
  • libMPG123: GNU LGPLv2.1
  • libOGG: BSD 3-clause "New" or "Revised" License
  • libOpenMPT: BSD
  • libOPNMIDI: GNU LGPLv3+ or GNU GPLv3+
  • libOpus: BSD 3-clause "New" or "Revised" License
  • libSDL2: ZLib
  • libTimidity-SDL: The "Artistic License"
  • libVorbis: BSD 3-clause "New" or "Revised" License
  • libWavPack: BSD 3-clause "New" or "Revised" License
  • libXMP: GNU LGPLv2+, partially MIT
  • libZlib: ZLib license

Libraries are can be freely used in non-free projects:

Static linking

(BSD, ZLib, and "Artistic" licenses are allows usage in closed-source projects)

  • libEDMIDI
  • libFLAC
  • libModPlug
  • libOGG
  • libOpenMPT
  • libOpus
  • libSDL2
  • libTimidity-SDL
  • libVorbis
  • libWavPack
  • libZlib

Dynamic linking

(LGPL allows usage in closed-source projects when LGPL-licensed components are linked dynamically)

  • libEDMIDI
  • libFLAC
  • libFluidLite
  • libGME
  • libModPlug
  • libMPG123
  • libOGG
  • libOpenMPT
  • libOpus
  • libSDL2
  • libTimidity
  • libVorbis
  • libWavPack
  • libXMP
  • libZlib

GPL-only projects

(These libraries has the viral GPL license and you can use these libraries in libre projects only with applying the GPL license to the whole project)

  • libADLMIDI
  • libOPNMIDI