1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
|
/* uuterm, Copyright (C) 2006 Rich Felker; licensed under GNU GPL v2 only */
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <signal.h>
#include <locale.h>
#include <sys/select.h>
#include <sys/time.h> /* for broken systems */
#include "uuterm.h"
#include "ucf.h"
int ucf_load(struct ucf *, const char *);
extern const unsigned char vga_ascii_ucf[];
extern const size_t vga_ascii_ucf_size;
int main(int argc, char *argv[])
{
struct uuterm t = { };
struct uudisp d = { };
struct ucf f = { };
int tty, max;
int i, l;
unsigned char b[256];
fd_set fds;
struct timeval tv;
void *buf;
setlocale(LC_CTYPE, "");
if (ucf_load(&f, getenv("UUTERM_FONT")) < 0
&& ucf_init(&f, vga_ascii_ucf, vga_ascii_ucf_size) < 0)
return 1;
d.cell_w = 8;
d.cell_h = 16;
d.font = &f;
if (uudisp_open(&d) < 0)
return 1;
for (i=1; i<argc; i++)
argv[i-1] = argv[i];
argv[i-1] = NULL;
if ((tty = uutty_open(argc > 1 ? argv : NULL, d.w, d.h)) < 0)
return 1;
signal(SIGHUP, SIG_IGN);
if (!(buf = uuterm_buf_alloc(d.w, d.h))) {
uudisp_close(&d);
return 1;
}
uuterm_replace_buffer(&t, d.w, d.h, buf);
uuterm_reset(&t);
for (;;) {
/* Setup fd_set containing fd's used by display and our tty */
FD_ZERO(&fds);
FD_SET(tty, &fds);
max = uudisp_fd_set(&d, tty, &fds);
tv.tv_sec = 0;
tv.tv_usec = 250000;
if (select(max, &fds, NULL, NULL, &tv) <= 0) {
d.blink++;
FD_ZERO(&fds);
}
/* Process input from the tty, up to buffer size */
if (FD_ISSET(tty, &fds)) {
if ((l = read(tty, b, sizeof b)) <= 0)
break;
for (i=0; i<l; i++) {
uuterm_stuff_byte(&t, b[i]);
if (t.reslen) write(tty, t.res, t.reslen);
}
}
/* Look for events from the display */
uudisp_next_event(&d, &fds);
if (d.w != t.w || d.h != t.h) {
void *newbuf = uuterm_buf_alloc(d.w, d.h);
if (newbuf) {
uuterm_replace_buffer(&t, d.w, d.h, newbuf);
uuterm_free(buf);
buf = newbuf;
uutty_resize(tty, d.w, d.h);
}
}
if (d.inlen) {
write(tty, d.intext, d.inlen);
d.blink = 1;
}
/* If no more input is pending, refresh display */
FD_ZERO(&fds);
FD_SET(tty, &fds);
tv.tv_sec = tv.tv_usec = 0;
select(max, &fds, NULL, NULL, &tv);
if (!FD_ISSET(tty, &fds))
uudisp_refresh(&d, &t);
}
uudisp_close(&d);
return 0;
}
|