~ubuntu-branches/ubuntu/gutsy/curl/gutsy

« back to all changes in this revision

Viewing changes to lib/splay.h

  • Committer: Bazaar Package Importer
  • Author(s): Martin Pitt
  • Date: 2006-06-29 15:04:24 UTC
  • mto: This revision was merged to the branch mainline in revision 8.
  • Revision ID: james.westby@ubuntu.com-20060629150424-be178abcwks1n519
Tags: upstream-7.15.4
ImportĀ upstreamĀ versionĀ 7.15.4

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
#ifndef __SPLAY_H
 
2
#define __SPLAY_H
 
3
/***************************************************************************
 
4
 *                                  _   _ ____  _
 
5
 *  Project                     ___| | | |  _ \| |
 
6
 *                             / __| | | | |_) | |
 
7
 *                            | (__| |_| |  _ <| |___
 
8
 *                             \___|\___/|_| \_\_____|
 
9
 *
 
10
 * Copyright (C) 1997 - 2006, Daniel Stenberg, <daniel@haxx.se>, et al.
 
11
 *
 
12
 * This software is licensed as described in the file COPYING, which
 
13
 * you should have received as part of this distribution. The terms
 
14
 * are also available at http://curl.haxx.se/docs/copyright.html.
 
15
 *
 
16
 * You may opt to use, copy, modify, merge, publish, distribute and/or sell
 
17
 * copies of the Software, and permit persons to whom the Software is
 
18
 * furnished to do so, under the terms of the COPYING file.
 
19
 *
 
20
 * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
 
21
 * KIND, either express or implied.
 
22
 *
 
23
 * $Id: splay.h,v 1.2 2006-05-27 22:26:41 bagder Exp $
 
24
 ***************************************************************************/
 
25
 
 
26
struct Curl_tree {
 
27
  struct Curl_tree *smaller; /* smaller node */
 
28
  struct Curl_tree *larger;  /* larger node */
 
29
  struct Curl_tree *same;    /* points to a node with identical key */
 
30
  int key;                   /* the "sort" key */
 
31
  void *payload;             /* data the splay code doesn't care about */
 
32
};
 
33
 
 
34
struct Curl_tree *Curl_splay(int i, struct Curl_tree *t);
 
35
struct Curl_tree *Curl_splayinsert(int key, struct Curl_tree *t,
 
36
                                   struct Curl_tree *new);
 
37
#if 0
 
38
struct Curl_tree *Curl_splayremove(int key, struct Curl_tree *t,
 
39
                                   struct Curl_tree **removed);
 
40
#endif
 
41
 
 
42
struct Curl_tree *Curl_splaygetbest(int key, struct Curl_tree *t,
 
43
                                    struct Curl_tree **removed);
 
44
int Curl_splayremovebyaddr(struct Curl_tree *t,
 
45
                           struct Curl_tree *remove,
 
46
                           struct Curl_tree **newroot);
 
47
 
 
48
#ifdef CURLDEBUG
 
49
void Curl_splayprint(struct Curl_tree * t, int d, char output);
 
50
#else
 
51
#define Curl_splayprint(x,y,z)
 
52
#endif
 
53
 
 
54
#endif