Windows2000/private/inet/wininet/gopher/buffer.h
2020-09-30 17:12:32 +02:00

207 lines
3.9 KiB
C

/*++
Copyright (c) 1994 Microsoft Corporation
Module Name:
buffer.h
Abstract:
Contains manifests, macros, types and typedefs for buffer.c
Author:
Richard L Firth (rfirth) 31-Oct-1994
Revision History:
31-Oct-1994 rfirth
Created
*/
#if defined(__cplusplus)
extern "C" {
#endif
// manifests
// LOOK_AHEAD_LENGTH - read enough characters to comprise the maximum (32-bit)
// length returned by gopher+
#define LOOK_AHEAD_LENGTH sizeof("+4294967296\r\n") // 12
// BUFFER_INFO - structure maintains information about responses from gopher
// server. The same data can be shared amongst many requests
typedef struct {
// ReferenceCount - number of VIEW_INFO structures referencing this buffer
LONG ReferenceCount;
// Flags - information about the buffer
DWORD Flags;
// RequestEvent - the owner of this event is the only thread which can
// make the gopher request that creates this buffer info. All other
// requesters for the same information wait for the first thread to signal
// the event, then just read the data returned by the first thread
// HANDLE RequestEvent;
// RequestWaiters - used in conjunction with RequestEvent. If this field
// is 0 by the time the initial requester thread comes to signal the
// event, it can do away with the event altogether, since it was only
// required to stop those other threads from making a redundant request
// DWORD RequestWaiters;
// ConnectedSocket - contains socket we are using to receive the data in
// the buffer, and the index into the parent SESSION_INFO's
// ADDRESS_INFO_LIST of the address used to connect the socket
// CONNECTED_SOCKET ConnectedSocket;
ICSocket * Socket;
// ResponseLength - the response length as told to us by the gopher+ server
int ResponseLength;
// BufferLength - length of Buffer
DWORD BufferLength;
// Buffer - containing response
LPBYTE Buffer;
// ResponseInfo - we read the gopher+ header information (i.e. length) here.
// The main reason is so that we can determine the length of a gopher+ file
// even though we were given a zero-length user buffer
char ResponseInfo[LOOK_AHEAD_LENGTH];
// BytesRemaining - number of bytes left in ResponseInfo that are data
int BytesRemaining;
// DataBytes - pointer into ResponseInfo where data bytes start
LPBYTE DataBytes;
// CriticalSection - used to serialize readers
// CRITICAL_SECTION CriticalSection;
} BUFFER_INFO, *LPBUFFER_INFO;
// BUFFER_INFO flags
#define BI_RECEIVE_COMPLETE 0x00000001 // receiver thread has finished
#define BI_DOT_AT_END 0x00000002 // buffer terminated with ".\r\n"
#define BI_BUFFER_RESPONSE 0x00000004 // response is buffered internally
#define BI_ERROR_RESPONSE 0x00000008 // the server responded with an error
#define BI_MOVEABLE 0x00000010 // buffer is moveable memory
#define BI_FIRST_RECEIVE 0x00000020 // this is the first receive
#define BI_OWN_BUFFER 0x00000040 // set if we own the buffer (directory)
// external data
DEBUG_DATA_EXTERN(LONG, NumberOfBuffers);
// prototypes
LPBUFFER_INFO
CreateBuffer(
OUT LPDWORD Error
);
VOID
DestroyBuffer(
IN LPBUFFER_INFO BufferInfo
);
VOID
AcquireBufferLock(
IN LPBUFFER_INFO BufferInfo
);
VOID
ReleaseBufferLock(
IN LPBUFFER_INFO BufferInfo
);
VOID
ReferenceBuffer(
IN LPBUFFER_INFO BufferInfo
);
LPBUFFER_INFO
DereferenceBuffer(
IN LPBUFFER_INFO BufferInfo
);
// macros
#if INET_DEBUG
#define BUFFER_CREATED() ++NumberOfBuffers
#define BUFFER_DESTROYED() --NumberOfBuffers
#define ASSERT_NO_BUFFERS() \
if (NumberOfBuffers != 0) { \
INET_ASSERT(FALSE); \
}
#else
#define BUFFER_CREATED() /* NOTHING */
#define BUFFER_DESTROYED() /* NOTHING */
#define ASSERT_NO_BUFFERS() /* NOTHING */
#endif
#if defined(__cplusplus)
}
#endif