2011-07-26 23:23:27 +08:00
|
|
|
#ifndef HEADER_CURL_MEMDEBUG_H
|
|
|
|
#define HEADER_CURL_MEMDEBUG_H
|
2011-09-03 01:40:53 +08:00
|
|
|
#ifdef CURLDEBUG
|
2002-09-03 19:52:59 +08:00
|
|
|
/***************************************************************************
|
2004-11-09 22:00:56 +08:00
|
|
|
* _ _ ____ _
|
|
|
|
* Project ___| | | | _ \| |
|
|
|
|
* / __| | | | |_) | |
|
|
|
|
* | (__| |_| | _ <| |___
|
2002-03-19 15:54:55 +08:00
|
|
|
* \___|\___/|_| \_\_____|
|
|
|
|
*
|
2017-10-10 22:56:35 +08:00
|
|
|
* Copyright (C) 1998 - 2017, Daniel Stenberg, <daniel@haxx.se>, et al.
|
2002-03-19 15:54:55 +08:00
|
|
|
*
|
2002-09-03 19:52:59 +08:00
|
|
|
* This software is licensed as described in the file COPYING, which
|
|
|
|
* you should have received as part of this distribution. The terms
|
2016-02-03 07:19:02 +08:00
|
|
|
* are also available at https://curl.haxx.se/docs/copyright.html.
|
2004-11-09 22:00:56 +08:00
|
|
|
*
|
2002-03-19 15:54:55 +08:00
|
|
|
* You may opt to use, copy, modify, merge, publish, distribute and/or sell
|
|
|
|
* copies of the Software, and permit persons to whom the Software is
|
2002-09-03 19:52:59 +08:00
|
|
|
* furnished to do so, under the terms of the COPYING file.
|
2002-03-19 15:54:55 +08:00
|
|
|
*
|
|
|
|
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
|
|
|
* KIND, either express or implied.
|
|
|
|
*
|
2002-09-03 19:52:59 +08:00
|
|
|
***************************************************************************/
|
2000-12-19 21:23:54 +08:00
|
|
|
|
2004-02-18 20:18:33 +08:00
|
|
|
/*
|
|
|
|
* CAUTION: this header is designed to work when included by the app-side
|
|
|
|
* as well as the library. Do not mix with library internals!
|
|
|
|
*/
|
|
|
|
|
2011-08-20 23:26:02 +08:00
|
|
|
#define CURL_MT_LOGFNAME_BUFSIZE 512
|
|
|
|
|
2003-08-14 22:19:36 +08:00
|
|
|
#define logfile curl_debuglogfile
|
|
|
|
|
2001-10-04 21:25:12 +08:00
|
|
|
extern FILE *logfile;
|
|
|
|
|
2000-12-14 23:56:59 +08:00
|
|
|
/* memory functions */
|
2004-11-09 22:00:56 +08:00
|
|
|
CURL_EXTERN void *curl_domalloc(size_t size, int line, const char *source);
|
2011-04-20 21:17:42 +08:00
|
|
|
CURL_EXTERN void *curl_docalloc(size_t elements, size_t size, int line,
|
|
|
|
const char *source);
|
|
|
|
CURL_EXTERN void *curl_dorealloc(void *ptr, size_t size, int line,
|
|
|
|
const char *source);
|
2004-11-09 22:00:56 +08:00
|
|
|
CURL_EXTERN void curl_dofree(void *ptr, int line, const char *source);
|
|
|
|
CURL_EXTERN char *curl_dostrdup(const char *str, int line, const char *source);
|
2013-07-19 12:44:46 +08:00
|
|
|
#if defined(WIN32) && defined(UNICODE)
|
2013-07-19 02:04:02 +08:00
|
|
|
CURL_EXTERN wchar_t *curl_dowcsdup(const wchar_t *str, int line,
|
|
|
|
const char *source);
|
|
|
|
#endif
|
|
|
|
|
2004-11-09 22:00:56 +08:00
|
|
|
CURL_EXTERN void curl_memdebug(const char *logname);
|
|
|
|
CURL_EXTERN void curl_memlimit(long limit);
|
2010-01-19 04:22:04 +08:00
|
|
|
CURL_EXTERN void curl_memlog(const char *format, ...);
|
2000-10-09 19:11:43 +08:00
|
|
|
|
2000-12-14 23:56:59 +08:00
|
|
|
/* file descriptor manipulators */
|
2010-02-23 07:28:56 +08:00
|
|
|
CURL_EXTERN curl_socket_t curl_socket(int domain, int type, int protocol,
|
2016-04-04 02:28:34 +08:00
|
|
|
int line, const char *source);
|
2010-02-23 07:28:56 +08:00
|
|
|
CURL_EXTERN void curl_mark_sclose(curl_socket_t sockfd,
|
2016-04-04 02:28:34 +08:00
|
|
|
int line, const char *source);
|
2010-02-23 07:28:56 +08:00
|
|
|
CURL_EXTERN int curl_sclose(curl_socket_t sockfd,
|
2016-04-04 02:28:34 +08:00
|
|
|
int line, const char *source);
|
2010-02-23 07:28:56 +08:00
|
|
|
CURL_EXTERN curl_socket_t curl_accept(curl_socket_t s, void *a, void *alen,
|
|
|
|
int line, const char *source);
|
2011-07-29 19:25:52 +08:00
|
|
|
#ifdef HAVE_SOCKETPAIR
|
|
|
|
CURL_EXTERN int curl_socketpair(int domain, int type, int protocol,
|
|
|
|
curl_socket_t socket_vector[2],
|
2016-04-04 02:28:34 +08:00
|
|
|
int line, const char *source);
|
2011-07-29 19:25:52 +08:00
|
|
|
#endif
|
2000-12-14 23:56:59 +08:00
|
|
|
|
2017-10-10 22:56:35 +08:00
|
|
|
/* send/receive sockets */
|
2017-10-27 16:10:30 +08:00
|
|
|
CURL_EXTERN SEND_TYPE_RETV curl_dosend(SEND_TYPE_ARG1 sockfd,
|
|
|
|
SEND_QUAL_ARG2 SEND_TYPE_ARG2 buf,
|
|
|
|
SEND_TYPE_ARG3 len,
|
|
|
|
SEND_TYPE_ARG4 flags, int line,
|
|
|
|
const char *source);
|
|
|
|
CURL_EXTERN RECV_TYPE_RETV curl_dorecv(RECV_TYPE_ARG1 sockfd,
|
|
|
|
RECV_TYPE_ARG2 buf, RECV_TYPE_ARG3 len,
|
|
|
|
RECV_TYPE_ARG4 flags, int line,
|
|
|
|
const char *source);
|
2017-10-10 22:56:35 +08:00
|
|
|
|
2000-12-19 21:23:54 +08:00
|
|
|
/* FILE functions */
|
2004-11-09 22:00:56 +08:00
|
|
|
CURL_EXTERN FILE *curl_fopen(const char *file, const char *mode, int line,
|
|
|
|
const char *source);
|
2008-09-13 11:45:03 +08:00
|
|
|
#ifdef HAVE_FDOPEN
|
2007-06-28 19:11:29 +08:00
|
|
|
CURL_EXTERN FILE *curl_fdopen(int filedes, const char *mode, int line,
|
|
|
|
const char *source);
|
2008-09-13 11:45:03 +08:00
|
|
|
#endif
|
2004-11-09 22:00:56 +08:00
|
|
|
CURL_EXTERN int curl_fclose(FILE *file, int line, const char *source);
|
2000-12-19 21:23:54 +08:00
|
|
|
|
2004-01-29 21:56:45 +08:00
|
|
|
#ifndef MEMDEBUG_NODEFINES
|
|
|
|
|
2000-10-09 19:11:43 +08:00
|
|
|
/* Set this symbol on the command-line, recompile all lib-sources */
|
2002-10-29 03:20:59 +08:00
|
|
|
#undef strdup
|
2000-10-09 19:11:43 +08:00
|
|
|
#define strdup(ptr) curl_dostrdup(ptr, __LINE__, __FILE__)
|
|
|
|
#define malloc(size) curl_domalloc(size, __LINE__, __FILE__)
|
2004-02-26 22:52:51 +08:00
|
|
|
#define calloc(nbelem,size) curl_docalloc(nbelem, size, __LINE__, __FILE__)
|
2000-10-09 19:11:43 +08:00
|
|
|
#define realloc(ptr,size) curl_dorealloc(ptr, size, __LINE__, __FILE__)
|
|
|
|
#define free(ptr) curl_dofree(ptr, __LINE__, __FILE__)
|
2017-10-10 22:56:35 +08:00
|
|
|
#define send(a,b,c,d) curl_dosend(a,b,c,d, __LINE__, __FILE__)
|
|
|
|
#define recv(a,b,c,d) curl_dorecv(a,b,c,d, __LINE__, __FILE__)
|
2000-12-14 23:56:59 +08:00
|
|
|
|
2013-07-19 02:04:02 +08:00
|
|
|
#ifdef WIN32
|
|
|
|
# ifdef UNICODE
|
2013-07-19 12:44:46 +08:00
|
|
|
# undef wcsdup
|
|
|
|
# define wcsdup(ptr) curl_dowcsdup(ptr, __LINE__, __FILE__)
|
|
|
|
# undef _wcsdup
|
|
|
|
# define _wcsdup(ptr) curl_dowcsdup(ptr, __LINE__, __FILE__)
|
|
|
|
# undef _tcsdup
|
2013-07-19 02:04:02 +08:00
|
|
|
# define _tcsdup(ptr) curl_dowcsdup(ptr, __LINE__, __FILE__)
|
|
|
|
# else
|
2013-07-19 12:44:46 +08:00
|
|
|
# undef _tcsdup
|
2013-07-19 02:04:02 +08:00
|
|
|
# define _tcsdup(ptr) curl_dostrdup(ptr, __LINE__, __FILE__)
|
|
|
|
# endif
|
|
|
|
#endif
|
|
|
|
|
2015-12-08 03:27:29 +08:00
|
|
|
#undef socket
|
2000-12-14 23:56:59 +08:00
|
|
|
#define socket(domain,type,protocol)\
|
2015-03-17 20:41:49 +08:00
|
|
|
curl_socket(domain, type, protocol, __LINE__, __FILE__)
|
2004-02-03 05:34:01 +08:00
|
|
|
#undef accept /* for those with accept as a macro */
|
2000-12-19 00:13:37 +08:00
|
|
|
#define accept(sock,addr,len)\
|
2015-03-17 20:41:49 +08:00
|
|
|
curl_accept(sock, addr, len, __LINE__, __FILE__)
|
2011-07-29 19:25:52 +08:00
|
|
|
#ifdef HAVE_SOCKETPAIR
|
|
|
|
#define socketpair(domain,type,protocol,socket_vector)\
|
2015-03-17 20:41:49 +08:00
|
|
|
curl_socketpair(domain, type, protocol, socket_vector, __LINE__, __FILE__)
|
2011-07-29 19:25:52 +08:00
|
|
|
#endif
|
2000-12-14 23:56:59 +08:00
|
|
|
|
2008-10-31 03:02:23 +08:00
|
|
|
#ifdef HAVE_GETADDRINFO
|
2005-06-30 21:28:58 +08:00
|
|
|
#if defined(getaddrinfo) && defined(__osf__)
|
|
|
|
/* OSF/1 and Tru64 have getaddrinfo as a define already, so we cannot define
|
|
|
|
our macro as for other platforms. Instead, we redefine the new name they
|
|
|
|
define getaddrinfo to become! */
|
|
|
|
#define ogetaddrinfo(host,serv,hint,res) \
|
2015-03-17 20:41:49 +08:00
|
|
|
curl_dogetaddrinfo(host, serv, hint, res, __LINE__, __FILE__)
|
2005-06-30 21:28:58 +08:00
|
|
|
#else
|
2005-11-14 07:53:14 +08:00
|
|
|
#undef getaddrinfo
|
2001-10-04 21:25:12 +08:00
|
|
|
#define getaddrinfo(host,serv,hint,res) \
|
2015-03-17 20:41:49 +08:00
|
|
|
curl_dogetaddrinfo(host, serv, hint, res, __LINE__, __FILE__)
|
2005-06-30 21:28:58 +08:00
|
|
|
#endif
|
2008-10-31 03:02:23 +08:00
|
|
|
#endif /* HAVE_GETADDRINFO */
|
2006-07-04 10:27:11 +08:00
|
|
|
|
|
|
|
#ifdef HAVE_GETNAMEINFO
|
2005-11-14 07:53:14 +08:00
|
|
|
#undef getnameinfo
|
2004-04-26 15:20:11 +08:00
|
|
|
#define getnameinfo(sa,salen,host,hostlen,serv,servlen,flags) \
|
2015-03-17 20:41:49 +08:00
|
|
|
curl_dogetnameinfo(sa, salen, host, hostlen, serv, servlen, flags, \
|
|
|
|
__LINE__, __FILE__)
|
2008-10-31 03:02:23 +08:00
|
|
|
#endif /* HAVE_GETNAMEINFO */
|
2006-07-04 10:27:11 +08:00
|
|
|
|
2008-10-31 03:02:23 +08:00
|
|
|
#ifdef HAVE_FREEADDRINFO
|
2005-11-14 07:53:14 +08:00
|
|
|
#undef freeaddrinfo
|
2001-10-04 21:25:12 +08:00
|
|
|
#define freeaddrinfo(data) \
|
2015-03-17 20:41:49 +08:00
|
|
|
curl_dofreeaddrinfo(data, __LINE__, __FILE__)
|
2008-10-31 03:02:23 +08:00
|
|
|
#endif /* HAVE_FREEADDRINFO */
|
2001-10-04 21:25:12 +08:00
|
|
|
|
2000-12-14 23:56:59 +08:00
|
|
|
/* sclose is probably already defined, redefine it! */
|
|
|
|
#undef sclose
|
|
|
|
#define sclose(sockfd) curl_sclose(sockfd,__LINE__,__FILE__)
|
|
|
|
|
2009-10-29 04:30:23 +08:00
|
|
|
#define fake_sclose(sockfd) curl_mark_sclose(sockfd,__LINE__,__FILE__)
|
|
|
|
|
2000-12-19 21:23:54 +08:00
|
|
|
#undef fopen
|
|
|
|
#define fopen(file,mode) curl_fopen(file,mode,__LINE__,__FILE__)
|
2007-06-28 19:11:29 +08:00
|
|
|
#undef fdopen
|
|
|
|
#define fdopen(file,mode) curl_fdopen(file,mode,__LINE__,__FILE__)
|
2000-12-19 21:23:54 +08:00
|
|
|
#define fclose(file) curl_fclose(file,__LINE__,__FILE__)
|
|
|
|
|
2004-01-29 21:56:45 +08:00
|
|
|
#endif /* MEMDEBUG_NODEFINES */
|
|
|
|
|
2004-02-18 20:18:33 +08:00
|
|
|
#endif /* CURLDEBUG */
|
2009-10-29 04:30:23 +08:00
|
|
|
|
2011-09-03 01:40:53 +08:00
|
|
|
/*
|
|
|
|
** Following section applies even when CURLDEBUG is not defined.
|
|
|
|
*/
|
|
|
|
|
2009-10-29 04:30:23 +08:00
|
|
|
#ifndef fake_sclose
|
2011-09-03 22:06:10 +08:00
|
|
|
#define fake_sclose(x) Curl_nop_stmt
|
2009-10-29 04:30:23 +08:00
|
|
|
#endif
|
2011-09-03 01:40:53 +08:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Curl_safefree defined as a macro to allow MemoryTracking feature
|
|
|
|
* to log free() calls at same location where Curl_safefree is used.
|
2011-09-15 23:35:23 +08:00
|
|
|
* This macro also assigns NULL to given pointer when free'd.
|
2011-09-03 01:40:53 +08:00
|
|
|
*/
|
|
|
|
|
2011-09-15 23:35:23 +08:00
|
|
|
#define Curl_safefree(ptr) \
|
2015-03-16 22:01:15 +08:00
|
|
|
do { free((ptr)); (ptr) = NULL;} WHILE_FALSE
|
2011-09-03 01:40:53 +08:00
|
|
|
|
|
|
|
#endif /* HEADER_CURL_MEMDEBUG_H */
|