35 lines
		
	
	
		
			924 B
		
	
	
	
		
			C
		
	
	
			
		
		
	
	
			35 lines
		
	
	
		
			924 B
		
	
	
	
		
			C
		
	
	
| /*
 | |
| Copyright 2020 Google LLC
 | |
| 
 | |
| Use of this source code is governed by a BSD-style
 | |
| license that can be found in the LICENSE file or at
 | |
| https://developers.google.com/open-source/licenses/bsd
 | |
| */
 | |
| 
 | |
| #ifndef TREE_H
 | |
| #define TREE_H
 | |
| 
 | |
| /* tree_node is a generic binary search tree. */
 | |
| struct tree_node {
 | |
| 	void *key;
 | |
| 	struct tree_node *left, *right;
 | |
| };
 | |
| 
 | |
| /* looks for `key` in `rootp` using `compare` as comparison function. If insert
 | |
|  * is set, insert the key if it's not found. Else, return NULL.
 | |
|  */
 | |
| struct tree_node *tree_search(void *key, struct tree_node **rootp,
 | |
| 			      int (*compare)(const void *, const void *),
 | |
| 			      int insert);
 | |
| 
 | |
| /* performs an infix walk of the tree. */
 | |
| void infix_walk(struct tree_node *t, void (*action)(void *arg, void *key),
 | |
| 		void *arg);
 | |
| 
 | |
| /*
 | |
|  * deallocates the tree nodes recursively. Keys should be deallocated separately
 | |
|  * by walking over the tree. */
 | |
| void tree_free(struct tree_node *t);
 | |
| 
 | |
| #endif
 |