/*                                           W3C Sample Code Library libwww File descriptions
                                    FILE DESCRIPTIONS
                                             
 */
/*
**      (c) COPYRIGHT MIT 1995.
**      Please first read the full copyright statement in the file COPYRIGH.
*/
/*

   Descriptions appearing in directory listings are produced by this module. This may be
   overridden by another module for those who which descriptions to come from somewhere
   else. It's only HTTP directory listings that contain a description field (if enabled by
   the Directory browsing module.
   
   This module is implemented by HTDescpt.c, and it is a part of the W3C Sample Code
   Library.
   
 */
#ifndef HTDESCRIPT_H
#define HTDESCRIPT_H

/*

DESCRIPTION FILE

   This module gets descriptions from the file defined by global variable
   HTDescriptionFilein the same directory as the directoy to be listed. The default value
   is .www_descript:
   
 */
extern char * HTDescriptionFile;
/*

   In the description file lines starting with a word starting with 'D' are taken to be
   descriptions (this looks funny now, but this is to make it easy to extend these
   description files to contain also other information. An example of the format of the
   description file is:
   
 */
/*
**      DESCRIBE  welcome.html  Our welcome page
**      DESCRIBE  map*.gif      Map as a GIF image
**      DESCRIBE  map*.ps       Map as a PostScript image
*/
/*

HTML TITLES

   If description is not specified for a file that is of type text/html, this module uses
   the HTML TITLE as the description. This feature can be turned off by setting the
   HTPeekTitlesvariable to false.
   
 */
extern BOOL HTPeekTitles;
/*

READ DESCRIPTION FILE

   The description file for a directory is read in only once by HTReadDescriptions(), and
   the result returned by it is given as an argument when finding out a description for a
   single file.
   
 */
extern HTList * HTReadDescriptions (char * dirname);
/*

GET DESCRIPTION FOR A FILE

   Once description file has been read and the list of descriptions is returned by
   HTReadDescriptions(), the function HTGetDescription()can be used to get a description
   for a given file:
   
 */
extern char * HTGetDescription (HTList *        descriptions,
                                       char *   dirname,
                                       char *   filename,
                                       HTFormat format);
/*

   Directory name has to be present because this function may then take a peek at the file
   itself (to get the HTML TITLE, for example). If formatis WWW_HTMLand description is not
   found, this module may be configured to use the HTML TITLE as the description.
   
   No string returned by this function should be freed!
   
FREEING DESCRIPTIONS

   Once descriptions have been gotten, the description list returned by
   HTReadDescriptions()must be freed by HTFreeDescriptions():
   
 */
extern void HTFreeDescriptions (HTList * descriptions);
/*

 */
#endif /* !HTDESCRIPT_H */
/*

   
   ___________________________________
   
                          @(#) $Id: HTDescpt.html,v 2.12 1997/02/16 18:42:07 frystyk Exp $
                                                                                          
    */
