]> git.proxmox.com Git - mirror_edk2.git/blame - EdkCompatibilityPkg/Sample/Tools/Source/UefiStrGather/StringDB.h
1) Sync EdkCompatibilityPkg with EDK 1.04. The changes includes:
[mirror_edk2.git] / EdkCompatibilityPkg / Sample / Tools / Source / UefiStrGather / StringDB.h
CommitLineData
95d675b5 1/*++\r
2\r
3Copyright (c) 2004, Intel Corporation \r
4All rights reserved. This program and the accompanying materials \r
5are licensed and made available under the terms and conditions of the BSD License \r
6which accompanies this distribution. The full text of the license may be found at \r
7http://opensource.org/licenses/bsd-license.php \r
8 \r
9THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, \r
10WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. \r
11\r
12Module Name:\r
13\r
14 StringDB.h\r
15\r
16Abstract:\r
17\r
18 Common defines and prototypes for string database management\r
19 \r
20--*/\r
21\r
22#ifndef _STRING_DB_H_\r
23#define _STRING_DB_H_\r
24\r
25#define LANGUAGE_NAME_STRING_NAME L"$LANGUAGE_NAME"\r
26#define PRINTABLE_LANGUAGE_NAME_STRING_NAME L"$PRINTABLE_LANGUAGE_NAME"\r
27\r
28typedef CHAR16 WCHAR;\r
29\r
30#define NARROW_CHAR 0xFFF0\r
31#define WIDE_CHAR 0xFFF1\r
32#define NON_BREAKING_CHAR 0xFFF2\r
33#define GLYPH_WIDTH 8\r
34#define GLYPH_HEIGHT 19\r
35\r
36#define STRING_DB_KEY (('S' << 24) | ('D' << 16) | ('B' << 8) | 'K')\r
37//\r
38// Version supported by this tool\r
39//\r
40#define STRING_DB_VERSION 0x00010000\r
41\r
42#define STRING_DB_MAJOR_VERSION_MASK 0xFFFF0000\r
43#define STRING_DB_MINOR_VERSION_MASK 0x0000FFFF\r
44\r
45#define DEFINE_STR L"// #define"\r
46\r
47#define EFI_STRING_ID_BEGIN 0x01\r
48\r
49//\r
50// This is the header that gets written to the top of the\r
51// output binary database file.\r
52//\r
53typedef struct {\r
54 UINT32 Key;\r
55 UINT32 HeaderSize;\r
56 UINT32 Version;\r
57 UINT32 NumStringIdenfiers;\r
58 UINT32 StringIdentifiersSize;\r
59 UINT32 NumLanguages;\r
60} STRING_DB_HEADER;\r
61\r
62//\r
63// When we write out data to the database, we have a UINT16 identifier, which\r
64// indicates what follows, followed by the data. Here's the structure.\r
65//\r
66typedef struct {\r
67 UINT16 DataType;\r
68 UINT16 Reserved;\r
69} DB_DATA_ITEM_HEADER;\r
70\r
71#define DB_DATA_TYPE_INVALID 0x0000\r
72#define DB_DATA_TYPE_STRING_IDENTIFIER 0x0001\r
73#define DB_DATA_TYPE_LANGUAGE_DEFINITION 0x0002\r
74#define DB_DATA_TYPE_STRING_DEFINITION 0x0003\r
75#define DB_DATA_TYPE_LAST DB_DATA_TYPE_STRING_DEFINITION\r
76\r
77//\r
78// We have to keep track of a list of languages, each of which has its own\r
79// list of strings. Define a structure to keep track of all languages and\r
80// their list of strings.\r
81//\r
82typedef struct _STRING_LIST {\r
83 struct _STRING_LIST *Next;\r
84 UINT32 Size; // number of bytes in string, including null terminator\r
85 WCHAR *LanguageName;\r
86 WCHAR *StringName; // for example STR_ID_TEXT1\r
87 WCHAR *Scope; //\r
88 WCHAR *Str; // the actual string\r
89 UINT16 Flags; // properties of this string (used, undefined)\r
90} STRING_LIST;\r
91\r
92typedef struct _LANGUAGE_LIST {\r
93 struct _LANGUAGE_LIST *Next;\r
94 WCHAR *LanguageName;\r
95 WCHAR *PrintableLanguageName;\r
96 WCHAR *SecondaryLanguageList;\r
97 STRING_LIST *String;\r
98 STRING_LIST *LastString;\r
99} LANGUAGE_LIST;\r
100\r
101//\r
102// We also keep track of all the string identifier names, which we assign unique\r
103// values to. Create a structure to keep track of them all.\r
104//\r
105typedef struct _STRING_IDENTIFIER {\r
106 struct _STRING_IDENTIFIER *Next;\r
107 UINT32 Index; // only need 16 bits, but makes it easier with UINT32\r
108 WCHAR *StringName;\r
109 UINT16 Flags; // if someone referenced it via STRING_TOKEN()\r
110} STRING_IDENTIFIER;\r
111//\r
112// Keep our globals in this structure to be as modular as possible.\r
113//\r
114typedef struct {\r
115 FILE *StringDBFptr;\r
116 LANGUAGE_LIST *LanguageList;\r
117 LANGUAGE_LIST *LastLanguageList;\r
118 LANGUAGE_LIST *CurrentLanguage; // keep track of the last language they used\r
119 STRING_IDENTIFIER *StringIdentifier;\r
120 STRING_IDENTIFIER *LastStringIdentifier;\r
121 UINT8 *StringDBFileName;\r
122 UINT32 NumStringIdentifiers;\r
123 UINT32 NumStringIdentifiersReferenced;\r
124 STRING_IDENTIFIER *CurrentStringIdentifier; // keep track of the last string identifier they added\r
125 WCHAR *CurrentScope;\r
126} STRING_DB_DATA;\r
127\r
128typedef struct _SPkgBlkBuffer {\r
129 UINT32 mBlkSize;\r
130 VOID *mBlkBuffer;\r
131 struct _SPkgBlkBuffer *mNext;\r
132} SPkgBlkBuffer;\r
133\r
134void\r
135StringDBConstructor (\r
136 void\r
137 )\r
138;\r
139void\r
140StringDBDestructor (\r
141 void\r
142 )\r
143;\r
144\r
145STATUS\r
146StringDBAddString (\r
147 WCHAR *LanguageName,\r
148 WCHAR *StringIdentifier,\r
149 WCHAR *Scope,\r
150 WCHAR *String,\r
151 BOOLEAN Format,\r
152 UINT16 Flags\r
153 )\r
154;\r
155\r
156STATUS\r
157StringDBSetScope (\r
158 WCHAR *Scope\r
159 )\r
160;\r
161\r
162#define STRING_FLAGS_REFERENCED 0x0001 // if referenced somewhere\r
163#define STRING_FLAGS_UNDEFINED 0x0002 // if we added it for padding purposes\r
164#define STRING_FLAGS_INDEX_ASSIGNED 0x0004 // so don't change the index value\r
165#define STRING_ID_INVALID 0xFFFF\r
166#define STRING_ID_LANGUAGE_NAME 0x0000\r
167#define STRING_ID_PRINTABLE_LANGUAGE_NAME 0x0001\r
168\r
169STATUS\r
170StringDBAddStringIdentifier (\r
171 WCHAR *StringIdentifier,\r
172 UINT16 *NewId,\r
173 UINT16 Flags\r
174 )\r
175;\r
176\r
177STATUS\r
178StringDBReadDatabase (\r
179 INT8 *DBFileName,\r
180 BOOLEAN IgnoreIfNotExist,\r
181 BOOLEAN Verbose\r
182 )\r
183;\r
184\r
185STATUS\r
186StringDBWriteDatabase (\r
187 INT8 *DBFileName,\r
188 BOOLEAN Verbose\r
189 )\r
190;\r
191\r
192STATUS\r
193StringDBDumpDatabase (\r
194 INT8 *DBFileName,\r
195 INT8 *OutputFileName,\r
196 BOOLEAN Verbose\r
197 )\r
198;\r
199\r
200STATUS\r
201StringDBAddLanguage (\r
202 WCHAR *LanguageName,\r
203 WCHAR *PrintableLanguageName,\r
204 WCHAR *SecondaryLanguageList\r
205 )\r
206;\r
207\r
208STATUS\r
209StringDBAddSecondaryLanguage (\r
210 WCHAR *LanguageName,\r
211 WCHAR *SecondaryLanguageList\r
212 )\r
213;\r
214\r
215STATUS\r
216StringDBDumpCStrings (\r
217 INT8 *BaseName,\r
218 INT8 *FileName\r
219 )\r
220;\r
221\r
222STATUS\r
223StringDBDumpStringDefines (\r
224 INT8 *FileName,\r
225 INT8 *BaseName\r
226 )\r
227;\r
228\r
229STATUS\r
230StringDBSetCurrentLanguage (\r
231 WCHAR *LanguageName\r
232 )\r
233;\r
234\r
235STATUS\r
236StringDBSetStringReferenced (\r
237 INT8 *StringIdentifierName,\r
238 BOOLEAN IgnoreNotFound\r
239 )\r
240;\r
241\r
242void\r
243StringDBFormatString (\r
244 WCHAR *String\r
245 )\r
246;\r
247\r
248LANGUAGE_LIST *\r
249StringDBFindLanguageList (\r
250 WCHAR *LanguageName\r
251 )\r
252;\r
253\r
254#endif // #ifndef _STRING_DB_H_\r