[sftp-int.c]
     Teach ls how to display multiple column display and allow users
     to return to single column format via 'ls -1'.  OK @djm
This commit is contained in:
Damien Miller 2003-05-15 13:49:21 +10:00
parent 4962ed6ab4
commit 19c8f2b310
2 changed files with 69 additions and 16 deletions

View File

@ -31,6 +31,10 @@
- mouring@cvs.openbsd.org 2003/05/15 03:39:07 - mouring@cvs.openbsd.org 2003/05/15 03:39:07
[sftp-int.c] [sftp-int.c]
Make put/get (globed and nonglobed) code more consistant. OK djm@ Make put/get (globed and nonglobed) code more consistant. OK djm@
- mouring@cvs.openbsd.org 2003/05/15 03:43:59
[sftp-int.c]
Teach ls how to display multiple column display and allow users
to return to single column format via 'ls -1'. OK @djm
- (djm) Always parse UsePAM - (djm) Always parse UsePAM
- (djm) Configure glue for DNS support (code doesn't work in portable yet) - (djm) Configure glue for DNS support (code doesn't work in portable yet)
- (djm) Import getrrsetbyname() function from OpenBSD libc (for DNS support) - (djm) Import getrrsetbyname() function from OpenBSD libc (for DNS support)
@ -1511,4 +1515,4 @@
save auth method before monitor_reset_key_state(); bugzilla bug #284; save auth method before monitor_reset_key_state(); bugzilla bug #284;
ok provos@ ok provos@
$Id: ChangeLog,v 1.2713 2003/05/15 03:48:59 djm Exp $ $Id: ChangeLog,v 1.2714 2003/05/15 03:49:21 djm Exp $

View File

@ -25,7 +25,7 @@
/* XXX: recursive operations */ /* XXX: recursive operations */
#include "includes.h" #include "includes.h"
RCSID("$OpenBSD: sftp-int.c,v 1.59 2003/05/15 03:39:07 mouring Exp $"); RCSID("$OpenBSD: sftp-int.c,v 1.60 2003/05/15 03:43:59 mouring Exp $");
#include "buffer.h" #include "buffer.h"
#include "xmalloc.h" #include "xmalloc.h"
@ -53,6 +53,10 @@ int showprogress = 1;
/* Seperators for interactive commands */ /* Seperators for interactive commands */
#define WHITESPACE " \t\r\n" #define WHITESPACE " \t\r\n"
/* Define what type of ls view (0 - multi-column) */
#define LONG_VIEW 1 /* Full view ala ls -l */
#define SHORT_VIEW 2 /* Single row view ala ls -1 */
/* Commands for interactive mode */ /* Commands for interactive mode */
#define I_CHDIR 1 #define I_CHDIR 1
#define I_CHGRP 2 #define I_CHGRP 2
@ -307,7 +311,10 @@ parse_ls_flags(const char **cpp, int *lflag)
for(; strchr(WHITESPACE, *cp) == NULL; cp++) { for(; strchr(WHITESPACE, *cp) == NULL; cp++) {
switch (*cp) { switch (*cp) {
case 'l': case 'l':
*lflag = 1; *lflag = LONG_VIEW;
break;
case '1':
*lflag = SHORT_VIEW;
break; break;
default: default:
error("Invalid flag -%c", *cp); error("Invalid flag -%c", *cp);
@ -558,15 +565,26 @@ sdirent_comp(const void *aa, const void *bb)
static int static int
do_ls_dir(struct sftp_conn *conn, char *path, char *strip_path, int lflag) do_ls_dir(struct sftp_conn *conn, char *path, char *strip_path, int lflag)
{ {
int n; int n, c = 1, colspace = 0, columns = 1;
SFTP_DIRENT **d; SFTP_DIRENT **d;
if ((n = do_readdir(conn, path, &d)) != 0) if ((n = do_readdir(conn, path, &d)) != 0)
return (n); return (n);
/* Count entries for sort */ if (!(lflag & SHORT_VIEW)) {
int m = 0, width = 80;
struct winsize ws;
/* Count entries for sort and find longest filename */
for (n = 0; d[n] != NULL; n++) for (n = 0; d[n] != NULL; n++)
; m = MAX(m, strlen(d[n]->filename));
if (ioctl(fileno(stdin), TIOCGWINSZ, &ws) != -1)
width = ws.ws_col;
columns = width / (m + 2);
colspace = width / columns;
}
qsort(d, n, sizeof(*d), sdirent_comp); qsort(d, n, sizeof(*d), sdirent_comp);
@ -577,7 +595,7 @@ do_ls_dir(struct sftp_conn *conn, char *path, char *strip_path, int lflag)
fname = path_strip(tmp, strip_path); fname = path_strip(tmp, strip_path);
xfree(tmp); xfree(tmp);
if (lflag) { if (lflag & LONG_VIEW) {
char *lname; char *lname;
struct stat sb; struct stat sb;
@ -587,13 +605,20 @@ do_ls_dir(struct sftp_conn *conn, char *path, char *strip_path, int lflag)
printf("%s\n", lname); printf("%s\n", lname);
xfree(lname); xfree(lname);
} else { } else {
/* XXX - multicolumn display would be nice here */ printf("%-*s", colspace, fname);
printf("%s\n", fname); if (c >= columns) {
printf("\n");
c = 1;
} else
c++;
} }
xfree(fname); xfree(fname);
} }
if (!(lflag & LONG_VIEW) && (c != 1))
printf("\n");
free_sftp_dirents(d); free_sftp_dirents(d);
return (0); return (0);
} }
@ -604,9 +629,8 @@ do_globbed_ls(struct sftp_conn *conn, char *path, char *strip_path,
int lflag) int lflag)
{ {
glob_t g; glob_t g;
int i; int i, c = 1, colspace = 0, columns = 1;
Attrib *a; Attrib *a;
struct stat sb;
memset(&g, 0, sizeof(g)); memset(&g, 0, sizeof(g));
@ -633,12 +657,30 @@ do_globbed_ls(struct sftp_conn *conn, char *path, char *strip_path,
} }
} }
if (!(lflag & SHORT_VIEW)) {
int m = 0, width = 80;
struct winsize ws;
/* Count entries for sort and find longest filename */
for (i = 0; g.gl_pathv[i]; i++)
m = MAX(m, strlen(g.gl_pathv[i]));
if (ioctl(fileno(stdin), TIOCGWINSZ, &ws) != -1)
width = ws.ws_col;
columns = width / (m + 2);
colspace = width / columns;
}
for (i = 0; g.gl_pathv[i]; i++) { for (i = 0; g.gl_pathv[i]; i++) {
char *fname, *lname; char *fname;
fname = path_strip(g.gl_pathv[i], strip_path); fname = path_strip(g.gl_pathv[i], strip_path);
if (lflag) { if (lflag & LONG_VIEW) {
char *lname;
struct stat sb;
/* /*
* XXX: this is slow - 1 roundtrip per path * XXX: this is slow - 1 roundtrip per path
* A solution to this is to fork glob() and * A solution to this is to fork glob() and
@ -654,12 +696,19 @@ do_globbed_ls(struct sftp_conn *conn, char *path, char *strip_path,
printf("%s\n", lname); printf("%s\n", lname);
xfree(lname); xfree(lname);
} else { } else {
/* XXX - multicolumn display would be nice here */ printf("%-*s", colspace, fname);
printf("%s\n", fname); if (c >= columns) {
printf("\n");
c = 1;
} else
c++;
} }
xfree(fname); xfree(fname);
} }
if (!(lflag & LONG_VIEW) && (c != 1))
printf("\n");
if (g.gl_pathc) if (g.gl_pathc)
globfree(&g); globfree(&g);