aboutsummaryrefslogtreecommitdiffstats
Commit message (Collapse)AuthorAgeFilesLines
* ffmeg: added support for the tags comment, genre, yearDavid Horn2009-01-302-0/+12
| | | | | | | | | | | | ffmpeg_tag_internal() does not look for a few tags that mpd supports. Most noteably: comment -> TAG_ITEM_COMMENT -> Description genre -> TAG_ITEM_GENRE -> WM/Genre (not WM/GenreID) year -> TAG_ITEM_DATE -> WM/Year I *think* that this is the last of the tags that AVFormatContext() in ffmpeg supports that mpd also uses.
* jack: reduced sleep time to 1msMax Kellermann2009-01-292-1/+2
| | | | | | | | | | When waiting for free space in the ring buffer, the JACK plugin sleeped 10ms until there is enough space. This delay was too large for low-latency setups (<10ms), and created a lot of xruns. Work around that by reducing the sleep time to 1ms. A proper solution for this would be to use an event based approach, and we will do it, just not now.
* jack: clear "shutdown" flag on reconnectMax Kellermann2009-01-292-0/+3
| | | | | | | When the connection failed once, you had to restart MPD, because it never cleared the jack_data.shutdown flag. Instead, it refused to play anything "because there is no client thread" (which is wrong at that point).
* jack: allocate ring buffers before connectingMax Kellermann2009-01-292-5/+5
| | | | | If the ring buffers are allocated after jack_activate(), mpd_jack_process() might segfault because it attempts to access them.
* jack: register ports before activating clientsMax Kellermann2009-01-291-5/+5
| | | | Call jack_port_register() before jack_activate().
* Modify version string to post-release version 0.14.2~gitAvuton Olrich2009-01-172-1/+4
|
* mpd version 0.14.1release-0.14.1Avuton Olrich2009-01-172-2/+2
|
* oggvorbis: disable seeking on remote songsMax Kellermann2009-01-172-6/+25
| | | | | | | | | | | | When libvorbis knows that a song is seekable, it seeks around like crazy in the file before starting to decode it. This is very expensive on remote HTTP resources, and delays MPD for 10 or 20 seconds. This patch disables seeking on remote songs, because the advantages of quickly playing a song seem to weigh more than the theoretical ability of seeking for most MPD users. If users feel this feature is needed, we will make a configuration option for that.
* decoder_api: added assertion on partial framesMax Kellermann2009-01-161-0/+1
| | | | Decoder plugins must not send partial frames.
* pcm_resample_fallback: corrected the sample calculationMax Kellermann2009-01-162-2/+5
| | | | | Due to rounding errors, it was possible that the fallback resampler returned partial frames.
* oggvorbis: define HAVE_OGGVORBIS when tremor is enabledMax Kellermann2009-01-152-1/+4
| | | | When tremor (libvorbisidec) is used, HAVE_OGGVORBIS was not defined.
* input_curl: don't call input_curl_select() when already at EOFMax Kellermann2009-01-151-1/+3
| | | | | | Calling input_curl_select() after EOF has been reached causes an assertion failure. This can happen if the HTTP response is empty. Check c->eof before calling input_curl_select().
* input_curl: set "ready" flag on EOFMax Kellermann2009-01-152-0/+6
| | | | Set the "ready" flag for empty resources.
* input_curl: call curl_multi_info_read() in constructorMax Kellermann2009-01-152-0/+7
| | | | | To check for early connect failures, call curl_multi_info_read() in the constructor input_curl_open(). This fixes an assertion failure.
* playlist: safely search the playlist for deleted songMax Kellermann2009-01-142-3/+5
| | | | | | | | When a song file is deleted during database update, all pointers to it must be removed from the playlist. The "for" loop in deleteASongFromPlaylist() did not deal with multiple copies of the deleted song properly, and left instances of the (to-be-invalidated) pointer in. Fix this by reversing the loop.
* song_save: check for colon and space when loading a tagMax Kellermann2009-01-141-2/+4
| | | | | | matchesAnMpdTagItemKey() broke when two tag items had the same prefix, because it did not check if the tag name ended after the prefix. Add a check for the colon and the space after the tag name.
* input_curl: honour http_proxy_* config directivesJoe Milbourn2009-01-132-0/+31
| | | | | | | | | | If http_proxy_{host, port, user, password} are provided in mpd.conf they are not passed on to libcurl. As a result mpd cannot stream from behind an http proxy. The attached patch `http_proxy.patch` makes the relevant calls to curl_easy_setopt(...) for all proxy configuration parameters, but is only tested for host and port.
* playlist: implement Fisher-Yates shuffle properlyMax Kellermann2009-01-132-2/+3
| | | | | | | | MPD's shuffling algorithm was not implemented well: it considers songs which were already swapped, making it somewhat non-random. Fix the Fisher-Yates shuffle algorithm by passing the proper bounds to the PRNG.
* playlist: use GLib's random number generatorMax Kellermann2009-01-131-6/+10
| | | | srandom() and random() are not portable. Use GLib's implementation.
* input_curl: use select() to eliminate busy loop during connectMax Kellermann2009-01-132-0/+8
| | | | | | | When decoder_run_song() (decoder_thread.c) waits for the input stream to become ready, it did that in a busy loop. Add a select() call to input_curl_buffer() during connect/handshake (i.e. before the first chunk of body data was received), to let the CPU relax.
* decoder_api: don't ignore DECODE_COMMAND_STOPMax Kellermann2009-01-131-2/+1
| | | | | | When the decoder thread is waiting for free chunks in the music pipe, don't ignore the STOP command. Just return dc.command without further checks.
* configure.ac: removed duplicate PKG_PROG_PKG_CONFIGMax Kellermann2009-01-131-2/+0
|
* updated .gitignoreMax Kellermann2009-01-131-0/+3
|
* update: save the database even if it is emptyMax Kellermann2009-01-133-1/+15
| | | | Save an empty database, even if the music directory is empty.
* pcm_utils: use the custom PRNG for volume ditheringMax Kellermann2009-01-135-6/+41
| | | | | Don't use libc's rand() function, because it is slow. Our own trivial linear congruential generator is good enough for dithering.
* update: refresh stats when database update is finishedMax Kellermann2009-01-132-0/+7
|
* configure.ac: detect libid3tag without pkg-configMax Kellermann2009-01-132-3/+9
| | | | | | libid3tag comes without a pkg-config file, and it is usually added by distribution packages. For those without .pc file, attempt to auto-detect the library with AC_CHECK_LIB.
* playlist: log errors during loadPlaylist()Max Kellermann2009-01-134-5/+5
| | | | | | Don't call command_error() if loading a song from the playlist fails. This may result in assertion failures, since command_error() may be called more than once.
* player_thread: fix cross-fading duplicate chunk bugMax Kellermann2009-01-042-0/+9
| | | | | | | | When the decoder of the new song is not fast enough, the player thread has to wait for it for a moment. However the variable "nextChunk" was reset to -1 during that, making the next loop iteration assume that cross-fading has not begun yet. This patch overwrites it with "0" while waiting.
* decoder_api: moved code to do_send_tag(), free temporary tagMax Kellermann2009-01-042-7/+18
| | | | | | | This patch fixes a minor memory leak: when decoder_tag() attempted to send a merged tag object (created by tag_add_stream_tags()), and was interrupted by a decoder command, it did not free the temporary merged tag object.
* NEWS: updated NEWS file for 0.14.1Max Kellermann2009-01-041-1/+10
|
* Check for pkg-config before using itQball Cow2009-01-041-0/+3
|
* jack: duplicate jack_get_ports() return valuesMax Kellermann2009-01-021-3/+4
| | | | | | | | | JACK documentation states: "The caller is responsible for calling free(3) any non-NULL returned value." This does not seem to include the array elements. Duplicate them after jack_get_ports(), and free only the array. Convert JackData.output_ports to non-const.
* bonjour: fixed "unused parameter" warningsMax Kellermann2009-01-021-7/+13
| | | | Add G_GNUC_UNUSED attributes.
* main: use g_setenv() instead of setenv()Max Kellermann2009-01-022-43/+1
| | | | Removed the fallback setenv() implementation for solaris.
* log: automatically append newlineMax Kellermann2009-01-021-2/+17
| | | | If a log message does not include a newline character, append it.
* tag_id3: strip leading and trailing whitespace from ID3 tagsThomas Jansen2009-01-021-2/+6
| | | | Fix for bug #1491.
* mp4: support the writer/composer tagFrank Mulder2009-01-021-0/+2
| | | | | | | | | | I tried to search for a certain composer in my collection, but only non-mp4 files showed up. The source code reveals that this tag is not read. This can be fixed by reading the 'Writer' tag field, in mp4_plugin.c, in function mp4_load_tag. I actually tried this, and after compiling with those lines added, also mp4 (.m4a) files showed up when searching for a composer.
* configure.ac: version number 0.14.1~gitMax Kellermann2009-01-022-1/+3
|
* MPD version 0.14release-0.14Avuton Olrich2008-12-252-6/+2
|
* Fix a few problems with the huge mpdconf update. There's alot of shift here, ↵Avuton Olrich2008-12-241-72/+86
| | | | mostly due to word wraps. This, also, improves on uniformity and clarity of the document.
* doc: fix "playlistdelete" documentationMax Kellermann2008-12-241-2/+2
| | | | | "playlistdelete" takes a song position, not a song id. There are no song ids in stored playlists.
* playlist: fix stored playlist modifications with absolute pathsMax Kellermann2008-12-243-2/+20
| | | | | | | | When save_absolute_paths_in_playlists was enabled in mpd.conf, MPD broke all playlists when manipulated using the "playlistdelete" command. The reason was that map_directory_child_fs() was used, which doesn't accept slashes in the file name. Use the new map_uri_fs() function instead.
* stored_playlist: fix integer overflow in length estimationMax Kellermann2008-12-241-1/+1
| | | | | | | With a large maximum playlist length, the integer multiplication "playlist_max_length * MPD_PATH_MAX" may overflow. Change that to a division. This was not a dangerous bug, since it was only used for a quick estimate.
* ffmpeg: case AV_NOPTS_VALUE to int64_tMax Kellermann2008-12-241-2/+2
| | | | | The old code casted it to a 32 bit integer, which cut off bits. AVFormatContext.duration is a int64_t, so use this type.
* ffmpeg: don't assign "0" to pointerMax Kellermann2008-12-241-1/+1
| | | | Use NULL instead. Found by sparse.
* Makefile.am: fix sparse invocationMax Kellermann2008-12-241-1/+4
| | | | Added missing includes.
* added build test script "test.sh"Max Kellermann2008-12-241-0/+87
|
* mp3: "tag" argument is unused when libid3tag is disabledMax Kellermann2008-12-241-2/+2
| | | | Add G_GNUC_UNUSED attributes.
* listen: "port" argument is unused when TCP support is disabledMax Kellermann2008-12-241-1/+2
| | | | Add a G_GNUC_UNUSED attribute.