mirror of
https://github.com/curl/curl.git
synced 2026-04-16 13:35:18 +08:00
Description of how this works in `docs/internal/RATELIMITS.ms`. Notable implementation changes: - KEEP_SEND_PAUSE/KEEP_SEND_HOLD and KEEP_RECV_PAUSE/KEEP_RECV_HOLD no longer exist. Pausing is down via blocked the new rlimits. - KEEP_SEND_TIMED no longer exists. Pausing "100-continue" transfers is done in the new `Curl_http_perform_pollset()` method. - HTTP/2 rate limiting implemented via window updates. When transfer initiaiting connection has a ratelimit, adjust the initial window size - HTTP/3 ngtcp2 rate limitin implemnented via ack updates - HTTP/3 quiche does not seem to support this via its API - the default progress-meter has been improved for accuracy in "current speed" results. pytest speed tests have been improved. Closes #19384
87 lines
3.1 KiB
C
87 lines
3.1 KiB
C
#ifndef HEADER_CURL_PROGRESS_H
|
|
#define HEADER_CURL_PROGRESS_H
|
|
/***************************************************************************
|
|
* _ _ ____ _
|
|
* Project ___| | | | _ \| |
|
|
* / __| | | | |_) | |
|
|
* | (__| |_| | _ <| |___
|
|
* \___|\___/|_| \_\_____|
|
|
*
|
|
* Copyright (C) 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
|
|
* are also available at https://curl.se/docs/copyright.html.
|
|
*
|
|
* You may opt to use, copy, modify, merge, publish, distribute and/or sell
|
|
* copies of the Software, and permit persons to whom the Software is
|
|
* furnished to do so, under the terms of the COPYING file.
|
|
*
|
|
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
|
* KIND, either express or implied.
|
|
*
|
|
* SPDX-License-Identifier: curl
|
|
*
|
|
***************************************************************************/
|
|
|
|
#include "curlx/timeval.h"
|
|
|
|
struct Curl_easy;
|
|
|
|
typedef enum {
|
|
TIMER_NONE,
|
|
TIMER_STARTOP,
|
|
TIMER_STARTSINGLE, /* start of transfer, might get queued */
|
|
TIMER_POSTQUEUE, /* start, immediately after dequeue */
|
|
TIMER_NAMELOOKUP,
|
|
TIMER_CONNECT,
|
|
TIMER_APPCONNECT,
|
|
TIMER_PRETRANSFER,
|
|
TIMER_STARTTRANSFER,
|
|
TIMER_POSTRANSFER,
|
|
TIMER_STARTACCEPT,
|
|
TIMER_REDIRECT,
|
|
TIMER_LAST /* must be last */
|
|
} timerid;
|
|
|
|
int Curl_pgrsDone(struct Curl_easy *data);
|
|
void Curl_pgrsStartNow(struct Curl_easy *data);
|
|
void Curl_pgrsSetDownloadSize(struct Curl_easy *data, curl_off_t size);
|
|
void Curl_pgrsSetUploadSize(struct Curl_easy *data, curl_off_t size);
|
|
|
|
void Curl_pgrsSetDownloadCounter(struct Curl_easy *data, curl_off_t size);
|
|
void Curl_pgrsSetUploadCounter(struct Curl_easy *data, curl_off_t size);
|
|
|
|
/* perform progress update, invoking callbacks at intervals */
|
|
CURLcode Curl_pgrsUpdate(struct Curl_easy *data);
|
|
/* perform progress update, no callbacks invoked */
|
|
void Curl_pgrsUpdate_nometer(struct Curl_easy *data);
|
|
/* perform progress update with callbacks and speed checks */
|
|
CURLcode Curl_pgrsCheck(struct Curl_easy *data);
|
|
|
|
/* Inform progress/speedcheck about receive pausing */
|
|
void Curl_pgrsRecvPause(struct Curl_easy *data, bool enable);
|
|
|
|
/* Reset sizes and couners for up- and download. */
|
|
void Curl_pgrsReset(struct Curl_easy *data);
|
|
/* Reset sizes for up- and download. */
|
|
void Curl_pgrsResetTransferSizes(struct Curl_easy *data);
|
|
|
|
struct curltime Curl_pgrsTime(struct Curl_easy *data, timerid timer);
|
|
/**
|
|
* Update progress timer with the elapsed time from its start to `timestamp`.
|
|
* This allows updating timers later and is used by happy eyeballing, where
|
|
* we only want to record the winner's times.
|
|
*/
|
|
void Curl_pgrsTimeWas(struct Curl_easy *data, timerid timer,
|
|
struct curltime timestamp);
|
|
|
|
void Curl_pgrsEarlyData(struct Curl_easy *data, curl_off_t sent);
|
|
|
|
#ifdef UNITTESTS
|
|
UNITTEST CURLcode pgrs_speedcheck(struct Curl_easy *data,
|
|
struct curltime *pnow);
|
|
#endif
|
|
|
|
#endif /* HEADER_CURL_PROGRESS_H */
|