2009-07-13 21:33:35 +02:00
|
|
|
/** @file
|
|
|
|
This is a test application that demonstrates how to use the sorting functions.
|
|
|
|
|
2010-04-24 14:12:42 +02:00
|
|
|
Copyright (c) 2009 - 2010, Intel Corporation. All rights reserved.<BR>
|
2019-04-04 01:07:06 +02:00
|
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
2009-07-13 21:33:35 +02:00
|
|
|
|
|
|
|
**/
|
|
|
|
|
|
|
|
#include <Uefi.h>
|
|
|
|
#include <Library/UefiLib.h>
|
|
|
|
#include <Library/DebugLib.h>
|
|
|
|
#include <Library/ShellCEntryLib.h>
|
|
|
|
#include <Library/SortLib.h>
|
|
|
|
|
2011-09-12 17:34:11 +02:00
|
|
|
/**
|
|
|
|
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
|
|
|
|
**/
|
2010-09-17 22:08:57 +02:00
|
|
|
INTN
|
|
|
|
EFIAPI
|
2011-09-20 03:34:39 +02:00
|
|
|
Test (
|
|
|
|
CONST VOID *b1,
|
|
|
|
CONST VOID *b2
|
|
|
|
)
|
2009-07-13 21:33:35 +02:00
|
|
|
{
|
|
|
|
if (*(INTN *)b1 == *(INTN *)b2) {
|
|
|
|
return (0);
|
|
|
|
}
|
2021-12-05 23:54:13 +01:00
|
|
|
|
2009-07-13 21:33:35 +02:00
|
|
|
if (*(INTN *)b1 < *(INTN *)b2) {
|
|
|
|
return (-1);
|
|
|
|
}
|
2021-12-05 23:54:13 +01:00
|
|
|
|
2009-07-13 21:33:35 +02:00
|
|
|
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.
|
|
|
|
|
2011-09-02 10:05:34 +02:00
|
|
|
@param Argc Argument count
|
|
|
|
@param Argv The parsed arguments
|
2009-07-13 21:33:35 +02:00
|
|
|
|
|
|
|
@retval 0 The application exited normally.
|
|
|
|
@retval Other An error occurred.
|
|
|
|
|
|
|
|
**/
|
2010-01-25 21:05:08 +01:00
|
|
|
INTN
|
|
|
|
EFIAPI
|
2009-07-13 21:33:35 +02:00
|
|
|
ShellAppMain (
|
2010-01-25 21:05:08 +01:00
|
|
|
IN UINTN Argc,
|
2009-07-13 21:33:35 +02:00
|
|
|
IN CHAR16 **Argv
|
2009-11-18 22:36:50 +01:00
|
|
|
)
|
|
|
|
{
|
2011-09-20 03:34:39 +02:00
|
|
|
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;
|
|
|
|
|
2009-07-13 21:33:35 +02:00
|
|
|
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;
|
|
|
|
}
|