home *** CD-ROM | disk | FTP | other *** search
/ rtsi.com / 2014.01.www.rtsi.com.tar / www.rtsi.com / OS9 / OSK / APPS / DVI_MGR / dvimgr_s.lzh / dvimgr / dvifile.beebe < prev    next >
Text File  |  1993-08-06  |  5KB  |  159 lines

  1. /* -*-C-*- dvifile.h */
  2. /*-->dvifile*/
  3. /**********************************************************************/
  4. /****************************** dvifile *******************************/
  5. /**********************************************************************/
  6.  
  7. void
  8. dvifile(argc,argv,filestr)
  9. int   argc;            /* argument count */
  10. char* argv[];            /* argument strings */
  11. char* filestr;            /* DVI filename to process */
  12. {
  13.  
  14. #define PAGENUMBER(p) ((p) < 0 ? (page_count + 1 + (p)) : (p))
  15.  
  16.     register INT16 i,j,m;    /* loop indices */
  17.     register INT16 swap;    /* swap storage */
  18.  
  19.     INT16 m_begin,m_end,m_step;    /* loop limits and increment */
  20.     INT16 list[3];        /* index list for sort */
  21.     char tempstr[MAXSTR];    /* temporary string storage */
  22.  
  23.  
  24.     /*
  25.     Establish the default  font file  search order.  This  is done  here
  26.     instead of  in  initglob()  or  option(),  because  both  could  set
  27.     fontlist[].
  28.  
  29.     By default, the search list contains  names for the PK, GF, and  PXL
  30.     font  files;  that  order   corresponds  to  increasing  size   (and
  31.     therefore, presumably, increasing  processing cost)  of font  raster
  32.     information.  This search  order may  be overridden at  run time  by
  33.     defining an alternate one in the environment variable FONTLIST;  the
  34.     order of  the  strings  "PK",  "GF",  and  "PXL"  in  that  variable
  35.     determines the search  order, and  letter case  is NOT  significant.
  36.     The  substrings  may  be  separated   by  zero  or  more   arbitrary
  37.     characters, so  the  values  "PK-GF-PXL", "PK  GF  PXL",  "PKGFPXL",
  38.     "PK;GF;PXL", "PK/GF/PXL"  are all  acceptable,  and all  choose  the
  39.     default search  order.   This  flexibility  in  separator  character
  40.     choice is occasioned  by the  requirement on some  systems that  the
  41.     environment variable have the syntax of a file name, or be a  single
  42.     "word".  If  any  substring  is  omitted, then  that  font  will  be
  43.     excluded from consideration.  Thus, "GF" permits the use only of  GF
  44.     font files.
  45.  
  46.     The indexes gf_index, pk_index, and pxl_index are in -1 .. 2, and at
  47.     least one must be non-negative.  A negative index excludes that font
  48.     file type from the search.
  49.     */
  50.  
  51.     /* Note that non-negative entries in list[] are UNIQUE. */
  52.     list[0] = gf_index = (INT16)strid2(fontlist,"GF");
  53.     list[1] = pk_index = (INT16)strid2(fontlist,"PK");
  54.     list[2] = pxl_index = (INT16)strid2(fontlist,"PXL");
  55.  
  56.     for (i = 0; i < 3; ++i)    /* put list in non-decreasing order */
  57.     for (j = i+1; j < 3; ++j)
  58.         if (list[i] > list[j])
  59.         {
  60.         swap = list[i];
  61.         list[i] = list[j];
  62.         list[j] = swap;
  63.         }
  64.     for (i = 0; i < 3; ++i)    /* assign indexes 0,1,2 */
  65.     if (list[i] >= 0)
  66.     {
  67.             if (list[i] == gf_index)
  68.         gf_index = i;
  69.             else if (list[i] == pk_index)
  70.         pk_index = i;
  71.             else if (list[i] == pxl_index)
  72.         pxl_index = i;
  73.     }
  74.  
  75.     if ((gf_index < 0) && (pk_index < 0) && (pxl_index < 0))
  76.     (void)fatal("dvifile():  FONTLIST does not define at least one of \
  77. GF, PK, or PXL fonts");
  78.  
  79.     (void)dviinit(filestr);    /* initialize DVI file processing */
  80.  
  81.     (void)devinit(argc,argv);    /* initialize device output */
  82.  
  83.     (void)readpost();
  84.     (void)FSEEK(dvifp, 14L, 0); /* position past preamble */
  85.     (void)getbytes(dvifp, tempstr,
  86.     (BYTE)nosignex(dvifp,(BYTE)1)); /* flush DVI comment */
  87.  
  88.     cur_page_number = 0;
  89.  
  90.  
  91. #if    (HPLASERJET|HPJETPLUS|GOLDENDAWNGL100|POSTSCRIPT|IMPRESS|CANON_A2)
  92.     /* print pages in reverse order because of laser printer */
  93.     /* page stacking */
  94.     if (backwards)
  95.     {
  96.     m_begin = 1;
  97.     m_end = page_count;
  98.     m_step = 1;
  99.     }
  100.     else    /* normal device order */
  101.     {
  102.     m_begin = page_count;
  103.     m_end = 1;
  104.     m_step = -1;
  105.     }
  106.  
  107. #else
  108.   /* NOT (HPLASERJET|HPJETPLUS|GOLDENDAWNGL100|POSTSCRIPT|IMPRESS|CANON_A2) */
  109.     /* print pages in forward order for most devices */
  110.     if (backwards)
  111.     {
  112.     m_begin = page_count;
  113.     m_end = 1;
  114.     m_step = -1;
  115.     }
  116.     else
  117.     {
  118.     m_begin = 1;
  119.     m_end = page_count;
  120.     m_step = 1;
  121.     }
  122. #endif /* (HPLASERJET|HPJETPLUS|GOLDENDAWNGL100|POSTSCRIPT|IMPRESS|CANON_A2) */
  123.  
  124.     for (i = 0; i < npage; ++i)        /* make page numbers positive */
  125.     {                    /* and order pairs non-decreasing */
  126.     page_begin[i] = PAGENUMBER(page_begin[i]);
  127.     page_end[i] = PAGENUMBER(page_end[i]);
  128.     if (page_begin[i] > page_end[i])
  129.     {
  130.         swap = page_begin[i];
  131.         page_begin[i] = page_end[i];
  132.         page_end[i] = swap;
  133.     }
  134.     }
  135.  
  136.     for (m = m_begin; ; m += m_step)
  137.     {
  138.     for (i = 0; i < npage; ++i)    /* search page list */
  139.         if ( IN(page_begin[i],m,page_end[i]) &&
  140.             (((m - page_begin[i]) % page_step[i]) == 0) )
  141.         {
  142.         if (!quiet)        /* start progress report */
  143.             (void)fprintf(stderr,"[%d", m);
  144.         cur_page_number++;/* sequential page number 1..N */
  145.         cur_index = m-1;    /* remember index globally */
  146.         prtpage(page_ptr[cur_index]);
  147.         if (!quiet)        /* finish progress report */
  148.             (void)fprintf(stderr,"] ");
  149.         break;
  150.         }
  151.     if (m == m_end)            /* exit loop after last page */
  152.         break;
  153.     }
  154.  
  155.     (void)devterm();        /* terminate device output */
  156.  
  157.     (void)dviterm();        /* terminate DVI file processing */
  158. }
  159.