diff options
| author | Justus Winter <[email protected]> | 2016-05-10 11:03:34 +0000 | 
|---|---|---|
| committer | Justus Winter <[email protected]> | 2016-05-10 11:03:34 +0000 | 
| commit | f531608539b45f0bbd036f430943b390ec21aa65 (patch) | |
| tree | 56cf3f4db0c38e668645668ebb3dec418bed77a5 /src/passwd.c | |
| parent | More GTK2 removal (diff) | |
| parent | Allow cc to detect missing cases in a switch. (diff) | |
| download | gpgme-f531608539b45f0bbd036f430943b390ec21aa65.tar.gz gpgme-f531608539b45f0bbd036f430943b390ec21aa65.zip | |
Merge branch 'master' into justus/pyme3
Diffstat (limited to 'src/passwd.c')
| -rw-r--r-- | src/passwd.c | 17 | 
1 files changed, 17 insertions, 0 deletions
| diff --git a/src/passwd.c b/src/passwd.c index e832026d..c34f3577 100644 --- a/src/passwd.c +++ b/src/passwd.c @@ -30,6 +30,9 @@  typedef struct  { +  /* The error code from a FAILURE status line or 0.  */ +  gpg_error_t failure_code; +    int success_seen;    int error_seen;  } *op_data_t; @@ -92,6 +95,10 @@ passwd_status_handler (void *priv, gpgme_status_code_t code, char *args)        opd->success_seen = 1;        break; +    case GPGME_STATUS_FAILURE: +      opd->failure_code = _gpgme_parse_failure (args); +      break; +      case GPGME_STATUS_EOF:        /* In case the OpenPGP engine does not properly implement the           passwd command we won't get a success status back and thus we @@ -102,6 +109,8 @@ passwd_status_handler (void *priv, gpgme_status_code_t code, char *args)        if (ctx->protocol == GPGME_PROTOCOL_OpenPGP            && !opd->error_seen && !opd->success_seen)          err = gpg_error (GPG_ERR_NOT_SUPPORTED); +      else if (opd->failure_code) +        err = opd->failure_code;        break;      default: @@ -139,6 +148,14 @@ passwd_start (gpgme_ctx_t ctx, int synchronous, gpgme_key_t key,    _gpgme_engine_set_status_handler (ctx->engine, passwd_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_passwd (ctx->engine, key, flags);  } | 
