Forgot to commit this:
[gnupg.git] / g10 / mdfilter.c
index 5a77c90..d6ccace 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, 1999, 2000, 2001 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,22 +42,17 @@ 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;
-       }
-
+       i = iobuf_read( a, buf, size );
+       if( i == -1 ) i = 0;
        if( i ) {
-           if( mfx->md5 )
-               md5_write(mfx->md5, buf, i );
-           if( mfx->rmd160 )
-               rmd160_write(mfx->rmd160, buf, i );
+           md_write(mfx->md, buf, i );
+           if( mfx->md2 )
+               md_write(mfx->md2, buf, i );
        }
        else
            rc = -1; /* eof */
@@ -72,12 +67,10 @@ md_filter( void *opaque, int control,
 void
 free_md_filter_context( md_filter_context_t *mfx )
 {
-    if( mfx->md5 )
-       md5_close(mfx->md5);
-    mfx->md5 = NULL;
-    if( mfx->rmd160 )
-       rmd160_close(mfx->rmd160);
-    mfx->rmd160 = NULL;
+    md_close(mfx->md);
+    md_close(mfx->md2);
+    mfx->md = NULL;
+    mfx->md2 = NULL;
     mfx->maxbuf_size = 0;
 }