1 76193d7c 2003-09-30 devnull #include <sys/types.h>
2 76193d7c 2003-09-30 devnull #include <sys/stat.h>
3 76193d7c 2003-09-30 devnull #include <sys/wait.h>
4 76193d7c 2003-09-30 devnull #include <pwd.h>
5 76193d7c 2003-09-30 devnull #include <signal.h>
6 76193d7c 2003-09-30 devnull #include <fcntl.h>
7 76193d7c 2003-09-30 devnull #include <errno.h>
9 76193d7c 2003-09-30 devnull #include "sam.h"
11 76193d7c 2003-09-30 devnull Rune samname[] = { '~', '~', 's', 'a', 'm', '~', '~', 0 };
13 76193d7c 2003-09-30 devnull static Rune l1[] = { '{', '[', '(', '<', 0253, 0};
14 76193d7c 2003-09-30 devnull static Rune l2[] = { '\n', 0};
15 76193d7c 2003-09-30 devnull static Rune l3[] = { '\'', '"', '`', 0};
16 76193d7c 2003-09-30 devnull Rune *left[]= { l1, l2, l3, 0};
18 76193d7c 2003-09-30 devnull static Rune r1[] = {'}', ']', ')', '>', 0273, 0};
19 76193d7c 2003-09-30 devnull static Rune r2[] = {'\n', 0};
20 76193d7c 2003-09-30 devnull static Rune r3[] = {'\'', '"', '`', 0};
21 76193d7c 2003-09-30 devnull Rune *right[]= { r1, r2, r3, 0};
23 76193d7c 2003-09-30 devnull #ifndef SAMTERMNAME
24 5b6dcaf4 2003-11-23 devnull #define SAMTERMNAME "samterm"
26 76193d7c 2003-09-30 devnull #ifndef TMPDIRNAME
27 76193d7c 2003-09-30 devnull #define TMPDIRNAME "/tmp"
29 76193d7c 2003-09-30 devnull #ifndef SHNAME
30 ffcafb8c 2003-10-11 devnull #define SHNAME "sh"
32 76193d7c 2003-09-30 devnull #ifndef SHPATHNAME
33 ffcafb8c 2003-10-11 devnull #define SHPATHNAME "/bin/sh"
35 76193d7c 2003-09-30 devnull #ifndef RXNAME
36 76193d7c 2003-09-30 devnull #define RXNAME "ssh"
38 76193d7c 2003-09-30 devnull #ifndef RXPATHNAME
39 5b6dcaf4 2003-11-23 devnull #define RXPATHNAME "ssh"
42 76193d7c 2003-09-30 devnull char RSAM[] = "sam";
43 76193d7c 2003-09-30 devnull char SAMTERM[] = SAMTERMNAME;
44 76193d7c 2003-09-30 devnull char HOME[] = "HOME";
45 76193d7c 2003-09-30 devnull char TMPDIR[] = TMPDIRNAME;
46 76193d7c 2003-09-30 devnull char SH[] = SHNAME;
47 76193d7c 2003-09-30 devnull char SHPATH[] = SHPATHNAME;
48 76193d7c 2003-09-30 devnull char RX[] = RXNAME;
49 76193d7c 2003-09-30 devnull char RXPATH[] = RXPATHNAME;
53 76193d7c 2003-09-30 devnull dprint(char *z, ...)
55 76193d7c 2003-09-30 devnull char buf[BLOCKSIZE];
56 76193d7c 2003-09-30 devnull va_list arg;
58 76193d7c 2003-09-30 devnull va_start(arg, z);
59 76193d7c 2003-09-30 devnull vseprint(buf, &buf[BLOCKSIZE], z, arg);
60 76193d7c 2003-09-30 devnull va_end(arg);
61 76193d7c 2003-09-30 devnull termwrite(buf);
65 76193d7c 2003-09-30 devnull print_ss(char *s, String *a, String *b)
67 76193d7c 2003-09-30 devnull dprint("?warning: %s: `%.*S' and `%.*S'\n", s, a->n, a->s, b->n, b->s);
71 76193d7c 2003-09-30 devnull print_s(char *s, String *a)
73 76193d7c 2003-09-30 devnull dprint("?warning: %s `%.*S'\n", s, a->n, a->s);
77 76193d7c 2003-09-30 devnull getuser(void)
79 76193d7c 2003-09-30 devnull static char user[64];
80 76193d7c 2003-09-30 devnull if(user[0] == 0){
81 76193d7c 2003-09-30 devnull struct passwd *pw = getpwuid(getuid());
82 76193d7c 2003-09-30 devnull strcpy(user, pw ? pw->pw_name : "nobody");
84 76193d7c 2003-09-30 devnull return user;
88 76193d7c 2003-09-30 devnull statfile(char *name, ulong *dev, uvlong *id, long *time, long *length, long *appendonly)
90 76193d7c 2003-09-30 devnull struct stat dirb;
92 76193d7c 2003-09-30 devnull if (stat(name, &dirb) == -1)
93 76193d7c 2003-09-30 devnull return -1;
95 76193d7c 2003-09-30 devnull *dev = dirb.st_dev;
97 76193d7c 2003-09-30 devnull *id = dirb.st_ino;
98 76193d7c 2003-09-30 devnull if (time)
99 76193d7c 2003-09-30 devnull *time = dirb.st_mtime;
100 76193d7c 2003-09-30 devnull if (length)
101 76193d7c 2003-09-30 devnull *length = dirb.st_size;
102 76193d7c 2003-09-30 devnull if(appendonly)
103 76193d7c 2003-09-30 devnull *appendonly = 0;
104 76193d7c 2003-09-30 devnull return 1;
108 76193d7c 2003-09-30 devnull statfd(int fd, ulong *dev, uvlong *id, long *time, long *length, long *appendonly)
110 76193d7c 2003-09-30 devnull struct stat dirb;
112 76193d7c 2003-09-30 devnull if (fstat(fd, &dirb) == -1)
113 76193d7c 2003-09-30 devnull return -1;
114 76193d7c 2003-09-30 devnull if (dev)
115 76193d7c 2003-09-30 devnull *dev = dirb.st_dev;
117 76193d7c 2003-09-30 devnull *id = dirb.st_ino;
118 76193d7c 2003-09-30 devnull if (time)
119 76193d7c 2003-09-30 devnull *time = dirb.st_mtime;
120 76193d7c 2003-09-30 devnull if (length)
121 76193d7c 2003-09-30 devnull *length = dirb.st_size;
122 76193d7c 2003-09-30 devnull if(appendonly)
123 76193d7c 2003-09-30 devnull *appendonly = 0;
124 76193d7c 2003-09-30 devnull return 1;
128 76193d7c 2003-09-30 devnull hup(int sig)
130 76193d7c 2003-09-30 devnull panicking = 1; // ???
131 76193d7c 2003-09-30 devnull rescue();
132 76193d7c 2003-09-30 devnull exit(1);
136 ffcafb8c 2003-10-11 devnull notify(void(*f)(void *, char *))
138 76193d7c 2003-09-30 devnull signal(SIGINT, SIG_IGN);
139 76193d7c 2003-09-30 devnull signal(SIGPIPE, SIG_IGN); // XXX - bpipeok?
140 76193d7c 2003-09-30 devnull signal(SIGHUP, hup);
141 76193d7c 2003-09-30 devnull return 1;
145 76193d7c 2003-09-30 devnull notifyf(void *a, char *b) /* never called; hup is instead */
149 76193d7c 2003-09-30 devnull static int
150 76193d7c 2003-09-30 devnull temp_file(char *buf, int bufsize)
152 76193d7c 2003-09-30 devnull char *tmp;
153 76193d7c 2003-09-30 devnull int n, fd;
155 76193d7c 2003-09-30 devnull tmp = getenv("TMPDIR");
156 76193d7c 2003-09-30 devnull if (!tmp)
157 76193d7c 2003-09-30 devnull tmp = TMPDIR;
159 76193d7c 2003-09-30 devnull n = snprint(buf, bufsize, "%s/sam.%d.XXXXXXX", tmp, getuid());
160 76193d7c 2003-09-30 devnull if (bufsize <= n)
161 76193d7c 2003-09-30 devnull return -1;
162 76193d7c 2003-09-30 devnull if ((fd = mkstemp(buf)) < 0) /* SES - linux sometimes uses mode 0666 */
163 76193d7c 2003-09-30 devnull return -1;
164 76193d7c 2003-09-30 devnull if (fcntl(fd, F_SETFD, fcntl(fd,F_GETFD,0) | FD_CLOEXEC) < 0)
165 76193d7c 2003-09-30 devnull return -1;
166 76193d7c 2003-09-30 devnull return fd;
170 76193d7c 2003-09-30 devnull tempdisk(void)
172 76193d7c 2003-09-30 devnull char buf[4096];
173 76193d7c 2003-09-30 devnull int fd = temp_file(buf, sizeof buf);
174 76193d7c 2003-09-30 devnull if (fd >= 0)
175 76193d7c 2003-09-30 devnull remove(buf);
176 76193d7c 2003-09-30 devnull return fd;
179 76193d7c 2003-09-30 devnull #undef wait
181 76193d7c 2003-09-30 devnull waitfor(int pid)
184 76193d7c 2003-09-30 devnull int rpid;
186 76193d7c 2003-09-30 devnull do; while((rpid = wait(&wm)) != pid && rpid != -1);
187 76193d7c 2003-09-30 devnull return (WEXITSTATUS(wm));
191 76193d7c 2003-09-30 devnull samerr(char *buf)
193 76193d7c 2003-09-30 devnull sprint(buf, "%s/sam.%s.err", TMPDIR, getuser());
197 76193d7c 2003-09-30 devnull emalloc(ulong n)
199 76193d7c 2003-09-30 devnull void *p;
201 76193d7c 2003-09-30 devnull p = malloc(n);
202 76193d7c 2003-09-30 devnull if(p == 0)
203 76193d7c 2003-09-30 devnull panic("malloc fails");
204 76193d7c 2003-09-30 devnull memset(p, 0, n);
205 76193d7c 2003-09-30 devnull return p;
209 76193d7c 2003-09-30 devnull erealloc(void *p, ulong n)
211 76193d7c 2003-09-30 devnull p = realloc(p, n);
212 76193d7c 2003-09-30 devnull if(p == 0)
213 76193d7c 2003-09-30 devnull panic("realloc fails");
214 76193d7c 2003-09-30 devnull return p;
219 76193d7c 2003-09-30 devnull strdup(const char *s)
221 76193d7c 2003-09-30 devnull return strcpy(emalloc(strlen(s)), s);
226 76193d7c 2003-09-30 devnull void exits(const char *s)
228 76193d7c 2003-09-30 devnull if (s) fprint(2, "exit: %s\n", s);
229 76193d7c 2003-09-30 devnull exit(s != 0);
233 76193d7c 2003-09-30 devnull _exits(const char *s)
235 76193d7c 2003-09-30 devnull if (s) fprint(2, "exit: %s\n", s);
236 76193d7c 2003-09-30 devnull _exit(s != 0);
239 76193d7c 2003-09-30 devnull int errstr(char *buf, int size)
241 76193d7c 2003-09-30 devnull extern int errno;
243 76193d7c 2003-09-30 devnull snprint(buf, size, "%s", strerror(errno));
244 76193d7c 2003-09-30 devnull return 1;
249 ffcafb8c 2003-10-11 devnull create(char *name, int omode, ulong perm)
251 76193d7c 2003-09-30 devnull int mode;
254 76193d7c 2003-09-30 devnull if (omode & OWRITE) mode = O_WRONLY;
255 76193d7c 2003-09-30 devnull else if (omode & OREAD) mode = O_RDONLY;
256 76193d7c 2003-09-30 devnull else mode = O_RDWR;
258 76193d7c 2003-09-30 devnull if ((fd = open(name, mode|O_CREAT|O_TRUNC, perm)) < 0)
259 76193d7c 2003-09-30 devnull return fd;
261 76193d7c 2003-09-30 devnull if (omode & OCEXEC)
262 76193d7c 2003-09-30 devnull fcntl(fd, F_SETFD, fcntl(fd,F_GETFD,0) | FD_CLOEXEC);
264 76193d7c 2003-09-30 devnull /* SES - not exactly right, but hopefully good enough. */
265 76193d7c 2003-09-30 devnull if (omode & ORCLOSE)
266 76193d7c 2003-09-30 devnull remove(name);
268 76193d7c 2003-09-30 devnull return fd;
271 a995e477 2003-10-01 devnull /* SHOULD BE ELSEWHERE */
272 ffcafb8c 2003-10-11 devnull #if 0 /* needed on old __APPLE__ */
273 a995e477 2003-10-01 devnull #include <lib9.h>
275 a995e477 2003-10-01 devnull Lock plk;
278 a995e477 2003-10-01 devnull pread(int fd, void *buf, ulong n, ulong off)
280 a995e477 2003-10-01 devnull ulong rv;
282 a995e477 2003-10-01 devnull lock(&plk);
283 a995e477 2003-10-01 devnull if (lseek(fd, off, 0) != off)
284 a995e477 2003-10-01 devnull return -1;
285 a995e477 2003-10-01 devnull rv = read(fd, buf, n);
286 a995e477 2003-10-01 devnull unlock(&plk);
288 a995e477 2003-10-01 devnull return rv;
292 a995e477 2003-10-01 devnull pwrite(int fd, void *buf, ulong n, ulong off)
294 a995e477 2003-10-01 devnull ulong rv;
296 a995e477 2003-10-01 devnull lock(&plk);
297 a995e477 2003-10-01 devnull if (lseek(fd, off, 0) != off)
298 a995e477 2003-10-01 devnull return -1;
299 a995e477 2003-10-01 devnull rv = write(fd, buf, n);
300 a995e477 2003-10-01 devnull unlock(&plk);
302 a995e477 2003-10-01 devnull return rv;