See ChangeLog: Wed Sep 15 16:22:17 CEST 1999 Werner Koch
[gnupg.git] / g10 / mdfilter.c
index 17cf259..951fd73 100644 (file)
@@ -1,14 +1,14 @@
 /* mdfilter.c - filter data and calculate a message digest
- *     Copyright (c) 1997 by Werner Koch (dd9jn)
+ *     Copyright (C) 1998 Free Software Foundation, Inc.
  *
- * This file is part of G10.
+ * This file is part of GnuPG.
  *
- * G10 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.
  *
- * G10 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.
@@ -34,7 +34,7 @@
 
 
 /****************
- * The filter is used to collect a message digest
+ * This filter is used to collect a message digest
  */
 int
 md_filter( void *opaque, int control,
@@ -42,19 +42,18 @@ md_filter( void *opaque, int control,
 {
     size_t size = *ret_len;
     md_filter_context_t *mfx = opaque;
-    int i, c, rc=0;
+    int i, rc=0;
 
     if( control == IOBUFCTRL_UNDERFLOW ) {
        if( mfx->maxbuf_size && size > mfx->maxbuf_size )
            size = mfx->maxbuf_size;
-       for(i=0; i < size; i++ ) {
-           if( (c = iobuf_get(a)) == -1 )
-               break;
-           buf[i] = c;
-       }
-
-       if( i )
+       i = iobuf_read( a, buf, size );
+       if( i == -1 ) i = 0;
+       if( i ) {
            md_write(mfx->md, buf, i );
+           if( mfx->md2 )
+               md_write(mfx->md2, buf, i );
+       }
        else
            rc = -1; /* eof */
        *ret_len = i;
@@ -69,7 +68,9 @@ void
 free_md_filter_context( md_filter_context_t *mfx )
 {
     md_close(mfx->md);
+    md_close(mfx->md2);
     mfx->md = NULL;
+    mfx->md2 = NULL;
     mfx->maxbuf_size = 0;
 }