home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
OS/2 Shareware BBS: 10 Tools
/
10-Tools.zip
/
mitsch75.zip
/
scheme-7_5_17-src.zip
/
scheme-7.5.17
/
src
/
microcode
/
avltree.h
< prev
next >
Wrap
C/C++ Source or Header
|
2001-03-08
|
2KB
|
53 lines
/* -*-C-*-
$Id: avltree.h,v 1.4 2001/03/08 18:00:16 cph Exp $
Copyright (c) 1993, 1999-2001 Massachusetts Institute of Technology
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or (at
your option) any later version.
This program is distributed in the hope that it will be useful, but
WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
*/
#ifndef AVLTREE_H
#define AVLTREE_H
/* This file contains external declarations for a simple
AVL tree library.
It is used by the MIT Scheme microcode to quickly map
names to indices into various tables. */
#include "config.h"
extern CONST char * tree_error_message;
extern CONST char * tree_error_noise;
typedef struct tree_node_s * tree_node;
struct tree_node_s
{
int height;
tree_node left;
tree_node rite;
CONST char * name;
unsigned long value;
};
extern tree_node EXFUN
(tree_build, (unsigned long, CONST char **, unsigned long));
extern tree_node EXFUN (tree_lookup, (tree_node, CONST char *));
extern tree_node EXFUN (tree_insert, (tree_node, CONST char *, unsigned long));
extern void EXFUN (tree_free, (tree_node));
#endif /* AVLTREE_H */