gpg: Prepare for listing last_update and key origin data.
[gnupg.git] / g10 / mdfilter.c
index 5a77c90..f3318f1 100644 (file)
@@ -1,21 +1,20 @@
 /* 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
+ * the Free Software Foundation; either version 3 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.
  *
  * You should have received a copy of the GNU General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
+ * along with this program; if not, see <https://www.gnu.org/licenses/>.
  */
 
 #include <config.h>
 #include <stdlib.h>
 #include <string.h>
 #include <errno.h>
-#include <assert.h>
 
-#include "errors.h"
-#include "iobuf.h"
-#include "memory.h"
-#include "util.h"
+#include "gpg.h"
+#include "../common/status.h"
+#include "../common/iobuf.h"
+#include "../common/util.h"
 #include "filter.h"
 
 
 
 /****************
- * 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,29 +40,24 @@ 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 );
+           gcry_md_write(mfx->md, buf, i );
+           if( mfx->md2 )
+               gcry_md_write(mfx->md2, buf, i );
        }
        else
            rc = -1; /* eof */
        *ret_len = i;
     }
     else if( control == IOBUFCTRL_DESC )
-       *(char**)buf = "md_filter";
+        mem2str (buf, "md_filter", *ret_len);
     return rc;
 }
 
@@ -72,12 +65,9 @@ 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;
+    gcry_md_close(mfx->md);
+    gcry_md_close(mfx->md2);
+    mfx->md = NULL;
+    mfx->md2 = NULL;
     mfx->maxbuf_size = 0;
 }
-