#include "webcit.h"
#include "webserver.h"
+#ifdef HAVE_USELOCALE
+extern locale_t wc_locales[];
+#endif
+
typedef unsigned char byte;
#define FALSE 0 /**< no. */
if (wc_locales[WC->selected_language] == NULL) {
return strftime(s, max, format, tm);
}
- else { // TODO: this gives empty strings on debian.
+ else {
return strftime_l(s, max, format, tm, wc_locales[WC->selected_language]);
}
#else
}
+
/*
* Format a date/time stamp for output
*/
-void webcit_fmt_date(char *buf, time_t thetime, int brief)
+void webcit_fmt_date(char *buf, time_t thetime, int Format)
{
struct tm tm;
struct tm today_tm;
localtime_r(&thetime, &tm);
- if (brief) {
+ /*
+ * DATEFMT_FULL: full display
+ * DATEFMT_BRIEF: if date == today, show only the time
+ * otherwise, for messages up to 6 months old,
+ * show the month and day, and the time
+ * older than 6 months, show only the date
+ * DATEFMT_RAWDATE: show full date, regardless of age
+ * DATEFMT_LOCALEDATE: show full date as prefered for the locale
+ */
- /* If date == today, show only the time */
- if ((tm.tm_year == today_tm.tm_year)
- &&(tm.tm_mon == today_tm.tm_mon)
- &&(tm.tm_mday == today_tm.tm_mday)) {
- if (time_format == WC_TIMEFORMAT_24)
- wc_strftime(buf, 32, "%k:%M", &tm);
- else
- wc_strftime(buf, 32, "%l:%M%p", &tm);
- }
- /* Otherwise, for messages up to 6 months old, show the month and day, and the time */
- else if (today_timet - thetime < 15552000) {
- if (time_format == WC_TIMEFORMAT_24)
- wc_strftime(buf, 32, "%b %d %k:%M", &tm);
+ switch (Format) {
+ case DATEFMT_BRIEF:
+ if ((tm.tm_year == today_tm.tm_year)
+ &&(tm.tm_mon == today_tm.tm_mon)
+ &&(tm.tm_mday == today_tm.tm_mday)) {
+ if (time_format == WC_TIMEFORMAT_24)
+ wc_strftime(buf, 32, "%k:%M", &tm);
+ else
+ wc_strftime(buf, 32, "%l:%M%p", &tm);
+ }
+ else if (today_timet - thetime < 15552000) {
+ if (time_format == WC_TIMEFORMAT_24)
+ wc_strftime(buf, 32, "%b %d %k:%M", &tm);
+ else
+ wc_strftime(buf, 32, "%b %d %l:%M%p", &tm);
+ }
+ else {
+ wc_strftime(buf, 32, "%b %d %Y", &tm);
+ }
+ break;
+ case DATEFMT_FULL:
+ if (time_format == WC_TIMEFORMAT_24)
+ wc_strftime(buf, 32, "%a %b %d %Y %T %Z", &tm);
else
- wc_strftime(buf, 32, "%b %d %l:%M%p", &tm);
- }
- /* older than 6 months, show only the date */
- else {
- wc_strftime(buf, 32, "%b %d %Y", &tm);
- }
+ wc_strftime(buf, 32, "%a %b %d %Y %r %Z", &tm);
+ break;
+ case DATEFMT_RAWDATE:
+ wc_strftime(buf, 32, "%a %b %d %Y", &tm);
+ break;
+ case DATEFMT_LOCALEDATE:
+ wc_strftime(buf, 32, "%x", &tm);
+ break;
}
- else {
- if (time_format == WC_TIMEFORMAT_24)
- wc_strftime(buf, 32, "%a %b %d %Y %T %Z", &tm);
- else
- wc_strftime(buf, 32, "%a %b %d %Y %r %Z", &tm);
+}
+
+
+/*
+ * Try to guess whether the user will prefer 12 hour or 24 hour time based on the locale.
+ */
+long guess_calhourformat(void) {
+ char buf[32];
+ struct tm tm;
+ memset(&tm, 0, sizeof tm);
+ wc_strftime(buf, 32, "%X", &tm);
+ if (buf[strlen(buf)-1] == 'M') {
+ return 12;
}
+ return 24;
}
time_format_cache = &(WC->time_format_cache);
if (*time_format_cache == WC_TIMEFORMAT_NONE)
{
- get_pref_long("calhourformat", &calhourformat, 24);
+ get_pref_long("calhourformat", &calhourformat, 99);
+
+ /* If we don't know the user's time format preference yet,
+ * make a guess based on the locale.
+ */
+ if (calhourformat == 99) {
+ calhourformat = guess_calhourformat();
+ }
+
+ /* Now set the preference */
if (calhourformat == 24)
*time_format_cache = WC_TIMEFORMAT_24;
else
hour = hour - 12;
if (time_format == WC_TIMEFORMAT_24) {
- sprintf(buf, "%2d:%02d",
+ sprintf(buf, "%d:%02d",
tm->tm_hour, tm->tm_min
);
}
* FIXME won't read asctime
* Doesn't understand timezone, but we only should be using GMT/UTC anyway
*/
-time_t httpdate_to_timestamp(char *buf)
+time_t httpdate_to_timestamp(StrBuf *buf)
{
time_t t = 0;
struct tm tt;
- char *c;
+ const char *c;
/** Skip day of week, to number */
- for (c = buf; *c != ' '; c++)
+ for (c = ChrPtr(buf); *c != ' '; c++)
;
c++;
+
+ memset(&tt, 0, sizeof(tt));
/* Get day of month */
tt.tm_mday = atoi(c);
t = mktime(&tt);
return t;
}
+
+
+void LoadTimeformatSettingsCache(StrBuf *Preference, long lvalue)
+{
+ int *time_format_cache;
+
+ time_format_cache = &(WC->time_format_cache);
+ if (lvalue == 24)
+ *time_format_cache = WC_TIMEFORMAT_24;
+ else
+ *time_format_cache = WC_TIMEFORMAT_AMPM;
+}
+
+
+
+void
+InitModule_DATETIME
+(void)
+{
+ RegisterPreference("calhourformat", _("Time format"), PRF_INT, LoadTimeformatSettingsCache);
+
+
+}