/** @file This is a test application that demonstrates how to use the sorting functions. Copyright (c) 2009 - 2010, Intel Corporation. All rights reserved.
This program and the accompanying materials are licensed and made available under the terms and conditions of the BSD License which accompanies this distribution. The full text of the license may be found at http://opensource.org/licenses/bsd-license.php THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. **/ #include #include #include #include #include /** Test comparator. @param[in] b1 The first INTN @param[in] b2 The other INTN @retval 0 They are the same. @retval -1 b1 is less than b2 @retval 1 b1 is greater then b2 **/ INTN EFIAPI Test(CONST VOID *b1, CONST VOID *b2) { if (*(INTN*)b1 == *(INTN*)b2) { return (0); } if (*(INTN*)b1 < *(INTN*)b2) { return(-1); } return (1); } /** UEFI application entry point which has an interface similar to a standard C main function. The ShellCEntryLib library instance wrappers the actual UEFI application entry point and calls this ShellAppMain function. @param Argc Argument count @param Argv The parsed arguments @retval 0 The application exited normally. @retval Other An error occurred. **/ INTN EFIAPI ShellAppMain ( IN UINTN Argc, IN CHAR16 **Argv ) { INTN Array[10]; Array[0] = 2; Array[1] = 3; Array[2] = 4; Array[3] = 1; Array[4] = 5; Array[5] = 6; Array[6] = 7; Array[7] = 8; Array[8] = 1; Array[9] = 5; Print(L"Array = %d, %d, %d, %d, %d, %d, %d, %d, %d, %d\r\n", Array[0],Array[1],Array[2],Array[3],Array[4],Array[5],Array[6],Array[7],Array[8],Array[9]); PerformQuickSort(Array, 10, sizeof(INTN), Test); Print(L"POST-SORT\r\n"); Print(L"Array = %d, %d, %d, %d, %d, %d, %d, %d, %d, %d\r\n", Array[0],Array[1],Array[2],Array[3],Array[4],Array[5],Array[6],Array[7],Array[8],Array[9]); return 0; }