=================================================================== RCS file: /cvsrepo/anoncvs/cvs/src/usr.bin/ssh/sftp-glob.c,v retrieving revision 1.2.4.4 retrieving revision 1.3 diff -u -r1.2.4.4 -r1.3 --- src/usr.bin/ssh/sftp-glob.c 2002/03/08 17:04:43 1.2.4.4 +++ src/usr.bin/ssh/sftp-glob.c 2001/04/03 13:56:11 1.3 @@ -1,5 +1,5 @@ /* - * Copyright (c) 2001,2002 Damien Miller. All rights reserved. + * Copyright (c) 2001 Damien Miller. All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions @@ -23,14 +23,18 @@ */ #include "includes.h" -RCSID("$OpenBSD: sftp-glob.c,v 1.2.4.4 2002/03/08 17:04:43 brad Exp $"); +RCSID("$OpenBSD: sftp-glob.c,v 1.3 2001/04/03 13:56:11 stevesk Exp $"); #include +#include "ssh.h" #include "buffer.h" #include "bufaux.h" +#include "getput.h" #include "xmalloc.h" #include "log.h" +#include "atomicio.h" +#include "pathnames.h" #include "sftp.h" #include "sftp-common.h" @@ -43,17 +47,17 @@ }; static struct { - struct sftp_conn *conn; + int fd_in; + int fd_out; } cur; -static void * -fudge_opendir(const char *path) +void *fudge_opendir(const char *path) { struct SFTP_OPENDIR *r; - + r = xmalloc(sizeof(*r)); - - if (do_readdir(cur.conn, (char*)path, &r->dir)) + + if (do_readdir(cur.fd_in, cur.fd_out, (char*)path, &r->dir)) return(NULL); r->offset = 0; @@ -61,33 +65,30 @@ return((void*)r); } -static struct dirent * -fudge_readdir(struct SFTP_OPENDIR *od) +struct dirent *fudge_readdir(struct SFTP_OPENDIR *od) { static struct dirent ret; - + if (od->dir[od->offset] == NULL) return(NULL); memset(&ret, 0, sizeof(ret)); - strlcpy(ret.d_name, od->dir[od->offset++]->filename, + strlcpy(ret.d_name, od->dir[od->offset++]->filename, sizeof(ret.d_name)); return(&ret); } -static void -fudge_closedir(struct SFTP_OPENDIR *od) +void fudge_closedir(struct SFTP_OPENDIR *od) { free_sftp_dirents(od->dir); xfree(od); } -static void -attrib_to_stat(Attrib *a, struct stat *st) +void attrib_to_stat(Attrib *a, struct stat *st) { memset(st, 0, sizeof(*st)); - + if (a->flags & SSH2_FILEXFER_ATTR_SIZE) st->st_size = a->size; if (a->flags & SSH2_FILEXFER_ATTR_UIDGID) { @@ -102,44 +103,44 @@ } } -static int -fudge_lstat(const char *path, struct stat *st) +int fudge_lstat(const char *path, struct stat *st) { Attrib *a; - - if (!(a = do_lstat(cur.conn, (char*)path, 0))) + + if (!(a = do_lstat(cur.fd_in, cur.fd_out, (char*)path, 0))) return(-1); - + attrib_to_stat(a, st); - + return(0); } -static int -fudge_stat(const char *path, struct stat *st) +int fudge_stat(const char *path, struct stat *st) { Attrib *a; - - if (!(a = do_stat(cur.conn, (char*)path, 0))) + + if (!(a = do_stat(cur.fd_in, cur.fd_out, (char*)path, 0))) return(-1); - + attrib_to_stat(a, st); - + return(0); } int -remote_glob(struct sftp_conn *conn, const char *pattern, int flags, - int (*errfunc)(const char *, int), glob_t *pglob) +remote_glob(int fd_in, int fd_out, const char *pattern, int flags, + const int (*errfunc)(const char *, int), glob_t *pglob) { - pglob->gl_opendir = fudge_opendir; - pglob->gl_readdir = (struct dirent *(*)(void *))fudge_readdir; - pglob->gl_closedir = (void (*)(void *))fudge_closedir; + pglob->gl_opendir = (void*)fudge_opendir; + pglob->gl_readdir = (void*)fudge_readdir; + pglob->gl_closedir = (void*)fudge_closedir; pglob->gl_lstat = fudge_lstat; pglob->gl_stat = fudge_stat; - + memset(&cur, 0, sizeof(cur)); - cur.conn = conn; + cur.fd_in = fd_in; + cur.fd_out = fd_out; - return(glob(pattern, flags | GLOB_ALTDIRFUNC, errfunc, pglob)); + return(glob(pattern, flags | GLOB_ALTDIRFUNC, (void*)errfunc, + pglob)); }