ncsa-mosaic/libwww2/HTAccess.h
2013-03-10 01:59:42 +01:00

165 lines
3.5 KiB
C

/* HTAccess: Access manager for libwww
ACCESS MANAGER
This module keeps a list of valid protocol (naming scheme)
specifiers with associated access code. It allows documents to be
loaded given various combinations of parameters. New access
protocols may be registered at any time.
Part of the libwww library .
*/
#ifndef HTACCESS_H
#define HTACCESS_H
/* Definition uses:
*/
#include "HTUtils.h"
#include "tcp.h"
#include "HTAnchor.h"
#include "HTFormat.h"
#ifdef SHORT_NAMES
#define HTClientHost HTClHost
#define HTOutputStream HTOuStre
#define HTOutputFormat HTOuForm
#endif
/* Return codes from load routines:
**
** These codes may be returned by the protocol modules,
** and by the HTLoad routines.
** In general, positive codes are OK and negative ones are bad.
*/
#define HT_NO_DATA -9999 /* return code: OK but no data was loaded */
/* Typically, other app started or forked */
/*
Flags which may be set to control this module
*/
extern int HTDiag; /* Flag: load source as plain text */
extern char * HTClientHost; /* Name or number of telnetting host */
extern FILE * logfile; /* File to output one-liners to */
extern HTStream* HTOutputStream; /* For non-interactive, set this */
extern HTFormat HTOutputFormat; /* To convert on load, set this */
/*
Load a document from relative name
ON ENTRY,
relative_name The relative address of the file to be accessed.
here The anchor of the object being searched
ON EXIT,
returns YES Success in opening file
NO Failure
*/
extern BOOL HTLoadRelative PARAMS((
WWW_CONST char * relative_name,
HTParentAnchor * here));
/*
Load a document from absolute name
ON ENTRY,
addr The absolute address of the document to be accessed.
filter if YES, treat document as HTML
*/
/*
ON EXIT,
*/
/*
returns YES Success in opening document
NO Failure
*/
extern int HTLoadAbsolute PARAMS((WWW_CONST char * addr));
/*
Load a document from absolute name to a stream
ON ENTRY,
addr The absolute address of the document to be accessed.
filter if YES, treat document as HTML
ON EXIT,
returns YES Success in opening document
NO Failure
Note: This is equivalent to HTLoadDocument
*/
extern BOOL HTLoadToStream PARAMS((WWW_CONST char * addr, BOOL filter,
HTStream * sink));
/*
Make a stream for Saving object back
ON ENTRY,
anchor is valid anchor which has previously beeing loaded
ON EXIT,
returns 0 if error else a stream to save the object to.
*/
extern HTStream * HTSaveStream PARAMS((HTParentAnchor * anchor));
/*
Register an access method
*/
typedef struct _HTProtocol {
char * name;
int (*load)PARAMS((
WWW_CONST char * full_address,
HTParentAnchor * anchor,
HTFormat format_out,
HTStream* sink));
HTStream* (*saveStream)PARAMS((HTParentAnchor * anchor));
} HTProtocol;
extern BOOL HTRegisterProtocol PARAMS((HTProtocol * protocol));
#endif /* HTACCESS_H */