]>
diplodocus.org Git - nmh/blob - uip/vmhsbr.c
3 * vmhsbr.c -- routines to help vmh along
5 * This code is Copyright (c) 2002, by the authors of nmh. See the
6 * COPYRIGHT file in the root directory of the nmh distribution for
7 * complete copyright information.
12 * INI: include width of windows
19 static char *types
[] = {
21 "INI", "ACK", "ERR", "CMD", "QRY", "TTY", "WIN", "DATA", "EOF", "FIN",
25 static FILE *fp
= NULL
;
27 static int PEERrfd
= NOTOK
;
28 static int PEERwfd
= NOTOK
;
33 static int rclose (struct record
*, char *, ...);
37 rcinit (int rfd
, int wfd
)
39 char *cp
, buffer
[BUFSIZ
];
44 if ((cp
= getenv ("MHVDEBUG")) && *cp
) {
45 snprintf (buffer
, sizeof(buffer
), "%s.out", invo_name
);
46 if ((fp
= fopen (buffer
, "w"))) {
47 fseek (fp
, 0L, SEEK_END
);
48 fprintf (fp
, "%d: rcinit (%d, %d)\n", (int) getpid(), rfd
, wfd
);
74 rc2rc (char code
, int len
, char *data
, struct record
*rc
)
76 if (rc2peer (code
, len
, data
) == NOTOK
)
84 str2rc (char code
, char *str
, struct record
*rc
)
86 return rc2rc (code
, str
? strlen (str
) : 0, str
, rc
);
91 peer2rc (struct record
*rc
)
96 if (read (PEERrfd
, (char *) rc_head (rc
), RHSIZE (rc
)) != RHSIZE (rc
))
97 return rclose (rc
, "read from peer lost(1)");
99 rc
->rc_data
= mh_xmalloc ((unsigned) rc
->rc_len
+ 1);
100 if (read (PEERrfd
, rc
->rc_data
, rc
->rc_len
) != rc
->rc_len
)
101 return rclose (rc
, "read from peer lost(2)");
102 rc
->rc_data
[rc
->rc_len
] = 0;
108 fseek (fp
, 0L, SEEK_END
);
109 fprintf (fp
, "%d: <--- %s %d: \"%*.*s\"\n", (int) getpid(),
110 types
[(unsigned char)rc
->rc_type
], rc
->rc_len
,
111 rc
->rc_len
, rc
->rc_len
, rc
->rc_data
);
120 rc2peer (char code
, int len
, char *data
)
123 register struct record
*rc
= &rcs
;
129 fseek (fp
, 0L, SEEK_END
);
130 fprintf (fp
, "%d: ---> %s %d: \"%*.*s\"\n", (int) getpid(),
131 types
[(unsigned char)rc
->rc_type
], rc
->rc_len
,
132 rc
->rc_len
, rc
->rc_len
, data
);
136 if (write (PEERwfd
, (char *) rc_head (rc
), RHSIZE (rc
)) != RHSIZE (rc
))
137 return rclose (rc
, "write to peer lost(1)");
140 if (write (PEERwfd
, data
, rc
->rc_len
) != rc
->rc_len
)
141 return rclose (rc
, "write to peer lost(2)");
148 str2peer (char code
, char *str
)
150 return rc2peer (code
, str
? strlen (str
) : 0, str
);
155 fmt2peer (char code
, char *fmt
, ...)
161 return_value
= verr2peer (code
, NULL
, fmt
, ap
);
168 err2peer (char code
, char *what
, char *fmt
, ...)
174 return_value
= verr2peer(code
, what
, fmt
, ap
);
176 return return_value
; /* This routine returned garbage before 1999-07-15. */
181 verr2peer (char code
, char *what
, char *fmt
, va_list ap
)
185 char *bp
, *s
, buffer
[BUFSIZ
* 2];
187 /* Get buffer ready to go */
189 buflen
= sizeof(buffer
);
191 vsnprintf (bp
, buflen
, fmt
, ap
);
198 snprintf (bp
, buflen
, " %s: ", what
);
203 if ((s
= strerror (eindex
)))
204 strncpy (bp
, s
, buflen
);
206 snprintf (bp
, buflen
, "unknown error %d", eindex
);
212 return rc2peer (code
, bp
- buffer
, buffer
);
217 rclose (struct record
*rc
, char *fmt
, ...)
220 static char buffer
[BUFSIZ
* 2];
223 vsnprintf (buffer
, sizeof(buffer
), fmt
, ap
);
226 rc
->rc_len
= strlen (rc
->rc_data
= getcpy (buffer
));
227 return (rc
->rc_type
= RC_XXX
);