Annotation of embedaddon/curl/lib/speedcheck.c, revision 1.1
1.1 ! misho 1: /***************************************************************************
! 2: * _ _ ____ _
! 3: * Project ___| | | | _ \| |
! 4: * / __| | | | |_) | |
! 5: * | (__| |_| | _ <| |___
! 6: * \___|\___/|_| \_\_____|
! 7: *
! 8: * Copyright (C) 1998 - 2017, Daniel Stenberg, <daniel@haxx.se>, et al.
! 9: *
! 10: * This software is licensed as described in the file COPYING, which
! 11: * you should have received as part of this distribution. The terms
! 12: * are also available at https://curl.haxx.se/docs/copyright.html.
! 13: *
! 14: * You may opt to use, copy, modify, merge, publish, distribute and/or sell
! 15: * copies of the Software, and permit persons to whom the Software is
! 16: * furnished to do so, under the terms of the COPYING file.
! 17: *
! 18: * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
! 19: * KIND, either express or implied.
! 20: *
! 21: ***************************************************************************/
! 22:
! 23: #include "curl_setup.h"
! 24:
! 25: #include <curl/curl.h>
! 26: #include "urldata.h"
! 27: #include "sendf.h"
! 28: #include "multiif.h"
! 29: #include "speedcheck.h"
! 30:
! 31: void Curl_speedinit(struct Curl_easy *data)
! 32: {
! 33: memset(&data->state.keeps_speed, 0, sizeof(struct curltime));
! 34: }
! 35:
! 36: /*
! 37: * @unittest: 1606
! 38: */
! 39: CURLcode Curl_speedcheck(struct Curl_easy *data,
! 40: struct curltime now)
! 41: {
! 42: if((data->progress.current_speed >= 0) && data->set.low_speed_time) {
! 43: if(data->progress.current_speed < data->set.low_speed_limit) {
! 44: if(!data->state.keeps_speed.tv_sec)
! 45: /* under the limit at this very moment */
! 46: data->state.keeps_speed = now;
! 47: else {
! 48: /* how long has it been under the limit */
! 49: timediff_t howlong = Curl_timediff(now, data->state.keeps_speed);
! 50:
! 51: if(howlong >= data->set.low_speed_time * 1000) {
! 52: /* too long */
! 53: failf(data,
! 54: "Operation too slow. "
! 55: "Less than %ld bytes/sec transferred the last %ld seconds",
! 56: data->set.low_speed_limit,
! 57: data->set.low_speed_time);
! 58: return CURLE_OPERATION_TIMEDOUT;
! 59: }
! 60: }
! 61: }
! 62: else
! 63: /* faster right now */
! 64: data->state.keeps_speed.tv_sec = 0;
! 65: }
! 66:
! 67: if(data->set.low_speed_limit)
! 68: /* if low speed limit is enabled, set the expire timer to make this
! 69: connection's speed get checked again in a second */
! 70: Curl_expire(data, 1000, EXPIRE_SPEEDCHECK);
! 71:
! 72: return CURLE_OK;
! 73: }
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>