diff --git a/NEWS b/NEWS
index ae53f52c5..2defb5962 100644
--- a/NEWS
+++ b/NEWS
@@ -32,6 +32,14 @@ ver 0.16 (20??/??/??)
* obey $(sysconfdir) for default mpd.conf location
+ver 0.15.3 (2009/08/29)
+* decoders:
+ - vorbis: faster tag scanning with ov_test_callback()
+* output:
+ - fix stuttering due to uninitialized variable
+* update: don't re-read unchanged container files
+
+
ver 0.15.2 (2009/08/15)
* tags:
- ape: check the tag size (fixes integer underflow)
diff --git a/doc/protocol.xml b/doc/protocol.xml
index a08f95f1a..05a65de23 100644
--- a/doc/protocol.xml
+++ b/doc/protocol.xml
@@ -279,6 +279,24 @@
+
+
+ nextsong:
+
+ playlist song number of the next
+ song to be played
+
+
+
+
+
+ nextsongid:
+
+ playlist songid of the next song
+ to be played
+
+
+
time:
diff --git a/src/decoder/vorbis_plugin.c b/src/decoder/vorbis_plugin.c
index 39a075176..4548d1b57 100755
--- a/src/decoder/vorbis_plugin.c
+++ b/src/decoder/vorbis_plugin.c
@@ -382,7 +382,7 @@ vorbis_tag_dup(const char *file)
return NULL;
}
- if (ov_open(fp, &vf, NULL, 0) < 0) {
+ if (ov_test_callbacks(fp, &vf, NULL, 0, OV_CALLBACKS_STREAMONLY) < 0) {
fclose(fp);
return NULL;
}
diff --git a/src/output_init.c b/src/output_init.c
index 08873ac20..66444e9a5 100644
--- a/src/output_init.c
+++ b/src/output_init.c
@@ -178,6 +178,7 @@ audio_output_init(struct audio_output *ao, const struct config_param *param,
ao->plugin = plugin;
ao->enabled = config_get_block_bool(param, "enabled", true);
ao->open = false;
+ ao->pause = false;
ao->fail_timer = NULL;
/* set up the filter chain */
diff --git a/src/update.c b/src/update.c
index 6778a5989..cfe574e17 100644
--- a/src/update.c
+++ b/src/update.c
@@ -502,7 +502,8 @@ update_regular_file(struct directory *directory,
{
struct song* song = songvec_find(&directory->songs, name);
- if (plugin->container_scan != NULL)
+ if (!(song != NULL && st->st_mtime == song->mtime) &&
+ plugin->container_scan != NULL)
{
if (update_container_file(directory, name, st, plugin))
{