/*                             W3C Sample Code Library libwww Rule File Configuration manager
                             RULE FILE CONFIGURATION MANAGER
                                             
 */
/*
**      (c) COPYRIGHT MIT 1995.
**      Please first read the full copyright statement in the file COPYRIGH.
*/
/*

   The W3C Library provides this module for handling configuration files (a.k.a. rule
   files). Rule files can be used to initialize as much as the application desires
   including setting up new protocol modules etc. Also the rules file do not have to be a
   fil - it can be a database or any other way of storage information. This implementation
   is not used by the Library at all and is part of the Application interface.
   
   This module is implemented by HTRules.c, and it is a part of the W3C Sample Code
   Library.
   
 */
#ifndef HTRULE_H
#define HTRULE_H

#include "HTList.h"
#include "HTReq.h"
#include "HTFormat.h"
/*

PARSE A WHOLE RULE FILE

   Parsing a whole rule file is done using a converter stream. This means that a rule file
   can come from anywhere, even accross the network. We have defined a special content
   type for rule files called WWW_RULESin HTFormat.
   
 */
extern HTConverter HTRules;
/*

PARSE A SINGLE LINE FROM A RULES FILE

   This routine may be used for loading configuration information from sources other than
   the rule file, for example INI files for X resources. configis a string in the syntax
   of a rule file line.
   
 */
extern BOOL HTRule_parseLine (HTList * list, const char * config);
/*

ADD A RULE TO THE LIST

   This function adds a rule to the list of rules. The patternis a 0-terminated string
   containing a single "*". equivpoints to the equivalent string with * for the place
   where the text matched by * goes.
   
 */
typedef struct _HTRule HTRule;

typedef enum _HTRuleOp {
    HT_Invalid,
    HT_Map,
    HT_Pass,
    HT_Fail,
    HT_DefProt,
    HT_Protect,
    HT_Exec,
    HT_Redirect,
    HT_UseProxy
} HTRuleOp;

extern BOOL HTRule_add (HTList * list, HTRuleOp op,
                        const char * pattern, const char * replace);
/*

DELETE ALL REGISTERED RULES

   This function clears all rules registered
   
 */
extern BOOL HTRule_deleteAll (HTList *list);
/*

GLOBAL RULES

   Rules are handled as list as everything else that has to do with preferences. We
   provide two functions for getting and setting the global rules:
   
 */
extern HTList * HTRule_global   (void);
extern BOOL HTRule_setGlobal    (HTList * list);
extern BOOL HTRule_addGlobal    (HTRuleOp op, const char * pattern, const char * replace);
/*

TRANSLATE BY RULES

   This function walks through the list of rules and translates the reference when matches
   are found. The list is traversed in order starting from the head of the list. It
   returns the address of the equivalent string allocated from the heap which the CALLER
   MUST FREE. If no translation occured, then it is a copy of the original.
   
 */
extern char * HTRule_translate (HTList * list, const char * token,
                                BOOL ignore_case);
/*

 */
#endif
/*

   
   ___________________________________
   
                           @(#) $Id: HTRules.html,v 2.35 1997/02/16 18:42:57 frystyk Exp $
                                                                                          
    */
