/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 | | |