texlive[49967] Build/source/texk/dviout-util: dviout-util: man page,
commits+hironobu at tug.org
commits+hironobu at tug.org
Thu Feb 7 13:05:38 CET 2019
Revision: 49967
http://tug.org/svn/texlive?view=revision&revision=49967
Author: hironobu
Date: 2019-02-07 13:05:38 +0100 (Thu, 07 Feb 2019)
Log Message:
-----------
dviout-util: man page, chkdvifont update
Modified Paths:
--------------
trunk/Build/source/texk/dviout-util/ChangeLog
trunk/Build/source/texk/dviout-util/chkdvifont.c
trunk/Build/source/texk/dviout-util/chkdvifont.man
trunk/Build/source/texk/dviout-util/configure
trunk/Build/source/texk/dviout-util/configure.ac
trunk/Build/source/texk/dviout-util/dvispc.man
Modified: trunk/Build/source/texk/dviout-util/ChangeLog
===================================================================
--- trunk/Build/source/texk/dviout-util/ChangeLog 2019-02-07 01:23:40 UTC (rev 49966)
+++ trunk/Build/source/texk/dviout-util/ChangeLog 2019-02-07 12:05:38 UTC (rev 49967)
@@ -1,3 +1,9 @@
+2019-02-06 Hironobu Yamashita <h.y.acetaminophen at gmail.com>
+
+ * chkdvifont.c: Detect new JFM spec.
+ * chkdvifont.man, dvispc.man: Add fallback TeX and LaTeX logos.
+ * configure.ac: Version 20190206.
+
2018-11-25 Hironobu Yamashita <h.y.acetaminophen at gmail.com>
* configure.ac: Version 20181125.
Modified: trunk/Build/source/texk/dviout-util/chkdvifont.c
===================================================================
--- trunk/Build/source/texk/dviout-util/chkdvifont.c 2019-02-07 01:23:40 UTC (rev 49966)
+++ trunk/Build/source/texk/dviout-util/chkdvifont.c 2019-02-07 12:05:38 UTC (rev 49967)
@@ -1,10 +1,10 @@
/*
- * CHecK DVI FONTs (CHKDVIFONT)
+ * CHecK DVI FONTs (CHKDVIFONT)
* Dec 1990, originally written by SHIMA
- * Apr 1992, second version
- * May 1992, third version
- * Sep 1992, fifth version
- * May 1996, sixth version
+ * Apr 1992, second version
+ * May 1992, third version
+ * Sep 1992, fifth version
+ * May 1996, sixth version
*
* Usage: chkdvifont [-s] [-c] [-{f|F}<font_data_file>] [-d] dvi_file_name
* chkdvifont [-s] [-c] [-{f|F}<font_data_file>] [-t] tfm_file_name
@@ -43,12 +43,12 @@
#ifdef __GNUC__
/* Validate in case of UNIX */
-#define UNIX 1
-#define GCC 1
+#define UNIX 1
+#define GCC 1
#else
/* Win32 MSVC is assumed */
-#define WIN32 1
-#define MSVC 1
+#define WIN32 1
+#define MSVC 1
#endif
#include <stdio.h>
@@ -64,7 +64,7 @@
#endif
#include <string.h>
-#ifdef GCC
+#ifdef GCC
#include <ctype.h>
#endif
@@ -72,28 +72,28 @@
#include "dd.h"
-#define ID 2
-#define ID_PTEX 3
-#define END_DVI 223
-#define MAX_NAME 16
-#define MAX_FONT 1024
-#define BUF_SIZE 1024
+#define ID 2
+#define ID_PTEX 3
+#define END_DVI 223
+#define MAX_NAME 16
+#define MAX_FONT 1024
+#define BUF_SIZE 1024
-#define HALF_POINT (1L<<8)
+#define HALF_POINT (1L<<8)
-#define NEW_FONT 1
-#define NEW_POINT 2
-#define NEW_EUFM 4
-#define BAD_EUFM 8
-#define OLD_FONT 16
-#define OLD_EUFM 32
+#define NEW_FONT 1
+#define NEW_POINT 2
+#define NEW_EUFM 4
+#define BAD_EUFM 8
+#define OLD_FONT 16
+#define OLD_EUFM 32
-#define DVI_FILE 0
-#define TFM_FILE 1
-#define PXL_FILE 2
-#define PK_FILE 3
-#define VF_FILE 4
-#define VF_FILE_MAP 5
+#define DVI_FILE 0
+#define TFM_FILE 1
+#define PXL_FILE 2
+#define PK_FILE 3
+#define VF_FILE 4
+#define VF_FILE_MAP 5
char buf[BUF_SIZE];
char filename[MAXPATH];
@@ -103,35 +103,35 @@
*/
struct EUFM {
- int point; /* point number */
- unsigned int oldd; /* old checksum */
- unsigned int neww; /* new checksum */
+ int point; /* point number */
+ unsigned int oldd; /* old checksum */
+ unsigned int neww; /* new checksum */
};
/*
- Multiple lines for a point are allowed.
- The last line should be 0 point.
+ * Multiple lines for a point are allowed.
+ * The last line should be 0 point.
*/
struct EUFM eufm[] =
{
- 5, 0x0891FD38L, 0x246A686BL,
- 5, 0x0891FD38L, 0xB8C9AFD4L,
- 6, 0x2F8EDF02L, 0x9793B1E1L,
- 6, 0x2F8EDF02L, 0x65167BC4L,
- 7, 0x37CDA321L, 0x05184980L,
- 7, 0x37CDA321L, 0x58ED2602L,
- 8, 0x37CCA321L, 0x2564B2F5L,
- 8, 0x37CCA321L, 0x5C978225L,
- 9, 0x3F977CF3L, 0x1F6C4283L,
- 9, 0x3F977CF3L, 0xF833F3AFL,
- 10, 0xBF989013L, 0x8F256EB2L,
- 0, 0L, 0L
+ 5, 0x0891FD38L, 0x246A686BL,
+ 5, 0x0891FD38L, 0xB8C9AFD4L,
+ 6, 0x2F8EDF02L, 0x9793B1E1L,
+ 6, 0x2F8EDF02L, 0x65167BC4L,
+ 7, 0x37CDA321L, 0x05184980L,
+ 7, 0x37CDA321L, 0x58ED2602L,
+ 8, 0x37CCA321L, 0x2564B2F5L,
+ 8, 0x37CCA321L, 0x5C978225L,
+ 9, 0x3F977CF3L, 0x1F6C4283L,
+ 9, 0x3F977CF3L, 0xF833F3AFL,
+ 10, 0xBF989013L, 0x8F256EB2L,
+ 0, 0L, 0L
};
struct CHKFONT {
- char f_name[MAX_NAME]; /* font name with point */
- unsigned long oldd; /* old checksum */
- unsigned long neww; /* new checksum */
+ char f_name[MAX_NAME]; /* font name with point */
+ unsigned long oldd; /* old checksum */
+ unsigned long neww; /* new checksum */
};
struct CHKFONT chkfont[MAX_FONT];
@@ -148,18 +148,18 @@
*/
struct NEWPOINT {
- char *font_name; /* font name */
- int top; /* smallest point */
- int end; /* largest point */
+ char *font_name; /* font name */
+ int top; /* smallest point */
+ int end; /* largest point */
};
struct NEWPOINT newpoint[] =
{
- "cmbsy", 5, 9,
- "cmcsc", 8, 9,
- "cmex", 7, 9,
- "cmmib", 5, 9,
- "", 0, 0
+ "cmbsy", 5, 9,
+ "cmcsc", 8, 9,
+ "cmex", 7, 9,
+ "cmmib", 5, 9,
+ "", 0, 0
};
/*
@@ -174,18 +174,18 @@
};
struct FONT_ATR {
- /* parameters of font_def; See "TeX:The program". */
- long k, c, s, d;
- int a, l;
- char *n;
+ /* parameters of font_def; See "TeX:The program". */
+ long k, c, s, d;
+ int a, l;
+ char *n;
};
struct VFFONT_ATR {
- /* parameters of font_def; See "TeX:The program". */
- long k, c, d;
- double s;
- int a, l;
- char *n;
+ /* parameters of font_def; See "TeX:The program". */
+ long k, c, d;
+ double s;
+ int a, l;
+ char *n;
};
int mag[] =
@@ -193,10 +193,10 @@
2726, 2986, 3271, 3583, 3925, 4300, 4710, 5160, 32000};
char *font_ext[] = {
- "gf", "pk", "pxl", "far", "gth", NULL
+ "gf", "pk", "pxl", "far", "gth", NULL
};
-#define read_byte(x) (uchar)getc(x)
+#define read_byte(x) (uchar)getc(x)
void usage(void);
char *name_link(char *, char *);
@@ -225,10 +225,10 @@
struct FONT_ATR font;
struct VFFONT_ATR vffont;
-int f_v = -1; /* verbose mode */
-int f_d; /* ignore default data */
-int f_t; /* file_type */
-int n_data; /* number of font_data */
+int f_v = -1; /* verbose mode */
+int f_d; /* ignore default data */
+int f_t; /* file_type */
+int n_data; /* number of font_data */
uint f_type;
long pmag;
long hppp;
@@ -235,19 +235,19 @@
long vppp;
struct FINFO {
- char f_atrib;
- uchar f_time[2];
- uchar f_date[2];
- uchar f_size[4];
- char f_name[14];
- uchar f_pos[4];
+ char f_atrib;
+ uchar f_time[2];
+ uchar f_date[2];
+ uchar f_size[4];
+ char f_name[14];
+ uchar f_pos[4];
};
struct FARDIR {
- char f_name[10];
- uchar f_time[4];
- uchar f_size[4];
- uchar f_pos[4];
+ char f_name[10];
+ uchar f_time[4];
+ uchar f_size[4];
+ uchar f_pos[4];
};
uchar gth_buf[sizeof(struct FINFO)];
@@ -254,19 +254,19 @@
long f_end;
int f_cont;
-int strcmpl(const char *s, const char *t)
+int strcmpl(const char *s, const char *t)
{
- int i;
+ int i;
- i = strlen(t);
- if(strlen(s) < i ) return -1;
- s += strlen(s);
- while(i-- > 0){
- s--;
- if(toupper(*s) != toupper(t[i]))
- return -1;
- }
- return 0;
+ i = strlen(t);
+ if(strlen(s) < i ) return -1;
+ s += strlen(s);
+ while(i-- > 0){
+ s--;
+ if(toupper(*s) != toupper(t[i]))
+ return -1;
+ }
+ return 0;
}
@@ -276,8 +276,8 @@
char *original = p;
while (*p != '\0') {
- *p = tolower(*p);
- ++p;
+ *p = tolower(*p);
+ ++p;
}
return original;
}
@@ -285,1011 +285,1033 @@
int main(int argc, char **argv)
{
- int i, code;
- char *pt;
+ int i, code;
+ char *pt;
- if (argc < 2)
- usage();
- for (i = 1; i < argc - 1; i++) {
- if (argv[i][0] != '-')
- usage();
- switch (argv[i][1]) {
- case 'S':
- case 's':
- f_v = 0;
- break;
- case 'c':
- f_v = 1;
- break;
- case 'F':
- f_d = 1;
- case 'f':
- get_list(argv[i] + 2);
- break;
- case 'd':
- f_t = -1;
- break;
- case 't':
- f_t = 1;
- break;
- case 'p':
- f_t = 2;
- break;
- default:
- usage();
- }
- }
+ if (argc < 2)
+ usage();
+ for (i = 1; i < argc - 1; i++) {
+ if (argv[i][0] != '-')
+ usage();
+ switch (argv[i][1]) {
+ case 'S':
+ case 's':
+ f_v = 0;
+ break;
+ case 'c':
+ f_v = 1;
+ break;
+ case 'F':
+ f_d = 1;
+ case 'f':
+ get_list(argv[i] + 2);
+ break;
+ case 'd':
+ f_t = -1;
+ break;
+ case 't':
+ f_t = 1;
+ break;
+ case 'p':
+ f_t = 2;
+ break;
+ default:
+ usage();
+ }
+ }
- /* check extension */
- if (!f_t){
- pt = argv[argc-1];
- i = strlen(pt);
- while(--i > 0){
- if( pt[i] == '.' ) break;
- if( pt[i] == '\\' || pt[i] == '/' || pt[i] == ':' ){
- i = 1;
- }
- }
- if (i > 0){
- pt += i+1;
- if( strcmpl(pt, "dvi") == 0 ) f_t = -1;
- else{
- if( strcmpl(pt, "tfm") == 0 || strcmpl(pt, "ofm") == 0 ) f_t = 1;
- else{
- if( strcmpl(pt, "vf") == 0 ) f_t = 2; /* ovf is also included */
- else{
- for(i = 0; font_ext[i]; i++){
- if( strcmpl(pt, font_ext[i]) == 0 ){
- f_t = 2;
- break;
- }
- }
- }
- }
- }
- }
- }
- if(f_t == -1) f_t = 0;
- strcpy(filename, dvi_info.file_name = argv[argc - 1]);
- if (f_t != PXL_FILE && strchr(argv[argc - 1], '.') == NULL)
- dvi_info.file_name = name_link(argv[argc - 1],
- (f_t) ? "tfm" : "dvi");
- if ((dvi_info.file_ptr = fopen(dvi_info.file_name, "rb")) == NULL) {
- fprintf(stderr, "Cannot find %s\n", dvi_info.file_name);
- exit(255);
- }
- if (f_t != DVI_FILE) {
- font.n = dvi_info.file_name;
- if (f_t == TFM_FILE)
- tfm_define(dvi_info.file_ptr);
- else {
- if (chk_font_file(dvi_info.file_ptr)) {
- pxl_define(dvi_info.file_ptr);
- if (f_t == VF_FILE) {
- f_t = VF_FILE_MAP;
- code = read_byte(dvi_info.file_ptr);
- while (code >= FNT_DEF_1 && code < FNT_DEF_1 + 4) {
- vf_define(code, dvi_info.file_ptr);
- check_font();
- code = read_byte(dvi_info.file_ptr);
- }
- }
- }
- }
- }
- else {
- read_post(&dvi_info);
- if (f_v)
- show_dvi_data(&dvi_info);
- get_font_list(&dvi_info);
- if (f_v != -1
- && (f_type & (OLD_EUFM + NEW_EUFM)) == (OLD_EUFM + NEW_EUFM)) {
- fprintf(stderr, "old and new eufm fonts\n");
- exit(251);
- }
- }
- if (f_v != -1) {
- if (f_v != 0)
- printf("\n\n");
- printf("EXIT Code (errorlevel)\t\t= %d\n", f_type);
- if (f_type & OLD_EUFM)
- printf("Old eufm ");
- if (f_type & NEW_EUFM)
- printf("New eufm ");
- if (f_type & OLD_FONT)
- printf("Old font ");
- if (f_type & (NEW_FONT | NEW_POINT))
- printf("New font");
- if (f_type == 0)
- printf("No AMS Font");
- }
- printf("\n");
- exit(f_type);
+ /* check file extension */
+ if (!f_t){
+ pt = argv[argc-1];
+ i = strlen(pt);
+ while(--i > 0){
+ if( pt[i] == '.' ) break;
+ if( pt[i] == '\\' || pt[i] == '/' || pt[i] == ':' ){
+ i = 1;
+ }
+ }
+ if (i > 0){
+ pt += i+1;
+ if( strcmpl(pt, "dvi") == 0 )
+ f_t = -1;
+ else{
+ if( strcmpl(pt, "tfm") == 0 || strcmpl(pt, "ofm") == 0 )
+ f_t = 1;
+ else{
+ if( strcmpl(pt, "vf") == 0 )
+ f_t = 2; /* ovf is also included */
+ else{
+ for(i = 0; font_ext[i]; i++){
+ if( strcmpl(pt, font_ext[i]) == 0 ){
+ f_t = 2;
+ break;
+ }
+ }
+ }
+ }
+ }
+ }
+ }
+ if(f_t == -1) f_t = 0;
+ strcpy(filename, dvi_info.file_name = argv[argc - 1]);
+ if (f_t != PXL_FILE && strchr(argv[argc - 1], '.') == NULL)
+ dvi_info.file_name = name_link(argv[argc - 1],
+ (f_t) ? "tfm" : "dvi");
+ if ((dvi_info.file_ptr = fopen(dvi_info.file_name, "rb")) == NULL) {
+ fprintf(stderr, "Cannot find %s\n", dvi_info.file_name);
+ exit(255);
+ }
+ if (f_t != DVI_FILE) {
+ font.n = dvi_info.file_name;
+ if (f_t == TFM_FILE)
+ tfm_define(dvi_info.file_ptr);
+ else {
+ if (chk_font_file(dvi_info.file_ptr)) {
+ pxl_define(dvi_info.file_ptr);
+ if (f_t == VF_FILE) {
+ f_t = VF_FILE_MAP;
+ code = read_byte(dvi_info.file_ptr);
+ while (code >= FNT_DEF_1 && code < FNT_DEF_1 + 4) {
+ vf_define(code, dvi_info.file_ptr);
+ check_font();
+ code = read_byte(dvi_info.file_ptr);
+ }
+ }
+ }
+ }
+ }
+ else {
+ read_post(&dvi_info);
+ if (f_v)
+ show_dvi_data(&dvi_info);
+ get_font_list(&dvi_info);
+ if (f_v != -1
+ && (f_type & (OLD_EUFM + NEW_EUFM)) == (OLD_EUFM + NEW_EUFM)) {
+ fprintf(stderr, "old and new eufm fonts\n");
+ exit(251);
+ }
+ }
+ if (f_v != -1) {
+ if (f_v != 0)
+ printf("\n\n");
+ printf("EXIT Code (errorlevel)\t\t= %d\n", f_type);
+ if (f_type & OLD_EUFM)
+ printf("Old eufm ");
+ if (f_type & NEW_EUFM)
+ printf("New eufm ");
+ if (f_type & OLD_FONT)
+ printf("Old font ");
+ if (f_type & (NEW_FONT | NEW_POINT))
+ printf("New font");
+ if (f_type == 0)
+ printf("No AMS Font");
+ }
+ printf("\n");
+ exit(f_type);
}
int chk_font_file(FILE * fp)
{
- int i, f_num;
- long start;
- struct FINFO *finfo;
- struct FARDIR *fardir;
+ int i, f_num;
+ long start;
+ struct FINFO *finfo;
+ struct FARDIR *fardir;
- finfo = (struct FINFO *)gth_buf;
- fardir = (struct FARDIR *)gth_buf;
+ finfo = (struct FINFO *)gth_buf;
+ fardir = (struct FARDIR *)gth_buf;
- fread(gth_buf, sizeof(struct FINFO), 1, fp);
+ fread(gth_buf, sizeof(struct FINFO), 1, fp);
- if (strcmp(gth_buf + 8, "gather") == 0)
- goto gth;
+ if (strcmp(gth_buf + 8, "gather") == 0)
+ goto gth;
- fseek(fp, -8L, SEEK_END);
- f_num = read_uint(fp);
- start = read_long(fp);
- if (read_uint(fp) != (int)('f' + 'o' + 'n' + 't' + 'a' + 'r' + 'c' + 'h' + 'i' + 'v' + 'e')) {
- fseek(fp, 0L, SEEK_SET);
- return (1);
- }
- /* FAR file */
- if (f_v){
- f_cont = 1;
- printf("\t\"%s\" is a FAR file which contains...\n", filename);
- }
- while (f_num-- > 0) {
- if (f_v)
- printf("\n");
- fseek(fp, start, SEEK_SET);
- fread((char *)fardir, sizeof(struct FARDIR), 1, fp);
+ fseek(fp, -8L, SEEK_END);
+ f_num = read_uint(fp);
+ start = read_long(fp);
+ if (read_uint(fp) != (int)('f' + 'o' + 'n' + 't' + 'a' + 'r' + 'c' + 'h' + 'i' + 'v' + 'e')) {
+ fseek(fp, 0L, SEEK_SET);
+ return (1);
+ }
+ /* FAR file */
+ if (f_v){
+ f_cont = 1;
+ printf("\t\"%s\" is a FAR file which contains...\n", filename);
+ }
+ while (f_num-- > 0) {
+ if (f_v)
+ printf("\n");
+ fseek(fp, start, SEEK_SET);
+ fread((char *)fardir, sizeof(struct FARDIR), 1, fp);
- start = ftell(fp);
- font.n = fardir->f_name;
- f_end = to_long(fardir->f_pos) + to_long(fardir->f_size);
- fseek(fp, to_long(fardir->f_pos), SEEK_SET);
- pxl_define(fp);
- if (f_v)
- printf("\n");
- }
- return (0);
+ start = ftell(fp);
+ font.n = fardir->f_name;
+ f_end = to_long(fardir->f_pos) + to_long(fardir->f_size);
+ fseek(fp, to_long(fardir->f_pos), SEEK_SET);
+ pxl_define(fp);
+ if (f_v)
+ printf("\n");
+ }
+ return (0);
- gth: /* GTH file */
- if (f_v){
- f_cont = 1;
- printf("\t\"%s\" is a GTH file which contains...\n", filename);
- }
- start = gth_buf[0] + (gth_buf[1] << 8) + (gth_buf[2] << 16)
+ gth: /* GTH file */
+ if (f_v){
+ f_cont = 1;
+ printf("\t\"%s\" is a GTH file which contains...\n", filename);
+ }
+ start = gth_buf[0] + (gth_buf[1] << 8) + (gth_buf[2] << 16)
+ (gth_buf[3] << 24);
- f_num = gth_buf[4] + (gth_buf[5]<< 8);
- while (f_num-- > 0) {
- if (f_v)
- printf("\n");
- fseek(fp, start, SEEK_SET);
- fread(gth_buf, sizeof(struct FINFO), 1, fp);
+ f_num = gth_buf[4] + (gth_buf[5]<< 8);
+ while (f_num-- > 0) {
+ if (f_v)
+ printf("\n");
+ fseek(fp, start, SEEK_SET);
+ fread(gth_buf, sizeof(struct FINFO), 1, fp);
- start = ftell(fp);
- font.n = finfo->f_name;
- printf("%s:%d(%d)\n",
- font.n, to_long(finfo->f_pos), to_long(finfo->f_size));
- f_end = to_long(finfo->f_pos) + to_long(finfo->f_size);
- fseek(fp, to_long(finfo->f_pos), SEEK_SET);
- pxl_define(fp);
- if (f_v)
- printf("\n");
- }
- return (0);
+ start = ftell(fp);
+ font.n = finfo->f_name;
+ printf("%s:%d(%d)\n",
+ font.n, to_long(finfo->f_pos), to_long(finfo->f_size));
+ f_end = to_long(finfo->f_pos) + to_long(finfo->f_size);
+ fseek(fp, to_long(finfo->f_pos), SEEK_SET);
+ pxl_define(fp);
+ if (f_v)
+ printf("\n");
+ }
+ return (0);
}
void show_dvi_data(DVIFILE_INFO *dvi)
{
- int len, x, y;
- long s_width, s_hight;
+ int len, x, y;
+ long s_width, s_hight;
- printf("dvi file name\t\t\t= %s\n", dvi->file_name);
- fseek(dvi->file_ptr, 14L, SEEK_SET),
- len = (uchar)read_byte(dvi->file_ptr);
- printf("comment\t\t\t\t=%s\n", read_str(dvi->file_ptr, len));
- printf("factor converting to 10^{-5}m\t= %ld/%ld\n",
- dvi->num, dvi->den);
- printf("magnification\t\t\t= %ld\n", dvi->mag);
- printf("maximum width\t\t\t= %ld scaled points = %ld points\n",
- dvi->u, (dvi->u + HALF_POINT) >> 16);
- printf("maximum height+depth\t\t= %ld scaled points = %ld points\n",
- dvi->l, (dvi->l + HALF_POINT) >> 16);
- printf("maximum stack depth\t\t= %d\n", dvi->stack_depth);
- printf("number of pages\t\t\t= %d\n", dvi->total_page);
- s_width = ((dvi->u >> 6) * 2540) / 7227; /* scated 2^(-10) mm */
- s_hight = ((dvi->l >> 6) * 2540) / 7227; /* scaled 2^(-10) mm */
- x = (s_width + 512) / 1024;
- y = (s_hight + 512) / 1024;
- printf("page size\t\t\t= %2d.%d cm x %2d.%d cm\n",
- x / 10, x % 10, y / 10, y % 10);
- s_width = s_width * dvi->mag / 1000;
- s_hight = s_hight * dvi->mag / 1000;
- x = (s_width + 512) / 1024;
- y = (s_hight + 512) / 1024;
- printf("page size magnificated\t\t= %2d.%d cm x %2d.%d cm",
- x / 10, x % 10, y / 10, y % 10);
+ printf("dvi file name\t\t\t= %s\n", dvi->file_name);
+ fseek(dvi->file_ptr, 14L, SEEK_SET),
+ len = (uchar)read_byte(dvi->file_ptr);
+ printf("comment\t\t\t\t=%s\n", read_str(dvi->file_ptr, len));
+ printf("factor converting to 10^{-5}m\t= %ld/%ld\n",
+ dvi->num, dvi->den);
+ printf("magnification\t\t\t= %ld\n", dvi->mag);
+ printf("maximum width\t\t\t= %ld scaled points = %ld points\n",
+ dvi->u, (dvi->u + HALF_POINT) >> 16);
+ printf("maximum height+depth\t\t= %ld scaled points = %ld points\n",
+ dvi->l, (dvi->l + HALF_POINT) >> 16);
+ printf("maximum stack depth\t\t= %d\n", dvi->stack_depth);
+ printf("number of pages\t\t\t= %d\n", dvi->total_page);
+ s_width = ((dvi->u >> 6) * 2540) / 7227; /* scated 2^(-10) mm */
+ s_hight = ((dvi->l >> 6) * 2540) / 7227; /* scaled 2^(-10) mm */
+ x = (s_width + 512) / 1024;
+ y = (s_hight + 512) / 1024;
+ printf("page size\t\t\t= %2d.%d cm x %2d.%d cm\n",
+ x / 10, x % 10, y / 10, y % 10);
+ s_width = s_width * dvi->mag / 1000;
+ s_hight = s_hight * dvi->mag / 1000;
+ x = (s_width + 512) / 1024;
+ y = (s_hight + 512) / 1024;
+ printf("page size magnificated\t\t= %2d.%d cm x %2d.%d cm",
+ x / 10, x % 10, y / 10, y % 10);
}
int check_mag(int scale)
{
- int i;
+ int i;
- for (i = 0; scale > mag[i] + 1; i++);
- if (scale + 1 > mag[i])
- return (i + 1);
- return (-1);
+ for (i = 0; scale > mag[i] + 1; i++);
+ if (scale + 1 > mag[i])
+ return (i + 1);
+ return (-1);
}
void check_font(void)
{
- uchar point;
- char *pt;
- int ratio, cmag;
- int j;
- int f_point;
+ uchar point;
+ char *pt;
+ int ratio, cmag;
+ int j;
+ int f_point;
- if (f_v) {
- if (f_t != VF_FILE_MAP) {
- if (f_t == DVI_FILE)
- printf("\n\nFont %ld\n", font.k);
- printf("\tchecksum\t\t= %08lX\n", font.c);
- if (f_t != DVI_FILE)
- printf("\tdesign size\t\t= %ld 2^{-20} points = %ld points",
- font.d, font.d >> 20);
- else
- printf("\tdesign size\t\t=%9ld scaled points =%3ld points",
- font.d, font.d >> 16);
- }
- switch (f_t) {
+ if (f_v) {
+ if (f_t != VF_FILE_MAP) {
+ if (f_t == DVI_FILE)
+ printf("\n\nFont %ld\n", font.k);
+ printf("\tchecksum\t\t= %08lX\n", font.c);
+ if (f_t != DVI_FILE)
+ printf("\tdesign size\t\t= %ld 2^{-20} points = %ld points",
+ font.d, font.d >> 20);
+ else
+ printf("\tdesign size\t\t=%9ld scaled points =%3ld points",
+ font.d, font.d >> 16);
+ }
+ switch (f_t) {
- case (VF_FILE_MAP):
- printf("\n\n\tMapped Font %ld\n", vffont.k);
- // printf("\t\tchecksum\t= %08lX\n", vffont.c); /* always zero, we can't get it without tfm */
- printf("\t\tfont dsize\t= %ld 2^{-20} points = %ld points", vffont.d, vffont.d/(1<<20));
- printf("\n\t\tfont at\t\t= %9.6lf", vffont.s/(1<<20));
- printf("\n\t\tfont name\t= %s", vffont.n);
- break;
+ case (VF_FILE_MAP):
+ printf("\n\n\tMapped Font %ld\n", vffont.k);
+ // printf("\t\tchecksum\t= %08lX\n", vffont.c); /* always zero, we can't get it without tfm */
+ printf("\t\tfont dsize\t= %ld 2^{-20} points = %ld points", vffont.d, vffont.d/(1<<20));
+ printf("\n\t\tfont at\t\t= %9.6lf", vffont.s/(1<<20));
+ printf("\n\t\tfont name\t= %s", vffont.n);
+ break;
- case (VF_FILE):
- break;
+ case (VF_FILE):
+ break;
- case (PK_FILE):
- printf("\n\thorizontal\t\t= %ld 2^{-16} dots/point = %ld dpi",
- hppp, ((((hppp >> 4) * 7227) >> 12) + 49) / 100);
- printf("\n\tvertical\t\t= %ld 2^{-16} dots/point "
- "= %ld dpi\n\t\t\t\t",
- vppp, ((((vppp >> 4) * 7227) >> 12) + 49) / 100);
- break;
+ case (PK_FILE):
+ printf("\n\thorizontal\t\t= %ld 2^{-16} dots/point = %ld dpi",
+ hppp, ((((hppp >> 4) * 7227) >> 12) + 49) / 100);
+ printf("\n\tvertical\t\t= %ld 2^{-16} dots/point "
+ "= %ld dpi\n\t\t\t\t",
+ vppp, ((((vppp >> 4) * 7227) >> 12) + 49) / 100);
+ break;
- case (PXL_FILE):
- printf("\n\tmagnification\t\t= %ld (%ld dpi)\n\t\t\t\t",
- pmag, (pmag + 2) / 5);
- break;
+ case (PXL_FILE):
+ printf("\n\tmagnification\t\t= %ld (%ld dpi)\n\t\t\t\t",
+ pmag, (pmag + 2) / 5);
+ break;
- case (TFM_FILE):
- printf("\n\t\t\t\t");
- break;
+ case (TFM_FILE):
+ printf("\n\t\t\t\t");
+ break;
- case (DVI_FILE):
- printf("\n\tspace size\t\t=%9ld scaled points =%3ld points",
- font.s, font.s >> 16);
- ratio = 1000;
- cmag = 0;
- if (font.d > font.s)
- ratio = (font.d * 100L + (font.s / 20L)) / (font.s / 10L);
- else if (font.s > font.d)
- ratio = (font.s * 100L + (font.d / 20L)) / (font.d / 10L);
- if (ratio != 1000)
- cmag = check_mag(ratio);
- if (cmag > 0) {
- printf("\n\tmagnification\t\t= %smagstep%d%s",
- (font.d > font.s) ? "-" : "+", cmag / 2, (cmag & 1) ? ".5" : "");
- }
- else if (cmag < 0)
- printf("\n\tmagnification\t\t= %d",
- (font.d > font.s) ? ((int)((1000000L + ratio) / ratio)) : ratio);
- printf("\n\tfont name\t\t= %s", font.n);
- break;
- }
- }
- if (f_v == -1)
- return;
- for (j = 0; j < n_data; j++) {
- if (strcmp(chkfont[j].f_name, font.n) == 0) {
- if (chkfont[j].oldd == 0 || chkfont[j].oldd == font.c) {
- type("Old font");
- f_type |= OLD_FONT;
- return;
- }
- if (chkfont[j].neww == 0 || chkfont[j].neww == font.c) {
- type("New font");
- f_type |= NEW_FONT;
- return;
- }
- }
- }
- if (f_d)
- return;
+ case (DVI_FILE):
+ printf("\n\tspace size\t\t=%9ld scaled points =%3ld points",
+ font.s, font.s >> 16);
+ ratio = 1000;
+ cmag = 0;
+ if (font.d > font.s)
+ ratio = (font.d * 100L + (font.s / 20L)) / (font.s / 10L);
+ else if (font.s > font.d)
+ ratio = (font.s * 100L + (font.d / 20L)) / (font.d / 10L);
+ if (ratio != 1000)
+ cmag = check_mag(ratio);
+ if (cmag > 0) {
+ printf("\n\tmagnification\t\t= %smagstep%d%s",
+ (font.d > font.s) ? "-" : "+", cmag / 2, (cmag & 1) ? ".5" : "");
+ }
+ else if (cmag < 0)
+ printf("\n\tmagnification\t\t= %d",
+ (font.d > font.s) ? ((int)((1000000L + ratio) / ratio)) : ratio);
+ printf("\n\tfont name\t\t= %s", font.n);
+ break;
+ }
+ }
+ if (f_v == -1)
+ return;
+ for (j = 0; j < n_data; j++) {
+ if (strcmp(chkfont[j].f_name, font.n) == 0) {
+ if (chkfont[j].oldd == 0 || chkfont[j].oldd == font.c) {
+ type("Old font");
+ f_type |= OLD_FONT;
+ return;
+ }
+ if (chkfont[j].neww == 0 || chkfont[j].neww == font.c) {
+ type("New font");
+ f_type |= NEW_FONT;
+ return;
+ }
+ }
+ }
+ if (f_d)
+ return;
- pt = font.n + font.a + font.l - 1;
- while (*pt >= '0' && *pt <= '9')
- pt--;
- point = atoi(++pt);
- *pt = 0;
+ pt = font.n + font.a + font.l - 1;
+ while (*pt >= '0' && *pt <= '9')
+ pt--;
+ point = atoi(++pt);
+ *pt = 0;
- if (strcmp(font.n, "eufm") == 0) {
- j = f_point = 0;
- while (eufm[j].point != 0) {
- if (eufm[j].point == point) {
- f_point = 1;
- if (eufm[j].oldd == font.c) {
- f_type |= OLD_EUFM;
- type("Old AMSTeX");
- return;
- }
- else {
- if (eufm[j].neww == font.c) {
- f_type |= NEW_EUFM;
- type("AMSTeX 2.0 or newer"); /* V2.2 is available */
- return;
- }
- }
- }
- j++;
- }
- f_type |= BAD_EUFM;
- if (f_v)
- type(
- (f_point) ? "unknown checksum" : "unknown point size");
- return;
- }
- for (j = 0; oldfont[j][0] != 0; j++) {
- if (strcmp(font.n, oldfont[j]) == 0) {
- f_type |= OLD_FONT;
- type("Old AMS Font");
- return;
- }
- }
+ if (strcmp(font.n, "eufm") == 0) {
+ j = f_point = 0;
+ while (eufm[j].point != 0) {
+ if (eufm[j].point == point) {
+ f_point = 1;
+ if (eufm[j].oldd == font.c) {
+ f_type |= OLD_EUFM;
+ type("Old AMSTeX");
+ return;
+ }
+ else {
+ if (eufm[j].neww == font.c) {
+ f_type |= NEW_EUFM;
+ type("AMSTeX 2.0 or newer"); /* V2.2 is available */
+ return;
+ }
+ }
+ }
+ j++;
+ }
+ f_type |= BAD_EUFM;
+ if (f_v)
+ type(
+ (f_point) ? "unknown checksum" : "unknown point size");
+ return;
+ }
+ for (j = 0; oldfont[j][0] != 0; j++) {
+ if (strcmp(font.n, oldfont[j]) == 0) {
+ f_type |= OLD_FONT;
+ type("Old AMS Font");
+ return;
+ }
+ }
- for (j = 0; newfont[j][0] != 0; j++) {
- if (strcmp(font.n, newfont[j]) == 0) {
- f_type |= NEW_FONT;
- type("New AMS Font");
- return;
- }
- }
+ for (j = 0; newfont[j][0] != 0; j++) {
+ if (strcmp(font.n, newfont[j]) == 0) {
+ f_type |= NEW_FONT;
+ type("New AMS Font");
+ return;
+ }
+ }
- for (j = 0; newpoint[j].font_name[0] != 0; j++) {
- if (strcmp(font.n, newpoint[j].font_name) == 0) {
- if (newpoint[j].top <= point && newpoint[j].end >= point) {
- f_type |= NEW_POINT;
- type("New AMS Font");
- }
- return;
- }
- }
+ for (j = 0; newpoint[j].font_name[0] != 0; j++) {
+ if (strcmp(font.n, newpoint[j].font_name) == 0) {
+ if (newpoint[j].top <= point && newpoint[j].end >= point) {
+ f_type |= NEW_POINT;
+ type("New AMS Font");
+ }
+ return;
+ }
+ }
}
-char *
- name_link(char *base, char *ext)
- /* combine basename and extension.
- */
+char *name_link(char *base, char *ext)
+ /* combine basename and extension. */
{
- char *name;
- int base_len;
+ char *name;
+ int base_len;
- base_len = strlen(base);
- name = (char *)malloc(base_len + 5);
- strcpy(name, base);
- name[base_len] = '.';
- strcpy(name + base_len + 1, ext);
- return (name);
+ base_len = strlen(base);
+ name = (char *)malloc(base_len + 5);
+ strcpy(name, base);
+ name[base_len] = '.';
+ strcpy(name + base_len + 1, ext);
+ return (name);
}
void read_post(DVIFILE_INFO *dvi)
- /* read data from POSTAMBLE.
- */
+ /* read data from POSTAMBLE. */
{
- long endofs;
- int code;
+ long endofs;
+ int code;
- if ((uchar)read_byte(dvi->file_ptr) != PRE ||
- (uchar)read_byte(dvi->file_ptr) != ID) {
- err:fprintf(stderr, "%s is not correct DVI file\n", dvi->file_name);
- exit(254);
- }
- for (endofs = -3L; fseek(dvi->file_ptr, endofs, SEEK_END),
- (code = (uchar)read_byte(dvi->file_ptr)) != ID; endofs--)
- /* Search id number
- */
- if (code == ID_PTEX) {
- printf("This is extended DVI file [ID = 3] for pTeX.\n");
- break;
- }
- else if (code == EOF || code != END_DVI)
- goto err;
+ if ((uchar)read_byte(dvi->file_ptr) != PRE ||
+ (uchar)read_byte(dvi->file_ptr) != ID) {
+ err:
+ fprintf(stderr, "%s is not correct DVI file\n", dvi->file_name);
+ exit(254);
+ }
+ for (endofs = -3L; fseek(dvi->file_ptr, endofs, SEEK_END),
+ (code = (uchar)read_byte(dvi->file_ptr)) != ID; endofs--)
+ /* Search id number */
+ if (code == ID_PTEX) {
+ printf("This is extended DVI file [ID = 3] for pTeX.\n");
+ break;
+ }
+ else if (code == EOF || code != END_DVI)
+ goto err;
- fseek(dvi->file_ptr, endofs - 4L, SEEK_END);
- if ((dvi->post = read_long(dvi->file_ptr)) <= 0)
- goto err;
- /* Read the position of POSTAMBLE */
+ fseek(dvi->file_ptr, endofs - 4L, SEEK_END);
+ if ((dvi->post = read_long(dvi->file_ptr)) <= 0)
+ goto err;
+ /* Read the position of POSTAMBLE */
- fseek(dvi->file_ptr, dvi->post, SEEK_SET);
- /* Set file-ptr at POSTAMBLE */
+ fseek(dvi->file_ptr, dvi->post, SEEK_SET);
+ /* Set file-ptr at POSTAMBLE */
- if ((uchar)read_byte(dvi->file_ptr) != POST)
- goto err;
+ if ((uchar)read_byte(dvi->file_ptr) != POST)
+ goto err;
- if ((dvi->last_bop = read_long(dvi->file_ptr)) <= 0)
- goto err;
+ if ((dvi->last_bop = read_long(dvi->file_ptr)) <= 0)
+ goto err;
- dvi->num = read_long(dvi->file_ptr);
- dvi->den = read_long(dvi->file_ptr);
- dvi->mag = read_long(dvi->file_ptr);
+ dvi->num = read_long(dvi->file_ptr);
+ dvi->den = read_long(dvi->file_ptr);
+ dvi->mag = read_long(dvi->file_ptr);
- dvi->l = (SCALED_PT)read_long(dvi->file_ptr);
- dvi->u = (SCALED_PT)read_long(dvi->file_ptr);
+ dvi->l = (SCALED_PT)read_long(dvi->file_ptr);
+ dvi->u = (SCALED_PT)read_long(dvi->file_ptr);
- dvi->stack_depth = read_uint(dvi->file_ptr);
- dvi->total_page = read_uint(dvi->file_ptr);
+ dvi->stack_depth = read_uint(dvi->file_ptr);
+ dvi->total_page = read_uint(dvi->file_ptr);
- if (dvi->num <= 0 || dvi->den <= 0 || dvi->mag <= 0)
- goto err;
+ if (dvi->num <= 0 || dvi->den <= 0 || dvi->mag <= 0)
+ goto err;
- if (dvi->stack_depth < 0 || dvi->total_page <= 0)
- goto err;
+ if (dvi->stack_depth < 0 || dvi->total_page <= 0)
+ goto err;
}
void get_font_list(DVIFILE_INFO *dvi)
{
- int code, count;
+ int code, count;
- fseek(dvi->file_ptr, dvi->post + 29, SEEK_SET);
- while ((code = getc(dvi->file_ptr)) != POST_POST)
- if (code >= FNT_DEF_1 && code < FNT_DEF_1 + 4) {
- font_define(code, dvi->file_ptr);
- check_font();
- }
- else if (code != NOP) {
- fprintf(stderr, "Command error code:%d\n", code);
- exit(253);
- }
+ fseek(dvi->file_ptr, dvi->post + 29, SEEK_SET);
+ while ((code = getc(dvi->file_ptr)) != POST_POST)
+ if (code >= FNT_DEF_1 && code < FNT_DEF_1 + 4) {
+ font_define(code, dvi->file_ptr);
+ check_font();
+ }
+ else if (code != NOP) {
+ fprintf(stderr, "Command error code:%d\n", code);
+ exit(253);
+ }
}
void tfm_define(FILE * fp)
{
- int i, ch, nt, ofmlevel;
- long lf, lh, bc, ec, nw, nh, nd, ni, nl, nk, ne, np, fontdir, sum, size,
- headerlength, topchar, topwidth, topheight, topdepth, topitalic, ncw, nlw, neew,
- nco, npc, nki, nwi, nkf, nwf, nkm, nwm, nkr, nwr, nkg, nwg, nkp, nwp;
- char *s, *t, *u;
+ int i, x, ch, nt, tfmver; /* tfmver = OFM level or JFM version */
+ long lf, lh, bc, ec, nw, nh, nd, ni, nl, nk, ne, np, fontdir, sum, size,
+ headerlength, topchar, topwidth, topheight, topdepth, topitalic, ncw, nlw, neew,
+ nco, npc, nki, nwi, nkf, nwf, nkm, nwm, nkr, nwr, nkg, nwg, nkp, nwp;
+ char *s, *t, *u;
- font.n[strlen(font.n) - 4] = 0;
- s = font.n + strlen(font.n);
- while (*--s >= '0' && *s <= '9' && s >= font.n);
- t = s;
- while (*s != ':' && *s != '\\' && *s != '/' && s-- > font.n);
- font.n = s + 1;
- font.a = t - s;
- font.l = 0;
+ font.n[strlen(font.n) - 4] = 0;
+ s = font.n + strlen(font.n);
+ while (*--s >= '0' && *s <= '9' && s >= font.n);
+ t = s;
+ while (*s != ':' && *s != '\\' && *s != '/' && s-- > font.n);
+ font.n = s + 1;
+ font.a = t - s;
+ font.l = 0;
- /* initialize for standard TFM */
- ch = 't';
- u = "";
- nt = 0;
- ofmlevel = 0;
- headerlength = 6;
- topchar = 255;
- fontdir = 0;
- nco = npc = nki = nwi = nkf = nwf = nkm = nwm = nkr = nwr = nkg = nwg = nkp = nwp = 0;
+ /* initialize for standard TFM */
+ ch = 't';
+ u = "";
+ nt = 0;
+ tfmver = 0;
+ headerlength = 6;
+ topchar = 255;
+ fontdir = 0;
+ nco = npc = nki = nwi = nkf = nwf = nkm = nwm = nkr = nwr = nkg = nwg = nkp = nwp = 0;
- if ((i=read_uint(fp)) == 0) { /* (temporary) lf */
- /* assume OFM */
- ch = 'o';
- ofmlevel = read_uint(fp);
- if (ofmlevel == 0)
- headerlength = 14;
- else
- headerlength = 29;
- topchar = 1114111L;
- lf = read_long(fp); /* lf */
- lh = read_long(fp); /* lh */
- }
- else {
- if (i == 11 || i == 9) {
- /* assume JFM */
- ch = 'j';
- if( i == 9 ) u = "(tate)";
- headerlength = 7;
- nt = read_uint(fp); /* nt */
- lf = read_uint(fp); /* lf */
- }
- else {
- /* assume TFM */
- lf = i; /* lf */
- }
- lh = read_uint(fp); /* lh */
- }
+ if ((i=read_uint(fp)) == 0) { /* (temporary) lf */
+ /* assume OFM */
+ ch = 'o';
+ tfmver = read_uint(fp);
+ if (tfmver == 0)
+ headerlength = 14;
+ else
+ headerlength = 29;
+ topchar = 1114111L;
+ lf = read_long(fp); /* lf */
+ lh = read_long(fp); /* lh */
+ }
+ else {
+ if (i == 11 || i == 9) {
+ /* assume JFM */
+ ch = 'j';
+ if( i == 9 ) u = "(tate)";
+ headerlength = 7;
+ nt = read_uint(fp); /* nt */
+ lf = read_uint(fp); /* lf */
+ }
+ else {
+ /* assume TFM */
+ lf = i; /* lf */
+ }
+ lh = read_uint(fp); /* lh */
+ }
- /*
- [OFM format]
- Each entry is a 32-bit integer, non-negative and less than 2^31, and
- bc - 1 <= ec <= 1114111L (cf. 65535 in texmf-dist/doc/omega/base/doc-1.8.tex)
- lf = 14 + lh + 2 * (ec - bc + 1) + nw + nh + nd + ni + 2 * nl + nk + 2 * ne + np (for level 0)
- lf = 29 + lh + ncw + nw + nh + nd + ni + 2 * nl + nk + 2 * ne + np
- + nki + nwi + nkf + nwf + nkm + nwm + nkr + nwr + nkg + nwg + nkp + nwp (for level 1)
- nki + nkf + nkm + nkr + nkg + nkp < 32 (for level 1)
- [JFM format]
- Each entry is a 16-bit integer, non-negative and less than 2^15, and
- 0 <= ec <= 255
- bc = 0
- lf = 7 + nt + lh + (ec - bc + 1) + nw + nh + nd + ni + nl + nk + ng + np
- [TFM format]
- Each entry is a 16-bit integer, non-negative and less than 2^15, and
- bc - 1 <= ec <= 255
- ne <= 256
- lf = 6 + lh + (ec - bc + 1) + nw + nh + nd + ni + nl + nk + ne + np
- */
- if (ch == 'o') {
- bc = read_long(fp); /* bc */
- ec = read_long(fp); /* ec */
- nw = read_long(fp);
- nh = read_long(fp);
- nd = read_long(fp);
- ni = read_long(fp);
- nl = read_long(fp);
- nk = read_long(fp);
- ne = read_long(fp);
- np = read_long(fp);
- fontdir = read_long(fp);
- nlw = 2 * nl;
- neew = 2 * ne;
- topchar = 1114111L;
- topwidth = 1114111L;
- topheight = 255;
- topdepth = 255;
- topitalic = 255;
- if (ofmlevel == 0) {
- ncw = 2 * ( ec - bc + 1 );
- }
- else {
- nco = read_long(fp);
- ncw = read_long(fp);
- npc = read_long(fp);
- nki = read_long(fp);
- nwi = read_long(fp);
- nkf = read_long(fp);
- nwf = read_long(fp);
- nkm = read_long(fp);
- nwm = read_long(fp);
- nkr = read_long(fp);
- nwr = read_long(fp);
- nkg = read_long(fp);
- nwg = read_long(fp);
- nkp = read_long(fp);
- nwp = read_long(fp);
- }
- }
- else {
- bc = read_uint(fp); /* bc */
- ec = read_uint(fp); /* ec */
- nw = read_uint(fp);
- nh = read_uint(fp);
- nd = read_uint(fp);
- ni = read_uint(fp);
- nl = read_uint(fp);
- nk = read_uint(fp);
- ne = read_uint(fp); /* for JFM, this corresponds to ng instead */
- np = read_uint(fp);
- ncw = ec - bc + 1;
- nlw = nl;
- neew = ne;
- topwidth = 255;
- topheight = 15;
- topdepth = 15;
- topitalic = 63;
- }
- if (lf != (headerlength + nt + lh + ncw + nw + nh + nd + ni + nlw + nk + neew
- + np + nki + nwi + nkf + nwf + nkm + nwm + nkr + nwr + nkg + nwg + nkp + nwp)) {
- printf("\n\"%s\" is not a %cfm file\n", filename, ch);
- exit(254);
- }
- if (ch == 'j') {
- if (bc != 0 || ec < 0 || ec > topchar) {
- printf("\nThe %cfm file \"%s\" has illegal character code range: %ld -> %ld\n", ch, filename, bc, ec);
- exit(254);
- }
- }
- else {
- if (bc < 0 || bc > ec + 1 || ec > topchar) {
- printf("\nThe %cfm file \"%s\" has illegal character code range: %ld -> %ld\n", ch, filename, bc, ec);
- exit(254);
- }
- }
+ /*
+ [OFM format]
+ Each entry is a 32-bit integer, non-negative and less than 2^31, and
+ bc - 1 <= ec <= 1114111L (cf. 65535 in texmf-dist/doc/omega/base/doc-1.8.tex)
+ lf = 14 + lh + 2 * (ec - bc + 1) + nw + nh + nd + ni + 2 * nl + nk + 2 * ne + np (for level 0)
+ lf = 29 + lh + ncw + nw + nh + nd + ni + 2 * nl + nk + 2 * ne + np
+ + nki + nwi + nkf + nwf + nkm + nwm + nkr + nwr + nkg + nwg + nkp + nwp (for level 1)
+ nki + nkf + nkm + nkr + nkg + nkp < 32 (for level 1)
+ [JFM format]
+ Each entry is a 16-bit integer, non-negative and less than 2^15, and
+ 0 <= ec <= 255
+ bc = 0
+ lf = 7 + nt + lh + (ec - bc + 1) + nw + nh + nd + ni + nl + nk + ng + np
+ [TFM format]
+ Each entry is a 16-bit integer, non-negative and less than 2^15, and
+ bc - 1 <= ec <= 255
+ ne <= 256
+ lf = 6 + lh + (ec - bc + 1) + nw + nh + nd + ni + nl + nk + ne + np
+ */
+ if (ch == 'o') {
+ bc = read_long(fp); /* bc */
+ ec = read_long(fp); /* ec */
+ nw = read_long(fp);
+ nh = read_long(fp);
+ nd = read_long(fp);
+ ni = read_long(fp);
+ nl = read_long(fp);
+ nk = read_long(fp);
+ ne = read_long(fp);
+ np = read_long(fp);
+ fontdir = read_long(fp);
+ nlw = 2 * nl;
+ neew = 2 * ne;
+ topchar = 1114111L;
+ topwidth = 1114111L;
+ topheight = 255;
+ topdepth = 255;
+ topitalic = 255;
+ if (tfmver == 0) {
+ ncw = 2 * ( ec - bc + 1 );
+ }
+ else {
+ nco = read_long(fp);
+ ncw = read_long(fp);
+ npc = read_long(fp);
+ nki = read_long(fp);
+ nwi = read_long(fp);
+ nkf = read_long(fp);
+ nwf = read_long(fp);
+ nkm = read_long(fp);
+ nwm = read_long(fp);
+ nkr = read_long(fp);
+ nwr = read_long(fp);
+ nkg = read_long(fp);
+ nwg = read_long(fp);
+ nkp = read_long(fp);
+ nwp = read_long(fp);
+ }
+ }
+ else {
+ bc = read_uint(fp); /* bc */
+ ec = read_uint(fp); /* ec */
+ nw = read_uint(fp);
+ nh = read_uint(fp);
+ nd = read_uint(fp);
+ ni = read_uint(fp);
+ nl = read_uint(fp);
+ nk = read_uint(fp);
+ ne = read_uint(fp); /* for JFM, this corresponds to ng instead */
+ np = read_uint(fp);
+ ncw = ec - bc + 1;
+ nlw = nl;
+ neew = ne;
+ topwidth = 255;
+ topheight = 15;
+ topdepth = 15;
+ topitalic = 63;
+ }
+ if (lf != (headerlength + nt + lh + ncw + nw + nh + nd + ni + nlw + nk + neew
+ + np + nki + nwi + nkf + nwf + nkm + nwm + nkr + nwr + nkg + nwg + nkp + nwp)) {
+ printf("\n\"%s\" is not a %cfm file\n", filename, ch);
+ exit(254);
+ }
+ if (ch == 'j') {
+ if (bc != 0 || ec < 0 || ec > topchar) {
+ printf("\nThe %cfm file \"%s\" has illegal character code range: %ld -> %ld\n", ch, filename, bc, ec);
+ exit(254);
+ }
+ }
+ else {
+ if (bc < 0 || bc > ec + 1 || ec > topchar) {
+ printf("\nThe %cfm file \"%s\" has illegal character code range: %ld -> %ld\n", ch, filename, bc, ec);
+ exit(254);
+ }
+ }
#if 0
- /* more strict check */
- long ligsize = 800000L; /* set to 800000 for OFM, 32510 for TFM/JFM */
- if (lh < 2)
- printf("Warning: The header length is only %ld!\n", lh);
- if (nl > ligsize)
- printf("Warning: The lig/kern program is too long!\n");
- if (nw == 0 || nh == 0 || nd == 0 || ni == 0)
- printf("Warning: Incomplete subfiles for character dimensions!");
- if (ch != 'j' && ne > topchar + 1)
- printf("Warning: There are %ld extensible recipes!", ne);
+ /* more strict check */
+ long ligsize = 800000L; /* set to 800000 for OFM, 32510 for TFM/JFM */
+ if (lh < 2)
+ printf("Warning: The header length is only %ld!\n", lh);
+ if (nl > ligsize)
+ printf("Warning: The lig/kern program is too long!\n");
+ if (nw == 0 || nh == 0 || nd == 0 || ni == 0)
+ printf("Warning: Incomplete subfiles for character dimensions!");
+ if (ch != 'j' && ne > topchar + 1)
+ printf("Warning: There are %ld extensible recipes!", ne);
#endif
- if (f_v != 0) {
- if (ch == 'o')
- printf("\t\"%s\" is a %cfm level %d file :%3ld -> %3ld\n",
- font.n, ch, ofmlevel, bc, ec);
- else
- printf("\t\"%s\" is a %cfm%s file :%3ld -> %3ld\n",
- font.n, ch, u, bc, ec);
- }
+ font.c = read_n(fp,4); /* header[0] */
+ font.d = read_long(fp); /* header[1] */
+ if (ch == 'j') { /* check for new features in pTeX p3.8.0 / JFM 2.0 */
+ for (i = 2; i < lh; i++) /* the rest of header */
+ read_long(fp);
+ for (i = 0; i < nt; i++){ /* char_type */
+ read_n(fp,2); x = read_byte(fp); read_byte(fp);
+ if (x>0) tfmver |= 1; /* 3-byte kanji code */
+ }
+ for (i = 0; i < ec-bc+1; i++) /* char_info */
+ read_long(fp);
+ for (i = 0; i < nw+nh+nd+ni; i++) /* width, height, depth, italic */
+ read_long(fp);
+ for (i = 0; i < nl; i++) /* glue_kern */
+ x = read_byte(fp); read_n(fp,3);
+ if (x>0 && x<128) tfmver |= 2; /* SKIP command */
+ if (x>128 && x<=255) tfmver |= 4; /* rearrangement */
+ }
+ fclose(fp);
- font.c = read_n(fp,4); /* header[0] */
- font.d = read_long(fp); /* header[1] */
- fclose(fp);
- check_font();
+ if (f_v != 0) {
+ if (ch == 'o')
+ printf("\t\"%s\" is a %cfm level %d file :%3ld -> %3ld\n",
+ font.n, ch, tfmver, bc, ec);
+ else {
+ printf("\t\"%s\" is a %cfm%s file :%3ld -> %3ld\n",
+ font.n, ch, u, bc, ec);
+ if (ch == 'j' && tfmver > 0) {
+ printf("\t\tNew features in pTeX p3.8.0 / JFM 2.0:\n");
+ if (tfmver & 1) printf("\t\t+ 3-byte kanji code\n");
+ if (tfmver & 2) printf("\t\t+ SKIP command in glue_kern\n");
+ if (tfmver & 4) printf("\t\t+ rearrangement in glue_kern\n");
+ }
+ }
+ }
+ check_font();
}
-#define PK_PRE 247
-#define PK_ID 89
-#define GF_ID 131
-#define VF_ID 202
-#define PKD_ID ('p'+'k'+'d')
-#define PK_POST 245
-#define GF_POST 223
+#define PK_PRE 247
+#define PK_ID 89
+#define GF_ID 131
+#define VF_ID 202
+#define PKD_ID ('p'+'k'+'d')
+#define PK_POST 245
+#define GF_POST 223
-#define VFW_ID ((PK_PRE<<8)+VF_ID)
-#define GFW_ID ((PK_PRE<<8)+GF_ID)
-#define PKW_ID ((PK_PRE<<8)+PK_ID)
-#define PKDW_ID ((PK_PRE<<8)+PKD_ID)
-#define JXL4_0_ID (0x0001)
-#define JXL4_1_ID (0x8B25)
+#define VFW_ID ((PK_PRE<<8)+VF_ID)
+#define GFW_ID ((PK_PRE<<8)+GF_ID)
+#define PKW_ID ((PK_PRE<<8)+PK_ID)
+#define PKDW_ID ((PK_PRE<<8)+PKD_ID)
+#define JXL4_0_ID (0x0001)
+#define JXL4_1_ID (0x8B25)
void pxl_define(FILE * fp)
{
- int i, tmp, ch, code;
- char *type, *s, *t, *u;
- long endofs;
+ int i, tmp, ch, code;
+ char *type, *s, *t, *u;
+ long endofs;
- strlwr(font.n);
- s = u = font.n + strlen(font.n);
- ch = 0;
- while (*s != ':' && *s != '\\' && *s != '/' && *s != '.' &&
- s-- >= font.n);
- if (*s == '.') {
- ch = *(u = s);
- *s = 0;
- }
- s = font.n + strlen(font.n);
- while (*--s >= '0' && *s <= '9' && s >= font.n);
- t = s;
- while (*s != ':' && *s != '\\' && *s != '/' && s-- > font.n);
- font.n = s + 1;
- font.a = t - s;
- font.l = 0;
+ strlwr(font.n);
+ s = u = font.n + strlen(font.n);
+ ch = 0;
+ while (*s != ':' && *s != '\\' && *s != '/' && *s != '.' &&
+ s-- >= font.n);
+ if (*s == '.') {
+ ch = *(u = s);
+ *s = 0;
+ }
+ s = font.n + strlen(font.n);
+ while (*--s >= '0' && *s <= '9' && s >= font.n);
+ t = s;
+ while (*s != ':' && *s != '\\' && *s != '/' && s-- > font.n);
+ font.n = s + 1;
+ font.a = t - s;
+ font.l = 0;
- switch (tmp = read_uint(fp)) {
- case (0):
- switch (tmp = read_uint(fp)) {
- case (1001):
- type = "PXL1001";
- break;
+ switch (tmp = read_uint(fp)) {
+ case (0):
+ switch (tmp = read_uint(fp)) {
+ case (1001):
+ type = "PXL1001";
+ break;
- case (1002):
- type = "PXL1002";
- break;
+ case (1002):
+ type = "PXL1002";
+ break;
- case (1003):
- type = "PXL1003";
- break;
+ case (1003):
+ type = "PXL1003";
+ break;
- default:
- printf("\nUnknown id:0000%04X\n", tmp);
- exit(254);
- }
- if (f_end == 0)
- fseek(fp, -20L, SEEK_END);
- else
- fseek(fp, f_end - 20, SEEK_SET);
- font.c = read_n(fp,4);
- pmag = read_long(fp);
- font.d = read_long(fp);
- break;
+ default:
+ printf("\nUnknown id:0000%04X\n", tmp);
+ exit(254);
+ }
+ if (f_end == 0)
+ fseek(fp, -20L, SEEK_END);
+ else
+ fseek(fp, f_end - 20, SEEK_SET);
+ font.c = read_n(fp,4);
+ pmag = read_long(fp);
+ font.d = read_long(fp);
+ break;
- case (JXL4_0_ID):
- if (read_long(fp) == JXL4_1_ID) {
- type = "JXL4";
- if (f_end == 0)
- fseek(fp, -28L, SEEK_END);
- else
- fseek(fp, f_end - 28, SEEK_END);
- font.c = read_n(fp,4);
- pmag = read_long(fp);
- font.d = read_long(fp);
- }
- else
- goto id_err;
- break;
+ case (JXL4_0_ID):
+ if (read_long(fp) == JXL4_1_ID) {
+ type = "JXL4";
+ if (f_end == 0)
+ fseek(fp, -28L, SEEK_END);
+ else
+ fseek(fp, f_end - 28, SEEK_END);
+ font.c = read_n(fp,4);
+ pmag = read_long(fp);
+ font.d = read_long(fp);
+ }
+ else
+ goto id_err;
+ break;
- case (VFW_ID):
- type = "VF";
- f_t = VF_FILE;
- code = read_byte(fp);
- for (i = 0; i < code; i++)
- read_byte(fp);
- for (i = 0; i < 4; i++)
- font.c += read_byte(fp)<<(8*(3-i));
- for (i = 0; i < 4; i++)
- font.d += read_byte(fp)<<(8*(3-i));
- break;
+ case (VFW_ID):
+ type = "VF";
+ f_t = VF_FILE;
+ code = read_byte(fp);
+ for (i = 0; i < code; i++)
+ read_byte(fp);
+ for (i = 0; i < 4; i++)
+ font.c += read_byte(fp)<<(8*(3-i));
+ for (i = 0; i < 4; i++)
+ font.d += read_byte(fp)<<(8*(3-i));
+ break;
- case (GFW_ID):
- type = "GF";
- for (endofs = -3L; fseek(fp, endofs, SEEK_END),
- (code = (uchar)read_byte(fp)) == GF_POST; endofs--);
- /* Search id number */
- if (code != GF_ID) {
- fprintf(stderr, "This is not correct GF file\n");
- exit(252);
- }
- fseek(fp, endofs - 4, SEEK_END);
- endofs = read_long(fp);
- fseek(fp, endofs + 5, SEEK_SET);
- goto pk3;
+ case (GFW_ID):
+ type = "GF";
+ for (endofs = -3L; fseek(fp, endofs, SEEK_END),
+ (code = (uchar)read_byte(fp)) == GF_POST; endofs--);
+ /* Search id number */
+ if (code != GF_ID) {
+ fprintf(stderr, "This is not correct GF file\n");
+ exit(252);
+ }
+ fseek(fp, endofs - 4, SEEK_END);
+ endofs = read_long(fp);
+ fseek(fp, endofs + 5, SEEK_SET);
+ goto pk3;
- case (PKDW_ID):
- type = "PKD";
- goto pk2;
+ case (PKDW_ID):
+ type = "PKD";
+ goto pk2;
- case (PKW_ID):
- type = "PK";
- pk2:tmp = read_byte(fp);
- while (tmp--)
- (void)read_byte(fp);
- pk3:f_t = PK_FILE;
- font.d = read_long(fp);
- font.c = read_n(fp,4);
- hppp = read_long(fp);
- vppp = read_long(fp);
- break;
+ case (PKW_ID):
+ type = "PK";
+ pk2:tmp = read_byte(fp);
+ while (tmp--)
+ (void)read_byte(fp);
+ pk3:f_t = PK_FILE;
+ font.d = read_long(fp);
+ font.c = read_n(fp,4);
+ hppp = read_long(fp);
+ vppp = read_long(fp);
+ break;
- default:
- id_err:
- printf("\nUnknown id:%04X\n", tmp);
- exit(254);
- }
- if (f_v != 0) {
- *u = ch;
- printf("\t\"%s\" is in %s format\n", font.n, type);
- *u = 0;
- }
- check_font();
+ default:
+ id_err:
+ printf("\nUnknown id:%04X\n", tmp);
+ exit(254);
+ }
+ if (f_v != 0) {
+ *u = ch;
+ printf("\t\"%s\" is in %s format\n", font.n, type);
+ *u = 0;
+ }
+ check_font();
}
void font_define(int code, FILE * dvifile)
{
- int i, len, lenm;
+ int i, len, lenm;
- font.k = read_n(dvifile, code - FNT_DEF_1 + 1);
- font.c = read_n(dvifile,4);
- font.s = read_long(dvifile);
- font.d = read_long(dvifile);
- font.a = read_byte(dvifile);
- font.l = read_byte(dvifile);
+ font.k = read_n(dvifile, code - FNT_DEF_1 + 1);
+ font.c = read_n(dvifile,4);
+ font.s = read_long(dvifile);
+ font.d = read_long(dvifile);
+ font.a = read_byte(dvifile);
+ font.l = read_byte(dvifile);
- if (font.a == EOF || font.l == EOF) {
- fprintf(stderr, "Bad DVI file\n");
- exit(252);
- }
- font.n = read_str(dvifile, font.a + font.l);
+ if (font.a == EOF || font.l == EOF) {
+ fprintf(stderr, "Bad DVI file\n");
+ exit(252);
+ }
+ font.n = read_str(dvifile, font.a + font.l);
}
void vf_define(int code, FILE * vffile)
{
- int i, len, lenm;
+ int i, len, lenm;
- vffont.k = read_n(vffile, code - FNT_DEF_1 + 1);
- vffont.c = read_n(vffile,4);
- vffont.s = read_long(vffile);
- vffont.d = read_long(vffile);
- vffont.a = read_byte(vffile);
- vffont.l = read_byte(vffile);
+ vffont.k = read_n(vffile, code - FNT_DEF_1 + 1);
+ vffont.c = read_n(vffile,4);
+ vffont.s = read_long(vffile);
+ vffont.d = read_long(vffile);
+ vffont.a = read_byte(vffile);
+ vffont.l = read_byte(vffile);
- if (vffont.a == EOF || vffont.l == EOF) {
- fprintf(stderr, "Bad VF file\n");
- exit(252);
- }
- vffont.n = read_str(vffile, vffont.a + vffont.l);
+ if (vffont.a == EOF || vffont.l == EOF) {
+ fprintf(stderr, "Bad VF file\n");
+ exit(252);
+ }
+ vffont.n = read_str(vffile, vffont.a + vffont.l);
}
int read_uint(FILE * fp)
-{ /* read unsigned integer */
- int d;
+{ /* read unsigned integer */
+ int d;
- d = (uchar)getc(fp);
- d = (d << 8) | (uchar)getc(fp);
- return (d);
+ d = (uchar)getc(fp);
+ d = (d << 8) | (uchar)getc(fp);
+ return (d);
}
long read_mit(FILE * fp)
-{ /* read three bytes as long integer */
- long d;
+{ /* read three bytes as long integer */
+ long d;
- d = (uchar)getc(fp);
- if (d > 127)
- d -= 256;
- d = (d << 8) | (uchar)getc(fp);
- d = (d << 8) | (uchar)getc(fp);
- return (d);
+ d = (uchar)getc(fp);
+ if (d > 127)
+ d -= 256;
+ d = (d << 8) | (uchar)getc(fp);
+ d = (d << 8) | (uchar)getc(fp);
+ return (d);
}
long read_long(FILE * fp)
-{ /* read 4 bytes as long integer */
- long d;
+{ /* read 4 bytes as long integer */
+ long d;
- d = (uchar)getc(fp);
- if (d > 127)
- d -= 256;
- d = (d << 8) | (uchar)getc(fp);
- d = (d << 8) | (uchar)getc(fp);
- d = (d << 8) | (uchar)getc(fp);
- return (d);
+ d = (uchar)getc(fp);
+ if (d > 127)
+ d -= 256;
+ d = (d << 8) | (uchar)getc(fp);
+ d = (d << 8) | (uchar)getc(fp);
+ d = (d << 8) | (uchar)getc(fp);
+ return (d);
}
long to_long(uchar *pt)
-{ /* read 4 bytes as long integer */
- long d;
+{ /* read 4 bytes as long integer */
+ long d;
- d = (pt[3] << 8) + pt[2];
- d = (d << 16) + (pt[1] << 8) + pt[0];
- return (d);
+ d = (pt[3] << 8) + pt[2];
+ d = (d << 16) + (pt[1] << 8) + pt[0];
+ return (d);
}
-char *
- read_str(FILE * fp, int len)
+char *read_str(FILE * fp, int len)
{
- char *pt0, *pt;
+ char *pt0, *pt;
- if ((pt = pt0 = (char *)malloc(len + 1)) != NULL) {
- while (len-- > 0)
- *pt++ = getc(fp);
- *pt = '\0';
+ if ((pt = pt0 = (char *)malloc(len + 1)) != NULL) {
+ while (len-- > 0)
+ *pt++ = getc(fp);
+ *pt = '\0';
- }
- return (pt0);
+ }
+ return (pt0);
}
long read_n(FILE * fp, int n)
-{ /* read 1--4 bytes as unsigned long integer */
- ulong d;
+{ /* read 1--4 bytes as unsigned long integer */
+ ulong d;
- d = (uchar)getc(fp);
+ d = (uchar)getc(fp);
- switch (n) {
- case 4:
- d = (d << 8) | (uchar)getc(fp);
- case 3:
- d = (d << 8) | (uchar)getc(fp);
- case 2:
- d = (d << 8) | (uchar)getc(fp);
- }
- return ((long)d);
+ switch (n) {
+ case 4:
+ d = (d << 8) | (uchar)getc(fp);
+ case 3:
+ d = (d << 8) | (uchar)getc(fp);
+ case 2:
+ d = (d << 8) | (uchar)getc(fp);
+ }
+ return ((long)d);
}
long signed_read_n(FILE * fp, int n)
{
- long d;
+ long d;
- d = (uchar)getc(fp);
- if (d > 127)
- d -= 256;
- switch (n) {
- case 4:
- d = (d << 8) | (uchar)getc(fp);
- case 3:
- d = (d << 8) | (uchar)getc(fp);
- case 2:
- d = (d << 8) | (uchar)getc(fp);
- }
- return (d);
+ d = (uchar)getc(fp);
+ if (d > 127)
+ d -= 256;
+ switch (n) {
+ case 4:
+ d = (d << 8) | (uchar)getc(fp);
+ case 3:
+ d = (d << 8) | (uchar)getc(fp);
+ case 2:
+ d = (d << 8) | (uchar)getc(fp);
+ }
+ return (d);
}
void type(char *s)
{
- if (f_v)
- printf(" (%s) ", s);
+ if (f_v)
+ printf(" (%s) ", s);
}
void get_list(char *fname)
{
- FILE *fp;
+ FILE *fp;
- if ((fp = fopen(fname, "r")) == NULL) {
- fprintf(stderr, "Cannot find %s.\n", fname);
- exit(249);
- }
- for (n_data = 0; n_data < MAX_FONT;) {
- if (fgets(buf, BUF_SIZE, fp) == NULL)
- return;
- if (buf[0] == '#' || buf[0] == ';')
- continue;
- if (sscanf(buf, "%15s %X %X",
- chkfont[n_data].f_name,
- &(chkfont[n_data].oldd),
- &(chkfont[n_data].neww)) != 3) {
- fprintf(stderr, "error in %s[%s]\n", fname, buf);
- exit(248);
- }
- if (chkfont[n_data].oldd == chkfont[n_data].neww) {
- fprintf(stderr, "same check sum in %s[%s]\n", fname, buf);
- exit(248);
- }
- n_data++;
- }
- if (n_data >= MAX_FONT) {
- fprintf(stderr, "Too many font data in %s\n", fname);
- exit(248);
- }
+ if ((fp = fopen(fname, "r")) == NULL) {
+ fprintf(stderr, "Cannot find %s.\n", fname);
+ exit(249);
+ }
+ for (n_data = 0; n_data < MAX_FONT;) {
+ if (fgets(buf, BUF_SIZE, fp) == NULL)
+ return;
+ if (buf[0] == '#' || buf[0] == ';')
+ continue;
+ if (sscanf(buf, "%15s %X %X",
+ chkfont[n_data].f_name,
+ &(chkfont[n_data].oldd),
+ &(chkfont[n_data].neww)) != 3) {
+ fprintf(stderr, "error in %s[%s]\n", fname, buf);
+ exit(248);
+ }
+ if (chkfont[n_data].oldd == chkfont[n_data].neww) {
+ fprintf(stderr, "same check sum in %s[%s]\n", fname, buf);
+ exit(248);
+ }
+ n_data++;
+ }
+ if (n_data >= MAX_FONT) {
+ fprintf(stderr, "Too many font data in %s\n", fname);
+ exit(248);
+ }
}
void usage()
{
- fprintf(stderr,
- "\t<<< CHecK DVI/tfm/font file and tell informations of FONTs >>>\n"
- "\t\t\t\tOriginally written by SHIMA, 1990/1992\n"
- "\t\t\t\tVer.%s (%s)\n\n", VERSION, TL_VERSION);
- fprintf(stderr,
- "Usage: chkdvifont [-s] [-c] [-{f|F}<font_data_file>] [-d] dvi_file_name\n"
- " chkdvifont [-s] [-c] [-{f|F}<font_data_file>] [-t] tfm_file_name\n"
- " chkdvifont [-s] [-c] [-{f|F}<font_data_file>] [-p] font_file_name\n\n"
- "Option\t -c: check mode\n"
- "\t -s: silent check mode\n"
- "\t -f: use font_data_file (-F: and ignore default data)\n"
- "\t -d: force DVI mode\n"
- "\t -t: force TFM/OFM mode\n"
- "\t -p: force FONT mode\n"
- "\t (supported formats: vf/ovf/gf/pk/pkd/pxl/gth/far)\n"
- "\t By default, mode is guessed from the file extension.\n\n"
+ fprintf(stderr,
+ "\t<<< CHecK DVI/tfm/font file and tell informations of FONTs >>>\n"
+ "\t\t\t\tOriginally written by SHIMA, 1990/1992\n"
+ "\t\t\t\tVer.%s (%s)\n\n", VERSION, TL_VERSION);
+ fprintf(stderr,
+ "Usage: chkdvifont [-s] [-c] [-{f|F}<font_data_file>] [-d] dvi_file_name\n"
+ " chkdvifont [-s] [-c] [-{f|F}<font_data_file>] [-t] tfm_file_name\n"
+ " chkdvifont [-s] [-c] [-{f|F}<font_data_file>] [-p] font_file_name\n\n"
+ "Option\t -c: check mode\n"
+ "\t -s: silent check mode\n"
+ "\t -f: use font_data_file (-F: and ignore default data)\n"
+ "\t -d: force DVI mode\n"
+ "\t -t: force TFM/OFM mode\n"
+ "\t -p: force FONT mode\n"
+ "\t (supported formats: vf/ovf/gf/pk/pkd/pxl/gth/far)\n"
+ "\t By default, mode is guessed from the file extension.\n\n"
#if 0
- "Input M to see more. Push Return to quit");
- switch (getc(stdin)) {
- case ('M'):
- case ('m'):
- goto show;
- default:
- exit(250);
- }
+ "Input M to see more. Push Return to quit");
+ switch (getc(stdin)) {
+ case ('M'):
+ case ('m'):
+ goto show;
+ default:
+ exit(250);
+ }
exit(1);
show:
- fprintf(stderr, "\n\n"
+ fprintf(stderr, "\n\n"
#endif
- "Errorlevel is the sum of the following number\n"
- "\t 1: cmbsy5-9, cmcsc8-9, cmex7-9, cmmib5-9\n"
- "\t 2: new font: eu??, msam, msbm, wncy??, font_data_file\n"
- "\t 4: new eufm5-10\n"
- "\t 8: unknown eufm\n"
- "\t 16: old font: msxm, msym, amcsc, mcyr, mcyb, font_data_file\n"
- "\t 32: old eufm5-10\n"
- "If errorlevel is larger than 240,\n"
- "\t248: error in font_data_file\n"
- "\t249: cannot find font_data_file\n"
- "\t250: bad parameter\n"
- "\t251: old and new eufm\n"
- "\t252: bad dvi file\n"
- "\t253: error in dvi file\n"
- "\t254: not dvi/tfm file or unknown font ID\n"
- "\t255: cannot find dvi/tfm/font file\n\n"
- "\t\t<<< Example of font_data_file >>>\n"
- "# font_name old_check_sum new_check_sum (in HEX, 0 means existence check)\n"
- "eufm5 0891FD38 246A686B\n"
- "eufm10 BF989013 8F256EB2\n"
- "# The line beginning with # or ; is ignored.\n"
- );
- exit(0);
+ "Errorlevel is the sum of the following number\n"
+ "\t 1: cmbsy5-9, cmcsc8-9, cmex7-9, cmmib5-9\n"
+ "\t 2: new font: eu??, msam, msbm, wncy??, font_data_file\n"
+ "\t 4: new eufm5-10\n"
+ "\t 8: unknown eufm\n"
+ "\t 16: old font: msxm, msym, amcsc, mcyr, mcyb, font_data_file\n"
+ "\t 32: old eufm5-10\n"
+ "If errorlevel is larger than 240,\n"
+ "\t248: error in font_data_file\n"
+ "\t249: cannot find font_data_file\n"
+ "\t250: bad parameter\n"
+ "\t251: old and new eufm\n"
+ "\t252: bad dvi file\n"
+ "\t253: error in dvi file\n"
+ "\t254: not dvi/tfm file or unknown font ID\n"
+ "\t255: cannot find dvi/tfm/font file\n\n"
+ "\t\t<<< Example of font_data_file >>>\n"
+ "# font_name old_check_sum new_check_sum (in HEX, 0 means existence check)\n"
+ "eufm5 0891FD38 246A686B\n"
+ "eufm10 BF989013 8F256EB2\n"
+ "# The line beginning with # or ; is ignored.\n"
+ );
+ exit(0);
}
Modified: trunk/Build/source/texk/dviout-util/chkdvifont.man
===================================================================
--- trunk/Build/source/texk/dviout-util/chkdvifont.man 2019-02-07 01:23:40 UTC (rev 49966)
+++ trunk/Build/source/texk/dviout-util/chkdvifont.man 2019-02-07 12:05:38 UTC (rev 49967)
@@ -1,6 +1,11 @@
-.if t .ds TX T\\h'-0.1667m'\\v'0.20v'E\\v'-0.20v'\\h'-0.125m'X
-.if t .ds LX L\\h'-0.36m'\\v'-0.15v'\\s-2A\\s+2\\h'-0.15m'\\v'0.15v'T\\h'-0.1667m'\\v'0.20v'E\\v'-0.20v'\\h'-0.125m'X
.TH CHKDVIFONT 1
+\"=====================================================================
+.if t .ds TX \fRT\\h'-0.1667m'\\v'0.20v'E\\v'-0.20v'\\h'-0.125m'X\fP
+.if n .ds TX TeX
+.\" LX definition must follow TX so LX can use TX
+.if t .ds LX \fRL\\h'-0.36m'\\v'-0.15v'\s-2A\s0\\h'-0.15m'\\v'0.15v'\fP\*(TX
+.if n .ds LX LaTeX
+\"=====================================================================
.SH NAME
chkdvifont \- CHecK DVI/tfm/font file and tell informations of FONTs
.SH SYNOPSIS
Modified: trunk/Build/source/texk/dviout-util/configure
===================================================================
--- trunk/Build/source/texk/dviout-util/configure 2019-02-07 01:23:40 UTC (rev 49966)
+++ trunk/Build/source/texk/dviout-util/configure 2019-02-07 12:05:38 UTC (rev 49967)
@@ -1,6 +1,6 @@
#! /bin/sh
# Guess values for system-dependent variables and create Makefiles.
-# Generated by GNU Autoconf 2.69 for dviout-util (TeX Live) 20181125.
+# Generated by GNU Autoconf 2.69 for dviout-util (TeX Live) 20190206.
#
# Report bugs to <tex-k at tug.org>.
#
@@ -590,8 +590,8 @@
# Identity of this package.
PACKAGE_NAME='dviout-util (TeX Live)'
PACKAGE_TARNAME='dviout-util--tex-live-'
-PACKAGE_VERSION='20181125'
-PACKAGE_STRING='dviout-util (TeX Live) 20181125'
+PACKAGE_VERSION='20190206'
+PACKAGE_STRING='dviout-util (TeX Live) 20190206'
PACKAGE_BUGREPORT='tex-k at tug.org'
PACKAGE_URL=''
@@ -1332,7 +1332,7 @@
# Omit some internal or obsolete options to make the list less imposing.
# This message is too long to be a string in the A/UX 3.1 sh.
cat <<_ACEOF
-\`configure' configures dviout-util (TeX Live) 20181125 to adapt to many kinds of systems.
+\`configure' configures dviout-util (TeX Live) 20190206 to adapt to many kinds of systems.
Usage: $0 [OPTION]... [VAR=VALUE]...
@@ -1403,7 +1403,7 @@
if test -n "$ac_init_help"; then
case $ac_init_help in
- short | recursive ) echo "Configuration of dviout-util (TeX Live) 20181125:";;
+ short | recursive ) echo "Configuration of dviout-util (TeX Live) 20190206:";;
esac
cat <<\_ACEOF
@@ -1524,7 +1524,7 @@
test -n "$ac_init_help" && exit $ac_status
if $ac_init_version; then
cat <<\_ACEOF
-dviout-util (TeX Live) configure 20181125
+dviout-util (TeX Live) configure 20190206
generated by GNU Autoconf 2.69
Copyright (C) 2012 Free Software Foundation, Inc.
@@ -2180,7 +2180,7 @@
This file contains any messages produced by compilers while
running configure, to aid debugging if configure makes a mistake.
-It was created by dviout-util (TeX Live) $as_me 20181125, which was
+It was created by dviout-util (TeX Live) $as_me 20190206, which was
generated by GNU Autoconf 2.69. Invocation command line was
$ $0 $@
@@ -7867,7 +7867,7 @@
# Define the identity of the package.
PACKAGE='dviout-util--tex-live-'
- VERSION='20181125'
+ VERSION='20190206'
cat >>confdefs.h <<_ACEOF
@@ -13893,7 +13893,7 @@
Report bugs to <bug-libtool at gnu.org>."
lt_cl_version="\
-dviout-util (TeX Live) config.lt 20181125
+dviout-util (TeX Live) config.lt 20190206
configured by $0, generated by GNU Autoconf 2.69.
Copyright (C) 2011 Free Software Foundation, Inc.
@@ -15502,7 +15502,7 @@
# report actual input values of CONFIG_FILES etc. instead of their
# values after options handling.
ac_log="
-This file was extended by dviout-util (TeX Live) $as_me 20181125, which was
+This file was extended by dviout-util (TeX Live) $as_me 20190206, which was
generated by GNU Autoconf 2.69. Invocation command line was
CONFIG_FILES = $CONFIG_FILES
@@ -15568,7 +15568,7 @@
cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1
ac_cs_config="`$as_echo "$ac_configure_args" | sed 's/^ //; s/[\\""\`\$]/\\\\&/g'`"
ac_cs_version="\\
-dviout-util (TeX Live) config.status 20181125
+dviout-util (TeX Live) config.status 20190206
configured by $0, generated by GNU Autoconf 2.69,
with options \\"\$ac_cs_config\\"
Modified: trunk/Build/source/texk/dviout-util/configure.ac
===================================================================
--- trunk/Build/source/texk/dviout-util/configure.ac 2019-02-07 01:23:40 UTC (rev 49966)
+++ trunk/Build/source/texk/dviout-util/configure.ac 2019-02-07 12:05:38 UTC (rev 49967)
@@ -6,7 +6,7 @@
dnl gives unlimited permission to copy and/or distribute it,
dnl with or without modifications, as long as this notice is preserved.
dnl
-AC_INIT([dviout-util (TeX Live)], [20181125], [tex-k at tug.org])
+AC_INIT([dviout-util (TeX Live)], [20190206], [tex-k at tug.org])
AC_PREREQ([2.65])
AC_CONFIG_SRCDIR([dvispc.c])
AC_CONFIG_AUX_DIR([../../build-aux])
Modified: trunk/Build/source/texk/dviout-util/dvispc.man
===================================================================
--- trunk/Build/source/texk/dviout-util/dvispc.man 2019-02-07 01:23:40 UTC (rev 49966)
+++ trunk/Build/source/texk/dviout-util/dvispc.man 2019-02-07 12:05:38 UTC (rev 49967)
@@ -1,6 +1,11 @@
-.if t .ds TX T\\h'-0.1667m'\\v'0.20v'E\\v'-0.20v'\\h'-0.125m'X
-.if t .ds LX L\\h'-0.36m'\\v'-0.15v'\\s-2A\\s+2\\h'-0.15m'\\v'0.15v'T\\h'-0.1667m'\\v'0.20v'E\\v'-0.20v'\\h'-0.125m'X
.TH DVISPC 1
+\"=====================================================================
+.if t .ds TX \fRT\\h'-0.1667m'\\v'0.20v'E\\v'-0.20v'\\h'-0.125m'X\fP
+.if n .ds TX TeX
+.\" LX definition must follow TX so LX can use TX
+.if t .ds LX \fRL\\h'-0.36m'\\v'-0.15v'\s-2A\s0\\h'-0.15m'\\v'0.15v'\fP\*(TX
+.if n .ds LX LaTeX
+\"=====================================================================
.SH NAME
dvispc \- Modify a DVI file to be page-independent in specials
.SH SYNOPSIS
More information about the tex-live-commits
mailing list