mirror of
https://github.com/curl/curl.git
synced 2024-12-09 06:30:06 +08:00
4dee50b9c8
... to make all libcurl internals able to use the same data types for the struct members. The timeval struct differs subtly on several platforms so it makes it cumbersome to use everywhere. Ref: #1652 Closes #1693
62 lines
2.1 KiB
C
62 lines
2.1 KiB
C
#ifndef HEADER_CURL_TIMEVAL_H
|
|
#define HEADER_CURL_TIMEVAL_H
|
|
/***************************************************************************
|
|
* _ _ ____ _
|
|
* Project ___| | | | _ \| |
|
|
* / __| | | | |_) | |
|
|
* | (__| |_| | _ <| |___
|
|
* \___|\___/|_| \_\_____|
|
|
*
|
|
* Copyright (C) 1998 - 2017, 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.haxx.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.
|
|
*
|
|
***************************************************************************/
|
|
|
|
/*
|
|
* CAUTION: this header is designed to work when included by the app-side
|
|
* as well as the library. Do not mix with library internals!
|
|
*/
|
|
|
|
#include "curl_setup.h"
|
|
|
|
struct curltime {
|
|
time_t tv_sec; /* seconds */
|
|
unsigned int tv_usec; /* microseconds */
|
|
};
|
|
|
|
struct curltime curlx_tvnow(void);
|
|
|
|
/*
|
|
* Make sure that the first argument (t1) is the more recent time and t2 is
|
|
* the older time, as otherwise you get a weird negative time-diff back...
|
|
*
|
|
* Returns: the time difference in number of milliseconds.
|
|
*/
|
|
time_t curlx_tvdiff(struct curltime t1, struct curltime t2);
|
|
|
|
/*
|
|
* Make sure that the first argument (t1) is the more recent time and t2 is
|
|
* the older time, as otherwise you get a weird negative time-diff back...
|
|
*
|
|
* Returns: the time difference in number of microseconds.
|
|
*/
|
|
time_t Curl_tvdiff_us(struct curltime newer, struct curltime older);
|
|
|
|
/* These two defines below exist to provide the older API for library
|
|
internals only. */
|
|
#define Curl_tvnow() curlx_tvnow()
|
|
#define Curl_tvdiff(x,y) curlx_tvdiff(x,y)
|
|
|
|
#endif /* HEADER_CURL_TIMEVAL_H */
|
|
|