Commit message (Collapse) | Author | Age | Files | Lines | |
---|---|---|---|---|---|
* | configure.ac: prepare for 0.19.2 | Max Kellermann | 2014-10-23 | 2 | -1/+3 |
| | |||||
* | release v0.19.1 | Max Kellermann | 2014-10-19 | 2 | -3/+3 |
| | |||||
* | TextInputStream: manually shift the buffer before reading | Max Kellermann | 2014-10-19 | 2 | -0/+3 |
| | | | | | Fixes truncated lines in m3u and cue files (regression by commit 67958f7). | ||||
* | util/StaticFifoBuffer: make Shift() public | Max Kellermann | 2014-10-19 | 1 | -2/+0 |
| | |||||
* | playlist/extm3u: strip first line for #EXTM3U detection | Max Kellermann | 2014-10-17 | 2 | -2/+8 |
| | |||||
* | Makefile.am: distribute systemd/mpd.socket | Max Kellermann | 2014-10-12 | 2 | -0/+2 |
| | | | | | The file systemd/mpd.service.in is being distributed implicitly, but systemd/mpd.socket is not and needs to be added to EXTRA_DIST. | ||||
* | ThreadInputStream: call ThreadRead() inside the thread instead of Read() | Max Kellermann | 2014-10-11 | 2 | -1/+3 |
| | | | | Fixes deadlock bug in the "mms" plugin. | ||||
* | ThreadInputStream: add assertions | Max Kellermann | 2014-10-11 | 1 | -0/+8 |
| | |||||
* | NEWS: add missing line | Max Kellermann | 2014-10-11 | 1 | -0/+1 |
| | |||||
* | NEWS: fix typo in version number | Max Kellermann | 2014-10-11 | 1 | -1/+1 |
| | |||||
* | util/DynamicFifoBuffer: make the "Range" type public | Max Kellermann | 2014-10-11 | 1 | -0/+1 |
| | | | | | Export it from the protected base class. This fixes a build failure on Mac OS X. | ||||
* | configure.ac: prepare for 0.19.1 | Max Kellermann | 2014-10-11 | 2 | -1/+3 |
| | |||||
* | release v0.19 | Max Kellermann | 2014-10-10 | 3 | -4/+4 |
| | |||||
* | doc: document the mount/neighbor commands | Max Kellermann | 2014-10-10 | 3 | -1/+192 |
| | |||||
* | doc/protocol: add more markup | Max Kellermann | 2014-10-10 | 1 | -58/+71 |
| | |||||
* | db/upnp/Util: move caturl() to util/UriUtil.cxx | Max Kellermann | 2014-10-10 | 6 | -32/+39 |
| | |||||
* | event/IdleMonitor: remove redundant comment | Max Kellermann | 2014-10-10 | 1 | -2/+1 |
| | |||||
* | ZeroconfBonjour: use htons() instead of g_htons() | Max Kellermann | 2014-10-10 | 1 | -3/+3 |
| | |||||
* | TagString: implement fix_utf8() without GLib | Max Kellermann | 2014-10-10 | 1 | -22/+34 |
| | |||||
* | util/UTF8: add SequenceLengthUTF8() | Max Kellermann | 2014-10-10 | 2 | -0/+96 |
| | |||||
* | util/UTF8: new library | Max Kellermann | 2014-10-10 | 3 | -0/+340 |
| | |||||
* | TagString: return WritableBuffer<char> | Max Kellermann | 2014-10-10 | 3 | -24/+26 |
| | |||||
* | TagString: use strndup() for unterminated string | Max Kellermann | 2014-10-10 | 1 | -1/+1 |
| | | | | Fixes buffer overflow bug. | ||||
* | TagString: remove ISO-Latin-1 fallback | Max Kellermann | 2014-10-10 | 2 | -14/+2 |
| | | | | | | | | MPD handles all strings in UTF-8 internally. Those decoders which read Latin-1 tags are supposed to implement the conversion, instead of passing Latin-1 to TagBuilder::AddItem(). FixTagString() is simply the wrong place to do that, and hard-coding Latin-1 is kind of arbitrary. | ||||
* | fs/Traits: use value_type | Max Kellermann | 2014-10-10 | 1 | -4/+4 |
| | |||||
* | Main: run the OS X native event loop | nanotech | 2014-10-10 | 5 | -0/+52 |
| | |||||
* | storage/nfs: use the libnfs async API | Max Kellermann | 2014-10-09 | 4 | -49/+398 |
| | | | | Share the NFS connection with the NFS input plugin. | ||||
* | lib/nfs/Connection: reduce Error instance allocations | Max Kellermann | 2014-10-09 | 1 | -3/+2 |
| | |||||
* | lib/nfs/Glue: add assertion | Max Kellermann | 2014-10-09 | 1 | -0/+1 |
| | |||||
* | StoragePlugin: pass EventLoop to constructor | Max Kellermann | 2014-10-09 | 11 | -15/+31 |
| | |||||
* | test/run_input, ...: add struct ScopeIOThread | Max Kellermann | 2014-10-07 | 9 | -32/+57 |
| | | | | Auto-stop the IO thread in all error handlers. | ||||
* | storage/nfs: move code to class MemoryStorageDirectoryReader | Max Kellermann | 2014-10-07 | 4 | -73/+151 |
| | | | | | | Read all directory entries into memory and close the struct nfsdir before returning the StorageDirectoryReader instance. This is what libnfs does, anyway. | ||||
* | storage/nfs: move code to Copy() | Max Kellermann | 2014-10-07 | 1 | -18/+30 |
| | |||||
* | lib/nfs/Connection: add methods {Open,Read,Close}Directory() | Max Kellermann | 2014-10-07 | 2 | -0/+53 |
| | |||||
* | lib/nfs/Connection: add method Stat(path) | Max Kellermann | 2014-10-07 | 2 | -0/+33 |
| | |||||
* | test/run_storage: new debug program | Max Kellermann | 2014-10-07 | 2 | -2/+143 |
| | |||||
* | Makefile.am: add libnfs and libsmbclient to STORAGE_LIBS | Max Kellermann | 2014-10-07 | 1 | -1/+4 |
| | |||||
* | lib/nfs/Connection: make GetEventLoop() public | Max Kellermann | 2014-10-06 | 1 | -4/+4 |
| | |||||
* | lib/nfs/Base: kludge to reduce number of NFS mounts | Max Kellermann | 2014-10-05 | 5 | -7/+128 |
| | | | | | | | Creating a NfsStorage sets its own export_name as the "base". Now NfsFileReader can use this information to derive the export_name to be mounted, instead of guessing. This solves the "too many connection" problem on the NFS server while updating the database. | ||||
* | Makefile.am: compile libffmpeg.a with FFMPEG_CFLAGS | Max Kellermann | 2014-10-04 | 1 | -0/+2 |
| | |||||
* | PlaylistStream: use OpenLocalInputStream() | Max Kellermann | 2014-10-02 | 1 | -5/+3 |
| | |||||
* | PlaylistStream: pass Path instance to playlist_open_path() | Max Kellermann | 2014-10-02 | 3 | -11/+19 |
| | | | | | Convert filesystem charset to UTF-8 for playlist_list_open_uri(). This fixes one of many remaining charset bugs. | ||||
* | archive/bzip2: use OpenLocalInputStream() | Max Kellermann | 2014-10-02 | 1 | -2/+2 |
| | |||||
* | input/Open: use OpenLocalInputStream() | Max Kellermann | 2014-10-02 | 5 | -33/+34 |
| | | | | | | | Make the "open" method of plugins "file" and "archive" dummy methods that always fail. Instead, let InputStream::Open() hard-code access to these two plugins by using OpenLocalInputStream(). This allows simplifyin the algorithm for falling back to probing archive plugins. | ||||
* | DecoderThread: use OpenLocalInputStream() for local files | Max Kellermann | 2014-10-02 | 1 | -1/+20 |
| | |||||
* | TagFile: use OpenLocalInputStream() | Max Kellermann | 2014-10-02 | 1 | -3/+4 |
| | |||||
* | input/LocalOpen: new library for opening local files | Max Kellermann | 2014-10-02 | 3 | -0/+87 |
| | | | | Combines the "file" and the "archive" input plugins. | ||||
* | input/archive: export function OpenArchiveInputStream() | Max Kellermann | 2014-10-02 | 2 | -16/+33 |
| | |||||
* | input/file: export function OpenFileInputStream() | Max Kellermann | 2014-10-02 | 2 | -13/+37 |
| | |||||
* | input/file: generate Error when errno==ENOENT | Max Kellermann | 2014-10-02 | 1 | -1/+1 |
| | | | | | This special case was useless. Fixes the dreaded "Unrecognized URI" error message when a file does not exist. |