gdi32: Directly use ntdll in load_system_links.

Signed-off-by: Jacek Caban <jacek@codeweavers.com>
Signed-off-by: Huw Davies <huw@codeweavers.com>
Signed-off-by: Alexandre Julliard <julliard@winehq.org>
This commit is contained in:
Jacek Caban 2021-09-23 13:44:09 +01:00 committed by Alexandre Julliard
parent 4ad71bb1b9
commit dbb0f28489
1 changed files with 22 additions and 14 deletions

View File

@ -91,6 +91,18 @@ static const MAT2 identity = { {0,1}, {0,0}, {0,0}, {0,1} };
static const WCHAR nt_prefixW[] = {'\\','?','?','\\'}; static const WCHAR nt_prefixW[] = {'\\','?','?','\\'};
static const WCHAR system_link_keyW[] =
{
'\\','R','e','g','i','s','t','r','y',
'\\','M','a','c','h','i','n','e',
'\\','S','o','f','t','w','a','r','e',
'\\','M','i','c','r','o','s','o','f','t',
'\\','W','i','n','d','o','w','s',' ','N','T',
'\\','C','u','r','r','e','n','t','V','e','r','s','i','o','n',
'\\','F','o','n','t','L','i','n','k',
'\\','S','y','s','t','e','m','L','i','n','k'
};
static const WCHAR font_substitutes_keyW[] = static const WCHAR font_substitutes_keyW[] =
{ {
'\\','R','e','g','i','s','t','r','y', '\\','R','e','g','i','s','t','r','y',
@ -1470,34 +1482,33 @@ static void load_system_links(void)
struct gdi_font_link *font_link, *system_font_link; struct gdi_font_link *font_link, *system_font_link;
struct gdi_font_face *face; struct gdi_font_face *face;
if (!RegOpenKeyW( HKEY_LOCAL_MACHINE, if ((hkey = reg_open_key( NULL, system_link_keyW, sizeof(system_link_keyW) )))
L"Software\\Microsoft\\Windows NT\\CurrentVersion\\FontLink\\SystemLink", &hkey ))
{ {
WCHAR value[MAX_PATH], data[1024]; char buffer[4096];
DWORD type, val_len, data_len; KEY_VALUE_FULL_INFORMATION *info = (KEY_VALUE_FULL_INFORMATION *)buffer;
WCHAR value[MAX_PATH];
WCHAR *entry, *next; WCHAR *entry, *next;
val_len = ARRAY_SIZE(value);
data_len = sizeof(data);
i = 0; i = 0;
while (!RegEnumValueW( hkey, i++, value, &val_len, NULL, &type, (LPBYTE)data, &data_len)) while (reg_enum_value( hkey, i++, info, sizeof(buffer), value, sizeof(value) ))
{ {
/* Don't store fonts that are only substitutes for other fonts */ /* Don't store fonts that are only substitutes for other fonts */
if (!get_gdi_font_subst( value, -1, NULL )) if (!get_gdi_font_subst( value, -1, NULL ))
{ {
char *data = (char *)info + info->DataOffset;
font_link = add_gdi_font_link( value ); font_link = add_gdi_font_link( value );
for (entry = data; (char *)entry < (char *)data + data_len && *entry; entry = next) for (entry = (WCHAR *)data; (char *)entry < data + info->DataLength && *entry; entry = next)
{ {
const WCHAR *family_name = NULL; const WCHAR *family_name = NULL;
WCHAR *p; WCHAR *p;
TRACE("%s: %s\n", debugstr_w(value), debugstr_w(entry)); TRACE( "%s: %s\n", debugstr_w(value), debugstr_w(entry) );
next = entry + lstrlenW(entry) + 1; next = entry + lstrlenW(entry) + 1;
if ((p = wcschr( entry, ',' ))) if ((p = wcschr( entry, ',' )))
{ {
*p++ = 0; *p++ = 0;
while (iswspace(*p)) p++; while (*p == ' ' || *p == '\t') p++;
if (!(family_name = get_gdi_font_subst( p, -1, NULL ))) family_name = p; if (!(family_name = get_gdi_font_subst( p, -1, NULL ))) family_name = p;
} }
if ((face = find_face_from_filename( entry, family_name ))) if ((face = find_face_from_filename( entry, family_name )))
@ -1510,11 +1521,8 @@ static void load_system_links(void)
} }
} }
else TRACE("%s: SystemLink entry for substituted font, ignoring\n", debugstr_w(value)); else TRACE("%s: SystemLink entry for substituted font, ignoring\n", debugstr_w(value));
val_len = ARRAY_SIZE(value);
data_len = sizeof(data);
} }
RegCloseKey( hkey ); NtClose( hkey );
} }
if ((shelldlg_name = get_gdi_font_subst( L"MS Shell Dlg", -1, NULL ))) if ((shelldlg_name = get_gdi_font_subst( L"MS Shell Dlg", -1, NULL )))