date_time.h
Go to the documentation of this file.
1 /**
2  * @file date_time.h
3  * @brief Date and time management
4  *
5  * @section License
6  *
7  * SPDX-License-Identifier: GPL-2.0-or-later
8  *
9  * Copyright (C) 2010-2025 Oryx Embedded SARL. All rights reserved.
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
13  * as published by the Free Software Foundation; either version 2
14  * of 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, write to the Free Software Foundation,
23  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
24  *
25  * @author Oryx Embedded SARL (www.oryx-embedded.com)
26  * @version 2.5.4
27  **/
28 
29 #ifndef _DATE_TIME_H
30 #define _DATE_TIME_H
31 
32 //Dependencies
33 #include <time.h>
34 #include "os_port.h"
35 
36 //C++ guard
37 #ifdef __cplusplus
38 extern "C" {
39 #endif
40 
41 
42 /**
43  * @brief 64-bit time representation
44  **/
45 
46 typedef int64_t time64_t;
47 
48 
49 /**
50  * @brief Date and time representation
51  **/
52 
53 typedef struct
54 {
55  uint16_t year;
56  uint8_t month;
57  uint8_t day;
58  uint8_t dayOfWeek;
59  uint8_t hours;
60  uint8_t minutes;
61  uint8_t seconds;
62  uint16_t milliseconds;
63 } DateTime;
64 
65 
66 //Date and time management
68 const char_t *formatDate(const DateTime *date, char_t *str);
69 
70 void getCurrentDate(DateTime *date);
71 time_t getCurrentUnixTime(void);
72 
73 void convertUnixTimeToDate(time_t t, DateTime *date);
75 
76 time_t convertDateToUnixTime(const DateTime *date);
78 
79 int_t compareDateTime(const DateTime *date1, const DateTime *date2);
80 
81 uint8_t computeDayOfWeek(uint16_t y, uint8_t m, uint8_t d);
82 
83 //C++ guard
84 #ifdef __cplusplus
85 }
86 #endif
87 
88 #endif
time64_t convertDateToUnixTime64(const DateTime *date)
Convert date to 64-bit Unix timestamp.
Definition: date_time.c:371
signed int int_t
Definition: compiler_port.h:56
uint16_t year
Definition: date_time.h:55
uint8_t t
Definition: lldp_ext_med.h:212
void convertUnixTimeToDate64(time64_t t, DateTime *date)
Convert 64-bit Unix timestamp to date.
Definition: date_time.c:266
void getCurrentDate(DateTime *date)
Get current date and time.
Definition: date_time.c:169
time_t getCurrentUnixTime(void)
Get current time.
Definition: date_time.c:186
int64_t time64_t
64-bit time representation
Definition: date_time.h:46
uint8_t day
Definition: date_time.h:57
const char_t * formatSystemTime(systime_t time, char_t *str)
Format system time.
Definition: date_time.c:77
void convertUnixTimeToDate(time_t t, DateTime *date)
Convert Unix timestamp to date.
Definition: date_time.c:204
uint8_t minutes
Definition: date_time.h:60
uint8_t hours
Definition: date_time.h:59
Date and time representation.
Definition: date_time.h:54
const char_t * formatDate(const DateTime *date, char_t *str)
Format date.
Definition: date_time.c:135
uint8_t seconds
Definition: date_time.h:61
uint32_t systime_t
System time.
uint8_t month
Definition: date_time.h:56
char char_t
Definition: compiler_port.h:55
uint8_t computeDayOfWeek(uint16_t y, uint8_t m, uint8_t d)
Calculate day of week.
Definition: date_time.c:494
uint32_t time
uint8_t m
Definition: ndp.h:304
time_t convertDateToUnixTime(const DateTime *date)
Convert date to Unix timestamp.
Definition: date_time.c:328
uint16_t milliseconds
Definition: date_time.h:62
int_t compareDateTime(const DateTime *date1, const DateTime *date2)
Compare dates.
Definition: date_time.c:415
uint8_t dayOfWeek
Definition: date_time.h:58
RTOS abstraction layer.