00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034
00035
00036
00037 #ifndef lint
00038 static const char libbu_rb_extreme_RCSid[] = "@(#) $Header: /cvsroot/brlcad/brlcad/src/libbu/rb_extreme.c,v 14.13 2006/08/31 23:16:38 lbutler Exp $";
00039 #endif
00040
00041 #include "common.h"
00042
00043 #include <stdlib.h>
00044 #include <stdio.h>
00045 #include <math.h>
00046
00047 #include "machine.h"
00048 #include "rtlist.h"
00049 #include "bu.h"
00050 #include "compat4.h"
00051 #include "./rb_internals.h"
00052
00053
00054
00055
00056
00057
00058
00059
00060
00061
00062
00063 static struct bu_rb_node *_rb_extreme (struct bu_rb_node *root, int order, int sense, struct bu_rb_node *empty_node)
00064 {
00065 struct bu_rb_node *child;
00066 bu_rb_tree *tree;
00067
00068 if (root == empty_node)
00069 return (root);
00070
00071 while (1)
00072 {
00073 BU_CKMAG(root, BU_RB_NODE_MAGIC, "red-black node");
00074 tree = root -> rbn_tree;
00075 BU_RB_CKORDER(tree, order);
00076
00077 child = (sense == SENSE_MIN) ? bu_rb_left_child(root, order) :
00078 bu_rb_right_child(root, order);
00079 if (child == empty_node)
00080 break;
00081 root = child;
00082 }
00083
00084
00085 bu_rb_current(tree) = root;
00086
00087 return (root);
00088 }
00089
00090
00091
00092
00093
00094
00095
00096
00097
00098
00099 void *bu_rb_extreme (bu_rb_tree *tree, int order, int sense)
00100 {
00101 struct bu_rb_node *node;
00102
00103 BU_CKMAG(tree, BU_RB_TREE_MAGIC, "red-black tree");
00104 BU_RB_CKORDER(tree, order);
00105
00106 if ((sense != SENSE_MIN) && (sense != SENSE_MAX))
00107 {
00108 bu_log("FATAL: bu_rb_extreme(): invalid sense %d, file %s, line %s\n",
00109 sense, __FILE__, __LINE__);
00110 bu_bomb("");
00111 }
00112
00113
00114 node = _rb_extreme(bu_rb_root(tree, order), order, sense,
00115 bu_rb_null(tree));
00116
00117 if (node == bu_rb_null(tree))
00118 return (NULL);
00119 else
00120 return (bu_rb_data(node, order));
00121 }
00122
00123
00124
00125
00126
00127
00128
00129
00130
00131
00132
00133 struct bu_rb_node *_rb_neighbor (struct bu_rb_node *node, int order, int sense)
00134 {
00135 struct bu_rb_node *child;
00136 struct bu_rb_node *parent;
00137 bu_rb_tree *tree;
00138 struct bu_rb_node *empty_node;
00139
00140 BU_CKMAG(node, BU_RB_NODE_MAGIC, "red-black node");
00141 tree = node -> rbn_tree;
00142 BU_RB_CKORDER(tree, order);
00143
00144 empty_node = bu_rb_null(tree);
00145
00146 child = (sense == SENSE_MIN) ? bu_rb_left_child(node, order) :
00147 bu_rb_right_child(node, order);
00148 if (child != empty_node)
00149 return (_rb_extreme(child, order, 1 - sense, empty_node));
00150 parent = bu_rb_parent(node, order);
00151 while ((parent != empty_node) &&
00152 (node == bu_rb_child(parent, order, sense)))
00153 {
00154 node = parent;
00155 parent = bu_rb_parent(parent, order);
00156 }
00157
00158
00159 bu_rb_current(tree) = parent;
00160
00161 return (parent);
00162 }
00163
00164
00165
00166
00167
00168
00169
00170
00171
00172
00173
00174
00175 void *bu_rb_neighbor (bu_rb_tree *tree, int order, int sense)
00176 {
00177 struct bu_rb_node *node;
00178
00179 BU_CKMAG(tree, BU_RB_TREE_MAGIC, "red-black tree");
00180 BU_RB_CKORDER(tree, order);
00181
00182 if ((sense != SENSE_MIN) && (sense != SENSE_MAX))
00183 {
00184 bu_log("FATAL: bu_rb_neighbor(): invalid sense %d, file %s, line %s\n",
00185 sense, __FILE__, __LINE__);
00186 bu_bomb("");
00187 }
00188
00189
00190 node = _rb_neighbor(bu_rb_current(tree), order, sense);
00191
00192 if (node == bu_rb_null(tree))
00193 return (NULL);
00194 else
00195 {
00196
00197 bu_rb_current(tree) = node;
00198 return (bu_rb_data(node, order));
00199 }
00200 }
00201
00202
00203
00204
00205
00206
00207
00208
00209
00210
00211 void *bu_rb_curr (bu_rb_tree *tree, int order)
00212 {
00213 BU_CKMAG(tree, BU_RB_TREE_MAGIC, "red-black tree");
00214 BU_RB_CKORDER(tree, order);
00215
00216 if (bu_rb_current(tree) == bu_rb_null(tree))
00217 return (NULL);
00218 else
00219 return (bu_rb_data(bu_rb_current(tree), order));
00220 }
00221
00222
00223
00224
00225
00226
00227
00228
00229
00230