These files are a subset of the python-2.7.2.tgz distribution from python.org. Changed files from PyMod-2.7.2 have been copied into the corresponding directories of this tree, replacing the original files in the distribution. Signed-off-by: daryl.mcdaniel@intel.com git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@13197 6f19259b-4bc3-4df7-8a09-765794883524
		
			
				
	
	
		
			28 lines
		
	
	
		
			928 B
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			28 lines
		
	
	
		
			928 B
		
	
	
	
		
			C
		
	
	
	
	
	
/* "Rotating trees" (Armin Rigo)
 | 
						|
 *
 | 
						|
 * Google "splay trees" for the general idea.
 | 
						|
 *
 | 
						|
 * It's a dict-like data structure that works best when accesses are not
 | 
						|
 * random, but follow a strong pattern.  The one implemented here is for
 | 
						|
 * access patterns where the same small set of keys is looked up over
 | 
						|
 * and over again, and this set of keys evolves slowly over time.
 | 
						|
 */
 | 
						|
 | 
						|
#include <stdlib.h>
 | 
						|
 | 
						|
#define EMPTY_ROTATING_TREE       ((rotating_node_t *)NULL)
 | 
						|
 | 
						|
typedef struct rotating_node_s rotating_node_t;
 | 
						|
typedef int (*rotating_tree_enum_fn) (rotating_node_t *node, void *arg);
 | 
						|
 | 
						|
struct rotating_node_s {
 | 
						|
	void *key;
 | 
						|
	rotating_node_t *left;
 | 
						|
	rotating_node_t *right;
 | 
						|
};
 | 
						|
 | 
						|
void RotatingTree_Add(rotating_node_t **root, rotating_node_t *node);
 | 
						|
rotating_node_t* RotatingTree_Get(rotating_node_t **root, void *key);
 | 
						|
int RotatingTree_Enum(rotating_node_t *root, rotating_tree_enum_fn enumfn,
 | 
						|
		      void *arg);
 |