Upgrade ShellLib and fix bug with param parsing

git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@9398 6f19259b-4bc3-4df7-8a09-765794883524
This commit is contained in:
jcarsey 2009-11-09 18:08:58 +00:00
parent b303ea726e
commit 2247dde4b6
3 changed files with 368 additions and 105 deletions

View File

@ -647,13 +647,17 @@ extern SHELL_PARAM_ITEM EmptyParamList[];
**/ **/
EFI_STATUS EFI_STATUS
EFIAPI EFIAPI
ShellCommandLineParse ( ShellCommandLineParseEx (
IN CONST SHELL_PARAM_ITEM *CheckList, IN CONST SHELL_PARAM_ITEM *CheckList,
OUT LIST_ENTRY **CheckPackage, OUT LIST_ENTRY **CheckPackage,
OUT CHAR16 **ProblemParam OPTIONAL, OUT CHAR16 **ProblemParam OPTIONAL,
IN BOOLEAN AutoPageBreak IN BOOLEAN AutoPageBreak,
IN BOOLEAN AlwaysAllowNumbers
); );
// make it easy to upgrade from older versions of the shell library.
#define ShellCommandLineParse(CheckList,CheckPackage,ProblemParam,AutoPageBreak) ShellCommandLineParseEx(CheckList,CheckPackage,ProblemParam,AutoPageBreak,FALSE)
/** /**
Frees shell variable list that was returned from ShellCommandLineParse. Frees shell variable list that was returned from ShellCommandLineParse.
@ -733,6 +737,20 @@ ShellCommandLineGetRawValue (
IN UINT32 Position IN UINT32 Position
); );
/**
returns the number of command line value parameters that were parsed.
this will not include flags.
@retval (UINTN)-1 No parsing has ocurred
@return other The number of value parameters found
**/
UINTN
EFIAPI
ShellCommandLineGetCount(
VOID
);
/** /**
This function causes the shell library to initialize itself. If the shell library This function causes the shell library to initialize itself. If the shell library
is already initialized it will de-initialize all the current protocol poitners and is already initialized it will de-initialize all the current protocol poitners and
@ -789,4 +807,59 @@ ShellPrintEx(
... ...
); );
/**
Print at a specific location on the screen.
This function will move the cursor to a given screen location, print the specified string,
and return the cursor to the original locaiton.
If -1 is specified for either the Row or Col the current screen location for BOTH
will be used and the cursor's position will not be moved back to an original location.
if either Row or Col is out of range for the current console, then ASSERT
if Format is NULL, then ASSERT
In addition to the standard %-based flags as supported by UefiLib Print() this supports
the following additional flags:
%N - Set output attribute to normal
%H - Set output attribute to highlight
%E - Set output attribute to error
%B - Set output attribute to blue color
%V - Set output attribute to green color
Note: The background color is controlled by the shell command cls.
@param[in] Row the row to print at
@param[in] Col the column to print at
@param[in] HiiFormatStringId the format string Id for getting from Hii
@param[in] HiiFormatHandle the format string Handle for getting from Hii
@return the number of characters printed to the screen
**/
UINTN
EFIAPI
ShellPrintHiiEx(
IN INT32 Col OPTIONAL,
IN INT32 Row OPTIONAL,
IN CONST EFI_STRING_ID HiiFormatStringId,
IN CONST EFI_HANDLE HiiFormatHandle,
...
);
/**
Function to determine if a given filename represents a file or a directory.
@param[in] DirName Path to directory to test.
@retval EFI_SUCCESS The Path represents a directory
@retval EFI_NOT_FOUND The Path does not represent a directory
@return other The path failed to open
**/
EFI_STATUS
EFIAPI
ShellIsDirectory(
IN CONST CHAR16 *DirName
);
#endif // __SHELL_LIB__ #endif // __SHELL_LIB__

View File

@ -24,6 +24,7 @@ WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
#include <Library/FileHandleLib.h> #include <Library/FileHandleLib.h>
#include <Library/PrintLib.h> #include <Library/PrintLib.h>
#include <Library/UefiLib.h> #include <Library/UefiLib.h>
#include <Library/HiiLib.h>
#include <Protocol/EfiShellEnvironment2.h> #include <Protocol/EfiShellEnvironment2.h>
#include <Protocol/EfiShellInterface.h> #include <Protocol/EfiShellInterface.h>
@ -52,6 +53,29 @@ STATIC EFI_SHELL_PROTOCOL *mEfiShellProtocol;
STATIC EFI_SHELL_PARAMETERS_PROTOCOL *mEfiShellParametersProtocol; STATIC EFI_SHELL_PARAMETERS_PROTOCOL *mEfiShellParametersProtocol;
STATIC EFI_HANDLE mEfiShellEnvironment2Handle; STATIC EFI_HANDLE mEfiShellEnvironment2Handle;
STATIC FILE_HANDLE_FUNCTION_MAP FileFunctionMap; STATIC FILE_HANDLE_FUNCTION_MAP FileFunctionMap;
STATIC UINTN mTotalParameterCount;
/**
Check if a Unicode character is a hexadecimal character.
This internal function checks if a Unicode character is a
decimal character. The valid hexadecimal character is
L'0' to L'9', L'a' to L'f', or L'A' to L'F'.
@param Char The character to check against.
@retval TRUE If the Char is a hexadecmial character.
@retval FALSE If the Char is not a hexadecmial character.
**/
BOOLEAN
EFIAPI
ShellInternalIsHexaDecimalDigitCharacter (
IN CHAR16 Char
) {
return (BOOLEAN) ((Char >= L'0' && Char <= L'9') || (Char >= L'A' && Char <= L'F') || (Char >= L'a' && Char <= L'f'));
}
/** /**
helper function to find ShellEnvironment2 for constructor helper function to find ShellEnvironment2 for constructor
@ -60,8 +84,7 @@ EFI_STATUS
EFIAPI EFIAPI
ShellFindSE2 ( ShellFindSE2 (
IN EFI_HANDLE ImageHandle IN EFI_HANDLE ImageHandle
) ) {
{
EFI_STATUS Status; EFI_STATUS Status;
EFI_HANDLE *Buffer; EFI_HANDLE *Buffer;
UINTN BufferSize; UINTN BufferSize;
@ -89,15 +112,19 @@ ShellFindSE2 (
&BufferSize, &BufferSize,
Buffer Buffer
); );
ASSERT(Status == EFI_BUFFER_TOO_SMALL); //
Buffer = (EFI_HANDLE*)AllocatePool(BufferSize); // maybe it's not there???
ASSERT(Buffer != NULL); //
Status = gBS->LocateHandle (ByProtocol, if (Status == EFI_BUFFER_TOO_SMALL) {
&gEfiShellEnvironment2Guid, Buffer = (EFI_HANDLE*)AllocatePool(BufferSize);
NULL, // ignored for ByProtocol ASSERT(Buffer != NULL);
&BufferSize, Status = gBS->LocateHandle (ByProtocol,
Buffer &gEfiShellEnvironment2Guid,
); NULL, // ignored for ByProtocol
&BufferSize,
Buffer
);
}
if (!EFI_ERROR (Status)) { if (!EFI_ERROR (Status)) {
// //
// now parse the list of returned handles // now parse the list of returned handles
@ -130,9 +157,14 @@ EFIAPI
ShellLibConstructorWorker ( ShellLibConstructorWorker (
IN EFI_HANDLE ImageHandle, IN EFI_HANDLE ImageHandle,
IN EFI_SYSTEM_TABLE *SystemTable IN EFI_SYSTEM_TABLE *SystemTable
){ ) {
EFI_STATUS Status; EFI_STATUS Status;
//
// Set the parameter count to an invalid number
//
mTotalParameterCount = (UINTN)(-1);
// //
// UEFI 2.0 shell interfaces (used preferentially) // UEFI 2.0 shell interfaces (used preferentially)
// //
@ -226,8 +258,7 @@ EFIAPI
ShellLibConstructor ( ShellLibConstructor (
IN EFI_HANDLE ImageHandle, IN EFI_HANDLE ImageHandle,
IN EFI_SYSTEM_TABLE *SystemTable IN EFI_SYSTEM_TABLE *SystemTable
) ) {
{
mEfiShellEnvironment2 = NULL; mEfiShellEnvironment2 = NULL;
@ -254,7 +285,7 @@ EFIAPI
ShellLibDestructor ( ShellLibDestructor (
IN EFI_HANDLE ImageHandle, IN EFI_HANDLE ImageHandle,
IN EFI_SYSTEM_TABLE *SystemTable IN EFI_SYSTEM_TABLE *SystemTable
){ ) {
if (mEfiShellEnvironment2 != NULL) { if (mEfiShellEnvironment2 != NULL) {
gBS->CloseProtocol(mEfiShellEnvironment2Handle==NULL?ImageHandle:mEfiShellEnvironment2Handle, gBS->CloseProtocol(mEfiShellEnvironment2Handle==NULL?ImageHandle:mEfiShellEnvironment2Handle,
&gEfiShellEnvironment2Guid, &gEfiShellEnvironment2Guid,
@ -340,8 +371,7 @@ EFI_FILE_INFO*
EFIAPI EFIAPI
ShellGetFileInfo ( ShellGetFileInfo (
IN EFI_FILE_HANDLE FileHandle IN EFI_FILE_HANDLE FileHandle
) ) {
{
return (FileFunctionMap.GetFileInfo(FileHandle)); return (FileFunctionMap.GetFileInfo(FileHandle));
} }
@ -368,8 +398,7 @@ EFIAPI
ShellSetFileInfo ( ShellSetFileInfo (
IN EFI_FILE_HANDLE FileHandle, IN EFI_FILE_HANDLE FileHandle,
IN EFI_FILE_INFO *FileInfo IN EFI_FILE_INFO *FileInfo
) ) {
{
return (FileFunctionMap.SetFileInfo(FileHandle, FileInfo)); return (FileFunctionMap.SetFileInfo(FileHandle, FileInfo));
} }
@ -411,8 +440,7 @@ ShellOpenFileByDevicePath(
OUT EFI_FILE_HANDLE *FileHandle, OUT EFI_FILE_HANDLE *FileHandle,
IN UINT64 OpenMode, IN UINT64 OpenMode,
IN UINT64 Attributes IN UINT64 Attributes
) ) {
{
CHAR16 *FileName; CHAR16 *FileName;
EFI_STATUS Status; EFI_STATUS Status;
EFI_SIMPLE_FILE_SYSTEM_PROTOCOL *EfiSimpleFileSystemProtocol; EFI_SIMPLE_FILE_SYSTEM_PROTOCOL *EfiSimpleFileSystemProtocol;
@ -562,8 +590,7 @@ ShellOpenFileByName(
OUT EFI_FILE_HANDLE *FileHandle, OUT EFI_FILE_HANDLE *FileHandle,
IN UINT64 OpenMode, IN UINT64 OpenMode,
IN UINT64 Attributes IN UINT64 Attributes
) ) {
{
EFI_HANDLE DeviceHandle; EFI_HANDLE DeviceHandle;
EFI_DEVICE_PATH_PROTOCOL *FilePath; EFI_DEVICE_PATH_PROTOCOL *FilePath;
EFI_STATUS Status; EFI_STATUS Status;
@ -581,11 +608,12 @@ ShellOpenFileByName(
Status = mEfiShellProtocol->OpenFileByName(FileName, Status = mEfiShellProtocol->OpenFileByName(FileName,
FileHandle, FileHandle,
OpenMode); OpenMode);
if (!EFI_ERROR(Status)){ if (!EFI_ERROR(Status) && ((OpenMode & EFI_FILE_MODE_CREATE) != 0)){
FileInfo = FileHandleGetInfo(*FileHandle); FileInfo = FileFunctionMap.GetFileInfo(*FileHandle);
ASSERT(FileInfo != NULL); ASSERT(FileInfo != NULL);
FileInfo->Attribute = Attributes; FileInfo->Attribute = Attributes;
Status = FileHandleSetInfo(*FileHandle, FileInfo); Status = FileFunctionMap.SetFileInfo(*FileHandle, FileInfo);
FreePool(FileInfo);
} }
return (Status); return (Status);
} }
@ -638,16 +666,22 @@ EFIAPI
ShellCreateDirectory( ShellCreateDirectory(
IN CONST CHAR16 *DirectoryName, IN CONST CHAR16 *DirectoryName,
OUT EFI_FILE_HANDLE *FileHandle OUT EFI_FILE_HANDLE *FileHandle
) ) {
{ if (mEfiShellProtocol != NULL) {
// //
// this is a pass thru to the open file function with sepcific open mode and attributes // Use UEFI Shell 2.0 method
// //
return (ShellOpenFileByName(DirectoryName, return (mEfiShellProtocol->CreateFile(DirectoryName,
FileHandle, EFI_FILE_DIRECTORY,
EFI_FILE_MODE_READ | EFI_FILE_MODE_WRITE | EFI_FILE_MODE_CREATE, FileHandle
EFI_FILE_DIRECTORY ));
)); } else {
return (ShellOpenFileByName(DirectoryName,
FileHandle,
EFI_FILE_MODE_READ | EFI_FILE_MODE_WRITE | EFI_FILE_MODE_CREATE,
EFI_FILE_DIRECTORY
));
}
} }
/** /**
@ -685,8 +719,7 @@ ShellReadFile(
IN EFI_FILE_HANDLE FileHandle, IN EFI_FILE_HANDLE FileHandle,
IN OUT UINTN *BufferSize, IN OUT UINTN *BufferSize,
OUT VOID *Buffer OUT VOID *Buffer
) ) {
{
return (FileFunctionMap.ReadFile(FileHandle, BufferSize, Buffer)); return (FileFunctionMap.ReadFile(FileHandle, BufferSize, Buffer));
} }
@ -721,8 +754,7 @@ ShellWriteFile(
IN EFI_FILE_HANDLE FileHandle, IN EFI_FILE_HANDLE FileHandle,
IN OUT UINTN *BufferSize, IN OUT UINTN *BufferSize,
IN VOID *Buffer IN VOID *Buffer
) ) {
{
return (FileFunctionMap.WriteFile(FileHandle, BufferSize, Buffer)); return (FileFunctionMap.WriteFile(FileHandle, BufferSize, Buffer));
} }
@ -741,8 +773,7 @@ EFI_STATUS
EFIAPI EFIAPI
ShellCloseFile ( ShellCloseFile (
IN EFI_FILE_HANDLE *FileHandle IN EFI_FILE_HANDLE *FileHandle
) ) {
{
return (FileFunctionMap.CloseFile(*FileHandle)); return (FileFunctionMap.CloseFile(*FileHandle));
} }
@ -764,8 +795,7 @@ EFI_STATUS
EFIAPI EFIAPI
ShellDeleteFile ( ShellDeleteFile (
IN EFI_FILE_HANDLE *FileHandle IN EFI_FILE_HANDLE *FileHandle
) ) {
{
return (FileFunctionMap.DeleteFile(*FileHandle)); return (FileFunctionMap.DeleteFile(*FileHandle));
} }
@ -793,8 +823,7 @@ EFIAPI
ShellSetFilePosition ( ShellSetFilePosition (
IN EFI_FILE_HANDLE FileHandle, IN EFI_FILE_HANDLE FileHandle,
IN UINT64 Position IN UINT64 Position
) ) {
{
return (FileFunctionMap.SetFilePosition(FileHandle, Position)); return (FileFunctionMap.SetFilePosition(FileHandle, Position));
} }
@ -818,8 +847,7 @@ EFIAPI
ShellGetFilePosition ( ShellGetFilePosition (
IN EFI_FILE_HANDLE FileHandle, IN EFI_FILE_HANDLE FileHandle,
OUT UINT64 *Position OUT UINT64 *Position
) ) {
{
return (FileFunctionMap.GetFilePosition(FileHandle, Position)); return (FileFunctionMap.GetFilePosition(FileHandle, Position));
} }
/** /**
@ -840,8 +868,7 @@ EFI_STATUS
EFIAPI EFIAPI
ShellFlushFile ( ShellFlushFile (
IN EFI_FILE_HANDLE FileHandle IN EFI_FILE_HANDLE FileHandle
) ) {
{
return (FileFunctionMap.FlushFile(FileHandle)); return (FileFunctionMap.FlushFile(FileHandle));
} }
@ -868,8 +895,7 @@ EFIAPI
ShellFindFirstFile ( ShellFindFirstFile (
IN EFI_FILE_HANDLE DirHandle, IN EFI_FILE_HANDLE DirHandle,
OUT EFI_FILE_INFO **Buffer OUT EFI_FILE_INFO **Buffer
) ) {
{
// //
// pass to file handle lib // pass to file handle lib
// //
@ -900,8 +926,7 @@ ShellFindNextFile(
IN EFI_FILE_HANDLE DirHandle, IN EFI_FILE_HANDLE DirHandle,
OUT EFI_FILE_INFO *Buffer, OUT EFI_FILE_INFO *Buffer,
OUT BOOLEAN *NoFile OUT BOOLEAN *NoFile
) ) {
{
// //
// pass to file handle lib // pass to file handle lib
// //
@ -927,8 +952,7 @@ EFIAPI
ShellGetFileSize ( ShellGetFileSize (
IN EFI_FILE_HANDLE FileHandle, IN EFI_FILE_HANDLE FileHandle,
OUT UINT64 *Size OUT UINT64 *Size
) ) {
{
return (FileFunctionMap.GetFileSize(FileHandle, Size)); return (FileFunctionMap.GetFileSize(FileHandle, Size));
} }
/** /**
@ -1345,9 +1369,15 @@ ShellOpenFileMetaArg (
} }
InitializeListHead(&((*ListHead)->Link)); InitializeListHead(&((*ListHead)->Link));
} }
return (mEfiShellProtocol->OpenFileList(Arg, Status = mEfiShellProtocol->OpenFileList(Arg,
OpenMode, OpenMode,
ListHead)); ListHead);
if (EFI_ERROR(Status)) {
mEfiShellProtocol->RemoveDupInFileList(ListHead);
} else {
Status = mEfiShellProtocol->RemoveDupInFileList(ListHead);
}
return (Status);
} }
// //
@ -1463,8 +1493,7 @@ InternalIsOnCheckList (
IN CONST CHAR16 *Name, IN CONST CHAR16 *Name,
IN CONST SHELL_PARAM_ITEM *CheckList, IN CONST SHELL_PARAM_ITEM *CheckList,
OUT ParamType *Type OUT ParamType *Type
) ) {
{
SHELL_PARAM_ITEM *TempListItem; SHELL_PARAM_ITEM *TempListItem;
// //
@ -1499,6 +1528,7 @@ InternalIsOnCheckList (
return (TRUE); return (TRUE);
} }
} }
return (FALSE); return (FALSE);
} }
/** /**
@ -1512,7 +1542,8 @@ InternalIsOnCheckList (
BOOLEAN BOOLEAN
EFIAPI EFIAPI
InternalIsFlag ( InternalIsFlag (
IN CONST CHAR16 *Name IN CONST CHAR16 *Name,
IN BOOLEAN AlwaysAllowNumbers
) )
{ {
// //
@ -1520,6 +1551,13 @@ InternalIsFlag (
// //
ASSERT(Name != NULL); ASSERT(Name != NULL);
//
// If we accept numbers then dont return TRUE. (they will be values)
//
if (((Name[0] == L'-' || Name[0] == L'+') && ShellInternalIsHexaDecimalDigitCharacter(Name[1])) && AlwaysAllowNumbers == TRUE) {
return (FALSE);
}
// //
// If the Name has a / or - as the first character return TRUE // If the Name has a / or - as the first character return TRUE
// //
@ -1556,6 +1594,7 @@ InternalIsFlag (
the invalid command line argument was returned in the invalid command line argument was returned in
ProblemParam if provided. ProblemParam if provided.
**/ **/
STATIC
EFI_STATUS EFI_STATUS
EFIAPI EFIAPI
InternalCommandLineParse ( InternalCommandLineParse (
@ -1564,24 +1603,16 @@ InternalCommandLineParse (
OUT CHAR16 **ProblemParam OPTIONAL, OUT CHAR16 **ProblemParam OPTIONAL,
IN BOOLEAN AutoPageBreak, IN BOOLEAN AutoPageBreak,
IN CONST CHAR16 **Argv, IN CONST CHAR16 **Argv,
IN UINTN Argc IN UINTN Argc,
) IN BOOLEAN AlwaysAllowNumbers
{ ) {
UINTN LoopCounter; UINTN LoopCounter;
UINTN Count;
ParamType CurrentItemType; ParamType CurrentItemType;
SHELL_PARAM_PACKAGE *CurrentItemPackage; SHELL_PARAM_PACKAGE *CurrentItemPackage;
BOOLEAN GetItemValue; BOOLEAN GetItemValue;
CurrentItemPackage = NULL; CurrentItemPackage = NULL;
mTotalParameterCount = 0;
//
// ASSERTs
//
ASSERT(CheckList != NULL);
ASSERT(Argv != NULL);
Count = 0;
GetItemValue = FALSE; GetItemValue = FALSE;
// //
@ -1592,6 +1623,12 @@ InternalCommandLineParse (
return (EFI_SUCCESS); return (EFI_SUCCESS);
} }
//
// ASSERTs
//
ASSERT(CheckList != NULL);
ASSERT(Argv != NULL);
// //
// initialize the linked list // initialize the linked list
// //
@ -1607,6 +1644,13 @@ InternalCommandLineParse (
// do nothing for NULL argv // do nothing for NULL argv
// //
} else if (InternalIsOnCheckList(Argv[LoopCounter], CheckList, &CurrentItemType) == TRUE) { } else if (InternalIsOnCheckList(Argv[LoopCounter], CheckList, &CurrentItemType) == TRUE) {
//
// We might have leftover if last parameter didnt have optional value
//
if (GetItemValue == TRUE) {
GetItemValue = FALSE;
InsertHeadList(*CheckPackage, &CurrentItemPackage->Link);
}
// //
// this is a flag // this is a flag
// //
@ -1633,7 +1677,7 @@ InternalCommandLineParse (
// //
InsertHeadList(*CheckPackage, &CurrentItemPackage->Link); InsertHeadList(*CheckPackage, &CurrentItemPackage->Link);
} }
} else if (GetItemValue == TRUE && InternalIsFlag(Argv[LoopCounter]) == FALSE) { } else if (GetItemValue == TRUE && InternalIsFlag(Argv[LoopCounter], AlwaysAllowNumbers) == FALSE) {
ASSERT(CurrentItemPackage != NULL); ASSERT(CurrentItemPackage != NULL);
// //
// get the item VALUE for the previous flag // get the item VALUE for the previous flag
@ -1643,7 +1687,7 @@ InternalCommandLineParse (
ASSERT(CurrentItemPackage->Value != NULL); ASSERT(CurrentItemPackage->Value != NULL);
StrCpy(CurrentItemPackage->Value, Argv[LoopCounter]); StrCpy(CurrentItemPackage->Value, Argv[LoopCounter]);
InsertHeadList(*CheckPackage, &CurrentItemPackage->Link); InsertHeadList(*CheckPackage, &CurrentItemPackage->Link);
} else if (InternalIsFlag(Argv[LoopCounter]) == FALSE) { } else if (InternalIsFlag(Argv[LoopCounter], AlwaysAllowNumbers) == FALSE) {
// //
// add this one as a non-flag // add this one as a non-flag
// //
@ -1654,7 +1698,7 @@ InternalCommandLineParse (
CurrentItemPackage->Value = AllocatePool(StrSize(Argv[LoopCounter])); CurrentItemPackage->Value = AllocatePool(StrSize(Argv[LoopCounter]));
ASSERT(CurrentItemPackage->Value != NULL); ASSERT(CurrentItemPackage->Value != NULL);
StrCpy(CurrentItemPackage->Value, Argv[LoopCounter]); StrCpy(CurrentItemPackage->Value, Argv[LoopCounter]);
CurrentItemPackage->OriginalPosition = Count++; CurrentItemPackage->OriginalPosition = mTotalParameterCount++;
InsertHeadList(*CheckPackage, &CurrentItemPackage->Link); InsertHeadList(*CheckPackage, &CurrentItemPackage->Link);
} else if (ProblemParam) { } else if (ProblemParam) {
// //
@ -1708,13 +1752,13 @@ InternalCommandLineParse (
**/ **/
EFI_STATUS EFI_STATUS
EFIAPI EFIAPI
ShellCommandLineParse ( ShellCommandLineParseEx (
IN CONST SHELL_PARAM_ITEM *CheckList, IN CONST SHELL_PARAM_ITEM *CheckList,
OUT LIST_ENTRY **CheckPackage, OUT LIST_ENTRY **CheckPackage,
OUT CHAR16 **ProblemParam OPTIONAL, OUT CHAR16 **ProblemParam OPTIONAL,
IN BOOLEAN AutoPageBreak IN BOOLEAN AutoPageBreak,
) IN BOOLEAN AlwaysAllowNumbers
{ ) {
// //
// ASSERT that CheckList and CheckPackage aren't NULL // ASSERT that CheckList and CheckPackage aren't NULL
// //
@ -1730,7 +1774,8 @@ ShellCommandLineParse (
ProblemParam, ProblemParam,
AutoPageBreak, AutoPageBreak,
(CONST CHAR16**) mEfiShellParametersProtocol->Argv, (CONST CHAR16**) mEfiShellParametersProtocol->Argv,
mEfiShellParametersProtocol->Argc )); mEfiShellParametersProtocol->Argc,
AlwaysAllowNumbers));
} }
// //
@ -1742,7 +1787,8 @@ ShellCommandLineParse (
ProblemParam, ProblemParam,
AutoPageBreak, AutoPageBreak,
(CONST CHAR16**) mEfiShellInterface->Argv, (CONST CHAR16**) mEfiShellInterface->Argv,
mEfiShellInterface->Argc )); mEfiShellInterface->Argc,
AlwaysAllowNumbers));
} }
/** /**
@ -1761,8 +1807,7 @@ VOID
EFIAPI EFIAPI
ShellCommandLineFreeVarList ( ShellCommandLineFreeVarList (
IN LIST_ENTRY *CheckPackage IN LIST_ENTRY *CheckPackage
) ) {
{
LIST_ENTRY *Node; LIST_ENTRY *Node;
// //
@ -1776,7 +1821,7 @@ ShellCommandLineFreeVarList (
// for each node in the list // for each node in the list
// //
for ( Node = GetFirstNode(CheckPackage) for ( Node = GetFirstNode(CheckPackage)
; Node != CheckPackage ; IsListEmpty(CheckPackage) == FALSE
; Node = GetFirstNode(CheckPackage) ; Node = GetFirstNode(CheckPackage)
){ ){
// //
@ -1827,8 +1872,7 @@ EFIAPI
ShellCommandLineGetFlag ( ShellCommandLineGetFlag (
IN CONST LIST_ENTRY *CheckPackage, IN CONST LIST_ENTRY *CheckPackage,
IN CHAR16 *KeyString IN CHAR16 *KeyString
) ) {
{
LIST_ENTRY *Node; LIST_ENTRY *Node;
// //
@ -1886,8 +1930,7 @@ EFIAPI
ShellCommandLineGetValue ( ShellCommandLineGetValue (
IN CONST LIST_ENTRY *CheckPackage, IN CONST LIST_ENTRY *CheckPackage,
IN CHAR16 *KeyString IN CHAR16 *KeyString
) ) {
{
LIST_ENTRY *Node; LIST_ENTRY *Node;
// //
@ -1946,8 +1989,7 @@ EFIAPI
ShellCommandLineGetRawValue ( ShellCommandLineGetRawValue (
IN CONST LIST_ENTRY *CheckPackage, IN CONST LIST_ENTRY *CheckPackage,
IN UINT32 Position IN UINT32 Position
) ) {
{
LIST_ENTRY *Node; LIST_ENTRY *Node;
// //
@ -1973,6 +2015,23 @@ ShellCommandLineGetRawValue (
} }
return (NULL); return (NULL);
} }
/**
returns the number of command line value parameters that were parsed.
this will not include flags.
@retval (UINTN)-1 No parsing has ocurred
@return other The number of value parameters found
**/
UINTN
EFIAPI
ShellCommandLineGetCount(
VOID
){
return (mTotalParameterCount);
}
/** /**
This is a find and replace function. it will return the NewString as a copy of This is a find and replace function. it will return the NewString as a copy of
SourceString with each instance of FindTarget replaced with ReplaceWith. SourceString with each instance of FindTarget replaced with ReplaceWith.
@ -2004,7 +2063,8 @@ CopyReplace(
IN UINTN NewSize, IN UINTN NewSize,
IN CONST CHAR16 *FindTarget, IN CONST CHAR16 *FindTarget,
IN CONST CHAR16 *ReplaceWith IN CONST CHAR16 *ReplaceWith
){ )
{
UINTN Size; UINTN Size;
if ( (SourceString == NULL) if ( (SourceString == NULL)
|| (NewString == NULL) || (NewString == NULL)
@ -2015,8 +2075,8 @@ CopyReplace(
){ ){
return (EFI_INVALID_PARAMETER); return (EFI_INVALID_PARAMETER);
} }
NewString = SetMem16(NewString, NewSize, L'\0'); NewString = SetMem16(NewString, NewSize, CHAR_NULL);
while (*SourceString != L'\0') { while (*SourceString != CHAR_NULL) {
if (StrnCmp(SourceString, FindTarget, StrLen(FindTarget)) == 0) { if (StrnCmp(SourceString, FindTarget, StrLen(FindTarget)) == 0) {
SourceString += StrLen(FindTarget); SourceString += StrLen(FindTarget);
Size = StrSize(NewString); Size = StrSize(NewString);
@ -2060,30 +2120,28 @@ CopyReplace(
@param[in] Row the row to print at @param[in] Row the row to print at
@param[in] Col the column to print at @param[in] Col the column to print at
@param[in] Format the format string @param[in] Format the format string
@param[in] Marker the marker for the variable argument list
@return the number of characters printed to the screen @return the number of characters printed to the screen
**/ **/
UINTN UINTN
EFIAPI EFIAPI
ShellPrintEx( InternalShellPrintWorker(
IN INT32 Col OPTIONAL, IN INT32 Col OPTIONAL,
IN INT32 Row OPTIONAL, IN INT32 Row OPTIONAL,
IN CONST CHAR16 *Format, IN CONST CHAR16 *Format,
... VA_LIST Marker
){ )
VA_LIST Marker; {
UINTN BufferSize; UINTN BufferSize;
CHAR16 *PostReplaceFormat; CHAR16 *PostReplaceFormat;
CHAR16 *PostReplaceFormat2; CHAR16 *PostReplaceFormat2;
UINTN Return; UINTN Return;
EFI_STATUS Status; EFI_STATUS Status;
UINTN NormalAttribute; UINTN NormalAttribute;
CHAR16 *ResumeLocation; CHAR16 *ResumeLocation;
CHAR16 *FormatWalker; CHAR16 *FormatWalker;
VA_START (Marker, Format);
BufferSize = (PcdGet32 (PcdUefiLibMaxPrintBufferSize) + 1) * sizeof (CHAR16); BufferSize = (PcdGet32 (PcdUefiLibMaxPrintBufferSize) + 1) * sizeof (CHAR16);
PostReplaceFormat = AllocateZeroPool (BufferSize); PostReplaceFormat = AllocateZeroPool (BufferSize);
@ -2119,13 +2177,13 @@ ShellPrintEx(
NormalAttribute = gST->ConOut->Mode->Attribute; NormalAttribute = gST->ConOut->Mode->Attribute;
FormatWalker = PostReplaceFormat2; FormatWalker = PostReplaceFormat2;
while (*FormatWalker != L'\0') { while (*FormatWalker != CHAR_NULL) {
// //
// Find the next attribute change request // Find the next attribute change request
// //
ResumeLocation = StrStr(FormatWalker, L"%"); ResumeLocation = StrStr(FormatWalker, L"%");
if (ResumeLocation != NULL) { if (ResumeLocation != NULL) {
*ResumeLocation = L'\0'; *ResumeLocation = CHAR_NULL;
} }
// //
// print the current FormatWalker string // print the current FormatWalker string
@ -2174,3 +2232,133 @@ ShellPrintEx(
return (Return); return (Return);
} }
/**
Print at a specific location on the screen.
This function will move the cursor to a given screen location and print the specified string
If -1 is specified for either the Row or Col the current screen location for BOTH
will be used.
if either Row or Col is out of range for the current console, then ASSERT
if Format is NULL, then ASSERT
In addition to the standard %-based flags as supported by UefiLib Print() this supports
the following additional flags:
%N - Set output attribute to normal
%H - Set output attribute to highlight
%E - Set output attribute to error
%B - Set output attribute to blue color
%V - Set output attribute to green color
Note: The background color is controlled by the shell command cls.
@param[in] Row the row to print at
@param[in] Col the column to print at
@param[in] Format the format string
@return the number of characters printed to the screen
**/
UINTN
EFIAPI
ShellPrintEx(
IN INT32 Col OPTIONAL,
IN INT32 Row OPTIONAL,
IN CONST CHAR16 *Format,
...
)
{
VA_LIST Marker;
VA_START (Marker, Format);
return (InternalShellPrintWorker(Col, Row, Format, Marker));
}
/**
Print at a specific location on the screen.
This function will move the cursor to a given screen location, print the specified string,
and return the cursor to the original locaiton.
If -1 is specified for either the Row or Col the current screen location for BOTH
will be used and the cursor's position will not be moved back to an original location.
if either Row or Col is out of range for the current console, then ASSERT
if Format is NULL, then ASSERT
In addition to the standard %-based flags as supported by UefiLib Print() this supports
the following additional flags:
%N - Set output attribute to normal
%H - Set output attribute to highlight
%E - Set output attribute to error
%B - Set output attribute to blue color
%V - Set output attribute to green color
Note: The background color is controlled by the shell command cls.
@param[in] Row the row to print at
@param[in] Col the column to print at
@param[in] HiiFormatStringId the format string Id for getting from Hii
@param[in] HiiFormatHandle the format string Handle for getting from Hii
@return the number of characters printed to the screen
**/
UINTN
EFIAPI
ShellPrintHiiEx(
IN INT32 Col OPTIONAL,
IN INT32 Row OPTIONAL,
IN CONST EFI_STRING_ID HiiFormatStringId,
IN CONST EFI_HANDLE HiiFormatHandle,
...
)
{
VA_LIST Marker;
CHAR16 *HiiFormatString;
UINTN RetVal;
VA_START (Marker, HiiFormatHandle);
HiiFormatString = HiiGetString(HiiFormatHandle, HiiFormatStringId, NULL);
ASSERT(HiiFormatString != NULL);
RetVal = InternalShellPrintWorker(Col, Row, HiiFormatString, Marker);
FreePool(HiiFormatString);
return (RetVal);
}
/**
Function to determine if a given filename represents a file or a directory.
@param[in] DirName Path to directory to test.
@retval EFI_SUCCESS The Path represents a directory
@retval EFI_NOT_FOUND The Path does not represent a directory
@return other The path failed to open
**/
EFI_STATUS
EFIAPI
ShellIsDirectory(
IN CONST CHAR16 *DirName
)
{
EFI_STATUS Status;
EFI_FILE_HANDLE Handle;
Handle = NULL;
Status = ShellOpenFileByName(DirName, &Handle, EFI_FILE_MODE_READ, 0);
if (EFI_ERROR(Status)) {
return (Status);
}
if (FileHandleIsDirectory(Handle) == EFI_SUCCESS) {
ShellCloseFile(&Handle);
return (EFI_SUCCESS);
}
ShellCloseFile(&Handle);
return (EFI_NOT_FOUND);
}

View File

@ -33,6 +33,7 @@
[Packages] [Packages]
MdePkg/MdePkg.dec MdePkg/MdePkg.dec
MdeModulePkg/MdeModulePkg.dec
ShellPkg/ShellPkg.dec ShellPkg/ShellPkg.dec
[LibraryClasses] [LibraryClasses]
@ -45,6 +46,7 @@
FileHandleLib FileHandleLib
PrintLib PrintLib
UefiLib UefiLib
HiiLib
[Protocols] [Protocols]
gEfiSimpleFileSystemProtocolGuid # ALWAYS_CONSUMED gEfiSimpleFileSystemProtocolGuid # ALWAYS_CONSUMED