From 0d4a6c3dfc06d7d5769c19a3d112c5fdeae70525 Mon Sep 17 00:00:00 2001 From: Qiu Shumin Date: Sun, 21 Feb 2016 15:55:14 +0800 Subject: [PATCH] MdeModulePkg: Add sample help information for HelloWorld application. Since Shell supports finding help information from resource section of application image. We enhance the HelloWorld to add help information string. After the HelloWorld are loaded in system the help string will be stored in resource section of the application image. Cc: Feng Tian Cc: Jaben Carsey Cc: Liming Gao Cc: Ruiyu Ni Contributed-under: TianoCore Contribution Agreement 1.0 Signed-off-by: Qiu Shumin Reviewed-by: Ruiyu Ni Reviewed-by: Liming Gao --- .../Application/HelloWorld/HelloWorld.c | 11 +++++++- .../Application/HelloWorld/HelloWorld.inf | 8 +++++- .../Application/HelloWorld/HelloWorldStr.uni | 27 +++++++++++++++++++ 3 files changed, 44 insertions(+), 2 deletions(-) create mode 100644 MdeModulePkg/Application/HelloWorld/HelloWorldStr.uni diff --git a/MdeModulePkg/Application/HelloWorld/HelloWorld.c b/MdeModulePkg/Application/HelloWorld/HelloWorld.c index 1821b2dd76..164571bfb0 100644 --- a/MdeModulePkg/Application/HelloWorld/HelloWorld.c +++ b/MdeModulePkg/Application/HelloWorld/HelloWorld.c @@ -2,7 +2,7 @@ This sample application bases on HelloWorld PCD setting to print "UEFI Hello World!" to the UEFI Console. - Copyright (c) 2006 - 2008, Intel Corporation. All rights reserved.
+ Copyright (c) 2006 - 2016, 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 @@ -18,6 +18,15 @@ #include #include +// +// String token ID of help message text. +// Shell supports to find help message in the resource section of an application image if +// .MAN file is not found. This global variable is added to make build tool recognizes +// that the help string is consumed by user and then build tool will add the string into +// the resource section. Thus the application can use '-?' option to show help message in +// Shell. +// +GLOBAL_REMOVE_IF_UNREFERENCED EFI_STRING_ID mStringHelpTokenId = STRING_TOKEN (STR_HELLO_WORLD_HELP_INFORMATION); /** The user Entry Point for Application. The user code starts with this function diff --git a/MdeModulePkg/Application/HelloWorld/HelloWorld.inf b/MdeModulePkg/Application/HelloWorld/HelloWorld.inf index 6514ef32ec..2240e17b72 100644 --- a/MdeModulePkg/Application/HelloWorld/HelloWorld.inf +++ b/MdeModulePkg/Application/HelloWorld/HelloWorld.inf @@ -6,7 +6,7 @@ # # It demos how to use EDKII PCD mechanism to make code more flexible. # -# Copyright (c) 2008 - 2014, Intel Corporation. All rights reserved.
+# Copyright (c) 2008 - 2016, 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 @@ -27,6 +27,11 @@ VERSION_STRING = 1.0 ENTRY_POINT = UefiMain +# +# This flag specifies whether HII resource section is generated into PE image. +# + UEFI_HII_RESOURCE_SECTION = TRUE + # # The following information is for reference only and not required by the build tools. # @@ -35,6 +40,7 @@ [Sources] HelloWorld.c + HelloWorldStr.uni [Packages] MdePkg/MdePkg.dec diff --git a/MdeModulePkg/Application/HelloWorld/HelloWorldStr.uni b/MdeModulePkg/Application/HelloWorld/HelloWorldStr.uni new file mode 100644 index 0000000000..3b8b33a37a --- /dev/null +++ b/MdeModulePkg/Application/HelloWorld/HelloWorldStr.uni @@ -0,0 +1,27 @@ +// /** @file +// Sample UEFI Application Reference EDKII Module. +// +// This is a sample shell application that will print "UEFI Hello World!" to the +// UEFI Console based on PCD setting. +// +// It demos how to use EDKII PCD mechanism to make code more flexible. +// +// Copyright (c) 2016, 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. +// +// **/ + +/=# + +#langdef en-US "English" + +#string STR_HELLO_WORLD_HELP_INFORMATION #language en-US "" +".TH HelloWorld 0 "Displays a \"UEFI Hello World!\" string."\r\n" +".SH NAME\r\n" +"HelloWorld application.\r\n" -- 2.39.2