diff options
| author | Marcus Brinkmann <[email protected]> | 2004-09-23 19:23:33 +0000 | 
|---|---|---|
| committer | Marcus Brinkmann <[email protected]> | 2004-09-23 19:23:33 +0000 | 
| commit | 7bfcd45c9fde613409db28e189412ce14be2badc (patch) | |
| tree | 90b993a59f1dac2ad03c05c3ad44e29abf3485b7 | |
| parent | 2004-09-23 Marcus Brinkmann <[email protected]> (diff) | |
| download | gpgme-7bfcd45c9fde613409db28e189412ce14be2badc.tar.gz gpgme-7bfcd45c9fde613409db28e189412ce14be2badc.zip | |
2004-09-23  Marcus Brinkmann  <[email protected]>
	* data.c (_gpgme_data_outbound_handler): Close the file descriptor
	if we get an EPIPE.
Diffstat (limited to '')
| -rw-r--r-- | gpgme/ChangeLog | 4 | ||||
| -rw-r--r-- | gpgme/data.c | 12 | 
2 files changed, 15 insertions, 1 deletions
| diff --git a/gpgme/ChangeLog b/gpgme/ChangeLog index 039b197e..57177e8f 100644 --- a/gpgme/ChangeLog +++ b/gpgme/ChangeLog @@ -1,5 +1,8 @@  2004-09-23  Marcus Brinkmann  <[email protected]> +	* data.c (_gpgme_data_outbound_handler): Close the file descriptor +	if we get an EPIPE. +	  	* data-stream.c (stream_seek): Call ftello and return the current  	offset.  	* data.h (struct gpgme_data): Change type of data.mem.offset to @@ -8,6 +11,7 @@  	callback.  If SEEK_CUR, adjust the offset by the pending buffer  	size.  Clear pending buffer on success. +  2004-09-14  Marcus Brinkmann  <[email protected]>  	* gpgme.m4: Add copyright notice. diff --git a/gpgme/data.c b/gpgme/data.c index aba1986b..e4e13a3e 100644 --- a/gpgme/data.c +++ b/gpgme/data.c @@ -219,9 +219,19 @@ _gpgme_data_outbound_handler (void *opaque, int fd)      }    nwritten = _gpgme_io_write (fd, dh->pending, dh->pending_len); -  if (nwritten == -1 && errno == EAGAIN ) +  if (nwritten == -1 && errno == EAGAIN)      return 0; +  if (nwritten == -1 && errno == EPIPE) +    { +      /* Not much we can do.  The other end closed the pipe, but we +	 still have data.  This should only ever happen if the other +	 end is going to tell us what happened on some other channel. +	 Silently close our end.  */ +      _gpgme_io_close (fd); +      return 0; +    } +    if (nwritten <= 0)      return gpg_error_from_errno (errno); | 
