diff options
Diffstat (limited to 'lib/getinfo.c')
| -rw-r--r-- | lib/getinfo.c | 60 | 
1 files changed, 58 insertions, 2 deletions
diff --git a/lib/getinfo.c b/lib/getinfo.c index 2b8f2303e..9aac5e2b8 100644 --- a/lib/getinfo.c +++ b/lib/getinfo.c @@ -5,7 +5,7 @@   *                            | (__| |_| |  _ <| |___   *                             \___|\___/|_| \_\_____|   * - * Copyright (C) 1998 - 2019, Daniel Stenberg, <daniel@haxx.se>, et al. + * Copyright (C) 1998 - 2020, Daniel Stenberg, <daniel@haxx.se>, et al.   *   * This software is licensed as described in the file COPYING, which   * you should have received as part of this distribution. The terms @@ -147,6 +147,20 @@ static CURLcode getinfo_long(struct Curl_easy *data, CURLINFO info,      long          *to_long;    } lptr; +#ifdef DEBUGBUILD +  char *timestr = getenv("CURL_TIME"); +  if(timestr) { +    unsigned long val = strtol(timestr, NULL, 10); +    switch(info) { +    case CURLINFO_LOCAL_PORT: +      *param_longp = (long)val; +      return CURLE_OK; +    default: +      break; +    } +  } +#endif +    switch(info) {    case CURLINFO_RESPONSE_CODE:      *param_longp = data->info.httpcode; @@ -258,6 +272,27 @@ static CURLcode getinfo_long(struct Curl_easy *data, CURLINFO info,  static CURLcode getinfo_offt(struct Curl_easy *data, CURLINFO info,                               curl_off_t *param_offt)  { +#ifdef DEBUGBUILD +  char *timestr = getenv("CURL_TIME"); +  if(timestr) { +    unsigned long val = strtol(timestr, NULL, 10); +    switch(info) { +    case CURLINFO_TOTAL_TIME_T: +    case CURLINFO_NAMELOOKUP_TIME_T: +    case CURLINFO_CONNECT_TIME_T: +    case CURLINFO_APPCONNECT_TIME_T: +    case CURLINFO_PRETRANSFER_TIME_T: +    case CURLINFO_STARTTRANSFER_TIME_T: +    case CURLINFO_REDIRECT_TIME_T: +    case CURLINFO_SPEED_DOWNLOAD_T: +    case CURLINFO_SPEED_UPLOAD_T: +      *param_offt = (curl_off_t)val; +      return CURLE_OK; +    default: +      break; +    } +  } +#endif    switch(info) {    case CURLINFO_FILETIME_T:      *param_offt = (curl_off_t)data->info.filetime; @@ -282,7 +317,7 @@ static CURLcode getinfo_offt(struct Curl_easy *data, CURLINFO info,      *param_offt = (data->progress.flags & PGRS_UL_SIZE_KNOWN)?        data->progress.size_ul:-1;      break; -  case CURLINFO_TOTAL_TIME_T: +   case CURLINFO_TOTAL_TIME_T:      *param_offt = data->progress.timespent;      break;    case CURLINFO_NAMELOOKUP_TIME_T: @@ -316,6 +351,27 @@ static CURLcode getinfo_offt(struct Curl_easy *data, CURLINFO info,  static CURLcode getinfo_double(struct Curl_easy *data, CURLINFO info,                                 double *param_doublep)  { +#ifdef DEBUGBUILD +  char *timestr = getenv("CURL_TIME"); +  if(timestr) { +    unsigned long val = strtol(timestr, NULL, 10); +    switch(info) { +    case CURLINFO_TOTAL_TIME: +    case CURLINFO_NAMELOOKUP_TIME: +    case CURLINFO_CONNECT_TIME: +    case CURLINFO_APPCONNECT_TIME: +    case CURLINFO_PRETRANSFER_TIME: +    case CURLINFO_STARTTRANSFER_TIME: +    case CURLINFO_REDIRECT_TIME: +    case CURLINFO_SPEED_DOWNLOAD: +    case CURLINFO_SPEED_UPLOAD: +      *param_doublep = (double)val; +      return CURLE_OK; +    default: +      break; +    } +  } +#endif    switch(info) {    case CURLINFO_TOTAL_TIME:      *param_doublep = DOUBLE_SECS(data->progress.timespent);  | 
