| /** @file | |
| This is a test application that demonstrates how to use the sorting functions. | |
| Copyright (c) 2009 - 2010, Intel Corporation. All rights reserved.<BR> | |
| 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 <Uefi.h> | |
| #include <Library/UefiLib.h> | |
| #include <Library/DebugLib.h> | |
| #include <Library/ShellCEntryLib.h> | |
| #include <Library/SortLib.h> | |
| /** | |
| 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; | |
| } |