/
circle/
circle/lib/misc/
circle/lib/plrobjs/
circle/lib/world/shp/
/* ************************************************************************
*   File: mail.h                                        Part of CircleMUD *
*  Usage: header file for mail system                                     *
*                                                                         *
*  All rights reserved.  See license.doc for complete information.        *
*                                                                         *
*  Copyright (C) 1993 by the Trustees of the Johns Hopkins University     *
*  CircleMUD is based on DikuMUD, Copyright (C) 1990, 1991.               *
************************************************************************ */

/******* MUD MAIL SYSTEM HEADER FILE ****************************
 ***     written by Jeremy Elson (jelson@server.cs.jhu.edu)   ***
 ****   compliments of CircleMUD (circle.cs.jhu.edu 4000)    ****
 ***************************************************************/

/* INSTALLATION INSTRUCTIONS in MAIL.C */

/* You can modify the following constants to fit your own MUD.  */

/* command numbers of the "mail", "check", and "receive" commands
   in your interpreter. */
#define CMD_MAIL	247
#define CMD_CHECK	248
#define CMD_RECEIVE	249

/* minimum level a player must be to send mail	*/
#define MIN_MAIL_LEVEL 2

/* # of gold coins required to send mail	*/
#define STAMP_PRICE 150

/* Maximum size of mail in bytes (arbitrary)	*/
#define MAX_MAIL_SIZE 4000

/* Max size of player names			*/
#define NAME_SIZE  15

/* size of mail file allocation blocks		*/
#define BLOCK_SIZE 100

/* NOTE:  Make sure that your block size is big enough -- if not,
   HEADER_BLOCK_DATASIZE will end up negative.  This is a bad thing.
   Check the define below to make sure it is >0 when choosing values
   for NAME_SIZE and BLOCK_SIZE.  100 is a nice round number for
   BLOCK_SIZE and is the default ... why bother trying to change it
   anyway?

   The mail system will always allocate disk space in chunks of size
   BLOCK_SIZE.
*/

/* USER CHANGABLE DEFINES ABOVE **
***************************************************************************
**   DON'T TOUCH DEFINES BELOW  */

int	scan_file(void);
int	has_mail(char *recipient);
void	store_mail(char *to, char *from, char *message_pointer);
char	*read_delete(char *recipient, char *recipient_formatted);

#define INT_SIZE  sizeof(int)
#define CHAR_SIZE sizeof(char)
#define LONG_SIZE sizeof(long)

#define HEADER_BLOCK_DATASIZE (BLOCK_SIZE-1-((CHAR_SIZE*(NAME_SIZE+1)*2)+(3*LONG_SIZE)))
/* size of the data part of a header block */

#define DATA_BLOCK_DATASIZE (BLOCK_SIZE-LONG_SIZE-1)
/* size of the data part of a data block */

/* note that an extra space is allowed in all string fields for the
   terminating null character.  */

#define HEADER_BLOCK  -1
#define LAST_BLOCK    -2
#define DELETED_BLOCK -3

/* note: next_block is part of header_blk in a data block; we can't combine
   them here because we have to be able to differentiate a data block from a
   header block when booting mail system.
*/

struct header_block_type_d {
   long	block_type;  	/* is this a header block or data block? */
   long	next_block;	/* if header block, link to next block   */
   char	from[NAME_SIZE+1]; /* who is this letter from?		 */
   char	to[NAME_SIZE+1];/* who is this letter to?		 */
   long	mail_time;	/* when was the letter mailed?		 */
   char	txt[HEADER_BLOCK_DATASIZE+1]; /* the actual text	*/
};

struct data_block_type_d {
   long	block_type;  	/* -1 if header block, -2 if last data block
      				   in mail, otherwise a link to the next */
   char	txt[DATA_BLOCK_DATASIZE+1]; /* the actual text		 */
};

typedef struct header_block_type_d header_block_type;
typedef struct data_block_type_d data_block_type;

struct position_list_type_d {
   long	position;
   struct position_list_type_d *next;
};

typedef struct position_list_type_d position_list_type;

struct mail_index_type_d {
   char	recipient[NAME_SIZE+1]; /* who the mail is for */
   position_list_type   	 * list_start;  /* list of mail positions    */
   struct mail_index_type_d *next;
};

typedef struct mail_index_type_d mail_index_type;