Coverage Report

Created: 2025-08-03 06:43

/src/tarantool/third_party/c-dt/dt_tm.c
Line
Count
Source (jump to first uncovered line)
1
/*
2
 * Copyright (c) 2012-2015 Christian Hansen <chansen@cpan.org>
3
 * <https://github.com/chansen/c-dt>
4
 * All rights reserved.
5
 * 
6
 * Redistribution and use in source and binary forms, with or without
7
 * modification, are permitted provided that the following conditions are met: 
8
 * 
9
 * 1. Redistributions of source code must retain the above copyright notice, this
10
 *    list of conditions and the following disclaimer. 
11
 * 2. Redistributions in binary form must reproduce the above copyright notice,
12
 *    this list of conditions and the following disclaimer in the documentation
13
 *    and/or other materials provided with the distribution. 
14
 * 
15
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
16
 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
17
 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
18
 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR
19
 * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
20
 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
21
 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
22
 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
23
 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
24
 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
25
 */
26
#include "dt_core.h"
27
#include "dt_tm.h"
28
29
dt_t
30
0
dt_from_struct_tm(const struct tm *tm) {
31
0
    return dt_from_ymd(tm->tm_year + 1900, tm->tm_mon + 1, tm->tm_mday);
32
0
}
33
34
void
35
2.88k
dt_to_struct_tm(dt_t dt, struct tm *tm) {
36
2.88k
    int y, m, d;
37
38
2.88k
    dt_to_ymd(dt, &y, &m, &d);
39
2.88k
    tm->tm_year = y - 1900;
40
2.88k
    tm->tm_mon  = m - 1;                    /* [0=Jan, 11=Dec] */
41
2.88k
    tm->tm_mday = d;
42
2.88k
    tm->tm_wday = dt_dow(dt) % 7;           /* [0=Sun, 6=Sat] */
43
2.88k
    tm->tm_yday = dt - dt_from_yd(y, 1);    /* [0, 365] */
44
2.88k
}
45