mirror of
https://github.com/ksherlock/gopher.git
synced 2025-01-21 07:30:52 +00:00
better gopher support
This commit is contained in:
parent
f305f78412
commit
f718cd8afb
@ -1,9 +1,10 @@
|
||||
#include "Connect.h"
|
||||
#include "connection.h"
|
||||
#include <string.h>
|
||||
|
||||
//static char pstring[256];
|
||||
static char pstring[256];
|
||||
|
||||
|
||||
static Word LoginAndOpen(ConnectBuffer *buffer)
|
||||
static Word LoginAndOpen(Connection *buffer)
|
||||
{
|
||||
Word ipid;
|
||||
Word terr;
|
||||
@ -17,7 +18,7 @@ static Word LoginAndOpen(ConnectBuffer *buffer)
|
||||
|
||||
if (_toolErr)
|
||||
{
|
||||
buffer->state = ConnectStateError;
|
||||
buffer->state = kConnectionStateError;
|
||||
return -1;
|
||||
}
|
||||
|
||||
@ -25,33 +26,33 @@ static Word LoginAndOpen(ConnectBuffer *buffer)
|
||||
if (_toolErr || terr)
|
||||
{
|
||||
TCPIPLogout(ipid);
|
||||
buffer->state = ConnectStateError;
|
||||
buffer->state = kConnectionStateError;
|
||||
buffer->terr = terr;
|
||||
buffer->ipid = 0;
|
||||
return -1;
|
||||
}
|
||||
|
||||
buffer->ipid = ipid;
|
||||
buffer->state = ConnectStateConnecting;
|
||||
buffer->state = kConnectionStateConnecting;
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
Word ConnectionPoll(ConnectBuffer *buffer)
|
||||
Word ConnectionPoll(Connection *buffer)
|
||||
{
|
||||
Word state;
|
||||
if (!buffer) return -1;
|
||||
state = buffer->state;
|
||||
|
||||
if (state == 0) return -1;
|
||||
if (state == ConnectStateConnected) return 1;
|
||||
if (state == ConnectStateDisconnected) return 1;
|
||||
if (state == ConnectStateError) return -1;
|
||||
if (state == kConnectionStateConnected) return 1;
|
||||
if (state == kConnectionStateDisconnected) return 1;
|
||||
if (state == kConnectionStateError) return -1;
|
||||
|
||||
TCPIPPoll();
|
||||
|
||||
if (state == ConnectStateDNR)
|
||||
if (state == kConnectionStateDNR)
|
||||
{
|
||||
if (buffer->dnr.DNRstatus == DNR_OK)
|
||||
{
|
||||
@ -59,19 +60,19 @@ Word ConnectionPoll(ConnectBuffer *buffer)
|
||||
}
|
||||
else if (buffer->dnr.DNRstatus != DNR_Pending)
|
||||
{
|
||||
buffer->state = ConnectStateError;
|
||||
buffer->state = kConnectionStateError;
|
||||
return -1;
|
||||
}
|
||||
}
|
||||
|
||||
if (state == ConnectStateConnecting || state == ConnectStateDisconnecting)
|
||||
if (state == kConnectionStateConnecting || state == kConnectionStateDisconnecting)
|
||||
{
|
||||
Word terr;
|
||||
static srBuff sr;
|
||||
|
||||
terr = TCPIPStatusTCP(buffer->ipid, &sr);
|
||||
|
||||
if (state == ConnectStateDisconnecting)
|
||||
if (state == kConnectionStateDisconnecting)
|
||||
{
|
||||
// these are not errors.
|
||||
if (terr == tcperrConClosing || terr == tcperrClosing)
|
||||
@ -85,14 +86,14 @@ Word ConnectionPoll(ConnectBuffer *buffer)
|
||||
TCPIPCloseTCP(buffer->ipid);
|
||||
TCPIPLogout(buffer->ipid);
|
||||
buffer->ipid = 0;
|
||||
buffer->state = ConnectStateError;
|
||||
buffer->state = kConnectionStateError;
|
||||
buffer->terr = terr;
|
||||
return -1;
|
||||
}
|
||||
|
||||
if (sr.srState == TCPSESTABLISHED) // && state == ConnectStateConnecting)
|
||||
if (sr.srState == TCPSESTABLISHED) // && state == kConnectionStateConnecting)
|
||||
{
|
||||
buffer->state = ConnectStateConnected;
|
||||
buffer->state = kConnectionStateConnected;
|
||||
return 1;
|
||||
}
|
||||
|
||||
@ -100,7 +101,7 @@ Word ConnectionPoll(ConnectBuffer *buffer)
|
||||
{
|
||||
TCPIPLogout(buffer->ipid);
|
||||
buffer->ipid = 0;
|
||||
buffer->state = ConnectStateDisconnected;
|
||||
buffer->state = kConnectionStateDisconnected;
|
||||
return 1;
|
||||
}
|
||||
}
|
||||
@ -108,13 +109,41 @@ Word ConnectionPoll(ConnectBuffer *buffer)
|
||||
return 0;
|
||||
}
|
||||
|
||||
Word ConnectionOpen(ConnectBuffer *buffer, const char *host, Word port)
|
||||
Word ConnectionOpenC(Connection *buffer, const char *host, Word port)
|
||||
{
|
||||
Word length;
|
||||
|
||||
if (!host) return -1;
|
||||
|
||||
length = strlen(host);
|
||||
if (length > 255) return -1;
|
||||
|
||||
pstring[0] = length & 0xff;
|
||||
memcpy(pstring + 1, host, length);
|
||||
|
||||
return ConnectionOpen(buffer, pstring, port);
|
||||
}
|
||||
|
||||
Word ConnectionOpenGS(Connection *buffer, const GSString255 *host, Word port)
|
||||
{
|
||||
if (!host) return -1;
|
||||
if (host->length > 255) return -1;
|
||||
|
||||
pstring[0] = host->length & 0xff;
|
||||
memcpy(pstring + 1, host->text, host->length);
|
||||
|
||||
return ConnectionOpen(buffer, pstring, port);
|
||||
}
|
||||
|
||||
Word ConnectionOpen(Connection *buffer, const char *host, Word port)
|
||||
{
|
||||
buffer->state = 0;
|
||||
buffer->ipid = 0;
|
||||
buffer->terr = 0;
|
||||
buffer->port = port;
|
||||
|
||||
if (!buffer || !*buffer) return -1;
|
||||
|
||||
// 1. check if we need to do DNR.
|
||||
if (TCPIPValidateIPString(host))
|
||||
{
|
||||
@ -129,14 +158,14 @@ Word ConnectionOpen(ConnectBuffer *buffer, const char *host, Word port)
|
||||
TCPIPDNRNameToIP(host, &buffer->dnr);
|
||||
if (_toolErr)
|
||||
{
|
||||
buffer->state = ConnectStateError;
|
||||
buffer->state = kConnectionStateError;
|
||||
return -1;
|
||||
}
|
||||
buffer->state = ConnectStateDNR;
|
||||
buffer->state = kConnectionStateDNR;
|
||||
return 0;
|
||||
}
|
||||
|
||||
void ConnectionInit(ConnectBuffer *buffer, Word memID)
|
||||
void ConnectionInit(Connection *buffer, Word memID)
|
||||
{
|
||||
buffer->memID = memID;
|
||||
buffer->ipid = 0;
|
||||
@ -147,19 +176,19 @@ void ConnectionInit(ConnectBuffer *buffer, Word memID)
|
||||
buffer->dnr.DNRIPaddress = 0;
|
||||
}
|
||||
|
||||
Word ConnectionClose(ConnectBuffer *buffer)
|
||||
Word ConnectionClose(Connection *buffer)
|
||||
{
|
||||
Word state = buffer->state;
|
||||
|
||||
// todo -- how do you close if not yet connected?
|
||||
if (state == ConnectStateConnected)
|
||||
if (state == kConnectionStateConnected)
|
||||
{
|
||||
buffer->state = ConnectStateDisconnecting;
|
||||
buffer->state = kConnectionStateDisconnecting;
|
||||
buffer->terr = TCPIPCloseTCP(buffer->ipid);
|
||||
return 0;
|
||||
}
|
||||
|
||||
if (state == ConnectStateDNR)
|
||||
if (state == kConnectionStateDNR)
|
||||
{
|
||||
TCPIPCancelDNR(&buffer->dnr);
|
||||
buffer->state = 0;
|
39
connection.h
Normal file
39
connection.h
Normal file
@ -0,0 +1,39 @@
|
||||
#ifndef __CONNECT_H__
|
||||
#define __CONNECT_H__
|
||||
|
||||
#ifndef __TCPIP__
|
||||
#include <tcpip.h>
|
||||
#endif
|
||||
|
||||
enum {
|
||||
kConnectionStateDNR = 1,
|
||||
kConnectionStateConnecting,
|
||||
kConnectionStateConnected,
|
||||
kConnectionStateDisconnecting,
|
||||
kConnectionStateDisconnected,
|
||||
kConnectionStateError
|
||||
};
|
||||
|
||||
typedef struct Connection {
|
||||
Word memID;
|
||||
Word ipid;
|
||||
Word terr;
|
||||
Word state;
|
||||
dnrBuffer dnr;
|
||||
Word port;
|
||||
} Connection;
|
||||
|
||||
|
||||
|
||||
void ConnectionInit(Connection *, Word memID);
|
||||
|
||||
Word ConnectionOpen(Connection *, const char *host, Word port);
|
||||
Word ConnectionOpenC(Connection *, const char *host, Word port);
|
||||
Word ConnectionOpenGS(Connection *, const GSString255 *host, Word port);
|
||||
|
||||
Word ConnectionClose(Connection *);
|
||||
Word ConnectionPoll(Connection *);
|
||||
|
||||
|
||||
|
||||
#endif
|
16
fast.memory.h
Normal file
16
fast.memory.h
Normal file
@ -0,0 +1,16 @@
|
||||
#ifndef _fast_memory_h_
|
||||
#define _fast_memory_h_
|
||||
|
||||
struct _Handle
|
||||
{
|
||||
void *pointer;
|
||||
Word attr;
|
||||
Word owner;
|
||||
LongWord size;
|
||||
};
|
||||
|
||||
#define _HLock(h) ((struct _Handle *)h)->attr |= 0x8000
|
||||
#define _HUnlock(h) ((struct _Handle *)h)->attr &= 0x7fff
|
||||
#define _GetHandleSize(h) ((struct _Handle *)h)->size
|
||||
|
||||
#endif
|
Loading…
x
Reference in New Issue
Block a user