ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/deliantra/server/common/logger.C
Revision: 1.14
Committed: Sat Jun 9 23:18:17 2007 UTC (17 years ago) by root
Content type: text/plain
Branch: MAIN
Changes since 1.13: +11 -11 lines
Log Message:
- use less stackspace for logging
- do not copy logging message.
- less overhead for stderr logging
  (should really log asynchronously).
- force a trailing \n on log messages.
- log in 0.1ms granularity (might be overkill).

File Contents

# Content
1 /*
2 * This file is part of Crossfire TRT, the Multiplayer Online Role Playing Game.
3 *
4 * 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 *
8 * 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 *
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 *
18 * 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 */
24
25 #include <cstdarg>
26 #include <global.h>
27 #include <funcpoint.h>
28
29 void
30 LOG (int flags, const char *format, ...)
31 {
32 int level = flags & 15;
33
34 if (level > settings.debug)
35 return;
36
37 char buf[20480];
38
39 struct timeval tv;
40 gettimeofday (&tv, 0);
41 struct tm *ptime = localtime (&tv.tv_sec);
42
43 int len = strftime (buf, sizeof (buf) - 7, "%Y-%m-%d %H:%M:%S", ptime);
44 len += sprintf (buf + len, ".%04d ", (int)(tv.tv_usec / 100));
45
46 va_list ap;
47 va_start (ap, format);
48 len += vsnprintf (buf + len, sizeof (buf) - len, format, ap);
49 va_end (ap);
50
51 len = min (sizeof (buf) - 1, len);
52
53 if (buf [len - 1] != '\n')
54 buf [len++] = '\n'; // not 0-terminated
55
56 write (STDERR_FILENO, buf, len);
57 if (logfile != stderr)
58 fwrite (buf, 1, len, logfile);
59
60 if (flags & logBacktrace)
61 log_backtrace (buf);
62 }