tool_operate.h 3.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  1. #ifndef HEADER_CURL_TOOL_OPERATE_H
  2. #define HEADER_CURL_TOOL_OPERATE_H
  3. /***************************************************************************
  4. * _ _ ____ _
  5. * Project ___| | | | _ \| |
  6. * / __| | | | |_) | |
  7. * | (__| |_| | _ <| |___
  8. * \___|\___/|_| \_\_____|
  9. *
  10. * Copyright (C) Daniel Stenberg, <daniel@haxx.se>, et al.
  11. *
  12. * This software is licensed as described in the file COPYING, which
  13. * you should have received as part of this distribution. The terms
  14. * are also available at https://curl.se/docs/copyright.html.
  15. *
  16. * You may opt to use, copy, modify, merge, publish, distribute and/or sell
  17. * copies of the Software, and permit persons to whom the Software is
  18. * furnished to do so, under the terms of the COPYING file.
  19. *
  20. * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
  21. * KIND, either express or implied.
  22. *
  23. * SPDX-License-Identifier: curl
  24. *
  25. ***************************************************************************/
  26. #include "tool_setup.h"
  27. #include "tool_cb_hdr.h"
  28. #include "tool_cb_prg.h"
  29. #include "tool_sdecls.h"
  30. struct per_transfer {
  31. /* double linked */
  32. struct per_transfer *next;
  33. struct per_transfer *prev;
  34. struct OperationConfig *config; /* for this transfer */
  35. struct curl_certinfo *certinfo;
  36. CURL *curl;
  37. long retry_numretries;
  38. long retry_sleep_default;
  39. long retry_sleep;
  40. struct timeval start; /* start of this transfer */
  41. struct timeval retrystart;
  42. char *this_url;
  43. unsigned int urlnum; /* the index of the given URL */
  44. char *outfile;
  45. bool infdopen; /* TRUE if infd needs closing */
  46. int infd;
  47. bool noprogress;
  48. struct ProgressData progressbar;
  49. struct OutStruct outs;
  50. struct OutStruct heads;
  51. struct OutStruct etag_save;
  52. struct InStruct input;
  53. struct HdrCbData hdrcbdata;
  54. long num_headers;
  55. bool was_last_header_empty;
  56. bool added; /* set TRUE when added to the multi handle */
  57. time_t startat; /* when doing parallel transfers, this is a retry transfer
  58. that has been set to sleep until this time before it
  59. should get started (again) */
  60. bool abort; /* when doing parallel transfers and this is TRUE then a critical
  61. error (eg --fail-early) has occurred in another transfer and
  62. this transfer will be aborted in the progress callback */
  63. /* for parallel progress bar */
  64. curl_off_t dltotal;
  65. curl_off_t dlnow;
  66. curl_off_t ultotal;
  67. curl_off_t ulnow;
  68. bool dltotal_added; /* if the total has been added from this */
  69. bool ultotal_added;
  70. /* NULL or malloced */
  71. char *uploadfile;
  72. char *errorbuffer; /* alloced and assigned while this is used for a
  73. transfer */
  74. };
  75. CURLcode operate(struct GlobalConfig *config, int argc, argv_item_t argv[]);
  76. void single_transfer_cleanup(struct OperationConfig *config);
  77. extern struct per_transfer *transfers; /* first node */
  78. #endif /* HEADER_CURL_TOOL_OPERATE_H */