Merge branch 'v0.17.x'

This commit is contained in:
Max Kellermann 2013-02-27 20:00:14 +01:00
commit 8017301de5
5 changed files with 22 additions and 16 deletions

1
NEWS
View File

@ -22,6 +22,7 @@ ver 0.17.4 (2013/??/??)
- ffmpeg: support float planar audio (ffmpeg 1.1) - ffmpeg: support float planar audio (ffmpeg 1.1)
* player: * player:
- implement missing "idle" events on output errors - implement missing "idle" events on output errors
* clock: fix build failure
ver 0.17.3 (2013/01/06) ver 0.17.3 (2013/01/06)
* output: * output:

View File

@ -18,23 +18,23 @@ uses CONF_FILE.
Read more about MPD at <\fBhttp://www.musicpd.org/\fP>. Read more about MPD at <\fBhttp://www.musicpd.org/\fP>.
.SH OPTIONS .SH OPTIONS
.TP .TP
.BI --help .BI \-\-help
Output a brief help message. Output a brief help message.
.TP .TP
.BI --kill .BI \-\-kill
Kill the currently running mpd session. The pid_file parameter must be Kill the currently running mpd session. The pid_file parameter must be
specified in the config file for this to work. specified in the config file for this to work.
.TP .TP
.BI --no-daemon .BI \-\-no\-daemon
Don't detach from console. Don't detach from console.
.TP .TP
.BI --stderr .BI \-\-stderr
Print messages stderr. Print messages stderr.
.TP .TP
.BI --verbose .BI \-\-verbose
Verbose logging. Verbose logging.
.TP .TP
.BI --version .BI \-\-version
Print version information. Print version information.
.SH FILES .SH FILES
.TP .TP

View File

@ -175,7 +175,7 @@ only choice) if MPD was compiled without libsamplerate.
.RE .RE
.IP .IP
For an up-to-date list of available converters, please see the libsamplerate For an up-to-date list of available converters, please see the libsamplerate
documentation (available online at <\fBhttp://www.mega-nerd.com/SRC/\fP>). documentation (available online at <\fBhttp://www.mega\-nerd.com/SRC/\fP>).
.TP .TP
.B replaygain <off or album or track or auto> .B replaygain <off or album or track or auto>
If specified, mpd will adjust the volume of songs played using ReplayGain tags If specified, mpd will adjust the volume of songs played using ReplayGain tags
@ -186,7 +186,7 @@ tags if random play is activated otherwise the album ReplayGain tags. Currently
only FLAC, Ogg Vorbis, Musepack, and MP3 (through ID3v2 ReplayGain tags, not only FLAC, Ogg Vorbis, Musepack, and MP3 (through ID3v2 ReplayGain tags, not
APEv2) are supported. APEv2) are supported.
.TP .TP
.B replaygain_preamp <-15 to 15> .B replaygain_preamp <\-15 to 15>
This is the gain (in dB) applied to songs with ReplayGain tags. This is the gain (in dB) applied to songs with ReplayGain tags.
.TP .TP
.B volume_normalization <yes or no> .B volume_normalization <yes or no>
@ -227,12 +227,12 @@ is 8192.
.TP .TP
.B filesystem_charset <charset> .B filesystem_charset <charset>
This specifies the character set used for the filesystem. A list of supported This specifies the character set used for the filesystem. A list of supported
character sets can be obtained by running "iconv -l". The default is character sets can be obtained by running "iconv \-l". The default is
determined from the locale when the db was originally created. determined from the locale when the db was originally created.
.TP .TP
.B id3v1_encoding <charset> .B id3v1_encoding <charset>
This specifies the character set which ID3v1 tags are encoded in. A list of This specifies the character set which ID3v1 tags are encoded in. A list of
supported character sets can be obtained by running "iconv -l". The default is supported character sets can be obtained by running "iconv \-l". The default is
to let libid3tag convert them (from ISO-8859-1, as the standard specifies) and to let libid3tag convert them (from ISO-8859-1, as the standard specifies) and
do no additional conversion. do no additional conversion.
.TP .TP
@ -260,7 +260,7 @@ be used alone to disable all metadata. The default is to use all known tag
types except for comments and those starting with "musicbrainz". types except for comments and those starting with "musicbrainz".
.TP .TP
.B auto_update <yes or no> .B auto_update <yes or no>
This specifies the wheter to support automatic update of music database when This specifies the whether to support automatic update of music database when
files are changed in music_directory. The default is to disable autoupdate files are changed in music_directory. The default is to disable autoupdate
of database. of database.
.TP .TP
@ -282,7 +282,7 @@ better but requires more processing and higher bandwidth. Default is yes.
.TP .TP
.B type <type> .B type <type>
This specifies the audio output type. See the list of supported outputs in mpd This specifies the audio output type. See the list of supported outputs in mpd
--version for possible values. \-\-version for possible values.
.TP .TP
.B name <name> .B name <name>
This specifies a unique name for the audio output. This specifies a unique name for the audio output.

View File

@ -25,6 +25,9 @@
#include <mach/mach_time.h> #include <mach/mach_time.h>
#else #else
#include <time.h> #include <time.h>
#ifndef CLOCK_MONOTONIC
#include <sys/time.h>
#endif
#endif #endif
unsigned unsigned
@ -89,7 +92,7 @@ monotonic_clock_us(void)
/* we have no monotonic clock, fall back to gettimeofday() */ /* we have no monotonic clock, fall back to gettimeofday() */
struct timeval tv; struct timeval tv;
gettimeofday(&tv, 0); gettimeofday(&tv, 0);
return (uint64_t)tv.tv_sec * 1000 + (uint64_t)(tv.tv_usec) / 1000(; return (uint64_t)tv.tv_sec * 1000 + (uint64_t)tv.tv_usec;
#endif #endif
} }

View File

@ -31,9 +31,9 @@
struct timer *timer_new(const struct audio_format *af) struct timer *timer_new(const struct audio_format *af)
{ {
struct timer *timer = g_new(struct timer, 1); struct timer *timer = g_new(struct timer, 1);
timer->time = 0; timer->time = 0; // us
timer->started = 0; timer->started = 0; // false
timer->rate = af->sample_rate * audio_format_frame_size(af); timer->rate = af->sample_rate * audio_format_frame_size(af); // samples per second
return timer; return timer;
} }
@ -59,6 +59,8 @@ void timer_add(struct timer *timer, int size)
{ {
assert(timer->started); assert(timer->started);
// (size samples) / (rate samples per second) = duration seconds
// duration seconds * 1000000 = duration us
timer->time += ((uint64_t)size * 1000000) / timer->rate; timer->time += ((uint64_t)size * 1000000) / timer->rate;
} }