File: debugcxt.tex

package info (click to toggle)
wxwidgets2.8 2.8.10.1-3
  • links: PTS, VCS
  • area: main
  • in suites: squeeze
  • size: 239,052 kB
  • ctags: 289,550
  • sloc: cpp: 1,838,857; xml: 396,717; python: 282,506; ansic: 126,171; makefile: 51,406; sh: 14,581; asm: 299; sql: 258; lex: 194; perl: 139; yacc: 128; pascal: 95; php: 39; lisp: 38; tcl: 24; haskell: 20; java: 18; cs: 18; erlang: 17; ruby: 16; ada: 9; ml: 9; csh: 9
file content (275 lines) | stat: -rw-r--r-- 8,991 bytes parent folder | download | duplicates (7)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
\section{\class{wxDebugContext}}\label{wxdebugcontext}

A class for performing various debugging and memory tracing
operations. Full functionality (such as printing out objects
currently allocated) is only present in a debugging build of wxWidgets,
i.e. if the \_\_WXDEBUG\_\_ symbol is defined. wxDebugContext
and related functions and macros can be compiled out by setting
wxUSE\_DEBUG\_CONTEXT to 0 is setup.h

\wxheading{Derived from}

No parent class.

\wxheading{Include files}

<wx/memory.h>

\wxheading{See also}

\overview{Overview}{wxdebugcontextoverview}

\latexignore{\rtfignore{\wxheading{Members}}}

\membersection{wxDebugContext::Check}\label{wxdebugcontextcheck}

\func{int}{Check}{\void}

Checks the memory blocks for errors, starting from the currently set
checkpoint.

\wxheading{Return value}

Returns the number of errors,
so a value of zero represents success. Returns -1 if an error
was detected that prevents further checking.

\membersection{wxDebugContext::Dump}\label{wxdebugcontextdump}

\func{bool}{Dump}{\void}

Performs a memory dump from the currently set checkpoint, writing to the
current debug stream. Calls the {\bf Dump} member function for each wxObject
derived instance.

\wxheading{Return value}

true if the function succeeded, false otherwise.

\membersection{wxDebugContext::GetCheckPrevious}\label{wxdebugcontextgetcheckprevious}

\func{bool}{GetCheckPrevious}{\void}

Returns true if the memory allocator checks all previous memory blocks for errors.
By default, this is false since it slows down execution considerably.

\wxheading{See also}

\helpref{wxDebugContext::SetCheckPrevious}{wxdebugcontextsetcheckprevious}

\membersection{wxDebugContext::GetDebugMode}\label{wxdebugcontextgetdebugmode}

\func{bool}{GetDebugMode}{\void}

Returns true if debug mode is on. If debug mode is on, the wxObject new and delete
operators store or use information about memory allocation. Otherwise,
a straight malloc and free will be performed by these operators.

\wxheading{See also}

\helpref{wxDebugContext::SetDebugMode}{wxdebugcontextsetdebugmode}

\membersection{wxDebugContext::GetLevel}\label{wxdebugcontextgetlevel}

\func{int}{GetLevel}{\void}

Gets the debug level (default 1). The debug level is used by the wxTraceLevel function and
the WXTRACELEVEL macro to specify how detailed the trace information is; setting
a different level will only have an effect if trace statements in the application
specify a value other than one.

This is obsolete, replaced by \helpref{wxLog}{wxlog} functionality.

\wxheading{See also}

\helpref{wxDebugContext::SetLevel}{wxdebugcontextsetlevel}

\membersection{wxDebugContext::GetStream}\label{wxdebugcontextgetstream}

\func{ostream\&}{GetStream}{\void}

Returns the output stream associated with the debug context.

This is obsolete, replaced by \helpref{wxLog}{wxlog} functionality.

\wxheading{See also}

\helpref{wxDebugContext::SetStream}{wxdebugcontextsetstream}

\membersection{wxDebugContext::GetStreamBuf}\label{wxdebugcontextgetstreambuf}

\func{streambuf*}{GetStreamBuf}{\void}

Returns a pointer to the output stream buffer associated with the debug context.
There may not necessarily be a stream buffer if the stream has been set
by the user.

This is obsolete, replaced by \helpref{wxLog}{wxlog} functionality.

\membersection{wxDebugContext::HasStream}\label{wxdebugcontexthasstream}

\func{bool}{HasStream}{\void}

Returns true if there is a stream currently associated
with the debug context.

This is obsolete, replaced by \helpref{wxLog}{wxlog} functionality.

\wxheading{See also}

\helpref{wxDebugContext::SetStream}{wxdebugcontextsetstream}, \helpref{wxDebugContext::GetStream}{wxdebugcontextgetstream}

\membersection{wxDebugContext::PrintClasses}\label{wxdebugcontextprintclasses}

\func{bool}{PrintClasses}{\void}

Prints a list of the classes declared in this application, giving derivation
and whether instances of this class can be dynamically created.

\wxheading{See also}

\helpref{wxDebugContext::PrintStatistics}{wxdebugcontextprintstatistics}

\membersection{wxDebugContext::PrintStatistics}\label{wxdebugcontextprintstatistics}

\func{bool}{PrintStatistics}{\param{bool}{ detailed = true}}

Performs a statistics analysis from the currently set checkpoint, writing
to the current debug stream. The number of object and non-object
allocations is printed, together with the total size.

\wxheading{Parameters}

\docparam{detailed}{If true, the function will also print how many
objects of each class have been allocated, and the space taken by
these class instances.}

\wxheading{See also}

\helpref{wxDebugContext::PrintStatistics}{wxdebugcontextprintstatistics}

\membersection{wxDebugContext::SetCheckpoint}\label{wxdebugcontextsetcheckpoint}

\func{void}{SetCheckpoint}{\param{bool}{ all = false}}

Sets the current checkpoint: Dump and PrintStatistics operations will
be performed from this point on. This allows you to ignore allocations
that have been performed up to this point.

\wxheading{Parameters}

\docparam{all}{If true, the checkpoint is reset to include all
memory allocations since the program started.}

\membersection{wxDebugContext::SetCheckPrevious}\label{wxdebugcontextsetcheckprevious}

\func{void}{SetCheckPrevious}{\param{bool}{ check}}

Tells the memory allocator to check all previous memory blocks for errors.
By default, this is false since it slows down execution considerably.

\wxheading{See also}

\helpref{wxDebugContext::GetCheckPrevious}{wxdebugcontextgetcheckprevious}

\membersection{wxDebugContext::SetDebugMode}\label{wxdebugcontextsetdebugmode}

\func{void}{SetDebugMode}{\param{bool}{ debug}}

Sets the debug mode on or off. If debug mode is on, the wxObject new and delete
operators store or use information about memory allocation. Otherwise,
a straight malloc and free will be performed by these operators.

By default, debug mode is on if \_\_WXDEBUG\_\_ is defined. If the application
uses this function, it should make sure that all object memory allocated
is deallocated with the same value of debug mode. Otherwise, the
delete operator might try to look for memory information that does not
exist.

\wxheading{See also}

\helpref{wxDebugContext::GetDebugMode}{wxdebugcontextgetdebugmode}

\membersection{wxDebugContext::SetFile}\label{wxdebugcontextsetfile}

\func{bool}{SetFile}{\param{const wxString\& }{filename}}

Sets the current debug file and creates a stream. This will delete any existing
stream and stream buffer. By default, the debug context stream
outputs to the debugger (Windows) or standard error (other platforms).

\membersection{wxDebugContext::SetLevel}\label{wxdebugcontextsetlevel}

\func{void}{SetLevel}{\param{int}{ level}}

Sets the debug level (default 1). The debug level is used by the wxTraceLevel function and
the WXTRACELEVEL macro to specify how detailed the trace information is; setting
a different level will only have an effect if trace statements in the application
specify a value other than one.

This is obsolete, replaced by \helpref{wxLog}{wxlog} functionality.

\wxheading{See also}

\helpref{wxDebugContext::GetLevel}{wxdebugcontextgetlevel}

\membersection{wxDebugContext::SetStandardError}\label{wxdebugcontextsetstandarderror}

\func{bool}{SetStandardError}{\void}

Sets the debugging stream to be the debugger (Windows) or standard error (other platforms).
This is the default setting. The existing stream will be flushed and deleted.

This is obsolete, replaced by \helpref{wxLog}{wxlog} functionality.

\membersection{wxDebugContext::SetStream}\label{wxdebugcontextsetstream}

\func{void}{SetStream}{\param{ostream* }{stream}, \param{streambuf* }{streamBuf = NULL}}

Sets the stream and optionally, stream buffer associated with the debug context.
This operation flushes and deletes the existing stream (and stream buffer if any).

This is obsolete, replaced by \helpref{wxLog}{wxlog} functionality.

\wxheading{Parameters}

\docparam{stream}{Stream to associate with the debug context. Do not set this to NULL.}

\docparam{streamBuf}{Stream buffer to associate with the debug context.}

\wxheading{See also}

\helpref{wxDebugContext::GetStream}{wxdebugcontextgetstream}, \helpref{wxDebugContext::HasStream}{wxdebugcontexthasstream}

\section{\class{wxDebugStreamBuf}}\label{wxdebugstreambuf}

This class allows you to treat debugging output in a similar
(stream-based) fashion on different platforms. Under
Windows, an ostream constructed with this buffer outputs
to the debugger, or other program that intercepts debugging
output. On other platforms, the output goes to standard error (cerr).

This is soon to be obsolete, replaced by \helpref{wxLog}{wxlog} functionality.

\wxheading{Derived from}

streambuf

\wxheading{Include files}

<wx/memory.h>

\wxheading{Example}

\begin{verbatim}
  wxDebugStreamBuf streamBuf;
  ostream stream(&streamBuf);

  stream << "Hello world!" << endl;
\end{verbatim}

\wxheading{See also}

\overview{Overview}{wxdebugcontextoverview}