mirror of
				https://github.com/MariaDB/server.git
				synced 2025-11-04 04:46:15 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			104 lines
		
	
	
	
		
			3.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			104 lines
		
	
	
	
		
			3.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/*****************************************************************************
 | 
						|
 | 
						|
Copyright (c) 1995, 2009, Oracle and/or its affiliates. All Rights Reserved.
 | 
						|
 | 
						|
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; version 2 of the License.
 | 
						|
 | 
						|
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.,
 | 
						|
51 Franklin Street, Fifth Floor, Boston, MA 02110-1335 USA
 | 
						|
 | 
						|
*****************************************************************************/
 | 
						|
 | 
						|
/******************************************************************//**
 | 
						|
@file include/ut0sort.h
 | 
						|
Sort utility
 | 
						|
 | 
						|
Created 11/9/1995 Heikki Tuuri
 | 
						|
***********************************************************************/
 | 
						|
 | 
						|
#ifndef ut0sort_h
 | 
						|
#define ut0sort_h
 | 
						|
 | 
						|
/* This module gives a macro definition of the body of
 | 
						|
a standard sort function for an array of elements of any
 | 
						|
type. The comparison function is given as a parameter to
 | 
						|
the macro. The sort algorithm is mergesort which has logarithmic
 | 
						|
worst case.
 | 
						|
*/
 | 
						|
 | 
						|
/*******************************************************************//**
 | 
						|
This macro expands to the body of a standard sort function.
 | 
						|
The sort function uses mergesort and must be defined separately
 | 
						|
for each type of array.
 | 
						|
Also the comparison function has to be defined individually
 | 
						|
for each array cell type. SORT_FUN is the sort function name.
 | 
						|
The function takes the array to be sorted (ARR),
 | 
						|
the array of auxiliary space (AUX_ARR) of same size,
 | 
						|
and the low (LOW), inclusive, and high (HIGH), noninclusive,
 | 
						|
limits for the sort interval as arguments.
 | 
						|
CMP_FUN is the comparison function name. It takes as arguments
 | 
						|
two elements from the array and returns 1, if the first is bigger,
 | 
						|
0 if equal, and -1 if the second bigger. */
 | 
						|
 | 
						|
#define UT_SORT_FUNCTION_BODY(SORT_FUN, ARR, AUX_ARR, LOW, HIGH, CMP_FUN)\
 | 
						|
{\
 | 
						|
	ulint		ut_sort_mid77;\
 | 
						|
	ulint		ut_sort_i77;\
 | 
						|
	ulint		ut_sort_low77;\
 | 
						|
	ulint		ut_sort_high77;\
 | 
						|
\
 | 
						|
	ut_ad((LOW) < (HIGH));\
 | 
						|
	ut_ad(ARR);\
 | 
						|
	ut_ad(AUX_ARR);\
 | 
						|
\
 | 
						|
	if ((LOW) == (HIGH) - 1) {\
 | 
						|
		return;\
 | 
						|
	} else if ((LOW) == (HIGH) - 2) {\
 | 
						|
		if (CMP_FUN((ARR)[LOW], (ARR)[(HIGH) - 1]) > 0) {\
 | 
						|
			(AUX_ARR)[LOW] = (ARR)[LOW];\
 | 
						|
			(ARR)[LOW] = (ARR)[(HIGH) - 1];\
 | 
						|
			(ARR)[(HIGH) - 1] = (AUX_ARR)[LOW];\
 | 
						|
		}\
 | 
						|
		return;\
 | 
						|
	}\
 | 
						|
\
 | 
						|
	ut_sort_mid77 = ((LOW) + (HIGH)) / 2;\
 | 
						|
\
 | 
						|
	SORT_FUN((ARR), (AUX_ARR), (LOW), ut_sort_mid77);\
 | 
						|
	SORT_FUN((ARR), (AUX_ARR), ut_sort_mid77, (HIGH));\
 | 
						|
\
 | 
						|
	ut_sort_low77 = (LOW);\
 | 
						|
	ut_sort_high77 = ut_sort_mid77;\
 | 
						|
\
 | 
						|
	for (ut_sort_i77 = (LOW); ut_sort_i77 < (HIGH); ut_sort_i77++) {\
 | 
						|
\
 | 
						|
		if (ut_sort_low77 >= ut_sort_mid77) {\
 | 
						|
			(AUX_ARR)[ut_sort_i77] = (ARR)[ut_sort_high77];\
 | 
						|
			ut_sort_high77++;\
 | 
						|
		} else if (ut_sort_high77 >= (HIGH)) {\
 | 
						|
			(AUX_ARR)[ut_sort_i77] = (ARR)[ut_sort_low77];\
 | 
						|
			ut_sort_low77++;\
 | 
						|
		} else if (CMP_FUN((ARR)[ut_sort_low77],\
 | 
						|
				   (ARR)[ut_sort_high77]) > 0) {\
 | 
						|
			(AUX_ARR)[ut_sort_i77] = (ARR)[ut_sort_high77];\
 | 
						|
			ut_sort_high77++;\
 | 
						|
		} else {\
 | 
						|
			(AUX_ARR)[ut_sort_i77] = (ARR)[ut_sort_low77];\
 | 
						|
			ut_sort_low77++;\
 | 
						|
		}\
 | 
						|
	}\
 | 
						|
\
 | 
						|
	memcpy((void*) ((ARR) + (LOW)), (AUX_ARR) + (LOW),\
 | 
						|
	       ((HIGH) - (LOW)) * sizeof *(ARR));\
 | 
						|
}\
 | 
						|
 | 
						|
 | 
						|
#endif
 | 
						|
 |