From: Marcus Brinkmann Date: Tue, 25 Jun 2002 11:14:44 +0000 (+0000) Subject: 2002-06-25 Marcus Brinkmann X-Git-Tag: gpgme-0-3-8~7 X-Git-Url: http://git.tremily.us/?a=commitdiff_plain;h=ea042a1fa9a2909a32ced5b0773216e745fcf927;p=gpgme.git 2002-06-25 Marcus Brinkmann * engine-gpgsm.c (_gpgme_gpgsm_op_export): Implement. --- diff --git a/gpgme/ChangeLog b/gpgme/ChangeLog index b896650..cd73a3e 100644 --- a/gpgme/ChangeLog +++ b/gpgme/ChangeLog @@ -1,3 +1,7 @@ +2002-06-25 Marcus Brinkmann + + * engine-gpgsm.c (_gpgme_gpgsm_op_export): Implement. + 2002-06-21 Marcus Brinkmann * engine-gpgsm.c (gpgsm_assuan_simple_command): Return ERR. diff --git a/gpgme/engine-gpgsm.c b/gpgme/engine-gpgsm.c index 7e26f0d..6115b25 100644 --- a/gpgme/engine-gpgsm.c +++ b/gpgme/engine-gpgsm.c @@ -759,8 +759,24 @@ GpgmeError _gpgme_gpgsm_op_export (GpgsmObject gpgsm, GpgmeRecipients recp, GpgmeData keydata, int use_armor) { - /* FIXME */ - return mk_error (Not_Implemented); + GpgmeError err; + + if (!gpgsm) + return mk_error (Invalid_Value); + + gpgsm->command = xtrystrdup ("EXPORT"); + if (!gpgsm->command) + return mk_error (Out_Of_Core); + + gpgsm->output_cb.data = keydata; + err = gpgsm_set_fd (gpgsm->assuan_ctx, "OUTPUT", gpgsm->output_fd_server, + use_armor ? "--armor" : 0); + if (err) + return err; + _gpgme_io_close (gpgsm->input_cb.fd); + _gpgme_io_close (gpgsm->message_cb.fd); + + return 0; }