Commit 4b0f2701 authored by Josh Coalson's avatar Josh Coalson
Browse files

fix bug with fractional seconds on some locales (SF#1858012:...

fix bug with fractional seconds on some locales (SF#1858012:
parent 4a570080
......@@ -86,6 +86,7 @@
<li>Added a new options <span class="argument"><a href="documentation_tools_flac.html#flac_options_preserve_modtime">--preserve-modtime</a></span> and <span class="argument"><a href="documentation_tools_flac.html#flac_options_no_preserve_modtime">--no-preserve-modtime</a></span> to specify whether or not output files should copy the timestamp and permissions from their input files. The default is <span class="argument"><a href="documentation_tools_flac.html#flac_options_preserve_modtime">--preserve-modtime</a></span> as in previous versions. (<a href=";aid=1805428&amp;group_id=13478&amp;atid=363478">SF #1805428</a>).</li>
<li>The <span class="argument"><a href="documentation_tools_flac.html#flac_options_sector_align">--sector-align</a></span> option of <span class="commandname">flac</span> has been deprecated and may not exist in future versions. <a href="">shntool</a> provides similar functionality. (<a href=";aid=1805946&amp;group_id=13478&amp;atid=363478">SF #1805946</a>)</li>
<li>Fix bug where <span class="commandname">flac</span> was disallowing use of <span class="argument">--replay-gain</span> when encoding from stdin (<a href="">SF #1840124</a>).</li>
<li>Fix bug with fractional seconds on some locales (<a href="">SF #1858012</a>).</li>
......@@ -55,7 +55,7 @@ static FLAC__bool local__parse_timecode_(const char *s, double *value)
double ret;
unsigned i;
char c;
char c, *endptr;
/* parse [0-9][0-9]*: */
c = *s++;
......@@ -74,12 +74,9 @@ static FLAC__bool local__parse_timecode_(const char *s, double *value)
/* parse [0-9]*[.,]?[0-9]* i.e. a sign-less rational number (. or , OK for fractional seconds, to support different locales) */
if(strspn(s, "1234567890.,") != strlen(s))
return false;
const char *p = strpbrk(s, ".,");
if(p && 0 != strpbrk(++p, ".,"))
return false;
ret += atof(s);
ret += strtod(s, &endptr);
if (endptr == s || *endptr)
return false;
*value = ret;
return true;
Markdown is supported
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment