mirror of
https://github.com/GothenburgBitFactory/taskwarrior.git
synced 2025-06-26 10:54:26 +02:00
Fixed floating point arithmetic when type casting.
See http://stackoverflow.com/questions/1989708/type-casting-with-printf-statements-under-mac-osx-and-linux
This commit is contained in:
parent
be75b4bf3a
commit
93067f3c3b
1 changed files with 17 additions and 17 deletions
24
src/util.cpp
24
src/util.cpp
|
@ -168,24 +168,24 @@ std::string formatSeconds (time_t delta)
|
|||
sprintf (formatted, "%.1f yrs", (days / 365)); // TODO i18n
|
||||
else if (delta > 86400 * 84)
|
||||
sprintf (formatted, "%1d mth%s", // TODO i18n
|
||||
(int) (days / 30.6),
|
||||
((int) (days / 30.6) == 1 ? "" : "s")); // TODO i18n
|
||||
(int) (float) (days / 30.6),
|
||||
((int) (float) (days / 30.6) == 1 ? "" : "s")); // TODO i18n
|
||||
else if (delta > 86400 * 13)
|
||||
sprintf (formatted, "%d wk%s", // TODO i18n
|
||||
(int) (days / 7.0),
|
||||
((int) (days / 7.0) == 1 ? "" : "s")); // TODO i18n
|
||||
(int) (float) (days / 7.0),
|
||||
((int) (float) (days / 7.0) == 1 ? "" : "s")); // TODO i18n
|
||||
else if (delta >= 86400)
|
||||
sprintf (formatted, "%d day%s", // TODO i18n
|
||||
(int) days,
|
||||
((int) days == 1 ? "" : "s")); // TODO i18n
|
||||
else if (delta >= 3600)
|
||||
sprintf (formatted, "%d hr%s", // TODO i18n
|
||||
(int) (delta / 3600),
|
||||
((int) (delta / 3600) == 1 ? "" : "s")); // TODO i18n
|
||||
(int) (float) (delta / 3600),
|
||||
((int) (float) (delta / 3600) == 1 ? "" : "s")); // TODO i18n
|
||||
else if (delta >= 60)
|
||||
sprintf (formatted, "%d min%s", // TODO i18n
|
||||
(int) (delta / 60),
|
||||
((int) (delta / 60) == 1 ? "" : "s")); // TODO i18n
|
||||
(int) (float) (delta / 60),
|
||||
((int) (float) (delta / 60) == 1 ? "" : "s")); // TODO i18n
|
||||
else if (delta >= 1)
|
||||
sprintf (formatted, "%d sec%s", // TODO i18n
|
||||
(int) delta,
|
||||
|
@ -204,11 +204,11 @@ std::string formatSecondsCompact (time_t delta)
|
|||
float days = (float) delta / 86400.0;
|
||||
|
||||
if (delta >= 86400 * 365) sprintf (formatted, "%.1fy", (days / 365)); // TODO i18n
|
||||
else if (delta >= 86400 * 84) sprintf (formatted, "%1dmo", (int) (days / 30.6)); // TODO i18n
|
||||
else if (delta >= 86400 * 13) sprintf (formatted, "%dwk", (int) (days / 7.0)); // TODO i18n
|
||||
else if (delta >= 86400 * 84) sprintf (formatted, "%1dmo", (int) (float) (days / 30.6)); // TODO i18n
|
||||
else if (delta >= 86400 * 13) sprintf (formatted, "%dwk", (int) (float) (days / 7.0)); // TODO i18n
|
||||
else if (delta >= 86400) sprintf (formatted, "%dd", (int) days); // TODO i18n
|
||||
else if (delta >= 3600) sprintf (formatted, "%dh", (int) (delta / 3600)); // TODO i18n
|
||||
else if (delta >= 60) sprintf (formatted, "%dm", (int) (delta / 60)); // TODO i18n
|
||||
else if (delta >= 3600) sprintf (formatted, "%dh", (int) (float) (delta / 3600)); // TODO i18n
|
||||
else if (delta >= 60) sprintf (formatted, "%dm", (int) (float) (delta / 60)); // TODO i18n
|
||||
else if (delta >= 1) sprintf (formatted, "%ds", (int) delta); // TODO i18n
|
||||
else strcpy (formatted, "-");
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue