GnuCash  5.6-150-g038405b370+
gnc-date.h
Go to the documentation of this file.
1 /********************************************************************
2  * gnc-date.h (to be renamed qofdate.h)
3  *
4  * Copyright (C) 1997 Robin D. Clark <rclark@cs.hmc.edu>
5  * Copyright (C) 1998-2000, 2003 Linas Vepstas <linas@linas.org>
6  * Copyright 2005 Neil Williams <linux@codehelp.co.uk>
7  * Copyright (C) 2005 David Hampton <hampton@employees.org>
8  * Copyright 2012 John Ralls <jralls@ceridwen.us>
9  ********************************************************************/
10 /********************************************************************\
11  * This program is free software; you can redistribute it and/or *
12  * modify it under the terms of the GNU General Public License as *
13  * published by the Free Software Foundation; either version 2 of *
14  * the License, or (at your option) any later version. *
15  * *
16  * This program is distributed in the hope that it will be useful, *
17  * but WITHOUT ANY WARRANTY; without even the implied warranty of *
18  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
19  * GNU General Public License for more details. *
20  * *
21  * You should have received a copy of the GNU General Public License*
22  * along with this program; if not, contact: *
23  * *
24  * Free Software Foundation Voice: +1-617-542-5942 *
25  * 51 Franklin Street, Fifth Floor Fax: +1-617-542-2652 *
26  * Boston, MA 02110-1301, USA gnu@gnu.org *
27 \********************************************************************/
66 #ifndef GNC_DATE_H
67 #define GNC_DATE_H
68 
69 #include <glib-object.h>
70 
71 #include <time.h>
72 
73 #ifdef __cplusplus
74 extern "C"
75 {
76 #endif
77 
78 
87 typedef gint64 time64;
88 /* A bit of a hack to create a type separate from the alias of int64_t so that
89  * compile-time dispatch can use the right KVP visitor.
90  */
91 typedef struct
92 {
93  time64 t;
94 } Time64;
95 
96 
100 GType time64_get_type( void );
101 #define GNC_TYPE_TIME64 (time64_get_type ())
102 
105 extern const char *gnc_default_strftime_date_format;
106 
108 #define MAX_DATE_LENGTH 34
109 
119 #define QOF_UTC_DATE_FORMAT "%Y-%m-%dT%H:%M:%SZ"
120 
122 typedef enum
123 {
132 } QofDateFormat;
133 
134 #define DATE_FORMAT_FIRST QOF_DATE_FORMAT_US
135 #define DATE_FORMAT_LAST QOF_DATE_FORMAT_UTC
136 
138 typedef enum
139 {
143 
148 typedef enum
149 {
150  GNCDATE_MONTH_NUMBER,
151  GNCDATE_MONTH_ABBREV,
152  GNCDATE_MONTH_NAME
154 
155 /* Replacements for POSIX functions which use time_t. Time_t is still
156  * 32 bits in Microsoft Windows, Apple OSX, and some BSD versions even
157  * when the rest of the system is 64-bits, as well as all 32-bit
158  * versions of Unix. 32-bit time_t overflows at 03:14:07 UTC on
159  * Tuesday, 19 January 2038 and so cannot represent dates after that.
160  *
161  * These functions use boost::date_time internally.
162  */
169 struct tm* gnc_localtime (const time64 *secs);
170 
177 struct tm* gnc_localtime_r (const time64 *secs, struct tm* time);
178 
185 struct tm* gnc_gmtime (const time64 *secs);
186 
190 gint gnc_start_of_week (void);
191 
198 time64 gnc_mktime (struct tm* time);
199 
206 time64 gnc_timegm (struct tm* time);
207 
216 gchar* gnc_ctime (const time64 *secs);
217 
224 time64 gnc_time (time64 *tbuf);
225 
235 gdouble gnc_difftime (const time64 secs1, const time64 secs2);
236 
240 void gnc_tm_free (struct tm* time);
241 
244 
246 const gchar* gnc_date_dateformat_to_string(QofDateFormat format);
247 
253 gboolean gnc_date_string_to_dateformat(const gchar* format_string,
254  QofDateFormat *format);
255 
256 const gchar* gnc_date_monthformat_to_string(GNCDateMonthFormat format);
257 
263 gboolean gnc_date_string_to_monthformat(const gchar *format_string,
264  GNCDateMonthFormat *format);
265 
271 char* gnc_print_time64(time64 time, const char* format);
272 
273 // @}
274 
279 GDate* gnc_g_date_new_today (void);
280 
284 void gnc_gdate_set_today (GDate* gd);
285 
290 void gnc_gdate_set_time64 (GDate* gd, time64 time);
291 
298 
300 time64 gdate_to_time64 (GDate d);
301 
303 time64 gnc_dmy2time64 (gint day, gint month, gint year);
304 
312 time64 gnc_dmy2time64_neutral (gint day, gint month, gint year);
313 
315 time64 gnc_dmy2time64_end (gint day, gint month, gint year);
316 
333 time64 gnc_iso8601_to_time64_gmt(const gchar *);
334 
351 gchar * gnc_time64_to_iso8601_buff (time64, char * buff);
352 // @}
353 
354 /* ======================================================== */
355 
357 // @{
364 
371 
381 
391 // @}
392 
393 /* ======================================================== */
394 
401 void qof_date_completion_set(QofDateCompletion dc, int backmonths);
402 
412 gchar dateSeparator(void);
413 
414 /* ======================================================== */
415 
418 // @{
427 /* qof_format_time takes a format specification in UTF-8 and a broken-down time,
428  * tries to call strftime with a sufficiently large buffer and, if successful,
429  * return a newly allocated string in UTF-8 for the printing result.
430  *
431  * @param format A format specification in UTF-8.
432  *
433  * @param tm A broken-down time.
434  *
435  * @return A newly allocated string on success, or NULL otherwise.
436  */
437 /* gchar *qof_format_time(const gchar *format, const struct tm *tm); */
438 
453 gsize qof_strftime(gchar *buf, gsize max, const gchar *format,
454  const struct tm *tm);
455 
471 size_t qof_print_date_dmy_buff (gchar * buff, size_t buflen, int day, int month, int year);
472 
474 size_t qof_print_date_buff (char * buff, size_t buflen, time64 secs);
475 
477 size_t qof_print_gdate(char *buf, size_t bufflen, const GDate *gd);
478 
482 char * qof_print_date (time64 secs);
483 
484 
485 /* ------------------------------------------------------------------ */
486 /* time printing utilities */
487 
492 size_t qof_print_date_time_buff (char * buff, size_t len, time64 secs);
493 
507 gboolean qof_scan_date (const char *buff, int *day, int *month, int *year);
508 
509 // @}
510 
511 /* ======================================================== */
512 
516 // @{
517 
522 static inline
523 void gnc_tm_set_day_start (struct tm *tm)
524 {
525  /* First second of the day */
526  g_return_if_fail (tm != NULL);
527  tm->tm_hour = 0;
528  tm->tm_min = 0;
529  tm->tm_sec = 0;
530 }
531 
535 void gnc_tm_set_day_neutral (struct tm *tm);
536 
541 static inline
542 void gnc_tm_set_day_middle (struct tm *tm)
543 {
544  /* First second of the day */
545  g_return_if_fail (tm != NULL);
546  tm->tm_hour = 12;
547  tm->tm_min = 0;
548  tm->tm_sec = 0;
549 }
550 
555 static inline
556 void gnc_tm_set_day_end (struct tm *tm)
557 {
558  /* Last second of the day */
559  g_return_if_fail (tm != NULL);
560  tm->tm_hour = 23;
561  tm->tm_min = 59;
562  tm->tm_sec = 59;
563 }
564 
568 
572 
576 
578 int gnc_date_get_last_mday (int month, int year);
579 
580 // @}
581 
582 /* ======================================================== */
583 
585 // @{
588 void gnc_tm_get_today_start(struct tm *tm);
589 
592 void gnc_tm_get_today_neutral(struct tm *tm);
593 
596 void gnc_tm_get_today_end(struct tm *tm);
597 
601 
605 
609 char * gnc_date_timestamp (void);
610 
611 #define MIN_BUF_LEN 10
612 
617 void gnc_dow_abbrev(gchar *buf, int buf_len, int dow);
618 
620 
621 /* ======================================================== */
622 
624 // @{
625 
628 gint gnc_gdate_equal(gconstpointer gda, gconstpointer gdb);
629 
630 
633 guint gnc_gdate_hash( gconstpointer gd );
634 
636 
637 /* ======================================================== */
638 
640 // @{
645 GDate time64_to_gdate (time64 t);
646 
650 time64 gnc_time64_get_day_start_gdate (const GDate *date);
651 
655 time64 gnc_time64_get_day_end_gdate (const GDate *date);
656 
658 
659 /* ======================================================== */
660 
662 // @{
663 
669 void gnc_gdate_set_month_start (GDate *date);
670 
671 
677 void gnc_gdate_set_month_end (GDate *date);
678 
679 
686 void gnc_gdate_set_prev_month_start (GDate *date);
687 
688 
695 void gnc_gdate_set_prev_month_end (GDate *date);
696 
697 
703 void gnc_gdate_set_quarter_start (GDate *date);
704 
705 
711 void gnc_gdate_set_quarter_end (GDate *date);
712 
713 
720 void gnc_gdate_set_prev_quarter_start (GDate *date);
721 
722 
729 void gnc_gdate_set_prev_quarter_end (GDate *date);
730 
731 
737 void gnc_gdate_set_year_start (GDate *date);
738 
739 
745 void gnc_gdate_set_year_end (GDate *date);
746 
747 
754 void gnc_gdate_set_prev_year_start (GDate *date);
755 
756 
763 void gnc_gdate_set_prev_year_end (GDate *date);
764 
765 
775 void gnc_gdate_set_fiscal_year_start (GDate *date, const GDate *year_end);
776 
777 
787 void gnc_gdate_set_fiscal_year_end (GDate *date, const GDate *year_end);
788 
789 
799 void gnc_gdate_set_prev_fiscal_year_start (GDate *date, const GDate *year_end);
800 
801 
811 void gnc_gdate_set_prev_fiscal_year_end (GDate *date, const GDate *year_end);
812 
814 
816 #ifdef __cplusplus
817 }
818 #endif
819 
820 #endif /* GNC_DATE_H */
ISO: yyyy-mm-dd.
Definition: gnc-date.h:127
time64 gnc_iso8601_to_time64_gmt(const gchar *)
The gnc_iso8601_to_time64_gmt() routine converts an ISO-8601 style date/time string to time64...
size_t qof_print_date_dmy_buff(gchar *buff, size_t buflen, int day, int month, int year)
qof_print_date_dmy_buff Convert a date as day / month / year integers into a localized string represe...
gsize qof_strftime(gchar *buf, gsize max, const gchar *format, const struct tm *tm)
qof_strftime calls qof_format_time to print a given time and afterwards tries to put the result into ...
Definition: gnc-date.cpp:1056
Used by the check printing code.
Definition: gnc-date.h:130
gchar dateSeparator(void)
dateSeparator Return the field separator for the current date format
Definition: gnc-date.cpp:926
gboolean gnc_date_string_to_monthformat(const gchar *format_string, GNCDateMonthFormat *format)
Converts the month format to a printable string.
time64 gnc_dmy2time64_neutral(gint day, gint month, gint year)
Converts a day, month, and year to a time64 representing 11:00:00 UTC 11:00:00 UTC falls on the same ...
void gnc_gdate_set_fiscal_year_end(GDate *date, const GDate *year_end)
This function modifies a GDate to set it to the last day of the fiscal year in which it falls...
Definition: gnc-date.cpp:1604
const gchar * gnc_date_dateformat_to_string(QofDateFormat format)
The string->value versions return FALSE on success and TRUE on failure.
Definition: gnc-date.cpp:280
char * gnc_date_timestamp(void)
Make a timestamp in YYYYMMDDHHMMSS format.
Definition: gnc-date.cpp:1101
QofDateCompletion
Enum for date completion modes (for dates entered without year)
Definition: gnc-date.h:138
gint gnc_gdate_equal(gconstpointer gda, gconstpointer gdb)
Compares two GDate*&#39;s for equality; useful for using GDate*&#39;s as GHashTable keys. ...
Definition: gnc-date.cpp:1401
Continental Europe: dd.mm.yyyy.
Definition: gnc-date.h:126
guint gnc_gdate_hash(gconstpointer gd)
Provides a "hash" of a GDate* value; useful for using GDate*&#39;s as GHashTable keys.
Definition: gnc-date.cpp:1407
void gnc_gdate_set_quarter_start(GDate *date)
This function modifies a GDate to set it to the first day of the quarter in which it falls...
Definition: gnc-date.cpp:1509
size_t qof_print_gdate(char *buf, size_t bufflen, const GDate *gd)
Convenience; calls through to qof_print_date_dmy_buff().
Definition: gnc-date.cpp:597
size_t qof_print_date_time_buff(char *buff, size_t len, time64 secs)
Returns the number of bytes printed.
No Fancy Date Format, use Global.
Definition: gnc-date.h:131
time64 gnc_dmy2time64(gint day, gint month, gint year)
Convert a day, month, and year to a time64, returning the first second of the day.
void gnc_gdate_set_today(GDate *gd)
Set a GDate to the current day.
Definition: gnc-date.cpp:1236
GDate time64_to_gdate(time64 t)
Returns the GDate in which the time64 occurs.
Definition: gnc-date.cpp:1211
void gnc_gdate_set_prev_month_end(GDate *date)
This function modifies a GDate to set it to the last day of the month prior to the one in which it fa...
Definition: gnc-date.cpp:1499
void gnc_tm_get_today_start(struct tm *tm)
The gnc_tm_get_today_start() routine takes a pointer to a struct tm and fills it in with the first se...
Definition: gnc-date.cpp:1329
int gnc_date_get_last_mday(int month, int year)
Get the numerical last date of the month.
Definition: gnc-date.cpp:412
const char * gnc_default_strftime_date_format
The default date format for use with strftime.
Definition: gnc-date.cpp:73
void qof_date_completion_set(QofDateCompletion dc, int backmonths)
The qof_date_completion_set() routing sets the date completion method to one of QOF_DATE_COMPLETION_T...
Definition: gnc-date.cpp:467
struct tm * gnc_localtime_r(const time64 *secs, struct tm *time)
fill out a time struct from a 64-bit time value adjusted for the current time zone.
Definition: gnc-date.cpp:114
void gnc_tm_get_today_neutral(struct tm *tm)
The gnc_tm_get_today_start() routine takes a pointer to a struct tm and fills it in with the timezone...
Definition: gnc-date.cpp:1335
void gnc_tm_free(struct tm *time)
free a struct tm* created with gnc_localtime() or gnc_gmtime()
Definition: gnc-date.cpp:96
QofDateFormat qof_date_format_get(void)
The qof_date_format_get routine returns the date format that the date printing will use when printing...
Definition: gnc-date.cpp:427
use sliding 12-month window
Definition: gnc-date.h:141
char * qof_print_date(time64 secs)
Convenience; calls through to qof_print_date_dmy_buff().
Definition: gnc-date.cpp:609
void gnc_gdate_set_prev_year_end(GDate *date)
This function modifies a GDate to set it to the last day of the year prior to the one in which it fal...
Definition: gnc-date.cpp:1571
void gnc_gdate_set_prev_year_start(GDate *date)
This function modifies a GDate to set it to the first day of the year prior to the one in which it fa...
Definition: gnc-date.cpp:1564
char * gnc_print_time64(time64 time, const char *format)
print a time64 as a date string per format
Definition: gnc-date.cpp:369
time64 gnc_time64_get_day_start(time64 time_val)
The gnc_time64_get_day_start() routine will take the given time in seconds and adjust it to the first...
Definition: gnc-date.cpp:1296
void gnc_dow_abbrev(gchar *buf, int buf_len, int dow)
Localized DOW abbreviation.
Definition: gnc-date.cpp:1365
UTC: 2004-12-12T23:39:11Z.
Definition: gnc-date.h:129
time64 gnc_time64_get_today_start(void)
The gnc_time64_get_today_start() routine returns a time64 value corresponding to the first second of ...
Definition: gnc-date.cpp:1347
time64 gnc_mktime(struct tm *time)
calculate seconds from the epoch given a time struct
Definition: gnc-date.cpp:218
time64 gdate_to_time64(GDate d)
Turns a GDate into a time64, returning the first second of the day.
Definition: gnc-date.cpp:1253
GNCDateMonthFormat
This is how to format the month, as a number, an abbreviated string, or the full name.
Definition: gnc-date.h:148
time64 gnc_timegm(struct tm *time)
calculate seconds from the epoch given a time struct
Definition: gnc-date.cpp:234
void gnc_gdate_set_month_start(GDate *date)
This function modifies a GDate to set it to the first day of the month in which it falls...
Definition: gnc-date.cpp:1454
struct tm * gnc_localtime(const time64 *secs)
fill out a time struct from a 64-bit time value.
Definition: gnc-date.cpp:102
void gnc_gdate_set_prev_fiscal_year_end(GDate *date, const GDate *year_end)
This function modifies a GDate to set it to the last day of the fiscal year prior to the one in which...
Definition: gnc-date.cpp:1638
gdouble gnc_difftime(const time64 secs1, const time64 secs2)
Find the difference in seconds between two time values (deprecated)
Definition: gnc-date.cpp:271
void gnc_gdate_set_fiscal_year_start(GDate *date, const GDate *year_end)
This function modifies a GDate to set it to the first day of the fiscal year in which it falls...
Definition: gnc-date.cpp:1580
void gnc_gdate_set_year_end(GDate *date)
This function modifies a GDate to set it to the last day of the year in which it falls.
Definition: gnc-date.cpp:1557
const gchar * qof_date_text_format_get_string(QofDateFormat df)
This function returns a strftime formatting string for printing a date using words and numbers (e...
Definition: gnc-date.cpp:524
gboolean qof_scan_date(const char *buff, int *day, int *month, int *year)
qof_scan_date Convert a string into day / month / year integers according to the current dateFormat v...
Definition: gnc-date.cpp:918
void gnc_gdate_set_time64(GDate *gd, time64 time)
Set a GDate to a time64.
Definition: gnc-date.cpp:1244
void gnc_gdate_set_month_end(GDate *date)
This function modifies a GDate to set it to the last day of the month in which it falls...
Definition: gnc-date.cpp:1467
time64 gnc_time64_get_day_end_gdate(const GDate *date)
The gnc_time64_get_day_end() routine will take the given time in GLib GDate format and adjust it to t...
Definition: gnc-date.cpp:1432
time64 gnc_dmy2time64_end(gint day, gint month, gint year)
Same as gnc_dmy2time64, but last second of the day.
void gnc_gdate_set_prev_fiscal_year_start(GDate *date, const GDate *year_end)
This function modifies a GDate to set it to the first day of the fiscal year prior to the one in whic...
Definition: gnc-date.cpp:1627
void gnc_gdate_set_quarter_end(GDate *date)
This function modifies a GDate to set it to the last day of the quarter in which it falls...
Definition: gnc-date.cpp:1522
time64 gnc_time64_get_today_end(void)
The gnc_time64_get_today_end() routine returns a time64 value corresponding to the last second of tod...
Definition: gnc-date.cpp:1356
struct tm * gnc_gmtime(const time64 *secs)
fill out a time struct from a 64-bit time value
Definition: gnc-date.cpp:177
time64 gnc_time(time64 *tbuf)
get the current time
Definition: gnc-date.cpp:261
gint64 time64
Most systems that are currently maintained, including Microsoft Windows, BSD-derived Unixes and Linux...
Definition: gnc-date.h:87
void gnc_gdate_set_prev_quarter_end(GDate *date)
This function modifies a GDate to set it to the last day of the quarter prior to the one in which it ...
Definition: gnc-date.cpp:1541
use current year
Definition: gnc-date.h:140
gchar * gnc_ctime(const time64 *secs)
Return a string representation of a date from a 64-bit time value.
Definition: gnc-date.cpp:255
time64 gnc_time64_get_day_end(time64 time_val)
The gnc_time64_get_day_end() routine will take the given time in seconds and adjust it to the last se...
Definition: gnc-date.cpp:1316
Take from locale information.
Definition: gnc-date.h:128
void qof_date_format_set(QofDateFormat df)
The qof_date_format_set() routine sets date format to one of US, UK, CE, OR ISO.
Definition: gnc-date.cpp:432
time64 time64CanonicalDayTime(time64 t)
convert a time64 on a certain day (localtime) to the time64 representing midday on that day...
Definition: gnc-date.cpp:403
void gnc_tm_get_today_end(struct tm *tm)
The gnc_tm_get_today_end() routine takes a pointer to a struct tm and fills it in with the last secon...
Definition: gnc-date.cpp:1341
Britain: dd/mm/yyyy.
Definition: gnc-date.h:125
void gnc_tm_set_day_neutral(struct tm *tm)
The gnc_tm_set_day_neutral() inline routine will set the appropriate fields in the struct tm to indic...
Definition: gnc-date.cpp:1270
gboolean gnc_date_string_to_dateformat(const gchar *format_string, QofDateFormat *format)
Converts the date format to a printable string.
const gchar * qof_date_format_get_string(QofDateFormat df)
This function returns a strftime formatting string for printing an all numeric date (e...
Definition: gnc-date.cpp:501
time64 gnc_time64_get_day_start_gdate(const GDate *date)
The gnc_time64_get_day_start() routine will take the given time in GLib GDate format and adjust it to...
Definition: gnc-date.cpp:1418
gchar * gnc_time64_to_iso8601_buff(time64, char *buff)
The gnc_time64_to_iso8601_buff() routine takes the input UTC time64 value and prints it as an ISO-860...
Definition: gnc-date.cpp:1140
QofDateFormat
Enum for determining a date format.
Definition: gnc-date.h:122
United states: mm/dd/yyyy.
Definition: gnc-date.h:124
void gnc_gdate_set_prev_quarter_start(GDate *date)
This function modifies a GDate to set it to the first day of the quarter prior to the one in which it...
Definition: gnc-date.cpp:1534
gint gnc_start_of_week(void)
returns an integer corresponding to locale start of week
Definition: gnc-date.cpp:194
void gnc_gdate_set_year_start(GDate *date)
This function modifies a GDate to set it to the first day of the year in which it falls...
Definition: gnc-date.cpp:1550
size_t qof_print_date_buff(char *buff, size_t buflen, time64 secs)
Convenience: calls through to qof_print_date_dmy_buff().
Definition: gnc-date.cpp:573
time64 gnc_time64_get_day_neutral(time64 time_val)
The gnc_time64_get_day_neutral() routine will take the given time in seconds and adjust it to 10:59:0...
Definition: gnc-date.cpp:1307
GDate * gnc_g_date_new_today(void)
Returns a newly allocated date of the current clock time, taken from time(2).
Definition: gnc-date.cpp:1225
void gnc_gdate_set_prev_month_start(GDate *date)
This function modifies a GDate to set it to the first day of the month prior to the one in which it f...
Definition: gnc-date.cpp:1485