home *** CD-ROM | disk | FTP | other *** search
/ Tools / WinSN5.0Ver.iso / NETSCAP.50 / WIN1998.ZIP / ns / cmd / wincom / dllcom / src / dlldbg.cpp < prev    next >
Encoding:
C/C++ Source or Header  |  1998-04-08  |  1.7 KB  |  60 lines

  1. /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 2 -*-
  2.  *
  3.  * The contents of this file are subject to the Netscape Public License
  4.  * Version 1.0 (the "NPL"); you may not use this file except in
  5.  * compliance with the NPL.  You may obtain a copy of the NPL at
  6.  * http://www.mozilla.org/NPL/
  7.  *
  8.  * Software distributed under the NPL is distributed on an "AS IS" basis,
  9.  * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the NPL
  10.  * for the specific language governing rights and limitations under the
  11.  * NPL.
  12.  *
  13.  * The Initial Developer of this code under the NPL is Netscape
  14.  * Communications Corporation.  Portions created by Netscape are
  15.  * Copyright (C) 1998 Netscape Communications Corporation.  All Rights
  16.  * Reserved.
  17.  */
  18.  
  19. #include "dllcom.h"
  20. #include <stdio.h>
  21. #include <stdarg.h>
  22. #include <stdlib.h>
  23.  
  24. #ifdef DLL_DEBUG
  25.  
  26. #define TRACE_BUFFERSIZE 256
  27.  
  28. void DLL_Trace(const char *pFormat, ...)
  29. {
  30.     LPSTR    pBuffer = (char *)CoTaskMemAlloc(TRACE_BUFFERSIZE);
  31.  
  32.     if(pBuffer) {
  33.         //  Output module name.
  34.         strcpy(pBuffer, CComDll::m_pTraceID);
  35.         strcat(pBuffer, ":");
  36.  
  37.         //  Output module instance.
  38.         _ltoa(CProcess::GetProcessID(), pBuffer + lstrlen(pBuffer), 10);
  39.         strcat(pBuffer, ":  ");
  40.  
  41.         //  Output what programmer wanted now.
  42.         va_list args;
  43.         va_start(args, pFormat);
  44.     
  45.         vsprintf(pBuffer + lstrlen(pBuffer), pFormat, args);
  46.  
  47.         //  Offending trace statement.
  48.         //  Reduce output, or increase trace size.
  49.         DLL_ASSERT(lstrlen(pBuffer) < TRACE_BUFFERSIZE);
  50.  
  51.         OutputDebugString(pBuffer);
  52.  
  53.         va_end(args);
  54.  
  55.         CoTaskMemFree((LPVOID)pBuffer);
  56.         pBuffer = NULL;
  57.     }
  58. }
  59. #endif
  60.