rbb 99/04/20 13:46:43
Modified: apr/file_io/unix Makefile
include apr_file_io.h
docs fileio.txt threadproc.txt
Added: apr/file_io/unix pipe.c
Log:
added create_pipe and create_namedpipe calls to apr. These are untested,
because I will be using the createprocess stuff to test them as soon as I
write
it. They do compile though.
Revision Changes Path
1.7 +2 -1 apache-apr/apr/file_io/unix/Makefile
Index: Makefile
===================================================================
RCS file: /home/cvs/apache-apr/apr/file_io/unix/Makefile,v
retrieving revision 1.6
retrieving revision 1.7
diff -u -r1.6 -r1.7
--- Makefile 1999/04/12 17:48:19 1.6
+++ Makefile 1999/04/20 20:46:40 1.7
@@ -48,7 +48,7 @@
LIB= libfile.a
OBJS= open.o readwrite.o filedup.o filestat.o seek.o dir.o\
- fileacc.o
+ fileacc.o pipe.o
.c.o:
$(CC) -c $(INCLUDES) $(CFLAGS) $<
@@ -89,3 +89,4 @@
seek.o: seek.c
dir.o: dir.c
fileacc.o: fileacc.c
+pipe.o: pipe.c
1.1 apache-apr/apr/file_io/unix/pipe.c
Index: pipe.c
===================================================================
/* ====================================================================
* Copyright (c) 1999 The Apache Group. All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
*
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
*
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in
* the documentation and/or other materials provided with the
* distribution.
*
* 3. All advertising materials mentioning features or use of this
* software must display the following acknowledgment:
* "This product includes software developed by the Apache Group
* for use in the Apache HTTP server project (http://www.apache.org/)."
*
* 4. The names "Apache Server" and "Apache Group" must not be used to
* endorse or promote products derived from this software without
* prior written permission. For written permission, please contact
* [EMAIL PROTECTED]
*
* 5. Products derived from this software may not be called "Apache"
* nor may "Apache" appear in their names without prior written
* permission of the Apache Group.
*
* 6. Redistributions of any form whatsoever must retain the following
* acknowledgment:
* "This product includes software developed by the Apache Group
* for use in the Apache HTTP server project (http://www.apache.org/)."
*
* THIS SOFTWARE IS PROVIDED BY THE APACHE GROUP ``AS IS'' AND ANY
* EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
* PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE APACHE GROUP OR
* ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
* NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
* STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
* OF THE POSSIBILITY OF SUCH DAMAGE.
* ====================================================================
*
* This software consists of voluntary contributions made by many
* individuals on behalf of the Apache Group.
* For more information on the Apache Group and the Apache HTTP server
* project, please see <http://www.apache.org/>.
*
*/
#include "apr_file_io.h"
#include "apr_general.h"
#include <errno.h>
#include <string.h>
#include <stdio.h>
#include <sys/types.h>
#include <sys/stat.h>
apr_status_t apr_create_pipe(apr_file_t *in, apr_file_t *out)
{
int filedes[2];
if (pipe(filedes) == -1) {
return APR_FAILURE;
}
in->filedes = filedes[0];
in->fname = strdup("PIPE");
out->filedes = filedes[1];
out->fname = strdup("PIPE");
return APR_SUCCESS;
}
char *apr_create_namedpipe(char *dirpath, apr_fileperms_t mode)
{
char *tmp;
tmp = tempnam(dirpath, NULL);
if (mkfifo(tmp, mode) == -1) {
free(tmp);
return NULL;
}
return tmp;
}
1.16 +3 -0 apache-apr/include/apr_file_io.h
Index: apr_file_io.h
===================================================================
RCS file: /home/cvs/apache-apr/include/apr_file_io.h,v
retrieving revision 1.15
retrieving revision 1.16
diff -u -r1.15 -r1.16
--- apr_file_io.h 1999/04/12 17:50:43 1.15
+++ apr_file_io.h 1999/04/20 20:46:42 1.16
@@ -126,6 +126,9 @@
apr_status_t apr_make_dir(const char *, apr_fileperms_t);
apr_status_t apr_remove_dir(const char *);
+apr_status_t apr_create_pipe(apr_file_t *, apr_file_t *);
+char *apr_create_namedpipe(char *, apr_fileperms_t);
+
/*accessor and general file_io functions. */
apr_status_t apr_valid_file(apr_file_t *);
char *apr_get_filename(apr_file_t *);
1.14 +20 -0 apache-apr/docs/fileio.txt
Index: fileio.txt
===================================================================
RCS file: /home/cvs/apache-apr/docs/fileio.txt,v
retrieving revision 1.13
retrieving revision 1.14
diff -u -r1.13 -r1.14
--- fileio.txt 1999/04/12 18:54:48 1.13
+++ fileio.txt 1999/04/20 20:46:43 1.14
@@ -166,7 +166,27 @@
arg 1) File to get the name of
return) filename. NULL on failure
+ apr_status_t apr_create_pipe(apr_file_t *, apr_file_t *)
+ create an unnamed pipe
+ Arguments:
+ arg 1) File for reading from the pipe.
+ arg 2) File for writing to the pipe.
+ return) APR_SUCCESS or APR_FAILURE
+NOTE: Unnamed pipes are ALWAYS inherited by any child process created by the
+ process which created the pipes. If the platform is storing the file
+ name internally in apr, for pipes, this should be set to "PIPE" all
in
+ caps. This allows the program to easily determine what is a pipe,
and
+ what isn't. All other fields are left to the individual platform to
+ set appropriately.
+char *apr_create_namedpipe(char *, apr_fileperms_t)
+ create a uniquely named pipe in the temp directory.
+ Arguments:
+ arg 1) The directory to create the named pipe in. Can BE NULL!
+ arg 2) The permissions for the named pipe.
+ return) The name of the newly created pipe. (fully defined path)
+NOTE: If directory name is NULL, the platform decides where it is best to
put
+ the pipe. To get it in the current dir, use "." here :)
**************** IMPLEMENTATION DETAILS **************
1.2 +2 -3 apache-apr/docs/threadproc.txt
Index: threadproc.txt
===================================================================
RCS file: /home/cvs/apache-apr/docs/threadproc.txt,v
retrieving revision 1.1
retrieving revision 1.2
diff -u -r1.1 -r1.2
--- threadproc.txt 1999/04/20 15:12:27 1.1
+++ threadproc.txt 1999/04/20 20:46:43 1.2
@@ -22,11 +22,10 @@
to produce this function should define it as NULL, so that there are
no compile time errors.
-apr_status_t apr_createprocattr_init(apr_procattr_t *);
+apr_procattr_t *apr_createprocattr_init(void);
create a new process attr type with OS dependant defaults
Arguments:
- arg 1) New process attribute type.
- return) APR_SUCCESS or APR_FAILURE.
+ return) New process attribute type.
apr_status_t apr_setprocattr_io(apr_procattr_t *, apr_int32_t, apr_int32_t,
apr_int32_t)
setup stdin, stdout, and stderr attributes for the new proc