Line | Source | Count |
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 | #include "includes.h" | - |
75 | | - |
76 | #include <sys/types.h> | - |
77 | #ifdef HAVE_SYS_STAT_H | - |
78 | # include <sys/stat.h> | - |
79 | #endif | - |
80 | #ifdef HAVE_POLL_H | - |
81 | #include <poll.h> | - |
82 | #else | - |
83 | # ifdef HAVE_SYS_POLL_H | - |
84 | # include <sys/poll.h> | - |
85 | # endif | - |
86 | #endif | - |
87 | #ifdef HAVE_SYS_TIME_H | - |
88 | # include <sys/time.h> | - |
89 | #endif | - |
90 | #include <sys/wait.h> | - |
91 | #include <sys/uio.h> | - |
92 | | - |
93 | #include <ctype.h> | - |
94 | #include <dirent.h> | - |
95 | #include <errno.h> | - |
96 | #include <fcntl.h> | - |
97 | #include <limits.h> | - |
98 | #include <locale.h> | - |
99 | #include <pwd.h> | - |
100 | #include <signal.h> | - |
101 | #include <stdarg.h> | - |
102 | #ifdef HAVE_STDINT_H | - |
103 | #include <stdint.h> | - |
104 | #endif | - |
105 | #include <stdio.h> | - |
106 | #include <stdlib.h> | - |
107 | #include <string.h> | - |
108 | #include <time.h> | - |
109 | #include <unistd.h> | - |
110 | #if defined(HAVE_STRNVIS) && defined(HAVE_VIS_H) && !defined(BROKEN_STRNVIS) | - |
111 | #include <vis.h> | - |
112 | #endif | - |
113 | | - |
114 | #include "xmalloc.h" | - |
115 | #include "ssh.h" | - |
116 | #include "atomicio.h" | - |
117 | #include "pathnames.h" | - |
118 | #include "log.h" | - |
119 | #include "misc.h" | - |
120 | #include "progressmeter.h" | - |
121 | #include "utf8.h" | - |
122 | | - |
123 | extern char *__progname; | - |
124 | | - |
125 | #define COPY_BUFLEN 16384 | - |
126 | | - |
127 | int do_cmd(char *host, char *remuser, int port, char *cmd, int *fdin, int *fdout); | - |
128 | int do_cmd2(char *host, char *remuser, int port, char *cmd, int fdin, int fdout); | - |
129 | | - |
130 | | - |
131 | arglist args; | - |
132 | arglist remote_remote_args; | - |
133 | | - |
134 | | - |
135 | long long limit_kbps = 0; | - |
136 | struct bwlimit bwlimit; | - |
137 | | - |
138 | | - |
139 | char *curfile; | - |
140 | | - |
141 | | - |
142 | int verbose_mode = 0; | - |
143 | | - |
144 | | - |
145 | int showprogress = 1; | - |
146 | | - |
147 | | - |
148 | | - |
149 | | - |
150 | | - |
151 | int throughlocal = 0; | - |
152 | | - |
153 | | - |
154 | int sshport = -1; | - |
155 | | - |
156 | | - |
157 | char *ssh_program = _PATH_SSH_PROGRAM; | - |
158 | | - |
159 | | - |
160 | pid_t do_cmd_pid = -1; | - |
161 | | - |
162 | static void | - |
163 | killchild(int signo) | - |
164 | { | - |
165 | if (do_cmd_pid > 1) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
166 | kill(do_cmd_pid, signo ? signo : SIGTERM); | - |
167 | waitpid(do_cmd_pid, NULL, 0); | - |
168 | } never executed: end of block | 0 |
169 | | - |
170 | if (signo)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
171 | _exit(1); never executed: _exit(1); | 0 |
172 | exit(1); never executed: exit(1); | 0 |
173 | } | - |
174 | | - |
175 | static void | - |
176 | suspchild(int signo) | - |
177 | { | - |
178 | int status; | - |
179 | | - |
180 | if (do_cmd_pid > 1) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
181 | kill(do_cmd_pid, signo); | - |
182 | while (waitpid(do_cmd_pid, &status, WUNTRACED) == -1 &&TRUE | never evaluated | FALSE | never evaluated |
| 0 |
183 | errno == EINTR)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
184 | ; never executed: ; | 0 |
185 | kill(getpid(), SIGSTOP); | - |
186 | } never executed: end of block | 0 |
187 | } never executed: end of block | 0 |
188 | | - |
189 | static int | - |
190 | do_local_cmd(arglist *a) | - |
191 | { | - |
192 | u_int i; | - |
193 | int status; | - |
194 | pid_t pid; | - |
195 | | - |
196 | if (a->num == 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
197 | fatal("do_local_cmd: no arguments"); never executed: fatal("do_local_cmd: no arguments"); | 0 |
198 | | - |
199 | if (verbose_mode) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
200 | fprintf(stderr, "Executing:"); | - |
201 | for (i = 0; i < a->num; i++)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
202 | fmprintf(stderr, " %s", a->list[i]); never executed: fmprintf( stderr , " %s", a->list[i]); | 0 |
203 | fprintf(stderr, "\n"); | - |
204 | } never executed: end of block | 0 |
205 | if ((pid = fork()) == -1)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
206 | fatal("do_local_cmd: fork: %s", strerror(errno)); never executed: fatal("do_local_cmd: fork: %s", strerror( (*__errno_location ()) )); | 0 |
207 | | - |
208 | if (pid == 0) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
209 | execvp(a->list[0], a->list); | - |
210 | perror(a->list[0]); | - |
211 | exit(1); never executed: exit(1); | 0 |
212 | } | - |
213 | | - |
214 | do_cmd_pid = pid; | - |
215 | signal(SIGTERM, killchild); | - |
216 | signal(SIGINT, killchild); | - |
217 | signal(SIGHUP, killchild); | - |
218 | | - |
219 | while (waitpid(pid, &status, 0) == -1)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
220 | if (errno != EINTR)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
221 | fatal("do_local_cmd: waitpid: %s", strerror(errno)); never executed: fatal("do_local_cmd: waitpid: %s", strerror( (*__errno_location ()) )); | 0 |
222 | | - |
223 | do_cmd_pid = -1; | - |
224 | | - |
225 | if (!WIFEXITED(status) || WEXITSTATUS(status) != 0)TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
226 | return (-1); never executed: return (-1); | 0 |
227 | | - |
228 | return (0); never executed: return (0); | 0 |
229 | } | - |
230 | | - |
231 | | - |
232 | | - |
233 | | - |
234 | | - |
235 | | - |
236 | | - |
237 | int | - |
238 | do_cmd(char *host, char *remuser, int port, char *cmd, int *fdin, int *fdout) | - |
239 | { | - |
240 | int pin[2], pout[2], reserved[2]; | - |
241 | | - |
242 | if (verbose_mode)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
243 | fmprintf(stderr, never executed: fmprintf( stderr , "Executing: program %s host %s, user %s, command %s\n", ssh_program, host, remuser ? remuser : "(unspecified)", cmd); | 0 |
244 | "Executing: program %s host %s, user %s, command %s\n", never executed: fmprintf( stderr , "Executing: program %s host %s, user %s, command %s\n", ssh_program, host, remuser ? remuser : "(unspecified)", cmd); | 0 |
245 | ssh_program, host, never executed: fmprintf( stderr , "Executing: program %s host %s, user %s, command %s\n", ssh_program, host, remuser ? remuser : "(unspecified)", cmd); | 0 |
246 | remuser ? remuser : "(unspecified)", cmd); never executed: fmprintf( stderr , "Executing: program %s host %s, user %s, command %s\n", ssh_program, host, remuser ? remuser : "(unspecified)", cmd); | 0 |
247 | | - |
248 | if (port == -1)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
249 | port = sshport; never executed: port = sshport; | 0 |
250 | | - |
251 | | - |
252 | | - |
253 | | - |
254 | | - |
255 | if (pipe(reserved) < 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
256 | fatal("pipe: %s", strerror(errno)); never executed: fatal("pipe: %s", strerror( (*__errno_location ()) )); | 0 |
257 | | - |
258 | | - |
259 | if (pipe(pin) < 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
260 | fatal("pipe: %s", strerror(errno)); never executed: fatal("pipe: %s", strerror( (*__errno_location ()) )); | 0 |
261 | if (pipe(pout) < 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
262 | fatal("pipe: %s", strerror(errno)); never executed: fatal("pipe: %s", strerror( (*__errno_location ()) )); | 0 |
263 | | - |
264 | | - |
265 | close(reserved[0]); | - |
266 | close(reserved[1]); | - |
267 | | - |
268 | signal(SIGTSTP, suspchild); | - |
269 | signal(SIGTTIN, suspchild); | - |
270 | signal(SIGTTOU, suspchild); | - |
271 | | - |
272 | | - |
273 | do_cmd_pid = fork(); | - |
274 | if (do_cmd_pid == 0) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
275 | | - |
276 | close(pin[1]); | - |
277 | close(pout[0]); | - |
278 | dup2(pin[0], 0); | - |
279 | dup2(pout[1], 1); | - |
280 | close(pin[0]); | - |
281 | close(pout[1]); | - |
282 | | - |
283 | replacearg(&args, 0, "%s", ssh_program); | - |
284 | if (port != -1) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
285 | addargs(&args, "-p"); | - |
286 | addargs(&args, "%d", port); | - |
287 | } never executed: end of block | 0 |
288 | if (remuser != NULL) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
289 | addargs(&args, "-l"); | - |
290 | addargs(&args, "%s", remuser); | - |
291 | } never executed: end of block | 0 |
292 | addargs(&args, "--"); | - |
293 | addargs(&args, "%s", host); | - |
294 | addargs(&args, "%s", cmd); | - |
295 | | - |
296 | execvp(ssh_program, args.list); | - |
297 | perror(ssh_program); | - |
298 | exit(1); never executed: exit(1); | 0 |
299 | } else if (do_cmd_pid == -1) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
300 | fatal("fork: %s", strerror(errno)); | - |
301 | } never executed: end of block | 0 |
302 | | - |
303 | close(pin[0]); | - |
304 | *fdout = pin[1]; | - |
305 | close(pout[1]); | - |
306 | *fdin = pout[0]; | - |
307 | signal(SIGTERM, killchild); | - |
308 | signal(SIGINT, killchild); | - |
309 | signal(SIGHUP, killchild); | - |
310 | return 0; never executed: return 0; | 0 |
311 | } | - |
312 | | - |
313 | | - |
314 | | - |
315 | | - |
316 | | - |
317 | | - |
318 | int | - |
319 | do_cmd2(char *host, char *remuser, int port, char *cmd, int fdin, int fdout) | - |
320 | { | - |
321 | pid_t pid; | - |
322 | int status; | - |
323 | | - |
324 | if (verbose_mode)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
325 | fmprintf(stderr, never executed: fmprintf( stderr , "Executing: 2nd program %s host %s, user %s, command %s\n", ssh_program, host, remuser ? remuser : "(unspecified)", cmd); | 0 |
326 | "Executing: 2nd program %s host %s, user %s, command %s\n", never executed: fmprintf( stderr , "Executing: 2nd program %s host %s, user %s, command %s\n", ssh_program, host, remuser ? remuser : "(unspecified)", cmd); | 0 |
327 | ssh_program, host, never executed: fmprintf( stderr , "Executing: 2nd program %s host %s, user %s, command %s\n", ssh_program, host, remuser ? remuser : "(unspecified)", cmd); | 0 |
328 | remuser ? remuser : "(unspecified)", cmd); never executed: fmprintf( stderr , "Executing: 2nd program %s host %s, user %s, command %s\n", ssh_program, host, remuser ? remuser : "(unspecified)", cmd); | 0 |
329 | | - |
330 | if (port == -1)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
331 | port = sshport; never executed: port = sshport; | 0 |
332 | | - |
333 | | - |
334 | pid = fork(); | - |
335 | if (pid == 0) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
336 | dup2(fdin, 0); | - |
337 | dup2(fdout, 1); | - |
338 | | - |
339 | replacearg(&args, 0, "%s", ssh_program); | - |
340 | if (port != -1) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
341 | addargs(&args, "-p"); | - |
342 | addargs(&args, "%d", port); | - |
343 | } never executed: end of block | 0 |
344 | if (remuser != NULL) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
345 | addargs(&args, "-l"); | - |
346 | addargs(&args, "%s", remuser); | - |
347 | } never executed: end of block | 0 |
348 | addargs(&args, "--"); | - |
349 | addargs(&args, "%s", host); | - |
350 | addargs(&args, "%s", cmd); | - |
351 | | - |
352 | execvp(ssh_program, args.list); | - |
353 | perror(ssh_program); | - |
354 | exit(1); never executed: exit(1); | 0 |
355 | } else if (pid == -1) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
356 | fatal("fork: %s", strerror(errno)); | - |
357 | } never executed: end of block | 0 |
358 | while (waitpid(pid, &status, 0) == -1)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
359 | if (errno != EINTR)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
360 | fatal("do_cmd2: waitpid: %s", strerror(errno)); never executed: fatal("do_cmd2: waitpid: %s", strerror( (*__errno_location ()) )); | 0 |
361 | return 0; never executed: return 0; | 0 |
362 | } | - |
363 | | - |
364 | typedef struct { | - |
365 | size_t cnt; | - |
366 | char *buf; | - |
367 | } BUF; | - |
368 | | - |
369 | BUF *allocbuf(BUF *, int, int); | - |
370 | void lostconn(int); | - |
371 | int okname(char *); | - |
372 | void run_err(const char *,...); | - |
373 | void verifydir(char *); | - |
374 | | - |
375 | struct passwd *pwd; | - |
376 | uid_t userid; | - |
377 | int errs, remin, remout; | - |
378 | int pflag, iamremote, iamrecursive, targetshouldbedirectory; | - |
379 | | - |
380 | #define CMDNEEDS 64 | - |
381 | char cmd[CMDNEEDS]; | - |
382 | | - |
383 | int response(void); | - |
384 | void rsource(char *, struct stat *); | - |
385 | void sink(int, char *[]); | - |
386 | void source(int, char *[]); | - |
387 | void tolocal(int, char *[]); | - |
388 | void toremote(int, char *[]); | - |
389 | void usage(void); | - |
390 | | - |
391 | int | - |
392 | main(int argc, char **argv) | - |
393 | { | - |
394 | int ch, fflag, tflag, status, n; | - |
395 | char **newargv; | - |
396 | const char *errstr; | - |
397 | extern char *optarg; | - |
398 | extern int optind; | - |
399 | | - |
400 | | - |
401 | sanitise_stdfd(); | - |
402 | | - |
403 | msetlocale(); | - |
404 | | - |
405 | | - |
406 | newargv = xcalloc(MAXIMUM(argc + 1, 1), sizeof(*newargv)); | - |
407 | for (n = 0; n < argc; n++)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
408 | newargv[n] = xstrdup(argv[n]); never executed: newargv[n] = xstrdup(argv[n]); | 0 |
409 | argv = newargv; | - |
410 | | - |
411 | __progname = ssh_get_progname(argv[0]); | - |
412 | | - |
413 | memset(&args, '\0', sizeof(args)); | - |
414 | memset(&remote_remote_args, '\0', sizeof(remote_remote_args)); | - |
415 | args.list = remote_remote_args.list = NULL; | - |
416 | addargs(&args, "%s", ssh_program); | - |
417 | addargs(&args, "-x"); | - |
418 | addargs(&args, "-oForwardAgent=no"); | - |
419 | addargs(&args, "-oPermitLocalCommand=no"); | - |
420 | addargs(&args, "-oClearAllForwardings=yes"); | - |
421 | addargs(&args, "-oRemoteCommand=none"); | - |
422 | addargs(&args, "-oRequestTTY=no"); | - |
423 | | - |
424 | fflag = tflag = 0; | - |
425 | while ((ch = getopt(argc, argv, "dfl:prtvBCc:i:P:q12346S:o:F:")) != -1)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
426 | switch (ch) { | - |
427 | | - |
428 | case '1': never executed: case '1': | 0 |
429 | fatal("SSH protocol v.1 is no longer supported"); | - |
430 | break; never executed: break; | 0 |
431 | case '2': never executed: case '2': | 0 |
432 | | - |
433 | break; never executed: break; | 0 |
434 | case '4': never executed: case '4': | 0 |
435 | case '6': never executed: case '6': | 0 |
436 | case 'C': never executed: case 'C': | 0 |
437 | addargs(&args, "-%c", ch); | - |
438 | addargs(&remote_remote_args, "-%c", ch); | - |
439 | break; never executed: break; | 0 |
440 | case '3': never executed: case '3': | 0 |
441 | throughlocal = 1; | - |
442 | break; never executed: break; | 0 |
443 | case 'o': never executed: case 'o': | 0 |
444 | case 'c': never executed: case 'c': | 0 |
445 | case 'i': never executed: case 'i': | 0 |
446 | case 'F': never executed: case 'F': | 0 |
447 | addargs(&remote_remote_args, "-%c", ch); | - |
448 | addargs(&remote_remote_args, "%s", optarg); | - |
449 | addargs(&args, "-%c", ch); | - |
450 | addargs(&args, "%s", optarg); | - |
451 | break; never executed: break; | 0 |
452 | case 'P': never executed: case 'P': | 0 |
453 | sshport = a2port(optarg); | - |
454 | if (sshport <= 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
455 | fatal("bad port \"%s\"\n", optarg); never executed: fatal("bad port \"%s\"\n", BSDoptarg); | 0 |
456 | break; never executed: break; | 0 |
457 | case 'B': never executed: case 'B': | 0 |
458 | addargs(&remote_remote_args, "-oBatchmode=yes"); | - |
459 | addargs(&args, "-oBatchmode=yes"); | - |
460 | break; never executed: break; | 0 |
461 | case 'l': never executed: case 'l': | 0 |
462 | limit_kbps = strtonum(optarg, 1, 100 * 1024 * 1024, | - |
463 | &errstr); | - |
464 | if (errstr != NULL)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
465 | usage(); never executed: usage(); | 0 |
466 | limit_kbps *= 1024; | - |
467 | bandwidth_limit_init(&bwlimit, limit_kbps, COPY_BUFLEN); | - |
468 | break; never executed: break; | 0 |
469 | case 'p': never executed: case 'p': | 0 |
470 | pflag = 1; | - |
471 | break; never executed: break; | 0 |
472 | case 'r': never executed: case 'r': | 0 |
473 | iamrecursive = 1; | - |
474 | break; never executed: break; | 0 |
475 | case 'S': never executed: case 'S': | 0 |
476 | ssh_program = xstrdup(optarg); | - |
477 | break; never executed: break; | 0 |
478 | case 'v': never executed: case 'v': | 0 |
479 | addargs(&args, "-v"); | - |
480 | addargs(&remote_remote_args, "-v"); | - |
481 | verbose_mode = 1; | - |
482 | break; never executed: break; | 0 |
483 | case 'q': never executed: case 'q': | 0 |
484 | addargs(&args, "-q"); | - |
485 | addargs(&remote_remote_args, "-q"); | - |
486 | showprogress = 0; | - |
487 | break; never executed: break; | 0 |
488 | | - |
489 | | - |
490 | case 'd': never executed: case 'd': | 0 |
491 | targetshouldbedirectory = 1; | - |
492 | break; never executed: break; | 0 |
493 | case 'f': never executed: case 'f': | 0 |
494 | iamremote = 1; | - |
495 | fflag = 1; | - |
496 | break; never executed: break; | 0 |
497 | case 't': never executed: case 't': | 0 |
498 | iamremote = 1; | - |
499 | tflag = 1; | - |
500 | #ifdef HAVE_CYGWIN | - |
501 | setmode(0, O_BINARY); | - |
502 | #endif | - |
503 | break; never executed: break; | 0 |
504 | default: never executed: default: | 0 |
505 | usage(); | - |
506 | } never executed: end of block | 0 |
507 | argc -= optind; | - |
508 | argv += optind; | - |
509 | | - |
510 | if ((pwd = getpwuid(userid = getuid())) == NULL)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
511 | fatal("unknown user %u", (u_int) userid); never executed: fatal("unknown user %u", (u_int) userid); | 0 |
512 | | - |
513 | if (!isatty(STDOUT_FILENO))TRUE | never evaluated | FALSE | never evaluated |
| 0 |
514 | showprogress = 0; never executed: showprogress = 0; | 0 |
515 | | - |
516 | if (pflag) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
517 | | - |
518 | } else { never executed: end of block | 0 |
519 | if (pledge("stdio rpath wpath cpath fattr tty proc exec",TRUE | never evaluated | FALSE | never evaluated |
| 0 |
520 | NULL) == -1) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
521 | perror("pledge"); | - |
522 | exit(1); never executed: exit(1); | 0 |
523 | } | - |
524 | } never executed: end of block | 0 |
525 | | - |
526 | remin = STDIN_FILENO; | - |
527 | remout = STDOUT_FILENO; | - |
528 | | - |
529 | if (fflag) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
530 | | - |
531 | (void) response(); | - |
532 | source(argc, argv); | - |
533 | exit(errs != 0); never executed: exit(errs != 0); | 0 |
534 | } | - |
535 | if (tflag) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
536 | | - |
537 | sink(argc, argv); | - |
538 | exit(errs != 0); never executed: exit(errs != 0); | 0 |
539 | } | - |
540 | if (argc < 2)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
541 | usage(); never executed: usage(); | 0 |
542 | if (argc > 2)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
543 | targetshouldbedirectory = 1; never executed: targetshouldbedirectory = 1; | 0 |
544 | | - |
545 | remin = remout = -1; | - |
546 | do_cmd_pid = -1; | - |
547 | | - |
548 | (void) snprintf(cmd, sizeof cmd, "scp%s%s%s%s", | - |
549 | verbose_mode ? " -v" : "", | - |
550 | iamrecursive ? " -r" : "", pflag ? " -p" : "", | - |
551 | targetshouldbedirectory ? " -d" : ""); | - |
552 | | - |
553 | (void) signal(SIGPIPE, lostconn); | - |
554 | | - |
555 | if (colon(argv[argc - 1])) TRUE | never evaluated | FALSE | never evaluated |
| 0 |
556 | toremote(argc, argv); never executed: toremote(argc, argv); | 0 |
557 | else { | - |
558 | if (targetshouldbedirectory)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
559 | verifydir(argv[argc - 1]); never executed: verifydir(argv[argc - 1]); | 0 |
560 | tolocal(argc, argv); | - |
561 | } never executed: end of block | 0 |
562 | | - |
563 | | - |
564 | | - |
565 | | - |
566 | if (do_cmd_pid != -1 && errs == 0) {TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
567 | if (remin != -1)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
568 | (void) close(remin); never executed: (void) close(remin); | 0 |
569 | if (remout != -1)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
570 | (void) close(remout); never executed: (void) close(remout); | 0 |
571 | if (waitpid(do_cmd_pid, &status, 0) == -1)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
572 | errs = 1; never executed: errs = 1; | 0 |
573 | else { | - |
574 | if (!WIFEXITED(status) || WEXITSTATUS(status) != 0)TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
575 | errs = 1; never executed: errs = 1; | 0 |
576 | } never executed: end of block | 0 |
577 | } | - |
578 | exit(errs != 0); never executed: exit(errs != 0); | 0 |
579 | } | - |
580 | | - |
581 | | - |
582 | static int | - |
583 | scpio(void *_cnt, size_t s) | - |
584 | { | - |
585 | off_t *cnt = (off_t *)_cnt; | - |
586 | | - |
587 | *cnt += s; | - |
588 | if (limit_kbps > 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
589 | bandwidth_limit(&bwlimit, s); never executed: bandwidth_limit(&bwlimit, s); | 0 |
590 | return 0; never executed: return 0; | 0 |
591 | } | - |
592 | | - |
593 | static int | - |
594 | do_times(int fd, int verb, const struct stat *sb) | - |
595 | { | - |
596 | | - |
597 | char buf[(20 + 7 + 2) * 2 + 2]; | - |
598 | | - |
599 | (void)snprintf(buf, sizeof(buf), "T%llu 0 %llu 0\n", | - |
600 | (unsigned long long) (sb->st_mtime < 0 ? 0 : sb->st_mtime), | - |
601 | (unsigned long long) (sb->st_atime < 0 ? 0 : sb->st_atime)); | - |
602 | if (verb) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
603 | fprintf(stderr, "File mtime %lld atime %lld\n", | - |
604 | (long long)sb->st_mtime, (long long)sb->st_atime); | - |
605 | fprintf(stderr, "Sending file timestamps: %s", buf); | - |
606 | } never executed: end of block | 0 |
607 | (void) atomicio(vwrite, fd, buf, strlen(buf)); | - |
608 | return (response()); never executed: return (response()); | 0 |
609 | } | - |
610 | | - |
611 | static int | - |
612 | parse_scp_uri(const char *uri, char **userp, char **hostp, int *portp, | - |
613 | char **pathp) | - |
614 | { | - |
615 | int r; | - |
616 | | - |
617 | r = parse_uri("scp", uri, userp, hostp, portp, pathp); | - |
618 | if (r == 0 && *pathp == NULL)TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
619 | *pathp = xstrdup("."); never executed: *pathp = xstrdup("."); | 0 |
620 | return r; never executed: return r; | 0 |
621 | } | - |
622 | | - |
623 | void | - |
624 | toremote(int argc, char **argv) | - |
625 | { | - |
626 | char *suser = NULL, *host = NULL, *src = NULL; | - |
627 | char *bp, *tuser, *thost, *targ; | - |
628 | int sport = -1, tport = -1; | - |
629 | arglist alist; | - |
630 | int i, r; | - |
631 | u_int j; | - |
632 | | - |
633 | memset(&alist, '\0', sizeof(alist)); | - |
634 | alist.list = NULL; | - |
635 | | - |
636 | | - |
637 | r = parse_scp_uri(argv[argc - 1], &tuser, &thost, &tport, &targ); | - |
638 | if (r == -1) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
639 | fmprintf(stderr, "%s: invalid uri\n", argv[argc - 1]); | - |
640 | ++errs; | - |
641 | goto out; never executed: goto out; | 0 |
642 | } | - |
643 | if (r != 0) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
644 | if (parse_user_host_path(argv[argc - 1], &tuser, &thost,TRUE | never evaluated | FALSE | never evaluated |
| 0 |
645 | &targ) == -1) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
646 | fmprintf(stderr, "%s: invalid target\n", argv[argc - 1]); | - |
647 | ++errs; | - |
648 | goto out; never executed: goto out; | 0 |
649 | } | - |
650 | } never executed: end of block | 0 |
651 | if (tuser != NULL && !okname(tuser)) {TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
652 | ++errs; | - |
653 | goto out; never executed: goto out; | 0 |
654 | } | - |
655 | | - |
656 | | - |
657 | for (i = 0; i < argc - 1; i++) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
658 | free(suser); | - |
659 | free(host); | - |
660 | free(src); | - |
661 | r = parse_scp_uri(argv[i], &suser, &host, &sport, &src); | - |
662 | if (r == -1) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
663 | fmprintf(stderr, "%s: invalid uri\n", argv[i]); | - |
664 | ++errs; | - |
665 | continue; never executed: continue; | 0 |
666 | } | - |
667 | if (r != 0) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
668 | parse_user_host_path(argv[i], &suser, &host, &src); | - |
669 | } never executed: end of block | 0 |
670 | if (suser != NULL && !okname(suser)) {TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
671 | ++errs; | - |
672 | continue; never executed: continue; | 0 |
673 | } | - |
674 | if (host && throughlocal) { TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
675 | xasprintf(&bp, "%s -f %s%s", cmd, | - |
676 | *src == '-' ? "-- " : "", src); | - |
677 | if (do_cmd(host, suser, sport, bp, &remin, &remout) < 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
678 | exit(1); never executed: exit(1); | 0 |
679 | free(bp); | - |
680 | xasprintf(&bp, "%s -t %s%s", cmd, | - |
681 | *targ == '-' ? "-- " : "", targ); | - |
682 | if (do_cmd2(thost, tuser, tport, bp, remin, remout) < 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
683 | exit(1); never executed: exit(1); | 0 |
684 | free(bp); | - |
685 | (void) close(remin); | - |
686 | (void) close(remout); | - |
687 | remin = remout = -1; | - |
688 | } else if (host) { never executed: end of block TRUE | never evaluated | FALSE | never evaluated |
| 0 |
689 | if (tport != -1 && tport != SSH_DEFAULT_PORT) {TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
690 | | - |
691 | fatal("target port not supported with two " | - |
692 | "remote hosts without the -3 option"); | - |
693 | } never executed: end of block | 0 |
694 | | - |
695 | freeargs(&alist); | - |
696 | addargs(&alist, "%s", ssh_program); | - |
697 | addargs(&alist, "-x"); | - |
698 | addargs(&alist, "-oClearAllForwardings=yes"); | - |
699 | addargs(&alist, "-n"); | - |
700 | for (j = 0; j < remote_remote_args.num; j++) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
701 | addargs(&alist, "%s", | - |
702 | remote_remote_args.list[j]); | - |
703 | } never executed: end of block | 0 |
704 | | - |
705 | if (sport != -1) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
706 | addargs(&alist, "-p"); | - |
707 | addargs(&alist, "%d", sport); | - |
708 | } never executed: end of block | 0 |
709 | if (suser) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
710 | addargs(&alist, "-l"); | - |
711 | addargs(&alist, "%s", suser); | - |
712 | } never executed: end of block | 0 |
713 | addargs(&alist, "--"); | - |
714 | addargs(&alist, "%s", host); | - |
715 | addargs(&alist, "%s", cmd); | - |
716 | addargs(&alist, "%s", src); | - |
717 | addargs(&alist, "%s%s%s:%s", | - |
718 | tuser ? tuser : "", tuser ? "@" : "", | - |
719 | thost, targ); | - |
720 | if (do_local_cmd(&alist) != 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
721 | errs = 1; never executed: errs = 1; | 0 |
722 | } else { never executed: end of block | 0 |
723 | if (remin == -1) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
724 | xasprintf(&bp, "%s -t %s%s", cmd, | - |
725 | *targ == '-' ? "-- " : "", targ); | - |
726 | if (do_cmd(thost, tuser, tport, bp, &remin,TRUE | never evaluated | FALSE | never evaluated |
| 0 |
727 | &remout) < 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
728 | exit(1); never executed: exit(1); | 0 |
729 | if (response() < 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
730 | exit(1); never executed: exit(1); | 0 |
731 | free(bp); | - |
732 | } never executed: end of block | 0 |
733 | source(1, argv + i); | - |
734 | } never executed: end of block | 0 |
735 | } | - |
736 | out: code before this statement never executed: out: | 0 |
737 | free(tuser); | - |
738 | free(thost); | - |
739 | free(targ); | - |
740 | free(suser); | - |
741 | free(host); | - |
742 | free(src); | - |
743 | } never executed: end of block | 0 |
744 | | - |
745 | void | - |
746 | tolocal(int argc, char **argv) | - |
747 | { | - |
748 | char *bp, *host = NULL, *src = NULL, *suser = NULL; | - |
749 | arglist alist; | - |
750 | int i, r, sport = -1; | - |
751 | | - |
752 | memset(&alist, '\0', sizeof(alist)); | - |
753 | alist.list = NULL; | - |
754 | | - |
755 | for (i = 0; i < argc - 1; i++) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
756 | free(suser); | - |
757 | free(host); | - |
758 | free(src); | - |
759 | r = parse_scp_uri(argv[i], &suser, &host, &sport, &src); | - |
760 | if (r == -1) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
761 | fmprintf(stderr, "%s: invalid uri\n", argv[i]); | - |
762 | ++errs; | - |
763 | continue; never executed: continue; | 0 |
764 | } | - |
765 | if (r != 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
766 | parse_user_host_path(argv[i], &suser, &host, &src); never executed: parse_user_host_path(argv[i], &suser, &host, &src); | 0 |
767 | if (suser != NULL && !okname(suser)) {TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
768 | ++errs; | - |
769 | continue; never executed: continue; | 0 |
770 | } | - |
771 | if (!host) { TRUE | never evaluated | FALSE | never evaluated |
| 0 |
772 | freeargs(&alist); | - |
773 | addargs(&alist, "%s", _PATH_CP); | - |
774 | if (iamrecursive)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
775 | addargs(&alist, "-r"); never executed: addargs(&alist, "-r"); | 0 |
776 | if (pflag)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
777 | addargs(&alist, "-p"); never executed: addargs(&alist, "-p"); | 0 |
778 | addargs(&alist, "--"); | - |
779 | addargs(&alist, "%s", argv[i]); | - |
780 | addargs(&alist, "%s", argv[argc-1]); | - |
781 | if (do_local_cmd(&alist))TRUE | never evaluated | FALSE | never evaluated |
| 0 |
782 | ++errs; never executed: ++errs; | 0 |
783 | continue; never executed: continue; | 0 |
784 | } | - |
785 | | - |
786 | xasprintf(&bp, "%s -f %s%s", | - |
787 | cmd, *src == '-' ? "-- " : "", src); | - |
788 | if (do_cmd(host, suser, sport, bp, &remin, &remout) < 0) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
789 | free(bp); | - |
790 | ++errs; | - |
791 | continue; never executed: continue; | 0 |
792 | } | - |
793 | free(bp); | - |
794 | sink(1, argv + argc - 1); | - |
795 | (void) close(remin); | - |
796 | remin = remout = -1; | - |
797 | } never executed: end of block | 0 |
798 | free(suser); | - |
799 | free(host); | - |
800 | free(src); | - |
801 | } never executed: end of block | 0 |
802 | | - |
803 | void | - |
804 | source(int argc, char **argv) | - |
805 | { | - |
806 | struct stat stb; | - |
807 | static BUF buffer; | - |
808 | BUF *bp; | - |
809 | off_t i, statbytes; | - |
810 | size_t amt, nr; | - |
811 | int fd = -1, haderr, indx; | - |
812 | char *last, *name, buf[2048], encname[PATH_MAX]; | - |
813 | int len; | - |
814 | | - |
815 | for (indx = 0; indx < argc; ++indx) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
816 | name = argv[indx]; | - |
817 | statbytes = 0; | - |
818 | len = strlen(name); | - |
819 | while (len > 1 && name[len-1] == '/')TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
820 | name[--len] = '\0'; never executed: name[--len] = '\0'; | 0 |
821 | if ((fd = open(name, O_RDONLY|O_NONBLOCK, 0)) < 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
822 | goto syserr; never executed: goto syserr; | 0 |
823 | if (strchr(name, '\n') != NULL) {TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
824 | strnvis(encname, name, sizeof(encname), VIS_NL); | - |
825 | name = encname; | - |
826 | } never executed: end of block | 0 |
827 | if (fstat(fd, &stb) < 0) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
828 | syserr: run_err("%s: %s", name, strerror(errno)); | - |
829 | goto next; never executed: goto next; | 0 |
830 | } | - |
831 | if (stb.st_size < 0) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
832 | run_err("%s: %s", name, "Negative file size"); | - |
833 | goto next; never executed: goto next; | 0 |
834 | } | - |
835 | unset_nonblock(fd); | - |
836 | switch (stb.st_mode & S_IFMT) { | - |
837 | case S_IFREG: never executed: case 0100000 : | 0 |
838 | break; never executed: break; | 0 |
839 | case S_IFDIR: never executed: case 0040000 : | 0 |
840 | if (iamrecursive) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
841 | rsource(name, &stb); | - |
842 | goto next; never executed: goto next; | 0 |
843 | } | - |
844 | | - |
845 | default: code before this statement never executed: default: never executed: default: | 0 |
846 | run_err("%s: not a regular file", name); | - |
847 | goto next; never executed: goto next; | 0 |
848 | } | - |
849 | if ((last = strrchr(name, '/')) == NULL)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
850 | last = name; never executed: last = name; | 0 |
851 | else | - |
852 | ++last; never executed: ++last; | 0 |
853 | curfile = last; | - |
854 | if (pflag) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
855 | if (do_times(remout, verbose_mode, &stb) < 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
856 | goto next; never executed: goto next; | 0 |
857 | } never executed: end of block | 0 |
858 | #define FILEMODEMASK (S_ISUID|S_ISGID|S_IRWXU|S_IRWXG|S_IRWXO) | - |
859 | snprintf(buf, sizeof buf, "C%04o %lld %s\n", | - |
860 | (u_int) (stb.st_mode & FILEMODEMASK), | - |
861 | (long long)stb.st_size, last); | - |
862 | if (verbose_mode)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
863 | fmprintf(stderr, "Sending file modes: %s", buf); never executed: fmprintf( stderr , "Sending file modes: %s", buf); | 0 |
864 | (void) atomicio(vwrite, remout, buf, strlen(buf)); | - |
865 | if (response() < 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
866 | goto next; never executed: goto next; | 0 |
867 | if ((bp = allocbuf(&buffer, fd, COPY_BUFLEN)) == NULL) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
868 | next: if (fd != -1) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
869 | (void) close(fd); | - |
870 | fd = -1; | - |
871 | } never executed: end of block | 0 |
872 | continue; never executed: continue; | 0 |
873 | } | - |
874 | if (showprogress)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
875 | start_progress_meter(curfile, stb.st_size, &statbytes); never executed: start_progress_meter(curfile, stb.st_size, &statbytes); | 0 |
876 | set_nonblock(remout); | - |
877 | for (haderr = i = 0; i < stb.st_size; i += bp->cnt) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
878 | amt = bp->cnt; | - |
879 | if (i + (off_t)amt > stb.st_size)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
880 | amt = stb.st_size - i; never executed: amt = stb.st_size - i; | 0 |
881 | if (!haderr) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
882 | if ((nr = atomicio(read, fd,TRUE | never evaluated | FALSE | never evaluated |
| 0 |
883 | bp->buf, amt)) != amt) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
884 | haderr = errno; | - |
885 | memset(bp->buf + nr, 0, amt - nr); | - |
886 | } never executed: end of block | 0 |
887 | } never executed: end of block | 0 |
888 | | - |
889 | if (haderr) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
890 | (void)atomicio(vwrite, remout, bp->buf, amt); | - |
891 | memset(bp->buf, 0, amt); | - |
892 | continue; never executed: continue; | 0 |
893 | } | - |
894 | if (atomicio6(vwrite, remout, bp->buf, amt, scpio,TRUE | never evaluated | FALSE | never evaluated |
| 0 |
895 | &statbytes) != amt)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
896 | haderr = errno; never executed: haderr = (*__errno_location ()) ; | 0 |
897 | } never executed: end of block | 0 |
898 | unset_nonblock(remout); | - |
899 | | - |
900 | if (fd != -1) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
901 | if (close(fd) < 0 && !haderr)TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
902 | haderr = errno; never executed: haderr = (*__errno_location ()) ; | 0 |
903 | fd = -1; | - |
904 | } never executed: end of block | 0 |
905 | if (!haderr)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
906 | (void) atomicio(vwrite, remout, "", 1); never executed: (void) atomicio((ssize_t (*)(int, void *, size_t))write, remout, "", 1); | 0 |
907 | else | - |
908 | run_err("%s: %s", name, strerror(haderr)); never executed: run_err("%s: %s", name, strerror(haderr)); | 0 |
909 | (void) response(); | - |
910 | if (showprogress)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
911 | stop_progress_meter(); never executed: stop_progress_meter(); | 0 |
912 | } never executed: end of block | 0 |
913 | } never executed: end of block | 0 |
914 | | - |
915 | void | - |
916 | rsource(char *name, struct stat *statp) | - |
917 | { | - |
918 | DIR *dirp; | - |
919 | struct dirent *dp; | - |
920 | char *last, *vect[1], path[PATH_MAX]; | - |
921 | | - |
922 | if (!(dirp = opendir(name))) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
923 | run_err("%s: %s", name, strerror(errno)); | - |
924 | return; never executed: return; | 0 |
925 | } | - |
926 | last = strrchr(name, '/'); | - |
927 | if (last == NULL)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
928 | last = name; never executed: last = name; | 0 |
929 | else | - |
930 | last++; never executed: last++; | 0 |
931 | if (pflag) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
932 | if (do_times(remout, verbose_mode, statp) < 0) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
933 | closedir(dirp); | - |
934 | return; never executed: return; | 0 |
935 | } | - |
936 | } never executed: end of block | 0 |
937 | (void) snprintf(path, sizeof path, "D%04o %d %.1024s\n", | - |
938 | (u_int) (statp->st_mode & FILEMODEMASK), 0, last); | - |
939 | if (verbose_mode)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
940 | fmprintf(stderr, "Entering directory: %s", path); never executed: fmprintf( stderr , "Entering directory: %s", path); | 0 |
941 | (void) atomicio(vwrite, remout, path, strlen(path)); | - |
942 | if (response() < 0) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
943 | closedir(dirp); | - |
944 | return; never executed: return; | 0 |
945 | } | - |
946 | while ((dp = readdir(dirp)) != NULL) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
947 | if (dp->d_ino == 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
948 | continue; never executed: continue; | 0 |
949 | if (!strcmp(dp->d_name, ".") || !strcmp(dp->d_name, "..")) never executed: __result = (((const unsigned char *) (const char *) ( dp->d_name ))[3] - __s2[3]); never executed: end of block never executed: end of block never executed: __result = (((const unsigned char *) (const char *) ( "." ))[3] - __s2[3]); never executed: end of block never executed: end of block never executed: __result = (((const unsigned char *) (const char *) ( dp->d_name ))[3] - __s2[3]); never executed: end of block never executed: end of block never executed: __result = (((const unsigned char *) (const char *) ( ".." ))[3] - __s2[3]); never executed: end of block never executed: end of block TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
950 | continue; never executed: continue; | 0 |
951 | if (strlen(name) + 1 + strlen(dp->d_name) >= sizeof(path) - 1) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
952 | run_err("%s/%s: name too long", name, dp->d_name); | - |
953 | continue; never executed: continue; | 0 |
954 | } | - |
955 | (void) snprintf(path, sizeof path, "%s/%s", name, dp->d_name); | - |
956 | vect[0] = path; | - |
957 | source(1, vect); | - |
958 | } never executed: end of block | 0 |
959 | (void) closedir(dirp); | - |
960 | (void) atomicio(vwrite, remout, "E\n", 2); | - |
961 | (void) response(); | - |
962 | } never executed: end of block | 0 |
963 | | - |
964 | #define TYPE_OVERFLOW(type, val) \ | - |
965 | ((sizeof(type) == 4 && (val) > INT32_MAX) || \ | - |
966 | (sizeof(type) == 8 && (val) > INT64_MAX) || \ | - |
967 | (sizeof(type) != 4 && sizeof(type) != 8)) | - |
968 | | - |
969 | void | - |
970 | sink(int argc, char **argv) | - |
971 | { | - |
972 | static BUF buffer; | - |
973 | struct stat stb; | - |
974 | enum { | - |
975 | YES, NO, DISPLAYED | - |
976 | } wrerr; | - |
977 | BUF *bp; | - |
978 | off_t i; | - |
979 | size_t j, count; | - |
980 | int amt, exists, first, ofd; | - |
981 | mode_t mode, omode, mask; | - |
982 | off_t size, statbytes; | - |
983 | unsigned long long ull; | - |
984 | int setimes, targisdir, wrerrno = 0; | - |
985 | char ch, *cp, *np, *targ, *why, *vect[1], buf[2048], visbuf[2048]; | - |
986 | struct timeval tv[2]; | - |
987 | | - |
988 | #define atime tv[0] | - |
989 | #define mtime tv[1] | - |
990 | #define SCREWUP(str) { why = str; goto screwup; } | - |
991 | | - |
992 | if (TYPE_OVERFLOW(time_t, 0) || TYPE_OVERFLOW(off_t, 0))TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
993 | SCREWUP("Unexpected off_t/time_t size"); never executed: goto screwup; | 0 |
994 | | - |
995 | setimes = targisdir = 0; | - |
996 | mask = umask(0); | - |
997 | if (!pflag)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
998 | (void) umask(mask); never executed: (void) umask(mask); | 0 |
999 | if (argc != 1) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1000 | run_err("ambiguous target"); | - |
1001 | exit(1); never executed: exit(1); | 0 |
1002 | } | - |
1003 | targ = *argv; | - |
1004 | if (targetshouldbedirectory)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1005 | verifydir(targ); never executed: verifydir(targ); | 0 |
1006 | | - |
1007 | (void) atomicio(vwrite, remout, "", 1); | - |
1008 | if (stat(targ, &stb) == 0 && S_ISDIR(stb.st_mode))TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1009 | targisdir = 1; never executed: targisdir = 1; | 0 |
1010 | for (first = 1;; first = 0) { | - |
1011 | cp = buf; | - |
1012 | if (atomicio(read, remin, cp, 1) != 1)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1013 | return; never executed: return; | 0 |
1014 | if (*cp++ == '\n')TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1015 | SCREWUP("unexpected <newline>"); never executed: goto screwup; | 0 |
1016 | do { | - |
1017 | if (atomicio(read, remin, &ch, sizeof(ch)) != sizeof(ch))TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1018 | SCREWUP("lost connection"); never executed: goto screwup; | 0 |
1019 | *cp++ = ch; | - |
1020 | } while (cp < &buf[sizeof(buf) - 1] && ch != '\n'); never executed: end of block TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1021 | *cp = 0; | - |
1022 | if (verbose_mode)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1023 | fmprintf(stderr, "Sink: %s", buf); never executed: fmprintf( stderr , "Sink: %s", buf); | 0 |
1024 | | - |
1025 | if (buf[0] == '\01' || buf[0] == '\02') {TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1026 | if (iamremote == 0) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1027 | (void) snmprintf(visbuf, sizeof(visbuf), | - |
1028 | NULL, "%s", buf + 1); | - |
1029 | (void) atomicio(vwrite, STDERR_FILENO, | - |
1030 | visbuf, strlen(visbuf)); | - |
1031 | } never executed: end of block | 0 |
1032 | if (buf[0] == '\02')TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1033 | exit(1); never executed: exit(1); | 0 |
1034 | ++errs; | - |
1035 | continue; never executed: continue; | 0 |
1036 | } | - |
1037 | if (buf[0] == 'E') {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1038 | (void) atomicio(vwrite, remout, "", 1); | - |
1039 | return; never executed: return; | 0 |
1040 | } | - |
1041 | if (ch == '\n')TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1042 | *--cp = 0; never executed: *--cp = 0; | 0 |
1043 | | - |
1044 | cp = buf; | - |
1045 | if (*cp == 'T') {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1046 | setimes++; | - |
1047 | cp++; | - |
1048 | if (!isdigit((unsigned char)*cp))TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1049 | SCREWUP("mtime.sec not present"); never executed: goto screwup; | 0 |
1050 | ull = strtoull(cp, &cp, 10); | - |
1051 | if (!cp || *cp++ != ' ')TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1052 | SCREWUP("mtime.sec not delimited"); never executed: goto screwup; | 0 |
1053 | if (TYPE_OVERFLOW(time_t, ull))TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1054 | setimes = 0; never executed: setimes = 0; | 0 |
1055 | mtime.tv_sec = ull; | - |
1056 | mtime.tv_usec = strtol(cp, &cp, 10); | - |
1057 | if (!cp || *cp++ != ' ' || mtime.tv_usec < 0 ||TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1058 | mtime.tv_usec > 999999)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1059 | SCREWUP("mtime.usec not delimited"); never executed: goto screwup; | 0 |
1060 | if (!isdigit((unsigned char)*cp))TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1061 | SCREWUP("atime.sec not present"); never executed: goto screwup; | 0 |
1062 | ull = strtoull(cp, &cp, 10); | - |
1063 | if (!cp || *cp++ != ' ')TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1064 | SCREWUP("atime.sec not delimited"); never executed: goto screwup; | 0 |
1065 | if (TYPE_OVERFLOW(time_t, ull))TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1066 | setimes = 0; never executed: setimes = 0; | 0 |
1067 | atime.tv_sec = ull; | - |
1068 | atime.tv_usec = strtol(cp, &cp, 10); | - |
1069 | if (!cp || *cp++ != '\0' || atime.tv_usec < 0 ||TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1070 | atime.tv_usec > 999999)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1071 | SCREWUP("atime.usec not delimited"); never executed: goto screwup; | 0 |
1072 | (void) atomicio(vwrite, remout, "", 1); | - |
1073 | continue; never executed: continue; | 0 |
1074 | } | - |
1075 | if (*cp != 'C' && *cp != 'D') {TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1076 | | - |
1077 | | - |
1078 | | - |
1079 | | - |
1080 | | - |
1081 | | - |
1082 | | - |
1083 | if (first) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1084 | run_err("%s", cp); | - |
1085 | exit(1); never executed: exit(1); | 0 |
1086 | } | - |
1087 | SCREWUP("expected control record"); never executed: goto screwup; | 0 |
1088 | } | - |
1089 | mode = 0; | - |
1090 | for (++cp; cp < buf + 5; cp++) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1091 | if (*cp < '0' || *cp > '7')TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1092 | SCREWUP("bad mode"); never executed: goto screwup; | 0 |
1093 | mode = (mode << 3) | (*cp - '0'); | - |
1094 | } never executed: end of block | 0 |
1095 | if (!pflag)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1096 | mode &= ~mask; never executed: mode &= ~mask; | 0 |
1097 | if (*cp++ != ' ')TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1098 | SCREWUP("mode not delimited"); never executed: goto screwup; | 0 |
1099 | | - |
1100 | if (!isdigit((unsigned char)*cp))TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1101 | SCREWUP("size not present"); never executed: goto screwup; | 0 |
1102 | ull = strtoull(cp, &cp, 10); | - |
1103 | if (!cp || *cp++ != ' ')TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1104 | SCREWUP("size not delimited"); never executed: goto screwup; | 0 |
1105 | if (TYPE_OVERFLOW(off_t, ull))TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1106 | SCREWUP("size out of range"); never executed: goto screwup; | 0 |
1107 | size = (off_t)ull; | - |
1108 | | - |
1109 | if ((strchr(cp, '/') != NULL) || (strcmp(cp, "..") == 0)) { never executed: __result = (((const unsigned char *) (const char *) ( cp ))[3] - __s2[3]); never executed: end of block never executed: end of block never executed: __result = (((const unsigned char *) (const char *) ( ".." ))[3] - __s2[3]); never executed: end of block never executed: end of block TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1110 | run_err("error: unexpected filename: %s", cp); | - |
1111 | exit(1); never executed: exit(1); | 0 |
1112 | } | - |
1113 | if (targisdir) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1114 | static char *namebuf; | - |
1115 | static size_t cursize; | - |
1116 | size_t need; | - |
1117 | | - |
1118 | need = strlen(targ) + strlen(cp) + 250; | - |
1119 | if (need > cursize) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1120 | free(namebuf); | - |
1121 | namebuf = xmalloc(need); | - |
1122 | cursize = need; | - |
1123 | } never executed: end of block | 0 |
1124 | (void) snprintf(namebuf, need, "%s%s%s", targ, | - |
1125 | strcmp(targ, "/") ? "/" : "", cp); never executed: __result = (((const unsigned char *) (const char *) ( targ ))[3] - __s2[3]); never executed: end of block never executed: end of block never executed: __result = (((const unsigned char *) (const char *) ( "/" ))[3] - __s2[3]); never executed: end of block never executed: end of block TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1126 | np = namebuf; | - |
1127 | } else never executed: end of block | 0 |
1128 | np = targ; never executed: np = targ; | 0 |
1129 | curfile = cp; | - |
1130 | exists = stat(np, &stb) == 0; | - |
1131 | if (buf[0] == 'D') {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1132 | int mod_flag = pflag; | - |
1133 | if (!iamrecursive)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1134 | SCREWUP("received directory without -r"); never executed: goto screwup; | 0 |
1135 | if (exists) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1136 | if (!S_ISDIR(stb.st_mode)) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1137 | errno = ENOTDIR; | - |
1138 | goto bad; never executed: goto bad; | 0 |
1139 | } | - |
1140 | if (pflag)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1141 | (void) chmod(np, mode); never executed: (void) chmod(np, mode); | 0 |
1142 | } else { never executed: end of block | 0 |
1143 | | - |
1144 | | - |
1145 | mod_flag = 1; | - |
1146 | if (mkdir(np, mode | S_IRWXU) < 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1147 | goto bad; never executed: goto bad; | 0 |
1148 | } never executed: end of block | 0 |
1149 | vect[0] = xstrdup(np); | - |
1150 | sink(1, vect); | - |
1151 | if (setimes) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1152 | setimes = 0; | - |
1153 | if (utimes(vect[0], tv) < 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1154 | run_err("%s: set times: %s", never executed: run_err("%s: set times: %s", vect[0], strerror( (*__errno_location ()) )); | 0 |
1155 | vect[0], strerror(errno)); never executed: run_err("%s: set times: %s", vect[0], strerror( (*__errno_location ()) )); | 0 |
1156 | } never executed: end of block | 0 |
1157 | if (mod_flag)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1158 | (void) chmod(vect[0], mode); never executed: (void) chmod(vect[0], mode); | 0 |
1159 | free(vect[0]); | - |
1160 | continue; never executed: continue; | 0 |
1161 | } | - |
1162 | omode = mode; | - |
1163 | mode |= S_IWUSR; | - |
1164 | if ((ofd = open(np, O_WRONLY|O_CREAT, mode)) < 0) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1165 | bad: run_err("%s: %s", np, strerror(errno)); | - |
1166 | continue; never executed: continue; | 0 |
1167 | } | - |
1168 | (void) atomicio(vwrite, remout, "", 1); | - |
1169 | if ((bp = allocbuf(&buffer, ofd, COPY_BUFLEN)) == NULL) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1170 | (void) close(ofd); | - |
1171 | continue; never executed: continue; | 0 |
1172 | } | - |
1173 | cp = bp->buf; | - |
1174 | wrerr = NO; | - |
1175 | | - |
1176 | statbytes = 0; | - |
1177 | if (showprogress)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1178 | start_progress_meter(curfile, size, &statbytes); never executed: start_progress_meter(curfile, size, &statbytes); | 0 |
1179 | set_nonblock(remin); | - |
1180 | for (count = i = 0; i < size; i += bp->cnt) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1181 | amt = bp->cnt; | - |
1182 | if (i + amt > size)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1183 | amt = size - i; never executed: amt = size - i; | 0 |
1184 | count += amt; | - |
1185 | do { | - |
1186 | j = atomicio6(read, remin, cp, amt, | - |
1187 | scpio, &statbytes); | - |
1188 | if (j == 0) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1189 | run_err("%s", j != EPIPE ? | - |
1190 | strerror(errno) : | - |
1191 | "dropped connection"); | - |
1192 | exit(1); never executed: exit(1); | 0 |
1193 | } | - |
1194 | amt -= j; | - |
1195 | cp += j; | - |
1196 | } while (amt > 0); never executed: end of block TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1197 | | - |
1198 | if (count == bp->cnt) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1199 | | - |
1200 | if (wrerr == NO) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1201 | if (atomicio(vwrite, ofd, bp->buf,TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1202 | count) != count) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1203 | wrerr = YES; | - |
1204 | wrerrno = errno; | - |
1205 | } never executed: end of block | 0 |
1206 | } never executed: end of block | 0 |
1207 | count = 0; | - |
1208 | cp = bp->buf; | - |
1209 | } never executed: end of block | 0 |
1210 | } never executed: end of block | 0 |
1211 | unset_nonblock(remin); | - |
1212 | if (count != 0 && wrerr == NO &&TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1213 | atomicio(vwrite, ofd, bp->buf, count) != count) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1214 | wrerr = YES; | - |
1215 | wrerrno = errno; | - |
1216 | } never executed: end of block | 0 |
1217 | if (wrerr == NO && (!exists || S_ISREG(stb.st_mode)) &&TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1218 | ftruncate(ofd, size) != 0) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1219 | run_err("%s: truncate: %s", np, strerror(errno)); | - |
1220 | wrerr = DISPLAYED; | - |
1221 | } never executed: end of block | 0 |
1222 | if (pflag) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1223 | if (exists || omode != mode)TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1224 | #ifdef HAVE_FCHMOD | - |
1225 | if (fchmod(ofd, omode)) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1226 | #else /* HAVE_FCHMOD */ | - |
1227 | if (chmod(np, omode)) { | - |
1228 | #endif /* HAVE_FCHMOD */ | - |
1229 | run_err("%s: set mode: %s", | - |
1230 | np, strerror(errno)); | - |
1231 | wrerr = DISPLAYED; | - |
1232 | } never executed: end of block | 0 |
1233 | } else { never executed: end of block | 0 |
1234 | if (!exists && omode != mode)TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1235 | #ifdef HAVE_FCHMOD | - |
1236 | if (fchmod(ofd, omode & ~mask)) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1237 | #else /* HAVE_FCHMOD */ | - |
1238 | if (chmod(np, omode & ~mask)) { | - |
1239 | #endif /* HAVE_FCHMOD */ | - |
1240 | run_err("%s: set mode: %s", | - |
1241 | np, strerror(errno)); | - |
1242 | wrerr = DISPLAYED; | - |
1243 | } never executed: end of block | 0 |
1244 | } never executed: end of block | 0 |
1245 | if (close(ofd) == -1) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1246 | wrerr = YES; | - |
1247 | wrerrno = errno; | - |
1248 | } never executed: end of block | 0 |
1249 | (void) response(); | - |
1250 | if (showprogress)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1251 | stop_progress_meter(); never executed: stop_progress_meter(); | 0 |
1252 | if (setimes && wrerr == NO) {TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1253 | setimes = 0; | - |
1254 | if (utimes(np, tv) < 0) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1255 | run_err("%s: set times: %s", | - |
1256 | np, strerror(errno)); | - |
1257 | wrerr = DISPLAYED; | - |
1258 | } never executed: end of block | 0 |
1259 | } never executed: end of block | 0 |
1260 | switch (wrerr) { | - |
1261 | case YES: never executed: case YES: | 0 |
1262 | run_err("%s: %s", np, strerror(wrerrno)); | - |
1263 | break; never executed: break; | 0 |
1264 | case NO: never executed: case NO: | 0 |
1265 | (void) atomicio(vwrite, remout, "", 1); | - |
1266 | break; never executed: break; | 0 |
1267 | case DISPLAYED: never executed: case DISPLAYED: | 0 |
1268 | break; never executed: break; | 0 |
1269 | } | - |
1270 | } never executed: end of block | 0 |
1271 | screwup: code before this statement never executed: screwup: | 0 |
1272 | run_err("protocol error: %s", why); | - |
1273 | exit(1); never executed: exit(1); | 0 |
1274 | } | - |
1275 | | - |
1276 | int | - |
1277 | response(void) | - |
1278 | { | - |
1279 | char ch, *cp, resp, rbuf[2048], visbuf[2048]; | - |
1280 | | - |
1281 | if (atomicio(read, remin, &resp, sizeof(resp)) != sizeof(resp))TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1282 | lostconn(0); never executed: lostconn(0); | 0 |
1283 | | - |
1284 | cp = rbuf; | - |
1285 | switch (resp) { | - |
1286 | case 0: never executed: case 0: | 0 |
1287 | return (0); never executed: return (0); | 0 |
1288 | default: never executed: default: | 0 |
1289 | *cp++ = resp; | - |
1290 | | - |
1291 | case 1: code before this statement never executed: case 1: never executed: case 1: | 0 |
1292 | case 2: never executed: case 2: | 0 |
1293 | do { | - |
1294 | if (atomicio(read, remin, &ch, sizeof(ch)) != sizeof(ch))TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1295 | lostconn(0); never executed: lostconn(0); | 0 |
1296 | *cp++ = ch; | - |
1297 | } while (cp < &rbuf[sizeof(rbuf) - 1] && ch != '\n'); never executed: end of block TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1298 | | - |
1299 | if (!iamremote) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1300 | cp[-1] = '\0'; | - |
1301 | (void) snmprintf(visbuf, sizeof(visbuf), | - |
1302 | NULL, "%s\n", rbuf); | - |
1303 | (void) atomicio(vwrite, STDERR_FILENO, | - |
1304 | visbuf, strlen(visbuf)); | - |
1305 | } never executed: end of block | 0 |
1306 | ++errs; | - |
1307 | if (resp == 1)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1308 | return (-1); never executed: return (-1); | 0 |
1309 | exit(1); never executed: exit(1); | 0 |
1310 | } | - |
1311 | | - |
1312 | } | - |
1313 | | - |
1314 | void | - |
1315 | usage(void) | - |
1316 | { | - |
1317 | (void) fprintf(stderr, | - |
1318 | "usage: scp [-346BCpqrv] [-c cipher] [-F ssh_config] [-i identity_file]\n" | - |
1319 | " [-l limit] [-o ssh_option] [-P port] [-S program] source ... target\n"); | - |
1320 | exit(1); never executed: exit(1); | 0 |
1321 | } | - |
1322 | | - |
1323 | void | - |
1324 | run_err(const char *fmt,...) | - |
1325 | { | - |
1326 | static FILE *fp; | - |
1327 | va_list ap; | - |
1328 | | - |
1329 | ++errs; | - |
1330 | if (fp != NULL || (remout != -1 && (fp = fdopen(remout, "w")))) {TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1331 | (void) fprintf(fp, "%c", 0x01); | - |
1332 | (void) fprintf(fp, "scp: "); | - |
1333 | va_start(ap, fmt); | - |
1334 | (void) vfprintf(fp, fmt, ap); | - |
1335 | va_end(ap); | - |
1336 | (void) fprintf(fp, "\n"); | - |
1337 | (void) fflush(fp); | - |
1338 | } never executed: end of block | 0 |
1339 | | - |
1340 | if (!iamremote) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1341 | va_start(ap, fmt); | - |
1342 | vfmprintf(stderr, fmt, ap); | - |
1343 | va_end(ap); | - |
1344 | fprintf(stderr, "\n"); | - |
1345 | } never executed: end of block | 0 |
1346 | } never executed: end of block | 0 |
1347 | | - |
1348 | void | - |
1349 | verifydir(char *cp) | - |
1350 | { | - |
1351 | struct stat stb; | - |
1352 | | - |
1353 | if (!stat(cp, &stb)) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1354 | if (S_ISDIR(stb.st_mode))TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1355 | return; never executed: return; | 0 |
1356 | errno = ENOTDIR; | - |
1357 | } never executed: end of block | 0 |
1358 | run_err("%s: %s", cp, strerror(errno)); | - |
1359 | killchild(0); | - |
1360 | } never executed: end of block | 0 |
1361 | | - |
1362 | int | - |
1363 | okname(char *cp0) | - |
1364 | { | - |
1365 | int c; | - |
1366 | char *cp; | - |
1367 | | - |
1368 | cp = cp0; | - |
1369 | do { | - |
1370 | c = (int)*cp; | - |
1371 | if (c & 0200)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1372 | goto bad; never executed: goto bad; | 0 |
1373 | if (!isalpha(c) && !isdigit((unsigned char)c)) {TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1374 | switch (c) { | - |
1375 | case '\'': never executed: case '\'': | 0 |
1376 | case '"': never executed: case '"': | 0 |
1377 | case '`': never executed: case '`': | 0 |
1378 | case ' ': never executed: case ' ': | 0 |
1379 | case '#': never executed: case '#': | 0 |
1380 | goto bad; never executed: goto bad; | 0 |
1381 | default: never executed: default: | 0 |
1382 | break; never executed: break; | 0 |
1383 | } | - |
1384 | } | - |
1385 | } while (*++cp); never executed: end of block TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1386 | return (1); never executed: return (1); | 0 |
1387 | | - |
1388 | bad: fmprintf(stderr, "%s: invalid user name\n", cp0); | - |
1389 | return (0); never executed: return (0); | 0 |
1390 | } | - |
1391 | | - |
1392 | BUF * | - |
1393 | allocbuf(BUF *bp, int fd, int blksize) | - |
1394 | { | - |
1395 | size_t size; | - |
1396 | #ifdef HAVE_STRUCT_STAT_ST_BLKSIZE | - |
1397 | struct stat stb; | - |
1398 | | - |
1399 | if (fstat(fd, &stb) < 0) {TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1400 | run_err("fstat: %s", strerror(errno)); | - |
1401 | return (0); never executed: return (0); | 0 |
1402 | } | - |
1403 | size = ROUNDUP(stb.st_blksize, blksize); | - |
1404 | if (size == 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1405 | size = blksize; never executed: size = blksize; | 0 |
1406 | #else /* HAVE_STRUCT_STAT_ST_BLKSIZE */ | - |
1407 | size = blksize; | - |
1408 | #endif /* HAVE_STRUCT_STAT_ST_BLKSIZE */ | - |
1409 | if (bp->cnt >= size)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1410 | return (bp); never executed: return (bp); | 0 |
1411 | bp->buf = xrecallocarray(bp->buf, bp->cnt, size, 1); | - |
1412 | bp->cnt = size; | - |
1413 | return (bp); never executed: return (bp); | 0 |
1414 | } | - |
1415 | | - |
1416 | void | - |
1417 | lostconn(int signo) | - |
1418 | { | - |
1419 | if (!iamremote)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1420 | (void)write(STDERR_FILENO, "lost connection\n", 16); never executed: (void)write( 2 , "lost connection\n", 16); | 0 |
1421 | if (signo)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1422 | _exit(1); never executed: _exit(1); | 0 |
1423 | else | - |
1424 | exit(1); never executed: exit(1); | 0 |
1425 | } | - |
| | |