xref: /third_party/curl/lib/splay.h (revision 13498266)
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