113498266Sopenharmony_ci#ifndef HEADER_CURL_SPLAY_H 213498266Sopenharmony_ci#define HEADER_CURL_SPLAY_H 313498266Sopenharmony_ci/*************************************************************************** 413498266Sopenharmony_ci * _ _ ____ _ 513498266Sopenharmony_ci * Project ___| | | | _ \| | 613498266Sopenharmony_ci * / __| | | | |_) | | 713498266Sopenharmony_ci * | (__| |_| | _ <| |___ 813498266Sopenharmony_ci * \___|\___/|_| \_\_____| 913498266Sopenharmony_ci * 1013498266Sopenharmony_ci * Copyright (C) Daniel Stenberg, <daniel@haxx.se>, et al. 1113498266Sopenharmony_ci * 1213498266Sopenharmony_ci * This software is licensed as described in the file COPYING, which 1313498266Sopenharmony_ci * you should have received as part of this distribution. The terms 1413498266Sopenharmony_ci * are also available at https://curl.se/docs/copyright.html. 1513498266Sopenharmony_ci * 1613498266Sopenharmony_ci * You may opt to use, copy, modify, merge, publish, distribute and/or sell 1713498266Sopenharmony_ci * copies of the Software, and permit persons to whom the Software is 1813498266Sopenharmony_ci * furnished to do so, under the terms of the COPYING file. 1913498266Sopenharmony_ci * 2013498266Sopenharmony_ci * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY 2113498266Sopenharmony_ci * KIND, either express or implied. 2213498266Sopenharmony_ci * 2313498266Sopenharmony_ci * SPDX-License-Identifier: curl 2413498266Sopenharmony_ci * 2513498266Sopenharmony_ci ***************************************************************************/ 2613498266Sopenharmony_ci#include "curl_setup.h" 2713498266Sopenharmony_ci#include "timeval.h" 2813498266Sopenharmony_ci 2913498266Sopenharmony_cistruct Curl_tree { 3013498266Sopenharmony_ci struct Curl_tree *smaller; /* smaller node */ 3113498266Sopenharmony_ci struct Curl_tree *larger; /* larger node */ 3213498266Sopenharmony_ci struct Curl_tree *samen; /* points to the next node with identical key */ 3313498266Sopenharmony_ci struct Curl_tree *samep; /* points to the prev node with identical key */ 3413498266Sopenharmony_ci struct curltime key; /* this node's "sort" key */ 3513498266Sopenharmony_ci void *payload; /* data the splay code doesn't care about */ 3613498266Sopenharmony_ci}; 3713498266Sopenharmony_ci 3813498266Sopenharmony_cistruct Curl_tree *Curl_splay(struct curltime i, 3913498266Sopenharmony_ci struct Curl_tree *t); 4013498266Sopenharmony_ci 4113498266Sopenharmony_cistruct Curl_tree *Curl_splayinsert(struct curltime key, 4213498266Sopenharmony_ci struct Curl_tree *t, 4313498266Sopenharmony_ci struct Curl_tree *newnode); 4413498266Sopenharmony_ci 4513498266Sopenharmony_cistruct Curl_tree *Curl_splaygetbest(struct curltime key, 4613498266Sopenharmony_ci struct Curl_tree *t, 4713498266Sopenharmony_ci struct Curl_tree **removed); 4813498266Sopenharmony_ci 4913498266Sopenharmony_ciint Curl_splayremove(struct Curl_tree *t, 5013498266Sopenharmony_ci struct Curl_tree *removenode, 5113498266Sopenharmony_ci struct Curl_tree **newroot); 5213498266Sopenharmony_ci 5313498266Sopenharmony_ci#define Curl_splaycomparekeys(i,j) ( ((i.tv_sec) < (j.tv_sec)) ? -1 : \ 5413498266Sopenharmony_ci ( ((i.tv_sec) > (j.tv_sec)) ? 1 : \ 5513498266Sopenharmony_ci ( ((i.tv_usec) < (j.tv_usec)) ? -1 : \ 5613498266Sopenharmony_ci ( ((i.tv_usec) > (j.tv_usec)) ? 1 : 0)))) 5713498266Sopenharmony_ci 5813498266Sopenharmony_ci#endif /* HEADER_CURL_SPLAY_H */ 59