summaryrefslogtreecommitdiff
path: root/EdkCompatibilityPkg/Compatibility/FrameworkHiiToUefiHiiThunk/HiiDatabase.c
diff options
context:
space:
mode:
authorqwang12 <qwang12@6f19259b-4bc3-4df7-8a09-765794883524>2008-04-14 06:57:09 +0000
committerqwang12 <qwang12@6f19259b-4bc3-4df7-8a09-765794883524>2008-04-14 06:57:09 +0000
commitee3428bb58cab20303116e6126837e39bfa64d74 (patch)
tree0095584ec4740a41e35d546c6f055e54943f639b /EdkCompatibilityPkg/Compatibility/FrameworkHiiToUefiHiiThunk/HiiDatabase.c
parentc344685c0cbd23d00ce032163cd42530c3068996 (diff)
downloadedk2-platforms-ee3428bb58cab20303116e6126837e39bfa64d74.tar.xz
Add in thunk support for HiiGetSecondaryLanguages and HiiGetPrimaryLanguages
git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@5064 6f19259b-4bc3-4df7-8a09-765794883524
Diffstat (limited to 'EdkCompatibilityPkg/Compatibility/FrameworkHiiToUefiHiiThunk/HiiDatabase.c')
-rw-r--r--EdkCompatibilityPkg/Compatibility/FrameworkHiiToUefiHiiThunk/HiiDatabase.c73
1 files changed, 68 insertions, 5 deletions
diff --git a/EdkCompatibilityPkg/Compatibility/FrameworkHiiToUefiHiiThunk/HiiDatabase.c b/EdkCompatibilityPkg/Compatibility/FrameworkHiiToUefiHiiThunk/HiiDatabase.c
index c7d339e107..d5ef19c356 100644
--- a/EdkCompatibilityPkg/Compatibility/FrameworkHiiToUefiHiiThunk/HiiDatabase.c
+++ b/EdkCompatibilityPkg/Compatibility/FrameworkHiiToUefiHiiThunk/HiiDatabase.c
@@ -1,8 +1,8 @@
/**@file
+Framework to UEFI 2.1 HII Thunk. The driver consume UEFI HII protocols
+to produce a Framework HII protocol.
-Framework to UEFI 2.1 HII Thunk
-
-Copyright (c) 2003, Intel Corporation
+Copyright (c) 2008, 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
@@ -175,7 +175,36 @@ Returns:
--*/
{
- ASSERT (FALSE);
+ EFI_HII_THUNK_PRIVATE_DATA *Private;
+ EFI_HII_HANDLE UefiHiiHandle;
+ CHAR8 *AsciiLanguageCodes;
+ CHAR16 *UnicodeLanguageCodes;
+
+ Private = EFI_HII_THUNK_PRIVATE_DATA_FROM_THIS(This);
+
+
+
+ UefiHiiHandle = FrameworkHiiHandleToUefiHiiHandle (Private, Handle);
+ if (UefiHiiHandle == NULL) {
+ return EFI_INVALID_PARAMETER;
+ }
+
+ AsciiLanguageCodes = HiiLibGetSupportedLanguages (UefiHiiHandle);
+
+ if (AsciiLanguageCodes == NULL) {
+ return EFI_INVALID_PARAMETER;
+ }
+
+ UnicodeLanguageCodes = AllocateZeroPool (AsciiStrSize (AsciiLanguageCodes) * sizeof (CHAR16));
+ if (UnicodeLanguageCodes == NULL) {
+ return EFI_OUT_OF_RESOURCES;
+ }
+
+ //
+ // The language returned is in RFC 3066 format.
+ //
+ *LanguageString = AsciiStrToUnicodeStr (AsciiLanguageCodes, UnicodeLanguageCodes);
+
return EFI_SUCCESS;
}
@@ -200,7 +229,41 @@ Returns:
--*/
{
- ASSERT (FALSE);
+ EFI_HII_THUNK_PRIVATE_DATA *Private;
+ EFI_HII_HANDLE UefiHiiHandle;
+ CHAR8 *AsciiPrimaryLanguage;
+ CHAR8 *AsciiLanguageCodes;
+ CHAR16 *UnicodeLanguageCodes;
+
+ Private = EFI_HII_THUNK_PRIVATE_DATA_FROM_THIS(This);
+
+
+
+ UefiHiiHandle = FrameworkHiiHandleToUefiHiiHandle (Private, Handle);
+ if (UefiHiiHandle == NULL) {
+ return EFI_INVALID_PARAMETER;
+ }
+
+ AsciiPrimaryLanguage = AllocateZeroPool (StrLen (PrimaryLanguage) + 1);
+
+ UnicodeStrToAsciiStr (PrimaryLanguage, AsciiPrimaryLanguage);
+
+ AsciiLanguageCodes = HiiLibGetSupportedSecondaryLanguages (UefiHiiHandle, AsciiPrimaryLanguage);
+
+ if (AsciiLanguageCodes == NULL) {
+ return EFI_INVALID_PARAMETER;
+ }
+
+ UnicodeLanguageCodes = AllocateZeroPool (AsciiStrSize (AsciiLanguageCodes) * sizeof (CHAR16));
+ if (UnicodeLanguageCodes == NULL) {
+ return EFI_OUT_OF_RESOURCES;
+ }
+
+ //
+ // The language returned is in RFC 3066 format.
+ //
+ *LanguageString = AsciiStrToUnicodeStr (AsciiLanguageCodes, UnicodeLanguageCodes);
+
return EFI_SUCCESS;
}