ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/deliantra/server/common/logger.C
Revision: 1.13
Committed: Mon May 28 21:21:40 2007 UTC (16 years, 11 months ago) by root
Content type: text/plain
Branch: MAIN
Changes since 1.12: +17 -17 lines
Log Message:
update copyrights in common/*.C and util/*.C

File Contents

# User Rev Content
1 elmex 1.1 /*
2 root 1.13 * This file is part of Crossfire TRT, the Multiplayer Online Role Playing Game.
3 pippijn 1.11 *
4 root 1.13 * Copyright (©) 2005,2006,2007 Marc Alexander Lehmann / Robin Redeker / the Crossfire TRT team
5     * Copyright (©) 2002,2007 Mark Wedel & Crossfire Development Team
6     * Copyright (©) 1992,2007 Frank Tore Johansen
7 pippijn 1.11 *
8 root 1.13 * Crossfire TRT is free software; you can redistribute it and/or modify it
9     * under the terms of the GNU General Public License as published by the Free
10     * Software Foundation; either version 2 of the License, or (at your option)
11     * any later version.
12 pippijn 1.11 *
13 root 1.13 * This program is distributed in the hope that it will be useful, but
14     * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
15     * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
16     * for more details.
17 pippijn 1.11 *
18 root 1.13 * You should have received a copy of the GNU General Public License along
19     * with Crossfire TRT; if not, write to the Free Software Foundation, Inc. 51
20     * Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
21     *
22     * The authors can be reached via e-mail to <crossfire@schmorp.de>
23 pippijn 1.11 */
24 elmex 1.1
25 root 1.12 #include <cstdarg>
26 elmex 1.1 #include <global.h>
27     #include <funcpoint.h>
28    
29 root 1.4 void
30 root 1.12 LOG (int flags, const char *format, ...)
31 elmex 1.1 {
32 root 1.12 int level = flags & 15;
33    
34     if (level > settings.debug)
35     return;
36    
37     char msec[20];
38     char buf[20460];
39     char tbuf[20480];
40    
41     struct timeval tv;
42     gettimeofday (&tv, 0);
43     struct tm *ptime = localtime (&tv.tv_sec);
44    
45     strftime (tbuf, sizeof (tbuf), "%Y-%m-%d %H:%M:%S", ptime);
46     sprintf (msec, ".%03d ", (int)(tv.tv_usec / 1000));
47    
48     va_list ap;
49     va_start (ap, format);
50     vsnprintf (buf, sizeof (buf), format, ap);
51     va_end (ap);
52    
53     strncat (tbuf, msec, sizeof (tbuf));
54     strncat (tbuf, buf, sizeof (tbuf));
55    
56     fputs (tbuf, logfile);
57     if (logfile != stderr)
58     fputs (tbuf, stderr);
59    
60     if (flags & logBacktrace)
61     log_backtrace (tbuf);
62 elmex 1.1 }