usp10: Cache the script with the feature so that in caches with multiple scripts we do not fetch the wrong feature from the cache.
diff --git a/dlls/usp10/shape.c b/dlls/usp10/shape.c
index c463681..66d65c2 100644
--- a/dlls/usp10/shape.c
+++ b/dlls/usp10/shape.c
@@ -1094,11 +1094,16 @@
static LPCVOID load_GSUB_feature(HDC hdc, SCRIPT_ANALYSIS *psa, ScriptCache *psc, const char* feat)
{
const GSUB_Feature *feature;
+ const char* script;
int i;
+ script = get_opentype_script(hdc,psa,psc,FALSE);
+
for (i = 0; i < psc->feature_count; i++)
- if (strncmp(psc->features[i].tag,feat,4)==0)
+ {
+ if (strncmp(psc->features[i].tag,feat,4)==0 && strncmp(psc->features[i].script,script,4)==0)
return psc->features[i].feature;
+ }
feature = NULL;
@@ -1146,6 +1151,7 @@
psc->features = HeapAlloc(GetProcessHeap(), 0, psc->feature_count * sizeof(LoadedFeature));
lstrcpynA(psc->features[psc->feature_count - 1].tag, feat, 5);
+ lstrcpynA(psc->features[psc->feature_count - 1].script, script, 5);
psc->features[psc->feature_count - 1].feature = feature;
return feature;
}
diff --git a/dlls/usp10/usp10_internal.h b/dlls/usp10/usp10_internal.h
index ebf9667..6f5d3d1 100644
--- a/dlls/usp10/usp10_internal.h
+++ b/dlls/usp10/usp10_internal.h
@@ -82,7 +82,8 @@
#define GLYPH_MAX 65536
typedef struct {
- char tag[4];
+ char tag[5];
+ char script[5];
LPCVOID feature;
} LoadedFeature;