diff options
| author | Daniel Stenberg <daniel@haxx.se> | 2000-10-02 06:30:40 +0000 | 
|---|---|---|
| committer | Daniel Stenberg <daniel@haxx.se> | 2000-10-02 06:30:40 +0000 | 
| commit | dfec172157b915c564c902996e85eed4b6d5f3b3 (patch) | |
| tree | 6125080905e2ecd334a3194e76d26742cace4a4c | |
| parent | 888182c16d045dad3929747dd7ba2481b01096b0 (diff) | |
moved out from the library and put here, uses the new curl_easy_getinfo()
| -rw-r--r-- | src/writeout.c | 204 | ||||
| -rw-r--r-- | src/writeout.h | 45 | 
2 files changed, 249 insertions, 0 deletions
| diff --git a/src/writeout.c b/src/writeout.c new file mode 100644 index 000000000..8a652ef6c --- /dev/null +++ b/src/writeout.c @@ -0,0 +1,204 @@ +/***************************************************************************** + *                                  _   _ ____  _      + *  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 <stdio.h> +#include <string.h> + +#include <curl/curl.h> +#include <curl/types.h> +#include <curl/easy.h> +#include <curl/mprintf.h> + +#include "writeout.h" + +typedef enum { +  VAR_NONE,       /* must be the first */ +  VAR_TOTAL_TIME, +  VAR_NAMELOOKUP_TIME, +  VAR_CONNECT_TIME, +  VAR_PRETRANSFER_TIME, +  VAR_SIZE_DOWNLOAD, +  VAR_SIZE_UPLOAD, +  VAR_SPEED_DOWNLOAD, +  VAR_SPEED_UPLOAD, +  VAR_HTTP_CODE, +  VAR_EFFECTIVE_URL, +  VAR_NUM_OF_VARS /* must be the last */ +} replaceid; + +struct variable { +  char *name; +  replaceid id; +}; + + +static struct variable replacements[]={ +  {"url_effective", VAR_EFFECTIVE_URL}, +  {"http_code", VAR_HTTP_CODE}, +  {"time_total", VAR_TOTAL_TIME}, +  {"time_namelookup", VAR_NAMELOOKUP_TIME}, +  {"time_connect", VAR_CONNECT_TIME}, +  {"time_pretransfer", VAR_PRETRANSFER_TIME}, +  {"size_download", VAR_SIZE_DOWNLOAD}, +  {"size_upload", VAR_SIZE_UPLOAD}, +  {"speed_download", VAR_SPEED_DOWNLOAD}, +  {"speed_upload", VAR_SPEED_UPLOAD}, +  {NULL} +}; + +void ourWriteOut(CURL *curl, char *writeinfo) +{ +  FILE *stream = stdout; +  char *ptr=writeinfo; +  char *stringp; +  long longinfo; +  double doubleinfo; + +  while(*ptr) { +    if('%' == *ptr) { +      if('%' == ptr[1]) { +        /* an escaped %-letter */ +        fputc('%', stream); +        ptr+=2; +      } +      else { +        /* this is meant as a variable to output */ +        char *end; +        char keepit; +        int i; +        if(('{' == ptr[1]) && (end=strchr(ptr, '}'))) { +          ptr+=2; /* pass the % and the { */ +          keepit=*end; +          *end=0; /* zero terminate */ +          for(i=0; replacements[i].name; i++) { +            if(strequal(ptr, replacements[i].name)) { +              switch(replacements[i].id) { +              case VAR_EFFECTIVE_URL: +                if(CURLE_OK == +                   curl_easy_getinfo(curl, CURLINFO_EFFECTIVE_URL, &stringp)) +                  fputs(stringp, stream); +                break; +              case VAR_HTTP_CODE: +                if(CURLE_OK == +                   curl_easy_getinfo(curl, CURLINFO_HTTP_CODE, &longinfo)) +                  fprintf(stream, "%03d", longinfo); +                break; +              case VAR_TOTAL_TIME: +                if(CURLE_OK == +                   curl_easy_getinfo(curl, CURLINFO_TOTAL_TIME, &doubleinfo)) +                  fprintf(stream, "%.3f", doubleinfo); +                break; +              case VAR_NAMELOOKUP_TIME: +                if(CURLE_OK == +                   curl_easy_getinfo(curl, CURLINFO_NAMELOOKUP_TIME, +                                     &doubleinfo)) +                  fprintf(stream, "%.3f", doubleinfo); +                break; +              case VAR_CONNECT_TIME: +                if(CURLE_OK == +                   curl_easy_getinfo(curl, CURLINFO_CONNECT_TIME, &doubleinfo)) +                  fprintf(stream, "%.3f", doubleinfo); +                break; +              case VAR_PRETRANSFER_TIME: +                if(CURLE_OK == +                   curl_easy_getinfo(curl, CURLINFO_PRETRANSFER_TIME, &doubleinfo)) +                  fprintf(stream, "%.3f", doubleinfo); +                break; +              case VAR_SIZE_UPLOAD: +                if(CURLE_OK == +                   curl_easy_getinfo(curl, CURLINFO_SIZE_UPLOAD, &doubleinfo)) +                  fprintf(stream, "%.3f", doubleinfo); +                break; +              case VAR_SIZE_DOWNLOAD: +                if(CURLE_OK == +                   curl_easy_getinfo(curl, CURLINFO_SIZE_DOWNLOAD, &doubleinfo)) +                  fprintf(stream, "%.3f", doubleinfo); +                break; +              case VAR_SPEED_DOWNLOAD: +                if(CURLE_OK == +                   curl_easy_getinfo(curl, CURLINFO_SPEED_DOWNLOAD, &doubleinfo)) +                  fprintf(stream, "%.3f", doubleinfo); +                break; +              case VAR_SPEED_UPLOAD: +                if(CURLE_OK == +                   curl_easy_getinfo(curl, CURLINFO_SPEED_UPLOAD, &doubleinfo)) +                  fprintf(stream, "%.3f", doubleinfo); +                break; +              } +              break; +            } +          } +          ptr=end+1; /* pass the end */ +          *end = keepit; +        } +        else { +          /* illegal syntax, then just output the characters that are used */ +          fputc('%', stream); +          fputc(ptr[1], stream); +          ptr+=2; +        } +      } +    } +    else if('\\' == *ptr) { +      switch(ptr[1]) { +      case 'r': +        fputc('\r', stream); +        break; +      case 'n': +        fputc('\n', stream); +        break; +      case 't': +        fputc('\t', stream); +        break; +      default: +        /* unknown, just output this */ +        fputc(*ptr, stream); +        fputc(ptr[1], stream); +        break; +      } +      ptr+=2; +    } +    else { +      fputc(*ptr, stream); +      ptr++; +    } +  } +   +} diff --git a/src/writeout.h b/src/writeout.h new file mode 100644 index 000000000..1d8bfd10f --- /dev/null +++ b/src/writeout.h @@ -0,0 +1,45 @@ +#ifndef __WRITEOUT_H +#define __WRITEOUT_H +/***************************************************************************** + *                                  _   _ ____  _      + *  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$ + * + * ------------------------------------------------------------ + ****************************************************************************/ + +void ourWriteOut(CURL *curl, char *out); + +#endif | 
