See ChangeLog: Sat Sep 18 12:16:08 CEST 1999 Werner Koch
[gnupg.git] / g10 / filter.h
index f4d9249..02e4e2e 100644 (file)
@@ -1,14 +1,14 @@
 /* filter.h
  *     Copyright (C) 1998 Free Software Foundation, Inc.
  *
- * This file is part of GNUPG.
+ * This file is part of GnuPG.
  *
- * GNUPG is free software; you can redistribute it and/or modify
+ * GnuPG is free software; you can redistribute it and/or modify
  * it under the terms of the GNU General Public License as published by
  * the Free Software Foundation; either version 2 of the License, or
  * (at your option) any later version.
  *
- * GNUPG is distributed in the hope that it will be useful,
+ * GnuPG is distributed in the hope that it will be useful,
  * but WITHOUT ANY WARRANTY; without even the implied warranty of
  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  * GNU General Public License for more details.
 #ifndef G10_FILTER_H
 #define G10_FILTER_H
 
+#include <gcrypt.h>
+
 #include "types.h"
-#include "cipher.h"
 
 typedef struct {
-    MD_HANDLE md;      /* catch all */
+    GCRY_MD_HD md;     /* catch all */
+    GCRY_MD_HD md2;    /* if we want to calculate an alternate hash */
     size_t maxbuf_size;
 } md_filter_context_t;
 
 typedef struct {
-    int status;
-    int what;
-    int only_keyblocks;  /* skip all headers but ".... key block" */
+    /* these fields may be initialized */
+    int what;              /* what kind of armor headers to write */
+    int only_keyblocks;     /* skip all headers but ".... key block" */
+    const char *hdrlines;   /* write these headerlines */
+
+    /* the following fields must be initialized to zero */
+    int inp_checked;       /* set if the input has been checked */
+    int inp_bypass;        /* set if the input is not armored */
+    int in_cleartext;      /* clear text message */
+    int not_dash_escaped;   /* clear text is not dash escaped */
+    int hashes;            /* detected hash algorithms */
+    int faked;             /* we are faking a literal data packet */
+    int truncated;         /* number of truncated lines */
+    int qp_detected;
+    int pgp2mode;
+
+    byte *buffer;          /* malloced buffer */
+    unsigned buffer_size;   /* and size of this buffer */
+    unsigned buffer_len;    /* used length of the buffer */
+    unsigned buffer_pos;    /* read position */
+
     byte radbuf[4];
-    int  idx, idx2;
+    int idx, idx2;
     u32 crc;
-    byte helpbuf[100];
-    int  helpidx, helplen;
-    unsigned empty;    /* empty line counter */
-    int hashes;        /* detected hash algorithms */
-    int faked;
-    int parse_state;
-    int inp_checked;   /* set if inp has been checked */
-    int inp_bypass;    /* set if the input is not armored */
-    int any_data;
-    const char *hdrlines;
-    int not_dash_escaped;
+
+    int status;            /* an internal state flag */
+    int any_data;          /* any valid armored data seen */
+    int pending_lf;        /* used together with faked */
 } armor_filter_context_t;
 
 
@@ -57,23 +70,31 @@ typedef struct {
     byte *outbuf;
     unsigned outbufsize;
     int algo;   /* compress algo */
+    int algo1hack;
 } compress_filter_context_t;
 
 
 typedef struct {
     DEK *dek;
     u32 datalen;
-    CIPHER_HANDLE cipher_hd;
+    GCRY_CIPHER_HD cipher_hd;
     int header;
+    GCRY_MD_HD mdc_hash;
 } cipher_filter_context_t;
 
 
 
 typedef struct {
-    int eof;
-    size_t idx;
-    size_t len;
-    byte buf[256];
+    byte *buffer;          /* malloced buffer */
+    unsigned buffer_size;   /* and size of this buffer */
+    unsigned buffer_len;    /* used length of the buffer */
+    unsigned buffer_pos;    /* read position */
+    int truncated;         /* number of truncated lines */
+    int not_dash_escaped;
+    int escape_from;
+    GCRY_MD_HD md;
+    int pending_lf;
+    int pending_esc;
 } text_filter_context_t;
 
 
@@ -99,6 +120,8 @@ int cipher_filter( void *opaque, int control,
 /*-- textfilter.c --*/
 int text_filter( void *opaque, int control,
                 IOBUF chain, byte *buf, size_t *ret_len);
+int copy_clearsig_text( IOBUF out, IOBUF inp, GCRY_MD_HD md,
+                         int escape_dash, int escape_from, int pgp2mode );