[Pkg-gnupg-commit] [libassuan] 29/437: * assuan-listen.c (assuan_close_input_fd): New. (assuan_close_output_fd): New. * assuan-handler.c (std_handler_reset): Always close them after a reset command. (std_handler_bye): Likewise.

Eric Dorland eric at moszumanska.debian.org
Fri May 22 05:33:19 UTC 2015


This is an automated email from the git hooks/post-receive script.

eric pushed a commit to branch master
in repository libassuan.

commit cfe7ddef47bd2707798e6ca417fbcbb6e7e2f927
Author: Werner Koch <wk at gnupg.org>
Date:   Fri Dec 14 19:35:56 2001 +0000

    * assuan-listen.c (assuan_close_input_fd): New.
    (assuan_close_output_fd): New.
    * assuan-handler.c (std_handler_reset): Always close them after a
    reset command.
    (std_handler_bye): Likewise.
---
 src/ChangeLog        |  8 ++++++++
 src/assuan-handler.c |  4 ++++
 src/assuan-listen.c  | 26 ++++++++++++++++++++++++++
 src/assuan.h         |  2 ++
 4 files changed, 40 insertions(+)

diff --git a/src/ChangeLog b/src/ChangeLog
index 5ccba92..f85e220 100644
--- a/src/ChangeLog
+++ b/src/ChangeLog
@@ -1,3 +1,11 @@
+2001-12-14  Werner Koch  <wk at gnupg.org>
+
+	* assuan-listen.c (assuan_close_input_fd): New.
+	(assuan_close_output_fd): New.
+	* assuan-handler.c (std_handler_reset): Always close them after a
+	reset command.
+	(std_handler_bye): Likewise.
+
 2001-12-14  Marcus Brinkmann  <marcus at g10code.de>
 
 	* assuan-buffer.c (_assuan_read_line): New variable ATTICLEN, use
diff --git a/src/assuan-handler.c b/src/assuan-handler.c
index 8ec8b23..a82bd53 100644
--- a/src/assuan-handler.c
+++ b/src/assuan-handler.c
@@ -54,6 +54,8 @@ std_handler_bye (ASSUAN_CONTEXT ctx, char *line)
 {
   if (ctx->bye_notify_fnc)
     ctx->bye_notify_fnc (ctx);
+  assuan_close_input_fd (ctx);
+  assuan_close_output_fd (ctx);
   return -1; /* pretty simple :-) */
 }
   
@@ -68,6 +70,8 @@ std_handler_reset (ASSUAN_CONTEXT ctx, char *line)
 {
   if (ctx->reset_notify_fnc)
     ctx->reset_notify_fnc (ctx);
+  assuan_close_input_fd (ctx);
+  assuan_close_output_fd (ctx);
   return 0;
 }
   
diff --git a/src/assuan-listen.c b/src/assuan-listen.c
index 822ef32..57fe4b6 100644
--- a/src/assuan-listen.c
+++ b/src/assuan-listen.c
@@ -22,6 +22,7 @@
 #include <stdlib.h>
 #include <stdio.h>
 #include <string.h>
+#include <unistd.h>
 
 #include "assuan-defs.h"
 
@@ -106,3 +107,28 @@ assuan_get_output_fd (ASSUAN_CONTEXT ctx)
 }
 
 
+/* Close the fd descriptor set by the command INPUT FD=n.  We handle
+   this fd inside assuan so that we can do some initial checks */
+AssuanError
+assuan_close_input_fd (ASSUAN_CONTEXT ctx)
+{
+  if (!ctx || ctx->input_fd == -1)
+    return ASSUAN_Invalid_Value;
+  close (ctx->input_fd);
+  ctx->input_fd = -1;
+  return 0;
+}
+
+/* Close the fd descriptor set by the command OUTPUT FD=n.  We handle
+   this fd inside assuan so that we can do some initial checks */
+AssuanError
+assuan_close_output_fd (ASSUAN_CONTEXT ctx)
+{
+  if (!ctx || ctx->output_fd == -1)
+    return ASSUAN_Invalid_Value;
+
+  close (ctx->output_fd);
+  ctx->output_fd = -1;
+  return 0;
+}
+
diff --git a/src/assuan.h b/src/assuan.h
index 485ad22..a4f887f 100644
--- a/src/assuan.h
+++ b/src/assuan.h
@@ -136,6 +136,8 @@ AssuanError assuan_set_hello_line (ASSUAN_CONTEXT ctx, const char *line);
 AssuanError assuan_accept (ASSUAN_CONTEXT ctx);
 int assuan_get_input_fd (ASSUAN_CONTEXT ctx);
 int assuan_get_output_fd (ASSUAN_CONTEXT ctx);
+AssuanError assuan_close_input_fd (ASSUAN_CONTEXT ctx);
+AssuanError assuan_close_output_fd (ASSUAN_CONTEXT ctx);
 
 
 /*-- assuan-pipe-server.c --*/

-- 
Alioth's /usr/local/bin/git-commit-notice on /srv/git.debian.org/git/pkg-gnupg/libassuan.git



More information about the Pkg-gnupg-commit mailing list