chiark
/
gitweb
/
~mdw
/
sw-tools
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Merge some changes from 1.0.4. Very odd.
[sw-tools]
/
src
/
sw_rsh.c
diff --git
a/src/sw_rsh.c
b/src/sw_rsh.c
index 785da7dfc71b3e8959ebdf419a2ddef059469aac..e0543511c4fd48062c5c597f3fa7e2c0d52dec3c 100644
(file)
--- a/
src/sw_rsh.c
+++ b/
src/sw_rsh.c
@@
-396,7
+396,7
@@
static void remote(sw_remote *r, const char *cmd, char *argv[], char *env[])
sym_table t;
sym_create(&t);
env_import(&t, env);
sym_table t;
sym_create(&t);
env_import(&t, env);
- if (env != environ) {
+ if (env
[0] && env
!= environ) {
free(env);
env_import(&t, environ);
}
free(env);
env_import(&t, environ);
}
@@
-538,7
+538,15
@@
void swrsh_remote(const char *cmd)
r.fdin = 0;
r.fdout = 1;
r.fdin = 0;
r.fdout = 1;
- /* --- Read packets from the remote host --- */
+ /* --- Object if stdin is a terminal --- */
+
+ if (isatty(STDIN_FILENO)) {
+ die(EXIT_FAILURE,
+ "don't use the `--remote' option unless "
+ "you know what you're doing.");
+ }
+
+ /* --- Read packets from the remote host --- */
for (;;) {
int t = pkrecv(&r);
for (;;) {
int t = pkrecv(&r);