diff options
| author | Marcus Brinkmann <[email protected]> | 2008-11-03 17:24:09 +0000 | 
|---|---|---|
| committer | Marcus Brinkmann <[email protected]> | 2008-11-03 17:24:09 +0000 | 
| commit | 66d0fa1973e5e1a1bff619de8b595673d1b76cc5 (patch) | |
| tree | 4b1f8e470fa455cbe3d9b5c4ab6fb4fa77f20ba3 /src/wait-private.c | |
| parent | assuan/ (diff) | |
| download | gpgme-66d0fa1973e5e1a1bff619de8b595673d1b76cc5.tar.gz gpgme-66d0fa1973e5e1a1bff619de8b595673d1b76cc5.zip | |
008-11-03  Marcus Brinkmann  <[email protected]>
        * configure.ac: Replace gpgme paths with src.
        * gpgme: Move to ...
        * src: ... this new directory.
assuan/
2008-11-03  Marcus Brinkmann  <[email protected]>
	* Makefile.am (INCLUDES): Replace gpgme path with src.
tests/
2008-11-03  Marcus Brinkmann  <[email protected]>
        * gpgsm/Makefile.am (INCLUDES, LDADD): Replace gpgme path with src.
        * gpg/Makefile.am (INCLUDES, LDADD, t_thread1_LDADD): Likewise.
	* Makefile.am (LDADD): Likewise.
Diffstat (limited to 'src/wait-private.c')
| -rw-r--r-- | src/wait-private.c | 144 | 
1 files changed, 144 insertions, 0 deletions
| diff --git a/src/wait-private.c b/src/wait-private.c new file mode 100644 index 00000000..2dee1a93 --- /dev/null +++ b/src/wait-private.c @@ -0,0 +1,144 @@ +/* wait-private.c  +   Copyright (C) 2000 Werner Koch (dd9jn) +   Copyright (C) 2001, 2002, 2003, 2004, 2005 g10 Code GmbH +  +   This file is part of GPGME. +  +   GPGME is free software; you can redistribute it and/or modify it +   under the terms of the GNU Lesser General Public License as +   published by the Free Software Foundation; either version 2.1 of +   the License, or (at your option) any later version. +    +   GPGME 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 +   Lesser General Public License for more details. +    +   You should have received a copy of the GNU Lesser 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.  */ + +#if HAVE_CONFIG_H +#include <config.h> +#endif +#include <assert.h> +#include <errno.h> + +#include "gpgme.h" +#include "context.h" +#include "wait.h" +#include "ops.h" +#include "priv-io.h" +#include "util.h" + + +/* The private event loops are used for all blocking operations, and +   for the key and trust item listing operations.  They are completely +   separated from each other.  */ + + +/* Internal I/O callback functions.  */ + +/* The add_io_cb and remove_io_cb handlers are shared with the global +   event loops.  */ + +void +_gpgme_wait_private_event_cb (void *data, gpgme_event_io_t type, +			      void *type_data) +{ +  switch (type) +    { +    case GPGME_EVENT_START: +      /* Nothing to do here, as the wait routine is called after the +	 initialization is finished.  */ +      break; + +    case GPGME_EVENT_DONE: +      break; + +    case GPGME_EVENT_NEXT_KEY: +      _gpgme_op_keylist_event_cb (data, type, type_data); +      break; + +    case GPGME_EVENT_NEXT_TRUSTITEM: +      _gpgme_op_trustlist_event_cb (data, type, type_data); +      break; +    } +} + + +/* If COND is a null pointer, wait until the blocking operation in CTX +   finished and return its error value.  Otherwise, wait until COND is +   satisfied or the operation finished.  */ +gpgme_error_t +_gpgme_wait_on_condition (gpgme_ctx_t ctx, volatile int *cond) +{ +  gpgme_error_t err = 0; +  int hang = 1; + +  do +    { +      int nr = _gpgme_io_select (ctx->fdt.fds, ctx->fdt.size, 0); +      unsigned int i; + +      if (nr < 0) +	{ +	  /* An error occured.  Close all fds in this context, and +	     signal it.  */ +	  err = gpg_error_from_errno (errno); +          _gpgme_cancel_with_err (ctx, err); + +	  return err; +	} +       +      for (i = 0; i < ctx->fdt.size && nr; i++) +	{ +	  if (ctx->fdt.fds[i].fd != -1 && ctx->fdt.fds[i].signaled) +	    { +	      ctx->fdt.fds[i].signaled = 0; +	      assert (nr); +	      nr--; + +	      LOCK (ctx->lock); +	      if (ctx->canceled) +		err = gpg_error (GPG_ERR_CANCELED); +	      UNLOCK (ctx->lock); +	       +	      if (!err) +		err = _gpgme_run_io_cb (&ctx->fdt.fds[i], 0); +	      if (err) +		{ +		  /* An error occured.  Close all fds in this context, +		     and signal it.  */ +		  _gpgme_cancel_with_err (ctx, err); + +		  return err; +		} +	    } +	} + +      for (i = 0; i < ctx->fdt.size; i++) +	if (ctx->fdt.fds[i].fd != -1) +	  break; +      if (i == ctx->fdt.size) +	{ +	  _gpgme_engine_io_event (ctx->engine, GPGME_EVENT_DONE, &err); +	  hang = 0; +	} +      if (cond && *cond) +	hang = 0; +    } +  while (hang); + +  return 0; +} + + +/* Wait until the blocking operation in context CTX has finished and +   return the error value.  */ +gpgme_error_t +_gpgme_wait_one (gpgme_ctx_t ctx) +{ +  return _gpgme_wait_on_condition (ctx, NULL); +} | 
