Welcome to mirror list, hosted at ThFree Co, Russian Federation.

cygwin.com/git/newlib-cygwin.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'winsup/cygwin/local_includes/select.h')
-rw-r--r--winsup/cygwin/local_includes/select.h135
1 files changed, 135 insertions, 0 deletions
diff --git a/winsup/cygwin/local_includes/select.h b/winsup/cygwin/local_includes/select.h
new file mode 100644
index 000000000..b794690b6
--- /dev/null
+++ b/winsup/cygwin/local_includes/select.h
@@ -0,0 +1,135 @@
+/* select.h
+
+This file is part of Cygwin.
+
+This software is a copyrighted work licensed under the terms of the
+Cygwin license. Please consult the file "CYGWIN_LICENSE" for
+details. */
+
+#ifndef _SELECT_H_
+#define _SELECT_H_
+
+struct fh_select_data_serial
+{
+ DWORD event;
+ OVERLAPPED ov;
+
+ fh_select_data_serial () : event (0) { memset (&ov, 0, sizeof ov); }
+};
+
+struct select_record
+{
+ int fd;
+ HANDLE h;
+ fhandler_base *fh;
+ _cygtls *tls;
+ int thread_errno;
+ bool windows_handle;
+ bool read_ready, write_ready, except_ready;
+ bool read_selected, write_selected, except_selected;
+ bool except_on_write;
+ int (*startup) (select_record *, class select_stuff *);
+ int (*peek) (select_record *, bool);
+ int (*verify) (select_record *, fd_set *, fd_set *, fd_set *);
+ void (*cleanup) (select_record *, class select_stuff *);
+ struct select_record *next;
+ /* If an fhandler type needs per-fhandler, per-select data, this union
+ is the place to add it. First candidate: fhandler_serial. */
+ union
+ {
+ fh_select_data_serial *fh_data_serial;
+ void *fh_data_union; /* type-agnostic placeholder for constructor */
+ };
+ void set_select_errno () {__seterrno (); thread_errno = errno;}
+ int saw_error () {return thread_errno;}
+ select_record (int): next (NULL) {}
+ select_record () :
+ fd (0), h (NULL), fh (NULL), tls (&_my_tls), thread_errno (0),
+ windows_handle (false), read_ready (false), write_ready (false),
+ except_ready (false), read_selected (false), write_selected (false),
+ except_selected (false), except_on_write (false),
+ startup (NULL), peek (NULL), verify (NULL), cleanup (NULL),
+ next (NULL), fh_data_union (NULL) {}
+#ifdef DEBUGGING
+ void dump_select_record ();
+#endif
+};
+
+struct select_info
+{
+ cygthread *thread;
+ bool stop_thread;
+ HANDLE bye;
+ select_record *start;
+ select_info (): thread (NULL), stop_thread (0), start (NULL) {}
+};
+
+struct select_console_info: public select_info
+{
+ select_console_info (): select_info () {}
+};
+
+struct select_pipe_info: public select_info
+{
+ select_pipe_info (): select_info () {}
+};
+
+struct select_fifo_info: public select_info
+{
+ select_fifo_info (): select_info () {}
+};
+
+struct select_socket_info: public select_info
+{
+ int num_w4;
+ LONG *ser_num;
+ HANDLE *w4;
+ select_socket_info (): select_info (), num_w4 (0), ser_num (0), w4 (NULL) {}
+};
+
+class select_stuff
+{
+public:
+ enum wait_states
+ {
+ select_signalled = -3,
+ select_error = -1,
+ select_ok = 0,
+ select_set_zero = 1
+ };
+
+ ~select_stuff ();
+ bool return_on_signal;
+ bool always_ready, windows_used;
+ select_record start;
+
+ /* If an fhandler type needs a singleton per-select datastructure for all
+ its objects in the descriptor lists, here's the place to be. This is
+ mainly used to maintain a single thread for all fhandlers of a single
+ type in the descriptor lists. */
+ select_console_info *device_specific_console;
+ select_pipe_info *device_specific_pipe;
+ select_pipe_info *device_specific_ptys;
+ select_fifo_info *device_specific_fifo;
+ select_socket_info *device_specific_socket;
+
+ bool test_and_set (int, fd_set *, fd_set *, fd_set *);
+ int poll (fd_set *, fd_set *, fd_set *);
+ wait_states wait (fd_set *, fd_set *, fd_set *, LONGLONG);
+ void cleanup ();
+ void destroy ();
+
+ select_stuff (): return_on_signal (false), always_ready (false),
+ windows_used (false), start (),
+ device_specific_console (NULL),
+ device_specific_pipe (NULL),
+ device_specific_ptys (NULL),
+ device_specific_fifo (NULL),
+ device_specific_socket (NULL)
+ {}
+};
+
+extern "C" int cygwin_select (int , fd_set *, fd_set *, fd_set *,
+ struct timeval *to);
+
+#endif /* _SELECT_H_ */