Line data Source code
1 : /*
2 : Minetest
3 : Copyright (C) 2013 celeron55, Perttu Ahola <celeron55@gmail.com>
4 :
5 : This program is free software; you can redistribute it and/or modify
6 : it under the terms of the GNU Lesser General Public License as published by
7 : the Free Software Foundation; either version 2.1 of the License, or
8 : (at your option) any later version.
9 :
10 : This program is distributed in the hope that it will be useful,
11 : but WITHOUT ANY WARRANTY; without even the implied warranty of
12 : MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 : GNU Lesser General Public License for more details.
14 :
15 : You should have received a copy of the GNU Lesser General Public License along
16 : with this program; if not, write to the Free Software Foundation, Inc.,
17 : 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
18 : */
19 :
20 : #ifndef GETTIME_HEADER
21 : #define GETTIME_HEADER
22 :
23 : #include "irrlichttypes.h"
24 :
25 : /*
26 : Get a millisecond counter value.
27 : Precision depends on implementation.
28 : Overflows at any value above 10000000.
29 :
30 : Implementation of this is done in:
31 : Normal build: main.cpp
32 : Server build: servermain.cpp
33 : */
34 : enum TimePrecision {
35 : PRECISION_SECONDS = 0,
36 : PRECISION_MILLI,
37 : PRECISION_MICRO,
38 : PRECISION_NANO
39 : };
40 :
41 : extern u32 getTimeMs();
42 : extern u32 getTime(TimePrecision prec);
43 :
44 : /*
45 : Timestamp stuff
46 : */
47 :
48 : #include <time.h>
49 : #include <string>
50 :
51 47502 : inline std::string getTimestamp()
52 : {
53 47502 : time_t t = time(NULL);
54 : // This is not really thread-safe but it won't break anything
55 : // except its own output, so just go with it.
56 47502 : struct tm *tm = localtime(&t);
57 : char cs[20]; //YYYY-MM-DD HH:MM:SS + '\0'
58 47502 : strftime(cs, 20, "%Y-%m-%d %H:%M:%S", tm);
59 47502 : return cs;
60 : }
61 :
62 :
63 : #endif
|