mirror of
https://git.tartarus.org/simon/putty.git
synced 2025-01-10 01:48:00 +00:00
Tidied up PSFTP batch mode. The gross hack using fxp_error_message
to report command failures is now gone; instead each sftp_cmd_* routine returns 0 or 1 depending on success, like they should have done right from the start. This fixes problems with `ls' prematurely terminating PSFTP batch files. [originally from svn r1481]
This commit is contained in:
parent
9cfcab6cb6
commit
8ecf3e147d
70
psftp.c
70
psftp.c
@ -168,13 +168,13 @@ struct sftp_command {
|
|||||||
|
|
||||||
int sftp_cmd_null(struct sftp_command *cmd)
|
int sftp_cmd_null(struct sftp_command *cmd)
|
||||||
{
|
{
|
||||||
return 0;
|
return 1; /* success */
|
||||||
}
|
}
|
||||||
|
|
||||||
int sftp_cmd_unknown(struct sftp_command *cmd)
|
int sftp_cmd_unknown(struct sftp_command *cmd)
|
||||||
{
|
{
|
||||||
printf("psftp: unknown command \"%s\"\n", cmd->words[0]);
|
printf("psftp: unknown command \"%s\"\n", cmd->words[0]);
|
||||||
return 0;
|
return 0; /* failure */
|
||||||
}
|
}
|
||||||
|
|
||||||
int sftp_cmd_quit(struct sftp_command *cmd)
|
int sftp_cmd_quit(struct sftp_command *cmd)
|
||||||
@ -269,7 +269,7 @@ int sftp_cmd_ls(struct sftp_command *cmd)
|
|||||||
|
|
||||||
sfree(cdir);
|
sfree(cdir);
|
||||||
|
|
||||||
return 0;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -309,7 +309,7 @@ int sftp_cmd_cd(struct sftp_command *cmd)
|
|||||||
pwd = dir;
|
pwd = dir;
|
||||||
printf("Remote directory is now %s\n", pwd);
|
printf("Remote directory is now %s\n", pwd);
|
||||||
|
|
||||||
return 0;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -323,7 +323,7 @@ int sftp_cmd_pwd(struct sftp_command *cmd)
|
|||||||
}
|
}
|
||||||
|
|
||||||
printf("Remote directory is %s\n", pwd);
|
printf("Remote directory is %s\n", pwd);
|
||||||
return 0;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -338,6 +338,7 @@ int sftp_general_get(struct sftp_command *cmd, int restart)
|
|||||||
char *fname, *outfname;
|
char *fname, *outfname;
|
||||||
uint64 offset;
|
uint64 offset;
|
||||||
FILE *fp;
|
FILE *fp;
|
||||||
|
int ret;
|
||||||
|
|
||||||
if (back == NULL) {
|
if (back == NULL) {
|
||||||
printf("psftp: not connected to a host; use \"open host.name\"\n");
|
printf("psftp: not connected to a host; use \"open host.name\"\n");
|
||||||
@ -393,6 +394,7 @@ int sftp_general_get(struct sftp_command *cmd, int restart)
|
|||||||
* FIXME: we can use FXP_FSTAT here to get the file size, and
|
* FIXME: we can use FXP_FSTAT here to get the file size, and
|
||||||
* thus put up a progress bar.
|
* thus put up a progress bar.
|
||||||
*/
|
*/
|
||||||
|
ret = 1;
|
||||||
while (1) {
|
while (1) {
|
||||||
char buffer[4096];
|
char buffer[4096];
|
||||||
int len;
|
int len;
|
||||||
@ -403,6 +405,7 @@ int sftp_general_get(struct sftp_command *cmd, int restart)
|
|||||||
break;
|
break;
|
||||||
if (len == -1) {
|
if (len == -1) {
|
||||||
printf("error while reading: %s\n", fxp_error());
|
printf("error while reading: %s\n", fxp_error());
|
||||||
|
ret = 0;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -411,12 +414,15 @@ int sftp_general_get(struct sftp_command *cmd, int restart)
|
|||||||
wlen = fwrite(buffer, 1, len - wpos, fp);
|
wlen = fwrite(buffer, 1, len - wpos, fp);
|
||||||
if (wlen <= 0) {
|
if (wlen <= 0) {
|
||||||
printf("error while writing local file\n");
|
printf("error while writing local file\n");
|
||||||
|
ret = 0;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
wpos += wlen;
|
wpos += wlen;
|
||||||
}
|
}
|
||||||
if (wpos < len) /* we had an error */
|
if (wpos < len) { /* we had an error */
|
||||||
|
ret = 0;
|
||||||
break;
|
break;
|
||||||
|
}
|
||||||
offset = uint64_add32(offset, len);
|
offset = uint64_add32(offset, len);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -424,7 +430,7 @@ int sftp_general_get(struct sftp_command *cmd, int restart)
|
|||||||
fxp_close(fh);
|
fxp_close(fh);
|
||||||
sfree(fname);
|
sfree(fname);
|
||||||
|
|
||||||
return 0;
|
return ret;
|
||||||
}
|
}
|
||||||
int sftp_cmd_get(struct sftp_command *cmd)
|
int sftp_cmd_get(struct sftp_command *cmd)
|
||||||
{
|
{
|
||||||
@ -447,6 +453,7 @@ int sftp_general_put(struct sftp_command *cmd, int restart)
|
|||||||
char *fname, *origoutfname, *outfname;
|
char *fname, *origoutfname, *outfname;
|
||||||
uint64 offset;
|
uint64 offset;
|
||||||
FILE *fp;
|
FILE *fp;
|
||||||
|
int ret;
|
||||||
|
|
||||||
if (back == NULL) {
|
if (back == NULL) {
|
||||||
printf("psftp: not connected to a host; use \"open host.name\"\n");
|
printf("psftp: not connected to a host; use \"open host.name\"\n");
|
||||||
@ -519,6 +526,7 @@ int sftp_general_put(struct sftp_command *cmd, int restart)
|
|||||||
* FIXME: we can use FXP_FSTAT here to get the file size, and
|
* FIXME: we can use FXP_FSTAT here to get the file size, and
|
||||||
* thus put up a progress bar.
|
* thus put up a progress bar.
|
||||||
*/
|
*/
|
||||||
|
ret = 1;
|
||||||
while (1) {
|
while (1) {
|
||||||
char buffer[4096];
|
char buffer[4096];
|
||||||
int len;
|
int len;
|
||||||
@ -526,12 +534,14 @@ int sftp_general_put(struct sftp_command *cmd, int restart)
|
|||||||
len = fread(buffer, 1, sizeof(buffer), fp);
|
len = fread(buffer, 1, sizeof(buffer), fp);
|
||||||
if (len == -1) {
|
if (len == -1) {
|
||||||
printf("error while reading local file\n");
|
printf("error while reading local file\n");
|
||||||
|
ret = 0;
|
||||||
break;
|
break;
|
||||||
} else if (len == 0) {
|
} else if (len == 0) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (!fxp_write(fh, buffer, offset, len)) {
|
if (!fxp_write(fh, buffer, offset, len)) {
|
||||||
printf("error while writing: %s\n", fxp_error());
|
printf("error while writing: %s\n", fxp_error());
|
||||||
|
ret = 0;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
offset = uint64_add32(offset, len);
|
offset = uint64_add32(offset, len);
|
||||||
@ -541,7 +551,7 @@ int sftp_general_put(struct sftp_command *cmd, int restart)
|
|||||||
fclose(fp);
|
fclose(fp);
|
||||||
sfree(outfname);
|
sfree(outfname);
|
||||||
|
|
||||||
return 0;
|
return ret;
|
||||||
}
|
}
|
||||||
int sftp_cmd_put(struct sftp_command *cmd)
|
int sftp_cmd_put(struct sftp_command *cmd)
|
||||||
{
|
{
|
||||||
@ -581,7 +591,7 @@ int sftp_cmd_mkdir(struct sftp_command *cmd)
|
|||||||
}
|
}
|
||||||
|
|
||||||
sfree(dir);
|
sfree(dir);
|
||||||
return 0;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
int sftp_cmd_rmdir(struct sftp_command *cmd)
|
int sftp_cmd_rmdir(struct sftp_command *cmd)
|
||||||
@ -613,7 +623,7 @@ int sftp_cmd_rmdir(struct sftp_command *cmd)
|
|||||||
}
|
}
|
||||||
|
|
||||||
sfree(dir);
|
sfree(dir);
|
||||||
return 0;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
int sftp_cmd_rm(struct sftp_command *cmd)
|
int sftp_cmd_rm(struct sftp_command *cmd)
|
||||||
@ -645,8 +655,7 @@ int sftp_cmd_rm(struct sftp_command *cmd)
|
|||||||
}
|
}
|
||||||
|
|
||||||
sfree(fname);
|
sfree(fname);
|
||||||
return 0;
|
return 1;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int sftp_cmd_mv(struct sftp_command *cmd)
|
int sftp_cmd_mv(struct sftp_command *cmd)
|
||||||
@ -716,7 +725,7 @@ int sftp_cmd_mv(struct sftp_command *cmd)
|
|||||||
|
|
||||||
sfree(srcfname);
|
sfree(srcfname);
|
||||||
sfree(dstfname);
|
sfree(dstfname);
|
||||||
return 0;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
int sftp_cmd_chmod(struct sftp_command *cmd)
|
int sftp_cmd_chmod(struct sftp_command *cmd)
|
||||||
@ -872,7 +881,7 @@ int sftp_cmd_chmod(struct sftp_command *cmd)
|
|||||||
printf("%s: %04o -> %04o\n", fname, oldperms, newperms);
|
printf("%s: %04o -> %04o\n", fname, oldperms, newperms);
|
||||||
|
|
||||||
sfree(fname);
|
sfree(fname);
|
||||||
return 0;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int sftp_cmd_open(struct sftp_command *cmd)
|
static int sftp_cmd_open(struct sftp_command *cmd)
|
||||||
@ -892,6 +901,7 @@ static int sftp_cmd_open(struct sftp_command *cmd)
|
|||||||
return -1; /* this is fatal */
|
return -1; /* this is fatal */
|
||||||
}
|
}
|
||||||
do_sftp_init();
|
do_sftp_init();
|
||||||
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int sftp_cmd_help(struct sftp_command *cmd);
|
static int sftp_cmd_help(struct sftp_command *cmd);
|
||||||
@ -1137,7 +1147,7 @@ static int sftp_cmd_help(struct sftp_command *cmd)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return 0;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ----------------------------------------------------------------------
|
/* ----------------------------------------------------------------------
|
||||||
@ -1151,9 +1161,9 @@ struct sftp_command *sftp_getcmd(FILE *fp, int mode, int modeflags)
|
|||||||
char *p, *q, *r;
|
char *p, *q, *r;
|
||||||
int quoting;
|
int quoting;
|
||||||
|
|
||||||
if ((mode == 0) || (modeflags & 1)) {
|
if ((mode == 0) || (modeflags & 1)) {
|
||||||
printf("psftp> ");
|
printf("psftp> ");
|
||||||
}
|
}
|
||||||
fflush(stdout);
|
fflush(stdout);
|
||||||
|
|
||||||
cmd = smalloc(sizeof(struct sftp_command));
|
cmd = smalloc(sizeof(struct sftp_command));
|
||||||
@ -1170,9 +1180,6 @@ struct sftp_command *sftp_getcmd(FILE *fp, int mode, int modeflags)
|
|||||||
linesize += 512;
|
linesize += 512;
|
||||||
line = srealloc(line, linesize);
|
line = srealloc(line, linesize);
|
||||||
ret = fgets(line + linelen, linesize - linelen, fp);
|
ret = fgets(line + linelen, linesize - linelen, fp);
|
||||||
if (modeflags & 1) {
|
|
||||||
printf("%s", ret);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!ret || (linelen == 0 && line[0] == '\0')) {
|
if (!ret || (linelen == 0 && line[0] == '\0')) {
|
||||||
cmd->obey = sftp_cmd_quit;
|
cmd->obey = sftp_cmd_quit;
|
||||||
@ -1187,6 +1194,9 @@ struct sftp_command *sftp_getcmd(FILE *fp, int mode, int modeflags)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if (modeflags & 1) {
|
||||||
|
printf("%s\n", line);
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Parse the command line into words. The syntax is:
|
* Parse the command line into words. The syntax is:
|
||||||
@ -1280,6 +1290,7 @@ static void do_sftp_init(void)
|
|||||||
void do_sftp(int mode, int modeflags, char *batchfile)
|
void do_sftp(int mode, int modeflags, char *batchfile)
|
||||||
{
|
{
|
||||||
FILE *fp;
|
FILE *fp;
|
||||||
|
int ret;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Batch mode?
|
* Batch mode?
|
||||||
@ -1290,12 +1301,12 @@ void do_sftp(int mode, int modeflags, char *batchfile)
|
|||||||
* Now we're ready to do Real Stuff.
|
* Now we're ready to do Real Stuff.
|
||||||
*/
|
*/
|
||||||
while (1) {
|
while (1) {
|
||||||
struct sftp_command *cmd;
|
struct sftp_command *cmd;
|
||||||
cmd = sftp_getcmd(stdin, 0, 0);
|
cmd = sftp_getcmd(stdin, 0, 0);
|
||||||
if (!cmd)
|
if (!cmd)
|
||||||
break;
|
break;
|
||||||
if (cmd->obey(cmd) < 0)
|
if (cmd->obey(cmd) < 0)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
fp = fopen(batchfile, "r");
|
fp = fopen(batchfile, "r");
|
||||||
@ -1308,9 +1319,10 @@ void do_sftp(int mode, int modeflags, char *batchfile)
|
|||||||
cmd = sftp_getcmd(fp, mode, modeflags);
|
cmd = sftp_getcmd(fp, mode, modeflags);
|
||||||
if (!cmd)
|
if (!cmd)
|
||||||
break;
|
break;
|
||||||
if (cmd->obey(cmd) < 0)
|
ret = cmd->obey(cmd);
|
||||||
|
if (ret < 0)
|
||||||
break;
|
break;
|
||||||
if (fxp_error() != NULL) {
|
if (ret == 0) {
|
||||||
if (!(modeflags & 2))
|
if (!(modeflags & 2))
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user