From 3e99020dbf0a159e34b84e7ae9125f2e368d5390 Mon Sep 17 00:00:00 2001 From: lgao4 Date: Fri, 26 Nov 2010 01:54:49 +0000 Subject: Sync all bug fixes between EDK1.04 and EDK1.06 into EdkCompatibilityPkg. git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@11094 6f19259b-4bc3-4df7-8a09-765794883524 --- .../Sample/Tools/Source/UefiStrGather/StringDB.c | 94 +++++++++++++++------- 1 file changed, 64 insertions(+), 30 deletions(-) (limited to 'EdkCompatibilityPkg/Sample/Tools/Source/UefiStrGather/StringDB.c') diff --git a/EdkCompatibilityPkg/Sample/Tools/Source/UefiStrGather/StringDB.c b/EdkCompatibilityPkg/Sample/Tools/Source/UefiStrGather/StringDB.c index 563204bab9..eaa15ad763 100644 --- a/EdkCompatibilityPkg/Sample/Tools/Source/UefiStrGather/StringDB.c +++ b/EdkCompatibilityPkg/Sample/Tools/Source/UefiStrGather/StringDB.c @@ -1,6 +1,6 @@ /*++ -Copyright (c) 2004 - 2007, Intel Corporation. All rights reserved.
+Copyright (c) 2004 - 2010, 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 @@ -2559,13 +2559,15 @@ ExportPackOut: STATUS StringDBCreateHiiExportPack ( - INT8 *FileName + INT8 *FileName, + WCHAR_STRING_LIST *LanguagesOfInterest ) { - FILE *File = NULL; - LANGUAGE_LIST *Lang = NULL; - EFI_HII_STRING_PACKAGE_HDR *StrPkgHdr = NULL; - SPkgBlkBuffer *BlkList = NULL; + FILE *File; + LANGUAGE_LIST *Lang; + EFI_HII_STRING_PACKAGE_HDR *StrPkgHdr; + SPkgBlkBuffer *BlkList; + WCHAR_STRING_LIST *LOIPtr; if (FileName == NULL) { return STATUS_ERROR; @@ -2577,18 +2579,26 @@ StringDBCreateHiiExportPack ( } for (Lang = mDBData.LanguageList; Lang != NULL; Lang = Lang->Next) { - if (StringDBGenStrPkgHdrAndBlkList(Lang, &StrPkgHdr, &BlkList) != STATUS_SUCCESS) { - fclose (File); - return STATUS_SUCCESS; + for (LOIPtr = LanguagesOfInterest; LOIPtr != NULL; LOIPtr = LOIPtr->Next) { + if (wcscmp (LOIPtr->Str, Lang->LanguageName) == 0) { + break; + } } - StrPkgWriteHdrBinary (File, StrPkgHdr); - StrPkgWriteBlkListBinary (File, BlkList); + if ((LanguagesOfInterest == NULL) || + (LanguagesOfInterest != NULL && LOIPtr != NULL)) { + if (StringDBGenStrPkgHdrAndBlkList(Lang, &StrPkgHdr, &BlkList) != STATUS_SUCCESS) { + fclose (File); + return STATUS_SUCCESS; + } - StrPkgHdrFree (StrPkgHdr); - StrPkgBlkBufferListFree (BlkList); - } + StrPkgWriteHdrBinary (File, StrPkgHdr); + StrPkgWriteBlkListBinary (File, BlkList); + StrPkgHdrFree (StrPkgHdr); + StrPkgBlkBufferListFree (BlkList); + } + } fclose (File); return STATUS_SUCCESS; } @@ -2605,16 +2615,18 @@ static const char *gSourceFileHeader[] = { STATUS StringDBDumpCStrings ( INT8 *BaseName, - INT8 *FileName + INT8 *FileName, + WCHAR_STRING_LIST *LanguagesOfInterest ) { EFI_STATUS Status; - FILE *File = NULL; - LANGUAGE_LIST *Lang = NULL; - EFI_HII_STRING_PACKAGE_HDR **StrPkgHdr = NULL; - SPkgBlkBuffer **BlkList = NULL; + FILE *File; + LANGUAGE_LIST *Lang; + EFI_HII_STRING_PACKAGE_HDR **StrPkgHdr; + SPkgBlkBuffer **BlkList; UINT32 Index; - UINT32 LangNumber = 0; + UINT32 LangNumber; + WCHAR_STRING_LIST *LOIPtr; if ((BaseName == NULL) || (FileName == NULL)) { return STATUS_ERROR; @@ -2631,14 +2643,36 @@ StringDBDumpCStrings ( BlkList = (SPkgBlkBuffer **) malloc (sizeof (SPkgBlkBuffer *) * LangNumber); for (Index = 0; Index < LangNumber; Index++) { StrPkgHdr[Index] = NULL; - BlkList[Index] = NULL; + BlkList[Index] = NULL; } - for (Index = 0, Lang = mDBData.LanguageList; Lang != NULL; Lang = Lang->Next, Index++) { - Status = StringDBGenStrPkgHdrAndBlkList(Lang, &StrPkgHdr[Index], &BlkList[Index]); - if (EFI_ERROR(Status)) { - return Status; + for (Index = 0, Lang = mDBData.LanguageList; Lang != NULL; Lang = Lang->Next) { + for (LOIPtr = LanguagesOfInterest; LOIPtr != NULL; LOIPtr = LOIPtr->Next) { + if (wcscmp (LOIPtr->Str, Lang->LanguageName) == 0) { + break; + } } + if ((LanguagesOfInterest == NULL) || + (LanguagesOfInterest != NULL && LOIPtr != NULL)) { + Status = StringDBGenStrPkgHdrAndBlkList(Lang, &StrPkgHdr[Index], &BlkList[Index]); + Index++; + if (EFI_ERROR(Status)) { + free (StrPkgHdr); + free (BlkList); + return STATUS_ERROR; + } + } + } + + // + // Update LangNumber after filter + // + LangNumber = Index; + + if (LangNumber == 0) { + free (StrPkgHdr); + free (BlkList); + return STATUS_SUCCESS; } if ((File = fopen (FileName, "w")) == NULL) { @@ -2657,11 +2691,9 @@ StringDBDumpCStrings ( // StrPkgWirteArrayLength (File, LangNumber, StrPkgHdr); - for (Index = 0, Lang = mDBData.LanguageList; Lang != NULL; Lang = Lang->Next, Index++) { - if (StrPkgHdr[Index] != NULL) { - StrPkgWriteHdrCFile (File, StrPkgHdr[Index]); - StrPkgWriteBlkListCFile (File, BlkList[Index], (Lang->Next == NULL) ? TRUE : FALSE); - } + for (Index = 0; Index < LangNumber; Index++) { + StrPkgWriteHdrCFile (File, StrPkgHdr[Index]); + StrPkgWriteBlkListCFile (File, BlkList[Index], (Index == LangNumber - 1) ? TRUE : FALSE); StrPkgHdrFree (StrPkgHdr[Index]); StrPkgBlkBufferListFree (BlkList[Index]); @@ -2670,5 +2702,7 @@ StringDBDumpCStrings ( fprintf (File, "\n};\n"); fclose (File); + free (StrPkgHdr); + free (BlkList); return STATUS_SUCCESS; } -- cgit v1.2.3