Skip to content
Snippets Groups Projects
memdebug.c 2.97 KiB
Newer Older
  • Learn to ignore specific revisions
  • #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>
    #include "urldata.h"
    #include <stdio.h>
    #include <string.h>
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    #include <stdlib.h>
    
    
    /*
     * 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!
     */
    
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    FILE *logfile;
    
    
    /* 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);
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
      fprintf(logfile?logfile:stderr, "MEM %s:%d malloc(%d) = %p\n",
    
              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;
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
      fprintf(logfile?logfile:stderr, "MEM %s:%d strdup(%p) (%d) = %p\n",
    
              source, line, str, len, mem);
      return mem;
    }
    
    void *curl_dorealloc(void *ptr, size_t size, int line, char *source)
    {
      void *mem=(realloc)(ptr, size);
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
      fprintf(logfile?logfile:stderr, "MEM %s:%d realloc(%p, %d) = %p\n",
    
              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);
      }
    
    
      (free)(ptr);
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
      fprintf(logfile?logfile:stderr, "MEM %s:%d free(%p)\n",
    
              source, line, ptr);
    }
    
    #endif /* MALLOCDEBUG */