|
|
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);
|