curl/lib/memdebug.c

119 lines
3.0 KiB
C
Raw Normal View History

2000-10-09 11:11:43 +00:00
#ifdef MALLOCDEBUG
/*****************************************************************************
* _ _ ____ _
* Project ___| | | | _ \| |
* / __| | | | |_) | |
* | (__| |_| | _ <| |___
* \___|\___/|_| \_\_____|
*
* The contents of this file are subject to the Mozilla Public License
* Version 1.0 (the "License"); you may not use this file except in
* compliance with the License. You may obtain a copy of the License at
* http://www.mozilla.org/MPL/
*
* Software distributed under the License is distributed on an "AS IS"
* basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See the
* License for the specific language governing rights and limitations
* under the License.
*
* The Original Code is Curl.
*
* The Initial Developer of the Original Code is Daniel Stenberg.
*
* Portions created by the Initial Developer are Copyright (C) 1999.
* All Rights Reserved.
*
* ------------------------------------------------------------
* Main author:
* - Daniel Stenberg <daniel@haxx.se>
*
* http://curl.haxx.se
*
* $Source$
* $Revision$
* $Date$
* $Author$
* $State$
* $Locker$
*
* ------------------------------------------------------------
****************************************************************************/
#include "setup.h"
#include <curl/curl.h>
#define _MPRINTF_REPLACE
#include <curl/mprintf.h>
2000-10-09 11:11:43 +00:00
#include "urldata.h"
#include <stdio.h>
#include <string.h>
2000-11-17 14:05:43 +00:00
#include <stdlib.h>
2000-10-09 11:11:43 +00:00
/*
* Note that these debug functions are very simple and they are meant to
* remain so. For advanced analysis, record a log file and write perl scripts
* to analyze them!
*
* Don't use these with multithreaded test programs!
*/
2000-10-25 07:41:11 +00:00
FILE *logfile;
2000-10-09 11:11:43 +00:00
/* this sets the log file name */
void curl_memdebug(char *logname)
{
logfile = fopen(logname, "w");
}
void *curl_domalloc(size_t size, int line, char *source)
{
void *mem=(malloc)(size);
2000-10-25 07:41:11 +00:00
fprintf(logfile?logfile:stderr, "MEM %s:%d malloc(%d) = %p\n",
2000-10-09 11:11:43 +00:00
source, line, size, mem);
return mem;
}
char *curl_dostrdup(char *str, int line, char *source)
{
char *mem;
size_t len;
if(NULL ==str) {
fprintf(stderr, "ILLEGAL strdup() on NULL at %s:%d\n",
source, line);
exit(2);
}
mem=(strdup)(str);
len=strlen(str)+1;
2000-10-25 07:41:11 +00:00
fprintf(logfile?logfile:stderr, "MEM %s:%d strdup(%p) (%d) = %p\n",
2000-10-09 11:11:43 +00:00
source, line, str, len, mem);
return mem;
}
void *curl_dorealloc(void *ptr, size_t size, int line, char *source)
{
void *mem=(realloc)(ptr, size);
2000-10-25 07:41:11 +00:00
fprintf(logfile?logfile:stderr, "MEM %s:%d realloc(%p, %d) = %p\n",
2000-10-09 11:11:43 +00:00
source, line, ptr, size, mem);
return mem;
}
void curl_dofree(void *ptr, int line, char *source)
{
if(NULL == ptr) {
fprintf(stderr, "ILLEGAL free() on NULL at %s:%d\n",
source, line);
exit(2);
}
2000-10-09 11:11:43 +00:00
(free)(ptr);
2000-10-25 07:41:11 +00:00
fprintf(logfile?logfile:stderr, "MEM %s:%d free(%p)\n",
2000-10-09 11:11:43 +00:00
source, line, ptr);
}
#endif /* MALLOCDEBUG */