X-Git-Url: https://git.proxmox.com/?p=mirror_edk2.git;a=blobdiff_plain;f=EdkCompatibilityPkg%2FSample%2FTools%2FSource%2FUefiStrGather%2FStringDB.c;h=eaa15ad76304af2af7198c18affe36a2fee732a0;hp=563204bab98c604d1c92e0d5a24cd7e911315548;hb=3e99020dbf0a159e34b84e7ae9125f2e368d5390;hpb=68bb5ce77e51cf35791e46f2202e36da97e5e6be 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; }