From 12c140ec5416d5d55fad85d28b1330da12203fb2e848da677571361376bfd4c8 Mon Sep 17 00:00:00 2001 From: OBS User unknown Date: Thu, 3 Apr 2008 23:29:31 +0000 Subject: [PATCH] OBS-URL: https://build.opensuse.org/package/show/openSUSE:Factory/gnuplot?expand=0&rev=11 --- gnuplot-4.2.3-utf8.dif | 4260 ++++++++++++++++++++++++++++++++++++++++ gnuplot.changes | 5 + gnuplot.spec | 8 +- 3 files changed, 4271 insertions(+), 2 deletions(-) create mode 100644 gnuplot-4.2.3-utf8.dif diff --git a/gnuplot-4.2.3-utf8.dif b/gnuplot-4.2.3-utf8.dif new file mode 100644 index 0000000..0861927 --- /dev/null +++ b/gnuplot-4.2.3-utf8.dif @@ -0,0 +1,4260 @@ +--- term/Makefile.am.in ++++ term/Makefile.am.in 2007-11-29 15:29:04.000000000 +0100 +@@ -13,7 +13,7 @@ + postscript_DATA = PostScript/8859-15.ps PostScript/8859-1.ps\ + PostScript/8859-2.ps PostScript/cp1250.ps PostScript/cp437.ps\ + PostScript/cp850.ps PostScript/cp852.ps PostScript/koi8r.ps PostScript/koi8u.ps\ +- PostScript/prologue.ps ++ PostScript/prologue.ps PostScript/utf-8.ps PostScript/aglfn.txt PostScript/NOTE.aglfn + + Makefile.am: Makefile.am.in + rm -f $@ $@t +--- term/gd.trm ++++ term/gd.trm 2008-03-30 01:32:40.000000000 +0100 +@@ -1839,7 +1839,7 @@ + #ifdef gdFTEX_Adobe_Custom + /* libgd defaults to UTF-8 encodings. We have limited options for */ + /* over-riding this, but we can try */ +- if (ENHgd_font && !strcmp(ENHgd_font,"Symbol")) { ++ if (encoding != S_ENC_UTF8 && ENHgd_font && !strcmp(ENHgd_font,"Symbol")) { + PNG_FONT_INFO.flags |= gdFTEX_CHARMAP; + PNG_FONT_INFO.charmap = gdFTEX_Adobe_Custom; + } else { +--- term/pslatex.trm ++++ term/pslatex.trm 2008-02-22 21:02:26.000000000 +0100 +@@ -1,5 +1,5 @@ + /* Hello, Emacs, this is -*-C-*- +- * $Id: pslatex.trm,v 1.69.2.1 2008/02/22 20:34:41 sfeam Exp $ ++ * $Id: pslatex.trm,v 1.72 2008/02/22 20:02:26 sfeam Exp $ + */ + + /* GNUPLOT - pslatex.trm */ +@@ -441,7 +441,10 @@ + case S_ENC_ISO8859_2: + inputenc = "latin2"; + break; +- case S_ENC_ISO8859_15: ++ case S_ENC_ISO8859_9: /* ISO8859-9 is Latin5 */ ++ inputenc = "latin5"; ++ break; ++ case S_ENC_ISO8859_15: /* ISO8859-15 is Latin9 */ + inputenc = "latin9"; + break; + case S_ENC_CP437: +--- term/post.trm ++++ term/post.trm 2008-03-13 19:01:27.000000000 +0100 +@@ -1,5 +1,5 @@ + /* Hello, Emacs: this is -*-C-*- ! +- * $Id: post.trm,v 1.203.2.10 2008/01/10 07:31:25 mikulik Exp $ ++ * $Id: post.trm,v 1.230 2008/03/13 18:01:27 sfeam Exp $ + */ + + /* GNUPLOT - post.trm */ +@@ -61,14 +61,18 @@ + * + * Dan Sebald, 7 March 2003: terminal entry for image functionality + * +- * Harald Harders (h.harders@tu-bs.de), 2004-12-02: +- * Moved all terminal settings into a single structure. ++ * Harald Harders (h.harders@tu-bs.de), 2004-12-02: ++ * Moved all terminal settings into a single structure. + * +- * Harald Harders (h.harders@tu-bs.de), 2005-02-08: +- * Merged functionality of postscript, pslatex, pstex, and epslatex terminals. ++ * Harald Harders (h.harders@tu-bs.de), 2005-02-08: ++ * Merged functionality of postscript, pslatex, pstex, and epslatex terminals. + * +- * Ethan Merritt Mar 2006: Break out prolog and character encodings into +- * separate files loaded at runtime ++ * Ethan Merritt Mar 2006: Break out prolog and character encodings into ++ * separate files loaded at runtime ++ * ++ * Thomas Henlich Sep 2007: Add support for UTF-8 encoding via the glyphshow ++ * operator. It supports PostScript Type1 fonts that use glyph names according ++ * to the Adobe Glyph List For New Fonts. + */ + + #include "driver.h" +@@ -106,7 +110,7 @@ + TERM_PUBLIC void PS_set_color (t_colorspec *); + TERM_PUBLIC void PS_filled_polygon (int, gpiPoint *); + #ifdef WITH_IMAGE +-TERM_PUBLIC void PS_image __PROTO((unsigned, unsigned, coordval *, gpiPoint *, t_imagecolor)); ++TERM_PUBLIC void PS_image __PROTO((unsigned int, unsigned int, coordval *, gpiPoint *, t_imagecolor)); + #endif + + /* To support "set term post enhanced" */ +@@ -123,6 +127,9 @@ + + TERM_PUBLIC void PS_path __PROTO((int p)); + static TBOOLEAN PS_newpath = FALSE; ++static TBOOLEAN ENHps_opened_string = FALSE; /* try to cut out empty ()'s */ ++ ++TERM_PUBLIC void PS_layer __PROTO((t_termlayer syncpoint)); + + #endif /* TERM_PROTO */ + +@@ -140,11 +147,12 @@ + } \ + } while (0) + +-/* Datastructure implementing inclusion of font files */ ++/* Data structure implementing inclusion of font files */ + struct ps_fontfile_def { + struct ps_fontfile_def *next;/* pointer to next fontfile in linked list */ + char *fontfile_name; + char *fontfile_fullname; ++ char *fontname; + }; + + /* Terminal type of postscript dialect */ +@@ -181,13 +189,14 @@ + double palfunc_deviation; /* terminal option */ + TBOOLEAN oldstyle; + TBOOLEAN epslatex_standalone; ++ TBOOLEAN adobeglyphnames; /* Choice of output names for UTF8 */ + } ps_params_t; + + #define POST_PARAMS_DEFAULT { \ + PSTERM_POSTSCRIPT, 50, 50, \ + PSTERM_LANDSCAPE, FALSE, FALSE, FALSE, FALSE, 1.0, 1.0, FALSE, \ + FALSE, FALSE, NULL, "Helvetica", 14, FALSE, FALSE, 2000, 0.003, \ +- FALSE, FALSE \ ++ FALSE, TRUE \ + } + + static ps_params_t post_params = POST_PARAMS_DEFAULT; +@@ -261,7 +270,9 @@ + static char *pslatex_auxname = NULL; + + /* Routine to copy pre-existing prolog files into output stream */ ++static FILE *PS_open_prologue_file __PROTO((char *)); + static void PS_dump_prologue_file __PROTO((char *)); ++static void PS_load_glyphlist __PROTO((void)); + + static const char GPFAR * GPFAR OldEPSL_linetypes[] = { + /* Line Types */ +@@ -280,20 +291,21 @@ + /* For MFshow and MFwidth the tos is an array with the string and font info: */ + /* [ ] */ + /* EAM Mar 2004 - Add in a special case overprint 3 = save, overprint 4 = restore */ ++/* EAM Nov 2007 - Accommodate UTF-8 support (Gshow) */ + + "/MFshow {\n", + " { dup 5 get 3 ge\n", /* EAM test for overprint 3 or 4 */ + " { 5 get 3 eq {gsave} {grestore} ifelse }\n", /* EAM */ + " {dup dup 0 get findfont exch 1 get scalefont setfont\n", + " [ currentpoint ] exch dup 2 get 0 exch R dup 5 get 2 ne {dup dup 6\n", +-" get exch 4 get {show} {stringwidth pop 0 R} ifelse }if dup 5 get 0 eq\n", ++" get exch 4 get {Gshow} {stringwidth pop 0 R} ifelse }if dup 5 get 0 eq\n", + " {dup 3 get {2 get neg 0 exch R pop} {pop aload pop M} ifelse} {dup 5\n", + " get 1 eq {dup 2 get exch dup 3 get exch 6 get stringwidth pop -2 div\n", + " dup 0 R} {dup 6 get stringwidth pop -2 div 0 R 6 get\n", + " show 2 index {aload pop M neg 3 -1 roll neg R pop pop} {pop pop pop\n", + " pop aload pop M} ifelse }ifelse }ifelse }\n", + " ifelse }\n", /* EAM */ +-" forall} bind def\n", ++" forall} def\n", + + /* get the width of the text */ + /* HH 2005-07-24 - Add in a special case overprint 3 = save, 4 = restore +@@ -301,9 +313,12 @@ + * additional value on the stack. between XYsave and XYrestore, + * this number is increased by the strings. By pop'ing this number, all + * strings between XYsave and XYrestore are ignored. */ ++/* EAM Nov 2007 - GSwidth is to allow the operator to work either with a string ++ * or with a glyph. Needed for UTF-8 support. Gwidth may do it better. */ ++"/Gswidth {dup type /stringtype eq {stringwidth} {pop (n) stringwidth} ifelse} def\n", + "/MFwidth {0 exch { dup 5 get 3 ge { 5 get 3 eq { 0 } { pop } ifelse }\n", + " {dup 3 get{dup dup 0 get findfont exch 1 get scalefont setfont\n", +-" 6 get stringwidth pop add} {pop} ifelse} ifelse} forall} bind def\n", ++" 6 get Gswidth pop add} {pop} ifelse} ifelse} forall} def\n", + + /* flush left show */ + "/MLshow { currentpoint stroke M\n", +@@ -366,8 +381,11 @@ + if (strcmp(fnp->name, myfname) == 0) + return NULL; + +- /* we did not find the name */ ++ /* Ignore it if illegal characters will corrupt the PostScript syntax */ ++ if (strpbrk(myfname, "{}[]() ")) ++ return NULL; + ++ /* we have not seen this font before; store name and apply encoding */ + fnp = (struct PS_FontName *)gp_alloc(sizeof(struct PS_FontName), + "PostScript Font record"); + fnp->name = gp_strdup(myfname); +@@ -376,12 +394,17 @@ + + switch(encoding) { + case S_ENC_ISO8859_1: ++ case S_ENC_UTF8: + recode = "reencodeISO def\n"; + break; + case S_ENC_ISO8859_2: + recode = "reencodeISO2 def\n"; + break; +- case S_ENC_ISO8859_15: ++ case S_ENC_ISO8859_9: /* ISO8859-9 is Latin5 */ ++ case S_ENC_CP1254: ++ recode = "reencodeISO9 def\n"; ++ break; ++ case S_ENC_ISO8859_15: /* ISO8859-15 is Latin9 */ + recode = "reencodeISO15 def\n"; + break; + case S_ENC_CP437: +@@ -407,11 +430,13 @@ + break; + } + +- if (can_reencode && recode) { +- fprintf(gppsfile,"/%s %s", myfname, recode); +- return NULL; +- } else +- return recode; ++ if (recode) { ++ if (ENHps_opened_string) ++ ENHPS_FLUSH(); ++ fprintf(gppsfile,"/%s %s", fnp->name, recode); ++ } ++ ++ return NULL; + } + + char * +@@ -454,6 +479,7 @@ + PSLATEX_ROTATE, PSLATEX_NOROTATE, PSLATEX_AUXFILE, PSLATEX_NOAUXFILE, + PSLATEX_OLDSTYLE, PSLATEX_NEWSTYLE, EPSLATEX_HEADER, EPSLATEX_NOHEADER, + PS_SIZE, ++ PS_ADOBEGLYPHNAMES, PS_NOADOBEGLYPHNAMES, + PS_OTHER + }; + +@@ -499,6 +525,8 @@ + { "noa$uxfile", PSLATEX_NOAUXFILE }, + { "old$style", PSLATEX_OLDSTYLE }, + { "new$style", PSLATEX_NEWSTYLE }, ++ { "adobe$glyphnames", PS_ADOBEGLYPHNAMES }, ++ { "noadobe$glyphnames", PS_NOADOBEGLYPHNAMES }, + { NULL, PS_OTHER } + }; + +@@ -848,35 +876,36 @@ + break; + case PS_FONTFILE: { + TBOOLEAN deleteentry = FALSE; ++ char *fontfilename = NULL; + c_token++; + if (ps_params->terminal != PSTERM_POSTSCRIPT) + int_error(c_token, + "extraneous argument in set terminal %s",term->name); + +- if (!isstring(c_token)) { +- if (equals(c_token, "add")) +- c_token++; +- else if (almost_equals(c_token, "del$ete")) { +- deleteentry = TRUE; +- c_token++; +- } else +- int_error(c_token, "Font filename expected"); +- } +- if (isstring(c_token)) { +- TBOOLEAN filename_doubled = FALSE; +- struct ps_fontfile_def *curr_ps_fontfile = ++ if (equals(c_token, "add")) ++ c_token++; ++ else if (almost_equals(c_token, "del$ete")) { ++ deleteentry = TRUE; ++ c_token++; ++ } ++ ++ if (!(fontfilename = try_to_get_string())) { ++ int_error(c_token, "Font filename expected"); ++ } else { ++ TBOOLEAN filename_doubled = FALSE; ++ struct ps_fontfile_def *curr_ps_fontfile = + ps_params->first_fontfile; +- struct ps_fontfile_def *prev_ps_fontfile = NULL; +- struct ps_fontfile_def *new_ps_fontfile = +- gp_alloc(sizeof(struct ps_fontfile_def), +- "new_ps_fontfile"); +- +- new_ps_fontfile->fontfile_name = +- gp_alloc (token_len(c_token), +- "new_ps_fontfile->fontfile_name"); +- quote_str(new_ps_fontfile->fontfile_name, +- c_token, token_len(c_token)); +- gp_expand_tilde(&(new_ps_fontfile->fontfile_name)); ++ struct ps_fontfile_def *prev_ps_fontfile = NULL; ++ struct ps_fontfile_def *new_ps_fontfile = ++ gp_alloc(sizeof(struct ps_fontfile_def), ++ "new_ps_fontfile"); ++ ++ new_ps_fontfile->fontfile_name = ++ gp_alloc (token_len(c_token), ++ "new_ps_fontfile->fontfile_name"); ++ gp_expand_tilde(&fontfilename); ++ new_ps_fontfile->fontfile_name = fontfilename; ++ new_ps_fontfile->fontname = NULL; + if (!deleteentry) { + #if defined(PIPES) + if (*(new_ps_fontfile->fontfile_name) != '<') { +@@ -884,7 +913,7 @@ + new_ps_fontfile->fontfile_fullname = + fontpath_fullname(new_ps_fontfile->fontfile_name); + if (!new_ps_fontfile->fontfile_fullname) +- int_error(c_token, "Font file '%s' not found", ++ int_error(c_token-1, "Font file '%s' not found", + new_ps_fontfile->fontfile_name); + #if defined(PIPES) + } else +@@ -901,45 +930,43 @@ + lf=lf->prev; + } + if ((lf && lf->interactive) || interactive) +- /* if (interactive) { */ + PS_load_fontfile(new_ps_fontfile,FALSE); + } + +- if (ps_params->first_fontfile) { +- while (curr_ps_fontfile) { +- if (strcmp(curr_ps_fontfile->fontfile_name, +- new_ps_fontfile->fontfile_name) == 0) { +- filename_doubled = TRUE; +- if (deleteentry) { ++ if (ps_params->first_fontfile) { ++ while (curr_ps_fontfile) { ++ if (strcmp(curr_ps_fontfile->fontfile_name, ++ new_ps_fontfile->fontfile_name) == 0) { ++ filename_doubled = TRUE; ++ if (deleteentry) { + delete_ps_fontfile(prev_ps_fontfile, + curr_ps_fontfile); +- curr_ps_fontfile = NULL; +- break; +- } +- } +- prev_ps_fontfile = curr_ps_fontfile; +- curr_ps_fontfile = curr_ps_fontfile->next; +- } +- if (!filename_doubled) { +- if (!deleteentry) +- prev_ps_fontfile->next = new_ps_fontfile; +- else +- int_warn(c_token,"Can't delete Font filename '%s'", +- new_ps_fontfile->fontfile_name); +- } +- } else { +- if (!deleteentry) +- ps_params->first_fontfile = new_ps_fontfile; +- else +- int_warn(c_token, "Can't delete Font filename '%s'", +- new_ps_fontfile->fontfile_name); +- } +- c_token++; +- } else +- int_error(c_token, "Font filename expected"); +- break; +- } +- case PS_NOFONTFILES: ++ curr_ps_fontfile = NULL; ++ break; ++ } ++ } ++ prev_ps_fontfile = curr_ps_fontfile; ++ curr_ps_fontfile = curr_ps_fontfile->next; ++ } ++ if (!filename_doubled) { ++ if (!deleteentry) ++ prev_ps_fontfile->next = new_ps_fontfile; ++ else ++ int_warn(c_token,"Can't delete Font filename '%s'", ++ new_ps_fontfile->fontfile_name); ++ } ++ } else { ++ if (!deleteentry) ++ ps_params->first_fontfile = new_ps_fontfile; ++ else ++ int_warn(c_token, "Can't delete Font filename '%s'", ++ new_ps_fontfile->fontfile_name); ++ } ++ c_token++; ++ } ++ break; ++ } ++ case PS_NOFONTFILES: + if (ps_params->terminal != PSTERM_POSTSCRIPT) + int_error(c_token, + "extraneous argument in set terminal %s",term->name); +@@ -948,6 +975,14 @@ + ps_params->first_fontfile); + ++c_token; + break; ++ case PS_ADOBEGLYPHNAMES: ++ ps_params->adobeglyphnames = TRUE; ++ ++c_token; ++ break; ++ case PS_NOADOBEGLYPHNAMES: ++ ps_params->adobeglyphnames = FALSE; ++ ++c_token; ++ break; + case PS_PALFUNCPARAM: + if (set_palfunc) + int_error(c_token, +@@ -1000,8 +1035,16 @@ + set_fontsize = TRUE; + *comma = '\0'; + } +- if (*s) ++ if (*s) { ++ /* Filter out characters that would confuse PostScript */ ++ if (strpbrk(s, "()[]{}| ")) { ++ int_warn(c_token-1,"Illegal characters in PostScript font name."); ++ int_warn(NO_CARET,"I will try to fix it but this may not work."); ++ while (strpbrk(s, "()[]{}| ")) ++ *(strpbrk(s, "()[]{}| ")) = '-'; ++ } + strncpy(ps_params->font, s, sizeof(ps_params->font)); ++ } + free(s); + } else + int_error(c_token-1, +@@ -1119,6 +1162,12 @@ + } + #endif + ++ if ((encoding == S_ENC_UTF8) && (ps_params->terminal == PSTERM_POSTSCRIPT)) { ++ sprintf(tmp_term_options," %sadobeglyphnames \\\n ", ++ ps_params->adobeglyphnames ? "" : "no"); ++ strcat(term_options,tmp_term_options); ++ } ++ + if (ps_explicit_size) { + if (ps_explicit_units == CM) + sprintf(tmp_term_options,"size %.2fcm, %.2fcm ", +@@ -1153,6 +1202,29 @@ + static TBOOLEAN ps_common_uses_fonts; + static unsigned int ps_common_xoff, ps_common_yoff; + ++/* The default UTF8 code will use glyph identifiers uniXXXX for all glyphs above 0x0100. ++ * If you define ADOBE_ENCODING_NAMES, then it will instead use the glyph names from the ++ * file aglfn.txt. Names in the range 0x0100 - 0x01FF correspond to those used by the ++ * Latin1 encoding scheme. This unicode code page deliberately uses the same character ++ * mapping as Latin1. Adobe also recommends names for many characters outside this ++ * range, but not all fonts adhere to this. You can substitute a different aglfn.txt ++ * file at run time if you want to use a different scheme. ++ */ ++#define ADOBE_ENCODING_NAMES 1 ++ ++#if (ADOBE_ENCODING_NAMES) ++ ++typedef struct ps_glyph { ++ unsigned long unicode; ++ char * glyphname; ++} ps_glyph; ++ ++static ps_glyph *aglist = NULL; ++static int aglist_alloc = 0; ++static int aglist_size = 0; ++static int psglyphs = 0; ++ ++#endif + + TERM_PUBLIC void + PS_load_fontfile(struct ps_fontfile_def *current_ps_fontfile, TBOOLEAN doload) +@@ -1207,7 +1279,7 @@ + current_ps_fontfile->fontfile_name + 1); + #endif + } +- else if (strcmp(ext,"ttf") == 0) { ++ else if (!strcmp(ext,"ttf") || !strcmp(ext,"otf")) { + /* TrueType */ + #if defined(PIPES) + ispipe = TRUE; +@@ -1286,6 +1358,7 @@ + strcpy(fontname,strstr(line+1,"/")+1); + fnende = strstr(fontname," "); + *fnende = '\0'; ++ current_ps_fontfile->fontname = gp_strdup(fontname); + /* Print font name */ + if (!doload) { + if (current_ps_fontfile->fontfile_fullname) +@@ -1366,6 +1439,8 @@ + + while (current_ps_fontfile) { + PS_load_fontfile(current_ps_fontfile,doload); ++ if (current_ps_fontfile->fontname) ++ PS_RememberFont(current_ps_fontfile->fontname, 1); + current_ps_fontfile = current_ps_fontfile->next; + } + } +@@ -1519,11 +1594,16 @@ + free(outstr2); + } + ++ /* Dump the body of the prologue */ ++ PS_dump_prologue_file("prologue.ps"); ++ + /* insert font encoding vector */ + if (uses_fonts) { + switch (encoding) { + case S_ENC_ISO8859_1: PS_dump_prologue_file("8859-1.ps"); break; + case S_ENC_ISO8859_2: PS_dump_prologue_file("8859-2.ps"); break; ++ case S_ENC_CP1254: ++ case S_ENC_ISO8859_9: PS_dump_prologue_file("8859-9.ps"); break; + case S_ENC_ISO8859_15: PS_dump_prologue_file("8859-15.ps"); break; + case S_ENC_CP437: PS_dump_prologue_file("cp437.ps"); break; + case S_ENC_CP850: PS_dump_prologue_file("cp850.ps"); break; +@@ -1531,14 +1611,14 @@ + case S_ENC_CP1250: PS_dump_prologue_file("cp1250.ps"); break; + case S_ENC_KOI8_R: PS_dump_prologue_file("koi8r.ps"); break; + case S_ENC_KOI8_U: PS_dump_prologue_file("koi8u.ps"); break; ++ case S_ENC_UTF8: PS_dump_prologue_file("utf-8.ps"); ++ if (!aglist) PS_load_glyphlist(); ++ break; + case S_ENC_DEFAULT: + default: break; + } + } + +- /* Dump the body of the prologue */ +- PS_dump_prologue_file("prologue.ps"); +- + /* Redefine old epslatex linetypes if requested */ + if ((ps_params->terminal == PSTERM_EPSLATEX) && ps_params->oldstyle) { + for (i = 0; OldEPSL_linetypes[i] != NULL; i++) +@@ -1583,6 +1663,7 @@ + xmax_t = term->xmax * (xsize + xoffset) / (2*PS_SC); + ymin_t = term->ymax * yoffset / (2*PS_SC); + ymax_t = term->ymax * (ysize + yoffset) / (2*PS_SC); ++ term->tscale = PS_SC * 2; + break; + case PSTERM_PORTRAIT: + if (!ps_explicit_size) { +@@ -1593,6 +1674,7 @@ + xmax_t = term->xmax * (xsize + xoffset) / PS_SC; + ymin_t = term->ymax * yoffset / PS_SC; + ymax_t = term->ymax * (ysize + yoffset) / PS_SC; ++ term->tscale = PS_SC; + break; + case PSTERM_LANDSCAPE: + if (!ps_explicit_size) { +@@ -1603,6 +1685,7 @@ + ymax_t = term->xmax * (xsize+xoffset) / PS_SC; + xmin_t = term->ymax * (1-ysize-yoffset) / PS_SC; + xmax_t = term->ymax * (1-yoffset) / PS_SC; ++ term->tscale = PS_SC; + break; + default: + int_error(NO_CARET, "invalid postscript format used"); +@@ -1695,11 +1778,6 @@ + { + fputs("%%Trailer\n", gppsfile); + +- /* I think the following commands should be executed +- `if (ps_common_uses_fonts)`. So I changed the next line. +- Please see "PS_RememberFont", too. */ /* JFi */ +- +- /* if (!ps_common_uses_fonts) { */ /* JFi */ + if (ps_common_uses_fonts) { + fputs("%%DocumentFonts: ", gppsfile); + while (PS_DocFonts) { +@@ -1876,38 +1954,97 @@ + TERM_PUBLIC void + PS_put_text(unsigned int x, unsigned int y, const char *str) + { +- char ch; ++#define PS_NONE 0 ++#define PS_TEXT 1 ++#define PS_GLYPH 2 ++ unsigned long ch; + + if (!str && !strlen(str)) + return; + PS_move(x,y); + if (ps_ang != 0) +- fprintf(gppsfile,"currentpoint gsave translate %d rotate 0 0 M\n", +- ps_ang); +- putc('(',gppsfile); +- ch = *str++; +- while(ch!='\0') { +- if ((ch=='(') || (ch==')') || (ch=='\\')) +- putc('\\', gppsfile); +- putc(ch, gppsfile); +- ch = *str++; +- } ++ fprintf(gppsfile,"currentpoint gsave translate %d rotate 0 0 M\n", ps_ang); + +- switch(ps_justify) { +- case LEFT : +- fputs(") Lshow\n", gppsfile); +- break; +- case CENTRE : +- fputs(") Cshow\n", gppsfile); +- break; +- case RIGHT : +- fputs(") Rshow\n", gppsfile); +- break; ++ if (encoding == S_ENC_UTF8 && contains8bit(str)) { ++ /* UTF-8 encoding with multibyte characters present */ ++ int mode = PS_NONE; ++ ++ putc('[', gppsfile); ++ ++ for (utf8toulong(&ch, &str); ch != '\0'; utf8toulong(&ch, &str)) { ++ if (ch < 0x100) { ++ if (mode != PS_TEXT) ++ putc('(', gppsfile); ++ if (ch == '(' || ch == ')' || ch == '\\') ++ putc('\\', gppsfile); ++ putc((char)ch, gppsfile); ++ mode = PS_TEXT; ++ } else { ++ int i; ++ if (mode == PS_TEXT) ++ putc(')', gppsfile); ++ putc('/', gppsfile); ++#if (ADOBE_ENCODING_NAMES) ++ for (i = 0; i < psglyphs; i++) { ++ if (aglist[i].unicode == ch) { ++ fputs(aglist[i].glyphname, gppsfile); ++ break; ++ } ++ } ++ if (i >= psglyphs) /* Must not have found a glyph name */ ++#endif ++ fprintf(gppsfile, (ch > 0xffff) ? "u%lX" : "uni%04lX", ch); ++ mode = PS_GLYPH; ++ } ++ } ++ ++ if (mode == PS_TEXT) ++ putc(')', gppsfile); ++ ++ switch(ps_justify) { ++ case LEFT : ++ fputs("] GLshow\n", gppsfile); ++ break; ++ case CENTRE : ++ fputs("] GCshow\n", gppsfile); ++ break; ++ case RIGHT : ++ fputs("] GRshow\n", gppsfile); ++ break; ++ } ++ ++ } else { ++ /* plain old 8-bit mode (not UTF-8), or UTF-8 string with only 7-bit characters */ ++ putc('(',gppsfile); ++ ch = (char) *str++; ++ while(ch!='\0') { ++ if ((ch=='(') || (ch==')') || (ch=='\\')) ++ putc('\\', gppsfile); ++ putc((char) ch, gppsfile); ++ ch = (char) *str++; ++ } ++ ++ switch(ps_justify) { ++ case LEFT : ++ fputs(") Lshow\n", gppsfile); ++ break; ++ case CENTRE : ++ fputs(") Cshow\n", gppsfile); ++ break; ++ case RIGHT : ++ fputs(") Rshow\n", gppsfile); ++ break; ++ } + } ++ + if (ps_ang != 0) + fputs("grestore\n", gppsfile); + ps_path_count = 0; + PS_relative_ok = FALSE; ++ ++#undef PS_NONE ++#undef PS_TEXT ++#undef PS_GLYPH + } + + +@@ -2025,6 +2162,7 @@ + switch(style & 0xf) { + + case FS_SOLID: ++ case FS_TRANSPARENT_SOLID: + /* style == 1 --> fill with intensity according to filldensity */ + filldens = (style >> 4) / 100.0; + if(filldens < 0.0) +@@ -2036,6 +2174,7 @@ + break; + + case FS_PATTERN: ++ case FS_TRANSPARENT_PATTERN: + /* style == 2 --> fill with pattern according to fillpattern */ + /* the upper 3 nibbles of 'style' contain pattern number */ + pattern = (style >> 4) % 8; +@@ -2088,8 +2227,6 @@ + + /* ENHPOST */ + +-static TBOOLEAN ENHps_opened_string; /* try to cut out empty ()'s */ +- + /* + * close a postscript string if it has been opened + */ +@@ -2102,6 +2239,8 @@ + } + } + ++static char *ENHps_opensequence = NULL; ++ + /* + * open a postscript string + */ +@@ -2125,22 +2264,92 @@ + } + + if (!ENHps_opened_string) { +- fprintf(gppsfile, "[(%s) %.1f %.1f %s %s %d (", ++ int safelen = strlen(fontname) + 40; ++ free(ENHps_opensequence); ++ ENHps_opensequence = gp_alloc(safelen,"ENHPS_opensequence"); ++ /* EAM November 2007 - moved here from enhanced_recursion() */ ++ PS_RememberFont(fontname,1); ++#ifdef HAVE_SNPRINTF ++ snprintf(ENHps_opensequence, safelen, "[(%s) %.1f %.1f %s %s %d ", + fontname, fontsize, base, + widthflag ? "true" : "false", + showflag ? "true" : "false", + overprint); ++#else ++ sprintf(ENHps_opensequence, "[(%s) %.1f %.1f %s %s %d ", ++ fontname, fontsize, base, ++ widthflag ? "true" : "false", ++ showflag ? "true" : "false", ++ overprint); ++#endif ++ fprintf(gppsfile, "%s(", ENHps_opensequence); + ENHps_opened_string = TRUE; + } + } + + /* +- * write one or more characters from inside enhanced text processing ++ * Write one character from inside enhanced text processing. ++ * This is trivial except in the case of multi-byte encoding. + */ + TERM_PUBLIC void + ENHPS_WRITEC(int c) + { +- fputc(c, gppsfile); ++ static int in_utf8 = 0; /* nonzero means we are inside a multibyte sequence */ ++ static char utf8[6]; /* holds the multibyte sequence being accumulated */ ++ static int nbytes = 0; /* number of bytes expected in the sequence */ ++ ++ /* UTF-8 Encoding */ ++ if (encoding == S_ENC_UTF8 && (c & 0x80) != 0) { ++ if (in_utf8 == 0) { ++ nbytes = (c & 0xE0) == 0xC0 ? 2 ++ : (c & 0xF0) == 0xE0 ? 3 ++ : (c & 0xF8) == 0xF0 ? 4 ++ : 0; ++ if (!nbytes) /* Illegal UTF8 char; hope it's printable */ ++ fputc(c, gppsfile); ++ else ++ utf8[in_utf8++] = c; ++ } else { ++ utf8[in_utf8++] = c; ++ if (in_utf8 >= nbytes) { ++ unsigned long wch = '\0'; ++ const char *str = &utf8[0]; ++ int i; ++ ++ utf8[nbytes] = '\0'; ++ in_utf8 = 0; ++ utf8toulong(&wch, &str); ++ ++ if (wch < 0x100) { /* Single byte ISO8859-1 character */ ++ fputc(wch, gppsfile); ++ return; ++ } ++ ++ /* Finish off previous partial string, if any */ ++ ENHPS_FLUSH(); ++ ++ /* Write a new partial string for this glyph */ ++ fprintf(gppsfile, "%s/", ENHps_opensequence); ++#if (ADOBE_ENCODING_NAMES) ++ for (i = 0; i < psglyphs; i++) { ++ if (aglist[i].unicode == wch) { ++ fputs(aglist[i].glyphname, gppsfile); ++ break; ++ } ++ } ++ if (i >= psglyphs) /* Must not have found a glyph name */ ++#endif ++ fprintf(gppsfile, (wch > 0xffff) ? "u%lX" : "uni%04lX", wch); ++ fprintf(gppsfile, "]\n"); ++ ++ /* Mark string closed */ ++ ENHps_opened_string = FALSE; ++ } ++ } ++ } else ++ ++ /* Single byte character */ ++ fputc(c, gppsfile); + } + + /* a set-font routine for enhanced post : simply copies +@@ -2189,7 +2398,7 @@ + + PS_FLUSH_PATH; + +- /* if there are no magic characters, we should just be able ++ /* FIXME: if there are no magic characters, we should just be able + * punt the string to PS_put_text(), which will give shorter + * ps output [eg tics and stuff rarely need extra processing], + * but we need to make sure that the current font is the +@@ -2549,7 +2758,7 @@ + TERM_PUBLIC int PS_make_palette (t_sm_palette *palette) + { + if (palette == NULL) { +- return 0; /* postscript can do continuous colors */ ++ return 0; /* postscript can do continuous colors */ + } + + PS_make_header(palette); +@@ -2622,16 +2831,25 @@ + /* General case for solid or pattern-filled polygons + * gsave N ... density PolyFill + */ ++ int fillpar = style >> 4; ++ style = style &0xf; ++ + fprintf(gppsfile, "gsave "); + fprintf(gppsfile, "%i %i N", corners[0].x, corners[0].y); +- for (i = 1; i < points; i++) +- fprintf(gppsfile, " %i %i V", +- corners[i].x-corners[i-1].x, corners[i].y-corners[i-1].y); ++ for (i = 1; i < points; i++) { ++ /* The rationale for mixing V and L is given in PS_vector */ ++ if (i % 105) ++ fprintf(gppsfile, " %i %i V", corners[i].x-corners[i-1].x, ++ corners[i].y-corners[i-1].y); ++ else ++ fprintf(gppsfile, " %i %i L", corners[i].x, corners[i].y); ++ } + +- switch(style & 0xf) { ++ switch(style) { + + case FS_SOLID: +- filldens = (style >> 4) / 100.0; ++ case FS_TRANSPARENT_SOLID: ++ filldens = (fillpar) / 100.0; + if(filldens < 0.0) + filldens = 0.0; + if(filldens >= 1.0) +@@ -2640,8 +2858,10 @@ + fprintf(gppsfile, " %.2f PolyFill\n", filldens); + break; + ++ case FS_TRANSPARENT_PATTERN: ++ fprintf(gppsfile," /TransparentPatterns true def\n"); + case FS_PATTERN: +- pattern = (style >> 4) % 8; ++ pattern = (fillpar) % 8; + if (pattern == 0) { + filldens = 0.5; + fprintf(gppsfile, " %.1f PolyFill\n", filldens); +@@ -2698,10 +2918,11 @@ + if (prev != NULL) /* there is a previous ps_fontfile */ + prev->next = this->next; + else /* this = ps_params->first_fontfile */ +- /* so change ps_params->first_fontfile */ ++ /* so change ps_params->first_fontfile */ + ps_params->first_fontfile = this->next; + free(this->fontfile_name); + free(this->fontfile_fullname); ++ free(this->fontname); + free(this); + this = NULL; + } +@@ -2738,13 +2959,13 @@ + * routine. + */ + static char * +-PS_encode_image(unsigned M, unsigned N, coordval *image, t_imagecolor color_mode, int bits_per_component, int max_colors, enum PS_ENCODING encoding, int *return_num_bytes) ++PS_encode_image(unsigned int M, unsigned int N, coordval *image, t_imagecolor color_mode, int bits_per_component, int max_colors, enum PS_ENCODING encoding, int *return_num_bytes) + { +- unsigned coord_remaining; ++ unsigned int coord_remaining; + coordval *coord_ptr; + unsigned short i_line; +- unsigned i_element; +- unsigned end_of_line; ++ unsigned int i_element; ++ unsigned int end_of_line; + unsigned short bits_remaining, bits_start; + + unsigned long tuple4; +@@ -2912,7 +3133,7 @@ + + + static void +-print_five_operand_image(unsigned M, unsigned N, gpiPoint *corner, t_imagecolor color_mode, unsigned short bits_per_component) ++print_five_operand_image(unsigned int M, unsigned int N, gpiPoint *corner, t_imagecolor color_mode, unsigned short bits_per_component) + { + char *space = ps_params->level1 ? "" : " "; + +@@ -2937,7 +3158,7 @@ + + + TERM_PUBLIC void +-PS_image (unsigned M, unsigned N, coordval *image, gpiPoint *corner, t_imagecolor color_mode) ++PS_image (unsigned int M, unsigned int N, coordval *image, gpiPoint *corner, t_imagecolor color_mode) + { + char *encoded_image; + int num_encoded_bytes; +@@ -3109,13 +3330,12 @@ + * If unsuccessful, look for hardcoded absolute path on UNIX, + * or hardcoded relative path on Windows and OS2, + * or files included at compile time. */ +-static void +-PS_dump_prologue_file(char *name) ++static FILE * ++PS_open_prologue_file(char *name) + { + char *fullname; + char *ps_prologue_dir; + FILE *prologue_fd; +- char buf[256]; + + if ((ps_prologue_dir = getenv("GNUPLOT_PS_DIR")) == NULL) { + #ifdef GNUPLOT_PS_DIR +@@ -3167,6 +3387,8 @@ + dump = prologue_8859_1_ps; + else if (!strcmp(name,"8859-2.ps")) + dump = prologue_8859_2_ps; ++ else if (!strcmp(name,"8859-9.ps")) ++ dump = prologue_8859_9_ps; + else if (!strcmp(name,"cp1250.ps")) + dump = prologue_cp1250_ps; + else if (!strcmp(name,"cp437.ps")) +@@ -3179,16 +3401,18 @@ + dump = prologue_koi8r_ps; + else if (!strcmp(name,"koi8u.ps")) + dump = prologue_koi8u_ps; ++ else if (!strcmp(name,"utf-8.ps")) ++ dump = prologue_utf_8_ps; + else if (!strcmp(name,"prologue.ps")) + dump = prologue_prologue_ps; + else +- int_error(NO_CARET,"Requested Postscript prologue is not included"); ++ int_warn(NO_CARET,"Requested Postscript prologue %s not found",name); + + if (dump) { + for (i = 0; dump[i] != NULL; ++i) + fprintf(gppsfile, "%s", dump[i]); + } +- return; ++ return NULL; + #endif /* GNUPLOT_PS_DIR */ + } + +@@ -3219,8 +3443,62 @@ + int_error(NO_CARET,"Plot failed!"); + } + free(fullname); +- while (fgets(buf, sizeof(buf), prologue_fd)) +- fputs(buf, gppsfile); ++ return prologue_fd; ++} ++ ++static void ++PS_dump_prologue_file(char *name) ++{ ++ char buf[256]; ++ FILE *prologue_fd = PS_open_prologue_file(name); ++ ++ if (prologue_fd) { ++ while (fgets(buf, sizeof(buf), prologue_fd)) ++ fputs(buf, gppsfile); ++ fclose(prologue_fd); ++ } ++} ++ ++static void ++PS_load_glyphlist() ++{ ++ char buf[256]; ++ char *next = NULL; ++ unsigned int code; ++ int len; ++ char glyph_name[32]; ++ FILE *prologue_fd = PS_open_prologue_file("aglfn.txt"); ++ ++ if (!prologue_fd) ++ return; ++ ++ while (fgets(buf, sizeof(buf), prologue_fd)) { ++ if (*buf == '#' || *buf == '\n') ++ continue; ++ code = strtol(buf,&next,16); ++ ++ /* User control over whether Adobe glyph names are used for unicode */ ++ /* entries above 0x0100. I.e. when we see a UTF-8 alpha, do we write */ ++ /* /alpha rather than /uni03B1? Some fonts want one or the other. */ ++ /* This is controlled by 'set term post adobeglyphnames'. */ ++ if (code >= 0x0100 && !ps_params->adobeglyphnames) ++ continue; ++ ++ next++; ++ len = strchr(next,';') - next; ++ strncpy(glyph_name, next, len); ++ glyph_name[len] = '\0'; ++ FPRINTF((stderr, "%04X %s\n", code, glyph_name)); ++ if (aglist_size + sizeof(ps_glyph) > aglist_alloc) { ++ aglist_alloc += 2048; ++ aglist = gp_realloc(aglist, aglist_alloc, "aglist"); ++ } ++ aglist[psglyphs].unicode = code; ++ aglist[psglyphs].glyphname = gp_strdup(glyph_name); ++ aglist_size += sizeof(ps_glyph); ++ psglyphs++; ++ } ++ + fclose(prologue_fd); + } + +@@ -3241,6 +3519,32 @@ + + } + ++TERM_PUBLIC void ++PS_layer(t_termlayer syncpoint) ++{ ++ static int plotno = 0; ++ ++ /* We must ignore all syncpoints that we don't recognize */ ++ switch (syncpoint) { ++ ++ default: ++ break; ++ ++ case TERM_LAYER_BEFORE_PLOT: ++ fprintf(gppsfile, "%% Begin plot #%d\n", ++plotno); ++ break; ++ ++ case TERM_LAYER_AFTER_PLOT: ++ fprintf(gppsfile, "%% End plot #%d\n", plotno); ++ break; ++ ++ case TERM_LAYER_RESET: ++ plotno = 0; ++ break; ++ ++ } ++} ++ + #endif /* TERM_BODY */ + + #ifdef TERM_TABLE +@@ -3253,7 +3557,7 @@ + PS_text, null_scale, PS_graphics, PS_move, PS_vector, + PS_linetype, PS_put_text, PS_text_angle, + PS_justify_text, PS_point, PS_arrow, PS_set_font, PS_pointsize, +- TERM_BINARY|TERM_IS_POSTSCRIPT|TERM_CAN_CLIP /*flags*/, ++ TERM_BINARY|TERM_IS_POSTSCRIPT|TERM_CAN_CLIP|TERM_CAN_DASH /*flags*/, + 0 /*suspend*/, 0 /*resume*/, PS_fillbox, PS_linewidth + #ifdef USE_MOUSE + , 0, 0, 0, 0, 0 /* no mouse support for postscript */ +@@ -3266,8 +3570,9 @@ + , PS_image + #endif + , ENHPS_OPEN, ENHPS_FLUSH, ENHPS_WRITEC +- , 0 /* layer control */ ++ , PS_layer /* used only to insert comments */ + , PS_path ++ , PS_SC /* terminal to pixel coord scale factor */ + TERM_TABLE_END(post_driver) + + #undef LAST_TERM +@@ -3378,7 +3683,7 @@ + " but transfers the texts to LaTeX instead of including in the PostScript", + " code. Thus, many options are the same as in the `postscript terminal`.", + "", +-" From version 4.0 to 4.2, some changes have been invoked into the default ", ++" From version 4.0 to 4.1, some changes have been invoked into the default ", + " appearance of the epslatex terminal to reach better consistency with the", + " postscript terminal: The plot size has been changed from 5 x 3 inches to", + " 5 x 3.5 inches; the character width is now estimated to be 60% of the font", +@@ -3571,7 +3876,7 @@ + " \\special{psfile=...} command. Remember to close the `output file` before", + " next plot unless in `multiplot` mode.", + "", +-" Gnuplot versions prior version 4.2 have generated plots of the size", ++" Gnuplot versions prior version 4.1 have generated plots of the size", + " 5 x 3 inches using the ps(la)tex terminal while the current version generates", + " 5 x 3.5 inches to be consistent with the postscript eps terminal. In", + " addition, the character width is now estimated to be 60% of the font size", +@@ -3624,7 +3929,7 @@ + " {enhanced | noenhanced}", + " {defaultplex | simplex | duplex}", + " {fontfile [add | delete] \"\"", +-" | nofontfiles}", ++" | nofontfiles} {{no}adobeglyphnames}", + PS_COMMON_OPTS1 + PS_COMMON_OPTS2 + PS_COMMON_PROLOG_INFO +@@ -3694,112 +3999,6 @@ + " A PostScript file is editable, so once `gnuplot` has created one, you are", + " free to modify it to your heart's desire. See the `editing postscript`", + " section for some hints.", +-"2 enhanced postscript", +-"?commands set terminal postscript enhanced", +-"?set terminal postscript enhanced", +-"?set term postscript enhanced", +-"?terminal postscript enhanced", +-"?term postscript enhanced", +-"?enhanced_postscript", +-"?enhanced postscript", +-"?Enhanced postscript", +-"?enhanced text", +-"?Enhanced text", +-"?enhanced", +-" Several terminal types support an enhanced text mode in which ", +-" additional formatting information is embedded in the text string.", +-"", +-"@start table - first is interactive cleartext form", +-" Control Examples Explanation", +-" ^ a^x superscript", +-" _ a_x subscript", +-" @ @x or a@^b_c phantom box (occupies no width)", +-" & &{space} inserts space of specified length", +-" ~ ~a{.8-} overprints '-' on 'a', raised by .8", +-" times the current fontsize", +-"#\\begin{tabular}{|ccl|} \\hline", +-"#\\multicolumn{3}{|c|}{Enhanced Text Control Codes} \\\\ \\hline", +-"#Control & Examples & Explanation \\\\ \\hline", +-"#\\verb~^~ & \\verb~a^x~ & superscript\\\\", +-"#\\verb~_~ & \\verb~a_x~ & subscript\\\\", +-"#\\verb~@~ & \\verb~@x or a@^b_c~ & phantom box (occupies no width)\\\\", +-"#\\verb~&~ & \\verb~&{space}~ & inserts space of specified length\\\\", +-"#\\verb|~| & \\verb|~a{.8-}| & overprints '-' on 'a', raised by .8\\\\", +-"#\\verb~ ~ & \\verb~ ~ & times the current fontsize\\\\", +-"%c c l .", +-"%.TE", /* ugly - doc2ms uses @ for column separator, but here we */ +-"%.TS", /* need @ in table, so end and restart the table ! */ +-"%center box tab ($) ;", +-"%c c l .", +-"%Control$Examples$Explanation", +-"%_", +-"%^$a^x$superscript", +-"%\\&_$a\\&_x$subscript", +-"% @ $ @x or a\\&@^b\\&_c$phantom box (occupies no width)", +-"% & $ &{space}$inserts space of specified length", +-"% ~ $ ~a{.8-}$overprints '-' on 'a', raised by .8", +-"% $ $times the current fontsize", +-"@end table", +-"", +-" Braces can be used to place multiple-character text where a single character", +-" is expected (e.g., 2^{10}). To change the font and/or size, use the full", +-" form: {/[fontname][=fontsize | *fontscale] text}. Thus {/Symbol=20 G} is a", +-" 20-point GAMMA and {/*0.75 K} is a K at three-quarters of whatever fontsize", +-" is currently in effect. (The '/' character MUST be the first character after", +-" the '{'.)", +-"", +-" If the encoding vector has been changed by `set encoding`, the default", +-" encoding vector can be used instead by following the slash with a dash. This", +-" is unnecessary if you use the Symbol font, however---since /Symbol uses its", +-" own encoding vector, `gnuplot` will not apply any other encoding vector to", +-" it.", +-"", +-" The phantom box is useful for a@^b_c to align superscripts and subscripts", +-" but does not work well for overwriting an accent on a letter. (To do the", +-" latter, it is much better to use 'set encoding iso_8859_1' to change to the", +-" ISO Latin-1 encoding vector, which contains a large variety of letters with", +-" accents or other diacritical marks.) Since the box is non-spacing, it is", +-" sensible to put the shorter of the subscript or superscript in the box (that", +-" is, after the @).", +-"", +-" Space equal in length to a string can be inserted using the '&' character.", +-" Thus", +-" 'abc&{def}ghi'", +-" would produce", +-" 'abc ghi'.", +-"", +-" The '~' character causes the next character or bracketed text to be", +-" overprinted by the following character or bracketed text. The second text", +-" will be horizontally centered on the first. Thus '~a/' will result in an 'a'", +-" with a slash through it. You can also shift the second text vertically by", +-" preceding the second text with a number, which will define the fraction of the", +-" current fontsize by which the text will be raised or lowered. In this case", +-" the number and text must be enclosed in brackets because more than one", +-" character is necessary. If the overprinted text begins with a number, put a", +-" space between the vertical offset and the text ('~{abc}{.5 000}'); otherwise", +-" no space is needed ('~{abc}{.5---}'). You can change the font for one or", +-" both strings ('~a{.5 /*.2 o}'---an 'a' with a one-fifth-size 'o' on top---and", +-" the space between the number and the slash is necessary), but you can't", +-" change it after the beginning of the string. Neither can you use any other", +-" special syntax within either string. You can, of course, use control", +-" characters by escaping them (see below), such as '~a{\\^}'", +-"", +-" You can access special symbols numerically by specifying \\character-code (in", +-" octal), e.g., {/Symbol \\245} is the symbol for infinity.", +-"", +-" You can escape control characters using \\, e.g., \\\\, \\{, and so on.", +-"", +-" But be aware that strings in double-quotes are parsed differently than those", +-" enclosed in single-quotes. The major difference is that backslashes may need", +-" to be doubled when in double-quoted strings.", +-"", +-" Examples (these are hard to describe in words---try them!):", +-" set xlabel 'Time (10^6 {/Symbol m}s)'", +-" set title '{/Symbol=18 \\362@_{/=9.6 0}^{/=12 x}} \\", +-" {/Helvetica e^{-{/Symbol m}^2/2} d}{/Symbol m}'", +-"", +-" The file \"ps_guide.ps\" in the /docs/psdoc subdirectory of the `gnuplot` source", +-" distribution contains more examples of the enhanced syntax.", + "2 editing postscript", + "?commands set terminal postscript editing", + "?set terminal postscript editing", +@@ -3955,6 +4154,26 @@ + " controlled at the time gnuplot is built. However, you can control this", + " either by defining an environment variable GNUPLOT_PS_DIR or by using the", + " gnuplot command `set loadpath`. See `set loadpath`.", ++"2 postscript adobeglyphnames", ++"?commands set terminal postscript adobeglyphnames", ++"?set terminal postscript adobeglyphnames", ++"?terminal postscript adobeglyphnames", ++"?postscript adobeglyphnames", ++"?adobeglyphnames", ++"=UTF-8", ++" This setting is only relevant to PostScript output with UTF-8 encoding.", ++" It controls the names used to describe characters with Unicode entry points", ++" higher than 0x00FF. That is, all characters outside of the Latin1 set.", ++" In general unicode characters do not have a unique name; they have only a", ++" unicode identification code. However, Adobe have a recommended scheme for", ++" assigning names to certain ranges of characters (extended Latin, Greek, etc).", ++" Some fonts use this scheme, others do not. By default, gnuplot will use", ++" the Adobe glyph names. E.g. the lower case Greek letter alpha will be called", ++" /alpha. If you specific `noadobeglyphnames` then instead gnuplot will use", ++" /uni03B1 to describe this character. If you get this setting wrong, the", ++" character may not be found even if it is present in the font.", ++" It is probably always correct to use the default for Adobe fonts, but for", ++" other fonts you may have to try both settings. See also `fontfile`.", + "", + "" + END_HELP(post) +--- term/PostScript/cp1250.ps ++++ term/PostScript/cp1250.ps 2007-11-05 19:21:56.000000000 +0100 +@@ -1,3 +1,6 @@ ++% ++% Encoding for code page 1250 (Microsoft Windows Central and Eastern European) ++% + /reencodeCP1250 { + dup dup findfont dup length dict begin + { 1 index /FID ne { def }{ pop pop } ifelse } forall +--- term/PostScript/unicode_small.map ++++ term/PostScript/unicode_small.map 2007-11-11 20:22:23.000000000 +0100 +@@ -0,0 +1,462 @@ ++=00 U+0000 ++=01 U+0001 ++=02 U+0002 ++=03 U+0003 ++=04 U+0004 ++=05 U+0005 ++=06 U+0006 ++=07 U+0007 ++=08 U+0008 ++=09 U+0009 ++=0A U+000A ++=0B U+000B ++=0C U+000C ++=0D U+000D ++=0E U+000E ++=0F U+000F ++=10 U+0010 ++=11 U+0011 ++=12 U+0012 ++=13 U+0013 ++=14 U+0014 ++=15 U+0015 ++=16 U+0016 ++=17 U+0017 ++=18 U+0018 ++=19 U+0019 ++=1A U+001A ++=1B U+001B ++=1C U+001C ++=1D U+001D ++=1E U+001E ++=1F U+001F ++!20 U+0020 space ++!21 U+0021 exclam ++!22 U+0022 quotedbl ++!23 U+0023 numbersign ++!24 U+0024 dollar ++!25 U+0025 percent ++!26 U+0026 ampersand ++!27 U+0027 quotesingle ++!28 U+0028 parenleft ++!29 U+0029 parenright ++!2A U+002A asterisk ++!2B U+002B plus ++!2C U+002C comma ++!2D U+002D hyphen ++!2E U+002E period ++!2F U+002F slash ++!30 U+0030 zero ++!31 U+0031 one ++!32 U+0032 two ++!33 U+0033 three ++!34 U+0034 four ++!35 U+0035 five ++!36 U+0036 six ++!37 U+0037 seven ++!38 U+0038 eight ++!39 U+0039 nine ++!3A U+003A colon ++!3B U+003B semicolon ++!3C U+003C less ++!3D U+003D equal ++!3E U+003E greater ++!3F U+003F question ++!40 U+0040 at ++!41 U+0041 A ++!42 U+0042 B ++!43 U+0043 C ++!44 U+0044 D ++!45 U+0045 E ++!46 U+0046 F ++!47 U+0047 G ++!48 U+0048 H ++!49 U+0049 I ++!4A U+004A J ++!4B U+004B K ++!4C U+004C L ++!4D U+004D M ++!4E U+004E N ++!4F U+004F O ++!50 U+0050 P ++!51 U+0051 Q ++!52 U+0052 R ++!53 U+0053 S ++!54 U+0054 T ++!55 U+0055 U ++!56 U+0056 V ++!57 U+0057 W ++!58 U+0058 X ++!59 U+0059 Y ++!5A U+005A Z ++!5B U+005B bracketleft ++!5C U+005C backslash ++!5D U+005D bracketright ++!5E U+005E asciicircum ++!5F U+005F underscore ++!60 U+0060 grave ++!61 U+0061 a ++!62 U+0062 b ++!63 U+0063 c ++!64 U+0064 d ++!65 U+0065 e ++!66 U+0066 f ++!67 U+0067 g ++!68 U+0068 h ++!69 U+0069 i ++!6A U+006A j ++!6B U+006B k ++!6C U+006C l ++!6D U+006D m ++!6E U+006E n ++!6F U+006F o ++!70 U+0070 p ++!71 U+0071 q ++!72 U+0072 r ++!73 U+0073 s ++!74 U+0074 t ++!75 U+0075 u ++!76 U+0076 v ++!77 U+0077 w ++!78 U+0078 x ++!79 U+0079 y ++!7A U+007A z ++!7B U+007B braceleft ++!7C U+007C bar ++!7D U+007D braceright ++!7E U+007E asciitilde ++=A0 U+00A0 ++!A1 U+00A1 exclamdown ++!A2 U+00A2 cent ++!A3 U+00A3 sterling ++!A4 U+00A4 currency ++!A5 U+00A5 yen ++!A6 U+00A6 brokenbar ++!A7 U+00A7 section ++!A8 U+00A8 dieresis ++!A9 U+00A9 copyright ++!AA U+00AA ordfeminine ++!AB U+00AB guillemotleft ++!AC U+00AC logicalnot ++=AD U+00AD ++!AE U+00AE registered ++!AF U+00AF macron ++!B0 U+00B0 degree ++!B1 U+00B1 plusminus ++=B2 U+00B2 ++=B3 U+00B3 ++!B4 U+00B4 acute ++=B5 U+00B5 ++!B6 U+00B6 paragraph ++!B7 U+00B7 periodcentered ++!B8 U+00B8 cedilla ++=B9 U+00B9 ++!BA U+00BA ordmasculine ++!BB U+00BB guillemotright ++!BC U+00BC onequarter ++!BD U+00BD onehalf ++!BE U+00BE threequarters ++!BF U+00BF questiondown ++!C0 U+00C0 Agrave ++!C1 U+00C1 Aacute ++!C2 U+00C2 Acircumflex ++!C3 U+00C3 Atilde ++!C4 U+00C4 Adieresis ++!C5 U+00C5 Aring ++!C6 U+00C6 AE ++!C7 U+00C7 Ccedilla ++!C8 U+00C8 Egrave ++!C9 U+00C9 Eacute ++!CA U+00CA Ecircumflex ++!CB U+00CB Edieresis ++!CC U+00CC Igrave ++!CD U+00CD Iacute ++!CE U+00CE Icircumflex ++!CF U+00CF Idieresis ++!D0 U+00D0 Eth ++!D1 U+00D1 Ntilde ++!D2 U+00D2 Ograve ++!D3 U+00D3 Oacute ++!D4 U+00D4 Ocircumflex ++!D5 U+00D5 Otilde ++!D6 U+00D6 Odieresis ++!D7 U+00D7 multiply ++!D8 U+00D8 Oslash ++!D9 U+00D9 Ugrave ++!DA U+00DA Uacute ++!DB U+00DB Ucircumflex ++!DC U+00DC Udieresis ++!DD U+00DD Yacute ++!DE U+00DE Thorn ++!DF U+00DF germandbls ++!E0 U+00E0 agrave ++!E1 U+00E1 aacute ++!E2 U+00E2 acircumflex ++!E3 U+00E3 atilde ++!E4 U+00E4 adieresis ++!E5 U+00E5 aring ++!E6 U+00E6 ae ++!E7 U+00E7 ccedilla ++!E8 U+00E8 egrave ++!E9 U+00E9 eacute ++!EA U+00EA ecircumflex ++!EB U+00EB edieresis ++!EC U+00EC igrave ++!ED U+00ED iacute ++!EE U+00EE icircumflex ++!EF U+00EF idieresis ++!F0 U+00F0 eth ++!F1 U+00F1 ntilde ++!F2 U+00F2 ograve ++!F3 U+00F3 oacute ++!F4 U+00F4 ocircumflex ++!F5 U+00F5 otilde ++!F6 U+00F6 odieresis ++!F7 U+00F7 divide ++!F8 U+00F8 oslash ++!F9 U+00F9 ugrave ++!FA U+00FA uacute ++!FB U+00FB ucircumflex ++!FC U+00FC udieresis ++!FD U+00FD yacute ++!FE U+00FE thorn ++!FF U+00FF ydieresis ++!19e U+0391 uni0391 ++!19f U+0392 uni0392 ++!1a0 U+0393 uni0393 ++!1a1 U+0394 uni0394 ++!1a2 U+0395 uni0395 ++!1a3 U+0396 uni0396 ++!1a4 U+0397 uni0397 ++!1a5 U+0398 uni0398 ++!1a6 U+0399 uni0399 ++!1a7 U+039A uni039A ++!1a8 U+039B uni039B ++!1a9 U+039C uni039C ++!1aa U+039D uni039D ++!1ab U+039E uni039E ++!1ac U+039F uni039F ++!1ad U+03A0 uni03A0 ++!1ae U+03A1 uni03A1 ++!1af U+03A3 uni03A3 ++!1b0 U+03A4 uni03A4 ++!1b1 U+03A5 uni03A5 ++!1b2 U+03A6 uni03A6 ++!1b3 U+03A7 uni03A7 ++!1b4 U+03A8 uni03A8 ++!1b5 U+03A9 uni03A9 ++!1b6 U+03B1 uni03B1 ++!1b7 U+03B2 uni03B2 ++!1b8 U+03B3 uni03B3 ++!1b9 U+03B4 uni03B4 ++!1ba U+03B5 uni03B5 ++!1bb U+03B6 uni03B6 ++!1bc U+03B7 uni03B7 ++!1bd U+03B8 uni03B8 ++!1be U+03B9 uni03B9 ++!1bf U+03BA uni03BA ++!1c0 U+03BB uni03BB ++!1c1 U+03BC uni03BC ++!1c2 U+03BD uni03BD ++!1c3 U+03BE uni03BE ++!1c4 U+03BF uni03BF ++!1c5 U+03C0 uni03C0 ++!1c6 U+03C1 uni03C1 ++!1c7 U+03C2 uni03C2 ++!1c8 U+03C3 uni03C3 ++!1c9 U+03C4 uni03C4 ++!1ca U+03C5 uni03C5 ++!1cb U+03C6 uni03C6 ++!1cc U+03C7 uni03C7 ++!1cd U+03C8 uni03C8 ++!1ce U+03C9 uni03C9 ++!1cf U+03D0 uni03D0 ++!1d0 U+03D1 uni03D1 ++!1d1 U+03D5 uni03D5 ++!1d2 U+03D6 uni03D6 ++!25b U+2016 uni2016 ++!26d U+2032 uni2032 ++!26e U+2033 uni2033 ++!26f U+2034 uni2034 ++!270 U+2035 uni2035 ++!271 U+2036 uni2036 ++!272 U+2037 uni2037 ++!273 U+2039 uni2039 ++!274 U+203A uni203A ++!275 U+203C uni203C ++!276 U+2044 uni2044 ++!277 U+20AC uni20AC ++!278 U+2107 uni2107 ++!279 U+210B uni210B ++!27a U+210E uni210E ++!27b U+210F uni210F ++!27e U+2113 uni2113 ++!284 U+211B uni211B ++!289 U+2126 uni2126 ++!28a U+2127 uni2127 ++!28d U+212B uni212B ++!295 U+2135 uni2135 ++!296 U+2136 uni2136 ++!297 U+2137 uni2137 ++!298 U+2138 uni2138 ++!299 U+2190 uni2190 ++!29a U+2191 uni2191 ++!29b U+2192 uni2192 ++!29c U+2193 uni2193 ++!29d U+2194 uni2194 ++!29e U+2195 uni2195 ++!2a1 U+21D0 uni21D0 ++!2a2 U+21D1 uni21D1 ++!2a3 U+21D2 uni21D2 ++!2a4 U+21D3 uni21D3 ++!2a5 U+21D4 uni21D4 ++!2a6 U+2200 uni2200 ++!2a7 U+2202 uni2202 ++!2a8 U+2203 uni2203 ++!2aa U+2205 uni2205 ++!2ab U+2206 uni2206 ++!2ac U+2207 uni2207 ++!2ad U+2208 uni2208 ++!2ae U+2209 uni2209 ++!2af U+220A uni220A ++!2b0 U+220B uni220B ++!2b1 U+220C uni220C ++!2b2 U+220D uni220D ++!2b4 U+220F uni220F ++!2b6 U+2211 uni2211 ++!2b7 U+2212 uni2212 ++!2b8 U+2213 uni2213 ++!2ba U+2215 uni2215 ++!2bb U+2216 uni2216 ++!2bc U+2217 uni2217 ++!2bd U+2218 uni2218 ++!2be U+2219 uni2219 ++!2bf U+221A uni221A ++!2c0 U+221B uni221B ++!2c1 U+221C uni221C ++!2c2 U+221D uni221D ++!2c3 U+221E uni221E ++!2c4 U+221F uni221F ++!2c8 U+2223 uni2223 ++!2ca U+2225 uni2225 ++!2cc U+2227 uni2227 ++!2cd U+2228 uni2228 ++!2ce U+2229 uni2229 ++!2cf U+222A uni222A ++!2d0 U+222B uni222B ++!2d1 U+222C uni222C ++!2d2 U+222D uni222D ++!2d3 U+222E uni222E ++!2d9 U+2234 uni2234 ++!2da U+2235 uni2235 ++!2db U+2236 uni2236 ++!2dc U+2237 uni2237 ++!2e1 U+223C uni223C ++!2e2 U+223D uni223D ++!2e3 U+223E uni223E ++!2e4 U+223F uni223F ++!2e6 U+2241 uni2241 ++!2e7 U+2242 uni2242 ++!2e8 U+2243 uni2243 ++!2e9 U+2244 uni2244 ++!2ea U+2245 uni2245 ++!2eb U+2246 uni2246 ++!2ec U+2247 uni2247 ++!2ed U+2248 uni2248 ++!2ee U+2249 uni2249 ++!2f4 U+224F uni224F ++!2f5 U+225F uni225F ++!2f6 U+2260 uni2260 ++!2f7 U+2261 uni2261 ++!2fa U+2264 uni2264 ++!2fb U+2265 uni2265 ++!2fc U+2266 uni2266 ++!2fd U+2267 uni2267 ++!300 U+226A uni226A ++!301 U+226B uni226B ++!302 U+226C uni226C ++!303 U+226D uni226D ++!304 U+226E uni226E ++!305 U+226F uni226F ++!306 U+2270 uni2270 ++!307 U+2271 uni2271 ++!308 U+2272 uni2272 ++!309 U+2273 uni2273 ++!30a U+2274 uni2274 ++!30b U+2275 uni2275 ++!310 U+227A uni227A ++!311 U+227B uni227B ++!312 U+227C uni227C ++!313 U+227D uni227D ++!314 U+227E uni227E ++!315 U+227F uni227F ++!316 U+2280 uni2280 ++!317 U+2281 uni2281 ++!318 U+2282 uni2282 ++!319 U+2283 uni2283 ++!31a U+2284 uni2284 ++!31b U+2285 uni2285 ++!31c U+2286 uni2286 ++!31d U+2287 uni2287 ++!31e U+2288 uni2288 ++!31f U+2289 uni2289 ++!389 U+2297 uni2297 ++!38b U+2299 uni2299 ++!320 U+22C0 uni22C0 ++!321 U+22C1 uni22C1 ++!322 U+22C2 uni22C2 ++!323 U+22C3 uni22C3 ++!327 U+2310 uni2310 ++!328 U+2320 uni2320 ++!329 U+2321 uni2321 ++!32a U+2322 uni2322 ++!32b U+2323 uni2323 ++!32c U+2329 uni2329 ++!32d U+232A uni232A ++!32e U+239B uni239B ++!32f U+239C uni239C ++!330 U+239D uni239D ++!331 U+239E uni239E ++!332 U+239F uni239F ++!333 U+23A0 uni23A0 ++!334 U+23A1 uni23A1 ++!335 U+23A2 uni2392 ++!336 U+23A3 uni23A3 ++!337 U+23A4 uni23A4 ++!338 U+23A5 uni23A5 ++!339 U+23A6 uni23A6 ++!33a U+23A7 uni23A7 ++!33b U+23A8 uni23A8 ++!33c U+23A9 uni23A9 ++!33d U+23AA uni23AA ++!33e U+23AB uni23AB ++!33f U+23AC uni23AC ++!340 U+23AD uni23AD ++!341 U+23AE uni23AE ++!342 U+23AF uni23AF ++!343 U+23B0 uni23B0 ++!344 U+23B1 uni23B1 ++!345 U+23B2 uni23B2 ++!346 U+23B3 uni23B3 ++!347 U+23B4 uni23B4 ++!348 U+23B5 uni23B5 ++!349 U+23B6 uni23B6 ++!34a U+23B7 uni23B7 ++!34b U+23B8 uni23B8 ++!34c U+23B9 uni23B9 ++!356 U+25A0 uni25A0 ++!357 U+25A1 uni25A1 ++!358 U+25AA uni25AA ++!359 U+25AB uni25AB ++!35b U+25B2 uni25B2 ++!35c U+25B3 uni25B3 ++!35d U+25BC uni25BC ++!35e U+25BD uni25BD ++!35a U+25C6 uni25C6 ++!35f U+25CA uni25CA ++!360 U+25CB uni25CB ++!361 U+25CF uni25CF ++!364 U+25E6 uni25E6 ++!362 U+25FB uni25FB ++!363 U+25FC uni25FC ++!365 U+2609 uni2609 +--- term/PostScript/8859-15.ps ++++ term/PostScript/8859-15.ps 2007-11-05 19:21:56.000000000 +0100 +@@ -1,3 +1,6 @@ ++% ++% Encoding for ISO-8859-15 (also called Latin9) ++% + /reencodeISO15 { + dup dup findfont dup length dict begin + { 1 index /FID ne { def }{ pop pop } ifelse } forall +--- term/PostScript/utf-8.ps ++++ term/PostScript/utf-8.ps 2007-11-11 20:22:23.000000000 +0100 +@@ -0,0 +1,58 @@ ++% ++% Base ISO8859-1 character encoding plus support macros for UTF-8 encoding ++% via the glyphshow operator ++% ++/reencodeISO { ++dup dup findfont dup length dict begin ++{ 1 index /FID ne { def }{ pop pop } ifelse } forall ++currentdict /CharStrings known { ++ CharStrings /Idieresis known { ++ /Encoding ISOLatin1Encoding def } if ++} if ++currentdict end definefont ++} def ++/ISOLatin1Encoding [ ++/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef ++/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef ++/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef ++/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef ++/space/exclam/quotedbl/numbersign/dollar/percent/ampersand/quoteright ++/parenleft/parenright/asterisk/plus/comma/minus/period/slash ++/zero/one/two/three/four/five/six/seven/eight/nine/colon/semicolon ++/less/equal/greater/question/at/A/B/C/D/E/F/G/H/I/J/K/L/M/N ++/O/P/Q/R/S/T/U/V/W/X/Y/Z/bracketleft/backslash/bracketright ++/asciicircum/underscore/quoteleft/a/b/c/d/e/f/g/h/i/j/k/l/m ++/n/o/p/q/r/s/t/u/v/w/x/y/z/braceleft/bar/braceright/asciitilde ++/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef ++/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef ++/.notdef/dotlessi/grave/acute/circumflex/tilde/macron/breve ++/dotaccent/dieresis/.notdef/ring/cedilla/.notdef/hungarumlaut ++/ogonek/caron/space/exclamdown/cent/sterling/currency/yen/brokenbar ++/section/dieresis/copyright/ordfeminine/guillemotleft/logicalnot ++/hyphen/registered/macron/degree/plusminus/twosuperior/threesuperior ++/acute/mu/paragraph/periodcentered/cedilla/onesuperior/ordmasculine ++/guillemotright/onequarter/onehalf/threequarters/questiondown ++/Agrave/Aacute/Acircumflex/Atilde/Adieresis/Aring/AE/Ccedilla ++/Egrave/Eacute/Ecircumflex/Edieresis/Igrave/Iacute/Icircumflex ++/Idieresis/Eth/Ntilde/Ograve/Oacute/Ocircumflex/Otilde/Odieresis ++/multiply/Oslash/Ugrave/Uacute/Ucircumflex/Udieresis/Yacute ++/Thorn/germandbls/agrave/aacute/acircumflex/atilde/adieresis ++/aring/ae/ccedilla/egrave/eacute/ecircumflex/edieresis/igrave ++/iacute/icircumflex/idieresis/eth/ntilde/ograve/oacute/ocircumflex ++/otilde/odieresis/divide/oslash/ugrave/uacute/ucircumflex/udieresis ++/yacute/thorn/ydieresis ++] def ++ ++/Gshow { dup type /stringtype eq { show } { glyphshow } ifelse } def ++ ++/Gsall { {Gshow} forall } def ++/Gwidth { ++ dup currentpoint pop exch ++ gsave 6 array currentmatrix nulldevice setmatrix Gsall currentpoint pop grestore sub ++ } def ++/GLshow {currentpoint stroke M 0 vshift R ++ Blacktext {gsave 0 setgray Gsall grestore} {Gsall} ifelse} def ++/GRshow {currentpoint stroke M dup Gwidth vshift R ++ Blacktext {gsave 0 setgray Gsall grestore} {Gsall} ifelse} def ++/GCshow {currentpoint stroke M dup Gwidth 2 div vshift R ++ Blacktext {gsave 0 setgray Gsall grestore} {Gsall} ifelse} def +--- term/PostScript/8859-1.ps ++++ term/PostScript/8859-1.ps 2007-11-05 19:21:56.000000000 +0100 +@@ -1,3 +1,6 @@ ++% ++% Encoding for ISO-8859-1 (also called Latin1) ++% + /reencodeISO { + dup dup findfont dup length dict begin + { 1 index /FID ne { def }{ pop pop } ifelse } forall +--- term/PostScript/cp437.ps ++++ term/PostScript/cp437.ps 2007-11-05 19:21:56.000000000 +0100 +@@ -1,4 +1,5 @@ +-% encoding for code page 437 ++% ++% encoding for code page 437 (original MSDOS) + % version 1.0: - Mainly letters are mapped. The following positions + % (JFi) are left blank (undefined): + % -- first 32 positions, +--- term/PostScript/cp852.ps ++++ term/PostScript/cp852.ps 2007-11-05 19:21:56.000000000 +0100 +@@ -1,4 +1,5 @@ +-% encoding for code page 852 ++% ++% encoding for code page 852 (MSDOS Central European) + /reencodeCP852 { + dup dup findfont dup length dict begin + { 1 index /FID ne { def }{ pop pop } ifelse } forall +--- term/PostScript/NOTE.aglfn ++++ term/PostScript/NOTE.aglfn 2008-03-31 17:44:57.145018619 +0200 +@@ -0,0 +1,2 @@ ++The document aglfn.txt was obtained from http://www.adobe.com/devnet/opentype/archives/aglfn.txt ++Do never change this document as this is not allowed by the license found therein. +--- term/PostScript/aglfn.txt ++++ term/PostScript/aglfn.txt 2007-11-13 04:46:16.000000000 +0100 +@@ -0,0 +1,932 @@ ++# ################################################################################### ++# Copyright (c) 2003,2005,2006,2007 Adobe Systems Incorporated ++# ++# Permission is hereby granted, free of charge, to any person obtaining a ++# copy of this documentation file to use, copy, publish, distribute, ++# sublicense, and/or sell copies of the documentation, and to permit ++# others to do the same, provided that: ++# - No modification, editing or other alteration of this document is ++# allowed; and ++# - The above copyright notice and this permission notice shall be ++# included in all copies of the documentation. ++# ++# Permission is hereby granted, free of charge, to any person obtaining a ++# copy of this documentation file, to create their own derivative works ++# from the content of this document to use, copy, publish, distribute, ++# sublicense, and/or sell the derivative works, and to permit others to do ++# the same, provided that the derived work is not represented as being a ++# copy or version of this document. ++# ++# Adobe shall not be liable to any party for any loss of revenue or profit ++# or for indirect, incidental, special, consequential, or other similar ++# damages, whether based on tort (including without limitation negligence ++# or strict liability), contract or other legal or equitable grounds even ++# if Adobe has been advised or had reason to know of the possibility of ++# such damages.Ê The Adobe materials are provided on an "AS IS" basis.Ê ++# Adobe specifically disclaims all express, statutory, or implied ++# warranties relating to the Adobe materials, including but not limited to ++# those concerning merchantability or fitness for a particular purpose or ++# non-infringement of any third party rights regarding the Adobe ++# materials. ++# ################################################################################### ++# Name: Adobe Glyph List For New Fonts ++# Table version: 1.6 ++# Date: 30 Januaury 2006 ++# ++# Description: ++# ++# The Adobe Glyph List For New Fonts (AGLFN) is meant to provide a list of ++# base glyph names which are compatible with the AGL specification at ++# http://partners.adobe.com/asn/developer/type/unicodegn.html. ++# and which can be used as described in section 6 of that document. ++# ++# This list comprises the set of glyph names from the AGLv2,0 which map ++# to via the AGL rules to the semanticly correct Unicode value. For ++# example, Asmall is omitted as the AGL maps this to the Unicode ++# Private Use Area value F761, rather than to the Unicode value for the ++# character "A". "ffi" is also omitted, as the AGL maps this to the ++# Alphabetic Presentation Forms Area value FB03, rather than ++# decomposing it to the three-value Unicode sequence 0066,0066,0069. ++# See section 7.1 of the Unicode Standard 4.0 on this issue. ++# "arrowvertex" is omitted becuase this now has a real Unicode ++# character value, and the AGL is now incorrect in mapping this to the ++# Private Use Area value F8E6. ++# ++# If you do not find an appropriate name for your glyph in this list, ++# then please refer to section 6 of the document: ++# http://partners.adobe.com/asn/developer/typeforum/unicodegn.html. ++# ++# The Unicode values and names are given for convenience. ++# ++# Format: Semicolon-delimited fields: ++# ++# (1) Standard UV or CUS UV. (4 uppercase hexadecimal digits) ++# ++# (2) Glyph name. (upper- and lowercase letters, digits) ++# ++# (3) Character names: Unicode character names for standard UVs, and ++# descriptive names for CUS UVs. (uppercase letters, hyphen, space) ++# ++# The entries are sorted by glyph name in increasing ASCII order; entries ++# with the same glyph name are sorted in decreasing priority order. ++# ++# Lines starting with "#" are comments; blank lines should be ignored. ++# ++# 1.6 [30 January 2006] ++# - Completed work intended in 1.5 ++# ++# 1.5 [23 November 2005] ++# - removed duplicated block at end of file ++# - changed mappings: ++# 2206;Delta;INCREMENT changed to 0394;Delta;GREEK CAPITAL LETTER DELTA ++# 2126;Omega;OHM SIGN changed to 03A9;Omega;GREEK CAPITAL LETTER OMEGA ++# 03BC;mu;MICRO SIGN changed to 03BC;mu;GREEK SMALL LETTER MU ++# - corrected statement above about why ffi is omitted. ++ ++# 1.4 [24 September 2003] Changed version to 1.4, to avoid confusion ++# with the AGL 1.3 ++# fixed spelling errors in the header ++# fully removed arrowvertex, as it is mapped only to a PUA Unicode value in some fonts. ++# ++# 1.1 [17 April 2003] Renamed [Tt]cedilla back to [Tt]commaaccent: ++# ++# 1.0 [31 Jan 2003] Original version. Derived from the AGLv1.2 by: ++# - removing the PUA area codes ++# - removing duplicate Unicode mappings, and ++# - renaming tcommaaccent to tcedilla and Tcommaaccent to Tcedilla ++# ++0041;A;LATIN CAPITAL LETTER A ++00C6;AE;LATIN CAPITAL LETTER AE ++01FC;AEacute;LATIN CAPITAL LETTER AE WITH ACUTE ++00C1;Aacute;LATIN CAPITAL LETTER A WITH ACUTE ++0102;Abreve;LATIN CAPITAL LETTER A WITH BREVE ++00C2;Acircumflex;LATIN CAPITAL LETTER A WITH CIRCUMFLEX ++00C4;Adieresis;LATIN CAPITAL LETTER A WITH DIAERESIS ++00C0;Agrave;LATIN CAPITAL LETTER A WITH GRAVE ++0391;Alpha;GREEK CAPITAL LETTER ALPHA ++0386;Alphatonos;GREEK CAPITAL LETTER ALPHA WITH TONOS ++0100;Amacron;LATIN CAPITAL LETTER A WITH MACRON ++0104;Aogonek;LATIN CAPITAL LETTER A WITH OGONEK ++00C5;Aring;LATIN CAPITAL LETTER A WITH RING ABOVE ++01FA;Aringacute;LATIN CAPITAL LETTER A WITH RING ABOVE AND ACUTE ++00C3;Atilde;LATIN CAPITAL LETTER A WITH TILDE ++0042;B;LATIN CAPITAL LETTER B ++0392;Beta;GREEK CAPITAL LETTER BETA ++0043;C;LATIN CAPITAL LETTER C ++0106;Cacute;LATIN CAPITAL LETTER C WITH ACUTE ++010C;Ccaron;LATIN CAPITAL LETTER C WITH CARON ++00C7;Ccedilla;LATIN CAPITAL LETTER C WITH CEDILLA ++0108;Ccircumflex;LATIN CAPITAL LETTER C WITH CIRCUMFLEX ++010A;Cdotaccent;LATIN CAPITAL LETTER C WITH DOT ABOVE ++03A7;Chi;GREEK CAPITAL LETTER CHI ++0044;D;LATIN CAPITAL LETTER D ++010E;Dcaron;LATIN CAPITAL LETTER D WITH CARON ++0110;Dcroat;LATIN CAPITAL LETTER D WITH STROKE ++0394;Delta;GREEK CAPITAL LETTER DELTA ++0045;E;LATIN CAPITAL LETTER E ++00C9;Eacute;LATIN CAPITAL LETTER E WITH ACUTE ++0114;Ebreve;LATIN CAPITAL LETTER E WITH BREVE ++011A;Ecaron;LATIN CAPITAL LETTER E WITH CARON ++00CA;Ecircumflex;LATIN CAPITAL LETTER E WITH CIRCUMFLEX ++00CB;Edieresis;LATIN CAPITAL LETTER E WITH DIAERESIS ++0116;Edotaccent;LATIN CAPITAL LETTER E WITH DOT ABOVE ++00C8;Egrave;LATIN CAPITAL LETTER E WITH GRAVE ++0112;Emacron;LATIN CAPITAL LETTER E WITH MACRON ++014A;Eng;LATIN CAPITAL LETTER ENG ++0118;Eogonek;LATIN CAPITAL LETTER E WITH OGONEK ++0395;Epsilon;GREEK CAPITAL LETTER EPSILON ++0388;Epsilontonos;GREEK CAPITAL LETTER EPSILON WITH TONOS ++0397;Eta;GREEK CAPITAL LETTER ETA ++0389;Etatonos;GREEK CAPITAL LETTER ETA WITH TONOS ++00D0;Eth;LATIN CAPITAL LETTER ETH ++20AC;Euro;EURO SIGN ++0046;F;LATIN CAPITAL LETTER F ++0047;G;LATIN CAPITAL LETTER G ++0393;Gamma;GREEK CAPITAL LETTER GAMMA ++011E;Gbreve;LATIN CAPITAL LETTER G WITH BREVE ++01E6;Gcaron;LATIN CAPITAL LETTER G WITH CARON ++011C;Gcircumflex;LATIN CAPITAL LETTER G WITH CIRCUMFLEX ++0122;Gcommaaccent;LATIN CAPITAL LETTER G WITH CEDILLA ++0120;Gdotaccent;LATIN CAPITAL LETTER G WITH DOT ABOVE ++0048;H;LATIN CAPITAL LETTER H ++25CF;H18533;BLACK CIRCLE ++25AA;H18543;BLACK SMALL SQUARE ++25AB;H18551;WHITE SMALL SQUARE ++25A1;H22073;WHITE SQUARE ++0126;Hbar;LATIN CAPITAL LETTER H WITH STROKE ++0124;Hcircumflex;LATIN CAPITAL LETTER H WITH CIRCUMFLEX ++0049;I;LATIN CAPITAL LETTER I ++0132;IJ;LATIN CAPITAL LIGATURE IJ ++00CD;Iacute;LATIN CAPITAL LETTER I WITH ACUTE ++012C;Ibreve;LATIN CAPITAL LETTER I WITH BREVE ++00CE;Icircumflex;LATIN CAPITAL LETTER I WITH CIRCUMFLEX ++00CF;Idieresis;LATIN CAPITAL LETTER I WITH DIAERESIS ++0130;Idotaccent;LATIN CAPITAL LETTER I WITH DOT ABOVE ++2111;Ifraktur;BLACK-LETTER CAPITAL I ++00CC;Igrave;LATIN CAPITAL LETTER I WITH GRAVE ++012A;Imacron;LATIN CAPITAL LETTER I WITH MACRON ++012E;Iogonek;LATIN CAPITAL LETTER I WITH OGONEK ++0399;Iota;GREEK CAPITAL LETTER IOTA ++03AA;Iotadieresis;GREEK CAPITAL LETTER IOTA WITH DIALYTIKA ++038A;Iotatonos;GREEK CAPITAL LETTER IOTA WITH TONOS ++0128;Itilde;LATIN CAPITAL LETTER I WITH TILDE ++004A;J;LATIN CAPITAL LETTER J ++0134;Jcircumflex;LATIN CAPITAL LETTER J WITH CIRCUMFLEX ++004B;K;LATIN CAPITAL LETTER K ++039A;Kappa;GREEK CAPITAL LETTER KAPPA ++0136;Kcommaaccent;LATIN CAPITAL LETTER K WITH CEDILLA ++004C;L;LATIN CAPITAL LETTER L ++0139;Lacute;LATIN CAPITAL LETTER L WITH ACUTE ++039B;Lambda;GREEK CAPITAL LETTER LAMDA ++013D;Lcaron;LATIN CAPITAL LETTER L WITH CARON ++013B;Lcommaaccent;LATIN CAPITAL LETTER L WITH CEDILLA ++013F;Ldot;LATIN CAPITAL LETTER L WITH MIDDLE DOT ++0141;Lslash;LATIN CAPITAL LETTER L WITH STROKE ++004D;M;LATIN CAPITAL LETTER M ++039C;Mu;GREEK CAPITAL LETTER MU ++004E;N;LATIN CAPITAL LETTER N ++0143;Nacute;LATIN CAPITAL LETTER N WITH ACUTE ++0147;Ncaron;LATIN CAPITAL LETTER N WITH CARON ++0145;Ncommaaccent;LATIN CAPITAL LETTER N WITH CEDILLA ++00D1;Ntilde;LATIN CAPITAL LETTER N WITH TILDE ++039D;Nu;GREEK CAPITAL LETTER NU ++004F;O;LATIN CAPITAL LETTER O ++0152;OE;LATIN CAPITAL LIGATURE OE ++00D3;Oacute;LATIN CAPITAL LETTER O WITH ACUTE ++014E;Obreve;LATIN CAPITAL LETTER O WITH BREVE ++00D4;Ocircumflex;LATIN CAPITAL LETTER O WITH CIRCUMFLEX ++00D6;Odieresis;LATIN CAPITAL LETTER O WITH DIAERESIS ++00D2;Ograve;LATIN CAPITAL LETTER O WITH GRAVE ++01A0;Ohorn;LATIN CAPITAL LETTER O WITH HORN ++0150;Ohungarumlaut;LATIN CAPITAL LETTER O WITH DOUBLE ACUTE ++014C;Omacron;LATIN CAPITAL LETTER O WITH MACRON ++03A9;Omega;GREEK CAPITAL LETTER OMEGA ++038F;Omegatonos;GREEK CAPITAL LETTER OMEGA WITH TONOS ++039F;Omicron;GREEK CAPITAL LETTER OMICRON ++038C;Omicrontonos;GREEK CAPITAL LETTER OMICRON WITH TONOS ++00D8;Oslash;LATIN CAPITAL LETTER O WITH STROKE ++01FE;Oslashacute;LATIN CAPITAL LETTER O WITH STROKE AND ACUTE ++00D5;Otilde;LATIN CAPITAL LETTER O WITH TILDE ++0050;P;LATIN CAPITAL LETTER P ++03A6;Phi;GREEK CAPITAL LETTER PHI ++03A0;Pi;GREEK CAPITAL LETTER PI ++03A8;Psi;GREEK CAPITAL LETTER PSI ++0051;Q;LATIN CAPITAL LETTER Q ++0052;R;LATIN CAPITAL LETTER R ++0154;Racute;LATIN CAPITAL LETTER R WITH ACUTE ++0158;Rcaron;LATIN CAPITAL LETTER R WITH CARON ++0156;Rcommaaccent;LATIN CAPITAL LETTER R WITH CEDILLA ++211C;Rfraktur;BLACK-LETTER CAPITAL R ++03A1;Rho;GREEK CAPITAL LETTER RHO ++0053;S;LATIN CAPITAL LETTER S ++250C;SF010000;BOX DRAWINGS LIGHT DOWN AND RIGHT ++2514;SF020000;BOX DRAWINGS LIGHT UP AND RIGHT ++2510;SF030000;BOX DRAWINGS LIGHT DOWN AND LEFT ++2518;SF040000;BOX DRAWINGS LIGHT UP AND LEFT ++253C;SF050000;BOX DRAWINGS LIGHT VERTICAL AND HORIZONTAL ++252C;SF060000;BOX DRAWINGS LIGHT DOWN AND HORIZONTAL ++2534;SF070000;BOX DRAWINGS LIGHT UP AND HORIZONTAL ++251C;SF080000;BOX DRAWINGS LIGHT VERTICAL AND RIGHT ++2524;SF090000;BOX DRAWINGS LIGHT VERTICAL AND LEFT ++2500;SF100000;BOX DRAWINGS LIGHT HORIZONTAL ++2502;SF110000;BOX DRAWINGS LIGHT VERTICAL ++2561;SF190000;BOX DRAWINGS VERTICAL SINGLE AND LEFT DOUBLE ++2562;SF200000;BOX DRAWINGS VERTICAL DOUBLE AND LEFT SINGLE ++2556;SF210000;BOX DRAWINGS DOWN DOUBLE AND LEFT SINGLE ++2555;SF220000;BOX DRAWINGS DOWN SINGLE AND LEFT DOUBLE ++2563;SF230000;BOX DRAWINGS DOUBLE VERTICAL AND LEFT ++2551;SF240000;BOX DRAWINGS DOUBLE VERTICAL ++2557;SF250000;BOX DRAWINGS DOUBLE DOWN AND LEFT ++255D;SF260000;BOX DRAWINGS DOUBLE UP AND LEFT ++255C;SF270000;BOX DRAWINGS UP DOUBLE AND LEFT SINGLE ++255B;SF280000;BOX DRAWINGS UP SINGLE AND LEFT DOUBLE ++255E;SF360000;BOX DRAWINGS VERTICAL SINGLE AND RIGHT DOUBLE ++255F;SF370000;BOX DRAWINGS VERTICAL DOUBLE AND RIGHT SINGLE ++255A;SF380000;BOX DRAWINGS DOUBLE UP AND RIGHT ++2554;SF390000;BOX DRAWINGS DOUBLE DOWN AND RIGHT ++2569;SF400000;BOX DRAWINGS DOUBLE UP AND HORIZONTAL ++2566;SF410000;BOX DRAWINGS DOUBLE DOWN AND HORIZONTAL ++2560;SF420000;BOX DRAWINGS DOUBLE VERTICAL AND RIGHT ++2550;SF430000;BOX DRAWINGS DOUBLE HORIZONTAL ++256C;SF440000;BOX DRAWINGS DOUBLE VERTICAL AND HORIZONTAL ++2567;SF450000;BOX DRAWINGS UP SINGLE AND HORIZONTAL DOUBLE ++2568;SF460000;BOX DRAWINGS UP DOUBLE AND HORIZONTAL SINGLE ++2564;SF470000;BOX DRAWINGS DOWN SINGLE AND HORIZONTAL DOUBLE ++2565;SF480000;BOX DRAWINGS DOWN DOUBLE AND HORIZONTAL SINGLE ++2559;SF490000;BOX DRAWINGS UP DOUBLE AND RIGHT SINGLE ++2558;SF500000;BOX DRAWINGS UP SINGLE AND RIGHT DOUBLE ++2552;SF510000;BOX DRAWINGS DOWN SINGLE AND RIGHT DOUBLE ++2553;SF520000;BOX DRAWINGS DOWN DOUBLE AND RIGHT SINGLE ++256B;SF530000;BOX DRAWINGS VERTICAL DOUBLE AND HORIZONTAL SINGLE ++256A;SF540000;BOX DRAWINGS VERTICAL SINGLE AND HORIZONTAL DOUBLE ++015A;Sacute;LATIN CAPITAL LETTER S WITH ACUTE ++0160;Scaron;LATIN CAPITAL LETTER S WITH CARON ++015E;Scedilla;LATIN CAPITAL LETTER S WITH CEDILLA ++015C;Scircumflex;LATIN CAPITAL LETTER S WITH CIRCUMFLEX ++0218;Scommaaccent;LATIN CAPITAL LETTER S WITH COMMA BELOW ++03A3;Sigma;GREEK CAPITAL LETTER SIGMA ++0054;T;LATIN CAPITAL LETTER T ++03A4;Tau;GREEK CAPITAL LETTER TAU ++0166;Tbar;LATIN CAPITAL LETTER T WITH STROKE ++0164;Tcaron;LATIN CAPITAL LETTER T WITH CARON ++0162;Tcommaaccent;LATIN CAPITAL LETTER T WITH CEDILLA ++0398;Theta;GREEK CAPITAL LETTER THETA ++00DE;Thorn;LATIN CAPITAL LETTER THORN ++0055;U;LATIN CAPITAL LETTER U ++00DA;Uacute;LATIN CAPITAL LETTER U WITH ACUTE ++016C;Ubreve;LATIN CAPITAL LETTER U WITH BREVE ++00DB;Ucircumflex;LATIN CAPITAL LETTER U WITH CIRCUMFLEX ++00DC;Udieresis;LATIN CAPITAL LETTER U WITH DIAERESIS ++00D9;Ugrave;LATIN CAPITAL LETTER U WITH GRAVE ++01AF;Uhorn;LATIN CAPITAL LETTER U WITH HORN ++0170;Uhungarumlaut;LATIN CAPITAL LETTER U WITH DOUBLE ACUTE ++016A;Umacron;LATIN CAPITAL LETTER U WITH MACRON ++0172;Uogonek;LATIN CAPITAL LETTER U WITH OGONEK ++03A5;Upsilon;GREEK CAPITAL LETTER UPSILON ++03D2;Upsilon1;GREEK UPSILON WITH HOOK SYMBOL ++03AB;Upsilondieresis;GREEK CAPITAL LETTER UPSILON WITH DIALYTIKA ++038E;Upsilontonos;GREEK CAPITAL LETTER UPSILON WITH TONOS ++016E;Uring;LATIN CAPITAL LETTER U WITH RING ABOVE ++0168;Utilde;LATIN CAPITAL LETTER U WITH TILDE ++0056;V;LATIN CAPITAL LETTER V ++0057;W;LATIN CAPITAL LETTER W ++1E82;Wacute;LATIN CAPITAL LETTER W WITH ACUTE ++0174;Wcircumflex;LATIN CAPITAL LETTER W WITH CIRCUMFLEX ++1E84;Wdieresis;LATIN CAPITAL LETTER W WITH DIAERESIS ++1E80;Wgrave;LATIN CAPITAL LETTER W WITH GRAVE ++0058;X;LATIN CAPITAL LETTER X ++039E;Xi;GREEK CAPITAL LETTER XI ++0059;Y;LATIN CAPITAL LETTER Y ++00DD;Yacute;LATIN CAPITAL LETTER Y WITH ACUTE ++0176;Ycircumflex;LATIN CAPITAL LETTER Y WITH CIRCUMFLEX ++0178;Ydieresis;LATIN CAPITAL LETTER Y WITH DIAERESIS ++1EF2;Ygrave;LATIN CAPITAL LETTER Y WITH GRAVE ++005A;Z;LATIN CAPITAL LETTER Z ++0179;Zacute;LATIN CAPITAL LETTER Z WITH ACUTE ++017D;Zcaron;LATIN CAPITAL LETTER Z WITH CARON ++017B;Zdotaccent;LATIN CAPITAL LETTER Z WITH DOT ABOVE ++0396;Zeta;GREEK CAPITAL LETTER ZETA ++0061;a;LATIN SMALL LETTER A ++00E1;aacute;LATIN SMALL LETTER A WITH ACUTE ++0103;abreve;LATIN SMALL LETTER A WITH BREVE ++00E2;acircumflex;LATIN SMALL LETTER A WITH CIRCUMFLEX ++00B4;acute;ACUTE ACCENT ++0301;acutecomb;COMBINING ACUTE ACCENT ++00E4;adieresis;LATIN SMALL LETTER A WITH DIAERESIS ++00E6;ae;LATIN SMALL LETTER AE ++01FD;aeacute;LATIN SMALL LETTER AE WITH ACUTE ++2015;afii00208;HORIZONTAL BAR ++0410;afii10017;CYRILLIC CAPITAL LETTER A ++0411;afii10018;CYRILLIC CAPITAL LETTER BE ++0412;afii10019;CYRILLIC CAPITAL LETTER VE ++0413;afii10020;CYRILLIC CAPITAL LETTER GHE ++0414;afii10021;CYRILLIC CAPITAL LETTER DE ++0415;afii10022;CYRILLIC CAPITAL LETTER IE ++0401;afii10023;CYRILLIC CAPITAL LETTER IO ++0416;afii10024;CYRILLIC CAPITAL LETTER ZHE ++0417;afii10025;CYRILLIC CAPITAL LETTER ZE ++0418;afii10026;CYRILLIC CAPITAL LETTER I ++0419;afii10027;CYRILLIC CAPITAL LETTER SHORT I ++041A;afii10028;CYRILLIC CAPITAL LETTER KA ++041B;afii10029;CYRILLIC CAPITAL LETTER EL ++041C;afii10030;CYRILLIC CAPITAL LETTER EM ++041D;afii10031;CYRILLIC CAPITAL LETTER EN ++041E;afii10032;CYRILLIC CAPITAL LETTER O ++041F;afii10033;CYRILLIC CAPITAL LETTER PE ++0420;afii10034;CYRILLIC CAPITAL LETTER ER ++0421;afii10035;CYRILLIC CAPITAL LETTER ES ++0422;afii10036;CYRILLIC CAPITAL LETTER TE ++0423;afii10037;CYRILLIC CAPITAL LETTER U ++0424;afii10038;CYRILLIC CAPITAL LETTER EF ++0425;afii10039;CYRILLIC CAPITAL LETTER HA ++0426;afii10040;CYRILLIC CAPITAL LETTER TSE ++0427;afii10041;CYRILLIC CAPITAL LETTER CHE ++0428;afii10042;CYRILLIC CAPITAL LETTER SHA ++0429;afii10043;CYRILLIC CAPITAL LETTER SHCHA ++042A;afii10044;CYRILLIC CAPITAL LETTER HARD SIGN ++042B;afii10045;CYRILLIC CAPITAL LETTER YERU ++042C;afii10046;CYRILLIC CAPITAL LETTER SOFT SIGN ++042D;afii10047;CYRILLIC CAPITAL LETTER E ++042E;afii10048;CYRILLIC CAPITAL LETTER YU ++042F;afii10049;CYRILLIC CAPITAL LETTER YA ++0490;afii10050;CYRILLIC CAPITAL LETTER GHE WITH UPTURN ++0402;afii10051;CYRILLIC CAPITAL LETTER DJE ++0403;afii10052;CYRILLIC CAPITAL LETTER GJE ++0404;afii10053;CYRILLIC CAPITAL LETTER UKRAINIAN IE ++0405;afii10054;CYRILLIC CAPITAL LETTER DZE ++0406;afii10055;CYRILLIC CAPITAL LETTER BYELORUSSIAN-UKRAINIAN I ++0407;afii10056;CYRILLIC CAPITAL LETTER YI ++0408;afii10057;CYRILLIC CAPITAL LETTER JE ++0409;afii10058;CYRILLIC CAPITAL LETTER LJE ++040A;afii10059;CYRILLIC CAPITAL LETTER NJE ++040B;afii10060;CYRILLIC CAPITAL LETTER TSHE ++040C;afii10061;CYRILLIC CAPITAL LETTER KJE ++040E;afii10062;CYRILLIC CAPITAL LETTER SHORT U ++0430;afii10065;CYRILLIC SMALL LETTER A ++0431;afii10066;CYRILLIC SMALL LETTER BE ++0432;afii10067;CYRILLIC SMALL LETTER VE ++0433;afii10068;CYRILLIC SMALL LETTER GHE ++0434;afii10069;CYRILLIC SMALL LETTER DE ++0435;afii10070;CYRILLIC SMALL LETTER IE ++0451;afii10071;CYRILLIC SMALL LETTER IO ++0436;afii10072;CYRILLIC SMALL LETTER ZHE ++0437;afii10073;CYRILLIC SMALL LETTER ZE ++0438;afii10074;CYRILLIC SMALL LETTER I ++0439;afii10075;CYRILLIC SMALL LETTER SHORT I ++043A;afii10076;CYRILLIC SMALL LETTER KA ++043B;afii10077;CYRILLIC SMALL LETTER EL ++043C;afii10078;CYRILLIC SMALL LETTER EM ++043D;afii10079;CYRILLIC SMALL LETTER EN ++043E;afii10080;CYRILLIC SMALL LETTER O ++043F;afii10081;CYRILLIC SMALL LETTER PE ++0440;afii10082;CYRILLIC SMALL LETTER ER ++0441;afii10083;CYRILLIC SMALL LETTER ES ++0442;afii10084;CYRILLIC SMALL LETTER TE ++0443;afii10085;CYRILLIC SMALL LETTER U ++0444;afii10086;CYRILLIC SMALL LETTER EF ++0445;afii10087;CYRILLIC SMALL LETTER HA ++0446;afii10088;CYRILLIC SMALL LETTER TSE ++0447;afii10089;CYRILLIC SMALL LETTER CHE ++0448;afii10090;CYRILLIC SMALL LETTER SHA ++0449;afii10091;CYRILLIC SMALL LETTER SHCHA ++044A;afii10092;CYRILLIC SMALL LETTER HARD SIGN ++044B;afii10093;CYRILLIC SMALL LETTER YERU ++044C;afii10094;CYRILLIC SMALL LETTER SOFT SIGN ++044D;afii10095;CYRILLIC SMALL LETTER E ++044E;afii10096;CYRILLIC SMALL LETTER YU ++044F;afii10097;CYRILLIC SMALL LETTER YA ++0491;afii10098;CYRILLIC SMALL LETTER GHE WITH UPTURN ++0452;afii10099;CYRILLIC SMALL LETTER DJE ++0453;afii10100;CYRILLIC SMALL LETTER GJE ++0454;afii10101;CYRILLIC SMALL LETTER UKRAINIAN IE ++0455;afii10102;CYRILLIC SMALL LETTER DZE ++0456;afii10103;CYRILLIC SMALL LETTER BYELORUSSIAN-UKRAINIAN I ++0457;afii10104;CYRILLIC SMALL LETTER YI ++0458;afii10105;CYRILLIC SMALL LETTER JE ++0459;afii10106;CYRILLIC SMALL LETTER LJE ++045A;afii10107;CYRILLIC SMALL LETTER NJE ++045B;afii10108;CYRILLIC SMALL LETTER TSHE ++045C;afii10109;CYRILLIC SMALL LETTER KJE ++045E;afii10110;CYRILLIC SMALL LETTER SHORT U ++040F;afii10145;CYRILLIC CAPITAL LETTER DZHE ++0462;afii10146;CYRILLIC CAPITAL LETTER YAT ++0472;afii10147;CYRILLIC CAPITAL LETTER FITA ++0474;afii10148;CYRILLIC CAPITAL LETTER IZHITSA ++045F;afii10193;CYRILLIC SMALL LETTER DZHE ++0463;afii10194;CYRILLIC SMALL LETTER YAT ++0473;afii10195;CYRILLIC SMALL LETTER FITA ++0475;afii10196;CYRILLIC SMALL LETTER IZHITSA ++04D9;afii10846;CYRILLIC SMALL LETTER SCHWA ++200E;afii299;LEFT-TO-RIGHT MARK ++200F;afii300;RIGHT-TO-LEFT MARK ++200D;afii301;ZERO WIDTH JOINER ++066A;afii57381;ARABIC PERCENT SIGN ++060C;afii57388;ARABIC COMMA ++0660;afii57392;ARABIC-INDIC DIGIT ZERO ++0661;afii57393;ARABIC-INDIC DIGIT ONE ++0662;afii57394;ARABIC-INDIC DIGIT TWO ++0663;afii57395;ARABIC-INDIC DIGIT THREE ++0664;afii57396;ARABIC-INDIC DIGIT FOUR ++0665;afii57397;ARABIC-INDIC DIGIT FIVE ++0666;afii57398;ARABIC-INDIC DIGIT SIX ++0667;afii57399;ARABIC-INDIC DIGIT SEVEN ++0668;afii57400;ARABIC-INDIC DIGIT EIGHT ++0669;afii57401;ARABIC-INDIC DIGIT NINE ++061B;afii57403;ARABIC SEMICOLON ++061F;afii57407;ARABIC QUESTION MARK ++0621;afii57409;ARABIC LETTER HAMZA ++0622;afii57410;ARABIC LETTER ALEF WITH MADDA ABOVE ++0623;afii57411;ARABIC LETTER ALEF WITH HAMZA ABOVE ++0624;afii57412;ARABIC LETTER WAW WITH HAMZA ABOVE ++0625;afii57413;ARABIC LETTER ALEF WITH HAMZA BELOW ++0626;afii57414;ARABIC LETTER YEH WITH HAMZA ABOVE ++0627;afii57415;ARABIC LETTER ALEF ++0628;afii57416;ARABIC LETTER BEH ++0629;afii57417;ARABIC LETTER TEH MARBUTA ++062A;afii57418;ARABIC LETTER TEH ++062B;afii57419;ARABIC LETTER THEH ++062C;afii57420;ARABIC LETTER JEEM ++062D;afii57421;ARABIC LETTER HAH ++062E;afii57422;ARABIC LETTER KHAH ++062F;afii57423;ARABIC LETTER DAL ++0630;afii57424;ARABIC LETTER THAL ++0631;afii57425;ARABIC LETTER REH ++0632;afii57426;ARABIC LETTER ZAIN ++0633;afii57427;ARABIC LETTER SEEN ++0634;afii57428;ARABIC LETTER SHEEN ++0635;afii57429;ARABIC LETTER SAD ++0636;afii57430;ARABIC LETTER DAD ++0637;afii57431;ARABIC LETTER TAH ++0638;afii57432;ARABIC LETTER ZAH ++0639;afii57433;ARABIC LETTER AIN ++063A;afii57434;ARABIC LETTER GHAIN ++0640;afii57440;ARABIC TATWEEL ++0641;afii57441;ARABIC LETTER FEH ++0642;afii57442;ARABIC LETTER QAF ++0643;afii57443;ARABIC LETTER KAF ++0644;afii57444;ARABIC LETTER LAM ++0645;afii57445;ARABIC LETTER MEEM ++0646;afii57446;ARABIC LETTER NOON ++0648;afii57448;ARABIC LETTER WAW ++0649;afii57449;ARABIC LETTER ALEF MAKSURA ++064A;afii57450;ARABIC LETTER YEH ++064B;afii57451;ARABIC FATHATAN ++064C;afii57452;ARABIC DAMMATAN ++064D;afii57453;ARABIC KASRATAN ++064E;afii57454;ARABIC FATHA ++064F;afii57455;ARABIC DAMMA ++0650;afii57456;ARABIC KASRA ++0651;afii57457;ARABIC SHADDA ++0652;afii57458;ARABIC SUKUN ++0647;afii57470;ARABIC LETTER HEH ++06A4;afii57505;ARABIC LETTER VEH ++067E;afii57506;ARABIC LETTER PEH ++0686;afii57507;ARABIC LETTER TCHEH ++0698;afii57508;ARABIC LETTER JEH ++06AF;afii57509;ARABIC LETTER GAF ++0679;afii57511;ARABIC LETTER TTEH ++0688;afii57512;ARABIC LETTER DDAL ++0691;afii57513;ARABIC LETTER RREH ++06BA;afii57514;ARABIC LETTER NOON GHUNNA ++06D2;afii57519;ARABIC LETTER YEH BARREE ++06D5;afii57534;ARABIC LETTER AE ++20AA;afii57636;NEW SHEQEL SIGN ++05BE;afii57645;HEBREW PUNCTUATION MAQAF ++05C3;afii57658;HEBREW PUNCTUATION SOF PASUQ ++05D0;afii57664;HEBREW LETTER ALEF ++05D1;afii57665;HEBREW LETTER BET ++05D2;afii57666;HEBREW LETTER GIMEL ++05D3;afii57667;HEBREW LETTER DALET ++05D4;afii57668;HEBREW LETTER HE ++05D5;afii57669;HEBREW LETTER VAV ++05D6;afii57670;HEBREW LETTER ZAYIN ++05D7;afii57671;HEBREW LETTER HET ++05D8;afii57672;HEBREW LETTER TET ++05D9;afii57673;HEBREW LETTER YOD ++05DA;afii57674;HEBREW LETTER FINAL KAF ++05DB;afii57675;HEBREW LETTER KAF ++05DC;afii57676;HEBREW LETTER LAMED ++05DD;afii57677;HEBREW LETTER FINAL MEM ++05DE;afii57678;HEBREW LETTER MEM ++05DF;afii57679;HEBREW LETTER FINAL NUN ++05E0;afii57680;HEBREW LETTER NUN ++05E1;afii57681;HEBREW LETTER SAMEKH ++05E2;afii57682;HEBREW LETTER AYIN ++05E3;afii57683;HEBREW LETTER FINAL PE ++05E4;afii57684;HEBREW LETTER PE ++05E5;afii57685;HEBREW LETTER FINAL TSADI ++05E6;afii57686;HEBREW LETTER TSADI ++05E7;afii57687;HEBREW LETTER QOF ++05E8;afii57688;HEBREW LETTER RESH ++05E9;afii57689;HEBREW LETTER SHIN ++05EA;afii57690;HEBREW LETTER TAV ++05F0;afii57716;HEBREW LIGATURE YIDDISH DOUBLE VAV ++05F1;afii57717;HEBREW LIGATURE YIDDISH VAV YOD ++05F2;afii57718;HEBREW LIGATURE YIDDISH DOUBLE YOD ++05B4;afii57793;HEBREW POINT HIRIQ ++05B5;afii57794;HEBREW POINT TSERE ++05B6;afii57795;HEBREW POINT SEGOL ++05BB;afii57796;HEBREW POINT QUBUTS ++05B8;afii57797;HEBREW POINT QAMATS ++05B7;afii57798;HEBREW POINT PATAH ++05B0;afii57799;HEBREW POINT SHEVA ++05B2;afii57800;HEBREW POINT HATAF PATAH ++05B1;afii57801;HEBREW POINT HATAF SEGOL ++05B3;afii57802;HEBREW POINT HATAF QAMATS ++05C2;afii57803;HEBREW POINT SIN DOT ++05C1;afii57804;HEBREW POINT SHIN DOT ++05B9;afii57806;HEBREW POINT HOLAM ++05BC;afii57807;HEBREW POINT DAGESH OR MAPIQ ++05BD;afii57839;HEBREW POINT METEG ++05BF;afii57841;HEBREW POINT RAFE ++05C0;afii57842;HEBREW PUNCTUATION PASEQ ++02BC;afii57929;MODIFIER LETTER APOSTROPHE ++2105;afii61248;CARE OF ++2113;afii61289;SCRIPT SMALL L ++2116;afii61352;NUMERO SIGN ++202C;afii61573;POP DIRECTIONAL FORMATTING ++202D;afii61574;LEFT-TO-RIGHT OVERRIDE ++202E;afii61575;RIGHT-TO-LEFT OVERRIDE ++200C;afii61664;ZERO WIDTH NON-JOINER ++066D;afii63167;ARABIC FIVE POINTED STAR ++02BD;afii64937;MODIFIER LETTER REVERSED COMMA ++00E0;agrave;LATIN SMALL LETTER A WITH GRAVE ++2135;aleph;ALEF SYMBOL ++03B1;alpha;GREEK SMALL LETTER ALPHA ++03AC;alphatonos;GREEK SMALL LETTER ALPHA WITH TONOS ++0101;amacron;LATIN SMALL LETTER A WITH MACRON ++0026;ampersand;AMPERSAND ++2220;angle;ANGLE ++2329;angleleft;LEFT-POINTING ANGLE BRACKET ++232A;angleright;RIGHT-POINTING ANGLE BRACKET ++0387;anoteleia;GREEK ANO TELEIA ++0105;aogonek;LATIN SMALL LETTER A WITH OGONEK ++2248;approxequal;ALMOST EQUAL TO ++00E5;aring;LATIN SMALL LETTER A WITH RING ABOVE ++01FB;aringacute;LATIN SMALL LETTER A WITH RING ABOVE AND ACUTE ++2194;arrowboth;LEFT RIGHT ARROW ++21D4;arrowdblboth;LEFT RIGHT DOUBLE ARROW ++21D3;arrowdbldown;DOWNWARDS DOUBLE ARROW ++21D0;arrowdblleft;LEFTWARDS DOUBLE ARROW ++21D2;arrowdblright;RIGHTWARDS DOUBLE ARROW ++21D1;arrowdblup;UPWARDS DOUBLE ARROW ++2193;arrowdown;DOWNWARDS ARROW ++2190;arrowleft;LEFTWARDS ARROW ++2192;arrowright;RIGHTWARDS ARROW ++2191;arrowup;UPWARDS ARROW ++2195;arrowupdn;UP DOWN ARROW ++21A8;arrowupdnbse;UP DOWN ARROW WITH BASE ++005E;asciicircum;CIRCUMFLEX ACCENT ++007E;asciitilde;TILDE ++002A;asterisk;ASTERISK ++2217;asteriskmath;ASTERISK OPERATOR ++0040;at;COMMERCIAL AT ++00E3;atilde;LATIN SMALL LETTER A WITH TILDE ++0062;b;LATIN SMALL LETTER B ++005C;backslash;REVERSE SOLIDUS ++007C;bar;VERTICAL LINE ++03B2;beta;GREEK SMALL LETTER BETA ++2588;block;FULL BLOCK ++007B;braceleft;LEFT CURLY BRACKET ++007D;braceright;RIGHT CURLY BRACKET ++005B;bracketleft;LEFT SQUARE BRACKET ++005D;bracketright;RIGHT SQUARE BRACKET ++02D8;breve;BREVE ++00A6;brokenbar;BROKEN BAR ++2022;bullet;BULLET ++0063;c;LATIN SMALL LETTER C ++0107;cacute;LATIN SMALL LETTER C WITH ACUTE ++02C7;caron;CARON ++21B5;carriagereturn;DOWNWARDS ARROW WITH CORNER LEFTWARDS ++010D;ccaron;LATIN SMALL LETTER C WITH CARON ++00E7;ccedilla;LATIN SMALL LETTER C WITH CEDILLA ++0109;ccircumflex;LATIN SMALL LETTER C WITH CIRCUMFLEX ++010B;cdotaccent;LATIN SMALL LETTER C WITH DOT ABOVE ++00B8;cedilla;CEDILLA ++00A2;cent;CENT SIGN ++03C7;chi;GREEK SMALL LETTER CHI ++25CB;circle;WHITE CIRCLE ++2297;circlemultiply;CIRCLED TIMES ++2295;circleplus;CIRCLED PLUS ++02C6;circumflex;MODIFIER LETTER CIRCUMFLEX ACCENT ++2663;club;BLACK CLUB SUIT ++003A;colon;COLON ++20A1;colonmonetary;COLON SIGN ++002C;comma;COMMA ++2245;congruent;APPROXIMATELY EQUAL TO ++00A9;copyright;COPYRIGHT SIGN ++00A4;currency;CURRENCY SIGN ++0064;d;LATIN SMALL LETTER D ++2020;dagger;DAGGER ++2021;daggerdbl;DOUBLE DAGGER ++010F;dcaron;LATIN SMALL LETTER D WITH CARON ++0111;dcroat;LATIN SMALL LETTER D WITH STROKE ++00B0;degree;DEGREE SIGN ++03B4;delta;GREEK SMALL LETTER DELTA ++2666;diamond;BLACK DIAMOND SUIT ++00A8;dieresis;DIAERESIS ++0385;dieresistonos;GREEK DIALYTIKA TONOS ++00F7;divide;DIVISION SIGN ++2593;dkshade;DARK SHADE ++2584;dnblock;LOWER HALF BLOCK ++0024;dollar;DOLLAR SIGN ++20AB;dong;DONG SIGN ++02D9;dotaccent;DOT ABOVE ++0323;dotbelowcomb;COMBINING DOT BELOW ++0131;dotlessi;LATIN SMALL LETTER DOTLESS I ++22C5;dotmath;DOT OPERATOR ++0065;e;LATIN SMALL LETTER E ++00E9;eacute;LATIN SMALL LETTER E WITH ACUTE ++0115;ebreve;LATIN SMALL LETTER E WITH BREVE ++011B;ecaron;LATIN SMALL LETTER E WITH CARON ++00EA;ecircumflex;LATIN SMALL LETTER E WITH CIRCUMFLEX ++00EB;edieresis;LATIN SMALL LETTER E WITH DIAERESIS ++0117;edotaccent;LATIN SMALL LETTER E WITH DOT ABOVE ++00E8;egrave;LATIN SMALL LETTER E WITH GRAVE ++0038;eight;DIGIT EIGHT ++2208;element;ELEMENT OF ++2026;ellipsis;HORIZONTAL ELLIPSIS ++0113;emacron;LATIN SMALL LETTER E WITH MACRON ++2014;emdash;EM DASH ++2205;emptyset;EMPTY SET ++2013;endash;EN DASH ++014B;eng;LATIN SMALL LETTER ENG ++0119;eogonek;LATIN SMALL LETTER E WITH OGONEK ++03B5;epsilon;GREEK SMALL LETTER EPSILON ++03AD;epsilontonos;GREEK SMALL LETTER EPSILON WITH TONOS ++003D;equal;EQUALS SIGN ++2261;equivalence;IDENTICAL TO ++212E;estimated;ESTIMATED SYMBOL ++03B7;eta;GREEK SMALL LETTER ETA ++03AE;etatonos;GREEK SMALL LETTER ETA WITH TONOS ++00F0;eth;LATIN SMALL LETTER ETH ++0021;exclam;EXCLAMATION MARK ++203C;exclamdbl;DOUBLE EXCLAMATION MARK ++00A1;exclamdown;INVERTED EXCLAMATION MARK ++2203;existential;THERE EXISTS ++0066;f;LATIN SMALL LETTER F ++2640;female;FEMALE SIGN ++2012;figuredash;FIGURE DASH ++25A0;filledbox;BLACK SQUARE ++25AC;filledrect;BLACK RECTANGLE ++0035;five;DIGIT FIVE ++215D;fiveeighths;VULGAR FRACTION FIVE EIGHTHS ++0192;florin;LATIN SMALL LETTER F WITH HOOK ++0034;four;DIGIT FOUR ++2044;fraction;FRACTION SLASH ++20A3;franc;FRENCH FRANC SIGN ++0067;g;LATIN SMALL LETTER G ++03B3;gamma;GREEK SMALL LETTER GAMMA ++011F;gbreve;LATIN SMALL LETTER G WITH BREVE ++01E7;gcaron;LATIN SMALL LETTER G WITH CARON ++011D;gcircumflex;LATIN SMALL LETTER G WITH CIRCUMFLEX ++0123;gcommaaccent;LATIN SMALL LETTER G WITH CEDILLA ++0121;gdotaccent;LATIN SMALL LETTER G WITH DOT ABOVE ++00DF;germandbls;LATIN SMALL LETTER SHARP S ++2207;gradient;NABLA ++0060;grave;GRAVE ACCENT ++0300;gravecomb;COMBINING GRAVE ACCENT ++003E;greater;GREATER-THAN SIGN ++2265;greaterequal;GREATER-THAN OR EQUAL TO ++00AB;guillemotleft;LEFT-POINTING DOUBLE ANGLE QUOTATION MARK ++00BB;guillemotright;RIGHT-POINTING DOUBLE ANGLE QUOTATION MARK ++2039;guilsinglleft;SINGLE LEFT-POINTING ANGLE QUOTATION MARK ++203A;guilsinglright;SINGLE RIGHT-POINTING ANGLE QUOTATION MARK ++0068;h;LATIN SMALL LETTER H ++0127;hbar;LATIN SMALL LETTER H WITH STROKE ++0125;hcircumflex;LATIN SMALL LETTER H WITH CIRCUMFLEX ++2665;heart;BLACK HEART SUIT ++0309;hookabovecomb;COMBINING HOOK ABOVE ++2302;house;HOUSE ++02DD;hungarumlaut;DOUBLE ACUTE ACCENT ++002D;hyphen;HYPHEN-MINUS ++0069;i;LATIN SMALL LETTER I ++00ED;iacute;LATIN SMALL LETTER I WITH ACUTE ++012D;ibreve;LATIN SMALL LETTER I WITH BREVE ++00EE;icircumflex;LATIN SMALL LETTER I WITH CIRCUMFLEX ++00EF;idieresis;LATIN SMALL LETTER I WITH DIAERESIS ++00EC;igrave;LATIN SMALL LETTER I WITH GRAVE ++0133;ij;LATIN SMALL LIGATURE IJ ++012B;imacron;LATIN SMALL LETTER I WITH MACRON ++221E;infinity;INFINITY ++222B;integral;INTEGRAL ++2321;integralbt;BOTTOM HALF INTEGRAL ++2320;integraltp;TOP HALF INTEGRAL ++2229;intersection;INTERSECTION ++25D8;invbullet;INVERSE BULLET ++25D9;invcircle;INVERSE WHITE CIRCLE ++263B;invsmileface;BLACK SMILING FACE ++012F;iogonek;LATIN SMALL LETTER I WITH OGONEK ++03B9;iota;GREEK SMALL LETTER IOTA ++03CA;iotadieresis;GREEK SMALL LETTER IOTA WITH DIALYTIKA ++0390;iotadieresistonos;GREEK SMALL LETTER IOTA WITH DIALYTIKA AND TONOS ++03AF;iotatonos;GREEK SMALL LETTER IOTA WITH TONOS ++0129;itilde;LATIN SMALL LETTER I WITH TILDE ++006A;j;LATIN SMALL LETTER J ++0135;jcircumflex;LATIN SMALL LETTER J WITH CIRCUMFLEX ++006B;k;LATIN SMALL LETTER K ++03BA;kappa;GREEK SMALL LETTER KAPPA ++0137;kcommaaccent;LATIN SMALL LETTER K WITH CEDILLA ++0138;kgreenlandic;LATIN SMALL LETTER KRA ++006C;l;LATIN SMALL LETTER L ++013A;lacute;LATIN SMALL LETTER L WITH ACUTE ++03BB;lambda;GREEK SMALL LETTER LAMDA ++013E;lcaron;LATIN SMALL LETTER L WITH CARON ++013C;lcommaaccent;LATIN SMALL LETTER L WITH CEDILLA ++0140;ldot;LATIN SMALL LETTER L WITH MIDDLE DOT ++003C;less;LESS-THAN SIGN ++2264;lessequal;LESS-THAN OR EQUAL TO ++258C;lfblock;LEFT HALF BLOCK ++20A4;lira;LIRA SIGN ++2227;logicaland;LOGICAL AND ++00AC;logicalnot;NOT SIGN ++2228;logicalor;LOGICAL OR ++017F;longs;LATIN SMALL LETTER LONG S ++25CA;lozenge;LOZENGE ++0142;lslash;LATIN SMALL LETTER L WITH STROKE ++2591;ltshade;LIGHT SHADE ++006D;m;LATIN SMALL LETTER M ++00AF;macron;MACRON ++2642;male;MALE SIGN ++2212;minus;MINUS SIGN ++2032;minute;PRIME ++03BC;mu;GREEK SMALL LETTER MU ++00D7;multiply;MULTIPLICATION SIGN ++266A;musicalnote;EIGHTH NOTE ++266B;musicalnotedbl;BEAMED EIGHTH NOTES ++006E;n;LATIN SMALL LETTER N ++0144;nacute;LATIN SMALL LETTER N WITH ACUTE ++0149;napostrophe;LATIN SMALL LETTER N PRECEDED BY APOSTROPHE ++0148;ncaron;LATIN SMALL LETTER N WITH CARON ++0146;ncommaaccent;LATIN SMALL LETTER N WITH CEDILLA ++0039;nine;DIGIT NINE ++2209;notelement;NOT AN ELEMENT OF ++2260;notequal;NOT EQUAL TO ++2284;notsubset;NOT A SUBSET OF ++00F1;ntilde;LATIN SMALL LETTER N WITH TILDE ++03BD;nu;GREEK SMALL LETTER NU ++0023;numbersign;NUMBER SIGN ++006F;o;LATIN SMALL LETTER O ++00F3;oacute;LATIN SMALL LETTER O WITH ACUTE ++014F;obreve;LATIN SMALL LETTER O WITH BREVE ++00F4;ocircumflex;LATIN SMALL LETTER O WITH CIRCUMFLEX ++00F6;odieresis;LATIN SMALL LETTER O WITH DIAERESIS ++0153;oe;LATIN SMALL LIGATURE OE ++02DB;ogonek;OGONEK ++00F2;ograve;LATIN SMALL LETTER O WITH GRAVE ++01A1;ohorn;LATIN SMALL LETTER O WITH HORN ++0151;ohungarumlaut;LATIN SMALL LETTER O WITH DOUBLE ACUTE ++014D;omacron;LATIN SMALL LETTER O WITH MACRON ++03C9;omega;GREEK SMALL LETTER OMEGA ++03D6;omega1;GREEK PI SYMBOL ++03CE;omegatonos;GREEK SMALL LETTER OMEGA WITH TONOS ++03BF;omicron;GREEK SMALL LETTER OMICRON ++03CC;omicrontonos;GREEK SMALL LETTER OMICRON WITH TONOS ++0031;one;DIGIT ONE ++2024;onedotenleader;ONE DOT LEADER ++215B;oneeighth;VULGAR FRACTION ONE EIGHTH ++00BD;onehalf;VULGAR FRACTION ONE HALF ++00BC;onequarter;VULGAR FRACTION ONE QUARTER ++2153;onethird;VULGAR FRACTION ONE THIRD ++25E6;openbullet;WHITE BULLET ++00AA;ordfeminine;FEMININE ORDINAL INDICATOR ++00BA;ordmasculine;MASCULINE ORDINAL INDICATOR ++221F;orthogonal;RIGHT ANGLE ++00F8;oslash;LATIN SMALL LETTER O WITH STROKE ++01FF;oslashacute;LATIN SMALL LETTER O WITH STROKE AND ACUTE ++00F5;otilde;LATIN SMALL LETTER O WITH TILDE ++0070;p;LATIN SMALL LETTER P ++00B6;paragraph;PILCROW SIGN ++0028;parenleft;LEFT PARENTHESIS ++0029;parenright;RIGHT PARENTHESIS ++2202;partialdiff;PARTIAL DIFFERENTIAL ++0025;percent;PERCENT SIGN ++002E;period;FULL STOP ++00B7;periodcentered;MIDDLE DOT ++22A5;perpendicular;UP TACK ++2030;perthousand;PER MILLE SIGN ++20A7;peseta;PESETA SIGN ++03C6;phi;GREEK SMALL LETTER PHI ++03D5;phi1;GREEK PHI SYMBOL ++03C0;pi;GREEK SMALL LETTER PI ++002B;plus;PLUS SIGN ++00B1;plusminus;PLUS-MINUS SIGN ++211E;prescription;PRESCRIPTION TAKE ++220F;product;N-ARY PRODUCT ++2282;propersubset;SUBSET OF ++2283;propersuperset;SUPERSET OF ++221D;proportional;PROPORTIONAL TO ++03C8;psi;GREEK SMALL LETTER PSI ++0071;q;LATIN SMALL LETTER Q ++003F;question;QUESTION MARK ++00BF;questiondown;INVERTED QUESTION MARK ++0022;quotedbl;QUOTATION MARK ++201E;quotedblbase;DOUBLE LOW-9 QUOTATION MARK ++201C;quotedblleft;LEFT DOUBLE QUOTATION MARK ++201D;quotedblright;RIGHT DOUBLE QUOTATION MARK ++2018;quoteleft;LEFT SINGLE QUOTATION MARK ++201B;quotereversed;SINGLE HIGH-REVERSED-9 QUOTATION MARK ++2019;quoteright;RIGHT SINGLE QUOTATION MARK ++201A;quotesinglbase;SINGLE LOW-9 QUOTATION MARK ++0027;quotesingle;APOSTROPHE ++0072;r;LATIN SMALL LETTER R ++0155;racute;LATIN SMALL LETTER R WITH ACUTE ++221A;radical;SQUARE ROOT ++0159;rcaron;LATIN SMALL LETTER R WITH CARON ++0157;rcommaaccent;LATIN SMALL LETTER R WITH CEDILLA ++2286;reflexsubset;SUBSET OF OR EQUAL TO ++2287;reflexsuperset;SUPERSET OF OR EQUAL TO ++00AE;registered;REGISTERED SIGN ++2310;revlogicalnot;REVERSED NOT SIGN ++03C1;rho;GREEK SMALL LETTER RHO ++02DA;ring;RING ABOVE ++2590;rtblock;RIGHT HALF BLOCK ++0073;s;LATIN SMALL LETTER S ++015B;sacute;LATIN SMALL LETTER S WITH ACUTE ++0161;scaron;LATIN SMALL LETTER S WITH CARON ++015F;scedilla;LATIN SMALL LETTER S WITH CEDILLA ++015D;scircumflex;LATIN SMALL LETTER S WITH CIRCUMFLEX ++0219;scommaaccent;LATIN SMALL LETTER S WITH COMMA BELOW ++2033;second;DOUBLE PRIME ++00A7;section;SECTION SIGN ++003B;semicolon;SEMICOLON ++0037;seven;DIGIT SEVEN ++215E;seveneighths;VULGAR FRACTION SEVEN EIGHTHS ++2592;shade;MEDIUM SHADE ++03C3;sigma;GREEK SMALL LETTER SIGMA ++03C2;sigma1;GREEK SMALL LETTER FINAL SIGMA ++223C;similar;TILDE OPERATOR ++0036;six;DIGIT SIX ++002F;slash;SOLIDUS ++263A;smileface;WHITE SMILING FACE ++0020;space;SPACE ++2660;spade;BLACK SPADE SUIT ++00A3;sterling;POUND SIGN ++220B;suchthat;CONTAINS AS MEMBER ++2211;summation;N-ARY SUMMATION ++263C;sun;WHITE SUN WITH RAYS ++0074;t;LATIN SMALL LETTER T ++03C4;tau;GREEK SMALL LETTER TAU ++0167;tbar;LATIN SMALL LETTER T WITH STROKE ++0165;tcaron;LATIN SMALL LETTER T WITH CARON ++0163;tcommaaccent;LATIN SMALL LETTER T WITH CEDILLA ++2234;therefore;THEREFORE ++03B8;theta;GREEK SMALL LETTER THETA ++03D1;theta1;GREEK THETA SYMBOL ++00FE;thorn;LATIN SMALL LETTER THORN ++0033;three;DIGIT THREE ++215C;threeeighths;VULGAR FRACTION THREE EIGHTHS ++00BE;threequarters;VULGAR FRACTION THREE QUARTERS ++02DC;tilde;SMALL TILDE ++0303;tildecomb;COMBINING TILDE ++0384;tonos;GREEK TONOS ++2122;trademark;TRADE MARK SIGN ++25BC;triagdn;BLACK DOWN-POINTING TRIANGLE ++25C4;triaglf;BLACK LEFT-POINTING POINTER ++25BA;triagrt;BLACK RIGHT-POINTING POINTER ++25B2;triagup;BLACK UP-POINTING TRIANGLE ++0032;two;DIGIT TWO ++2025;twodotenleader;TWO DOT LEADER ++2154;twothirds;VULGAR FRACTION TWO THIRDS ++0075;u;LATIN SMALL LETTER U ++00FA;uacute;LATIN SMALL LETTER U WITH ACUTE ++016D;ubreve;LATIN SMALL LETTER U WITH BREVE ++00FB;ucircumflex;LATIN SMALL LETTER U WITH CIRCUMFLEX ++00FC;udieresis;LATIN SMALL LETTER U WITH DIAERESIS ++00F9;ugrave;LATIN SMALL LETTER U WITH GRAVE ++01B0;uhorn;LATIN SMALL LETTER U WITH HORN ++0171;uhungarumlaut;LATIN SMALL LETTER U WITH DOUBLE ACUTE ++016B;umacron;LATIN SMALL LETTER U WITH MACRON ++005F;underscore;LOW LINE ++2017;underscoredbl;DOUBLE LOW LINE ++222A;union;UNION ++2200;universal;FOR ALL ++0173;uogonek;LATIN SMALL LETTER U WITH OGONEK ++2580;upblock;UPPER HALF BLOCK ++03C5;upsilon;GREEK SMALL LETTER UPSILON ++03CB;upsilondieresis;GREEK SMALL LETTER UPSILON WITH DIALYTIKA ++03B0;upsilondieresistonos;GREEK SMALL LETTER UPSILON WITH DIALYTIKA AND TONOS ++03CD;upsilontonos;GREEK SMALL LETTER UPSILON WITH TONOS ++016F;uring;LATIN SMALL LETTER U WITH RING ABOVE ++0169;utilde;LATIN SMALL LETTER U WITH TILDE ++0076;v;LATIN SMALL LETTER V ++0077;w;LATIN SMALL LETTER W ++1E83;wacute;LATIN SMALL LETTER W WITH ACUTE ++0175;wcircumflex;LATIN SMALL LETTER W WITH CIRCUMFLEX ++1E85;wdieresis;LATIN SMALL LETTER W WITH DIAERESIS ++2118;weierstrass;SCRIPT CAPITAL P ++1E81;wgrave;LATIN SMALL LETTER W WITH GRAVE ++0078;x;LATIN SMALL LETTER X ++03BE;xi;GREEK SMALL LETTER XI ++0079;y;LATIN SMALL LETTER Y ++00FD;yacute;LATIN SMALL LETTER Y WITH ACUTE ++0177;ycircumflex;LATIN SMALL LETTER Y WITH CIRCUMFLEX ++00FF;ydieresis;LATIN SMALL LETTER Y WITH DIAERESIS ++00A5;yen;YEN SIGN ++1EF3;ygrave;LATIN SMALL LETTER Y WITH GRAVE ++007A;z;LATIN SMALL LETTER Z ++017A;zacute;LATIN SMALL LETTER Z WITH ACUTE ++017E;zcaron;LATIN SMALL LETTER Z WITH CARON ++017C;zdotaccent;LATIN SMALL LETTER Z WITH DOT ABOVE ++0030;zero;DIGIT ZERO ++03B6;zeta;GREEK SMALL LETTER ZETA +--- term/PostScript/koi8r.ps ++++ term/PostScript/koi8r.ps 2007-11-05 19:21:56.000000000 +0100 +@@ -1,4 +1,5 @@ +-% encoding for code page koi8r ++% ++% encoding for code page koi8r (8-bit Russian) + % version 1.0: - Mainly letters are mapped. The following positions + % (JFi) are left blank (undefined): + % -- first 32 positions, +--- term/PostScript/unicode_big.map ++++ term/PostScript/unicode_big.map 2007-11-11 20:22:22.000000000 +0100 +@@ -0,0 +1,863 @@ ++=00 U+0000 ++=01 U+0001 ++=02 U+0002 ++=03 U+0003 ++=04 U+0004 ++=05 U+0005 ++=06 U+0006 ++=07 U+0007 ++=08 U+0008 ++=09 U+0009 ++=0A U+000A ++=0B U+000B ++=0C U+000C ++=0D U+000D ++=0E U+000E ++=0F U+000F ++=10 U+0010 ++=11 U+0011 ++=12 U+0012 ++=13 U+0013 ++=14 U+0014 ++=15 U+0015 ++=16 U+0016 ++=17 U+0017 ++=18 U+0018 ++=19 U+0019 ++=1A U+001A ++=1B U+001B ++=1C U+001C ++=1D U+001D ++=1E U+001E ++=1F U+001F ++!20 U+0020 space ++!21 U+0021 exclam ++!22 U+0022 quotedbl ++!23 U+0023 numbersign ++!24 U+0024 dollar ++!25 U+0025 percent ++!26 U+0026 ampersand ++!27 U+0027 quotesingle ++!28 U+0028 parenleft ++!29 U+0029 parenright ++!2A U+002A asterisk ++!2B U+002B plus ++!2C U+002C comma ++!2D U+002D hyphen ++!2E U+002E period ++!2F U+002F slash ++!30 U+0030 zero ++!31 U+0031 one ++!32 U+0032 two ++!33 U+0033 three ++!34 U+0034 four ++!35 U+0035 five ++!36 U+0036 six ++!37 U+0037 seven ++!38 U+0038 eight ++!39 U+0039 nine ++!3A U+003A colon ++!3B U+003B semicolon ++!3C U+003C less ++!3D U+003D equal ++!3E U+003E greater ++!3F U+003F question ++!40 U+0040 at ++!41 U+0041 A ++!42 U+0042 B ++!43 U+0043 C ++!44 U+0044 D ++!45 U+0045 E ++!46 U+0046 F ++!47 U+0047 G ++!48 U+0048 H ++!49 U+0049 I ++!4A U+004A J ++!4B U+004B K ++!4C U+004C L ++!4D U+004D M ++!4E U+004E N ++!4F U+004F O ++!50 U+0050 P ++!51 U+0051 Q ++!52 U+0052 R ++!53 U+0053 S ++!54 U+0054 T ++!55 U+0055 U ++!56 U+0056 V ++!57 U+0057 W ++!58 U+0058 X ++!59 U+0059 Y ++!5A U+005A Z ++!5B U+005B bracketleft ++!5C U+005C backslash ++!5D U+005D bracketright ++!5E U+005E asciicircum ++!5F U+005F underscore ++!60 U+0060 grave ++!61 U+0061 a ++!62 U+0062 b ++!63 U+0063 c ++!64 U+0064 d ++!65 U+0065 e ++!66 U+0066 f ++!67 U+0067 g ++!68 U+0068 h ++!69 U+0069 i ++!6A U+006A j ++!6B U+006B k ++!6C U+006C l ++!6D U+006D m ++!6E U+006E n ++!6F U+006F o ++!70 U+0070 p ++!71 U+0071 q ++!72 U+0072 r ++!73 U+0073 s ++!74 U+0074 t ++!75 U+0075 u ++!76 U+0076 v ++!77 U+0077 w ++!78 U+0078 x ++!79 U+0079 y ++!7A U+007A z ++!7B U+007B braceleft ++!7C U+007C bar ++!7D U+007D braceright ++!7E U+007E asciitilde ++=A0 U+00A0 ++!A1 U+00A1 exclamdown ++!A2 U+00A2 cent ++!A3 U+00A3 sterling ++!A4 U+00A4 currency ++!A5 U+00A5 yen ++!A6 U+00A6 brokenbar ++!A7 U+00A7 section ++!A8 U+00A8 dieresis ++!A9 U+00A9 copyright ++!AA U+00AA ordfeminine ++!AB U+00AB guillemotleft ++!AC U+00AC logicalnot ++=AD U+00AD ++!AE U+00AE registered ++!AF U+00AF macron ++!B0 U+00B0 degree ++!B1 U+00B1 plusminus ++=B2 U+00B2 ++=B3 U+00B3 ++!B4 U+00B4 acute ++=B5 U+00B5 ++!B6 U+00B6 paragraph ++!B7 U+00B7 periodcentered ++!B8 U+00B8 cedilla ++=B9 U+00B9 ++!BA U+00BA ordmasculine ++!BB U+00BB guillemotright ++!BC U+00BC onequarter ++!BD U+00BD onehalf ++!BE U+00BE threequarters ++!BF U+00BF questiondown ++!C0 U+00C0 Agrave ++!C1 U+00C1 Aacute ++!C2 U+00C2 Acircumflex ++!C3 U+00C3 Atilde ++!C4 U+00C4 Adieresis ++!C5 U+00C5 Aring ++!C6 U+00C6 AE ++!C7 U+00C7 Ccedilla ++!C8 U+00C8 Egrave ++!C9 U+00C9 Eacute ++!CA U+00CA Ecircumflex ++!CB U+00CB Edieresis ++!CC U+00CC Igrave ++!CD U+00CD Iacute ++!CE U+00CE Icircumflex ++!CF U+00CF Idieresis ++!D0 U+00D0 Eth ++!D1 U+00D1 Ntilde ++!D2 U+00D2 Ograve ++!D3 U+00D3 Oacute ++!D4 U+00D4 Ocircumflex ++!D5 U+00D5 Otilde ++!D6 U+00D6 Odieresis ++!D7 U+00D7 multiply ++!D8 U+00D8 Oslash ++!D9 U+00D9 Ugrave ++!DA U+00DA Uacute ++!DB U+00DB Ucircumflex ++!DC U+00DC Udieresis ++!DD U+00DD Yacute ++!DE U+00DE Thorn ++!DF U+00DF germandbls ++!E0 U+00E0 agrave ++!E1 U+00E1 aacute ++!E2 U+00E2 acircumflex ++!E3 U+00E3 atilde ++!E4 U+00E4 adieresis ++!E5 U+00E5 aring ++!E6 U+00E6 ae ++!E7 U+00E7 ccedilla ++!E8 U+00E8 egrave ++!E9 U+00E9 eacute ++!EA U+00EA ecircumflex ++!EB U+00EB edieresis ++!EC U+00EC igrave ++!ED U+00ED iacute ++!EE U+00EE icircumflex ++!EF U+00EF idieresis ++!F0 U+00F0 eth ++!F1 U+00F1 ntilde ++!F2 U+00F2 ograve ++!F3 U+00F3 oacute ++!F4 U+00F4 ocircumflex ++!F5 U+00F5 otilde ++!F6 U+00F6 odieresis ++!F7 U+00F7 divide ++!F8 U+00F8 oslash ++!F9 U+00F9 ugrave ++!FA U+00FA uacute ++!FB U+00FB ucircumflex ++!FC U+00FC udieresis ++!FD U+00FD yacute ++!FE U+00FE thorn ++!FF U+00FF ydieresis ++!100 U+0100 Amacron ++!101 U+0101 amacron ++!102 U+0102 Abreve ++!103 U+0103 abreve ++!104 U+0104 Aogonek ++!105 U+0105 aogonek ++!106 U+0106 Cacute ++!107 U+0107 cacute ++!108 U+0108 Ccircumflex ++!109 U+0109 ccircumflex ++!10a U+010A Cdotaccent ++!10b U+010B cdotaccent ++!10c U+010C Ccaron ++!10d U+010D ccaron ++!10e U+010E Dcaron ++!10f U+010F dcaron ++!110 U+0110 Dcroat ++!111 U+0111 dcroat ++!112 U+0112 Emacron ++!113 U+0113 emacron ++!114 U+0114 Ebreve ++!115 U+0115 ebreve ++!116 U+0116 Edotaccent ++!117 U+0117 edotaccent ++!118 U+0118 Eogonek ++!119 U+0119 eogonek ++!11a U+011A Ecaron ++!11b U+011B ecaron ++!11c U+011C Gcircumflex ++!11d U+011D gcircumflex ++!11e U+011E Gbreve ++!11f U+011F gbreve ++!120 U+0120 Gdotaccent ++!121 U+0121 gdotaccent ++!122 U+0122 Gcommaaccent ++!123 U+0123 gcommaaccent ++!124 U+0124 Hcircumflex ++!125 U+0125 hcircumflex ++!126 U+0126 Hbar ++!127 U+0127 hbar ++!128 U+0128 Itilde ++!129 U+0129 itilde ++!12a U+012A Imacron ++!12b U+012B imacron ++!12c U+012C Ibreve ++!12d U+012D ibreve ++!12e U+012E Iogonek ++!12f U+012F iogonek ++!130 U+0130 Idotaccent ++!131 U+0131 dotlessi ++!132 U+0132 IJ ++!133 U+0133 ij ++!134 U+0134 Jcircumflex ++!135 U+0135 jcircumflex ++!136 U+0136 Kcommaaccent ++!137 U+0137 kcommaaccent ++!138 U+0138 kgreenlandic ++!139 U+0139 Lacute ++!13a U+013A lacute ++!13b U+013B Lcommaaccent ++!13c U+013C lcommaaccent ++!13d U+013D Lcaron ++!13e U+013E lcaron ++!13f U+013F Ldot ++!140 U+0140 ldot ++!141 U+0141 Lslash ++!142 U+0142 lslash ++!143 U+0143 Nacute ++!144 U+0144 nacute ++!145 U+0145 Ncommaaccent ++!146 U+0146 ncommaaccent ++!147 U+0147 Ncaron ++!148 U+0148 ncaron ++!149 U+0149 napostrophe ++!14a U+014A Eng ++!14b U+014B eng ++!14c U+014C Omacron ++!14d U+014D omacron ++!14e U+014E Obreve ++!14f U+014F obreve ++!150 U+0150 Ohungarumlaut ++!151 U+0151 ohungarumlaut ++!152 U+0152 OE ++!153 U+0153 oe ++!154 U+0154 Racute ++!155 U+0155 racute ++!156 U+0156 Rcommaaccent ++!157 U+0157 rcommaaccent ++!158 U+0158 Rcaron ++!159 U+0159 rcaron ++!15a U+015A Sacute ++!15b U+015B sacute ++!15c U+015C Scircumflex ++!15d U+015D scircumflex ++!15e U+015E Scedilla ++!15f U+015F scedilla ++!160 U+0160 Scaron ++!161 U+0161 scaron ++!162 U+0162 Tcommaaccent ++!163 U+0163 tcommaaccent ++!164 U+0164 Tcaron ++!165 U+0165 tcaron ++!166 U+0166 Tbar ++!167 U+0167 tbar ++!168 U+0168 Utilde ++!169 U+0169 utilde ++!16a U+016A Umacron ++!16b U+016B umacron ++!16c U+016C Ubreve ++!16d U+016D ubreve ++!16e U+016E Uring ++!16f U+016F uring ++!170 U+0170 Uhungarumlaut ++!171 U+0171 uhungarumlaut ++!172 U+0172 Uogonek ++!173 U+0173 uogonek ++!174 U+0174 Wcircumflex ++!175 U+0175 wcircumflex ++!176 U+0176 Ycircumflex ++!177 U+0177 ycircumflex ++!178 U+0178 Ydieresis ++!179 U+0179 Zacute ++!17a U+017A zacute ++!17b U+017B Zdotaccent ++!17c U+017C zdotaccent ++!17d U+017D Zcaron ++!17e U+017E zcaron ++!17f U+017F longs ++!180 U+0192 florin ++!181 U+01A0 Ohorn ++!182 U+01A1 ohorn ++!183 U+01AF Uhorn ++!184 U+01B0 uhorn ++!185 U+01E6 Gcaron ++!186 U+01E7 gcaron ++!187 U+01FA Aringacute ++!188 U+01FB aringacute ++!189 U+01FC AEacute ++!18a U+01FD aeacute ++!18b U+01FE Oslashacute ++!18c U+01FF oslashacute ++!18d U+0218 uni0218 ++!18e U+0219 uni0219 ++!18f U+02BC uni02BC ++!190 U+02BD uni02BD ++!191 U+02C6 uni02C6 ++!192 U+02C7 uni02C7 ++!193 U+02D8 uni02D8 ++!194 U+02D9 uni02D9 ++!195 U+02DA uni02DA ++!196 U+02DB uni02DB ++!197 U+02DC uni02DC ++!198 U+02DD uni02DD ++!199 U+0300 uni0300 ++!19a U+0301 uni0301 ++!19b U+0303 uni0303 ++!19c U+0309 uni0309 ++!19d U+0323 uni0323 ++!19e U+0391 uni0391 ++!19f U+0392 uni0392 ++!1a0 U+0393 uni0393 ++!1a1 U+0394 uni0394 ++!1a2 U+0395 uni0395 ++!1a3 U+0396 uni0396 ++!1a4 U+0397 uni0397 ++!1a5 U+0398 uni0398 ++!1a6 U+0399 uni0399 ++!1a7 U+039A uni039A ++!1a8 U+039B uni039B ++!1a9 U+039C uni039C ++!1aa U+039D uni039D ++!1ab U+039E uni039E ++!1ac U+039F uni039F ++!1ad U+03A0 uni03A0 ++!1ae U+03A1 uni03A1 ++!1af U+03A3 uni03A3 ++!1b0 U+03A4 uni03A4 ++!1b1 U+03A5 uni03A5 ++!1b2 U+03A6 uni03A6 ++!1b3 U+03A7 uni03A7 ++!1b4 U+03A8 uni03A8 ++!1b5 U+03A9 uni03A9 ++!1b6 U+03B1 uni03B1 ++!1b7 U+03B2 uni03B2 ++!1b8 U+03B3 uni03B3 ++!1b9 U+03B4 uni03B4 ++!1ba U+03B5 uni03B5 ++!1bb U+03B6 uni03B6 ++!1bc U+03B7 uni03B7 ++!1bd U+03B8 uni03B8 ++!1be U+03B9 uni03B9 ++!1bf U+03BA uni03BA ++!1c0 U+03BB uni03BB ++!1c1 U+03BC uni03BC ++!1c2 U+03BD uni03BD ++!1c3 U+03BE uni03BE ++!1c4 U+03BF uni03BF ++!1c5 U+03C0 uni03C0 ++!1c6 U+03C1 uni03C1 ++!1c7 U+03C2 uni03C2 ++!1c8 U+03C3 uni03C3 ++!1c9 U+03C4 uni03C4 ++!1ca U+03C5 uni03C5 ++!1cb U+03C6 uni03C6 ++!1cc U+03C7 uni03C7 ++!1cd U+03C8 uni03C8 ++!1ce U+03C9 uni03C9 ++!1cf U+03D0 uni03D0 ++!1d0 U+03D1 uni03D1 ++!1d1 U+03D5 uni03D5 ++!1d2 U+03D6 uni03D6 ++!1d3 U+0401 uni0401 ++!1d4 U+0402 uni0402 ++!1d5 U+0403 uni0403 ++!1d6 U+0404 uni0404 ++!1d7 U+0405 uni0405 ++!1d8 U+0406 uni0406 ++!1d9 U+0407 uni0407 ++!1da U+0408 uni0408 ++!1db U+0409 uni0409 ++!1dc U+040A uni040A ++!1dd U+040B uni040B ++!1de U+040C uni040C ++!1df U+040E uni040E ++!1e0 U+040F uni040F ++!1e1 U+0410 uni0410 ++!1e2 U+0411 uni0411 ++!1e3 U+0412 uni0412 ++!1e4 U+0413 uni0413 ++!1e5 U+0414 uni0414 ++!1e6 U+0415 uni0415 ++!1e7 U+0416 uni0416 ++!1e8 U+0417 uni0417 ++!1e9 U+0418 uni0418 ++!1ea U+0419 uni0419 ++!1eb U+041A uni041A ++!1ec U+041B uni041B ++!1ed U+041C uni041C ++!1ee U+041D uni041D ++!1ef U+041E uni041E ++!1f0 U+041F uni041F ++!1f1 U+0420 uni0420 ++!1f2 U+0421 uni0421 ++!1f3 U+0422 uni0422 ++!1f4 U+0423 uni0423 ++!1f5 U+0424 uni0424 ++!1f6 U+0425 uni0425 ++!1f7 U+0426 uni0426 ++!1f8 U+0427 uni0427 ++!1f9 U+0428 uni0428 ++!1fa U+0429 uni0429 ++!1fb U+042A uni042A ++!1fc U+042B uni042B ++!1fd U+042C uni042C ++!1fe U+042D uni042D ++!1ff U+042E uni042E ++!200 U+042F uni042F ++!201 U+0430 uni0430 ++!202 U+0431 uni0431 ++!203 U+0432 uni0432 ++!204 U+0433 uni0433 ++!205 U+0434 uni0434 ++!206 U+0435 uni0435 ++!207 U+0436 uni0436 ++!208 U+0437 uni0437 ++!209 U+0438 uni0438 ++!20a U+0439 uni0439 ++!20b U+043A uni043A ++!20c U+043B uni043B ++!20d U+043C uni043C ++!20e U+043D uni043D ++!20f U+043E uni043E ++!210 U+043F uni043F ++!211 U+0440 uni0440 ++!212 U+0441 uni0441 ++!213 U+0442 uni0442 ++!214 U+0443 uni0443 ++!215 U+0444 uni0444 ++!216 U+0445 uni0445 ++!217 U+0446 uni0446 ++!218 U+0447 uni0447 ++!219 U+0448 uni0448 ++!21a U+0449 uni0449 ++!21b U+044A uni044A ++!21c U+044B uni044B ++!21d U+044C uni044C ++!21e U+044D uni044D ++!21f U+044E uni044E ++!220 U+044F uni044F ++!221 U+0451 uni0451 ++!222 U+0452 uni0452 ++!223 U+0453 uni0453 ++!224 U+0454 uni0454 ++!225 U+0455 uni0455 ++!226 U+0456 uni0456 ++!227 U+0457 uni0457 ++!228 U+0458 uni0458 ++!229 U+0459 uni0459 ++!22a U+045A uni045A ++!22b U+045B uni045B ++!22c U+045C uni045C ++!22d U+045E uni045E ++!22e U+045F uni045F ++!22f U+0490 uni0490 ++!230 U+0491 uni0491 ++!231 U+05D0 uni05D0 ++!232 U+05D1 uni05D1 ++!233 U+05D2 uni05D2 ++!234 U+05D3 uni05D3 ++!235 U+05D4 uni05D4 ++!236 U+05D5 uni05D5 ++!237 U+05D6 uni05D6 ++!238 U+05D7 uni05D7 ++!239 U+05D8 uni05D8 ++!23a U+05D9 uni05D9 ++!23b U+05DA uni05DA ++!23c U+05DB uni05DB ++!23d U+05DC uni05DC ++!23e U+05DD uni05DD ++!23f U+05DE uni05DE ++!240 U+05DF uni05DF ++!241 U+05E0 uni05E0 ++!242 U+05E1 uni05E1 ++!243 U+05E2 uni05E2 ++!244 U+05E3 uni05E3 ++!245 U+05E4 uni05E4 ++!246 U+05E5 uni05E5 ++!247 U+05E6 uni05E6 ++!248 U+05E7 uni05E7 ++!249 U+05E8 uni05E8 ++!24a U+05E9 uni05E9 ++!24b U+05EA uni05EA ++!24c U+1E80 uni1E80 Extended latin ++!24d U+1E81 uni1E81 Extended latin ++!24e U+1E82 uni1E82 Extended latin ++!24f U+1E83 uni1E83 Extended latin ++!250 U+1E84 uni1E84 Extended latin ++!251 U+1E85 uni1E85 Extended latin ++!252 U+1EF2 uni1EF2 Extended latin ++!253 U+1EF3 uni1EF3 Extended latin ++!254 U+200C uni200C ++!255 U+200D uni200D ++!256 U+200E uni200E ++!257 U+200F uni200F ++!258 U+2012 uni2012 ++!259 U+2013 uni2013 ++!25a U+2014 uni2014 ++!25b U+2015 uni2015 ++!25c U+2017 uni2017 ++!25d U+2018 uni2018 ++!25e U+2019 uni2019 ++!25f U+201A uni201A ++!260 U+201B uni201B ++!261 U+201C uni201C ++!262 U+201D uni201D ++!263 U+201E uni201E ++!264 U+2020 uni2020 ++!265 U+2021 uni2021 ++!266 U+2022 uni2022 ++!267 U+2024 uni2024 ++!268 U+2025 uni2025 ++!269 U+2026 uni2026 ++!26a U+202C uni202C ++!26b U+202D uni202D ++!26c U+202E uni202E ++!26d U+2032 uni2032 ++!26e U+2033 uni2033 ++!26f U+2034 uni2034 ++!270 U+2035 uni2035 ++!271 U+2036 uni2036 ++!272 U+2037 uni2037 ++!273 U+2039 uni2039 ++!274 U+203A uni203A ++!275 U+203C uni203C ++!276 U+2044 uni2044 ++!277 U+20AC uni20AC ++!278 U+2107 uni2107 ++!279 U+210B uni210B ++!27a U+210E uni210E ++!27b U+210F uni210F ++!27c U+2111 uni2111 ++!27d U+2112 uni2112 ++!27e U+2113 uni2113 ++!27f U+2115 uni2115 ++!280 U+2116 uni2116 ++!281 U+2118 uni2118 ++!282 U+2119 uni2119 ++!283 U+211A uni211A ++!284 U+211B uni211B ++!285 U+211C uni211C ++!286 U+211D uni211D ++!287 U+2122 uni2122 ++!288 U+2124 uni2124 ++!289 U+2126 uni2126 ++!28a U+2127 uni2127 ++!28b U+2128 uni2128 ++!28c U+2129 uni2129 ++!28d U+212B uni212B ++!28e U+212C uni212C ++!28f U+212E uni212E ++!290 U+212F uni212F ++!291 U+2130 uni2130 ++!292 U+2131 uni2131 ++!293 U+2133 uni2133 ++!294 U+2134 uni2134 ++!295 U+2135 uni2135 ++!296 U+2136 uni2136 ++!297 U+2137 uni2137 ++!298 U+2138 uni2138 ++!299 U+2190 uni2190 ++!29a U+2191 uni2191 ++!29b U+2192 uni2192 ++!29c U+2193 uni2193 ++!29d U+2194 uni2194 ++!29e U+2195 uni2195 ++!2a1 U+21D0 uni21D0 ++!2a2 U+21D1 uni21D1 ++!2a3 U+21D2 uni21D2 ++!2a4 U+21D3 uni21D3 ++!2a5 U+21D4 uni21D4 ++!2a6 U+2200 uni2200 ++!2a7 U+2202 uni2202 ++!2a8 U+2203 uni2203 ++!2a9 U+2204 uni2204 ++!2aa U+2205 uni2205 ++!2ab U+2206 uni2206 ++!2ac U+2207 uni2207 ++!2ad U+2208 uni2208 ++!2ae U+2209 uni2209 ++!2af U+220A uni220A ++!2b0 U+220B uni220B ++!2b1 U+220C uni220C ++!2b2 U+220D uni220D ++!2b3 U+220E uni220E ++!2b4 U+220F uni220F ++!2b5 U+2210 uni2210 ++!2b6 U+2211 uni2211 ++!2b7 U+2212 uni2212 ++!2b8 U+2213 uni2213 ++!2b9 U+2214 uni2214 ++!2ba U+2215 uni2215 ++!2bb U+2216 uni2216 ++!2bc U+2217 uni2217 ++!2bd U+2218 uni2218 ++!2be U+2219 uni2219 ++!2bf U+221A uni221A ++!2c0 U+221B uni221B ++!2c1 U+221C uni221C ++!2c2 U+221D uni221D ++!2c3 U+221E uni221E ++!2c4 U+221F uni221F ++!2c5 U+2220 uni2220 ++!2c6 U+2221 uni2221 ++!2c7 U+2222 uni2222 ++!2c8 U+2223 uni2223 ++!2c9 U+2224 uni2224 ++!2ca U+2225 uni2225 ++!2cb U+2226 uni2226 ++!2cc U+2227 uni2227 ++!2cd U+2228 uni2228 ++!2ce U+2229 uni2229 ++!2cf U+222A uni222A ++!2d0 U+222B uni222B ++!2d1 U+222C uni222C ++!2d2 U+222D uni222D ++!2d3 U+222E uni222E ++!2d4 U+222F uni222F ++!2d5 U+2230 uni2230 ++!2d6 U+2231 uni2231 ++!2d7 U+2232 uni2232 ++!2d8 U+2233 uni2233 ++!2d9 U+2234 uni2234 ++!2da U+2235 uni2235 ++!2db U+2236 uni2236 ++!2dc U+2237 uni2237 ++!2dd U+2238 uni2238 ++!2de U+2239 uni2239 ++!2df U+223A uni223A ++!2e0 U+223B uni223B ++!2e1 U+223C uni223C ++!2e2 U+223D uni223D ++!2e3 U+223E uni223E ++!2e4 U+223F uni223F ++!2e5 U+2240 uni2240 ++!2e6 U+2241 uni2241 ++!2e7 U+2242 uni2242 ++!2e8 U+2243 uni2243 ++!2e9 U+2244 uni2244 ++!2ea U+2245 uni2245 ++!2eb U+2246 uni2246 ++!2ec U+2247 uni2247 ++!2ed U+2248 uni2248 ++!2ee U+2249 uni2249 ++!2ef U+224A uni224A ++!2f0 U+224B uni224B ++!2f1 U+224C uni224C ++!2f2 U+224D uni224D ++!2f3 U+224E uni224E ++!2f4 U+224F uni224F ++!2f5 U+225F uni225F ++!2f6 U+2260 uni2260 ++!2f7 U+2261 uni2261 ++!2f8 U+2262 uni2262 ++!2f9 U+2263 uni2263 ++!2fa U+2264 uni2264 ++!2fb U+2265 uni2265 ++!2fc U+2266 uni2266 ++!2fd U+2267 uni2267 ++!2fe U+2268 uni2268 ++!2ff U+2269 uni2269 ++!300 U+226A uni226A ++!301 U+226B uni226B ++!302 U+226C uni226C ++!303 U+226D uni226D ++!304 U+226E uni226E ++!305 U+226F uni226F ++!306 U+2270 uni2270 ++!307 U+2271 uni2271 ++!308 U+2272 uni2272 ++!309 U+2273 uni2273 ++!30a U+2274 uni2274 ++!30b U+2275 uni2275 ++!30c U+2276 uni2276 ++!30d U+2277 uni2277 ++!30e U+2278 uni2278 ++!30f U+2279 uni2279 ++!310 U+227A uni227A ++!311 U+227B uni227B ++!312 U+227C uni227C ++!313 U+227D uni227D ++!314 U+227E uni227E ++!315 U+227F uni227F ++!316 U+2280 uni2280 ++!317 U+2281 uni2281 ++!318 U+2282 uni2282 ++!319 U+2283 uni2283 ++!31a U+2284 uni2284 ++!31b U+2285 uni2285 ++!31c U+2286 uni2286 ++!31d U+2287 uni2287 ++!31e U+2288 uni2288 ++!31f U+2289 uni2289 ++!320 U+22C0 uni22C0 ++!321 U+22C1 uni22C1 ++!322 U+22C2 uni22C2 ++!323 U+22C3 uni22C3 ++!324 U+22C4 uni22C4 ++!325 U+22C5 uni22C5 ++!326 U+2302 uni2302 ++!327 U+2310 uni2310 ++!328 U+2320 uni2320 ++!329 U+2321 uni2321 ++!32a U+2322 uni2322 ++!32b U+2323 uni2323 ++!32c U+2329 uni2329 ++!32d U+232A uni232A ++!32e U+239B uni239B ++!32f U+239C uni239C ++!330 U+239D uni239D ++!331 U+239E uni239E ++!332 U+239F uni239F ++!333 U+23A0 uni23A0 ++!334 U+23A1 uni23A1 ++!335 U+23A2 uni2392 ++!336 U+23A3 uni23A3 ++!337 U+23A4 uni23A4 ++!338 U+23A5 uni23A5 ++!339 U+23A6 uni23A6 ++!33a U+23A7 uni23A7 ++!33b U+23A8 uni23A8 ++!33c U+23A9 uni23A9 ++!33d U+23AA uni23AA ++!33e U+23AB uni23AB ++!33f U+23AC uni23AC ++!340 U+23AD uni23AD ++!341 U+23AE uni23AE ++!342 U+23AF uni23AF ++!343 U+23B0 uni23B0 ++!344 U+23B1 uni23B1 ++!345 U+23B2 uni23B2 ++!346 U+23B3 uni23B3 ++!347 U+23B4 uni23B4 ++!348 U+23B5 uni23B5 ++!349 U+23B6 uni23B6 ++!34a U+23B7 uni23B7 ++!34b U+23B8 uni23B8 ++!34c U+23B9 uni23B9 ++!34d U+23BA uni23BA ++!34e U+23BB uni23BB ++!34f U+23BC uni23BC ++!350 U+23BD uni23BD ++!351 U+23BE uni23BE ++!352 U+23BF uni23BF ++!353 U+23DE uni23DE ++!354 U+23DF uni23DF ++!355 U+23E1 uni23E1 ++!356 U+25A0 uni25A0 ++!357 U+25A1 uni25A1 ++!358 U+25AA uni25AA ++!359 U+25AB uni25AB ++!35b U+25B2 uni25B2 ++!35c U+25B3 uni25B3 ++!35d U+25BC uni25BC ++!35e U+25BD uni25BD ++!35a U+25C6 uni25C6 ++!35f U+25CA uni25CA ++!360 U+25CB uni25CB ++!361 U+25CF uni25CF ++!364 U+25E6 uni25E6 ++!362 U+25FB uni25FB ++!363 U+25FC uni25FC ++!365 U+2609 uni2609 ++!366 U+2639 uni2639 ++!367 U+263C uni263C ++!368 U+263D uni263D ++!369 U+263E uni263E ++!36a U+263F uni263F ++!36b U+2640 uni2640 ++!36c U+2641 uni2641 ++!36d U+2642 uni2642 ++!36e U+2643 uni2643 ++!36f U+2644 uni2644 ++!370 U+2645 uni2645 ++!371 U+2646 uni2646 ++!372 U+2647 uni2647 ++!373 U+2648 uni2648 ++!374 U+2649 uni2649 ++!375 U+264A uni264A ++!376 U+264B uni264B ++!377 U+264C uni264C ++!378 U+264D uni264D ++!379 U+264E uni264E ++!37a U+264F uni264F ++!37b U+2650 uni2650 ++!37c U+2651 uni2651 ++!37d U+2652 uni2652 ++!37e U+2653 uni2653 ++!37f U+25C7 uni25C7 ++!380 U+2297 uni2297 ++!381 U+2299 uni2299 +--- term/PostScript/8859-2.ps ++++ term/PostScript/8859-2.ps 2007-11-05 19:21:56.000000000 +0100 +@@ -1,4 +1,5 @@ +-% Encoding for ISO-8859-2 (also called as Latin-2), with ++% ++% Encoding for ISO-8859-2 (also called Latin2), with + % minor differences to "true" ISO-8859-2 (*commaaccent + % instead of *cedilla for sStT -> incorrect in ISO-8859-2, + % the standard will probably be modified in this respect) +--- term/PostScript/8859-9.ps ++++ term/PostScript/8859-9.ps 2008-01-14 07:38:26.000000000 +0100 +@@ -0,0 +1,44 @@ ++% ++% Encoding for ISO_8859_9 (also called Latin5) ++% Plus code points 80-9F used in Codepage 1254 ++% ++/reencodeISO9 { ++dup dup findfont dup length dict begin ++{ 1 index /FID ne { def }{ pop pop } ifelse } forall ++currentdict /CharStrings known { ++ CharStrings /Idieresis known { ++ /Encoding ISOLatin5Encoding def } if ++} if ++currentdict end definefont ++} def ++/ISOLatin5Encoding [ ++/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef ++/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef ++/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef ++/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef ++/space/exclam/quotedbl/numbersign/dollar/percent/ampersand/quoteright ++/parenleft/parenright/asterisk/plus/comma/minus/period/slash ++/zero/one/two/three/four/five/six/seven/eight/nine/colon/semicolon ++/less/equal/greater/question/at/A/B/C/D/E/F/G/H/I/J/K/L/M/N ++/O/P/Q/R/S/T/U/V/W/X/Y/Z/bracketleft/backslash/bracketright ++/asciicircum/underscore/quoteleft/a/b/c/d/e/f/g/h/i/j/k/l/m ++/n/o/p/q/r/s/t/u/v/w/x/y/z/braceleft/bar/braceright/asciitilde ++/Euro/.notdef/quotesinglbase/florin/quotedblbase/ellipsis/dagger/daggerdbl ++/circumflex/perthousand/Scaron/guilsinglleft/OE/.notdef/.notdef/.notdef ++/.notdef/quoteleft/quoteright/quotedblleft/quotedblright/bullet/endash/emdash ++/tilde/trademark/scaron/guilsinglright/oe/.notdef/.notdef/Ydieresis ++/.notdef/space/exclamdown/cent/sterling/currency/yen/brokenbar ++/section/dieresis/copyright/ordfeminine/guillemotleft/logicalnot ++/hyphen/registered/macron/degree/plusminus/twosuperior/threesuperior ++/acute/mu/paragraph/bullet/cedilla/onesuperior/ordmasculine ++/guillemotright/onequarter/onehalf/threequarters/questiondown ++/Agrave/Aacute/Acircumflex/Atilde/Adieresis/Aring/AE/Ccedilla ++/Egrave/Eacute/Ecircumflex/Edieresis/Igrave/Iacute/Icircumflex ++/Idieresis/Gbreve/Ntilde/Ograve/Oacute/Ocircumflex/Otilde/Odieresis ++/multiply/Oslash/Ugrave/Uacute/Ucircumflex/Udieresis/Idotaccent ++/Scedilla/germandbls/agrave/aacute/acircumflex/atilde/adieresis ++/aring/ae/ccedilla/egrave/eacute/ecircumflex/edieresis/igrave ++/iacute/icircumflex/idieresis/gbreve/ntilde/ograve/oacute/ocircumflex ++/otilde/odieresis/divide/oslash/ugrave/uacute/ucircumflex/udieresis ++/dotlessi/scedilla/ydieresis ++] def +--- term/PostScript/cp850.ps ++++ term/PostScript/cp850.ps 2007-11-05 19:21:56.000000000 +0100 +@@ -1,4 +1,5 @@ +-% encoding for code page 850 ++% ++% encoding for code page 850 (obsolete MSDOS Western Europe) + % version 1.0: - Mainly letters are mapped. The following positions + % (JFi) are left blank (undefined): + % -- first 32 positions, +--- term/PostScript/prologue.ps ++++ term/PostScript/prologue.ps 2007-11-11 20:22:22.000000000 +0100 +@@ -1,5 +1,5 @@ + % +-% Gnuplot Prolog Version 4.2 (August 2006) ++% Gnuplot Prolog Version 4.2 (November 2007) + % + /M {moveto} bind def + /L {lineto} bind def +@@ -9,6 +9,7 @@ + /Z {closepath} bind def + /C {setrgbcolor} bind def + /f {rlineto fill} bind def ++/Gshow {show} def % May be redefined later in the file to support UTF-8 + /vpt2 vpt 2 mul def + /hpt2 hpt 2 mul def + /Lshow {currentpoint stroke M 0 vshift R +--- term/PostScript/prologues.h ++++ term/PostScript/prologues.h 2008-01-24 00:05:50.000000000 +0100 +@@ -2,6 +2,9 @@ + * in a form suitable to inclusion in a C source code */ + + static const char *prologue_8859_1_ps[] = { ++"%\n", ++"% Encoding for ISO-8859-1 (also called Latin1)\n", ++"%\n", + "/reencodeISO {\n", + "dup dup findfont dup length dict begin\n", + "{ 1 index /FID ne { def }{ pop pop } ifelse } forall\n", +@@ -46,6 +49,9 @@ + }; + + static const char *prologue_8859_15_ps[] = { ++"%\n", ++"% Encoding for ISO-8859-15 (also called Latin9)\n", ++"%\n", + "/reencodeISO15 {\n", + "dup dup findfont dup length dict begin\n", + "{ 1 index /FID ne { def }{ pop pop } ifelse } forall\n", +@@ -90,7 +96,8 @@ + }; + + static const char *prologue_8859_2_ps[] = { +-"% Encoding for ISO-8859-2 (also called as Latin-2), with\n", ++"%\n", ++"% Encoding for ISO-8859-2 (also called Latin2), with\n", + "% minor differences to \"true\" ISO-8859-2 (*commaaccent \n", + "% instead of *cedilla for sStT -> incorrect in ISO-8859-2,\n", + "% the standard will probably be modified in this respect)\n", +@@ -138,7 +145,58 @@ + NULL + }; + ++static const char *prologue_8859_9_ps[] = { ++"%\n", ++"% Encoding for ISO_8859_9 (also called Latin5)\n", ++"% Plus code points 80-9F used in Codepage 1254\n", ++"%\n", ++"/reencodeISO9 {\n", ++"dup dup findfont dup length dict begin\n", ++"{ 1 index /FID ne { def }{ pop pop } ifelse } forall\n", ++"currentdict /CharStrings known {\n", ++"\tCharStrings /Idieresis known {\n", ++"\t\t/Encoding ISOLatin5Encoding def } if\n", ++"} if\n", ++"currentdict end definefont\n", ++"} def\n", ++"/ISOLatin5Encoding [\n", ++"/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef\n", ++"/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef\n", ++"/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef\n", ++"/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef\n", ++"/space/exclam/quotedbl/numbersign/dollar/percent/ampersand/quoteright\n", ++"/parenleft/parenright/asterisk/plus/comma/minus/period/slash\n", ++"/zero/one/two/three/four/five/six/seven/eight/nine/colon/semicolon\n", ++"/less/equal/greater/question/at/A/B/C/D/E/F/G/H/I/J/K/L/M/N\n", ++"/O/P/Q/R/S/T/U/V/W/X/Y/Z/bracketleft/backslash/bracketright\n", ++"/asciicircum/underscore/quoteleft/a/b/c/d/e/f/g/h/i/j/k/l/m\n", ++"/n/o/p/q/r/s/t/u/v/w/x/y/z/braceleft/bar/braceright/asciitilde\n", ++"/Euro/.notdef/quotesinglbase/florin/quotedblbase/ellipsis/dagger/daggerdbl\n", ++"/circumflex/perthousand/Scaron/guilsinglleft/OE/.notdef/.notdef/.notdef\n", ++"/.notdef/quoteleft/quoteright/quotedblleft/quotedblright/bullet/endash/emdash\n", ++"/tilde/trademark/scaron/guilsinglright/oe/.notdef/.notdef/Ydieresis\n", ++"/.notdef/space/exclamdown/cent/sterling/currency/yen/brokenbar\n", ++"/section/dieresis/copyright/ordfeminine/guillemotleft/logicalnot\n", ++"/hyphen/registered/macron/degree/plusminus/twosuperior/threesuperior\n", ++"/acute/mu/paragraph/bullet/cedilla/onesuperior/ordmasculine\n", ++"/guillemotright/onequarter/onehalf/threequarters/questiondown\n", ++"/Agrave/Aacute/Acircumflex/Atilde/Adieresis/Aring/AE/Ccedilla\n", ++"/Egrave/Eacute/Ecircumflex/Edieresis/Igrave/Iacute/Icircumflex\n", ++"/Idieresis/Gbreve/Ntilde/Ograve/Oacute/Ocircumflex/Otilde/Odieresis\n", ++"/multiply/Oslash/Ugrave/Uacute/Ucircumflex/Udieresis/Idotaccent\n", ++"/Scedilla/germandbls/agrave/aacute/acircumflex/atilde/adieresis\n", ++"/aring/ae/ccedilla/egrave/eacute/ecircumflex/edieresis/igrave\n", ++"/iacute/icircumflex/idieresis/gbreve/ntilde/ograve/oacute/ocircumflex\n", ++"/otilde/odieresis/divide/oslash/ugrave/uacute/ucircumflex/udieresis\n", ++"/dotlessi/scedilla/ydieresis\n", ++"] def\n", ++NULL ++}; ++ + static const char *prologue_cp1250_ps[] = { ++"%\n", ++"% Encoding for code page 1250 (Microsoft Windows Central and Eastern European)\n", ++"%\n", + "/reencodeCP1250 {\n", + "dup dup findfont dup length dict begin\n", + "{ 1 index /FID ne { def }{ pop pop } ifelse } forall\n", +@@ -181,7 +239,8 @@ + }; + + static const char *prologue_cp437_ps[] = { +-"% encoding for code page 437\n", ++"%\n", ++"% encoding for code page 437 (original MSDOS)\n", + "% version 1.0:\t- Mainly letters are mapped. The following positions\n", + "% (JFi)\t\t are left blank (undefined):\n", + "%\t\t-- first 32 positions,\n", +@@ -233,7 +292,8 @@ + }; + + static const char *prologue_cp850_ps[] = { +-"% encoding for code page 850\n", ++"%\n", ++"% encoding for code page 850 (obsolete MSDOS Western Europe)\n", + "% version 1.0: - Mainly letters are mapped. The following positions\n", + "% (JFi)\t\t are left blank (undefined):\n", + "%\t\t-- first 32 positions,\n", +@@ -282,7 +342,8 @@ + }; + + static const char *prologue_cp852_ps[] = { +-"% encoding for code page 852\n", ++"%\n", ++"% encoding for code page 852 (MSDOS Central European)\n", + "/reencodeCP852 {\n", + "dup dup findfont dup length dict begin\n", + "{ 1 index /FID ne { def }{ pop pop } ifelse } forall\n", +@@ -326,7 +387,8 @@ + }; + + static const char *prologue_koi8r_ps[] = { +-"% encoding for code page koi8r\n", ++"%\n", ++"% encoding for code page koi8r (8-bit Russian)\n", + "% version 1.0:\t- Mainly letters are mapped. The following positions\n", + "% (JFi)\t\t are left blank (undefined):\n", + "%\t\t-- first 32 positions,\n", +@@ -376,6 +438,7 @@ + + static const char *prologue_koi8u_ps[] = { + "%\n", ++"% encoding for code page koi8r (8-bit Ukrainian)\n", + "/reencodeKOI8U {\n", + "dup dup findfont dup length dict begin\n", + "{ 1 index /FID ne { def }{ pop pop } ifelse } forall\n", +@@ -419,7 +482,7 @@ + + static const char *prologue_prologue_ps[] = { + "%\n", +-"% Gnuplot Prolog Version 4.2 (August 2006)\n", ++"% Gnuplot Prolog Version 4.2 (November 2007)\n", + "%\n", + "/M {moveto} bind def\n", + "/L {lineto} bind def\n", +@@ -429,6 +492,7 @@ + "/Z {closepath} bind def\n", + "/C {setrgbcolor} bind def\n", + "/f {rlineto fill} bind def\n", ++"/Gshow {show} def % May be redefined later in the file to support UTF-8\n", + "/vpt2 vpt 2 mul def\n", + "/hpt2 hpt 2 mul def\n", + "/Lshow {currentpoint stroke M 0 vshift R \n", +@@ -669,7 +733,7 @@ + " ColR ColG ColB setrgbcolor} def\n", + "/BoxColFill {gsave Rec PolyFill} def\n", + "/PolyFill {gsave Density fill grestore grestore} def\n", +-"/h {rlineto rlineto rlineto gsave fill grestore} bind def\n", ++"/h {rlineto rlineto rlineto gsave closepath fill grestore} bind def\n", + "%\n", + "% PostScript Level 1 Pattern Fill routine for rectangles\n", + "% Usage: x y w h s a XX PatternFill\n", +@@ -789,3 +853,65 @@ + NULL + }; + ++static const char *prologue_utf_8_ps[] = { ++"%\n", ++"% Base ISO8859-1 character encoding plus support macros for UTF-8 encoding\n", ++"% via the glyphshow operator\n", ++"%\n", ++"/reencodeISO {\n", ++"dup dup findfont dup length dict begin\n", ++"{ 1 index /FID ne { def }{ pop pop } ifelse } forall\n", ++"currentdict /CharStrings known {\n", ++"\tCharStrings /Idieresis known {\n", ++"\t\t/Encoding ISOLatin1Encoding def } if\n", ++"} if\n", ++"currentdict end definefont\n", ++"} def\n", ++"/ISOLatin1Encoding [\n", ++"/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef\n", ++"/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef\n", ++"/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef\n", ++"/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef\n", ++"/space/exclam/quotedbl/numbersign/dollar/percent/ampersand/quoteright\n", ++"/parenleft/parenright/asterisk/plus/comma/minus/period/slash\n", ++"/zero/one/two/three/four/five/six/seven/eight/nine/colon/semicolon\n", ++"/less/equal/greater/question/at/A/B/C/D/E/F/G/H/I/J/K/L/M/N\n", ++"/O/P/Q/R/S/T/U/V/W/X/Y/Z/bracketleft/backslash/bracketright\n", ++"/asciicircum/underscore/quoteleft/a/b/c/d/e/f/g/h/i/j/k/l/m\n", ++"/n/o/p/q/r/s/t/u/v/w/x/y/z/braceleft/bar/braceright/asciitilde\n", ++"/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef\n", ++"/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef\n", ++"/.notdef/dotlessi/grave/acute/circumflex/tilde/macron/breve\n", ++"/dotaccent/dieresis/.notdef/ring/cedilla/.notdef/hungarumlaut\n", ++"/ogonek/caron/space/exclamdown/cent/sterling/currency/yen/brokenbar\n", ++"/section/dieresis/copyright/ordfeminine/guillemotleft/logicalnot\n", ++"/hyphen/registered/macron/degree/plusminus/twosuperior/threesuperior\n", ++"/acute/mu/paragraph/periodcentered/cedilla/onesuperior/ordmasculine\n", ++"/guillemotright/onequarter/onehalf/threequarters/questiondown\n", ++"/Agrave/Aacute/Acircumflex/Atilde/Adieresis/Aring/AE/Ccedilla\n", ++"/Egrave/Eacute/Ecircumflex/Edieresis/Igrave/Iacute/Icircumflex\n", ++"/Idieresis/Eth/Ntilde/Ograve/Oacute/Ocircumflex/Otilde/Odieresis\n", ++"/multiply/Oslash/Ugrave/Uacute/Ucircumflex/Udieresis/Yacute\n", ++"/Thorn/germandbls/agrave/aacute/acircumflex/atilde/adieresis\n", ++"/aring/ae/ccedilla/egrave/eacute/ecircumflex/edieresis/igrave\n", ++"/iacute/icircumflex/idieresis/eth/ntilde/ograve/oacute/ocircumflex\n", ++"/otilde/odieresis/divide/oslash/ugrave/uacute/ucircumflex/udieresis\n", ++"/yacute/thorn/ydieresis\n", ++"] def\n", ++"\n", ++"/Gshow { dup type /stringtype eq { show } { glyphshow } ifelse } def\n", ++"\n", ++"/Gsall { {Gshow} forall } def\n", ++"/Gwidth {\n", ++"\tdup currentpoint pop exch\n", ++"\tgsave 6 array currentmatrix nulldevice setmatrix Gsall currentpoint pop grestore sub\n", ++"\t} def\n", ++"/GLshow {currentpoint stroke M 0 vshift R \n", ++"\tBlacktext {gsave 0 setgray Gsall grestore} {Gsall} ifelse} def\n", ++"/GRshow {currentpoint stroke M dup Gwidth vshift R\n", ++"\tBlacktext {gsave 0 setgray Gsall grestore} {Gsall} ifelse} def\n", ++"/GCshow {currentpoint stroke M dup Gwidth 2 div vshift R \n", ++"\tBlacktext {gsave 0 setgray Gsall grestore} {Gsall} ifelse} def\n", ++NULL ++}; ++ +--- term/PostScript/koi8u.ps ++++ term/PostScript/koi8u.ps 2007-11-05 19:21:56.000000000 +0100 +@@ -1,4 +1,5 @@ + % ++% encoding for code page koi8r (8-bit Ukrainian) + /reencodeKOI8U { + dup dup findfont dup length dict begin + { 1 index /FID ne { def }{ pop pop } ifelse } forall +--- term/PostScript/unicode_maps.README ++++ term/PostScript/unicode_maps.README 2007-11-11 20:22:22.000000000 +0100 +@@ -0,0 +1,75 @@ ++ unicode maps README ++ =================== ++ ++Each unicode_XXX.map file contains a list of unicode code points that might ++plausibly be used from inside gnuplot. These are only relevant to the ++PostScript terminal drivers, and only if you want to use UTF-8 encoding. ++ ++If you have a TTF unicode font containing the relevant characters, you can ++use the unicode map file to instruct the external program ttf2pt1 to prepare ++an Adobe Type 1 font. ++ ++For example: ++ ++ ttf2pt1 -p ft -e -L unicode_big.map arialuni.ttf ++ ++This will extract character glyphs for these particular code points ++from arialuni.ttf and create a new file arialuni.ps. You can use this new ++*.pfa font file from gnuplot by saying ++ ++ set encoding utf8 ++ set term post fontfile 'arialuni.ps' font 'ArialUnicodeMS' ++ ++Note that gnuplot can run ttf2pt1 for you on the fly if you ++first define the appropriate command in the environmental variable ++GNUPLOT_TTFTOPFA. For example: ++ ++ setenv GNUPLOT_TTFTOPFA "ttf2pt1 -e -p ft -L unimap.map %s -" ++ ++In this case you could say ++ ++ set encoding utf8 ++ set term post fontfile 'arialuni.ttf' font 'ArialUnicodeMS' ++ ++In either case, the converted glyphs will be embedded in your ++gnuplot output file. There are several caveats: ++ ++1) This can make the file quite large. ++ ++2) If a glyph isn't in the starting *.ttf font to begin with, nothing ++ you do here will fix that. ++ ++3) If gnuplot runs the conversion for you, it will be triggered each ++ time you plot. ++ ++Several unicode map files are provided. They differ in how many ++characters they request, and hence in the size of the resulting font file. ++ ++ unicode_small.map (462 characters) ++ =================================== ++ ++- the Latin1 character set ++- the basic Greek alphabet ++- basic math and physical symbols ++- 133 less obscure math symbols from Unicode pages 34 and 35 ++ ++ ++ unicode_big.map (863 characters) ++ ================================= ++ ++- the Latin1 character set ++- extended Latin character sets needed to support other European languages ++- the Cyrillic alphabet, with extensions for various slavic languages ++ (may not be complete - please report omissions) ++- the basic Greek and Hebrew alphabets ++- basic math symbols ++- 176 mathematical symbols, some obscure, from Unicode pages 34 and 35 ++- physical and astronomical symbols ++ ++The unicode_big map makes a total of about 860 glyphs available to use ++from gnuplot, but only if they exist in the original TTF font file. ++The maximum number that ttf2pt1 can process is 1024. ++This is only a tiny fraction of the total characters indexed by Unicode. ++But if you need more, probably you would do better to use a different ++gnuplot terminal that supports direct use of UTF-8 TTF fonts (pdf, png, svg). ++ +--- src/term.c ++++ src/term.c 2008-02-24 20:49:37.000000000 +0100 +@@ -134,19 +134,23 @@ + enum set_encoding_id encoding; + /* table of encoding names, for output of the setting */ + const char *encoding_names[] = { +- "default", "iso_8859_1", "iso_8859_2", "iso_8859_15", +- "cp437", "cp850", "cp852", "cp1250", "koi8r", "koi8u", NULL }; ++ "default", "iso_8859_1", "iso_8859_2", "iso_8859_9", "iso_8859_15", ++ "cp437", "cp850", "cp852", "cp1250", "cp1254", "koi8r", "koi8u", ++ "utf8", NULL }; + /* 'set encoding' options */ + const struct gen_table set_encoding_tbl[] = + { + { "def$ault", S_ENC_DEFAULT }, ++ { "utf$8", S_ENC_UTF8 }, + { "iso$_8859_1", S_ENC_ISO8859_1 }, + { "iso_8859_2", S_ENC_ISO8859_2 }, ++ { "iso_8859_9", S_ENC_ISO8859_9 }, + { "iso_8859_15", S_ENC_ISO8859_15 }, + { "cp4$37", S_ENC_CP437 }, + { "cp850", S_ENC_CP850 }, + { "cp852", S_ENC_CP852 }, + { "cp1250", S_ENC_CP1250 }, ++ { "cp1254", S_ENC_CP1254 }, + { "koi8$r", S_ENC_KOI8_R }, + { "koi8$u", S_ENC_KOI8_U }, + { NULL, S_ENC_INVALID } +@@ -945,7 +948,7 @@ + + void + write_multiline( +- unsigned int x, unsigned y, ++ unsigned int x, unsigned int y, + char *text, + JUSTIFY hor, /* horizontal ... */ + VERT_JUSTIFY vert, /* ... and vertical just - text in hor direction despite angle */ +--- src/term_api.h ++++ src/term_api.h 2008-02-24 20:49:37.000000000 +0100 +@@ -124,7 +124,9 @@ + TERM_LAYER_RESET, + TERM_LAYER_BACKTEXT, + TERM_LAYER_FRONTTEXT, +- TERM_LAYER_END_TEXT ++ TERM_LAYER_END_TEXT, ++ TERM_LAYER_BEFORE_PLOT, ++ TERM_LAYER_AFTER_PLOT + } t_termlayer; + + typedef struct fill_style_type { +@@ -134,8 +136,9 @@ + int border_linetype; + } fill_style_type; + +-typedef enum t_fillstyle { FS_EMPTY, FS_SOLID, FS_PATTERN, FS_DEFAULT } +- t_fillstyle; ++typedef enum t_fillstyle { FS_EMPTY, FS_SOLID, FS_PATTERN, FS_DEFAULT, ++ FS_TRANSPARENT_SOLID, FS_TRANSPARENT_PATTERN } ++ t_fillstyle; + #define FS_OPAQUE (FS_SOLID + (100<<4)) + + #ifdef WITH_IMAGE +@@ -159,6 +162,7 @@ + #define TERM_ENHANCED_TEXT 32 /* enhanced text mode is enabled */ + #define TERM_NO_OUTPUTFILE 64 /* terminal doesnt write to a file */ + #define TERM_CAN_CLIP 128 /* terminal does its own clipping */ ++#define TERM_CAN_DASH 256 /* terminal supports dashed lines */ + + /* The terminal interface structure --- heart of the terminal layer. + * +@@ -254,6 +258,11 @@ + */ + void (*path) __PROTO((int p)); + ++/* Scale factor for converting terminal coordinates to output ++ * pixel coordinates. Used to provide data for external mousing code. ++ */ ++ double tscale; ++ + } TERMENTRY; + + #ifdef WIN16 +@@ -263,9 +272,10 @@ + #endif + + enum set_encoding_id { +- S_ENC_DEFAULT, S_ENC_ISO8859_1, S_ENC_ISO8859_2, S_ENC_ISO8859_15, +- S_ENC_CP437, S_ENC_CP850, S_ENC_CP852, S_ENC_CP1250, +- S_ENC_KOI8_R, S_ENC_KOI8_U, ++ S_ENC_DEFAULT, S_ENC_ISO8859_1, S_ENC_ISO8859_2, S_ENC_ISO8859_9, S_ENC_ISO8859_15, ++ S_ENC_CP437, S_ENC_CP850, S_ENC_CP852, S_ENC_CP1250, S_ENC_CP1254, ++ S_ENC_KOI8_R, S_ENC_KOI8_U, ++ S_ENC_UTF8, + S_ENC_INVALID + }; + +--- src/util.c ++++ src/util.c 2008-03-30 01:37:25.000000000 +0100 +@@ -1200,3 +1215,85 @@ + + return fullname; + } ++ ++TBOOLEAN contains8bit(const char *s) ++{ ++ while (*s) { ++ if ((*s++ & 0x80)) ++ return TRUE; ++ } ++ return FALSE; ++} ++ ++#define INVALID_UTF8 0xfffful ++ ++/* Read from second byte to end of UTF-8 sequence. ++ used by utftoulong() */ ++TBOOLEAN ++utf8_getmore (unsigned long * wch, const char **str, int nbytes) ++{ ++ int i; ++ unsigned char c; ++ unsigned long minvalue[] = {0x80, 0x800, 0x10000, 0x200000, 0x4000000}; ++ ++ for (i = 0; i < nbytes; i++) { ++ c = (unsigned char) **str; ++ ++ if ((c & 0xc0) != 0x80) { ++ *wch = INVALID_UTF8; ++ return FALSE; ++ } ++ *wch = (*wch << 6) | (c & 0x3f); ++ (*str)++; ++ } ++ ++ /* check for overlong UTF-8 sequences */ ++ if (*wch < minvalue[nbytes-1]) { ++ *wch = INVALID_UTF8; ++ return FALSE; ++ } ++ return TRUE; ++} ++ ++/* Convert UTF-8 multibyte sequence from string to unsigned long character. ++ Returns TRUE on success. ++*/ ++TBOOLEAN ++utf8toulong (unsigned long * wch, const char ** str) ++{ ++ unsigned char c; ++ ++ c = (unsigned char) *(*str)++; ++ if ((c & 0x80) == 0) { ++ *wch = (unsigned long) c; ++ return TRUE; ++ } ++ ++ if ((c & 0xe0) == 0xc0) { ++ *wch = c & 0x1f; ++ return utf8_getmore(wch, str, 1); ++ } ++ ++ if ((c & 0xf0) == 0xe0) { ++ *wch = c & 0x0f; ++ return utf8_getmore(wch, str, 2); ++ } ++ ++ if ((c & 0xf8) == 0xf0) { ++ *wch = c & 0x07; ++ return utf8_getmore(wch, str, 3); ++ } ++ ++ if ((c & 0xfc) == 0xf8) { ++ *wch = c & 0x03; ++ return utf8_getmore(wch, str, 4); ++ } ++ ++ if ((c & 0xfe) == 0xfc) { ++ *wch = c & 0x01; ++ return utf8_getmore(wch, str, 5); ++ } ++ ++ *wch = INVALID_UTF8; ++ return FALSE; ++} +--- src/set.c ++++ src/set.c 2008-03-30 04:08:58.000000000 +0200 +@@ -1211,7 +1211,7 @@ + temp = lookup_table(&set_encoding_tbl[0],c_token); + + if (temp == S_ENC_INVALID) +- int_error(c_token, "expecting one of 'default', 'iso_8859_1', 'iso_8859_2', 'iso_8859_15', 'cp437', 'cp850', 'cp852', 'koi8r' or 'koi8u'"); ++ int_error(c_token, "expecting one of 'default', 'utf8', 'iso_8859_1', 'iso_8859_2', 'iso_8859_9', 'iso_8859_15', 'cp437', 'cp850', 'cp852', 'koi8r', or 'koi8u'"); + c_token++; + } + encoding = temp; +--- docs/gnuplot.doc ++++ docs/gnuplot.doc 2008-03-30 12:31:59.000000000 +0200 +@@ -5791,6 +5791,7 @@ + ?show encoding + ?encoding + ?encodings ++=UTF-8 + The `set encoding` command selects a character encoding. + Syntax: + set encoding {} +@@ -5801,6 +5802,7 @@ + iso_8859_1 - the most common Western European font used by many + Unix workstations and by MS-Windows. This encoding is + known in the PostScript world as 'ISO-Latin1'. ++ iso_8859_15 - a variant of iso_8859_1 that includes the Euro symbol + iso_8859_2 - used in Central and Eastern Europe + iso_8859_15 - a variant of iso_8859_1 that includes the Euro symbol + koi8r - popular Unix cyrillic encoding +@@ -5809,6 +5811,9 @@ + cp850 - codepage for OS/2, Western Europe + cp852 - codepage for OS/2, Central and Eastern Europe + cp1250 - codepage for MS Windows, Central and Eastern Europe ++ cp1254 - codepage for MS Windows, Turkish (superset of Latin5) ++ utf8 - variable-length (multibyte) representation of Unicode ++ entry point for each character + + Generally you must set the encoding before setting the terminal type. + Note that encoding is not supported by all terminal drivers and that diff --git a/gnuplot.changes b/gnuplot.changes index 6f0e2a7..6c3f941 100644 --- a/gnuplot.changes +++ b/gnuplot.changes @@ -1,3 +1,8 @@ +------------------------------------------------------------------- +Mon Mar 31 17:49:45 CEST 2008 - werner@suse.de + +- Make gnupplot UTF-8 capable (bnc#375175) + ------------------------------------------------------------------- Wed Mar 26 12:47:02 CET 2008 - werner@suse.de diff --git a/gnuplot.spec b/gnuplot.spec index 6623489..51bc925 100644 --- a/gnuplot.spec +++ b/gnuplot.spec @@ -19,7 +19,7 @@ Group: Productivity/Graphics/Visualization/Graph AutoReqProv: on PreReq: %install_info_prereq Version: 4.2.3 -Release: 1 +Release: 5 Summary: Function Plotting Utility Source0: gnuplot-4.2.3.tar.bz2 Source2: gnuplot-fr.doc.bz2 @@ -29,6 +29,7 @@ Patch1: gnuplot-4.2.0-x11ovf.dif Patch2: gnuplot-4.2.2-fonts.dif Patch3: gnuplot-4.2.0-wxt.dif Patch4: gnuplot-4.2.0-demo.dif +Patch5: gnuplot-4.2.3-utf8.dif BuildRoot: %{_tmppath}/%{name}-%{version}-build %{expand: %%global _exec_prefix %(type -p pkg-config &>/dev/null && pkg-config --variable prefix x11 || echo /usr/X11R6)} %if "%_exec_prefix" == "/usr/X11R6" @@ -69,6 +70,7 @@ test $? -eq 0 || exit 1 %patch -P 0 -p 0 %patch -P 2 -p 0 %patch -P 4 -p 0 +%patch -P 5 -p 0 %build SECSVGA="-DSVGA_IS_SECURE=1" @@ -176,6 +178,8 @@ test $? -eq 0 || exit 1 %{_appdef}/Gnuplot %changelog +* Mon Mar 31 2008 werner@suse.de +- Make gnupplot UTF-8 capable (bnc#375175) * Wed Mar 26 2008 werner@suse.de - Update to gnuplot 4.2.3 * NEW options front and back to "set colorbox" @@ -373,7 +377,7 @@ test $? -eq 0 || exit 1 - no svgalib * Tue Jun 12 2001 schwab@suse.de - Fix for new autoconf. -* Tue May 08 2001 mfabian@suse.de +* Wed May 09 2001 mfabian@suse.de - bzip2 sources * Thu Mar 29 2001 garloff@suse.de - Prevent stupid rounding errors 10*10^23 instead of 10^24