- 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:
parent
079bac2a43
commit
0070776a03
|
@ -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
20
sftp.c
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue