mirror of https://github.com/acidanthera/audk.git
ShellPkg: Follow spec to remove the last '\' char in return name of GetCurDir().
In Shell spec 2.1 the return name of EFI_SHELL_PROTOCOL.GetCurDir() is defined as 'fs0:\current-dir' while in current implementation it's 'fs0:\current-dir\'. To follow spec the patch removed the redundant '\' char. Since it has been broken for a long time, some codes may depend on the broken behavior. After this change 'EFI_SHELL_PROTOCOL.GetCurDir()' and 'UefiShellLib.ShellGetCurrentDir()' will return a current directory string without tailing '\' (fs0:\current-dir), the value of Shell environment variable 'cwd' will become 'fs0:\current-dir' as well. This patch has updated all the code in EDKII to make them depend on the new behavior. Developers should check whether 'GetCurDir()' and 'ShellGetCurrentDir' are used in their source code. Contributed-under: TianoCore Contribution Agreement 1.0 Signed-off-by: Qiu Shumin <shumin.qiu@intel.com> Reviewed-by: Jaben Carsey <jaben.carsey@intel.com> git-svn-id: https://svn.code.sf.net/p/edk2/code/trunk/edk2@18653 6f19259b-4bc3-4df7-8a09-765794883524
This commit is contained in:
parent
a7e173b07a
commit
fbd2dfadfe
|
@ -510,6 +510,7 @@ FileInterfaceStdInRead(
|
||||||
Cwd = ShellInfoObject.NewEfiShellProtocol->GetCurDir(NULL);
|
Cwd = ShellInfoObject.NewEfiShellProtocol->GetCurDir(NULL);
|
||||||
if (Cwd != NULL) {
|
if (Cwd != NULL) {
|
||||||
StrnCpyS(TabStr, (*BufferSize)/sizeof(CHAR16), Cwd, (*BufferSize)/sizeof(CHAR16) - 1);
|
StrnCpyS(TabStr, (*BufferSize)/sizeof(CHAR16), Cwd, (*BufferSize)/sizeof(CHAR16) - 1);
|
||||||
|
StrCatS(TabStr, (*BufferSize)/sizeof(CHAR16), L"\\");
|
||||||
if (TabStr[StrLen(TabStr)-1] == L'\\' && *(CurrentString + TabPos) == L'\\' ) {
|
if (TabStr[StrLen(TabStr)-1] == L'\\' && *(CurrentString + TabPos) == L'\\' ) {
|
||||||
TabStr[StrLen(TabStr)-1] = CHAR_NULL;
|
TabStr[StrLen(TabStr)-1] = CHAR_NULL;
|
||||||
}
|
}
|
||||||
|
|
Binary file not shown.
|
@ -532,12 +532,13 @@ EfiShellGetDevicePathFromFilePath(
|
||||||
if (Cwd == NULL) {
|
if (Cwd == NULL) {
|
||||||
return (NULL);
|
return (NULL);
|
||||||
}
|
}
|
||||||
Size = StrSize(Cwd) + StrSize(Path) - sizeof(CHAR16);
|
Size = StrSize(Cwd) + StrSize(Path);
|
||||||
NewPath = AllocateZeroPool(Size);
|
NewPath = AllocateZeroPool(Size);
|
||||||
if (NewPath == NULL) {
|
if (NewPath == NULL) {
|
||||||
return (NULL);
|
return (NULL);
|
||||||
}
|
}
|
||||||
StrCpyS(NewPath, Size/sizeof(CHAR16), Cwd);
|
StrCpyS(NewPath, Size/sizeof(CHAR16), Cwd);
|
||||||
|
StrCatS(NewPath, Size/sizeof(CHAR16), L"\\");
|
||||||
if (*Path == L'\\') {
|
if (*Path == L'\\') {
|
||||||
Path++;
|
Path++;
|
||||||
while (PathRemoveLastItem(NewPath)) ;
|
while (PathRemoveLastItem(NewPath)) ;
|
||||||
|
@ -2495,6 +2496,7 @@ EfiShellOpenFileList(
|
||||||
CurDir = EfiShellGetCurDir(NULL);
|
CurDir = EfiShellGetCurDir(NULL);
|
||||||
ASSERT((Path2 == NULL && Path2Size == 0) || (Path2 != NULL));
|
ASSERT((Path2 == NULL && Path2Size == 0) || (Path2 != NULL));
|
||||||
StrnCatGrow(&Path2, &Path2Size, CurDir, 0);
|
StrnCatGrow(&Path2, &Path2Size, CurDir, 0);
|
||||||
|
StrnCatGrow(&Path2, &Path2Size, L"\\", 0);
|
||||||
if (*Path == L'\\') {
|
if (*Path == L'\\') {
|
||||||
Path++;
|
Path++;
|
||||||
while (PathRemoveLastItem(Path2)) ;
|
while (PathRemoveLastItem(Path2)) ;
|
||||||
|
@ -2797,6 +2799,8 @@ EfiShellSetEnv(
|
||||||
FileSystemMapping. In both cases, the returned name includes the file system
|
FileSystemMapping. In both cases, the returned name includes the file system
|
||||||
mapping (i.e. fs0:\current-dir).
|
mapping (i.e. fs0:\current-dir).
|
||||||
|
|
||||||
|
Note that the current directory string should exclude the tailing backslash character.
|
||||||
|
|
||||||
@param FileSystemMapping A pointer to the file system mapping. If NULL,
|
@param FileSystemMapping A pointer to the file system mapping. If NULL,
|
||||||
then the current working directory is returned.
|
then the current working directory is returned.
|
||||||
|
|
||||||
|
@ -2852,6 +2856,8 @@ EfiShellGetCurDir(
|
||||||
If the current working directory or the current working file system is changed then the
|
If the current working directory or the current working file system is changed then the
|
||||||
%cwd% environment variable will be updated
|
%cwd% environment variable will be updated
|
||||||
|
|
||||||
|
Note that the current directory string should exclude the tailing backslash character.
|
||||||
|
|
||||||
@param FileSystem A pointer to the file system's mapped name. If NULL, then the current working
|
@param FileSystem A pointer to the file system's mapped name. If NULL, then the current working
|
||||||
directory is changed.
|
directory is changed.
|
||||||
@param Dir Points to the NULL-terminated directory on the device specified by FileSystem.
|
@param Dir Points to the NULL-terminated directory on the device specified by FileSystem.
|
||||||
|
@ -2939,9 +2945,11 @@ EfiShellSetCurDir(
|
||||||
ASSERT((MapListItem->CurrentDirectoryPath == NULL && Size == 0) || (MapListItem->CurrentDirectoryPath != NULL));
|
ASSERT((MapListItem->CurrentDirectoryPath == NULL && Size == 0) || (MapListItem->CurrentDirectoryPath != NULL));
|
||||||
MapListItem->CurrentDirectoryPath = StrnCatGrow(&MapListItem->CurrentDirectoryPath, &Size, DirectoryName, 0);
|
MapListItem->CurrentDirectoryPath = StrnCatGrow(&MapListItem->CurrentDirectoryPath, &Size, DirectoryName, 0);
|
||||||
}
|
}
|
||||||
if ((MapListItem->CurrentDirectoryPath != NULL && MapListItem->CurrentDirectoryPath[StrLen(MapListItem->CurrentDirectoryPath)-1] != L'\\') || (MapListItem->CurrentDirectoryPath == NULL)) {
|
if ((MapListItem->CurrentDirectoryPath != NULL && MapListItem->CurrentDirectoryPath[StrLen(MapListItem->CurrentDirectoryPath)-1] == L'\\') || (MapListItem->CurrentDirectoryPath == NULL)) {
|
||||||
ASSERT((MapListItem->CurrentDirectoryPath == NULL && Size == 0) || (MapListItem->CurrentDirectoryPath != NULL));
|
ASSERT((MapListItem->CurrentDirectoryPath == NULL && Size == 0) || (MapListItem->CurrentDirectoryPath != NULL));
|
||||||
MapListItem->CurrentDirectoryPath = StrnCatGrow(&MapListItem->CurrentDirectoryPath, &Size, L"\\", 0);
|
if (MapListItem->CurrentDirectoryPath != NULL) {
|
||||||
|
MapListItem->CurrentDirectoryPath[StrLen(MapListItem->CurrentDirectoryPath)-1] = CHAR_NULL;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
//
|
//
|
||||||
|
@ -2973,9 +2981,9 @@ EfiShellSetCurDir(
|
||||||
MapListItem->CurrentDirectoryPath = StrnCatGrow(&MapListItem->CurrentDirectoryPath, &Size, L"\\", 0);
|
MapListItem->CurrentDirectoryPath = StrnCatGrow(&MapListItem->CurrentDirectoryPath, &Size, L"\\", 0);
|
||||||
ASSERT((MapListItem->CurrentDirectoryPath == NULL && Size == 0) || (MapListItem->CurrentDirectoryPath != NULL));
|
ASSERT((MapListItem->CurrentDirectoryPath == NULL && Size == 0) || (MapListItem->CurrentDirectoryPath != NULL));
|
||||||
MapListItem->CurrentDirectoryPath = StrnCatGrow(&MapListItem->CurrentDirectoryPath, &Size, DirectoryName, 0);
|
MapListItem->CurrentDirectoryPath = StrnCatGrow(&MapListItem->CurrentDirectoryPath, &Size, DirectoryName, 0);
|
||||||
if (MapListItem->CurrentDirectoryPath != NULL && MapListItem->CurrentDirectoryPath[StrLen(MapListItem->CurrentDirectoryPath)-1] != L'\\') {
|
if (MapListItem->CurrentDirectoryPath != NULL && MapListItem->CurrentDirectoryPath[StrLen(MapListItem->CurrentDirectoryPath)-1] == L'\\') {
|
||||||
ASSERT((MapListItem->CurrentDirectoryPath == NULL && Size == 0) || (MapListItem->CurrentDirectoryPath != NULL));
|
ASSERT((MapListItem->CurrentDirectoryPath == NULL && Size == 0) || (MapListItem->CurrentDirectoryPath != NULL));
|
||||||
MapListItem->CurrentDirectoryPath = StrnCatGrow(&MapListItem->CurrentDirectoryPath, &Size, L"\\", 0);
|
MapListItem->CurrentDirectoryPath[StrLen(MapListItem->CurrentDirectoryPath)-1] = CHAR_NULL;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
/** @file
|
/** @file
|
||||||
Provides interface to shell functionality for shell commands and applications.
|
Provides interface to shell functionality for shell commands and applications.
|
||||||
|
|
||||||
Copyright (c) 2006 - 2014, Intel Corporation. All rights reserved.<BR>
|
Copyright (c) 2006 - 2015, Intel Corporation. All rights reserved.<BR>
|
||||||
This program and the accompanying materials
|
This program and the accompanying materials
|
||||||
are licensed and made available under the terms and conditions of the BSD License
|
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
|
which accompanies this distribution. The full text of the license may be found at
|
||||||
|
@ -550,6 +550,8 @@ ShellExecute (
|
||||||
name. If the DeviceName is not NULL, it returns the current directory name
|
name. If the DeviceName is not NULL, it returns the current directory name
|
||||||
on specified drive.
|
on specified drive.
|
||||||
|
|
||||||
|
Note that the current directory string should exclude the tailing backslash character.
|
||||||
|
|
||||||
@param[in] DeviceName The name of the file system to get directory on.
|
@param[in] DeviceName The name of the file system to get directory on.
|
||||||
|
|
||||||
@retval NULL The directory does not exist.
|
@retval NULL The directory does not exist.
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
EFI Shell protocol as defined in the UEFI Shell 2.0 specification including errata.
|
EFI Shell protocol as defined in the UEFI Shell 2.0 specification including errata.
|
||||||
|
|
||||||
(C) Copyright 2014 Hewlett-Packard Development Company, L.P.<BR>
|
(C) Copyright 2014 Hewlett-Packard Development Company, L.P.<BR>
|
||||||
Copyright (c) 2006 - 2014, Intel Corporation. All rights reserved.<BR>
|
Copyright (c) 2006 - 2015, Intel Corporation. All rights reserved.<BR>
|
||||||
This program and the accompanying materials
|
This program and the accompanying materials
|
||||||
are licensed and made available under the terms and conditions of the BSD License
|
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
|
which accompanies this distribution. The full text of the license may be found at
|
||||||
|
@ -294,6 +294,8 @@ EFI_STATUS
|
||||||
FileSystemMapping. In both cases, the returned name includes the file system
|
FileSystemMapping. In both cases, the returned name includes the file system
|
||||||
mapping (i.e. fs0:\current-dir).
|
mapping (i.e. fs0:\current-dir).
|
||||||
|
|
||||||
|
Note that the current directory string should exclude the tailing backslash character.
|
||||||
|
|
||||||
@param[in] FileSystemMapping A pointer to the file system mapping. If NULL,
|
@param[in] FileSystemMapping A pointer to the file system mapping. If NULL,
|
||||||
then the current working directory is returned.
|
then the current working directory is returned.
|
||||||
|
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
Main file for attrib shell level 2 function.
|
Main file for attrib shell level 2 function.
|
||||||
|
|
||||||
(C) Copyright 2015 Hewlett-Packard Development Company, L.P.<BR>
|
(C) Copyright 2015 Hewlett-Packard Development Company, L.P.<BR>
|
||||||
Copyright (c) 2009 - 2014, Intel Corporation. All rights reserved.<BR>
|
Copyright (c) 2009 - 2015, Intel Corporation. All rights reserved.<BR>
|
||||||
This program and the accompanying materials
|
This program and the accompanying materials
|
||||||
are licensed and made available under the terms and conditions of the BSD License
|
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
|
which accompanies this distribution. The full text of the license may be found at
|
||||||
|
@ -31,8 +31,10 @@ ShellCommandRunCd (
|
||||||
EFI_STATUS Status;
|
EFI_STATUS Status;
|
||||||
LIST_ENTRY *Package;
|
LIST_ENTRY *Package;
|
||||||
CONST CHAR16 *Directory;
|
CONST CHAR16 *Directory;
|
||||||
|
CHAR16 *Cwd;
|
||||||
CHAR16 *Path;
|
CHAR16 *Path;
|
||||||
CHAR16 *Drive;
|
CHAR16 *Drive;
|
||||||
|
UINTN CwdSize;
|
||||||
UINTN DriveSize;
|
UINTN DriveSize;
|
||||||
CHAR16 *ProblemParam;
|
CHAR16 *ProblemParam;
|
||||||
SHELL_STATUS ShellStatus;
|
SHELL_STATUS ShellStatus;
|
||||||
|
@ -121,8 +123,14 @@ ShellCommandRunCd (
|
||||||
ShellPrintHiiEx(-1, -1, NULL, STRING_TOKEN (STR_GEN_NO_CWD), gShellLevel2HiiHandle, L"cd");
|
ShellPrintHiiEx(-1, -1, NULL, STRING_TOKEN (STR_GEN_NO_CWD), gShellLevel2HiiHandle, L"cd");
|
||||||
ShellStatus = SHELL_NOT_FOUND;
|
ShellStatus = SHELL_NOT_FOUND;
|
||||||
} else {
|
} else {
|
||||||
Drive = GetFullyQualifiedPath(Directory);
|
CwdSize = StrSize(Directory) + sizeof(CHAR16);
|
||||||
|
Cwd = AllocateZeroPool(CwdSize);
|
||||||
|
ASSERT(Cwd!=NULL);
|
||||||
|
StrCpyS(Cwd, StrSize(Directory)/sizeof(CHAR16)+1, Directory);
|
||||||
|
StrCatS(Cwd, StrSize(Directory)/sizeof(CHAR16)+1, L"\\");
|
||||||
|
Drive = GetFullyQualifiedPath(Cwd);
|
||||||
PathRemoveLastItem(Drive);
|
PathRemoveLastItem(Drive);
|
||||||
|
FreePool(Cwd);
|
||||||
}
|
}
|
||||||
if (ShellStatus == SHELL_SUCCESS && Drive != NULL) {
|
if (ShellStatus == SHELL_SUCCESS && Drive != NULL) {
|
||||||
//
|
//
|
||||||
|
@ -143,8 +151,14 @@ ShellCommandRunCd (
|
||||||
ShellPrintHiiEx(-1, -1, NULL, STRING_TOKEN (STR_GEN_NO_CWD), gShellLevel2HiiHandle, L"cd");
|
ShellPrintHiiEx(-1, -1, NULL, STRING_TOKEN (STR_GEN_NO_CWD), gShellLevel2HiiHandle, L"cd");
|
||||||
ShellStatus = SHELL_NOT_FOUND;
|
ShellStatus = SHELL_NOT_FOUND;
|
||||||
} else {
|
} else {
|
||||||
Drive = GetFullyQualifiedPath(Directory);
|
CwdSize = StrSize(Directory) + sizeof(CHAR16);
|
||||||
|
Cwd = AllocateZeroPool(CwdSize);
|
||||||
|
ASSERT(Cwd!=NULL);
|
||||||
|
StrCpyS(Cwd, StrSize(Directory)/sizeof(CHAR16)+1, Directory);
|
||||||
|
StrCatS(Cwd, StrSize(Directory)/sizeof(CHAR16)+1, L"\\");
|
||||||
|
Drive = GetFullyQualifiedPath(Cwd);
|
||||||
while (PathRemoveLastItem(Drive));
|
while (PathRemoveLastItem(Drive));
|
||||||
|
FreePool(Cwd);
|
||||||
}
|
}
|
||||||
if (ShellStatus == SHELL_SUCCESS && Drive != NULL) {
|
if (ShellStatus == SHELL_SUCCESS && Drive != NULL) {
|
||||||
//
|
//
|
||||||
|
@ -166,6 +180,7 @@ ShellCommandRunCd (
|
||||||
} else {
|
} else {
|
||||||
ASSERT((Drive == NULL && DriveSize == 0) || (Drive != NULL));
|
ASSERT((Drive == NULL && DriveSize == 0) || (Drive != NULL));
|
||||||
Drive = StrnCatGrow(&Drive, &DriveSize, ShellGetCurrentDir(NULL), 0);
|
Drive = StrnCatGrow(&Drive, &DriveSize, ShellGetCurrentDir(NULL), 0);
|
||||||
|
Drive = StrnCatGrow(&Drive, &DriveSize, L"\\", 0);
|
||||||
if (*Param1Copy == L'\\') {
|
if (*Param1Copy == L'\\') {
|
||||||
while (PathRemoveLastItem(Drive)) ;
|
while (PathRemoveLastItem(Drive)) ;
|
||||||
Drive = StrnCatGrow(&Drive, &DriveSize, Param1Copy+1, 0);
|
Drive = StrnCatGrow(&Drive, &DriveSize, Param1Copy+1, 0);
|
||||||
|
|
|
@ -360,7 +360,7 @@ ValidateAndCopyFiles(
|
||||||
|
|
||||||
NewSize = StrSize(CleanFilePathStr);
|
NewSize = StrSize(CleanFilePathStr);
|
||||||
NewSize += StrSize(Node->FullName);
|
NewSize += StrSize(Node->FullName);
|
||||||
NewSize += (Cwd == NULL)? 0 : StrSize(Cwd);
|
NewSize += (Cwd == NULL)? 0 : (StrSize(Cwd) + sizeof(CHAR16));
|
||||||
if (NewSize > PathSize) {
|
if (NewSize > PathSize) {
|
||||||
PathSize = NewSize;
|
PathSize = NewSize;
|
||||||
}
|
}
|
||||||
|
@ -428,6 +428,7 @@ ValidateAndCopyFiles(
|
||||||
//
|
//
|
||||||
if (Cwd != NULL) {
|
if (Cwd != NULL) {
|
||||||
StrCpyS(DestPath, PathSize / sizeof(CHAR16), Cwd);
|
StrCpyS(DestPath, PathSize / sizeof(CHAR16), Cwd);
|
||||||
|
StrCatS(DestPath, PathSize / sizeof(CHAR16), L"\\");
|
||||||
} else {
|
} else {
|
||||||
ShellPrintHiiEx(-1, -1, NULL, STRING_TOKEN (STR_GEN_DIR_NF), gShellLevel2HiiHandle, L"cp", CleanFilePathStr);
|
ShellPrintHiiEx(-1, -1, NULL, STRING_TOKEN (STR_GEN_DIR_NF), gShellLevel2HiiHandle, L"cp", CleanFilePathStr);
|
||||||
FreePool (CleanFilePathStr);
|
FreePool (CleanFilePathStr);
|
||||||
|
@ -456,6 +457,7 @@ ValidateAndCopyFiles(
|
||||||
//
|
//
|
||||||
if (Cwd != NULL) {
|
if (Cwd != NULL) {
|
||||||
StrCpyS(DestPath, PathSize/sizeof(CHAR16), Cwd);
|
StrCpyS(DestPath, PathSize/sizeof(CHAR16), Cwd);
|
||||||
|
StrCatS(DestPath, PathSize/sizeof(CHAR16), L"\\");
|
||||||
} else {
|
} else {
|
||||||
ShellPrintHiiEx(-1, -1, NULL, STRING_TOKEN (STR_GEN_DIR_NF), gShellLevel2HiiHandle, L"cp", CleanFilePathStr);
|
ShellPrintHiiEx(-1, -1, NULL, STRING_TOKEN (STR_GEN_DIR_NF), gShellLevel2HiiHandle, L"cp", CleanFilePathStr);
|
||||||
FreePool(CleanFilePathStr);
|
FreePool(CleanFilePathStr);
|
||||||
|
@ -467,6 +469,7 @@ ValidateAndCopyFiles(
|
||||||
} else if (StrStr(CleanFilePathStr, L":") == NULL) {
|
} else if (StrStr(CleanFilePathStr, L":") == NULL) {
|
||||||
if (Cwd != NULL) {
|
if (Cwd != NULL) {
|
||||||
StrCpyS(DestPath, PathSize/sizeof(CHAR16), Cwd);
|
StrCpyS(DestPath, PathSize/sizeof(CHAR16), Cwd);
|
||||||
|
StrCatS(DestPath, PathSize/sizeof(CHAR16), L"\\");
|
||||||
} else {
|
} else {
|
||||||
ShellPrintHiiEx(-1, -1, NULL, STRING_TOKEN (STR_GEN_DIR_NF), gShellLevel2HiiHandle, L"cp", CleanFilePathStr);
|
ShellPrintHiiEx(-1, -1, NULL, STRING_TOKEN (STR_GEN_DIR_NF), gShellLevel2HiiHandle, L"cp", CleanFilePathStr);
|
||||||
FreePool(CleanFilePathStr);
|
FreePool(CleanFilePathStr);
|
||||||
|
@ -644,6 +647,7 @@ ShellCommandRunCp (
|
||||||
BOOLEAN SilentMode;
|
BOOLEAN SilentMode;
|
||||||
BOOLEAN RecursiveMode;
|
BOOLEAN RecursiveMode;
|
||||||
CONST CHAR16 *Cwd;
|
CONST CHAR16 *Cwd;
|
||||||
|
CHAR16 *FullCwd;
|
||||||
|
|
||||||
ProblemParam = NULL;
|
ProblemParam = NULL;
|
||||||
ShellStatus = SHELL_SUCCESS;
|
ShellStatus = SHELL_SUCCESS;
|
||||||
|
@ -712,7 +716,11 @@ ShellCommandRunCp (
|
||||||
ShellPrintHiiEx(-1, -1, NULL, STRING_TOKEN (STR_GEN_FILE_NF), gShellLevel2HiiHandle, L"cp", ShellCommandLineGetRawValue(Package, 1));
|
ShellPrintHiiEx(-1, -1, NULL, STRING_TOKEN (STR_GEN_FILE_NF), gShellLevel2HiiHandle, L"cp", ShellCommandLineGetRawValue(Package, 1));
|
||||||
ShellStatus = SHELL_NOT_FOUND;
|
ShellStatus = SHELL_NOT_FOUND;
|
||||||
} else {
|
} else {
|
||||||
ShellStatus = ProcessValidateAndCopyFiles(FileList, Cwd, SilentMode, RecursiveMode);
|
FullCwd = AllocateZeroPool(StrSize(Cwd) + sizeof(CHAR16));
|
||||||
|
ASSERT (FullCwd != NULL);
|
||||||
|
StrCpyS(FullCwd, StrSize(Cwd)/sizeof(CHAR16)+1, Cwd);
|
||||||
|
ShellStatus = ProcessValidateAndCopyFiles(FileList, FullCwd, SilentMode, RecursiveMode);
|
||||||
|
FreePool(FullCwd);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
Main file for ls shell level 2 function.
|
Main file for ls shell level 2 function.
|
||||||
|
|
||||||
(C) Copyright 2013-2015 Hewlett-Packard Development Company, L.P.<BR>
|
(C) Copyright 2013-2015 Hewlett-Packard Development Company, L.P.<BR>
|
||||||
Copyright (c) 2009 - 2014, Intel Corporation. All rights reserved.<BR>
|
Copyright (c) 2009 - 2015, Intel Corporation. All rights reserved.<BR>
|
||||||
This program and the accompanying materials
|
This program and the accompanying materials
|
||||||
are licensed and made available under the terms and conditions of the BSD License
|
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
|
which accompanies this distribution. The full text of the license may be found at
|
||||||
|
@ -669,6 +669,8 @@ ShellCommandRunLs (
|
||||||
ASSERT(FullPath == NULL);
|
ASSERT(FullPath == NULL);
|
||||||
StrnCatGrow(&SearchString, NULL, L"*", 0);
|
StrnCatGrow(&SearchString, NULL, L"*", 0);
|
||||||
StrnCatGrow(&FullPath, NULL, CurDir, 0);
|
StrnCatGrow(&FullPath, NULL, CurDir, 0);
|
||||||
|
Size = FullPath != NULL? StrSize(FullPath) : 0;
|
||||||
|
StrnCatGrow(&FullPath, &Size, L"\\", 0);
|
||||||
} else {
|
} else {
|
||||||
if (StrStr(PathName, L":") == NULL && gEfiShellProtocol->GetCurDir(NULL) == NULL) {
|
if (StrStr(PathName, L":") == NULL && gEfiShellProtocol->GetCurDir(NULL) == NULL) {
|
||||||
//
|
//
|
||||||
|
@ -687,6 +689,8 @@ ShellCommandRunLs (
|
||||||
ShellCommandLineFreeVarList (Package);
|
ShellCommandLineFreeVarList (Package);
|
||||||
return SHELL_OUT_OF_RESOURCES;
|
return SHELL_OUT_OF_RESOURCES;
|
||||||
}
|
}
|
||||||
|
Size = FullPath != NULL? StrSize(FullPath) : 0;
|
||||||
|
StrnCatGrow(&FullPath, &Size, L"\\", 0);
|
||||||
}
|
}
|
||||||
StrnCatGrow(&FullPath, &Size, PathName, 0);
|
StrnCatGrow(&FullPath, &Size, PathName, 0);
|
||||||
if (FullPath == NULL) {
|
if (FullPath == NULL) {
|
||||||
|
|
|
@ -467,6 +467,7 @@ ValidateAndMoveFiles(
|
||||||
CHAR16 *DestPath;
|
CHAR16 *DestPath;
|
||||||
CHAR16 *FullDestPath;
|
CHAR16 *FullDestPath;
|
||||||
CONST CHAR16 *Cwd;
|
CONST CHAR16 *Cwd;
|
||||||
|
CHAR16 *FullCwd;
|
||||||
SHELL_STATUS ShellStatus;
|
SHELL_STATUS ShellStatus;
|
||||||
EFI_SHELL_FILE_INFO *Node;
|
EFI_SHELL_FILE_INFO *Node;
|
||||||
VOID *Response;
|
VOID *Response;
|
||||||
|
@ -483,8 +484,17 @@ ValidateAndMoveFiles(
|
||||||
Attr = 0;
|
Attr = 0;
|
||||||
CleanFilePathStr = NULL;
|
CleanFilePathStr = NULL;
|
||||||
|
|
||||||
|
FullCwd = AllocateZeroPool(StrSize(Cwd) + sizeof(CHAR16));
|
||||||
|
if (FullCwd == NULL) {
|
||||||
|
return SHELL_OUT_OF_RESOURCES;
|
||||||
|
} else {
|
||||||
|
StrCpyS(FullCwd, StrSize(Cwd)/sizeof(CHAR16)+1, Cwd);
|
||||||
|
StrCatS(FullCwd, StrSize(Cwd)/sizeof(CHAR16)+1, L"\\");
|
||||||
|
}
|
||||||
|
|
||||||
Status = ShellLevel2StripQuotes (DestParameter, &CleanFilePathStr);
|
Status = ShellLevel2StripQuotes (DestParameter, &CleanFilePathStr);
|
||||||
if (EFI_ERROR (Status)) {
|
if (EFI_ERROR (Status)) {
|
||||||
|
FreePool (FullCwd);
|
||||||
if (Status == EFI_OUT_OF_RESOURCES) {
|
if (Status == EFI_OUT_OF_RESOURCES) {
|
||||||
return SHELL_OUT_OF_RESOURCES;
|
return SHELL_OUT_OF_RESOURCES;
|
||||||
} else {
|
} else {
|
||||||
|
@ -497,14 +507,16 @@ ValidateAndMoveFiles(
|
||||||
//
|
//
|
||||||
// Get and validate the destination location
|
// Get and validate the destination location
|
||||||
//
|
//
|
||||||
ShellStatus = GetDestinationLocation(CleanFilePathStr, &DestPath, Cwd, (BOOLEAN)(FileList->Link.ForwardLink == FileList->Link.BackLink), &Attr);
|
ShellStatus = GetDestinationLocation(CleanFilePathStr, &DestPath, FullCwd, (BOOLEAN)(FileList->Link.ForwardLink == FileList->Link.BackLink), &Attr);
|
||||||
FreePool (CleanFilePathStr);
|
FreePool (CleanFilePathStr);
|
||||||
|
|
||||||
if (ShellStatus != SHELL_SUCCESS) {
|
if (ShellStatus != SHELL_SUCCESS) {
|
||||||
|
FreePool (FullCwd);
|
||||||
return (ShellStatus);
|
return (ShellStatus);
|
||||||
}
|
}
|
||||||
DestPath = PathCleanUpDirectories(DestPath);
|
DestPath = PathCleanUpDirectories(DestPath);
|
||||||
if (DestPath == NULL) {
|
if (DestPath == NULL) {
|
||||||
|
FreePool (FullCwd);
|
||||||
return (SHELL_OUT_OF_RESOURCES);
|
return (SHELL_OUT_OF_RESOURCES);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -514,6 +526,7 @@ ValidateAndMoveFiles(
|
||||||
SHELL_FREE_NON_NULL(DestPath);
|
SHELL_FREE_NON_NULL(DestPath);
|
||||||
SHELL_FREE_NON_NULL(HiiOutput);
|
SHELL_FREE_NON_NULL(HiiOutput);
|
||||||
SHELL_FREE_NON_NULL(HiiResultOk);
|
SHELL_FREE_NON_NULL(HiiResultOk);
|
||||||
|
FreePool (FullCwd);
|
||||||
return (SHELL_OUT_OF_RESOURCES);
|
return (SHELL_OUT_OF_RESOURCES);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -551,7 +564,7 @@ ValidateAndMoveFiles(
|
||||||
//
|
//
|
||||||
// Validate that the move is valid
|
// Validate that the move is valid
|
||||||
//
|
//
|
||||||
if (!IsValidMove(Node->FullName, Cwd, FullDestPath!=NULL? FullDestPath:DestPath, Node->Info->Attribute, Attr, Node->Status)) {
|
if (!IsValidMove(Node->FullName, FullCwd, FullDestPath!=NULL? FullDestPath:DestPath, Node->Info->Attribute, Attr, Node->Status)) {
|
||||||
ShellStatus = SHELL_INVALID_PARAMETER;
|
ShellStatus = SHELL_INVALID_PARAMETER;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
@ -575,6 +588,7 @@ ValidateAndMoveFiles(
|
||||||
//
|
//
|
||||||
// indicate to stop everything
|
// indicate to stop everything
|
||||||
//
|
//
|
||||||
|
FreePool(FullCwd);
|
||||||
return (SHELL_ABORTED);
|
return (SHELL_ABORTED);
|
||||||
case ShellPromptResponseAll:
|
case ShellPromptResponseAll:
|
||||||
*Resp = Response;
|
*Resp = Response;
|
||||||
|
@ -585,12 +599,13 @@ ValidateAndMoveFiles(
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
FreePool(Response);
|
FreePool(Response);
|
||||||
|
FreePool(FullCwd);
|
||||||
return SHELL_ABORTED;
|
return SHELL_ABORTED;
|
||||||
}
|
}
|
||||||
Status = ShellDeleteFileByName(FullDestPath!=NULL? FullDestPath:DestPath);
|
Status = ShellDeleteFileByName(FullDestPath!=NULL? FullDestPath:DestPath);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (IsBetweenFileSystem(Node->FullName, Cwd, DestPath)) {
|
if (IsBetweenFileSystem(Node->FullName, FullCwd, DestPath)) {
|
||||||
while (FullDestPath == NULL && DestPath != NULL && DestPath[0] != CHAR_NULL && DestPath[StrLen(DestPath) - 1] == L'\\') {
|
while (FullDestPath == NULL && DestPath != NULL && DestPath[0] != CHAR_NULL && DestPath[StrLen(DestPath) - 1] == L'\\') {
|
||||||
DestPath[StrLen(DestPath) - 1] = CHAR_NULL;
|
DestPath[StrLen(DestPath) - 1] = CHAR_NULL;
|
||||||
}
|
}
|
||||||
|
@ -631,6 +646,7 @@ ValidateAndMoveFiles(
|
||||||
SHELL_FREE_NON_NULL(DestPath);
|
SHELL_FREE_NON_NULL(DestPath);
|
||||||
SHELL_FREE_NON_NULL(HiiOutput);
|
SHELL_FREE_NON_NULL(HiiOutput);
|
||||||
SHELL_FREE_NON_NULL(HiiResultOk);
|
SHELL_FREE_NON_NULL(HiiResultOk);
|
||||||
|
FreePool (FullCwd);
|
||||||
return (ShellStatus);
|
return (ShellStatus);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -650,6 +666,8 @@ ShellCommandRunMv (
|
||||||
EFI_STATUS Status;
|
EFI_STATUS Status;
|
||||||
LIST_ENTRY *Package;
|
LIST_ENTRY *Package;
|
||||||
CHAR16 *ProblemParam;
|
CHAR16 *ProblemParam;
|
||||||
|
CHAR16 *Cwd;
|
||||||
|
UINTN CwdSize;
|
||||||
SHELL_STATUS ShellStatus;
|
SHELL_STATUS ShellStatus;
|
||||||
UINTN ParamCount;
|
UINTN ParamCount;
|
||||||
UINTN LoopCounter;
|
UINTN LoopCounter;
|
||||||
|
@ -713,7 +731,13 @@ ShellCommandRunMv (
|
||||||
//
|
//
|
||||||
// ValidateAndMoveFiles will report errors to the screen itself
|
// ValidateAndMoveFiles will report errors to the screen itself
|
||||||
//
|
//
|
||||||
ShellStatus = ValidateAndMoveFiles(FileList, &Response, ShellGetCurrentDir(NULL));
|
CwdSize = StrSize(ShellGetCurrentDir(NULL)) + 1;
|
||||||
|
Cwd = AllocateZeroPool(CwdSize);
|
||||||
|
ASSERT (Cwd != NULL);
|
||||||
|
StrCpyS(Cwd, CwdSize/sizeof(CHAR16), ShellGetCurrentDir(NULL));
|
||||||
|
StrCatS(Cwd, CwdSize/sizeof(CHAR16), L"\\");
|
||||||
|
ShellStatus = ValidateAndMoveFiles(FileList, &Response, Cwd);
|
||||||
|
FreePool(Cwd);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -231,7 +231,9 @@ IsValidDeleteTarget(
|
||||||
Pattern = NULL;
|
Pattern = NULL;
|
||||||
SearchString = NULL;
|
SearchString = NULL;
|
||||||
Size = 0;
|
Size = 0;
|
||||||
Pattern = StrnCatGrow(&Pattern , NULL, TempLocation , 0);
|
Pattern = StrnCatGrow(&Pattern, &Size, TempLocation , 0);
|
||||||
|
Pattern = StrnCatGrow(&Pattern, &Size, L"\\" , 0);
|
||||||
|
Size = 0;
|
||||||
SearchString = StrnCatGrow(&SearchString, &Size, Node->FullName, 0);
|
SearchString = StrnCatGrow(&SearchString, &Size, Node->FullName, 0);
|
||||||
if (!EFI_ERROR(ShellIsDirectory(SearchString))) {
|
if (!EFI_ERROR(ShellIsDirectory(SearchString))) {
|
||||||
SearchString = StrnCatGrow(&SearchString, &Size, L"\\", 0);
|
SearchString = StrnCatGrow(&SearchString, &Size, L"\\", 0);
|
||||||
|
|
|
@ -22,7 +22,7 @@
|
||||||
* functions are non-interactive only
|
* functions are non-interactive only
|
||||||
|
|
||||||
Copyright (c) 2014 Hewlett-Packard Development Company, L.P.
|
Copyright (c) 2014 Hewlett-Packard Development Company, L.P.
|
||||||
Copyright (c) 2009 - 2014, Intel Corporation. All rights reserved.<BR>
|
Copyright (c) 2009 - 2015, Intel Corporation. All rights reserved.<BR>
|
||||||
This program and the accompanying materials
|
This program and the accompanying materials
|
||||||
are licensed and made available under the terms and conditions of the BSD License
|
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
|
which accompanies this distribution. The full text of the license may be found at
|
||||||
|
@ -188,6 +188,7 @@ GetFullyQualifiedPath(
|
||||||
if (StrStr(Path, L":") == NULL) {
|
if (StrStr(Path, L":") == NULL) {
|
||||||
CurDir = gEfiShellProtocol->GetCurDir(NULL);
|
CurDir = gEfiShellProtocol->GetCurDir(NULL);
|
||||||
StrnCatGrow(&PathToReturn, &Size, CurDir, 0);
|
StrnCatGrow(&PathToReturn, &Size, CurDir, 0);
|
||||||
|
StrnCatGrow(&PathToReturn, &Size, L"\\", 0);
|
||||||
if (*Path == L'\\') {
|
if (*Path == L'\\') {
|
||||||
Path++;
|
Path++;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1276,6 +1276,8 @@ ShellExecute (
|
||||||
name. If the DeviceName is not NULL, it returns the current directory name
|
name. If the DeviceName is not NULL, it returns the current directory name
|
||||||
on specified drive.
|
on specified drive.
|
||||||
|
|
||||||
|
Note that the current directory string should exclude the tailing backslash character.
|
||||||
|
|
||||||
@param DeviceName the name of the drive to get directory on
|
@param DeviceName the name of the drive to get directory on
|
||||||
|
|
||||||
@retval NULL the directory does not exist
|
@retval NULL the directory does not exist
|
||||||
|
@ -1708,13 +1710,14 @@ ShellFindFilePath (
|
||||||
|
|
||||||
Path = ShellGetEnvironmentVariable(L"cwd");
|
Path = ShellGetEnvironmentVariable(L"cwd");
|
||||||
if (Path != NULL) {
|
if (Path != NULL) {
|
||||||
Size = StrSize(Path);
|
Size = StrSize(Path) + sizeof(CHAR16);
|
||||||
Size += StrSize(FileName);
|
Size += StrSize(FileName);
|
||||||
TestPath = AllocateZeroPool(Size);
|
TestPath = AllocateZeroPool(Size);
|
||||||
if (TestPath == NULL) {
|
if (TestPath == NULL) {
|
||||||
return (NULL);
|
return (NULL);
|
||||||
}
|
}
|
||||||
StrCpyS(TestPath, Size/sizeof(CHAR16), Path);
|
StrCpyS(TestPath, Size/sizeof(CHAR16), Path);
|
||||||
|
StrCatS(TestPath, Size/sizeof(CHAR16), L"\\");
|
||||||
StrCatS(TestPath, Size/sizeof(CHAR16), FileName);
|
StrCatS(TestPath, Size/sizeof(CHAR16), FileName);
|
||||||
Status = ShellOpenFileByName(TestPath, &Handle, EFI_FILE_MODE_READ, 0);
|
Status = ShellOpenFileByName(TestPath, &Handle, EFI_FILE_MODE_READ, 0);
|
||||||
if (!EFI_ERROR(Status)){
|
if (!EFI_ERROR(Status)){
|
||||||
|
|
Loading…
Reference in New Issue