diff options
author | Lubomir I. Ivanov <neolit123@gmail.com> | 2013-10-17 01:00:17 +0300 |
---|---|---|
committer | Dirk Hohndel <dirk@hohndel.org> | 2013-10-16 15:04:44 -0700 |
commit | 861b524e7a9ec743bb4495f70565bca8f9f43619 (patch) | |
tree | 82f3e47f2ba3e142b11316481c725d0ad0c575e5 /divelist.c | |
parent | 4c49670cdba403090067d8b92940b577d16ba550 (diff) | |
download | subsurface-861b524e7a9ec743bb4495f70565bca8f9f43619.tar.gz |
Helpers: move some date related function to qt-gui.cpp
divelist.c:
get_dive_date_string()
get_short_dive_date_string()
get_trip_date_string()
MinGW support for *printf and parameter positions (e.g. %1$d)
is horribly broken. Instead of implementing *proper* support
for this feature Microsoft decide to ignore the standard (again)
and they implement new functions with the '_p' suffix,
such as 'sprintf_p', which seem to be available from a 2003 runtime.
To top that 'sprintf_p' is not really a 'sprintf' but rather
a 'snprintf'.
It seems that the MinGW people ignore the issue and do not provide
wrappers of any sort, or at least for the current recommended compiler
for Qt 4.8.5 on Windows - which is a 4.4.0. A note of warning;
inspecting how MinGW does certain things in headers such as stdio.h,
can ensue bad dreams or other negative effects on to the viewer.
This forces us to move the following functions from the 'back-end'
(divelist.c) to the 'front-end' (qt-gui.cpp) and use QString.
Signed-off-by: Lubomir I. Ivanov <neolit123@gmail.com>
Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
Diffstat (limited to 'divelist.c')
-rw-r--r-- | divelist.c | 64 |
1 files changed, 0 insertions, 64 deletions
diff --git a/divelist.c b/divelist.c index 6df961808..858d61533 100644 --- a/divelist.c +++ b/divelist.c @@ -460,70 +460,6 @@ void update_cylinder_related_info(struct dive *dive) } } -#define MAX_DATE_STRING 256 -/* caller needs to free the string */ -char *get_dive_date_string(timestamp_t when) -{ - char *buffer = malloc(MAX_DATE_STRING); - if (buffer) { - struct tm tm; - utc_mkdate(when, &tm); - snprintf(buffer, MAX_DATE_STRING, - /*++GETTEXT 60 char buffer weekday, monthname, day of month, year, hour:min */ - translate("gettextFromC","%1$s, %2$s %3$d, %4$d %5$02d:%6$02d"), - weekday(tm.tm_wday), - monthname(tm.tm_mon), - tm.tm_mday, tm.tm_year + 1900, - tm.tm_hour, tm.tm_min); - } - return buffer; -} - -char *get_short_dive_date_string(timestamp_t when) -{ - char *buffer = malloc(MAX_DATE_STRING); - if (buffer) { - struct tm tm; - utc_mkdate(when, &tm); - snprintf(buffer, MAX_DATE_STRING, - /*++GETTEXT 40 char buffer monthname, day of month, year, hour:min */ - translate("gettextFromC","%1$s %2$d, %3$d\n%4$02d:%5$02d"), - monthname(tm.tm_mon), - tm.tm_mday, tm.tm_year +1900, - tm.tm_hour, tm.tm_min); - } - return buffer; -} - -/* caller needs to free the string */ -char *get_trip_date_string(timestamp_t when, int nr) -{ - char *buffer = malloc(MAX_DATE_STRING); - if (buffer) { - struct tm tm; - utc_mkdate(when, &tm); - if (nr != 1) { - snprintf(buffer, MAX_DATE_STRING, -#if PLURAL_HANDLING_IN_TRANLATION - /*++GETTEXT 60 char buffer monthname, year, nr dives */ - ngettext("%1$s %2$d (%3$d dive)", - "%1$s %2$d (%3$d dives)", nr), -#else - translate("gettextFromC","%1$s %2$d (%3$d dives)"), -#endif - monthname(tm.tm_mon), - tm.tm_year + 1900, - nr); - } else { - snprintf(buffer, MAX_DATE_STRING, - translate("gettextFromC","%1$s %2$d (1 dive)"), - monthname(tm.tm_mon), - tm.tm_year + 1900); - } - } - return buffer; -} - #define MAX_NITROX_STRING 80 #define UTF8_ELLIPSIS "\xE2\x80\xA6" |