mirror of
git://gcc.gnu.org/git/gcc.git
synced 2025-01-15 17:15:19 +08:00
d1b382088a
2009-04-21 Taras Glek <tglek@mozilla.com> * include/hashtab.h: Update GTY annotations to new syntax * include/splay-tree.h: Likewise gcc/ChangeLog 2009-04-21 Taras Glek <tglek@mozilla.com> * alias.c: Update GTY annotations to new syntax * basic-block.h: Likewise * bitmap.h: Likewise * c-common.h: Likewise * c-decl.c: Likewise * c-parser.c: Likewise * c-pragma.c: Likewise * c-tree.h: Likewise * cfgloop.h: Likewise * cgraph.h: Likewise * config/alpha/alpha.c: Likewise * config/arm/arm.h: Likewise * config/avr/avr.h: Likewise * config/bfin/bfin.c: Likewise * config/cris/cris.c: Likewise * config/darwin.c: Likewise * config/frv/frv.c: Likewise * config/i386/i386.c: Likewise * config/i386/i386.h: Likewise * config/i386/winnt.c: Likewise * config/ia64/ia64.h: Likewise * config/iq2000/iq2000.c: Likewise * config/mips/mips.c: Likewise * config/mmix/mmix.h: Likewise * config/pa/pa.c: Likewise * config/pa/pa.h: Likewise * config/rs6000/rs6000.c: Likewise * config/s390/s390.c: Likewise * config/sparc/sparc.c: Likewise * config/xtensa/xtensa.c: Likewise * cselib.h: Likewise * dbxout.c: Likewise * dwarf2out.c: Likewise * except.c: Likewise * except.h: Likewise * fixed-value.h: Likewise * function.c: Likewise * function.h: Likewise * gimple.h: Likewise * integrate.c: Likewise * optabs.c: Likewise * output.h: Likewise * real.h: Likewise * rtl.h: Likewise * stringpool.c: Likewise * tree-data-ref.c: Likewise * tree-flow.h: Likewise * tree-scalar-evolution.c: Likewise * tree-ssa-address.c: Likewise * tree-ssa-alias.h: Likewise * tree-ssa-operands.h: Likewise * tree.c: Likewise * tree.h: Likewise * varasm.c: Likewise * varray.h: Likewise * vec.h: Likewise * coretypes.h: Do not define GTY macro if it is already defined * doc/gty.texi: Update GTY documentation to new syntax * gengtype-lex.l: Enforce attribute-like syntax for GTY annotations on structs * gengtype-parse.c: Likewise gcc/ada/ChangeLog 2009-04-21 Taras Glek <tglek@mozilla.com> * gcc-interface/ada-tree.h: Update GTY annotations to new syntax * gcc-interface/trans.c: Likewise * gcc-interface/utils.c: Likewise gcc/cp/ChangeLog 2009-04-21 Taras Glek <tglek@mozilla.com> * cp-tree.h: Update GTY annotations to new syntax * decl.c: Likewise * mangle.c: Likewise * name-lookup.c: Likewise * name-lookup.h: Likewise * parser.c: Likewise * pt.c: Likewise * rtti.c: Likewise * semantics.c: Likewise * typeck2.c: Likewise gcc/fortran/ChangeLog 2009-04-21 Taras Glek <tglek@mozilla.com> * f95-lang.c: Update GTY annotations to new syntax * trans-intrinsic.c: Likewise * trans-io.c: Likewise * trans.h: Likewise gcc/java/ChangeLog 2009-04-21 Taras Glek <tglek@mozilla.com> * builtins.c: Update GTY annotations to new syntax * decl.c: Likewise * java-tree.h: Likewise * jcf.h: Likewise * lang.c: Likewise gcc/objc/ChangeLog 2009-04-21 Taras Glek <tglek@mozilla.com> * objc-act.c: Update GTY annotations to new syntax * objc-act.h: Likewise libcpp/ChangeLog 2009-04-21 Taras Glek <tglek@mozilla.com> * include/cpp-id-data.h: Update GTY annotations to new syntax * include/cpplib.h: Likewise * include/line-map.h: Likewise * include/symtab.h: Likewise From-SVN: r146607
151 lines
5.3 KiB
C
151 lines
5.3 KiB
C
/* A splay-tree datatype.
|
|
Copyright 1998, 1999, 2000, 2002, 2007 Free Software Foundation, Inc.
|
|
Contributed by Mark Mitchell (mark@markmitchell.com).
|
|
|
|
This file is part of GCC.
|
|
|
|
GCC 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, or (at your option)
|
|
any later version.
|
|
|
|
GCC 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 GCC; see the file COPYING. If not, write to
|
|
the Free Software Foundation, 51 Franklin Street - Fifth Floor,
|
|
Boston, MA 02110-1301, USA. */
|
|
|
|
/* For an easily readable description of splay-trees, see:
|
|
|
|
Lewis, Harry R. and Denenberg, Larry. Data Structures and Their
|
|
Algorithms. Harper-Collins, Inc. 1991.
|
|
|
|
The major feature of splay trees is that all basic tree operations
|
|
are amortized O(log n) time for a tree with n nodes. */
|
|
|
|
#ifndef _SPLAY_TREE_H
|
|
#define _SPLAY_TREE_H
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif /* __cplusplus */
|
|
|
|
#include "ansidecl.h"
|
|
|
|
#ifndef _WIN64
|
|
typedef unsigned long int libi_uhostptr_t;
|
|
typedef long int libi_shostptr_t;
|
|
#else
|
|
typedef unsigned long long libi_uhostptr_t;
|
|
typedef long long libi_shostptr_t;
|
|
#endif
|
|
|
|
#ifndef GTY
|
|
#define GTY(X)
|
|
#endif
|
|
|
|
/* Use typedefs for the key and data types to facilitate changing
|
|
these types, if necessary. These types should be sufficiently wide
|
|
that any pointer or scalar can be cast to these types, and then
|
|
cast back, without loss of precision. */
|
|
typedef libi_uhostptr_t splay_tree_key;
|
|
typedef libi_uhostptr_t splay_tree_value;
|
|
|
|
/* Forward declaration for a node in the tree. */
|
|
typedef struct splay_tree_node_s *splay_tree_node;
|
|
|
|
/* The type of a function which compares two splay-tree keys. The
|
|
function should return values as for qsort. */
|
|
typedef int (*splay_tree_compare_fn) (splay_tree_key, splay_tree_key);
|
|
|
|
/* The type of a function used to deallocate any resources associated
|
|
with the key. */
|
|
typedef void (*splay_tree_delete_key_fn) (splay_tree_key);
|
|
|
|
/* The type of a function used to deallocate any resources associated
|
|
with the value. */
|
|
typedef void (*splay_tree_delete_value_fn) (splay_tree_value);
|
|
|
|
/* The type of a function used to iterate over the tree. */
|
|
typedef int (*splay_tree_foreach_fn) (splay_tree_node, void*);
|
|
|
|
/* The type of a function used to allocate memory for tree root and
|
|
node structures. The first argument is the number of bytes needed;
|
|
the second is a data pointer the splay tree functions pass through
|
|
to the allocator. This function must never return zero. */
|
|
typedef void *(*splay_tree_allocate_fn) (int, void *);
|
|
|
|
/* The type of a function used to free memory allocated using the
|
|
corresponding splay_tree_allocate_fn. The first argument is the
|
|
memory to be freed; the latter is a data pointer the splay tree
|
|
functions pass through to the freer. */
|
|
typedef void (*splay_tree_deallocate_fn) (void *, void *);
|
|
|
|
/* The nodes in the splay tree. */
|
|
struct GTY(()) splay_tree_node_s {
|
|
/* The key. */
|
|
splay_tree_key GTY ((use_param1)) key;
|
|
|
|
/* The value. */
|
|
splay_tree_value GTY ((use_param2)) value;
|
|
|
|
/* The left and right children, respectively. */
|
|
splay_tree_node GTY ((use_params)) left;
|
|
splay_tree_node GTY ((use_params)) right;
|
|
};
|
|
|
|
/* The splay tree itself. */
|
|
struct GTY(()) splay_tree_s {
|
|
/* The root of the tree. */
|
|
splay_tree_node GTY ((use_params)) root;
|
|
|
|
/* The comparision function. */
|
|
splay_tree_compare_fn comp;
|
|
|
|
/* The deallocate-key function. NULL if no cleanup is necessary. */
|
|
splay_tree_delete_key_fn delete_key;
|
|
|
|
/* The deallocate-value function. NULL if no cleanup is necessary. */
|
|
splay_tree_delete_value_fn delete_value;
|
|
|
|
/* Allocate/free functions, and a data pointer to pass to them. */
|
|
splay_tree_allocate_fn allocate;
|
|
splay_tree_deallocate_fn deallocate;
|
|
void * GTY((skip)) allocate_data;
|
|
};
|
|
|
|
typedef struct splay_tree_s *splay_tree;
|
|
|
|
extern splay_tree splay_tree_new (splay_tree_compare_fn,
|
|
splay_tree_delete_key_fn,
|
|
splay_tree_delete_value_fn);
|
|
extern splay_tree splay_tree_new_with_allocator (splay_tree_compare_fn,
|
|
splay_tree_delete_key_fn,
|
|
splay_tree_delete_value_fn,
|
|
splay_tree_allocate_fn,
|
|
splay_tree_deallocate_fn,
|
|
void *);
|
|
extern void splay_tree_delete (splay_tree);
|
|
extern splay_tree_node splay_tree_insert (splay_tree,
|
|
splay_tree_key,
|
|
splay_tree_value);
|
|
extern void splay_tree_remove (splay_tree, splay_tree_key);
|
|
extern splay_tree_node splay_tree_lookup (splay_tree, splay_tree_key);
|
|
extern splay_tree_node splay_tree_predecessor (splay_tree, splay_tree_key);
|
|
extern splay_tree_node splay_tree_successor (splay_tree, splay_tree_key);
|
|
extern splay_tree_node splay_tree_max (splay_tree);
|
|
extern splay_tree_node splay_tree_min (splay_tree);
|
|
extern int splay_tree_foreach (splay_tree, splay_tree_foreach_fn, void*);
|
|
extern int splay_tree_compare_ints (splay_tree_key, splay_tree_key);
|
|
extern int splay_tree_compare_pointers (splay_tree_key, splay_tree_key);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif /* __cplusplus */
|
|
|
|
#endif /* _SPLAY_TREE_H */
|