⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 mutt.h

📁 mutt-1.5.12 源代码。linux 下邮件接受的工具。
💻 H
📖 第 1 页 / 共 2 页
字号:
  OPTPGPIGNORESUB,  OPTPGPCHECKEXIT,  OPTPGPLONGIDS,  OPTPGPAUTODEC,#if 0  OPTPGPENCRYPTSELF,#endif  OPTPGPRETAINABLESIG,  OPTPGPSTRICTENC,  OPTFORWDECRYPT,  OPTPGPSHOWUNUSABLE,  OPTPGPAUTOINLINE,  OPTPGPREPLYINLINE,  /* pseudo options */  OPTAUXSORT,		/* (pseudo) using auxillary sort function */  OPTFORCEREFRESH,	/* (pseudo) refresh even during macros */  OPTLOCALES,		/* (pseudo) set if user has valid locale definition */  OPTNOCURSES,		/* (pseudo) when sending in batch mode */  OPTNEEDREDRAW,	/* (pseudo) to notify caller of a submenu */  OPTSEARCHREVERSE,	/* (pseudo) used by ci_search_command */  OPTMSGERR,		/* (pseudo) used by mutt_error/mutt_message */  OPTSEARCHINVALID,	/* (pseudo) used to invalidate the search pat */  OPTSIGNALSBLOCKED,	/* (pseudo) using by mutt_block_signals () */  OPTSYSSIGNALSBLOCKED,	/* (pseudo) using by mutt_block_signals_system () */  OPTNEEDRESORT,	/* (pseudo) used to force a re-sort */  OPTRESORTINIT,	/* (pseudo) used to force the next resort to be from scratch */  OPTVIEWATTACH,	/* (pseudo) signals that we are viewing attachments */  OPTFORCEREDRAWINDEX,	/* (pseudo) used to force a redraw in the main index */  OPTFORCEREDRAWPAGER,	/* (pseudo) used to force a redraw in the pager */  OPTSORTSUBTHREADS,	/* (pseudo) used when $sort_aux changes */  OPTNEEDRESCORE,	/* (pseudo) set when the `score' command is used */  OPTATTACHMSG,		/* (pseudo) used by attach-message */  OPTKEEPQUIET,		/* (pseudo) shut up the message and refresh			 * 	    functions while we are executing an			 * 	    external program.			 */  OPTMENUCALLER,	/* (pseudo) tell menu to give caller a take */  OPTREDRAWTREE,	/* (pseudo) redraw the thread tree */  OPTPGPCHECKTRUST,	/* (pseudo) used by pgp_select_key () */  OPTDONTHANDLEPGPKEYS,	/* (pseudo) used to extract PGP keys */  OPTUNBUFFEREDINPUT,   /* (pseudo) don't use key buffer */  OPTMAX};#define mutt_bit_alloc(n) calloc ((n + 7) / 8, sizeof (char))#define mutt_bit_set(v,n) v[n/8] |= (1 << (n % 8))#define mutt_bit_unset(v,n) v[n/8] &= ~(1 << (n % 8))#define mutt_bit_toggle(v,n) v[n/8] ^= (1 << (n % 8))#define mutt_bit_isset(v,n) (v[n/8] & (1 << (n % 8)))#define set_option(x) mutt_bit_set(Options,x)#define unset_option(x) mutt_bit_unset(Options,x)#define toggle_option(x) mutt_bit_toggle(Options,x)#define option(x) mutt_bit_isset(Options,x)typedef struct list_t{  char *data;  struct list_t *next;} LIST;typedef struct rx_list_t{  REGEXP *rx;  struct rx_list_t *next;} RX_LIST;typedef struct spam_list_t{  REGEXP *rx;  int     nmatch;  char   *template;  struct spam_list_t *next;} SPAM_LIST;#define mutt_new_list() safe_calloc (1, sizeof (LIST))#define mutt_new_rx_list() safe_calloc (1, sizeof (RX_LIST))#define mutt_new_spam_list() safe_calloc (1, sizeof (SPAM_LIST))void mutt_free_list (LIST **);void mutt_free_rx_list (RX_LIST **);void mutt_free_spam_list (SPAM_LIST **);LIST *mutt_copy_list (LIST *);int mutt_matches_ignore (const char *, LIST *);/* add an element to a list */LIST *mutt_add_list (LIST *, const char *);LIST *mutt_add_list_n (LIST*, const void *, size_t);void mutt_init (int, LIST *);typedef struct alias{  struct alias *self;		/* XXX - ugly hack */  char *name;  ADDRESS *addr;  struct alias *next;  short tagged;  short del;  short num;} ALIAS;typedef struct envelope{  ADDRESS *return_path;  ADDRESS *from;  ADDRESS *to;  ADDRESS *cc;  ADDRESS *bcc;  ADDRESS *sender;  ADDRESS *reply_to;  ADDRESS *mail_followup_to;  char *list_post;		/* this stores a mailto URL, or nothing */  char *subject;  char *real_subj;		/* offset of the real subject */  char *message_id;  char *supersedes;  char *date;  char *x_label;  BUFFER *spam;  LIST *references;		/* message references (in reverse order) */  LIST *in_reply_to;		/* in-reply-to header content */  LIST *userhdrs;		/* user defined headers */  unsigned int irt_changed : 1; /* In-Reply-To changed to link/break threads */  unsigned int refs_changed : 1; /* References changed to break thread */} ENVELOPE;typedef struct parameter{  char *attribute;  char *value;  struct parameter *next;} PARAMETER;/* Information that helps in determing the Content-* of an attachment */typedef struct content{  long hibin;              /* 8-bit characters */  long lobin;              /* unprintable 7-bit chars (eg., control chars) */  long crlf;		   /* '\r' and '\n' characters */  long ascii;              /* number of ascii chars */  long linemax;            /* length of the longest line in the file */  unsigned int space : 1;  /* whitespace at the end of lines? */  unsigned int binary : 1; /* long lines, or CR not in CRLF pair */  unsigned int from : 1;   /* has a line beginning with "From "? */  unsigned int dot : 1;    /* has a line consisting of a single dot? */  unsigned int cr : 1;     /* has CR, even when in a CRLF pair */} CONTENT;typedef struct body{  char *xtype;			/* content-type if x-unknown */  char *subtype;                /* content-type subtype */  PARAMETER *parameter;         /* parameters of the content-type */  char *description;            /* content-description */  char *form_name;		/* Content-Disposition form-data name param */  long hdr_offset;              /* offset in stream where the headers begin.				 * this info is used when invoking metamail,				 * where we need to send the headers of the				 * attachment				 */  LOFF_T offset;                /* offset where the actual data begins */  LOFF_T length;                /* length (in bytes) of attachment */  char *filename;               /* when sending a message, this is the file				 * to which this structure refers				 */  char *d_filename;		/* filename to be used for the 				 * content-disposition header.				 * If NULL, filename is used 				 * instead.				 */  CONTENT *content;             /* structure used to store detailed info about				 * the content of the attachment.  this is used				 * to determine what content-transfer-encoding				 * is required when sending mail.				 */  struct body *next;            /* next attachment in the list */  struct body *parts;           /* parts of a multipart or message/rfc822 */  struct header *hdr;		/* header information for message/rfc822 */  struct attachptr *aptr;	/* Menu information, used in recvattach.c */  signed short attach_count;  time_t stamp;			/* time stamp of last				 * encoding update.				 */    unsigned int type : 4;        /* content-type primary type */  unsigned int encoding : 3;    /* content-transfer-encoding */  unsigned int disposition : 2; /* content-disposition */  unsigned int use_disp : 1;    /* Content-Disposition uses filename= ? */  unsigned int unlink : 1;      /* flag to indicate the the file named by				 * "filename" should be unlink()ed before				 * free()ing this structure				 */  unsigned int tagged : 1;  unsigned int deleted : 1;	/* attachment marked for deletion */  unsigned int noconv : 1;	/* don't do character set conversion */  unsigned int force_charset : 1;   				/* send mode: don't adjust the character				 * set when in send-mode.				 */  unsigned int is_signed_data : 1; /* A lot of MUAs don't indicate                                      S/MIME signed-data correctly,                                      e.g. they use foo.p7m even for                                      the name of signed data.  This                                      flag is used to keep track of                                      the actual message type.  It                                      gets set during the verification                                      (which is done if the encryption                                      try failed) and check by the                                      function to figure the type of                                      the message. */  unsigned int goodsig : 1;	/* good cryptographic signature */  unsigned int warnsig : 1;     /* maybe good signature */  unsigned int badsig : 1;	/* bad cryptographic signature (needed to check encrypted s/mime-signatures) */  unsigned int collapsed : 1;	/* used by recvattach */  unsigned int attach_qualifies : 1;} BODY;typedef struct header{  unsigned int security : 11;  /* bit 0-6: flags, bit 7,8: application.				 see: crypt.h pgplib.h, smime.h */  unsigned int mime : 1;    		/* has a MIME-Version header? */  unsigned int flagged : 1; 		/* marked important? */  unsigned int tagged : 1;  unsigned int deleted : 1;  unsigned int changed : 1;  unsigned int attach_del : 1; 		/* has an attachment marked for deletion */  unsigned int old : 1;  unsigned int read : 1;  unsigned int expired : 1; 		/* already expired? */  unsigned int superseded : 1; 		/* got superseded? */  unsigned int replied : 1;  unsigned int subject_changed : 1; 	/* used for threading */  unsigned int threaded : 1;	    	/* used for threading */  unsigned int display_subject : 1; 	/* used for threading */  unsigned int recip_valid : 1;  	/* is_recipient is valid */  unsigned int active : 1;	    	/* message is not to be removed */  unsigned int trash : 1;		/* message is marked as trashed on disk.					 * This flag is used by the maildir_trash					 * option.					 */    /* timezone of the sender of this message */  unsigned int zhours : 5;  unsigned int zminutes : 6;  unsigned int zoccident : 1;  /* bits used for caching when searching */  unsigned int searched : 1;  unsigned int matched : 1;  /* tells whether the attachment count is valid */  unsigned int attach_valid : 1;  /* the following are used to support collapsing threads  */  unsigned int collapsed : 1; 	/* is this message part of a collapsed thread? */  unsigned int limited : 1;   	/* is this message in a limited view?  */  size_t num_hidden;          	/* number of hidden messages in this view */  short recipient;		/* user_is_recipient()'s return value, cached */    int pair; 			/* color-pair to use when displaying in the index */  time_t date_sent;     	/* time when the message was sent (UTC) */  time_t received;      	/* time when the message was placed in the mailbox */  LOFF_T offset;          	/* where in the stream does this message begin? */  int lines;			/* how many lines in the body of this message? */  int index;			/* the absolute (unsorted) message number */  int msgno;			/* number displayed to the user */  int virtual;			/* virtual message number */  int score;  ENVELOPE *env;		/* envelope information */  BODY *content;		/* list of MIME parts */  char *path;    char *tree;           	/* character string to print thread tree */  struct thread *thread;  /* Number of qualifying attachments in message, if attach_valid */  short attach_total;#ifdef MIXMASTER  LIST *chain;#endif#ifdef USE_POP  int refno;			/* message number on server */#endif#if defined USE_POP || defined USE_IMAP  void *data;            	/* driver-specific data */#endif    char *maildir_flags;		/* unknown maildir flags */} HEADER;typedef struct thread{  unsigned int fake_thread : 1;  unsigned int duplicate_thread : 1;  unsigned int sort_children : 1;  unsigned int check_subject : 1;  unsigned int visible : 1;  unsigned int deep : 1;  unsigned int subtree_visible : 2;  unsigned int next_subtree_visible : 1;  struct thread *parent;  struct thread *child;  struct thread *next;  struct thread *prev;  HEADER *message;  HEADER *sort_key;} THREAD;/* flag to mutt_pattern_comp() */#define M_FULL_MSG	(1<<0)	/* enable body and header matching */typedef enum {  M_MATCH_FULL_ADDRESS = 1} pattern_exec_flag;typedef struct group_t{  ADDRESS *as;  RX_LIST *rs;  char *name;} group_t;typedef struct group_context_t{  group_t *g;  struct group_context_t *next;} group_context_t;typedef struct pattern_t{  short op;  unsigned int not : 1;  unsigned int alladdr : 1;  unsigned int stringmatch : 1;  unsigned int groupmatch : 1;  int min;  int max;  struct pattern_t *next;  struct pattern_t *child;		/* arguments to logical op */  union   {    regex_t *rx;    group_t *g;    char *str;  } p;} pattern_t;typedef struct{  char *path;  FILE *fp;  time_t mtime;  time_t mtime_cur;		/* used with maildir folders */  off_t size;  off_t vsize;  char *pattern;                /* limit pattern string */  pattern_t *limit_pattern;     /* compiled limit pattern */  HEADER **hdrs;  HEADER *last_tag;		/* last tagged msg. used to link threads */  THREAD *tree;			/* top of thread tree */  HASH *id_hash;		/* hash table by msg id */  HASH *subj_hash;		/* hash table by subject */  HASH *thread_hash;		/* hash table for threading */  int *v2r;			/* mapping from virtual to real msgno */  int hdrmax;			/* number of pointers in hdrs */  int msgcount;			/* number of messages in the mailbox */  int vcount;			/* the number of virtual messages */  int tagged;			/* how many messages are tagged? */  int new;			/* how many new messages? */  int unread;			/* how many unread messages? */  int deleted;			/* how many deleted messages */  int flagged;			/* how many flagged messages */  int msgnotreadyet;		/* which msg "new" in pager, -1 if none */#if defined USE_POP || defined USE_IMAP  void *data;			/* driver specific data */#endif /* USE_IMAP */  short magic;			/* mailbox type */  unsigned int locked : 1;	/* is the mailbox locked? */  unsigned int changed : 1;	/* mailbox has been modified */  unsigned int readonly : 1;    /* don't allow changes to the mailbox */  unsigned int dontwrite : 1;   /* dont write the mailbox on close */  unsigned int append : 1;	/* mailbox is opened in append mode */  unsigned int quiet : 1;	/* inhibit status messages? */  unsigned int collapsed : 1;   /* are all threads collapsed? */  unsigned int closing : 1;	/* mailbox is being closed */} CONTEXT;typedef struct{  FILE *fpin;  FILE *fpout;  char *prefix;  int flags;} STATE;/* used by enter.c */typedef struct{  wchar_t *wbuf;  size_t wbuflen;  size_t lastchar;  size_t curpos;  size_t begin;  int	 tabs;} ENTER_STATE;/* flags for the STATE struct */#define M_DISPLAY	(1<<0) /* output is displayed to the user */#define M_VERIFY	(1<<1) /* perform signature verification */#define M_PENDINGPREFIX (1<<2) /* prefix to write, but character must follow */#define M_WEED          (1<<3) /* weed headers even when not in display mode */#define M_CHARCONV	(1<<4) /* Do character set conversions */#define M_PRINTING	(1<<5) /* are we printing? - M_DISPLAY "light" */#define M_REPLYING	(1<<6) /* are we replying? */#define M_FIRSTDONE	(1<<7) /* the first attachment has been done */#define state_set_prefix(s) ((s)->flags |= M_PENDINGPREFIX)#define state_reset_prefix(s) ((s)->flags &= ~M_PENDINGPREFIX)#define state_puts(x,y) fputs(x,(y)->fpout)#define state_putc(x,y) fputc(x,(y)->fpout)void state_mark_attach (STATE *);void state_attach_puts (const char *, STATE *);void state_prefix_putc (char, STATE *);int  state_printf(STATE *, const char *, ...);/* for attachment counter */typedef struct{  char   *major;  int     major_int;  char   *minor;  regex_t minor_rx;} ATTACH_MATCH;#define M_PARTS_TOPLEVEL	(1<<0)	/* is the top-level part */#include "ascii.h"#include "protos.h"#include "lib.h"#include "globals.h"#endif /*MUTT_H*/

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -