summaryrefslogtreecommitdiff
path: root/ShellPkg/Application/ShellCTestApp/ShellCTestApp.c
blob: 0a60af0932b5ac29e1e4acd6f10311790f1f9c5d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
/** @file
  This is a test application that demonstrates how to use the C-style entry point 
  for a shell application.

  Copyright (c) 2009, Intel Corporation                                                         
  All rights reserved. This program and the accompanying materials                          
  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        
  http://opensource.org/licenses/bsd-license.php                                            

  THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,                     
  WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.             

**/

#include <Uefi.h>
#include <Library/UefiLib.h>
#include <Library/DebugLib.h>
#include <Library/ShellCEntryLib.h>

/**
  UEFI application entry point which has an interface similar to a
  standard C main function.

  The ShellCEntryLib library instance wrappers the actual UEFI application
  entry point and calls this ShellAppMain function.

  @param  ImageHandle  The image handle of the UEFI Application.
  @param  SystemTable  A pointer to the EFI System Table.

  @retval  0               The application exited normally.
  @retval  Other           An error occurred.

**/
INTN 
EFIAPI 
ShellAppMain (
  IN INTN Argc, 
  IN CHAR16 **Argv
  )
{
  INTN Index;

  Print(L"ShellCTestApp.c:ShellAppMain called with %d parameters\n", Argc);
  for (Index = 0; Index < Argc; Index++) {
    Print(L"Argv[%d]: %s\n", Index, Argv[Index]);
  }

  return 0;
}