Blame SOURCES/ghostscript-cve-2020-16307.patch

0ab051
diff --git a/devices/vector/gdevtxtw.c b/devices/vector/gdevtxtw.c
0ab051
index b958027..7f02608 100644
0ab051
--- a/devices/vector/gdevtxtw.c
0ab051
+++ b/devices/vector/gdevtxtw.c
0ab051
@@ -1693,97 +1693,100 @@ static int get_unicode(textw_text_enum_t *penum, gs_font *font, gs_glyph glyph,
0ab051
 
0ab051
     length = font->procs.decode_glyph((gs_font *)font, glyph, ch, NULL, 0);
0ab051
     if (length == 0) {
0ab051
-        code = font->procs.glyph_name(font, glyph, &gnstr);
0ab051
-        if (code >= 0 && gnstr.size == 7) {
0ab051
-            if (!memcmp(gnstr.data, "uni", 3)) {
0ab051
-                static const char *hexdigits = "0123456789ABCDEF";
0ab051
-                char *d0 = strchr(hexdigits, gnstr.data[3]);
0ab051
-                char *d1 = strchr(hexdigits, gnstr.data[4]);
0ab051
-                char *d2 = strchr(hexdigits, gnstr.data[5]);
0ab051
-                char *d3 = strchr(hexdigits, gnstr.data[6]);
0ab051
-
0ab051
-                if (d0 != NULL && d1 != NULL && d2 != NULL && d3 != NULL) {
0ab051
-                    *Buffer++ = ((d0 - hexdigits) << 12) + ((d1 - hexdigits) << 8) + ((d2 - hexdigits) << 4) + (d3 - hexdigits);
0ab051
-                    return 1;
0ab051
-                }
0ab051
-            }
0ab051
-        }
0ab051
-        if (length == 0) {
0ab051
-            single_glyph_list_t *sentry = (single_glyph_list_t *)&SingleGlyphList;
0ab051
-            double_glyph_list_t *dentry = (double_glyph_list_t *)&DoubleGlyphList;
0ab051
-            treble_glyph_list_t *tentry = (treble_glyph_list_t *)&TrebleGlyphList;
0ab051
-            quad_glyph_list_t *qentry = (quad_glyph_list_t *)&QuadGlyphList;
0ab051
-
0ab051
-            /* Search glyph to single Unicode value table */
0ab051
-            while (sentry->Glyph != 0) {
0ab051
-                if (sentry->Glyph[0] < gnstr.data[0]) {
0ab051
-                    sentry++;
0ab051
-                    continue;
0ab051
-                }
0ab051
-                if (sentry->Glyph[0] > gnstr.data[0]){
0ab051
-                    break;
0ab051
-                }
0ab051
-                if (strlen(sentry->Glyph) == gnstr.size) {
0ab051
-                    if(memcmp(gnstr.data, sentry->Glyph, gnstr.size) == 0) {
0ab051
-                        *Buffer = sentry->Unicode;
0ab051
+        if (glyph != GS_NO_GLYPH) {
0ab051
+            code = font->procs.glyph_name(font, glyph, &gnstr);
0ab051
+            if (code >= 0 && gnstr.size == 7) {
0ab051
+                if (!memcmp(gnstr.data, "uni", 3)) {
0ab051
+                    static const char *hexdigits = "0123456789ABCDEF";
0ab051
+                    char *d0 = strchr(hexdigits, gnstr.data[3]);
0ab051
+                    char *d1 = strchr(hexdigits, gnstr.data[4]);
0ab051
+                    char *d2 = strchr(hexdigits, gnstr.data[5]);
0ab051
+                    char *d3 = strchr(hexdigits, gnstr.data[6]);
0ab051
+
0ab051
+                    if (d0 != NULL && d1 != NULL && d2 != NULL && d3 != NULL) {
0ab051
+                        *Buffer++ = ((d0 - hexdigits) << 12) + ((d1 - hexdigits) << 8) + ((d2 - hexdigits) << 4) + (d3 - hexdigits);
0ab051
                         return 1;
0ab051
                     }
0ab051
                 }
0ab051
-                sentry++;
0ab051
             }
0ab051
 
0ab051
-            /* Search glyph to double Unicode value table */
0ab051
-            while (dentry->Glyph != 0) {
0ab051
-                if (dentry->Glyph[0] < gnstr.data[0]) {
0ab051
-                    dentry++;
0ab051
-                    continue;
0ab051
-                }
0ab051
-                if (dentry->Glyph[0] > gnstr.data[0]){
0ab051
-                    break;
0ab051
-                }
0ab051
-                if (strlen(dentry->Glyph) == gnstr.size) {
0ab051
-                    if(memcmp(gnstr.data, dentry->Glyph, gnstr.size) == 0) {
0ab051
-                        memcpy(Buffer, dentry->Unicode, 2);
0ab051
-                        return 2;
0ab051
+            if (length == 0) {
0ab051
+                single_glyph_list_t *sentry = (single_glyph_list_t *)&SingleGlyphList;
0ab051
+                double_glyph_list_t *dentry = (double_glyph_list_t *)&DoubleGlyphList;
0ab051
+                treble_glyph_list_t *tentry = (treble_glyph_list_t *)&TrebleGlyphList;
0ab051
+                quad_glyph_list_t *qentry = (quad_glyph_list_t *)&QuadGlyphList;
0ab051
+
0ab051
+                /* Search glyph to single Unicode value table */
0ab051
+                while (sentry->Glyph != 0) {
0ab051
+                    if (sentry->Glyph[0] < gnstr.data[0]) {
0ab051
+                        sentry++;
0ab051
+                        continue;
0ab051
+                    }
0ab051
+                    if (sentry->Glyph[0] > gnstr.data[0]){
0ab051
+                        break;
0ab051
+                    }
0ab051
+                    if (strlen(sentry->Glyph) == gnstr.size) {
0ab051
+                        if(memcmp(gnstr.data, sentry->Glyph, gnstr.size) == 0) {
0ab051
+                            *Buffer = sentry->Unicode;
0ab051
+                            return 1;
0ab051
+                        }
0ab051
                     }
0ab051
+                    sentry++;
0ab051
                 }
0ab051
-                dentry++;
0ab051
-            }
0ab051
 
0ab051
-            /* Search glyph to triple Unicode value table */
0ab051
-            while (tentry->Glyph != 0) {
0ab051
-                if (tentry->Glyph[0] < gnstr.data[0]) {
0ab051
-                    tentry++;
0ab051
-                    continue;
0ab051
-                }
0ab051
-                if (tentry->Glyph[0] > gnstr.data[0]){
0ab051
-                    break;
0ab051
-                }
0ab051
-                if (strlen(tentry->Glyph) == gnstr.size) {
0ab051
-                    if(memcmp(gnstr.data, tentry->Glyph, gnstr.size) == 0) {
0ab051
-                        memcpy(Buffer, tentry->Unicode, 3);
0ab051
-                        return 3;
0ab051
+                /* Search glyph to double Unicode value table */
0ab051
+                while (dentry->Glyph != 0) {
0ab051
+                    if (dentry->Glyph[0] < gnstr.data[0]) {
0ab051
+                        dentry++;
0ab051
+                        continue;
0ab051
                     }
0ab051
+                    if (dentry->Glyph[0] > gnstr.data[0]){
0ab051
+                        break;
0ab051
+                    }
0ab051
+                    if (strlen(dentry->Glyph) == gnstr.size) {
0ab051
+                        if(memcmp(gnstr.data, dentry->Glyph, gnstr.size) == 0) {
0ab051
+                            memcpy(Buffer, dentry->Unicode, 2);
0ab051
+                            return 2;
0ab051
+                        }
0ab051
+                    }
0ab051
+                    dentry++;
0ab051
                 }
0ab051
-                tentry++;
0ab051
-            }
0ab051
 
0ab051
-            /* Search glyph to quadruple Unicode value table */
0ab051
-            while (qentry->Glyph != 0) {
0ab051
-                if (qentry->Glyph[0] < gnstr.data[0]) {
0ab051
-                    qentry++;
0ab051
-                    continue;
0ab051
-                }
0ab051
-                if (qentry->Glyph[0] > gnstr.data[0]){
0ab051
-                    break;
0ab051
+                /* Search glyph to triple Unicode value table */
0ab051
+                while (tentry->Glyph != 0) {
0ab051
+                    if (tentry->Glyph[0] < gnstr.data[0]) {
0ab051
+                        tentry++;
0ab051
+                        continue;
0ab051
+                    }
0ab051
+                    if (tentry->Glyph[0] > gnstr.data[0]){
0ab051
+                        break;
0ab051
+                    }
0ab051
+                    if (strlen(tentry->Glyph) == gnstr.size) {
0ab051
+                        if(memcmp(gnstr.data, tentry->Glyph, gnstr.size) == 0) {
0ab051
+                            memcpy(Buffer, tentry->Unicode, 3);
0ab051
+                            return 3;
0ab051
+                        }
0ab051
+                    }
0ab051
+                    tentry++;
0ab051
                 }
0ab051
-                if (strlen(qentry->Glyph) == gnstr.size) {
0ab051
-                    if(memcmp(gnstr.data, qentry->Glyph, gnstr.size) == 0) {
0ab051
-                        memcpy(Buffer, qentry->Unicode, 4);
0ab051
-                        return 4;
0ab051
+
0ab051
+                /* Search glyph to quadruple Unicode value table */
0ab051
+                while (qentry->Glyph != 0) {
0ab051
+                    if (qentry->Glyph[0] < gnstr.data[0]) {
0ab051
+                        qentry++;
0ab051
+                        continue;
0ab051
+                    }
0ab051
+                    if (qentry->Glyph[0] > gnstr.data[0]){
0ab051
+                        break;
0ab051
                     }
0ab051
+                    if (strlen(qentry->Glyph) == gnstr.size) {
0ab051
+                        if(memcmp(gnstr.data, qentry->Glyph, gnstr.size) == 0) {
0ab051
+                            memcpy(Buffer, qentry->Unicode, 4);
0ab051
+                            return 4;
0ab051
+                        }
0ab051
+                    }
0ab051
+                    qentry++;
0ab051
                 }
0ab051
-                qentry++;
0ab051
             }
0ab051
         }
0ab051
         *Buffer = fallback;
0ab051
@@ -1890,8 +1893,8 @@ txtwrite_process_cmap_text(gs_text_enum_t *pte)
0ab051
                 pte->returned.total_width.x += dpt.x;
0ab051
                 pte->returned.total_width.y += dpt.y;
0ab051
 
0ab051
-                penum->TextBufferIndex += get_unicode(penum, (gs_font *)pte->orig_font, glyph, chr, &penum->TextBuffer[penum->TextBufferIndex]);
0ab051
                 penum->Widths[penum->TextBufferIndex] += dpt.x;
0ab051
+                penum->TextBufferIndex += get_unicode(penum, (gs_font *)pte->orig_font, glyph, chr, &penum->TextBuffer[penum->TextBufferIndex]);
0ab051
                 break;
0ab051
             case 2:		/* end of string */
0ab051
                 return 0;
0ab051
diff --git a/psi/zbfont.c b/psi/zbfont.c
0ab051
index 262fea9..abc03aa 100644
0ab051
--- a/psi/zbfont.c
0ab051
+++ b/psi/zbfont.c
0ab051
@@ -272,7 +272,7 @@ gs_font_map_glyph_to_unicode(gs_font *font, gs_glyph glyph, int ch, ushort *u, u
0ab051
          * can't be a default value for FontInfo.GlyphNames2Unicode .
0ab051
          */
0ab051
     }
0ab051
-    if (glyph <= GS_MIN_CID_GLYPH) {
0ab051
+    if (glyph <= GS_MIN_CID_GLYPH && glyph != GS_NO_GLYPH) {
0ab051
         UnicodeDecoding = zfont_get_to_unicode_map(font->dir);
0ab051
         if (UnicodeDecoding != NULL && r_type(UnicodeDecoding) == t_dictionary)
0ab051
             return gs_font_map_glyph_by_dict(font->memory, UnicodeDecoding, glyph, u, length);