X-Git-Url: https://asedeno.scripts.mit.edu/gitweb/?a=blobdiff_plain;f=sftp.h;h=c61340c1582273b9e8e723b60f56b2eeeb548e44;hb=89da2ddf564a93414ee9ab2df3f053608094e417;hp=54d91af2394e7d9de4b30a28efb559413f31928f;hpb=77cc3018626450f06de853d94e12f4cd800241dc;p=PuTTY.git diff --git a/sftp.h b/sftp.h index 54d91af2..c61340c1 100644 --- a/sftp.h +++ b/sftp.h @@ -67,6 +67,11 @@ int sftp_senddata(char *data, int len); int sftp_recvdata(char *data, int len); +/* + * Free sftp_requests + */ +void sftp_cleanup_request(void); + struct fxp_attrs { unsigned long flags; uint64 size; @@ -77,6 +82,19 @@ struct fxp_attrs { unsigned long mtime; }; +/* + * Copy between the possibly-unused permissions field in an fxp_attrs + * and a possibly-negative integer containing the same permissions. + */ +#define PUT_PERMISSIONS(attrs, perms) \ + ((perms) >= 0 ? \ + ((attrs).flags |= SSH_FILEXFER_ATTR_PERMISSIONS, \ + (attrs).permissions = (perms)) : \ + ((attrs).flags &= ~SSH_FILEXFER_ATTR_PERMISSIONS)) +#define GET_PERMISSIONS(attrs) \ + ((attrs).flags & SSH_FILEXFER_ATTR_PERMISSIONS ? \ + (attrs).permissions : -1) + struct fxp_handle { char *hstring; int hlen; @@ -107,20 +125,22 @@ int fxp_init(void); * Canonify a pathname. Concatenate the two given path elements * with a separating slash, unless the second is NULL. */ -struct sftp_request *fxp_realpath_send(char *path); +struct sftp_request *fxp_realpath_send(const char *path); char *fxp_realpath_recv(struct sftp_packet *pktin, struct sftp_request *req); /* - * Open a file. + * Open a file. 'attrs' contains attributes to be applied to the file + * if it's being created. */ -struct sftp_request *fxp_open_send(char *path, int type); +struct sftp_request *fxp_open_send(const char *path, int type, + struct fxp_attrs *attrs); struct fxp_handle *fxp_open_recv(struct sftp_packet *pktin, struct sftp_request *req); /* * Open a directory. */ -struct sftp_request *fxp_opendir_send(char *path); +struct sftp_request *fxp_opendir_send(const char *path); struct fxp_handle *fxp_opendir_recv(struct sftp_packet *pktin, struct sftp_request *req); @@ -133,31 +153,32 @@ void fxp_close_recv(struct sftp_packet *pktin, struct sftp_request *req); /* * Make a directory. */ -struct sftp_request *fxp_mkdir_send(char *path); +struct sftp_request *fxp_mkdir_send(const char *path); int fxp_mkdir_recv(struct sftp_packet *pktin, struct sftp_request *req); /* * Remove a directory. */ -struct sftp_request *fxp_rmdir_send(char *path); +struct sftp_request *fxp_rmdir_send(const char *path); int fxp_rmdir_recv(struct sftp_packet *pktin, struct sftp_request *req); /* * Remove a file. */ -struct sftp_request *fxp_remove_send(char *fname); +struct sftp_request *fxp_remove_send(const char *fname); int fxp_remove_recv(struct sftp_packet *pktin, struct sftp_request *req); /* * Rename a file. */ -struct sftp_request *fxp_rename_send(char *srcfname, char *dstfname); +struct sftp_request *fxp_rename_send(const char *srcfname, + const char *dstfname); int fxp_rename_recv(struct sftp_packet *pktin, struct sftp_request *req); /* * Return file attributes. */ -struct sftp_request *fxp_stat_send(char *fname); +struct sftp_request *fxp_stat_send(const char *fname); int fxp_stat_recv(struct sftp_packet *pktin, struct sftp_request *req, struct fxp_attrs *attrs); struct sftp_request *fxp_fstat_send(struct fxp_handle *handle); @@ -167,7 +188,8 @@ int fxp_fstat_recv(struct sftp_packet *pktin, struct sftp_request *req, /* * Set file attributes. */ -struct sftp_request *fxp_setstat_send(char *fname, struct fxp_attrs attrs); +struct sftp_request *fxp_setstat_send(const char *fname, + struct fxp_attrs attrs); int fxp_setstat_recv(struct sftp_packet *pktin, struct sftp_request *req); struct sftp_request *fxp_fsetstat_send(struct fxp_handle *handle, struct fxp_attrs attrs);