From a4883d4cb655c887ef527ff51ae363d3ecda633b Mon Sep 17 00:00:00 2001 From: Chris Phillips Date: Fri, 18 Oct 2013 20:53:06 +0000 Subject: =?UTF-8?q?ShellPkg:=20Fixes=20for=20the=20=E2=80=98type=E2=80=99?= =?UTF-8?q?=20command:=20-=20Better=20handling=20to=20skip=20byte=20order?= =?UTF-8?q?=20mark=20in=20Unicode=20files.=20-=20Only=20display=20valid=20?= =?UTF-8?q?ASCII=20characters.=20-=20Change=20to=20use=20ShellPrintEx()=20?= =?UTF-8?q?instead=20of=20Print().=20-=20Print=20each=20character=20instea?= =?UTF-8?q?d=20of=20%s=20to=20avoid=20possible=20overrun=20when=20not=20NU?= =?UTF-8?q?LL=20terminated.=20-=20Check=20for=20ExecutionBreak.?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Contributed-under: TianoCore Contribution Agreement 1.0 Signed-off-by: Chris Phillips reviewed-by: Jaben Carsey git-svn-id: https://svn.code.sf.net/p/edk2/code/trunk/edk2@14788 6f19259b-4bc3-4df7-8a09-765794883524 --- ShellPkg/Library/UefiShellLevel3CommandsLib/Type.c | 120 +++++++++++++++++---- 1 file changed, 98 insertions(+), 22 deletions(-) (limited to 'ShellPkg') diff --git a/ShellPkg/Library/UefiShellLevel3CommandsLib/Type.c b/ShellPkg/Library/UefiShellLevel3CommandsLib/Type.c index 50974c3fb9..dffefd1234 100644 --- a/ShellPkg/Library/UefiShellLevel3CommandsLib/Type.c +++ b/ShellPkg/Library/UefiShellLevel3CommandsLib/Type.c @@ -1,6 +1,7 @@ /** @file Main file for Type shell level 3 function. + Copyright (c) 2013, Hewlett-Packard Development Company, L.P. Copyright (c) 2009 - 2011, 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 @@ -31,59 +32,129 @@ EFI_STATUS EFIAPI TypeFileByHandle ( - IN EFI_HANDLE Handle, - BOOLEAN Ascii, - BOOLEAN UCS2 + IN SHELL_FILE_HANDLE Handle, + IN BOOLEAN Ascii, + IN BOOLEAN UCS2 ) { UINTN ReadSize; VOID *Buffer; + VOID *AllocatedBuffer; EFI_STATUS Status; UINTN LoopVar; + UINTN LoopSize; CHAR16 AsciiChar; + CHAR16 Ucs2Char; ReadSize = PcdGet32(PcdShellFileOperationSize); - Buffer = AllocateZeroPool(ReadSize); - if (Buffer == NULL) { + AllocatedBuffer = AllocateZeroPool(ReadSize); + if (AllocatedBuffer == NULL) { return (EFI_OUT_OF_RESOURCES); } Status = ShellSetFilePosition(Handle, 0); ASSERT_EFI_ERROR(Status); - while (ReadSize == ((UINTN)PcdGet32(PcdShellFileOperationSize))){ + while (ReadSize == ((UINTN)PcdGet32(PcdShellFileOperationSize))) { + Buffer = AllocatedBuffer; ZeroMem(Buffer, ReadSize); Status = ShellReadFile(Handle, &ReadSize, Buffer); if (EFI_ERROR(Status)){ break; } - if (!(Ascii|UCS2)){ + if (!(Ascii|UCS2)) { if (*(UINT16*)Buffer == gUnicodeFileTag) { UCS2 = TRUE; - Buffer = ((UINT16*)Buffer) + 1; } else { Ascii = TRUE; } } - // - // We want to use plain Print function here! (no color support for files) - // - if (Ascii){ - for (LoopVar = 0 ; LoopVar < ReadSize ; LoopVar++) { - AsciiChar = CHAR_NULL; - AsciiChar = ((CHAR8*)Buffer)[LoopVar]; - if (AsciiChar == CHAR_NULL) { - AsciiChar = '.'; - } - Print(L"%c", AsciiChar); + if (Ascii) { + LoopSize = ReadSize; + for (LoopVar = 0 ; LoopVar < LoopSize ; LoopVar++) { + // + // The valid range of ASCII characters is 0x20-0x7E. + // Display "." when there is an invalid character. + // + AsciiChar = CHAR_NULL; + AsciiChar = ((CHAR8*)Buffer)[LoopVar]; + if (AsciiChar == '\r' || AsciiChar == '\n') { + // + // Allow Line Feed (LF) (0xA) & Carriage Return (CR) (0xD) + // characters to be displayed as is. + // + if (AsciiChar == '\n' && ((CHAR8*)Buffer)[LoopVar-1] != '\r') { + // + // In case Line Feed (0xA) is encountered & Carriage Return (0xD) + // was not the previous character, print CR and LF. This is because + // Shell 2.0 requires carriage return with line feed for displaying + // each new line from left. + // + ShellPrintEx (-1, -1, L"\r\n"); + continue; + } + } else { + // + // For all other characters which are not printable, display '.' + // + if (AsciiChar < 0x20 || AsciiChar >= 0x7F) { + AsciiChar = '.'; + } + } + ShellPrintEx (-1, -1, L"%c", AsciiChar); } } else { - Print(L"%s", Buffer); + if (*(UINT16*)Buffer == gUnicodeFileTag) { + // + // For unicode files, skip displaying the byte order marker. + // + Buffer = ((UINT16*)Buffer) + 1; + LoopSize = (ReadSize / (sizeof (CHAR16))) - 1; + } else { + LoopSize = ReadSize / (sizeof (CHAR16)); + } + + for (LoopVar = 0 ; LoopVar < LoopSize ; LoopVar++) { + // + // An invalid range of characters is 0x0-0x1F. + // Display "." when there is an invalid character. + // + Ucs2Char = CHAR_NULL; + Ucs2Char = ((CHAR16*)Buffer)[LoopVar]; + if (Ucs2Char == '\r' || Ucs2Char == '\n') { + // + // Allow Line Feed (LF) (0xA) & Carriage Return (CR) (0xD) + // characters to be displayed as is. + // + if (Ucs2Char == '\n' && ((CHAR16*)Buffer)[LoopVar-1] != '\r') { + // + // In case Line Feed (0xA) is encountered & Carriage Return (0xD) + // was not the previous character, print CR and LF. This is because + // Shell 2.0 requires carriage return with line feed for displaying + // each new line from left. + // + ShellPrintEx (-1, -1, L"\r\n"); + continue; + } + } + else if (Ucs2Char < 0x20) { + // + // For all other characters which are not printable, display '.' + // + Ucs2Char = L'.'; + } + ShellPrintEx (-1, -1, L"%c", Ucs2Char); + } + } + + if (ShellGetExecutionBreakFlag()) { + break; } } - Print(L"\r\n", Buffer); + FreePool (AllocatedBuffer); + ShellPrintEx (-1, -1, L"\r\n"); return (Status); } @@ -196,6 +267,11 @@ ShellCommandRunType ( ; !IsNull(&FileList->Link, &Node->Link) && !ShellGetExecutionBreakFlag() ; Node = (EFI_SHELL_FILE_INFO*)GetNextNode(&FileList->Link, &Node->Link) ){ + + if (ShellGetExecutionBreakFlag()) { + break; + } + // // make sure the file opened ok // @@ -217,7 +293,7 @@ ShellCommandRunType ( // // do it // - Status = TypeFileByHandle(Node->Handle, AsciiMode, UnicodeMode); + Status = TypeFileByHandle (Node->Handle, AsciiMode, UnicodeMode); if (EFI_ERROR(Status)) { ShellPrintHiiEx(-1, -1, NULL, STRING_TOKEN (STR_TYP_ERROR), gShellLevel3HiiHandle, Node->FileName, Status); ShellStatus = SHELL_INVALID_PARAMETER; -- cgit v1.2.3