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

# 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 root 1.14 char buf[20480];
38 root 1.12
39     struct timeval tv;
40     gettimeofday (&tv, 0);
41     struct tm *ptime = localtime (&tv.tv_sec);
42    
43 root 1.14 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 root 1.12
46     va_list ap;
47     va_start (ap, format);
48 root 1.14 len += vsnprintf (buf + len, sizeof (buf) - len, format, ap);
49 root 1.12 va_end (ap);
50    
51 root 1.14 len = min (sizeof (buf) - 1, len);
52 root 1.12
53 root 1.14 if (buf [len - 1] != '\n')
54     buf [len++] = '\n'; // not 0-terminated
55    
56     write (STDERR_FILENO, buf, len);
57 root 1.12 if (logfile != stderr)
58 root 1.14 fwrite (buf, 1, len, logfile);
59 root 1.12
60     if (flags & logBacktrace)
61 root 1.14 log_backtrace (buf);
62 elmex 1.1 }