Commit message (Collapse) | Author | Age | Files | Lines | ||
---|---|---|---|---|---|---|
... | ||||||
* | | decoder_api.h, ...: add "extern C" | Max Kellermann | 2013-01-07 | 8 | -16/+7 | |
| | | ||||||
* | | DecoderAPI: _replay_gain() returns void | Max Kellermann | 2013-01-05 | 2 | -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++ sources | Max Kellermann | 2013-01-02 | 2 | -2/+0 | |
| | | | | | | | | The "bool" type is built-in. | |||||
* | | Add tag support for DSD (DSDIFF & DSF) decoders | Jurgen Kramer | 2012-10-27 | 4 | -2/+226 | |
| | | ||||||
* | | Merge branch 'v0.17.x' | Max Kellermann | 2012-10-05 | 1 | -12/+53 | |
|\| | | | | | | | | | Conflicts: src/PlaylistSave.cxx | |||||
| * | decoder/ffmpeg: support planar audio | Max Kellermann | 2012-10-05 | 1 | -0/+6 | |
| | | | | | | | | Implements Mantis feature request 3582. | |||||
| * | decoder/ffmpeg: fix playback of planar PCM data | Max Kellermann | 2012-10-05 | 1 | -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 Kellermann | 2012-10-05 | 1 | -5/+14 | |
| | | ||||||
| * | decoder/ffmpeg: ignore negative time stamps | Max Kellermann | 2012-10-05 | 1 | -1/+1 | |
| | | | | | | | | Works around assertion failure in decoder_timestamp(). | |||||
| * | decoder/ffmpeg: show unsupported sample format name | Max Kellermann | 2012-10-05 | 1 | -2/+13 | |
| | | | | | | | | Use av_get_sample_fmt_string() to obtain a human-readable string. | |||||
| * | decoder/ffmpeg: pass AVSampleFormat to ffmpeg_sample_format() | Max Kellermann | 2012-10-05 | 1 | -4/+9 | |
| | | | | | | | | API simplification. | |||||
| * | decoder/ffmpeg: remove duplicate sample format error message | Max Kellermann | 2012-10-05 | 1 | -1/+6 | |
| | | ||||||
* | | decoder/flac: support FLAC files inside archives | Max Kellermann | 2012-10-04 | 4 | -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 file | Max Kellermann | 2012-10-04 | 3 | -20/+9 | |
| | | ||||||
* | | decoder/flac: move callbacks to class FLACInput | Max Kellermann | 2012-10-02 | 5 | -110/+242 | |
| | | ||||||
* | | decoder/flac: add ctor/dtor to struct flac_data | Max Kellermann | 2012-10-02 | 3 | -34/+17 | |
| | | ||||||
* | | decoder/flac: add method FLACMetadataChain::Scan() | Max Kellermann | 2012-10-02 | 3 | -12/+12 | |
| | | | | | | | | Merge common code. | |||||
* | | decoder/flac: don't use FLAC__Metadata_SimpleIterator | Max Kellermann | 2012-10-02 | 1 | -32/+8 | |
| | | | | | | | | Use the new FLACMetadataIterator C++ class, which is more powerful. | |||||
* | | decoder/flac: add C++ libFLAC wrappers | Max Kellermann | 2012-10-02 | 2 | -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" code | Max Kellermann | 2012-10-02 | 4 | -41/+18 | |
| | | | | | | | | This has been deprecated by the "embcue" playlist plugin. | |||||
* | | decoder/flac: remove unused function flac_tag_load() | Max Kellermann | 2012-10-02 | 2 | -17/+0 | |
| | | ||||||
* | | decoder/flac: use C++ compiler | Max Kellermann | 2012-10-02 | 8 | -60/+109 | |
| | | ||||||
* | | {decoder,encoder}/flac: drop support for libFLAC 1.1 | Max Kellermann | 2012-10-02 | 2 | -168/+5 | |
| | | ||||||
* | | decoder/adplug: new decoder plugin | Max Kellermann | 2012-09-25 | 2 | -0/+173 | |
| | | ||||||
* | | decoder/vorbis: skip 16 bit quantisation, provide float samples | Simon Hosie | 2012-09-25 | 1 | -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. | |||||
* | | decoder/vorbis: rename local variables | Max Kellermann | 2012-09-25 | 1 | -14/+13 | |
| | | ||||||
* | | decoder/vorbis: improved support for initial seek | Max Kellermann | 2012-09-25 | 1 | -1/+1 | |
| | | | | | | | | Call decoder_get_command() before doing anything else. | |||||
* | | decoder/vorbis: make variables more local | Max Kellermann | 2012-09-25 | 1 | -26/+20 | |
| | | ||||||
* | | Merge branch 'v0.17.x' | Max Kellermann | 2012-09-25 | 3 | -22/+16 | |
|\| | | | | | | | | | Conflicts: src/locate.c | |||||
| * | decoder_control: remove MixRamp debug messages | Max Kellermann | 2012-09-25 | 2 | -6/+4 | |
| | | | | | | | | | | These are confusing, and since MixRamp development has ceased, not useful to anybody. | |||||
| * | decoder/wavpack: support all APEv2 tags | Max Kellermann | 2012-09-25 | 1 | -16/+12 | |
| | | | | | | | | | | WavPack tags are always APEv2, by definition. Reuse the tag_table from tag_ape.c, instead of rolling our own. | |||||
* | | src/decoder/opus: new decoder plugin for the Opus codec | Max Kellermann | 2012-09-05 | 11 | -0/+778 | |
| | | | | | | | | Using libopus and libogg. | |||||
* | | decoder/{flac,vorbis}: move tag table to XiphTags.c | Max Kellermann | 2012-09-05 | 4 | -16/+60 | |
| | | | | | | | | Merge duplicate data. | |||||
* | | decoder/ogg_codec: return UNKNOWN on error | Max Kellermann | 2012-09-04 | 2 | -1/+2 | |
| | | ||||||
* | | decoder/ogg_common: rename to ogg_codec.c | Max Kellermann | 2012-09-04 | 4 | -19/+19 | |
| | | ||||||
* | | decoder/ogg_common: pass decoder to _type_detect() | Max Kellermann | 2012-09-04 | 4 | -5/+5 | |
| | | | | | | | | Allow the function to be cancelled. | |||||
* | | decoder/ogg_common: apply coding style | Max Kellermann | 2012-09-04 | 2 | -6/+9 | |
| | | ||||||
* | | decoder/_ogg_common: rename to ogg_common.c | Max Kellermann | 2012-09-04 | 6 | -5/+5 | |
| | | ||||||
* | | Merge branch 'v0.17.x' | Max Kellermann | 2012-09-04 | 1 | -6/+8 | |
|\| | ||||||
| * | decoder/_ogg_common: fix buffer size check | Max Kellermann | 2012-09-04 | 1 | -1/+1 | |
| | | | | | | | | Fixes potential access to uninitialised memory. | |||||
| * | decoder/_ogg_common: simplify the large "if" expression | Max Kellermann | 2012-09-04 | 1 | -6/+8 | |
| | | ||||||
* | | decoder/mad, output_thread: add gcc_unlikely() | Max Kellermann | 2012-08-29 | 1 | -2/+2 | |
| | | ||||||
* | | Merge branch 'v0.17.x' | Max Kellermann | 2012-08-15 | 1 | -53/+28 | |
|\| | ||||||
| * | decoder/fluidsynth: add "sample_rate" setting | Max Kellermann | 2012-08-15 | 1 | -6/+14 | |
| | | ||||||
| * | decoder/fluidsynth: add "soundfont" setting | Max Kellermann | 2012-08-15 | 1 | -6/+7 | |
| | | | | | | | | Replaces the old global "soundfont" which never worked. | |||||
| * | configure.ac: auto-detect libfluidsynth | Max Kellermann | 2012-08-15 | 1 | -9/+0 | |
| | | | | | | | | | | Now that the libfluidsynth API was sanitized, we can enable the plugin automatically if libfluidsynth is installed. | |||||
| * | decoder/fluidsynth: stop playback at end of file | Max Kellermann | 2012-08-15 | 1 | -5/+4 | |
| | | | | | | | | Use libfluidsynth's new function fluid_player_get_status(). | |||||
| * | decoder/fluidsynth: don't duplicate path | Max Kellermann | 2012-08-15 | 1 | -6/+1 | |
| | | | | | | | | The libfluidsynth now accepts const strings. | |||||
| * | decoder/fluidsynth: check if file is really a MIDI | Max Kellermann | 2012-08-15 | 1 | -4/+1 | |
| | | | | | | | | Use fluid_is_midifile() to verify the file format. | |||||
| * | decoder/fluidsynth: remove throttle (requires libfluidsynth 1.1) | Max Kellermann | 2012-08-15 | 1 | -17/+1 | |
| | | | | | | | | | | The libfluidsynth API is now sane, and does not require real-time decoding. |