https://bugzilla.tianocore.org/show_bug.cgi?id=1373 Replace BSD 2-Clause License with BSD+Patent License. This change is based on the following emails: https://lists.01.org/pipermail/edk2-devel/2019-February/036260.html https://lists.01.org/pipermail/edk2-devel/2018-October/030385.html RFCs with detailed process for the license change: V3: https://lists.01.org/pipermail/edk2-devel/2019-March/038116.html V2: https://lists.01.org/pipermail/edk2-devel/2019-March/037669.html V1: https://lists.01.org/pipermail/edk2-devel/2019-March/037500.html Contributed-under: TianoCore Contribution Agreement 1.1 Signed-off-by: Michael D Kinney <michael.d.kinney@intel.com> Reviewed-by: Ray Ni <ray.ni@intel.com> Reviewed-by: Jaben Carsey <jaben.carsey@intel.com>
		
			
				
	
	
		
			281 lines
		
	
	
		
			9.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			281 lines
		
	
	
		
			9.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /** @file
 | |
|   Main file for Alias shell level 3 function.
 | |
| 
 | |
|   (C) Copyright 2015 Hewlett-Packard Development Company, L.P.<BR>
 | |
|   Copyright (c) 2009 - 2018, Intel Corporation. All rights reserved. <BR>
 | |
|   SPDX-License-Identifier: BSD-2-Clause-Patent
 | |
| 
 | |
| **/
 | |
| 
 | |
| #include "UefiShellLevel3CommandsLib.h"
 | |
| 
 | |
| #include <Library/ShellLib.h>
 | |
| 
 | |
| /**
 | |
|   Print out single alias registered with the Shell.
 | |
| 
 | |
|   @param[in]  Alias             Points to the NULL-terminated shell alias.
 | |
|                                 If this parameter is NULL, then all
 | |
|                                 aliases will be returned in ReturnedData.
 | |
|   @retval     SHELL_SUCCESS     the printout was sucessful
 | |
| **/
 | |
| SHELL_STATUS
 | |
| PrintSingleShellAlias(
 | |
|   IN  CONST CHAR16 *Alias
 | |
|   )
 | |
| {
 | |
|   CONST CHAR16        *ConstAliasVal;
 | |
|   SHELL_STATUS        ShellStatus;
 | |
|   BOOLEAN             Volatile;
 | |
| 
 | |
|   ShellStatus = SHELL_SUCCESS;
 | |
|   ConstAliasVal = gEfiShellProtocol->GetAlias (Alias, &Volatile);
 | |
|   if (ConstAliasVal == NULL) {
 | |
|     ShellPrintHiiEx (-1, -1, NULL, STRING_TOKEN (STR_GEN_PARAM_INV), gShellLevel3HiiHandle, L"alias", Alias);
 | |
|     ShellStatus = SHELL_INVALID_PARAMETER;
 | |
|   } else {
 | |
|     if (ShellCommandIsOnAliasList (Alias)) {
 | |
|       Volatile = FALSE;
 | |
|     }
 | |
|     ShellPrintHiiEx (-1, -1, NULL, STRING_TOKEN (STR_ALIAS_OUTPUT), gShellLevel3HiiHandle, !Volatile ? L' ' : L'*', Alias, ConstAliasVal);
 | |
|   }
 | |
|   return ShellStatus;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Print out each alias registered with the Shell.
 | |
| 
 | |
|   @retval STATUS_SUCCESS  the printout was sucessful
 | |
|   @return any return code from GetNextVariableName except EFI_NOT_FOUND
 | |
| **/
 | |
| SHELL_STATUS
 | |
| PrintAllShellAlias(
 | |
|   VOID
 | |
|   )
 | |
| {
 | |
|   CONST CHAR16      *ConstAllAliasList;
 | |
|   CHAR16            *Alias;
 | |
|   CHAR16            *Walker;
 | |
| 
 | |
|   ConstAllAliasList = gEfiShellProtocol->GetAlias(NULL, NULL);
 | |
|   if (ConstAllAliasList == NULL) {
 | |
|     return (SHELL_SUCCESS);
 | |
|   }
 | |
|   Alias = AllocateZeroPool(StrSize(ConstAllAliasList));
 | |
|   if (Alias == NULL) {
 | |
|     return (SHELL_OUT_OF_RESOURCES);
 | |
|   }
 | |
|   Walker = (CHAR16*)ConstAllAliasList;
 | |
| 
 | |
|   do {
 | |
|     CopyMem(Alias, Walker, StrSize(Walker));
 | |
|     Walker = StrStr(Alias, L";");
 | |
|     if (Walker != NULL) {
 | |
|       Walker[0] = CHAR_NULL;
 | |
|       Walker = Walker + 1;
 | |
|     }
 | |
|     PrintSingleShellAlias(Alias);
 | |
|   } while (Walker != NULL && Walker[0] != CHAR_NULL);
 | |
| 
 | |
|   FreePool(Alias);
 | |
| 
 | |
|   return (SHELL_SUCCESS);
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Changes a shell command alias.
 | |
| 
 | |
|   This function creates an alias for a shell command or if Alias is NULL it will delete an existing alias.
 | |
| 
 | |
| 
 | |
|   @param[in] Command            Points to the NULL-terminated shell command or existing alias.
 | |
|   @param[in] Alias              Points to the NULL-terminated alias for the shell command. If this is NULL, and
 | |
|                                 Command refers to an alias, that alias will be deleted.
 | |
|   @param[in] Replace            If TRUE and the alias already exists, then the existing alias will be replaced. If
 | |
|                                 FALSE and the alias already exists, then the existing alias is unchanged and
 | |
|                                 EFI_ACCESS_DENIED is returned.
 | |
|   @param[in] Volatile           if TRUE the Alias being set will be stored in a volatile fashion.  if FALSE the
 | |
|                                 Alias being set will be stored in a non-volatile fashion.
 | |
| 
 | |
|   @retval SHELL_SUCCESS        Alias created or deleted successfully.
 | |
|   @retval SHELL_NOT_FOUND       the Alias intended to be deleted was not found
 | |
|   @retval SHELL_ACCESS_DENIED   The alias is a built-in alias or already existed and Replace was set to
 | |
|                                 FALSE.
 | |
|   @retval SHELL_DEVICE_ERROR    Command is null or the empty string.
 | |
| **/
 | |
| SHELL_STATUS
 | |
| ShellLevel3CommandsLibSetAlias(
 | |
|   IN CONST CHAR16 *Command,
 | |
|   IN CONST CHAR16 *Alias,
 | |
|   IN BOOLEAN Replace,
 | |
|   IN BOOLEAN Volatile
 | |
|   )
 | |
| {
 | |
|   SHELL_STATUS        ShellStatus;
 | |
|   EFI_STATUS          Status;
 | |
| 
 | |
|   ShellStatus = SHELL_SUCCESS;
 | |
|   Status = gEfiShellProtocol->SetAlias (Command, Alias, Replace, Volatile);
 | |
|   if (EFI_ERROR(Status)) {
 | |
|     if (Status == EFI_ACCESS_DENIED) {
 | |
|       ShellPrintHiiEx (-1, -1, NULL, STRING_TOKEN (STR_GEN_ERR_AD), gShellLevel3HiiHandle, L"alias");
 | |
|       ShellStatus = SHELL_ACCESS_DENIED;
 | |
|     } else if (Status == EFI_NOT_FOUND) {
 | |
|       ShellPrintHiiEx (-1, -1, NULL, STRING_TOKEN (STR_GEN_ERR_NOT_FOUND), gShellLevel3HiiHandle, L"alias", Command);
 | |
|       ShellStatus = SHELL_NOT_FOUND;
 | |
|     } else {
 | |
|       ShellPrintHiiEx (-1, -1, NULL, STRING_TOKEN (STR_GEN_ERR_UK), gShellLevel3HiiHandle, L"alias", Status);
 | |
|       ShellStatus = SHELL_DEVICE_ERROR;
 | |
|     }
 | |
|   }
 | |
|   return ShellStatus;
 | |
| }
 | |
| 
 | |
| STATIC CONST SHELL_PARAM_ITEM ParamList[] = {
 | |
|   {L"-v", TypeFlag},
 | |
|   {L"-d", TypeValue},
 | |
|   {NULL, TypeMax}
 | |
|   };
 | |
| 
 | |
| /**
 | |
|   Function for 'alias' command.
 | |
| 
 | |
|   @param[in] ImageHandle  Handle to the Image (NULL if Internal).
 | |
|   @param[in] SystemTable  Pointer to the System Table (NULL if Internal).
 | |
| **/
 | |
| SHELL_STATUS
 | |
| EFIAPI
 | |
| ShellCommandRunAlias (
 | |
|   IN EFI_HANDLE        ImageHandle,
 | |
|   IN EFI_SYSTEM_TABLE  *SystemTable
 | |
|   )
 | |
| {
 | |
|   EFI_STATUS          Status;
 | |
|   LIST_ENTRY          *Package;
 | |
|   CHAR16              *ProblemParam;
 | |
|   SHELL_STATUS        ShellStatus;
 | |
|   CONST CHAR16        *Param1;
 | |
|   CONST CHAR16        *Param2;
 | |
|   CONST CHAR16        *ParamStrD;
 | |
|   CHAR16              *CleanParam2;
 | |
|   BOOLEAN             DeleteFlag;
 | |
|   BOOLEAN             VolatileFlag;
 | |
| 
 | |
|   ProblemParam        = NULL;
 | |
|   ShellStatus         = SHELL_SUCCESS;
 | |
|   CleanParam2         = NULL;
 | |
| 
 | |
|   //
 | |
|   // initialize the shell lib (we must be in non-auto-init...)
 | |
|   //
 | |
|   Status = ShellInitialize();
 | |
|   ASSERT_EFI_ERROR(Status);
 | |
| 
 | |
|   Status = CommandInit();
 | |
|   ASSERT_EFI_ERROR(Status);
 | |
| 
 | |
|   //
 | |
|   // parse the command line
 | |
|   //
 | |
|   Status = ShellCommandLineParse (ParamList, &Package, &ProblemParam, TRUE);
 | |
|   if (EFI_ERROR(Status)) {
 | |
|     if (Status == EFI_VOLUME_CORRUPTED && ProblemParam != NULL) {
 | |
|       ShellPrintHiiEx(-1, -1, NULL, STRING_TOKEN (STR_GEN_PROBLEM), gShellLevel3HiiHandle, L"alias", ProblemParam);
 | |
|       FreePool(ProblemParam);
 | |
|       ShellStatus = SHELL_INVALID_PARAMETER;
 | |
|     } else {
 | |
|       ASSERT(FALSE);
 | |
|     }
 | |
|   } else {
 | |
|     Param1 = ShellCommandLineGetRawValue(Package, 1);
 | |
|     Param2 = ShellCommandLineGetRawValue(Package, 2);
 | |
| 
 | |
|     DeleteFlag   = ShellCommandLineGetFlag (Package, L"-d");
 | |
|     VolatileFlag = ShellCommandLineGetFlag (Package, L"-v");
 | |
| 
 | |
|     if (Param2 != NULL) {
 | |
|       CleanParam2 = AllocateCopyPool (StrSize(Param2), Param2);
 | |
|       if (CleanParam2 == NULL) {
 | |
|         ShellCommandLineFreeVarList (Package);
 | |
|         return SHELL_OUT_OF_RESOURCES;
 | |
|       }
 | |
| 
 | |
|       if (CleanParam2[0] == L'\"' && CleanParam2[StrLen(CleanParam2)-1] == L'\"') {
 | |
|         CleanParam2[StrLen(CleanParam2)-1] = L'\0';
 | |
|         CopyMem (CleanParam2, CleanParam2 + 1, StrSize(CleanParam2) - sizeof(CleanParam2[0]));
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     if (!DeleteFlag && !VolatileFlag) {
 | |
|       switch (ShellCommandLineGetCount (Package)) {
 | |
|         case 1:
 | |
|           //
 | |
|           // "alias"
 | |
|           //
 | |
|           ShellStatus = PrintAllShellAlias ();
 | |
|           break;
 | |
|         case 2:
 | |
|           //
 | |
|           // "alias Param1"
 | |
|           //
 | |
|           ShellStatus = PrintSingleShellAlias (Param1);
 | |
|           break;
 | |
|         case 3:
 | |
|           //
 | |
|           // "alias Param1 CleanParam2"
 | |
|           //
 | |
|           ShellStatus = ShellLevel3CommandsLibSetAlias (CleanParam2, Param1, FALSE, VolatileFlag);
 | |
|           break;
 | |
|         default:
 | |
|           ShellPrintHiiEx (-1, -1, NULL, STRING_TOKEN (STR_GEN_TOO_MANY), gShellLevel3HiiHandle, L"alias");
 | |
|           ShellStatus = SHELL_INVALID_PARAMETER;
 | |
|       }
 | |
|     } else if (DeleteFlag) {
 | |
|       if (VolatileFlag || ShellCommandLineGetCount (Package) > 1) {
 | |
|         ShellPrintHiiEx (-1, -1, NULL, STRING_TOKEN (STR_GEN_TOO_MANY), gShellLevel3HiiHandle, L"alias");
 | |
|         ShellStatus = SHELL_INVALID_PARAMETER;
 | |
|       } else {
 | |
|         ParamStrD = ShellCommandLineGetValue (Package, L"-d");
 | |
|         if (ParamStrD == NULL) {
 | |
|           ShellPrintHiiEx (-1, -1, NULL, STRING_TOKEN (STR_GEN_TOO_FEW), gShellLevel3HiiHandle, L"alias");
 | |
|           ShellStatus = SHELL_INVALID_PARAMETER;
 | |
|         } else {
 | |
|           //
 | |
|           // Delete an alias: "alias -d ParamStrD"
 | |
|           //
 | |
|           ShellStatus = ShellLevel3CommandsLibSetAlias (ParamStrD, NULL, TRUE, FALSE);
 | |
|         }
 | |
|       }
 | |
|     } else {
 | |
|       //
 | |
|       // Set volatile alias.
 | |
|       //
 | |
|       ASSERT (VolatileFlag);
 | |
|       ASSERT (!DeleteFlag);
 | |
|       switch (ShellCommandLineGetCount (Package)) {
 | |
|         case 1:
 | |
|         case 2:
 | |
|           ShellPrintHiiEx (-1, -1, NULL, STRING_TOKEN (STR_GEN_TOO_FEW), gShellLevel3HiiHandle, L"alias");
 | |
|           ShellStatus = SHELL_INVALID_PARAMETER;
 | |
|           break;
 | |
|         case 3:
 | |
|           //
 | |
|           // "alias -v Param1 CleanParam2"
 | |
|           //
 | |
|           ShellStatus = ShellLevel3CommandsLibSetAlias (CleanParam2, Param1, FALSE, VolatileFlag);
 | |
|           break;
 | |
|         default:
 | |
|           ShellPrintHiiEx (-1, -1, NULL, STRING_TOKEN (STR_GEN_TOO_MANY), gShellLevel3HiiHandle, L"alias");
 | |
|           ShellStatus = SHELL_INVALID_PARAMETER;
 | |
|       }
 | |
|     }
 | |
|     //
 | |
|     // free the command line package
 | |
|     //
 | |
|     ShellCommandLineFreeVarList (Package);
 | |
|   }
 | |
| 
 | |
|   SHELL_FREE_NON_NULL (CleanParam2);
 | |
|   return (ShellStatus);
 | |
| }
 |