- djm@cvs.openbsd.org 2014/07/09 01:45:10

[sftp.c]
     more useful error message when GLOB_NOSPACE occurs;
     bz#2254, patch from Orion Poplawski
This commit is contained in:
Damien Miller 2014-07-09 13:07:06 +10:00
parent 079bac2a43
commit 0070776a03
2 changed files with 20 additions and 8 deletions

View File

@ -4,6 +4,10 @@
[ssh_config.5] [ssh_config.5]
mention that ProxyCommand is executed using shell "exec" to avoid mention that ProxyCommand is executed using shell "exec" to avoid
a lingering process; bz#1977 a lingering process; bz#1977
- djm@cvs.openbsd.org 2014/07/09 01:45:10
[sftp.c]
more useful error message when GLOB_NOSPACE occurs;
bz#2254, patch from Orion Poplawski
20140706 20140706
- OpenBSD CVS Sync - OpenBSD CVS Sync

20
sftp.c
View File

@ -1,4 +1,4 @@
/* $OpenBSD: sftp.c,v 1.163 2014/05/05 07:02:30 logan Exp $ */ /* $OpenBSD: sftp.c,v 1.164 2014/07/09 01:45:10 djm Exp $ */
/* /*
* Copyright (c) 2001-2004 Damien Miller <djm@openbsd.org> * Copyright (c) 2001-2004 Damien Miller <djm@openbsd.org>
* *
@ -589,15 +589,19 @@ process_get(struct sftp_conn *conn, char *src, char *dst, char *pwd,
char *abs_dst = NULL; char *abs_dst = NULL;
glob_t g; glob_t g;
char *filename, *tmp=NULL; char *filename, *tmp=NULL;
int i, err = 0; int i, r, err = 0;
abs_src = xstrdup(src); abs_src = xstrdup(src);
abs_src = make_absolute(abs_src, pwd); abs_src = make_absolute(abs_src, pwd);
memset(&g, 0, sizeof(g)); memset(&g, 0, sizeof(g));
debug3("Looking up %s", abs_src); debug3("Looking up %s", abs_src);
if (remote_glob(conn, abs_src, GLOB_MARK, NULL, &g)) { if ((r = remote_glob(conn, abs_src, GLOB_MARK, NULL, &g)) != 0) {
if (r == GLOB_NOSPACE) {
error("Too many matches for \"%s\".", abs_src);
} else {
error("File \"%s\" not found.", abs_src); error("File \"%s\" not found.", abs_src);
}
err = -1; err = -1;
goto out; goto out;
} }
@ -862,19 +866,23 @@ do_globbed_ls(struct sftp_conn *conn, char *path, char *strip_path,
{ {
char *fname, *lname; char *fname, *lname;
glob_t g; glob_t g;
int err; int err, r;
struct winsize ws; struct winsize ws;
u_int i, c = 1, colspace = 0, columns = 1, m = 0, width = 80; u_int i, c = 1, colspace = 0, columns = 1, m = 0, width = 80;
memset(&g, 0, sizeof(g)); memset(&g, 0, sizeof(g));
if (remote_glob(conn, path, if ((r = remote_glob(conn, path,
GLOB_MARK|GLOB_NOCHECK|GLOB_BRACE|GLOB_KEEPSTAT|GLOB_NOSORT, GLOB_MARK|GLOB_NOCHECK|GLOB_BRACE|GLOB_KEEPSTAT|GLOB_NOSORT,
NULL, &g) || NULL, &g)) != 0 ||
(g.gl_pathc && !g.gl_matchc)) { (g.gl_pathc && !g.gl_matchc)) {
if (g.gl_pathc) if (g.gl_pathc)
globfree(&g); globfree(&g);
if (r == GLOB_NOSPACE) {
error("Can't ls: Too many matches for \"%s\"", path);
} else {
error("Can't ls: \"%s\" not found", path); error("Can't ls: \"%s\" not found", path);
}
return -1; return -1;
} }