diff --git a/agent/ChangeLog b/agent/ChangeLog index 3c1aa54df..de911b9db 100644 --- a/agent/ChangeLog +++ b/agent/ChangeLog @@ -1,3 +1,9 @@ +2010-08-11 Werner Koch + + * call-scd.c (agent_card_scd): Pass assuan comment lines to the + caller. + (ASSUAN_CONVEY_COMMENTS): Provide replacement if needed. + 2010-05-12 Werner Koch * preset-passphrase.c (forget_passphrase): Actually implement diff --git a/agent/call-scd.c b/agent/call-scd.c index 93f1cf742..365c955f4 100644 --- a/agent/call-scd.c +++ b/agent/call-scd.c @@ -42,6 +42,15 @@ #define MAX_OPEN_FDS 20 #endif +/* This Assuan flag is only available since libassuan 2.0.2. Because + comments lines are comments anyway we can use a replacement which + might not do anything. assuan_{g,s}et_flag don't return an error + thus there won't be any ABI problem. */ +#ifndef ASSUAN_CONVEY_COMMENTS +#define ASSUAN_CONVEY_COMMENTS 4 +#endif + + /* Definition of module local data of the CTRL structure. */ struct scd_local_s { @@ -1129,6 +1138,7 @@ agent_card_scd (ctrl_t ctrl, const char *cmdline, { int rc; struct inq_needpin_s inqparm; + int saveflag; rc = start_scd (ctrl); if (rc) @@ -1138,10 +1148,13 @@ agent_card_scd (ctrl_t ctrl, const char *cmdline, inqparm.getpin_cb = getpin_cb; inqparm.getpin_cb_arg = getpin_cb_arg; inqparm.passthru = assuan_context; + saveflag = assuan_get_flag (ctrl->scd_local->ctx, ASSUAN_CONVEY_COMMENTS); + assuan_set_flag (ctrl->scd_local->ctx, ASSUAN_CONVEY_COMMENTS, 1); rc = assuan_transact (ctrl->scd_local->ctx, cmdline, pass_data_thru, assuan_context, inq_needpin, &inqparm, pass_status_thru, assuan_context); + assuan_set_flag (ctrl->scd_local->ctx, ASSUAN_CONVEY_COMMENTS, saveflag); if (rc) { return unlock_scd (ctrl, rc);