Henri Verbeet : usp10: Use usp10_array_reserve() in GSUB_initialize_language_cache().

Alexandre Julliard julliard at winehq.org
Mon Mar 19 18:32:51 CDT 2018


Module: wine
Branch: master
Commit: cc131ec07ec0c7746d1d73a07b037169559b5618
URL:    https://source.winehq.org/git/wine.git/?a=commit;h=cc131ec07ec0c7746d1d73a07b037169559b5618

Author: Henri Verbeet <hverbeet at codeweavers.com>
Date:   Mon Mar 19 00:27:11 2018 +0330

usp10: Use usp10_array_reserve() in GSUB_initialize_language_cache().

Signed-off-by: Henri Verbeet <hverbeet at codeweavers.com>
Signed-off-by: Aric Stewart <aric at codeweavers.com>
Signed-off-by: Alexandre Julliard <julliard at winehq.org>

---

 dlls/usp10/opentype.c | 49 +++++++++++++++++++++++++++----------------------
 1 file changed, 27 insertions(+), 22 deletions(-)

diff --git a/dlls/usp10/opentype.c b/dlls/usp10/opentype.c
index 616835e..49a88a6 100644
--- a/dlls/usp10/opentype.c
+++ b/dlls/usp10/opentype.c
@@ -2690,33 +2690,38 @@ static LoadedLanguage *usp10_script_get_language(LoadedScript *script, OPENTYPE_
 
 static void GSUB_initialize_language_cache(LoadedScript *script)
 {
-    int i;
+    const OT_Script *table;
+    DWORD offset;
+    SIZE_T i;
 
-    if (script->table[USP10_SCRIPT_TABLE_GSUB])
+    if (!(table = script->table[USP10_SCRIPT_TABLE_GSUB]))
+        return;
+
+    if ((offset = GET_BE_WORD(table->DefaultLangSys)))
     {
-        DWORD offset;
-        const OT_Script *table = script->table[USP10_SCRIPT_TABLE_GSUB];
-        script->language_count = GET_BE_WORD(table->LangSysCount);
-        offset = GET_BE_WORD(table->DefaultLangSys);
-        if (offset)
-        {
-            script->default_language.tag = MS_MAKE_TAG('d','f','l','t');
-            script->default_language.gsub_table = (const BYTE*)table + offset;
-        }
+        script->default_language.tag = MS_MAKE_TAG('d','f','l','t');
+        script->default_language.gsub_table = (const BYTE *)table + offset;
+    }
 
-        if (script->language_count)
-        {
-            TRACE("Deflang %p, LangCount %li\n",script->default_language.gsub_table, script->language_count);
+    if (!(script->language_count = GET_BE_WORD(table->LangSysCount)))
+        return;
 
-            script->languages = heap_alloc_zero(script->language_count * sizeof(*script->languages));
+    TRACE("Deflang %p, LangCount %lu.\n", script->default_language.gsub_table, script->language_count);
 
-            for (i = 0; i < script->language_count; i++)
-            {
-                int offset = GET_BE_WORD(table->LangSysRecord[i].LangSys);
-                script->languages[i].tag = MS_MAKE_TAG(table->LangSysRecord[i].LangSysTag[0], table->LangSysRecord[i].LangSysTag[1], table->LangSysRecord[i].LangSysTag[2], table->LangSysRecord[i].LangSysTag[3]);
-                script->languages[i].gsub_table = ((const BYTE*)table + offset);
-            }
-        }
+    if (!usp10_array_reserve((void **)&script->languages, &script->languages_size,
+            script->language_count, sizeof(*script->languages)))
+    {
+        ERR("Failed to grow languages array.\n");
+        return;
+    }
+
+    for (i = 0; i < script->language_count; ++i)
+    {
+        script->languages[i].tag = MS_MAKE_TAG(table->LangSysRecord[i].LangSysTag[0],
+                table->LangSysRecord[i].LangSysTag[1],
+                table->LangSysRecord[i].LangSysTag[2],
+                table->LangSysRecord[i].LangSysTag[3]);
+        script->languages[i].gsub_table = (const BYTE *)table + GET_BE_WORD(table->LangSysRecord[i].LangSys);
     }
 }
 




More information about the wine-cvs mailing list