VirtualBox

source: vbox/trunk/src/VBox/Devices/EFI/Firmware/ShellPkg/Include/Protocol/EfiShellDynamicCommand.h@ 58466

Last change on this file since 58466 was 58466, checked in by vboxsync, 9 years ago

EFI/Firmware: Merged in the svn:eol-style, svn:mime-type and trailing whitespace cleanup that was done after the initial UDK2014.SP1 import: svn merge /vendor/edk2/UDK2014.SP1 /vendor/edk2/current .

  • Property svn:eol-style set to native
File size: 2.8 KB
Line 
1/** @file
2 EFI Shell Dynamic Command registration protocol
3
4 (C) Copyright 2012-2014, Hewlett-Packard Development Company, L.P.
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
9
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.
12
13**/
14
15#ifndef __EFI_SHELL_DYNAMIC_COMMAND_PROTOCOL__
16#define __EFI_SHELL_DYNAMIC_COMMAND_PROTOCOL__
17
18#include <ShellBase.h>
19#include <Protocol/EfiShellParameters.h>
20#include <Protocol/EfiShell.h>
21
22
23// {3C7200E9-005F-4EA4-87DE-A3DFAC8A27C3}
24#define EFI_SHELL_DYNAMIC_COMMAND_PROTOCOL_GUID \
25 { \
26 0x3c7200e9, 0x005f, 0x4ea4, { 0x87, 0xde, 0xa3, 0xdf, 0xac, 0x8a, 0x27, 0xc3 } \
27 }
28
29
30//
31// Define for forward reference.
32//
33typedef struct _EFI_SHELL_DYNAMIC_COMMAND_PROTOCOL EFI_SHELL_DYNAMIC_COMMAND_PROTOCOL;
34
35
36/**
37 This is the shell command handler function pointer callback type. This
38 function handles the command when it is invoked in the shell.
39
40 @param[in] This The instance of the EFI_SHELL_DYNAMIC_COMMAND_PROTOCOL.
41 @param[in] SystemTable The pointer to the system table.
42 @param[in] ShellParameters The parameters associated with the command.
43 @param[in] Shell The instance of the shell protocol used in the context
44 of processing this command.
45
46 @return EFI_SUCCESS the operation was sucessful
47 @return other the operation failed.
48**/
49typedef
50SHELL_STATUS
51(EFIAPI * SHELL_COMMAND_HANDLER)(
52 IN EFI_SHELL_DYNAMIC_COMMAND_PROTOCOL *This,
53 IN EFI_SYSTEM_TABLE *SystemTable,
54 IN EFI_SHELL_PARAMETERS_PROTOCOL *ShellParameters,
55 IN EFI_SHELL_PROTOCOL *Shell
56 );
57
58/**
59 This is the command help handler function pointer callback type. This
60 function is responsible for displaying help information for the associated
61 command.
62
63 @param[in] This The instance of the EFI_SHELL_DYNAMIC_COMMAND_PROTOCOL.
64 @param[in] Language The pointer to the language string to use.
65
66 @return string Pool allocated help string, must be freed by caller
67**/
68typedef
69CHAR16*
70(EFIAPI * SHELL_COMMAND_GETHELP)(
71 IN EFI_SHELL_DYNAMIC_COMMAND_PROTOCOL *This,
72 IN CONST CHAR8 *Language
73 );
74
75/// EFI_SHELL_DYNAMIC_COMMAND_PROTOCOL protocol structure.
76struct _EFI_SHELL_DYNAMIC_COMMAND_PROTOCOL {
77
78 CONST CHAR16 *CommandName;
79 SHELL_COMMAND_HANDLER Handler;
80 SHELL_COMMAND_GETHELP GetHelp;
81
82};
83
84extern EFI_GUID gEfiShellDynamicCommandProtocolGuid;
85
86#endif
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette