2015-06-30 20:49:36 +00:00
|
|
|
# libsoundio
|
|
|
|
|
|
|
|
C library which provides cross-platform audio input and output. The API is
|
|
|
|
suitable for real-time software such as digital audio workstations as well
|
|
|
|
as consumer software such as music players.
|
|
|
|
|
2015-07-01 08:02:44 +00:00
|
|
|
This library is an abstraction; however it prioritizes performance and power
|
|
|
|
over API convenience. Features that only exist in some sound backends are
|
|
|
|
exposed.
|
|
|
|
|
2015-07-06 06:42:56 +00:00
|
|
|
**This library is a work-in-progress.**
|
|
|
|
|
2015-07-07 00:16:03 +00:00
|
|
|
## Alternatives
|
2015-07-06 06:42:56 +00:00
|
|
|
|
|
|
|
* [PortAudio](http://www.portaudio.com/)
|
2015-07-16 20:37:41 +00:00
|
|
|
- Does not support [PulseAudio](http://www.freedesktop.org/wiki/Software/PulseAudio/).
|
|
|
|
- Logs messages to stdio and you can't turn that off.
|
|
|
|
- Does not support channel layouts / channel maps.
|
|
|
|
- Does not support emitting an event when available devices change.
|
|
|
|
- Not written by me.
|
2015-07-06 06:42:56 +00:00
|
|
|
* [rtaudio](https://www.music.mcgill.ca/~gary/rtaudio/)
|
|
|
|
- It is not a C library.
|
|
|
|
- It uses [exceptions](http://stackoverflow.com/questions/1736146/why-is-exception-handling-bad).
|
2015-07-14 04:30:37 +00:00
|
|
|
- It does not support channel layouts / channel maps.
|
2015-07-16 20:37:41 +00:00
|
|
|
- Does not support emitting an event when available devices change.
|
|
|
|
- Not written by me.
|
2015-07-06 06:42:56 +00:00
|
|
|
* [SDL](https://www.libsdl.org/)
|
2015-07-16 20:37:41 +00:00
|
|
|
- Comes with baggage: display, windowing, input handling, and lots more.
|
|
|
|
- Not designed with real-time low latency audio in mind.
|
2015-07-06 06:42:56 +00:00
|
|
|
- Listing audio devices is [broken](https://github.com/andrewrk/node-groove/issues/13).
|
2015-07-16 20:37:41 +00:00
|
|
|
- Does not support recording devices.
|
|
|
|
- Does not support channel layouts / channel maps.
|
|
|
|
- Does not support emitting an event when available devices change.
|
|
|
|
- Not written by me.
|
2015-06-30 21:13:44 +00:00
|
|
|
|
2015-06-30 20:49:36 +00:00
|
|
|
## How It Works
|
|
|
|
|
2015-07-01 08:02:44 +00:00
|
|
|
libsoundio tries these backends in order. If unable to connect to that backend,
|
|
|
|
due to the backend not being installed, or the server not running, or the
|
|
|
|
platform is wrong, the next backend is tried.
|
|
|
|
|
|
|
|
0. JACK
|
|
|
|
0. PulseAudio
|
|
|
|
0. ALSA (Linux)
|
|
|
|
0. CoreAudio (OSX)
|
|
|
|
0. ASIO (Windows)
|
|
|
|
0. DirectSound (Windows)
|
|
|
|
0. OSS (BSD)
|
|
|
|
0. Dummy
|
|
|
|
|
|
|
|
## Contributing
|
|
|
|
|
2015-07-02 22:54:36 +00:00
|
|
|
libsoundio is programmed in a tiny subset of C++11:
|
2015-07-01 08:02:44 +00:00
|
|
|
|
|
|
|
* No STL.
|
|
|
|
* No `new` or `delete`.
|
|
|
|
* No `class`. All fields in structs are `public`.
|
|
|
|
* No exceptions or run-time type information.
|
|
|
|
* No references.
|
|
|
|
* No linking against libstdc++.
|
2015-06-30 20:49:36 +00:00
|
|
|
|
2015-07-02 22:54:36 +00:00
|
|
|
Don't get tricked - this is a *C library*, not a C++ library. We just take
|
|
|
|
advantage of a select few C++11 compiler features such as templates, and then
|
|
|
|
link against libc.
|
|
|
|
|
2015-07-02 10:48:27 +00:00
|
|
|
### Building
|
|
|
|
|
2015-07-02 22:54:36 +00:00
|
|
|
Install the dependencies:
|
|
|
|
|
|
|
|
* cmake
|
|
|
|
* ALSA library (optional)
|
|
|
|
* libjack2 (optional)
|
|
|
|
* libpulseaudio (optional)
|
|
|
|
|
2015-07-02 10:48:27 +00:00
|
|
|
```
|
2015-07-02 22:54:36 +00:00
|
|
|
mkdir build
|
|
|
|
cd build
|
|
|
|
cmake ..
|
|
|
|
make
|
|
|
|
sudo make install
|
2015-07-02 10:48:27 +00:00
|
|
|
```
|
|
|
|
|
2015-07-08 06:29:09 +00:00
|
|
|
### Building for Windows
|
2015-07-02 10:48:27 +00:00
|
|
|
|
|
|
|
You can build libsoundio with [mxe](http://mxe.cc/). Follow the
|
|
|
|
[requirements](http://mxe.cc/#requirements) section to install the
|
|
|
|
packages necessary on your system. Then somewhere on your file system:
|
|
|
|
|
|
|
|
```
|
2015-07-02 22:54:36 +00:00
|
|
|
git clone https://github.com/mxe/mxe
|
|
|
|
cd mxe
|
|
|
|
make gcc
|
2015-07-02 10:48:27 +00:00
|
|
|
```
|
|
|
|
|
|
|
|
Then in the libsoundio source directory (replace "/path/to/mxe" with the
|
|
|
|
appropriate path):
|
|
|
|
|
|
|
|
```
|
2015-07-02 22:54:36 +00:00
|
|
|
mkdir build-win
|
|
|
|
cd build-win
|
|
|
|
cmake .. -DCMAKE_TOOLCHAIN_FILE=/path/to/mxe/usr/i686-w64-mingw32.static/share/cmake/mxe-conf.cmake
|
|
|
|
make
|
2015-07-02 10:48:27 +00:00
|
|
|
```
|
|
|
|
|
2015-07-07 00:16:03 +00:00
|
|
|
#### Running the Tests
|
|
|
|
|
|
|
|
```
|
|
|
|
make test
|
|
|
|
```
|
|
|
|
|
|
|
|
For more detailed output:
|
|
|
|
|
|
|
|
```
|
|
|
|
make
|
|
|
|
./unit_tests
|
|
|
|
```
|
|
|
|
|
|
|
|
To see test coverage, install lcov, run `make coverage` and then
|
|
|
|
view `coverage/index.html` in a browser.
|
|
|
|
|
2015-06-30 20:49:36 +00:00
|
|
|
## Roadmap
|
|
|
|
|
2015-07-07 09:55:32 +00:00
|
|
|
0. implement ALSA (Linux) backend, get examples working
|
2015-07-16 03:57:00 +00:00
|
|
|
0. fix pulseaudio backend since I broke it
|
2015-07-04 10:08:15 +00:00
|
|
|
0. pipe record to playback example working with dummy linux, osx, windows
|
|
|
|
0. pipe record to playback example working with pulseaudio linux
|
|
|
|
0. implement CoreAudio (OSX) backend, get examples working
|
|
|
|
0. implement DirectSound (Windows) backend, get examples working
|
|
|
|
0. implement JACK backend, get examples working
|
2015-07-02 09:53:08 +00:00
|
|
|
0. Avoid calling `panic` in PulseAudio.
|
2015-07-04 10:08:15 +00:00
|
|
|
0. implement ASIO (Windows) backend, get examples working
|
2015-07-02 22:54:36 +00:00
|
|
|
0. clean up API and improve documentation
|
2015-07-07 09:55:32 +00:00
|
|
|
- make sure every function which can return an error documents which errors
|
|
|
|
it can return
|
|
|
|
- consider doing the public/private struct thing and make `backend_data` a
|
|
|
|
union instead of a `void *`
|
2015-07-02 22:54:36 +00:00
|
|
|
0. use a documentation generator and host the docs somewhere
|
2015-07-03 02:15:09 +00:00
|
|
|
0. -fvisibility=hidden and then explicitly export stuff
|
2015-07-04 10:08:15 +00:00
|
|
|
0. Integrate into libgroove and test with Groove Basin
|
|
|
|
0. Consider testing on FreeBSD
|
2015-07-07 00:16:03 +00:00
|
|
|
0. look at microphone example and determine if fewer memcpys can be done
|
|
|
|
with the audio data
|
2015-07-07 09:55:32 +00:00
|
|
|
- pulseaudio has peek() drop() which sucks, but what if libsoundio lets you
|
|
|
|
specify how much to peek() and if you don't peek all of it, save the
|
|
|
|
unused to a buffer for you.
|
2015-07-10 06:35:58 +00:00
|
|
|
0. add len arguments to APIs that have char *
|
2015-07-01 08:02:44 +00:00
|
|
|
|
|
|
|
## Planned Uses for libsoundio
|
|
|
|
|
|
|
|
* [Genesis](https://github.com/andrewrk/genesis)
|
|
|
|
* [libgroove](https://github.com/andrewrk/libgroove) ([Groove Basin](https://github.com/andrewrk/groovebasin))
|