home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
Geek Gadgets 1
/
ADE-1.bin
/
ade-dist
/
ncftp-2.3.0-src.tgz
/
tar.out
/
contrib
/
ncftp
/
Xfer.h
< prev
Wrap
C/C++ Source or Header
|
1996-09-28
|
3KB
|
125 lines
/* Xfer.h */
#ifndef _xfer_h_
#define _xfer_h_ 1
#ifndef _ftp_h_
#include "FTP.h"
#endif
#ifndef _rcmd_h_
#include "RCmd.h"
#endif
#define kXferBufSize 32768
/* These coincide with the definitions of kAcceptForWriting, etc., in FTP.h. */
#define kNetWriting kAcceptForWriting
#define kNetReading kAcceptForReading
#define NETREADING(xp) ((xp)->netMode == kNetReading)
#define NETWRITING(xp) ((xp)->netMode == kNetWriting)
/* More stuff for XferSpec setup.
* Typically, all of these are used at once when
* you don't want progress reports.
*/
#define kNoReports 0
#define kFileSizeDontCare 0L
#define kLocalFileIsStdout "-"
/* Some BlockProcs will timeout after the defined interval, and they
* return this instead of just -1 for a regular error.
*/
#define kTimeoutErr (-2)
/* If we got kMaxConsecTimeOuts of these increments in a row, we conclude
* that the host isn't responding anymore and abort the transfer.
*/
#define kMaxConsecTimeOuts 10
/* typedef struct XferSpec *XferSpecPtr; done in RCmd.h. */
#define kNoTransfer ((XferSpecPtr) 0)
typedef long (*GetBlockProc)(char *, size_t, XferSpecPtr);
typedef long (*PutBlockProc)(char *, size_t, XferSpecPtr);
/* Each progress meter function follows this calling format. */
typedef int (*ProgressMeterProc)(XferSpecPtr, int);
typedef struct XferSpec {
/* These must be filled in by you. */
int netMode; /* Reading or writing Net I/O? */
GetBlockProc getBlock;
PutBlockProc putBlock;
int inStream;
int outStream;
/* You can use this to point to another structure if you like. */
void *miscPtr;
/* Filled in by you if you want progress reports. */
int doReports;
char *localFileName;
char *remoteFileName;
long expectedSize;
long startPoint;
/* These are filled in by RDataCmd. */
ResponsePtr cmdResp;
ResponsePtr xferResp;
/* These are filled in by Progress routines. */
int progMeterInUse;
ProgressMeterProc prProc;
long bytesTransferred;
long bytesLeft;
double frac;
double bytesPerSec;
double secsElap;
struct timeval startTime;
struct timeval endTime;
long timeOfNextUpdate;
/* Needed to guarantee that the file times get set. */
int doUTime;
time_t remoteModTime;
} XferSpec;
#define CLEARXFERSPEC(R) PTRZERO(R, sizeof(XferSpec))
#ifndef _xfer_c_
extern XferSpecPtr gCurXp;
#endif
/* Instead of blocking forever on an I/O operation over the network, we
* can have the program give up after a period of time to update the progress
* meters and retry. Since that's the only reason we need to interrupt a
* long network I/O operation, that's not a very compelling reason to do it.
*
* You can use the timeout facility by using the actual functions. If not,
* just define them to the real read/write system calls.
*/
#define ReadOrTimeout read
#define WriteOrTimeout write
void InitXferBuffer(void);
int BufferGets(char *, size_t, XferSpecPtr);
void XferSigHandler(int);
XferSpecPtr InitXferSpec(void);
void DoneWithXferSpec(XferSpecPtr);
void AbortDataTransfer(XferSpecPtr);
int DataTransfer(XferSpecPtr);
void ResetBlockTimeout(void);
#ifndef ReadOrTimeout
int ReadOrTimeout(const int, char *, const size_t);
#endif
#ifndef WriteOrTimeout
int WriteOrTimeout(const int, char *, const size_t);
#endif /* WriteOrTimeout */
#endif /* _xfer_h_ */