1 /*****************************************************************
3 | Neptune - Debug Utilities
5 | Copyright (c) 2002-2008, Axiomatic Systems, LLC.
8 | Redistribution and use in source and binary forms, with or without
9 | modification, are permitted provided that the following conditions are met:
10 | * Redistributions of source code must retain the above copyright
11 | notice, this list of conditions and the following disclaimer.
12 | * Redistributions in binary form must reproduce the above copyright
13 | notice, this list of conditions and the following disclaimer in the
14 | documentation and/or other materials provided with the distribution.
15 | * Neither the name of Axiomatic Systems nor the
16 | names of its contributors may be used to endorse or promote products
17 | derived from this software without specific prior written permission.
19 | THIS SOFTWARE IS PROVIDED BY AXIOMATIC SYSTEMS ''AS IS'' AND ANY
20 | EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
21 | WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
22 | DISCLAIMED. IN NO EVENT SHALL AXIOMATIC SYSTEMS BE LIABLE FOR ANY
23 | DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
24 | (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
25 | LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
26 | ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
27 | (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
28 | SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
30 ****************************************************************/
32 /*----------------------------------------------------------------------
34 +---------------------------------------------------------------------*/
39 /*----------------------------------------------------------------------
41 +---------------------------------------------------------------------*/
42 #define NPT_DEBUG_LOCAL_BUFFER_SIZE 1024
43 #define NPT_DEBUG_BUFFER_INCREMENT 4096
44 #define NPT_DEBUG_BUFFER_MAX_SIZE 65536
46 /*----------------------------------------------------------------------
48 +---------------------------------------------------------------------*/
50 NPT_Debug(const char* format
, ...)
52 #if defined(NPT_DEBUG)
53 char local_buffer
[NPT_DEBUG_LOCAL_BUFFER_SIZE
];
54 unsigned int buffer_size
= NPT_DEBUG_LOCAL_BUFFER_SIZE
;
55 char* buffer
= local_buffer
;
58 va_start(args
, format
);
63 /* try to format the message (it might not fit) */
64 result
= NPT_FormatStringVN(buffer
, buffer_size
-1, format
, args
);
65 buffer
[buffer_size
-1] = 0; /* force a NULL termination */
66 if (result
>= 0) break;
68 /* the buffer was too small, try something bigger */
69 buffer_size
= (buffer_size
+NPT_DEBUG_BUFFER_INCREMENT
)*2;
70 if (buffer_size
> NPT_DEBUG_BUFFER_MAX_SIZE
) break;
71 if (buffer
!= local_buffer
) delete[] buffer
;
72 buffer
= new char[buffer_size
];
73 if (buffer
== NULL
) return;
76 NPT_DebugOutput(buffer
);
77 if (buffer
!= local_buffer
) delete[] buffer
;
81 NPT_COMPILER_UNUSED(format
);