diff options
author | Jason Rumney <jasonr@gnu.org> | 2008-04-04 11:59:09 +0000 |
---|---|---|
committer | Jason Rumney <jasonr@gnu.org> | 2008-04-04 11:59:09 +0000 |
commit | e38ac6e20364469afe2700548120924ad5807e56 (patch) | |
tree | 25e66ab9c26aff3c925dcaa2fc167da6cd0e5160 /src/w32uniscribe.c | |
parent | e6fa807c5ae9f8c5aecc7b99b03fbe54c4085dd5 (diff) | |
download | emacs-e38ac6e20364469afe2700548120924ad5807e56.tar.gz |
(uniscribe_check_otf): Add GC protection before consing.
Use CAR_SAFE to increment loop.
Diffstat (limited to 'src/w32uniscribe.c')
-rw-r--r-- | src/w32uniscribe.c | 7 |
1 files changed, 6 insertions, 1 deletions
diff --git a/src/w32uniscribe.c b/src/w32uniscribe.c index 2641aead054..62734d05cde 100644 --- a/src/w32uniscribe.c +++ b/src/w32uniscribe.c @@ -563,6 +563,7 @@ int uniscribe_check_otf (font, otf_spec) HFONT check_font, old_font; DWORD table; int i, retval = 0; + struct gcpro gcpro1; /* Check the spec is in the right format. */ if (!CONSP (otf_spec) || Flength (otf_spec) < 3) @@ -599,6 +600,10 @@ int uniscribe_check_otf (font, otf_spec) check_font = CreateFontIndirect (font); old_font = SelectObject (context, check_font); + /* Everything else is contained within otf_spec so should get + marked along with it. */ + GCPRO1 (otf_spec); + /* Scan GSUB and GPOS tables. */ for (i = 0; i < 2; i++) { @@ -676,7 +681,7 @@ int uniscribe_check_otf (font, otf_spec) documentation in font_prop_validate_otf, so count them. */ n_match_features = 0; rest = features[i]; - for (feature = XCAR (rest); CONSP (rest); feature = XCAR (rest)) + for (feature = XCAR (rest); CONSP (rest); feature = CAR_SAFE (rest)) { rest = XCDR (rest); if (!NILP (feature)) |