2
0

tool_operate.h 3.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  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 HdrCbData hdrcbdata;
  53. long num_headers;
  54. bool was_last_header_empty;
  55. bool added; /* set TRUE when added to the multi handle */
  56. time_t startat; /* when doing parallel transfers, this is a retry transfer
  57. that has been set to sleep until this time before it
  58. should get started (again) */
  59. bool abort; /* when doing parallel transfers and this is TRUE then a critical
  60. error (eg --fail-early) has occurred in another transfer and
  61. this transfer will be aborted in the progress callback */
  62. /* for parallel progress bar */
  63. curl_off_t dltotal;
  64. curl_off_t dlnow;
  65. curl_off_t ultotal;
  66. curl_off_t ulnow;
  67. curl_off_t uploadfilesize; /* expected total amount */
  68. curl_off_t uploadedsofar; /* amount delivered from the callback */
  69. bool dltotal_added; /* if the total has been added from this */
  70. bool ultotal_added;
  71. /* NULL or malloced */
  72. char *uploadfile;
  73. char *errorbuffer; /* allocated and assigned while this is used for a
  74. transfer */
  75. };
  76. CURLcode operate(struct GlobalConfig *config, int argc, argv_item_t argv[]);
  77. void single_transfer_cleanup(struct OperationConfig *config);
  78. extern struct per_transfer *transfers; /* first node */
  79. #endif /* HEADER_CURL_TOOL_OPERATE_H */