aboutsummaryrefslogtreecommitdiffstats
path: root/src/decoder (follow)
Commit message (Collapse)AuthorAgeFilesLines
* decoder/faad: use the newer NeAAC* APIMax Kellermann2013-01-291-41/+26
| | | | Drop support for the old faacDec* API.
* InputStream: use std::stringMax Kellermann2013-01-282-4/+6
|
* InputStream: store references instead of pointersMax Kellermann2013-01-281-1/+1
|
* decoder/ffmpeg: require ffmpeg/libav 0.7.6Max Kellermann2013-01-283-82/+3
| | | | | | | | This is the version present in Ubuntu Oneiric, the oldest distribution with gcc 4.6. Debian Squeeze is off target, because it has gcc 4.4, which is unable to compile MPD anyway. This commit drops all API compatibility hacks for older versions.
* decoder/mp4ff: delete obsolete pluginMax Kellermann2013-01-281-448/+0
| | | | The underlying library has been obsolete for many years.
* DecoderControl, InputStream: use Mutex/Cond instead of GMutex/GCondMax Kellermann2013-01-271-2/+2
|
* input_stream: forward-declare the structMax Kellermann2013-01-2616-54/+71
| | | | Hide the definition from C code, to prepare the transition to C++.
* decoder/ffmpeg: convert to C++Max Kellermann2013-01-264-24/+66
|
* Merge branch 'v0.17.x'Max Kellermann2013-01-161-0/+5
|\
| * decoder/ffmpeg: support float planar audioBrice Jaglin2013-01-161-0/+5
| |
* | string_util.c: provide fallback strndup() implementationDenis Krjuchkov2013-01-111-0/+1
| | | | | | | | | | This patch also adds extern "C" { } wrapper around string_util.h to allow its usage in C++ code
* | decoder/wavpack: convert to C++Max Kellermann2013-01-102-24/+57
| |
* | decoder/wavpack: include cleanupMax Kellermann2013-01-101-3/+0
| |
* | decoder/OggUtil,Opus: move code to new class OggSyncStateMax Kellermann2013-01-084-36/+102
| |
* | decoder/Opus: read total timeMax Kellermann2013-01-083-0/+100
| |
* | decoder/OggUtil: add OggExpectPageSeek()Max Kellermann2013-01-082-0/+56
| |
* | decoder/Opus: move page reader into the decoder classMax Kellermann2013-01-081-13/+34
| |
* | decoder/Opus: move code to HandlePackets()Max Kellermann2013-01-081-0/+7
| |
* | decoder/Opus: make internal methods inlineMax Kellermann2013-01-081-5/+5
| |
* | decoder/OggUtil: add OggExpectFirstPage() and OggExpectPageIn()Max Kellermann2013-01-083-8/+48
| |
* | decoder/Opus: use OggExpectPage() in main loopMax Kellermann2013-01-081-7/+5
| |
* | decoder/OggUtil: add struct forward declarationsMax Kellermann2013-01-082-5/+8
| |
* | input_stream: add method _cheap_seeking()Max Kellermann2013-01-071-3/+1
| | | | | | | | Move code from the Vorbis decoder plugin.
* | decoder/ogg_codec: convert to C++Max Kellermann2013-01-075-15/+8
| |
* | decoder/vorbis: convert to C++Max Kellermann2013-01-074-19/+55
| |
* | decoder_api.h, ...: add "extern C"Max Kellermann2013-01-078-16/+7
| |
* | DecoderAPI: _replay_gain() returns voidMax Kellermann2013-01-052-6/+4
| | | | | | | | | | | | Let the function decoder_replay_gain() update decoder_control::replay_gain_db instead of letting each decoder plugin take care for that.
* | don't include stdbool.h in C++ sourcesMax Kellermann2013-01-022-2/+0
| | | | | | | | The "bool" type is built-in.
* | Add tag support for DSD (DSDIFF & DSF) decodersJurgen Kramer2012-10-274-2/+226
| |
* | Merge branch 'v0.17.x'Max Kellermann2012-10-051-12/+53
|\| | | | | | | | | Conflicts: src/PlaylistSave.cxx
| * decoder/ffmpeg: support planar audioMax Kellermann2012-10-051-0/+6
| | | | | | | | Implements Mantis feature request 3582.
| * decoder/ffmpeg: fix playback of planar PCM dataMax Kellermann2012-10-051-8/+13
| | | | | | | | | | Interleaving was completely wrong. This code was never used, so it didn't have an effect.
| * decoder/ffmpeg: move code to copy_interleave_frame2()Max Kellermann2012-10-051-5/+14
| |
| * decoder/ffmpeg: ignore negative time stampsMax Kellermann2012-10-051-1/+1
| | | | | | | | Works around assertion failure in decoder_timestamp().
| * decoder/ffmpeg: show unsupported sample format nameMax Kellermann2012-10-051-2/+13
| | | | | | | | Use av_get_sample_fmt_string() to obtain a human-readable string.
| * decoder/ffmpeg: pass AVSampleFormat to ffmpeg_sample_format()Max Kellermann2012-10-051-4/+9
| | | | | | | | API simplification.
| * decoder/ffmpeg: remove duplicate sample format error messageMax Kellermann2012-10-051-1/+6
| |
* | decoder/flac: support FLAC files inside archivesMax Kellermann2012-10-044-2/+215
| | | | | | | | | | | | Implement the "scan_stream" method that can read tags from any input_stream object. This requires a FLAC__IOCallbacks implementation based on the input_stream API.
* | decoder/flac: move flac_scan_file2() to main plugin fileMax Kellermann2012-10-043-20/+9
| |
* | decoder/flac: move callbacks to class FLACInputMax Kellermann2012-10-025-110/+242
| |
* | decoder/flac: add ctor/dtor to struct flac_dataMax Kellermann2012-10-023-34/+17
| |
* | decoder/flac: add method FLACMetadataChain::Scan()Max Kellermann2012-10-023-12/+12
| | | | | | | | Merge common code.
* | decoder/flac: don't use FLAC__Metadata_SimpleIteratorMax Kellermann2012-10-021-32/+8
| | | | | | | | Use the new FLACMetadataIterator C++ class, which is more powerful.
* | decoder/flac: add C++ libFLAC wrappersMax Kellermann2012-10-022-14/+71
| | | | | | | | | | Not using libFLAC++ because this library adds a lot of overhead due to virtual method calls. This new class library is zero-overhead.
* | decoder/flac: eliminate the obsolete "track number" codeMax Kellermann2012-10-024-41/+18
| | | | | | | | This has been deprecated by the "embcue" playlist plugin.
* | decoder/flac: remove unused function flac_tag_load()Max Kellermann2012-10-022-17/+0
| |
* | decoder/flac: use C++ compilerMax Kellermann2012-10-028-60/+109
| |
* | {decoder,encoder}/flac: drop support for libFLAC 1.1Max Kellermann2012-10-022-168/+5
| |
* | decoder/adplug: new decoder pluginMax Kellermann2012-09-252-0/+173
| |
* | decoder/vorbis: skip 16 bit quantisation, provide float samplesSimon Hosie2012-09-251-0/+44
| | | | | | | | | | | | | | | | | | | | Internally the vorbis (non-Tremor) decoder is working in floating point, and it's not really necessary to cut the output back to 16-bit if the soundcard or OS supports higher resolution. The decoder can be trivially modified to bypass its internal quantisation and produce floating-point output, and a separate quantisation can be used as appropriate to the platform.