tool_operate: Moved memory tracking initialisation into tool_main

This commit is contained in:
Steve Holme 2014-02-02 13:45:35 +00:00
parent ffb8a21d85
commit 0104678c79
4 changed files with 39 additions and 42 deletions

View File

@ -82,6 +82,38 @@ static void main_checkfds(void)
#endif #endif
} }
#ifdef CURLDEBUG
void memory_tracking_init(void)
{
char *env;
/* if CURL_MEMDEBUG is set, this starts memory tracking message logging */
env = curlx_getenv("CURL_MEMDEBUG");
if(env) {
/* use the value as file name */
char fname[CURL_MT_LOGFNAME_BUFSIZE];
if(strlen(env) >= CURL_MT_LOGFNAME_BUFSIZE)
env[CURL_MT_LOGFNAME_BUFSIZE-1] = '\0';
strcpy(fname, env);
curl_free(env);
curl_memdebug(fname);
/* this weird stuff here is to make curl_free() get called
before curl_memdebug() as otherwise memory tracking will
log a free() without an alloc! */
}
/* if CURL_MEMLIMIT is set, this enables fail-on-alloc-number-N feature */
env = curlx_getenv("CURL_MEMLIMIT");
if(env) {
char *endptr;
long num = strtol(env, &endptr, 10);
if((endptr != env) && (endptr == env + strlen(env)) && (num > 0))
curl_memlimit(num);
curl_free(env);
}
}
#else
# define memory_tracking_init() Curl_nop_stmt
#endif
/* /*
** curl tool main function. ** curl tool main function.
*/ */
@ -99,6 +131,10 @@ int main(int argc, char *argv[])
(void)signal(SIGPIPE, SIG_IGN); (void)signal(SIGPIPE, SIG_IGN);
#endif #endif
/* Initialize memory tracking */
memory_tracking_init();
/* Start our curl operation */
res = operate(&config, argc, argv); res = operate(&config, argc, argv);
#ifdef __SYMBIAN32__ #ifdef __SYMBIAN32__

View File

@ -214,12 +214,9 @@ int operate(struct Configurable *config, int argc, argv_item_t argv[])
heads.stream = stdout; heads.stream = stdout;
heads.config = config; heads.config = config;
memory_tracking_init();
/* /*
** Initialize curl library - do not call any libcurl functions before ** Initialize curl library - do not call any libcurl functions before
** this point. Note that the memory_tracking_init() magic above is an ** this point.
** exception, but then that's not part of the official public API.
*/ */
if(main_init() != CURLE_OK) { if(main_init() != CURLE_OK) {
helpf(config->errors, "error initializing curl library\n"); helpf(config->errors, "error initializing curl library\n");

View File

@ -5,7 +5,7 @@
* | (__| |_| | _ <| |___ * | (__| |_| | _ <| |___
* \___|\___/|_| \_\_____| * \___|\___/|_| \_\_____|
* *
* Copyright (C) 1998 - 2013, Daniel Stenberg, <daniel@haxx.se>, et al. * Copyright (C) 1998 - 2014, Daniel Stenberg, <daniel@haxx.se>, et al.
* *
* This software is licensed as described in the file COPYING, which * This software is licensed as described in the file COPYING, which
* you should have received as part of this distribution. The terms * you should have received as part of this distribution. The terms
@ -219,33 +219,3 @@ void main_free(void)
metalink_cleanup(); metalink_cleanup();
} }
#ifdef CURLDEBUG
void memory_tracking_init(void)
{
char *env;
/* if CURL_MEMDEBUG is set, this starts memory tracking message logging */
env = curlx_getenv("CURL_MEMDEBUG");
if(env) {
/* use the value as file name */
char fname[CURL_MT_LOGFNAME_BUFSIZE];
if(strlen(env) >= CURL_MT_LOGFNAME_BUFSIZE)
env[CURL_MT_LOGFNAME_BUFSIZE-1] = '\0';
strcpy(fname, env);
curl_free(env);
curl_memdebug(fname);
/* this weird stuff here is to make curl_free() get called
before curl_memdebug() as otherwise memory tracking will
log a free() without an alloc! */
}
/* if CURL_MEMLIMIT is set, this enables fail-on-alloc-number-N feature */
env = curlx_getenv("CURL_MEMLIMIT");
if(env) {
char *endptr;
long num = strtol(env, &endptr, 10);
if((endptr != env) && (endptr == env + strlen(env)) && (num > 0))
curl_memlimit(num);
curl_free(env);
}
}
#endif

View File

@ -7,7 +7,7 @@
* | (__| |_| | _ <| |___ * | (__| |_| | _ <| |___
* \___|\___/|_| \_\_____| * \___|\___/|_| \_\_____|
* *
* Copyright (C) 1998 - 2012, Daniel Stenberg, <daniel@haxx.se>, et al. * Copyright (C) 1998 - 2014, Daniel Stenberg, <daniel@haxx.se>, et al.
* *
* This software is licensed as described in the file COPYING, which * This software is licensed as described in the file COPYING, which
* you should have received as part of this distribution. The terms * you should have received as part of this distribution. The terms
@ -41,11 +41,5 @@ CURLcode main_init(void);
void main_free(void); void main_free(void);
#ifdef CURLDEBUG
void memory_tracking_init(void);
#else
# define memory_tracking_init() Curl_nop_stmt
#endif
#endif /* HEADER_CURL_TOOL_OPERHLP_H */ #endif /* HEADER_CURL_TOOL_OPERHLP_H */