author | glx |
Sat, 17 May 2008 22:52:51 +0000 | |
changeset 9284 | e2987a51f382 |
parent 9111 | 48ce04029fe4 |
child 9336 | 6baad5b3033d |
permissions | -rw-r--r-- |
2186 | 1 |
/* $Id$ */ |
2 |
||
9111
48ce04029fe4
(svn r12971) -Documentation: add @file in files that missed them and add something more than whitespace as description of files that don't have a description.
rubidium
parents:
8409
diff
changeset
|
3 |
/** @file debug.cpp Handling of printing debug messages. */ |
6125
a6fff965707c
(svn r8862) -Cleanup: doxygen changes, again. Mostly @files missing tags and a few comments style.
belugas
parents:
5959
diff
changeset
|
4 |
|
1302 | 5 |
#include "stdafx.h" |
6 |
#include <stdio.h> |
|
1299 | 7 |
#include <stdarg.h> |
1891
862800791170
(svn r2397) - CodeChange: rename all "ttd" files to "openttd" files.
Darkvater
parents:
1847
diff
changeset
|
8 |
#include "openttd.h" |
1299 | 9 |
#include "console.h" |
10 |
#include "debug.h" |
|
8214
971f861d5543
(svn r11777) -Codechange: split the string header and make do not include it when it's not necessary.
rubidium
parents:
8192
diff
changeset
|
11 |
#include "string_func.h" |
5959
98a64c6e7f1f
(svn r8631) -Add: added parameter -l ip[:port] to ./openttd, which redirects DEBUG() to a remote connection over TCP
truelight
parents:
5664
diff
changeset
|
12 |
#include "network/core/core.h" |
98a64c6e7f1f
(svn r8631) -Add: added parameter -l ip[:port] to ./openttd, which redirects DEBUG() to a remote connection over TCP
truelight
parents:
5664
diff
changeset
|
13 |
|
98a64c6e7f1f
(svn r8631) -Add: added parameter -l ip[:port] to ./openttd, which redirects DEBUG() to a remote connection over TCP
truelight
parents:
5664
diff
changeset
|
14 |
#if defined(ENABLE_NETWORK) |
98a64c6e7f1f
(svn r8631) -Add: added parameter -l ip[:port] to ./openttd, which redirects DEBUG() to a remote connection over TCP
truelight
parents:
5664
diff
changeset
|
15 |
SOCKET _debug_socket = INVALID_SOCKET; |
98a64c6e7f1f
(svn r8631) -Add: added parameter -l ip[:port] to ./openttd, which redirects DEBUG() to a remote connection over TCP
truelight
parents:
5664
diff
changeset
|
16 |
#endif /* ENABLE_NETWORK */ |
1299 | 17 |
|
18 |
int _debug_ai_level; |
|
2210
b76184e0929c
(svn r2728) -Fix/Feature: Change the driver probing algorithm
tron
parents:
2186
diff
changeset
|
19 |
int _debug_driver_level; |
1299 | 20 |
int _debug_grf_level; |
21 |
int _debug_map_level; |
|
22 |
int _debug_misc_level; |
|
23 |
int _debug_ms_level; |
|
24 |
int _debug_net_level; |
|
5380
8ea58542b6e0
(svn r7565) -Codechange: Rework DEBUG functionality. Look for appropiate debugging levels to
Darkvater
parents:
5108
diff
changeset
|
25 |
int _debug_sprite_level; |
1322
a7fef520f54c
(svn r1826) -Feature: a brand new OldLoader so OpenTTD is TTD(Patch) compatible
truelight
parents:
1302
diff
changeset
|
26 |
int _debug_oldloader_level; |
2125
edc17858f9f6
(svn r2635) Fix: [ntp/misc] Improve the old pathfinder. Changed it to A* instead of Dijkstra.
ludde
parents:
2066
diff
changeset
|
27 |
int _debug_ntp_level; |
1678
187385f01cc9
(svn r2182) - Add: [NPF] There is now a debug class for NPF. Use -d npf<level> to enable debugging printouts from npf.
matthijs
parents:
1322
diff
changeset
|
28 |
int _debug_npf_level; |
3900
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
2916
diff
changeset
|
29 |
int _debug_yapf_level; |
5108
aeaef6fe53b7
(svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents:
3900
diff
changeset
|
30 |
int _debug_freetype_level; |
5380
8ea58542b6e0
(svn r7565) -Codechange: Rework DEBUG functionality. Look for appropiate debugging levels to
Darkvater
parents:
5108
diff
changeset
|
31 |
int _debug_sl_level; |
5664 | 32 |
int _debug_station_level; |
1299 | 33 |
|
34 |
||
6248
e4a2ed7e5613
(svn r9051) -Codechange: typedef [enum|struct] Y {} X; -> [enum|struct] X {};
rubidium
parents:
6247
diff
changeset
|
35 |
struct DebugLevel { |
1847
d94ed71b61e7
(svn r2352) - Feature: add the possibility to print out the current debug-level
Darkvater
parents:
1678
diff
changeset
|
36 |
const char *name; |
d94ed71b61e7
(svn r2352) - Feature: add the possibility to print out the current debug-level
Darkvater
parents:
1678
diff
changeset
|
37 |
int *level; |
6248
e4a2ed7e5613
(svn r9051) -Codechange: typedef [enum|struct] Y {} X; -> [enum|struct] X {};
rubidium
parents:
6247
diff
changeset
|
38 |
}; |
1847
d94ed71b61e7
(svn r2352) - Feature: add the possibility to print out the current debug-level
Darkvater
parents:
1678
diff
changeset
|
39 |
|
d94ed71b61e7
(svn r2352) - Feature: add the possibility to print out the current debug-level
Darkvater
parents:
1678
diff
changeset
|
40 |
#define DEBUG_LEVEL(x) { #x, &_debug_##x##_level } |
d94ed71b61e7
(svn r2352) - Feature: add the possibility to print out the current debug-level
Darkvater
parents:
1678
diff
changeset
|
41 |
static const DebugLevel debug_level[] = { |
d94ed71b61e7
(svn r2352) - Feature: add the possibility to print out the current debug-level
Darkvater
parents:
1678
diff
changeset
|
42 |
DEBUG_LEVEL(ai), |
2210
b76184e0929c
(svn r2728) -Fix/Feature: Change the driver probing algorithm
tron
parents:
2186
diff
changeset
|
43 |
DEBUG_LEVEL(driver), |
1847
d94ed71b61e7
(svn r2352) - Feature: add the possibility to print out the current debug-level
Darkvater
parents:
1678
diff
changeset
|
44 |
DEBUG_LEVEL(grf), |
d94ed71b61e7
(svn r2352) - Feature: add the possibility to print out the current debug-level
Darkvater
parents:
1678
diff
changeset
|
45 |
DEBUG_LEVEL(map), |
d94ed71b61e7
(svn r2352) - Feature: add the possibility to print out the current debug-level
Darkvater
parents:
1678
diff
changeset
|
46 |
DEBUG_LEVEL(misc), |
d94ed71b61e7
(svn r2352) - Feature: add the possibility to print out the current debug-level
Darkvater
parents:
1678
diff
changeset
|
47 |
DEBUG_LEVEL(ms), |
d94ed71b61e7
(svn r2352) - Feature: add the possibility to print out the current debug-level
Darkvater
parents:
1678
diff
changeset
|
48 |
DEBUG_LEVEL(net), |
5380
8ea58542b6e0
(svn r7565) -Codechange: Rework DEBUG functionality. Look for appropiate debugging levels to
Darkvater
parents:
5108
diff
changeset
|
49 |
DEBUG_LEVEL(sprite), |
1847
d94ed71b61e7
(svn r2352) - Feature: add the possibility to print out the current debug-level
Darkvater
parents:
1678
diff
changeset
|
50 |
DEBUG_LEVEL(oldloader), |
2125
edc17858f9f6
(svn r2635) Fix: [ntp/misc] Improve the old pathfinder. Changed it to A* instead of Dijkstra.
ludde
parents:
2066
diff
changeset
|
51 |
DEBUG_LEVEL(ntp), |
3900
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
2916
diff
changeset
|
52 |
DEBUG_LEVEL(npf), |
5108
aeaef6fe53b7
(svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents:
3900
diff
changeset
|
53 |
DEBUG_LEVEL(yapf), |
5380
8ea58542b6e0
(svn r7565) -Codechange: Rework DEBUG functionality. Look for appropiate debugging levels to
Darkvater
parents:
5108
diff
changeset
|
54 |
DEBUG_LEVEL(freetype), |
8ea58542b6e0
(svn r7565) -Codechange: Rework DEBUG functionality. Look for appropiate debugging levels to
Darkvater
parents:
5108
diff
changeset
|
55 |
DEBUG_LEVEL(sl), |
5664 | 56 |
DEBUG_LEVEL(station), |
1847
d94ed71b61e7
(svn r2352) - Feature: add the possibility to print out the current debug-level
Darkvater
parents:
1678
diff
changeset
|
57 |
}; |
d94ed71b61e7
(svn r2352) - Feature: add the possibility to print out the current debug-level
Darkvater
parents:
1678
diff
changeset
|
58 |
#undef DEBUG_LEVEL |
1299 | 59 |
|
5406
2df85542fee4
(svn r7602) -Fix (r7565): MSVC2003 and lower don't support variadic macros, so work around
Darkvater
parents:
5380
diff
changeset
|
60 |
#if !defined(NO_DEBUG_MESSAGES) |
2df85542fee4
(svn r7602) -Fix (r7565): MSVC2003 and lower don't support variadic macros, so work around
Darkvater
parents:
5380
diff
changeset
|
61 |
|
2df85542fee4
(svn r7602) -Fix (r7565): MSVC2003 and lower don't support variadic macros, so work around
Darkvater
parents:
5380
diff
changeset
|
62 |
void CDECL debug(const char *dbg, ...) |
2df85542fee4
(svn r7602) -Fix (r7565): MSVC2003 and lower don't support variadic macros, so work around
Darkvater
parents:
5380
diff
changeset
|
63 |
{ |
2df85542fee4
(svn r7602) -Fix (r7565): MSVC2003 and lower don't support variadic macros, so work around
Darkvater
parents:
5380
diff
changeset
|
64 |
va_list va; |
2df85542fee4
(svn r7602) -Fix (r7565): MSVC2003 and lower don't support variadic macros, so work around
Darkvater
parents:
5380
diff
changeset
|
65 |
va_start(va, dbg); |
8409
de295d5e2bb4
(svn r11979) -Codechange: drop MSVC 2003 support because MSVC 2003 is broken in such a manner that it triggers an internal compiler error without any clue what of the code is wrong. Even trying to bisect the problem does not give a single line of code that causes the trouble.
rubidium
parents:
8247
diff
changeset
|
66 |
const char *s; |
de295d5e2bb4
(svn r11979) -Codechange: drop MSVC 2003 support because MSVC 2003 is broken in such a manner that it triggers an internal compiler error without any clue what of the code is wrong. Even trying to bisect the problem does not give a single line of code that causes the trouble.
rubidium
parents:
8247
diff
changeset
|
67 |
char buf[1024]; |
5959
98a64c6e7f1f
(svn r8631) -Add: added parameter -l ip[:port] to ./openttd, which redirects DEBUG() to a remote connection over TCP
truelight
parents:
5664
diff
changeset
|
68 |
|
8409
de295d5e2bb4
(svn r11979) -Codechange: drop MSVC 2003 support because MSVC 2003 is broken in such a manner that it triggers an internal compiler error without any clue what of the code is wrong. Even trying to bisect the problem does not give a single line of code that causes the trouble.
rubidium
parents:
8247
diff
changeset
|
69 |
s = va_arg(va, const char*); |
de295d5e2bb4
(svn r11979) -Codechange: drop MSVC 2003 support because MSVC 2003 is broken in such a manner that it triggers an internal compiler error without any clue what of the code is wrong. Even trying to bisect the problem does not give a single line of code that causes the trouble.
rubidium
parents:
8247
diff
changeset
|
70 |
vsnprintf(buf, lengthof(buf), s, va); |
de295d5e2bb4
(svn r11979) -Codechange: drop MSVC 2003 support because MSVC 2003 is broken in such a manner that it triggers an internal compiler error without any clue what of the code is wrong. Even trying to bisect the problem does not give a single line of code that causes the trouble.
rubidium
parents:
8247
diff
changeset
|
71 |
va_end(va); |
de295d5e2bb4
(svn r11979) -Codechange: drop MSVC 2003 support because MSVC 2003 is broken in such a manner that it triggers an internal compiler error without any clue what of the code is wrong. Even trying to bisect the problem does not give a single line of code that causes the trouble.
rubidium
parents:
8247
diff
changeset
|
72 |
#if defined(ENABLE_NETWORK) |
de295d5e2bb4
(svn r11979) -Codechange: drop MSVC 2003 support because MSVC 2003 is broken in such a manner that it triggers an internal compiler error without any clue what of the code is wrong. Even trying to bisect the problem does not give a single line of code that causes the trouble.
rubidium
parents:
8247
diff
changeset
|
73 |
if (_debug_socket != INVALID_SOCKET) { |
de295d5e2bb4
(svn r11979) -Codechange: drop MSVC 2003 support because MSVC 2003 is broken in such a manner that it triggers an internal compiler error without any clue what of the code is wrong. Even trying to bisect the problem does not give a single line of code that causes the trouble.
rubidium
parents:
8247
diff
changeset
|
74 |
char buf2[lengthof(buf) + 32]; |
de295d5e2bb4
(svn r11979) -Codechange: drop MSVC 2003 support because MSVC 2003 is broken in such a manner that it triggers an internal compiler error without any clue what of the code is wrong. Even trying to bisect the problem does not give a single line of code that causes the trouble.
rubidium
parents:
8247
diff
changeset
|
75 |
|
de295d5e2bb4
(svn r11979) -Codechange: drop MSVC 2003 support because MSVC 2003 is broken in such a manner that it triggers an internal compiler error without any clue what of the code is wrong. Even trying to bisect the problem does not give a single line of code that causes the trouble.
rubidium
parents:
8247
diff
changeset
|
76 |
snprintf(buf2, lengthof(buf2), "dbg: [%s] %s\n", dbg, buf); |
de295d5e2bb4
(svn r11979) -Codechange: drop MSVC 2003 support because MSVC 2003 is broken in such a manner that it triggers an internal compiler error without any clue what of the code is wrong. Even trying to bisect the problem does not give a single line of code that causes the trouble.
rubidium
parents:
8247
diff
changeset
|
77 |
send(_debug_socket, buf2, strlen(buf2), 0); |
de295d5e2bb4
(svn r11979) -Codechange: drop MSVC 2003 support because MSVC 2003 is broken in such a manner that it triggers an internal compiler error without any clue what of the code is wrong. Even trying to bisect the problem does not give a single line of code that causes the trouble.
rubidium
parents:
8247
diff
changeset
|
78 |
} else |
5959
98a64c6e7f1f
(svn r8631) -Add: added parameter -l ip[:port] to ./openttd, which redirects DEBUG() to a remote connection over TCP
truelight
parents:
5664
diff
changeset
|
79 |
#endif /* ENABLE_NETWORK */ |
8409
de295d5e2bb4
(svn r11979) -Codechange: drop MSVC 2003 support because MSVC 2003 is broken in such a manner that it triggers an internal compiler error without any clue what of the code is wrong. Even trying to bisect the problem does not give a single line of code that causes the trouble.
rubidium
parents:
8247
diff
changeset
|
80 |
{ |
7405
2fd57f130eca
(svn r10778) -Fix: one-liners to allow MSVC and WINCE to work together (or anyway, a step towards that goal)
truelight
parents:
6248
diff
changeset
|
81 |
#if defined(WINCE) |
8409
de295d5e2bb4
(svn r11979) -Codechange: drop MSVC 2003 support because MSVC 2003 is broken in such a manner that it triggers an internal compiler error without any clue what of the code is wrong. Even trying to bisect the problem does not give a single line of code that causes the trouble.
rubidium
parents:
8247
diff
changeset
|
82 |
/* We need to do OTTD2FS twice, but as it uses a static buffer, we need to store one temporary */ |
de295d5e2bb4
(svn r11979) -Codechange: drop MSVC 2003 support because MSVC 2003 is broken in such a manner that it triggers an internal compiler error without any clue what of the code is wrong. Even trying to bisect the problem does not give a single line of code that causes the trouble.
rubidium
parents:
8247
diff
changeset
|
83 |
TCHAR tbuf[512]; |
de295d5e2bb4
(svn r11979) -Codechange: drop MSVC 2003 support because MSVC 2003 is broken in such a manner that it triggers an internal compiler error without any clue what of the code is wrong. Even trying to bisect the problem does not give a single line of code that causes the trouble.
rubidium
parents:
8247
diff
changeset
|
84 |
_sntprintf(tbuf, sizeof(tbuf), _T("%s"), OTTD2FS(dbg)); |
de295d5e2bb4
(svn r11979) -Codechange: drop MSVC 2003 support because MSVC 2003 is broken in such a manner that it triggers an internal compiler error without any clue what of the code is wrong. Even trying to bisect the problem does not give a single line of code that causes the trouble.
rubidium
parents:
8247
diff
changeset
|
85 |
NKDbgPrintfW(_T("dbg: [%s] %s\n"), tbuf, OTTD2FS(buf)); |
7405
2fd57f130eca
(svn r10778) -Fix: one-liners to allow MSVC and WINCE to work together (or anyway, a step towards that goal)
truelight
parents:
6248
diff
changeset
|
86 |
#else |
8409
de295d5e2bb4
(svn r11979) -Codechange: drop MSVC 2003 support because MSVC 2003 is broken in such a manner that it triggers an internal compiler error without any clue what of the code is wrong. Even trying to bisect the problem does not give a single line of code that causes the trouble.
rubidium
parents:
8247
diff
changeset
|
87 |
fprintf(stderr, "dbg: [%s] %s\n", dbg, buf); |
7405
2fd57f130eca
(svn r10778) -Fix: one-liners to allow MSVC and WINCE to work together (or anyway, a step towards that goal)
truelight
parents:
6248
diff
changeset
|
88 |
#endif |
8409
de295d5e2bb4
(svn r11979) -Codechange: drop MSVC 2003 support because MSVC 2003 is broken in such a manner that it triggers an internal compiler error without any clue what of the code is wrong. Even trying to bisect the problem does not give a single line of code that causes the trouble.
rubidium
parents:
8247
diff
changeset
|
89 |
IConsoleDebug(dbg, buf); |
5406
2df85542fee4
(svn r7602) -Fix (r7565): MSVC2003 and lower don't support variadic macros, so work around
Darkvater
parents:
5380
diff
changeset
|
90 |
} |
2df85542fee4
(svn r7602) -Fix (r7565): MSVC2003 and lower don't support variadic macros, so work around
Darkvater
parents:
5380
diff
changeset
|
91 |
} |
2df85542fee4
(svn r7602) -Fix (r7565): MSVC2003 and lower don't support variadic macros, so work around
Darkvater
parents:
5380
diff
changeset
|
92 |
#endif /* NO_DEBUG_MESSAGES */ |
2df85542fee4
(svn r7602) -Fix (r7565): MSVC2003 and lower don't support variadic macros, so work around
Darkvater
parents:
5380
diff
changeset
|
93 |
|
1299 | 94 |
void SetDebugString(const char *s) |
95 |
{ |
|
96 |
int v; |
|
97 |
char *end; |
|
98 |
const char *t; |
|
99 |
||
6125
a6fff965707c
(svn r8862) -Cleanup: doxygen changes, again. Mostly @files missing tags and a few comments style.
belugas
parents:
5959
diff
changeset
|
100 |
/* global debugging level? */ |
1299 | 101 |
if (*s >= '0' && *s <= '9') { |
102 |
const DebugLevel *i; |
|
103 |
||
104 |
v = strtoul(s, &end, 0); |
|
105 |
s = end; |
|
106 |
||
2639 | 107 |
for (i = debug_level; i != endof(debug_level); ++i) *i->level = v; |
1299 | 108 |
} |
109 |
||
6125
a6fff965707c
(svn r8862) -Cleanup: doxygen changes, again. Mostly @files missing tags and a few comments style.
belugas
parents:
5959
diff
changeset
|
110 |
/* individual levels */ |
2639 | 111 |
for (;;) { |
1299 | 112 |
const DebugLevel *i; |
113 |
int *p; |
|
114 |
||
6125
a6fff965707c
(svn r8862) -Cleanup: doxygen changes, again. Mostly @files missing tags and a few comments style.
belugas
parents:
5959
diff
changeset
|
115 |
/* skip delimiters */ |
1299 | 116 |
while (*s == ' ' || *s == ',' || *s == '\t') s++; |
117 |
if (*s == '\0') break; |
|
118 |
||
119 |
t = s; |
|
120 |
while (*s >= 'a' && *s <= 'z') s++; |
|
121 |
||
6125
a6fff965707c
(svn r8862) -Cleanup: doxygen changes, again. Mostly @files missing tags and a few comments style.
belugas
parents:
5959
diff
changeset
|
122 |
/* check debugging levels */ |
1299 | 123 |
p = NULL; |
124 |
for (i = debug_level; i != endof(debug_level); ++i) |
|
125 |
if (s == t + strlen(i->name) && strncmp(t, i->name, s - t) == 0) { |
|
126 |
p = i->level; |
|
127 |
break; |
|
128 |
} |
|
129 |
||
130 |
if (*s == '=') s++; |
|
131 |
v = strtoul(s, &end, 0); |
|
132 |
s = end; |
|
2639 | 133 |
if (p != NULL) { |
1299 | 134 |
*p = v; |
2639 | 135 |
} else { |
1299 | 136 |
ShowInfoF("Unknown debug level '%.*s'", s - t, t); |
137 |
return; |
|
138 |
} |
|
139 |
} |
|
140 |
} |
|
1847
d94ed71b61e7
(svn r2352) - Feature: add the possibility to print out the current debug-level
Darkvater
parents:
1678
diff
changeset
|
141 |
|
d94ed71b61e7
(svn r2352) - Feature: add the possibility to print out the current debug-level
Darkvater
parents:
1678
diff
changeset
|
142 |
/** Print out the current debug-level |
d94ed71b61e7
(svn r2352) - Feature: add the possibility to print out the current debug-level
Darkvater
parents:
1678
diff
changeset
|
143 |
* Just return a string with the values of all the debug categorites |
d94ed71b61e7
(svn r2352) - Feature: add the possibility to print out the current debug-level
Darkvater
parents:
1678
diff
changeset
|
144 |
* @return string with debug-levels |
d94ed71b61e7
(svn r2352) - Feature: add the possibility to print out the current debug-level
Darkvater
parents:
1678
diff
changeset
|
145 |
*/ |
6247 | 146 |
const char *GetDebugString() |
1847
d94ed71b61e7
(svn r2352) - Feature: add the possibility to print out the current debug-level
Darkvater
parents:
1678
diff
changeset
|
147 |
{ |
d94ed71b61e7
(svn r2352) - Feature: add the possibility to print out the current debug-level
Darkvater
parents:
1678
diff
changeset
|
148 |
const DebugLevel *i; |
8192
807098a4e2c1
(svn r11755) -Fix: Debug level string buffer was not long enough to contain all debug levels.
peter1138
parents:
8131
diff
changeset
|
149 |
static char dbgstr[150]; |
1847
d94ed71b61e7
(svn r2352) - Feature: add the possibility to print out the current debug-level
Darkvater
parents:
1678
diff
changeset
|
150 |
char dbgval[20]; |
d94ed71b61e7
(svn r2352) - Feature: add the possibility to print out the current debug-level
Darkvater
parents:
1678
diff
changeset
|
151 |
|
d94ed71b61e7
(svn r2352) - Feature: add the possibility to print out the current debug-level
Darkvater
parents:
1678
diff
changeset
|
152 |
memset(dbgstr, 0, sizeof(dbgstr)); |
d94ed71b61e7
(svn r2352) - Feature: add the possibility to print out the current debug-level
Darkvater
parents:
1678
diff
changeset
|
153 |
i = debug_level; |
d94ed71b61e7
(svn r2352) - Feature: add the possibility to print out the current debug-level
Darkvater
parents:
1678
diff
changeset
|
154 |
snprintf(dbgstr, sizeof(dbgstr), "%s=%d", i->name, *i->level); |
d94ed71b61e7
(svn r2352) - Feature: add the possibility to print out the current debug-level
Darkvater
parents:
1678
diff
changeset
|
155 |
|
d94ed71b61e7
(svn r2352) - Feature: add the possibility to print out the current debug-level
Darkvater
parents:
1678
diff
changeset
|
156 |
for (i++; i != endof(debug_level); i++) { |
d94ed71b61e7
(svn r2352) - Feature: add the possibility to print out the current debug-level
Darkvater
parents:
1678
diff
changeset
|
157 |
snprintf(dbgval, sizeof(dbgval), ", %s=%d", i->name, *i->level); |
d94ed71b61e7
(svn r2352) - Feature: add the possibility to print out the current debug-level
Darkvater
parents:
1678
diff
changeset
|
158 |
ttd_strlcat(dbgstr, dbgval, sizeof(dbgstr)); |
d94ed71b61e7
(svn r2352) - Feature: add the possibility to print out the current debug-level
Darkvater
parents:
1678
diff
changeset
|
159 |
} |
d94ed71b61e7
(svn r2352) - Feature: add the possibility to print out the current debug-level
Darkvater
parents:
1678
diff
changeset
|
160 |
|
d94ed71b61e7
(svn r2352) - Feature: add the possibility to print out the current debug-level
Darkvater
parents:
1678
diff
changeset
|
161 |
return dbgstr; |
d94ed71b61e7
(svn r2352) - Feature: add the possibility to print out the current debug-level
Darkvater
parents:
1678
diff
changeset
|
162 |
} |
8247
16e1c8db6f55
(svn r11811) -Fix: make compilation without networking work again (and thus move the debugdumpcommand stuff out of the network 'area').
rubidium
parents:
8214
diff
changeset
|
163 |
|
16e1c8db6f55
(svn r11811) -Fix: make compilation without networking work again (and thus move the debugdumpcommand stuff out of the network 'area').
rubidium
parents:
8214
diff
changeset
|
164 |
#ifdef DEBUG_DUMP_COMMANDS |
16e1c8db6f55
(svn r11811) -Fix: make compilation without networking work again (and thus move the debugdumpcommand stuff out of the network 'area').
rubidium
parents:
8214
diff
changeset
|
165 |
#include "fileio.h" |
16e1c8db6f55
(svn r11811) -Fix: make compilation without networking work again (and thus move the debugdumpcommand stuff out of the network 'area').
rubidium
parents:
8214
diff
changeset
|
166 |
|
16e1c8db6f55
(svn r11811) -Fix: make compilation without networking work again (and thus move the debugdumpcommand stuff out of the network 'area').
rubidium
parents:
8214
diff
changeset
|
167 |
void CDECL DebugDumpCommands(const char *s, ...) |
16e1c8db6f55
(svn r11811) -Fix: make compilation without networking work again (and thus move the debugdumpcommand stuff out of the network 'area').
rubidium
parents:
8214
diff
changeset
|
168 |
{ |
16e1c8db6f55
(svn r11811) -Fix: make compilation without networking work again (and thus move the debugdumpcommand stuff out of the network 'area').
rubidium
parents:
8214
diff
changeset
|
169 |
static FILE *f = FioFOpenFile("commands-out.log", "wb", AUTOSAVE_DIR); |
16e1c8db6f55
(svn r11811) -Fix: make compilation without networking work again (and thus move the debugdumpcommand stuff out of the network 'area').
rubidium
parents:
8214
diff
changeset
|
170 |
if (f == NULL) return; |
16e1c8db6f55
(svn r11811) -Fix: make compilation without networking work again (and thus move the debugdumpcommand stuff out of the network 'area').
rubidium
parents:
8214
diff
changeset
|
171 |
|
16e1c8db6f55
(svn r11811) -Fix: make compilation without networking work again (and thus move the debugdumpcommand stuff out of the network 'area').
rubidium
parents:
8214
diff
changeset
|
172 |
va_list va; |
16e1c8db6f55
(svn r11811) -Fix: make compilation without networking work again (and thus move the debugdumpcommand stuff out of the network 'area').
rubidium
parents:
8214
diff
changeset
|
173 |
va_start(va, s); |
16e1c8db6f55
(svn r11811) -Fix: make compilation without networking work again (and thus move the debugdumpcommand stuff out of the network 'area').
rubidium
parents:
8214
diff
changeset
|
174 |
vfprintf(f, s, va); |
16e1c8db6f55
(svn r11811) -Fix: make compilation without networking work again (and thus move the debugdumpcommand stuff out of the network 'area').
rubidium
parents:
8214
diff
changeset
|
175 |
va_end(va); |
16e1c8db6f55
(svn r11811) -Fix: make compilation without networking work again (and thus move the debugdumpcommand stuff out of the network 'area').
rubidium
parents:
8214
diff
changeset
|
176 |
|
16e1c8db6f55
(svn r11811) -Fix: make compilation without networking work again (and thus move the debugdumpcommand stuff out of the network 'area').
rubidium
parents:
8214
diff
changeset
|
177 |
fflush(f); |
16e1c8db6f55
(svn r11811) -Fix: make compilation without networking work again (and thus move the debugdumpcommand stuff out of the network 'area').
rubidium
parents:
8214
diff
changeset
|
178 |
} |
16e1c8db6f55
(svn r11811) -Fix: make compilation without networking work again (and thus move the debugdumpcommand stuff out of the network 'area').
rubidium
parents:
8214
diff
changeset
|
179 |
#endif /* DEBUG_DUMP_COMMANDS */ |