X-Git-Url: http://git.marmaro.de/?a=blobdiff_plain;f=h%2Fmh.h;h=225d0c91ff5b3c7d415f70f1e1e936fa41a472ef;hb=9f8f8b1e1d553774865f2c177191c359c3dc652c;hp=afe2682dc0883c542a0b48d715e72a5cdda48ecf;hpb=9d27405ff3562d183784a244ee44bbaf71eabda8;p=mmh diff --git a/h/mh.h b/h/mh.h index afe2682..225d0c9 100644 --- a/h/mh.h +++ b/h/mh.h @@ -1,21 +1,10 @@ /* * mh.h -- main header file for all of nmh - * - * $Id$ */ #include -/* A quick fix for Linux systems. According to the vfork manual page, - there is little difference in performance, so we aren't losing much. - But this fixes a minor message bug so why not? On NetBSD, this should - probably not happen. */ -#ifdef linux -#define vfork fork -#endif - - /* * Well-used constants */ @@ -38,6 +27,17 @@ #endif typedef unsigned char boolean; /* not int so we can pack in a structure */ +/* If we're using gcc then give it some information about + * functions that abort. + */ +#if __GNUC__ > 2 +#define NORETURN __attribute__((__noreturn__)) +#define NMH_UNUSED(i) (void) i +#else +#define NORETURN +#define NMH_UNUSED(i) i +#endif + /* * user context/profile structure */ @@ -67,6 +67,8 @@ struct swit { extern struct swit anoyes[]; /* standard yes/no switches */ +#define ATTACHFORMATS 3 /* Number of send attach formats. */ + /* * general folder attributes */ @@ -221,7 +223,15 @@ struct msgs { * m_getfld() message parsing */ -#define NAMESZ 128 /* Limit on component name size */ +#define NAMESZ 999 /* Limit on component name size. + RFC 2822 limits line lengths to + 998 characters, so a header name + can be at most that long. + m_getfld limits header names to 2 + less than NAMESZ, which is fine, + because header names must be + followed by a colon. Add one for + terminating NULL. */ #define LENERR (-2) /* Name too long error from getfld */ #define FMTERR (-3) /* Message Format error */ @@ -253,6 +263,11 @@ extern char *msg_delim; /* .. */ #define OUTPUTLINELEN 72 /* default line length for headers */ +#define LINK "@" /* Name of link to file to which you are */ + /* replying. */ + +#define NMH_ATTACH_HEADER "Nmh-Attachment" /* Default header for -attach */ + /* * miscellaneous macros */ @@ -283,6 +298,13 @@ extern char *defpath; /* pathname of user's profile */ extern char *ctxpath; /* pathname of user's context */ extern struct node *m_defs; /* list of profile/context entries */ +/* What style to use for generated Message-ID and Content-ID header + fields. The localname style is pid.time@localname, where time is + in seconds. The random style replaces the localname with some + (pseudo)random bytes and uses microsecond-resolution time. */ +int save_message_id_style (const char *); +char *message_id (time_t, int); + /* * These standard strings are defined in config.c. They are the * only system-dependent parameters in nmh, and thus by redefining @@ -299,9 +321,9 @@ extern char *defaultfolder; extern char *digestcomps; extern char *distcomps; extern char *draft; -extern char *faceproc; extern char *fileproc; extern char *foldprot; +extern char *formatproc; extern char *forwcomps; extern char *inbox; extern char *incproc; @@ -331,7 +353,6 @@ extern char *rcvdistcomps; extern char *rcvstoreproc; extern char *replcomps; extern char *replgroupcomps; -extern char *rmfproc; extern char *rmmproc; extern char *sendproc; extern char *showmimeproc; @@ -343,5 +364,7 @@ extern char *vmhproc; extern char *whatnowproc; extern char *whomproc; +extern void (*done) (int) NORETURN; + #include