Tweaking time class.
Originally committed to SVN as r2445.
This commit is contained in:
parent
5812315d85
commit
c029e5aac8
1 changed files with 24 additions and 4 deletions
|
@ -136,17 +136,36 @@ void Time::ParseString(const String &data)
|
||||||
size_t len = data.Length();
|
size_t len = data.Length();
|
||||||
size_t curIndex = 0;
|
size_t curIndex = 0;
|
||||||
char cur = 0;
|
char cur = 0;
|
||||||
|
bool gotDecimal = false;
|
||||||
for (size_t i=0;i<len;i++) {
|
for (size_t i=0;i<len;i++) {
|
||||||
cur = data[i];
|
cur = data[i];
|
||||||
if (cur == ':' || cur == '.' || cur == ',' || cur == ';') {
|
|
||||||
|
// Got a separator
|
||||||
|
bool isDecimalSeparator = (cur == '.' || cur == ',');
|
||||||
|
if (isDecimalSeparator || cur == ':' || cur == ';') {
|
||||||
|
if (isDecimalSeparator) {
|
||||||
|
if (gotDecimal) break;
|
||||||
|
gotDecimal = true;
|
||||||
|
}
|
||||||
values.at(curIndex++) = data.SubToInteger(last,i);
|
values.at(curIndex++) = data.SubToInteger(last,i);
|
||||||
last = i+1;
|
last = i+1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Reached end of string
|
||||||
if (i == len-1) {
|
if (i == len-1) {
|
||||||
int value = data.SubToInteger(last,len);
|
int value = data.SubToInteger(last,len);
|
||||||
size_t digits = len - last;
|
size_t digits = len - last;
|
||||||
|
|
||||||
|
// Ended in decimal, so we gotta normalize it to 3 digits
|
||||||
|
if (gotDecimal) {
|
||||||
|
if (digits != 3) {
|
||||||
if (digits == 2) value *= 10;
|
if (digits == 2) value *= 10;
|
||||||
if (digits == 1) value *= 100;
|
else if (digits == 1) value *= 100;
|
||||||
|
else if (digits > 3) {
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
values.at(curIndex++) = value;
|
values.at(curIndex++) = value;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -154,8 +173,9 @@ void Time::ParseString(const String &data)
|
||||||
// Turn into milliseconds
|
// Turn into milliseconds
|
||||||
size_t mult[] = { 0, 1, 1000, 60000, 3600000 };
|
size_t mult[] = { 0, 1, 1000, 60000, 3600000 };
|
||||||
size_t accum = 0;
|
size_t accum = 0;
|
||||||
|
size_t adjust = gotDecimal ? 0 : 1;
|
||||||
for (int i=(int)curIndex;--i>=0;) {
|
for (int i=(int)curIndex;--i>=0;) {
|
||||||
accum += values[i] * mult[curIndex-i];
|
accum += values[i] * mult[curIndex-i+adjust];
|
||||||
}
|
}
|
||||||
|
|
||||||
// Set
|
// Set
|
||||||
|
|
Loading…
Reference in a new issue