diff options
Diffstat (limited to 'src/genkey.c')
| -rw-r--r-- | src/genkey.c | 26 | 
1 files changed, 26 insertions, 0 deletions
| diff --git a/src/genkey.c b/src/genkey.c index fd6685ef..3afd3b41 100644 --- a/src/genkey.c +++ b/src/genkey.c @@ -37,6 +37,9 @@ typedef struct  {    struct _gpgme_op_genkey_result result; +  /* The error code from a FAILURE status line or 0.  */ +  gpg_error_t failure_code; +    /* The key parameters passed to the crypto engine.  */    gpgme_data_t key_parameter;  } *op_data_t; @@ -118,10 +121,25 @@ genkey_status_handler (void *priv, gpgme_status_code_t code, char *args)  	}        break; +    case GPGME_STATUS_FAILURE: +      opd->failure_code = _gpgme_parse_failure (args); +      break; +      case GPGME_STATUS_EOF:        /* FIXME: Should return some more useful error value.  */        if (!opd->result.primary && !opd->result.sub)  	return gpg_error (GPG_ERR_GENERAL); +      else if (opd->failure_code) +        return opd->failure_code; +      break; + +    case GPGME_STATUS_INQUIRE_MAXLEN: +      if (ctx->status_cb) +        { +          err = ctx->status_cb (ctx->status_cb_value, "INQUIRE_MAXLEN", args); +          if (err) +            return err; +        }        break;      default: @@ -186,6 +204,14 @@ genkey_start (gpgme_ctx_t ctx, int synchronous, const char *parms,    _gpgme_engine_set_status_handler (ctx->engine, genkey_status_handler, ctx); +  if (ctx->passphrase_cb) +    { +      err = _gpgme_engine_set_command_handler +        (ctx->engine, _gpgme_passphrase_command_handler, ctx, NULL); +      if (err) +        return err; +    } +    return _gpgme_engine_op_genkey (ctx->engine, opd->key_parameter,  				  ctx->use_armor, pubkey, seckey);  } | 
