From: Bruno Haible Date: Mon, 21 Apr 2008 21:47:45 +0000 (+0200) Subject: Port to native Windows platforms. X-Git-Url: https://pintos-os.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=f908ffa5808d84915d960bc4817a44b66d49719b;p=pspp Port to native Windows platforms. --- diff --git a/ChangeLog b/ChangeLog index 2be1c539e9..e7d624b473 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,7 @@ +2008-04-20 Bruno Haible + + * lib/isapipe.c: Port to native Windows platforms. + 2008-04-20 Bruno Haible * lib/gc-gnulib.c: Include before . diff --git a/lib/isapipe.c b/lib/isapipe.c index e71dc2b29d..495cba6a6a 100644 --- a/lib/isapipe.c +++ b/lib/isapipe.c @@ -1,6 +1,6 @@ /* Test whether a file descriptor is a pipe. - Copyright (C) 2006 Free Software Foundation, Inc. + Copyright (C) 2006, 2008 Free Software Foundation, Inc. This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -22,15 +22,42 @@ #include "isapipe.h" #include -#include -#include -#include -#include + +#if (defined _WIN32 || defined __WIN32__) && ! defined __CYGWIN__ +/* Windows platforms. */ + +/* Get _get_osfhandle. */ +# include + +/* Get GetFileType. */ +# include + +int +isapipe (int fd) +{ + HANDLE h = (HANDLE) _get_osfhandle (fd); + + if (h == INVALID_HANDLE_VALUE) + { + errno = EBADF; + return -1; + } + + return (GetFileType (h) == FILE_TYPE_PIPE); +} + +#else +/* Unix platforms. */ + +# include +# include +# include +# include /* The maximum link count for pipes; (nlink_t) -1 if not known. */ -#ifndef PIPE_LINK_COUNT_MAX -# define PIPE_LINK_COUNT_MAX ((nlink_t) (-1)) -#endif +# ifndef PIPE_LINK_COUNT_MAX +# define PIPE_LINK_COUNT_MAX ((nlink_t) (-1)) +# endif /* Return 1 if FD is a pipe, 0 if not, -1 (setting errno) on error. @@ -88,3 +115,5 @@ isapipe (int fd) (st.st_nlink <= pipe_link_count_max && (check_for_fifo ? S_ISFIFO (st.st_mode) : S_ISSOCK (st.st_mode))); } + +#endif