mirror of https://github.com/acidanthera/audk.git
ShellPkg/Shell: Add double quotes to args with white space
https://bugzilla.tianocore.org/show_bug.cgi?id=332 When the ShellLib ShellExecute() API or the Shell Protocol Execute() API are used to execute a command, the arguments are parsed to produce the Argc/Argv list in the Shell Parameters Protocol and double quotes are removed from arguments that are surrounded by double quotes. This is the required behavior of the Shell Parameters Protocol. The ProcessCommandLine() function in the shell implementation uses the Argc/Argv list from the Shell Parameters Protocol to assemble a new command line, but the double quotes that may have been originally present for an argument are not preserved. ProcessCommandLine() is updated to check if an argument added to the generated command line contains one or more white space characters, and if it does, double quotes are added around the argument. Cc: Jaben Carsey <jaben.carsey@intel.com> Cc: Ruiyu Ni <ruiyu.ni@intel.com> Contributed-under: TianoCore Contribution Agreement 1.0 Signed-off-by: Michael D Kinney <michael.d.kinney@intel.com> Reviewed-by: Ruiyu Ni <Ruiyu.ni@intel.com>
This commit is contained in:
parent
f7c11d9b99
commit
e044364b82
|
@ -1,7 +1,7 @@
|
||||||
/** @file
|
/** @file
|
||||||
This is THE shell (application)
|
This is THE shell (application)
|
||||||
|
|
||||||
Copyright (c) 2009 - 2016, Intel Corporation. All rights reserved.<BR>
|
Copyright (c) 2009 - 2017, Intel Corporation. All rights reserved.<BR>
|
||||||
(C) Copyright 2013-2014 Hewlett-Packard Development Company, L.P.<BR>
|
(C) Copyright 2013-2014 Hewlett-Packard Development Company, L.P.<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
|
||||||
|
@ -1042,11 +1042,31 @@ ProcessCommandLine(
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
ShellInfoObject.ShellInitSettings.FileName = AllocateCopyPool(StrSize(CurrentArg), CurrentArg);
|
ShellInfoObject.ShellInitSettings.FileName = NULL;
|
||||||
|
Size = 0;
|
||||||
|
//
|
||||||
|
// If first argument contains a space, then add double quotes before the argument
|
||||||
|
//
|
||||||
|
if (StrStr (CurrentArg, L" ") != NULL) {
|
||||||
|
StrnCatGrow(&ShellInfoObject.ShellInitSettings.FileName, &Size, L"\"", 0);
|
||||||
|
if (ShellInfoObject.ShellInitSettings.FileName == NULL) {
|
||||||
|
return (EFI_OUT_OF_RESOURCES);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
StrnCatGrow(&ShellInfoObject.ShellInitSettings.FileName, &Size, CurrentArg, 0);
|
||||||
if (ShellInfoObject.ShellInitSettings.FileName == NULL) {
|
if (ShellInfoObject.ShellInitSettings.FileName == NULL) {
|
||||||
return (EFI_OUT_OF_RESOURCES);
|
return (EFI_OUT_OF_RESOURCES);
|
||||||
}
|
}
|
||||||
//
|
//
|
||||||
|
// If first argument contains a space, then add double quotes after the argument
|
||||||
|
//
|
||||||
|
if (StrStr (CurrentArg, L" ") != NULL) {
|
||||||
|
StrnCatGrow(&ShellInfoObject.ShellInitSettings.FileName, &Size, L"\"", 0);
|
||||||
|
if (ShellInfoObject.ShellInitSettings.FileName == NULL) {
|
||||||
|
return (EFI_OUT_OF_RESOURCES);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
//
|
||||||
// We found `file-name`.
|
// We found `file-name`.
|
||||||
//
|
//
|
||||||
ShellInfoObject.ShellInitSettings.BitUnion.Bits.NoStartup = 1;
|
ShellInfoObject.ShellInitSettings.BitUnion.Bits.NoStartup = 1;
|
||||||
|
@ -1055,13 +1075,28 @@ ProcessCommandLine(
|
||||||
// Add `file-name-options`
|
// Add `file-name-options`
|
||||||
for (Size = 0 ; LoopVar < gEfiShellParametersProtocol->Argc ; LoopVar++) {
|
for (Size = 0 ; LoopVar < gEfiShellParametersProtocol->Argc ; LoopVar++) {
|
||||||
ASSERT((ShellInfoObject.ShellInitSettings.FileOptions == NULL && Size == 0) || (ShellInfoObject.ShellInitSettings.FileOptions != NULL));
|
ASSERT((ShellInfoObject.ShellInitSettings.FileOptions == NULL && Size == 0) || (ShellInfoObject.ShellInitSettings.FileOptions != NULL));
|
||||||
StrnCatGrow(&ShellInfoObject.ShellInitSettings.FileOptions,
|
//
|
||||||
&Size,
|
// Add a space between arguments
|
||||||
L" ",
|
//
|
||||||
0);
|
if (ShellInfoObject.ShellInitSettings.FileOptions != NULL) {
|
||||||
if (ShellInfoObject.ShellInitSettings.FileOptions == NULL) {
|
StrnCatGrow(&ShellInfoObject.ShellInitSettings.FileOptions, &Size, L" ", 0);
|
||||||
SHELL_FREE_NON_NULL(ShellInfoObject.ShellInitSettings.FileName);
|
if (ShellInfoObject.ShellInitSettings.FileOptions == NULL) {
|
||||||
return (EFI_OUT_OF_RESOURCES);
|
SHELL_FREE_NON_NULL(ShellInfoObject.ShellInitSettings.FileName);
|
||||||
|
return (EFI_OUT_OF_RESOURCES);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
//
|
||||||
|
// If an argumnent contains a space, then add double quotes before the argument
|
||||||
|
//
|
||||||
|
if (StrStr (gEfiShellParametersProtocol->Argv[LoopVar], L" ") != NULL) {
|
||||||
|
StrnCatGrow(&ShellInfoObject.ShellInitSettings.FileOptions,
|
||||||
|
&Size,
|
||||||
|
L"\"",
|
||||||
|
0);
|
||||||
|
if (ShellInfoObject.ShellInitSettings.FileOptions == NULL) {
|
||||||
|
SHELL_FREE_NON_NULL(ShellInfoObject.ShellInitSettings.FileName);
|
||||||
|
return (EFI_OUT_OF_RESOURCES);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
StrnCatGrow(&ShellInfoObject.ShellInitSettings.FileOptions,
|
StrnCatGrow(&ShellInfoObject.ShellInitSettings.FileOptions,
|
||||||
&Size,
|
&Size,
|
||||||
|
@ -1071,6 +1106,19 @@ ProcessCommandLine(
|
||||||
SHELL_FREE_NON_NULL(ShellInfoObject.ShellInitSettings.FileName);
|
SHELL_FREE_NON_NULL(ShellInfoObject.ShellInitSettings.FileName);
|
||||||
return (EFI_OUT_OF_RESOURCES);
|
return (EFI_OUT_OF_RESOURCES);
|
||||||
}
|
}
|
||||||
|
//
|
||||||
|
// If an argumnent contains a space, then add double quotes after the argument
|
||||||
|
//
|
||||||
|
if (StrStr (gEfiShellParametersProtocol->Argv[LoopVar], L" ") != NULL) {
|
||||||
|
StrnCatGrow(&ShellInfoObject.ShellInitSettings.FileOptions,
|
||||||
|
&Size,
|
||||||
|
L"\"",
|
||||||
|
0);
|
||||||
|
if (ShellInfoObject.ShellInitSettings.FileOptions == NULL) {
|
||||||
|
SHELL_FREE_NON_NULL(ShellInfoObject.ShellInitSettings.FileName);
|
||||||
|
return (EFI_OUT_OF_RESOURCES);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue