mirror of
https://github.com/GnoConsortium/gno.git
synced 2025-01-17 16:30:33 +00:00
327 lines
5.3 KiB
C
327 lines
5.3 KiB
C
/*
|
|
* io.c - low level I/O processing portion of nroff word processor
|
|
*
|
|
* adapted for atariST/TOS by Bill Rosenkranz 11/89
|
|
* net: rosenkra@hall.cray.com
|
|
* CIS: 71460,17
|
|
* GENIE: W.ROSENKRANZ
|
|
*
|
|
* original author:
|
|
*
|
|
* Stephen L. Browning
|
|
* 5723 North Parker Avenue
|
|
* Indianapolis, Indiana 46220
|
|
*
|
|
* history:
|
|
*
|
|
* - Originally written in BDS C;
|
|
* - Adapted for standard C by W. N. Paul
|
|
* - Heavily hacked up to conform to "real" nroff by Bill Rosenkranz
|
|
* - Heavily modified by Devin Reade to avoid memory trashing bugs.
|
|
*
|
|
* $Id: io.c,v 1.2 1997/03/20 06:40:50 gdr Exp $
|
|
*/
|
|
|
|
#ifdef __ORCAC__
|
|
segment "io________";
|
|
#pragma noroot
|
|
#pragma optimize 79
|
|
#endif
|
|
|
|
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
#include <string.h>
|
|
#include <assert.h>
|
|
#ifdef __GNO__
|
|
#include <err.h>
|
|
#include <termcap.h>
|
|
#else
|
|
#include "unix/err.h"
|
|
#include "unix/termcap.h"
|
|
#endif
|
|
|
|
#ifdef sparc
|
|
#include "unix/sunos.h"
|
|
#endif
|
|
|
|
#include "nroff.h"
|
|
#include "macros.h"
|
|
#include "io.h"
|
|
#include "escape.h"
|
|
|
|
char __i;
|
|
char *__s;
|
|
FILE *fpGLOB;
|
|
|
|
int
|
|
tprchar(char c)
|
|
{
|
|
return putc( c, fpGLOB );
|
|
}
|
|
|
|
/*
|
|
* getlin
|
|
*
|
|
* retrieve one line of input text from the push-back buffer or
|
|
* in_buf, place it in out_buf
|
|
*/
|
|
|
|
|
|
int
|
|
getlin (char *out_buf, FILE *in_buf) {
|
|
#if 0
|
|
/*
|
|
* gdr: these optimizations should work, but don't as yet ...
|
|
*/
|
|
register char *q;
|
|
register int i;
|
|
int c;
|
|
int nreg;
|
|
const char *dotc = ".c";
|
|
|
|
|
|
i = 0;
|
|
|
|
/* get characters from the push-back buffer */
|
|
q = out_buf;
|
|
while ((i < MAXLINE - 1) && (mac.ppb >= mac.pbb)) {
|
|
#if 1 /* doesn't happen */
|
|
c = *mac.ppb--;
|
|
if (c == EOF) {
|
|
*q = EOS;
|
|
return (i == 0) ? EOF : i;
|
|
}
|
|
*q++ = c;
|
|
#else
|
|
*q++ = c = *mac.ppb--;
|
|
#endif
|
|
if (c == '\n') {
|
|
break;
|
|
}
|
|
i++;
|
|
}
|
|
*q = EOS;
|
|
|
|
/* get characters from stream */
|
|
c = MAXLINE - i;
|
|
if (c > 0) {
|
|
fgets(q, c, in_buf);
|
|
}
|
|
|
|
FINDREG(dotc, nreg, q);
|
|
if (nreg > 0) {
|
|
set_ireg (dotc, rg[nreg].rval + 1, 0);
|
|
}
|
|
|
|
i = strlen(out_buf);
|
|
assert(i || feof(in_buf));
|
|
return (i == 0) ? EOF : i;
|
|
#else /* gdr: old way */
|
|
register char *q;
|
|
register int i;
|
|
int c;
|
|
int nreg;
|
|
const char *dotc = ".c";
|
|
|
|
q = out_buf;
|
|
for (i = 0; i < MAXLINE - 1; ++i) {
|
|
c = NGETC (in_buf);
|
|
if (c == EOF) {
|
|
*q = EOS;
|
|
c = strlen (out_buf);
|
|
return (c == 0 ? EOF : c);
|
|
}
|
|
*q++ = c;
|
|
if (c == '\n') {
|
|
break;
|
|
}
|
|
}
|
|
*q = EOS;
|
|
|
|
FINDREG(dotc, nreg, q);
|
|
if (nreg > 0) {
|
|
set_ireg (dotc, rg[nreg].rval + 1, 0);
|
|
}
|
|
|
|
return (strlen (out_buf));
|
|
#endif
|
|
}
|
|
|
|
|
|
/*
|
|
* pbstr
|
|
* Push back string into input stream
|
|
*/
|
|
void
|
|
pbstr (char *str) {
|
|
char *p;
|
|
|
|
if (str == NULL) {
|
|
return;
|
|
}
|
|
p = str + strlen(str) - 1;
|
|
while (p >= str) {
|
|
PUTBAK(*p);
|
|
--p;
|
|
}
|
|
return;
|
|
}
|
|
|
|
|
|
/*
|
|
* put
|
|
* put out line with proper spacing and indenting
|
|
*/
|
|
void
|
|
put (char *p) {
|
|
register int j;
|
|
char os[MAXLINE];
|
|
|
|
if (pg.lineno == 0 || pg.lineno > pg.bottom) {
|
|
phead ();
|
|
}
|
|
if (dc.prflg == TRUE) {
|
|
if (!dc.bsflg) {
|
|
if (strkovr (p, os) == TRUE) {
|
|
for (j = 0; j < pg.offset; ++j) {
|
|
PRCHAR2(' ', out_stream);
|
|
}
|
|
for (j = 0; j < dc.tival; ++j) {
|
|
PRCHAR2(' ', out_stream);
|
|
}
|
|
putlin (os, out_stream);
|
|
}
|
|
}
|
|
for (j = 0; j < pg.offset; ++j) {
|
|
PRCHAR2(' ', out_stream);
|
|
}
|
|
for (j = 0; j < dc.tival; ++j) {
|
|
PRCHAR2(' ', out_stream);
|
|
}
|
|
putlin (p, out_stream);
|
|
}
|
|
dc.tival = dc.inval;
|
|
skip (MIN(dc.lsval - 1, pg.bottom - pg.lineno));
|
|
pg.lineno = pg.lineno + dc.lsval;
|
|
set_ireg ("ln", pg.lineno, 0);
|
|
if (pg.lineno > pg.bottom) {
|
|
pfoot ();
|
|
#ifdef GEMDOS
|
|
if (stepping) {
|
|
wait_for_char();
|
|
}
|
|
#endif
|
|
}
|
|
}
|
|
|
|
/*
|
|
* putlin
|
|
* output a null terminated string to the file
|
|
* specified by pbuf.
|
|
*/
|
|
void
|
|
putlin (char *p, FILE *pbuf)
|
|
{
|
|
while (*p != EOS) {
|
|
PRCHAR(*p, pbuf);
|
|
p++;
|
|
}
|
|
}
|
|
|
|
|
|
|
|
#ifdef NOT_USED
|
|
|
|
/*
|
|
* prchar
|
|
* print character with test for printer
|
|
*/
|
|
void
|
|
prchar (char __c, FILE *fp)
|
|
{
|
|
#if 0
|
|
/* this really slows things down. it should be fixed. for now, ignore
|
|
* line printer...
|
|
*/
|
|
if (fp == stdout) {
|
|
putc (c, fp);
|
|
} else {
|
|
putc_lpr (c, fp);
|
|
}
|
|
#endif
|
|
|
|
#if 0
|
|
switch(c) {
|
|
case S_STANDOUT:
|
|
fpGLOB = fp;
|
|
tputs(s_standout,1,tprchar);
|
|
break;
|
|
case E_STANDOUT:
|
|
fpGLOB = fp;
|
|
tputs(e_standout,1,tprchar);
|
|
break;
|
|
case S_BOLD:
|
|
fpGLOB = fp;
|
|
tputs(s_bold,1,tprchar);
|
|
break;
|
|
case E_BOLD:
|
|
fpGLOB = fp;
|
|
tputs(e_bold,1,tprchar);
|
|
break;
|
|
case S_ITALIC:
|
|
fpGLOB = fp;
|
|
tputs(s_italic,1,tprchar);
|
|
break;
|
|
case E_ITALIC:
|
|
fpGLOB = fp;
|
|
tputs(e_italic,1,tprchar);
|
|
break;
|
|
case 13:
|
|
break;
|
|
default:
|
|
putc(c, fp);
|
|
}
|
|
#else
|
|
/*
|
|
* Don't use a case statement here; the macros are out of range
|
|
* for some compilers.
|
|
*/
|
|
if (__c == S_STANDOUT) {
|
|
fpGLOB = fp;
|
|
tputs(s_standout,1,tprchar);
|
|
} else if (__c == E_STANDOUT) {
|
|
fpGLOB = fp;
|
|
tputs(e_standout,1,tprchar);
|
|
} else if (__c == S_BOLD) {
|
|
fpGLOB = fp;
|
|
tputs(s_bold,1,tprchar);
|
|
} else if (__c == E_BOLD) {
|
|
fpGLOB = fp;
|
|
tputs(e_bold,1,tprchar);
|
|
} else if (__c == S_ITALIC) {
|
|
fpGLOB = fp;
|
|
tputs(s_italic,1,tprchar);
|
|
} else if (__c == E_ITALIC) {
|
|
fpGLOB = fp;
|
|
tputs(e_italic,1,tprchar);
|
|
} else if (__c == 13) {
|
|
;
|
|
} else {
|
|
putc(c, fp);
|
|
}
|
|
#endif
|
|
|
|
}
|
|
|
|
/*
|
|
* putc_lpr
|
|
* write char to printer
|
|
*/
|
|
void
|
|
putc_lpr (char c, FILE *fp)
|
|
{
|
|
putc (c, fp);
|
|
}
|
|
|
|
#endif /* NOT_USED */
|