Commit message (Collapse) | Author | Age | Files | Lines | ||
---|---|---|---|---|---|---|
... | ||||||
* | | ArchivePlugin: rename struct archive_plugin to ArchivePlugin | Max Kellermann | 2014-02-08 | 1 | -1/+1 | |
| | | ||||||
* | | storage/local: remove utf8 path from constructor | Max Kellermann | 2014-02-07 | 1 | -3/+4 | |
| | | | | | | | | Build the UTF-8 version of the path automatically in the constructor. | |||||
* | | StoragePlugin: add method MapToRelativeUTF8() | Max Kellermann | 2014-02-07 | 1 | -16/+8 | |
| | | | | | | | | Replaces map_to_relative_path() from Mapper.cxx. | |||||
* | | DecoderPlugin: pass Path instance to file_decode() and scan_file() | Max Kellermann | 2014-02-07 | 2 | -7/+9 | |
| | | ||||||
* | | Mapper: move map_song_detach() to db/DatabaseSong.cxx | Max Kellermann | 2014-02-07 | 1 | -6/+16 | |
| | | | | | | | | Use Storage::MapUTF8() internally, don't use global variables. | |||||
* | | mixer/Plugin: pass AudioOutput reference to init() | Max Kellermann | 2014-02-06 | 1 | -54/+2 | |
| | | | | | | | | Passing a void pointer is unsafe. | |||||
* | | Mixer: use reference instead of pointer for MixerPlugin | Max Kellermann | 2014-02-05 | 1 | -1/+1 | |
| | | ||||||
* | | MixerPlugin: add EventLoop& init() parameter | Max Kellermann | 2014-02-05 | 2 | -14/+7 | |
| | | ||||||
* | | event/Loop: remove the dummy constructor argument | Max Kellermann | 2014-02-05 | 5 | -5/+5 | |
| | | ||||||
* | | test/ShutdownHandler: make the constructor "explicit" | Max Kellermann | 2014-02-05 | 1 | -1/+1 | |
| | | ||||||
* | | db/DatabaseListener: add method OnDatabaseSongRemoved() | Max Kellermann | 2014-02-04 | 1 | -0/+4 | |
| | | | | | | | | Decouples db/update/Remove.cpp from global variables. | |||||
* | | Instance: add Database attribute | Max Kellermann | 2014-02-04 | 1 | -2/+9 | |
| | | | | | | | | Move from db/DatabaseGlue.cxx, eliminating global variable. | |||||
* | | db/DatabasePlaylist: pass Database reference around | Max Kellermann | 2014-02-04 | 1 | -4/+6 | |
| | | | | | | | | Reduce global variable usage, move to frontend code. | |||||
* | | SongLoader: new class that merges duplicate code | Max Kellermann | 2014-02-03 | 1 | -10/+41 | |
| | | | | | | | | | | There was quite a lot of duplicate code for loading DetachedSong objects, with different semantics for "securely" loading local files. | |||||
* | | output: move functions into the AudioOutput struct | Max Kellermann | 2014-01-29 | 1 | -1/+0 | |
| | | ||||||
* | | output: rename source files | Max Kellermann | 2014-01-28 | 1 | -1/+1 | |
| | | ||||||
* | | output: rename struct audio_output to AudioOutput | Max Kellermann | 2014-01-28 | 1 | -4/+4 | |
| | | ||||||
* | | OutputAll: convert to class, move instance to class Partition | Max Kellermann | 2014-01-28 | 1 | -3/+6 | |
| | | | | | | | | Another big chunk of code for multi-player support. | |||||
* | | Playlist{Info,Vector}: move to db/ | Max Kellermann | 2014-01-27 | 1 | -1/+1 | |
| | | ||||||
* | | Merge branch 'v0.18.x' | Max Kellermann | 2014-01-27 | 1 | -0/+85 | |
|\| | ||||||
| * | IcyMetadataParser: more robust tag parser | Max Kellermann | 2014-01-27 | 1 | -0/+15 | |
| | | | | | | | | | | Allow semicolons and single quotes in the stream title. This is not part of any specification, but found in real life. | |||||
| * | test/test_icy_parser: unit test for IcyMetaDataParser.cxx | Max Kellermann | 2014-01-27 | 1 | -0/+70 | |
| | | ||||||
* | | neighbor: new subsystem to detect file servers on the local network | Max Kellermann | 2014-01-26 | 2 | -0/+86 | |
| | | | | | | | | | | | | | | | | | | | | | | | | | | This commit adds the NeighborPlugin API which can be used to detect nearby file servers that can be used by input plugins. This list of servers is exported using the new "listneighbors" command. The idle even "neighbor" notifies interested clients when a new neighbor is found or an existing one is lost. There's a lot missing currently: protocol&user documentation, and a way to "mount" remote servers into the music database. Obviously, some code from the UPnP database plugin can be moved to a neighbor plugin. | |||||
* | | Mixer*: move to mixer/ | Max Kellermann | 2014-01-24 | 2 | -3/+3 | |
| | | ||||||
* | | Filter*: move to filter/ | Max Kellermann | 2014-01-24 | 3 | -5/+5 | |
| | | ||||||
* | | Database*: move to db/ | Max Kellermann | 2014-01-24 | 3 | -8/+8 | |
| | | ||||||
* | | Input*: move to input/ | Max Kellermann | 2014-01-24 | 8 | -16/+16 | |
| | | ||||||
* | | Update*: move to update/ | Max Kellermann | 2014-01-24 | 1 | -1/+1 | |
| | | ||||||
* | | Config*: move to config/ | Max Kellermann | 2014-01-24 | 13 | -17/+17 | |
| | | ||||||
* | | Queue*: move to queue/ | Max Kellermann | 2014-01-24 | 1 | -1/+1 | |
| | | ||||||
* | | Zeroconf*: move to zeroconf/ | Max Kellermann | 2014-01-24 | 1 | -1/+1 | |
| | | ||||||
* | | archive/*: move to archive/plugins/ | Max Kellermann | 2014-01-24 | 4 | -7/+7 | |
| | | ||||||
* | | decoder/*: move to decoder/plugins/ | Max Kellermann | 2014-01-24 | 4 | -6/+6 | |
| | | ||||||
* | | output/*: move to output/plugins/ | Max Kellermann | 2014-01-23 | 2 | -5/+5 | |
| | | ||||||
* | | playlist/*: move to playlist/plugins/ | Max Kellermann | 2014-01-23 | 2 | -4/+4 | |
| | | ||||||
* | | Encoder*: move to src/encoder | Max Kellermann | 2014-01-23 | 2 | -4/+4 | |
| | | | | | | | | .. and move the plugins to src/encoder/plugins/. | |||||
* | | LightDirectory: new struct replacing Directory in the DB API | Max Kellermann | 2014-01-22 | 1 | -5/+6 | |
| | | ||||||
* | | PlaylistSong: modify the given song object in-place | Max Kellermann | 2014-01-21 | 1 | -48/+31 | |
| | | | | | | | | Reduce bloat. | |||||
* | | test: add unit test for playlist_check_translate_song() | Max Kellermann | 2014-01-21 | 1 | -0/+290 | |
| | | ||||||
* | | Merge branch 'v0.18.x' | Max Kellermann | 2014-01-20 | 1 | -2/+2 | |
|\| | ||||||
| * | Queue: rename struct queue to Queue | Max Kellermann | 2014-01-20 | 1 | -2/+2 | |
| | | | | | | | | | | Works around a build failure on Solaris because annoyingly, Solaris reserves the name "queue". This rename was pending anyway. | |||||
* | | LightSong: new class to be used by DatabasePlugin callbacks | Max Kellermann | 2014-01-19 | 2 | -37/+4 | |
| | | | | | | | | | | Detach the Song class completely from the public API, only to be used by SimpleDatabase and the update thread. | |||||
* | | copyright year 2014 | Max Kellermann | 2014-01-13 | 36 | -36/+36 | |
| | | ||||||
* | | DatabasePlugin: add interface DatabaseListener | Max Kellermann | 2014-01-11 | 1 | -1/+14 | |
| | | | | | | | | Allow database plugins to announce that they have been modified. | |||||
* | | UPnP database plugin | Jean-Francois Dockes | 2014-01-09 | 1 | -0/+9 | |
| | | | | | | | | | | | | [mk: renamed source files, applied coding style, reduced bloat, using MPD's threading library, using MPD's error reporting and logging library and refactoring, fixed lots of bugs] | |||||
* | | DetachedSong: fork of struct Song | Max Kellermann | 2014-01-09 | 3 | -38/+42 | |
| | | | | | | | | | | | | From now on, struct Song will be used by the database only, and DetachedSong will be used by everybody else. DetachedSong is easier to use, but Song has lower overhead. | |||||
* | | test/DumpDatabase: fix nullptr dereference | Max Kellermann | 2014-01-09 | 1 | -1/+1 | |
| | | ||||||
* | | Merge branch 'v0.18.x' | Max Kellermann | 2014-01-08 | 1 | -0/+4 | |
|\| | ||||||
| * | util/UriUtil: uri_get_suffix() fails if name begins with dot | Max Kellermann | 2013-12-29 | 1 | -0/+4 | |
| | | | | | | | | | | A file called ".jpg" is not a JPEG file with an empty name; it is merely a hidden file. | |||||
* | | test: add missing includes | Max Kellermann | 2014-01-07 | 8 | -0/+11 | |
| | |