2 Main file for exit shell level 1 function.
4 Copyright (c) 2009 - 2010, Intel Corporation. All rights reserved.<BR>
5 This program and the accompanying materials
6 are licensed and made available under the terms and conditions of the BSD License
7 which accompanies this distribution. The full text of the license may be found at
8 http://opensource.org/licenses/bsd-license.php
10 THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
11 WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
15 #include "UefiShellLevel1CommandsLib.h"
17 STATIC CONST SHELL_PARAM_ITEM ParamList
[] = {
23 Function for 'exit' command.
25 @param[in] ImageHandle Handle to the Image (NULL if Internal).
26 @param[in] SystemTable Pointer to the System Table (NULL if Internal).
31 IN EFI_HANDLE ImageHandle
,
32 IN EFI_SYSTEM_TABLE
*SystemTable
38 SHELL_STATUS ShellStatus
;
40 ShellStatus
= SHELL_SUCCESS
;
43 // initialize the shell lib (we must be in non-auto-init...)
45 Status
= ShellInitialize();
46 ASSERT_EFI_ERROR(Status
);
48 Status
= CommandInit();
49 ASSERT_EFI_ERROR(Status
);
52 // parse the command line
54 Status
= ShellCommandLineParse (ParamList
, &Package
, &ProblemParam
, TRUE
);
55 if (EFI_ERROR(Status
)) {
56 if (Status
== EFI_VOLUME_CORRUPTED
&& ProblemParam
!= NULL
) {
57 ShellPrintHiiEx(-1, -1, NULL
, STRING_TOKEN (STR_GEN_PROBLEM
), gShellLevel1HiiHandle
, ProblemParam
);
58 FreePool(ProblemParam
);
59 ShellStatus
= SHELL_INVALID_PARAMETER
;
66 // If we are in a batch file and /b then pass TRUE otherwise false...
68 ShellCommandRegisterExit((BOOLEAN
)(gEfiShellProtocol
->BatchIsActive() && ShellCommandLineGetFlag(Package
, L
"/b")));
71 // return the specified error code
73 if (ShellCommandLineGetRawValue(Package
, 1) != NULL
) {
74 ShellStatus
= (SHELL_STATUS
)(ShellStrToUintn(ShellCommandLineGetRawValue(Package
, 1)));
77 ShellCommandLineFreeVarList (Package
);