Leaked source code of windows server 2003
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

198 lines
5.0 KiB

  1. /*==========================================================================
  2. *
  3. * Copyright (C) 1994-1995 Microsoft Corporation. All Rights Reserved.
  4. *
  5. * File: dpf.c
  6. * Content: debugging printf
  7. *@@BEGIN_MSINTERNAL
  8. * History:
  9. * Date By Reason
  10. * ==== == ======
  11. * 06-jan-95 craige initial implementation
  12. * 03-mar-95 craige added dprintf2
  13. * 31-mar-95 craige add DPFInit to read WIN.INI for [DirectDraw] section;
  14. * added dprintf3
  15. * 01-apr-95 craige happy fun joy updated header file
  16. * 06-apr-95 craige made stand-alone
  17. * 18-jun-95 craige use negative dpf level to display ONLY that level
  18. * 06-dec-95 jeffno Changed dprintf to use c-standard variable argument
  19. * list techniques. Also added abs for NT
  20. * 06-feb-96 colinmc added simple assertion mechanism for DirectDraw
  21. * 15-apr-96 kipo added msinternal
  22. *@@END_MSINTERNAL
  23. *
  24. ***************************************************************************/
  25. #include "pch.c"
  26. #ifdef NEW_DPF
  27. #include "newdpf.c"
  28. #else //use old debug:
  29. #include "dpf.h"
  30. #include <stdarg.h>
  31. //#ifdef WINNT
  32. //int abs(int x)
  33. //{
  34. // return x>=0?x:-x;
  35. //}
  36. //#endif
  37. #ifdef DEBUG
  38. #define USE_DDASSERT
  39. #ifndef START_STR
  40. #define START_STR "DDRAW: "
  41. #endif
  42. #ifndef PROF_SECT
  43. #define PROF_SECT "DirectDraw"
  44. #endif
  45. #define END_STR "\r\n"
  46. HWND hWndListBox;
  47. LONG lDebugLevel = 0;
  48. /*
  49. * dumpStr
  50. */
  51. static void dumpStr( LPSTR str )
  52. {
  53. OutputDebugString( str );
  54. #ifdef DPF_HWND
  55. if( hWndListBox != NULL )
  56. {
  57. if( !IsWindow( hWndListBox ) )
  58. {
  59. hWndListBox = NULL;
  60. }
  61. }
  62. if( hWndListBox != NULL )
  63. {
  64. UINT sel;
  65. int len;
  66. len = strlen( str );
  67. if( len > 0 )
  68. {
  69. if( str[len-1] == '\r' || str[len-1] == '\n' )
  70. {
  71. str[len-1] = 0;
  72. }
  73. if( len > 1 )
  74. {
  75. if( str[len-2] == '\r' || str[len-2] == '\n' )
  76. {
  77. str[len-2] = 0;
  78. }
  79. }
  80. }
  81. SendMessage( hWndListBox, LB_ADDSTRING, 0, (LONG) (LPSTR) str );
  82. sel = (UINT) SendMessage( hWndListBox, LB_GETCOUNT, 0, 0L );
  83. if( sel != LB_ERR )
  84. {
  85. SendMessage( hWndListBox, LB_SETCURSEL, sel-1, 0L );
  86. }
  87. }
  88. #endif
  89. } /* dumpStr */
  90. /*
  91. * dprintf
  92. */
  93. void cdecl dprintf( UINT lvl, LPSTR szFormat, ...)
  94. {
  95. char str[256];
  96. //char str2[256];
  97. BOOL allow = FALSE;
  98. va_list ap;
  99. va_start(ap,szFormat);
  100. if( lDebugLevel < 0 )
  101. {
  102. if( (UINT) -lDebugLevel == lvl )
  103. {
  104. allow = TRUE;
  105. }
  106. }
  107. else if( (UINT) lDebugLevel >= lvl )
  108. {
  109. allow = TRUE;
  110. }
  111. if( allow )
  112. {
  113. wsprintf( (LPSTR) str, START_STR );
  114. //GetModuleFileName(NULL,str2,256);
  115. //if (strrchr(str2,'\\'))
  116. // wsprintf(str+strlen(str),"%12s",strrchr(str2,'\\')+1);
  117. //strcat(str,":");
  118. wvsprintf( str+lstrlen( str ), szFormat, ap); //(LPVOID)(&szFormat+1) );
  119. lstrcat( (LPSTR) str, END_STR );
  120. dumpStr( str );
  121. }
  122. va_end(ap);
  123. } /* dprintf */
  124. /*
  125. * DPFInit
  126. */
  127. void DPFInit( void )
  128. {
  129. lDebugLevel = GetProfileInt( PROF_SECT, "debug", 0 );
  130. } /* DPFInit */
  131. #ifdef USE_DDASSERT
  132. /*
  133. * NOTE: I don't want to get into error checking for buffer overflows when
  134. * trying to issue an assertion failure message. So instead I just allocate
  135. * a buffer that is "bug enough" (I know, I know...)
  136. */
  137. #define ASSERT_BUFFER_SIZE 512
  138. #define ASSERT_BANNER_STRING "************************************************************"
  139. #define ASSERT_BREAK_SECTION "BreakOnAssert"
  140. #define ASSERT_BREAK_DEFAULT FALSE
  141. #define ASSERT_MESSAGE_LEVEL 0
  142. void _DDAssert( LPCSTR szFile, int nLine, LPCSTR szCondition )
  143. {
  144. char buffer[ASSERT_BUFFER_SIZE];
  145. /*
  146. * Build the debug stream message.
  147. */
  148. wsprintf( buffer, "ASSERTION FAILED! File %s Line %d: %s", szFile, nLine, szCondition );
  149. /*
  150. * Actually issue the message. These messages are considered error level
  151. * so they all go out at error level priority.
  152. */
  153. dprintf( ASSERT_MESSAGE_LEVEL, ASSERT_BANNER_STRING );
  154. dprintf( ASSERT_MESSAGE_LEVEL, buffer );
  155. dprintf( ASSERT_MESSAGE_LEVEL, ASSERT_BANNER_STRING );
  156. /*
  157. * Should we drop into the debugger?
  158. */
  159. if( GetProfileInt( PROF_SECT, ASSERT_BREAK_SECTION, ASSERT_BREAK_DEFAULT ) )
  160. {
  161. /*
  162. * Into the debugger we go...
  163. */
  164. DEBUG_BREAK();
  165. }
  166. }
  167. #endif /* USE_DDASSERT */
  168. #endif
  169. #endif //use new dpf