1999-12-19 16:17:45 +00:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2015-01-21 23:55:44 +00:00
|
|
|
enum {
|
|
|
|
kMacSocket_TimeoutErr = -2
|
1999-12-19 16:17:45 +00:00
|
|
|
};
|
|
|
|
|
2015-01-21 23:55:44 +00:00
|
|
|
// Since MacSocket does busy waiting, I do a callback while waiting
|
1999-12-19 16:17:45 +00:00
|
|
|
|
2015-01-21 23:55:44 +00:00
|
|
|
typedef OSErr(*MacSocket_IdleWaitCallback) (void *);
|
1999-12-19 16:17:45 +00:00
|
|
|
|
2015-01-21 23:55:44 +00:00
|
|
|
// Call this before anything else!
|
1999-12-19 16:17:45 +00:00
|
|
|
|
|
|
|
OSErr MacSocket_Startup(void);
|
|
|
|
|
2015-01-21 23:55:44 +00:00
|
|
|
// Call this to cleanup before quitting
|
1999-12-19 16:17:45 +00:00
|
|
|
|
|
|
|
OSErr MacSocket_Shutdown(void);
|
|
|
|
|
2015-01-21 23:55:44 +00:00
|
|
|
// Call this to allocate a "socket" (reference number is returned in
|
|
|
|
// outSocketNum)
|
|
|
|
// Note that inDoThreadSwitching is pretty much irrelevant right now, since I
|
|
|
|
// ignore it
|
|
|
|
// The inTimeoutTicks parameter is applied during reads/writes of data
|
|
|
|
// The inIdleWaitCallback parameter specifies a callback which is called
|
|
|
|
// during busy-waiting periods
|
|
|
|
// The inUserRefPtr parameter is passed back to the idle-wait callback
|
1999-12-19 16:17:45 +00:00
|
|
|
|
2015-01-21 23:55:44 +00:00
|
|
|
OSErr MacSocket_socket(int *outSocketNum, const Boolean inDoThreadSwitching,
|
|
|
|
const long inTimeoutTicks,
|
|
|
|
MacSocket_IdleWaitCallback inIdleWaitCallback,
|
|
|
|
void *inUserRefPtr);
|
1999-12-19 16:17:45 +00:00
|
|
|
|
2015-01-21 23:55:44 +00:00
|
|
|
// Call this to connect to an IP/DNS address
|
|
|
|
// Note that inTargetAddressAndPort is in "IP:port" format-- e.g.
|
|
|
|
// 10.1.1.1:123
|
1999-12-19 16:17:45 +00:00
|
|
|
|
2015-01-21 23:55:44 +00:00
|
|
|
OSErr MacSocket_connect(const int inSocketNum, char *inTargetAddressAndPort);
|
1999-12-19 16:17:45 +00:00
|
|
|
|
2015-01-21 23:55:44 +00:00
|
|
|
// Call this to listen on a port
|
|
|
|
// Since this a low-performance implementation, I allow a maximum of 1 (one!)
|
|
|
|
// incoming request when I listen
|
1999-12-19 16:17:45 +00:00
|
|
|
|
2015-01-21 23:55:44 +00:00
|
|
|
OSErr MacSocket_listen(const int inSocketNum, const int inPortNum);
|
1999-12-19 16:17:45 +00:00
|
|
|
|
2015-01-21 23:55:44 +00:00
|
|
|
// Call this to close a socket
|
1999-12-19 16:17:45 +00:00
|
|
|
|
|
|
|
OSErr MacSocket_close(const int inSocketNum);
|
|
|
|
|
2015-01-21 23:55:44 +00:00
|
|
|
// Call this to receive data on a socket
|
|
|
|
// Most parameters' purpose are obvious-- except maybe "inBlock" which
|
|
|
|
// controls whether I wait for data or return immediately
|
1999-12-19 16:17:45 +00:00
|
|
|
|
2015-01-21 23:55:44 +00:00
|
|
|
int MacSocket_recv(const int inSocketNum, void *outBuff, int outBuffLength,
|
|
|
|
const Boolean inBlock);
|
1999-12-19 16:17:45 +00:00
|
|
|
|
2015-01-21 23:55:44 +00:00
|
|
|
// Call this to send data on a socket
|
1999-12-19 16:17:45 +00:00
|
|
|
|
2015-01-21 23:55:44 +00:00
|
|
|
int MacSocket_send(const int inSocketNum, const void *inBuff,
|
|
|
|
int inBuffLength);
|
1999-12-19 16:17:45 +00:00
|
|
|
|
2015-01-21 23:55:44 +00:00
|
|
|
// If zero bytes were read in a call to MacSocket_recv(), it may be that the
|
|
|
|
// remote end has done a half-close
|
|
|
|
// This function will let you check whether that's true or not
|
1999-12-19 16:17:45 +00:00
|
|
|
|
|
|
|
Boolean MacSocket_RemoteEndIsClosing(const int inSocketNum);
|
|
|
|
|
2015-01-21 23:55:44 +00:00
|
|
|
// Call this to see if the listen has completed after a call to
|
|
|
|
// MacSocket_listen()
|
1999-12-19 16:17:45 +00:00
|
|
|
|
|
|
|
Boolean MacSocket_ListenCompleted(const int inSocketNum);
|
|
|
|
|
2015-01-21 23:55:44 +00:00
|
|
|
// These really aren't very useful anymore
|
1999-12-19 16:17:45 +00:00
|
|
|
|
|
|
|
Boolean MacSocket_LocalEndIsOpen(const int inSocketNum);
|
|
|
|
Boolean MacSocket_RemoteEndIsOpen(const int inSocketNum);
|
|
|
|
|
2015-01-21 23:55:44 +00:00
|
|
|
// You may wish to change the userRefPtr for a socket callback-- use this to
|
|
|
|
// do it
|
1999-12-19 16:17:45 +00:00
|
|
|
|
2015-01-21 23:55:44 +00:00
|
|
|
void MacSocket_SetUserRefPtr(const int inSocketNum, void *inNewRefPtr);
|
1999-12-19 16:17:45 +00:00
|
|
|
|
2015-01-21 23:55:44 +00:00
|
|
|
// Call these to get the socket's IP:port descriptor
|
1999-12-19 16:17:45 +00:00
|
|
|
|
2015-01-21 23:55:44 +00:00
|
|
|
void MacSocket_GetLocalIPAndPort(const int inSocketNum, char *outIPAndPort,
|
|
|
|
const int inIPAndPortLength);
|
|
|
|
void MacSocket_GetRemoteIPAndPort(const int inSocketNum, char *outIPAndPort,
|
|
|
|
const int inIPAndPortLength);
|
1999-12-19 16:17:45 +00:00
|
|
|
|
2015-01-21 23:55:44 +00:00
|
|
|
// Call this to get error info from a socket
|
1999-12-19 16:17:45 +00:00
|
|
|
|
2015-01-21 23:55:44 +00:00
|
|
|
void MacSocket_GetSocketErrorInfo(const int inSocketNum,
|
|
|
|
int *outSocketErrCode,
|
|
|
|
char *outSocketErrString,
|
|
|
|
const int inSocketErrStringMaxLength);
|
1999-12-19 16:17:45 +00:00
|
|
|
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|