LCOV - code coverage report
Current view: top level - src - gettime.h (source / functions) Hit Total Coverage
Test: report Lines: 5 5 100.0 %
Date: 2015-07-11 18:23:49 Functions: 1 1 100.0 %

          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

Generated by: LCOV version 1.11