]> sjero.net Git - wget/blobdiff - src/connect.h
[svn] Remove K&R support.
[wget] / src / connect.h
index 8b0ed4b31d57605e8ac9ed87248fb7bb877a4fb6..69d68cb0e630de04a37b37e95948a5563df8d627 100644 (file)
@@ -32,41 +32,45 @@ so, delete this exception statement from your version.  */
 
 #include "host.h"              /* for definition of ip_address */
 
+/* Function declarations */
+
 /* Returned by connect_to_host when host name cannot be resolved.  */
 enum {
   E_HOST = -100
 };
+int connect_to_host (const char *, int);
+int connect_to_ip (const ip_address *, int, const char *);
+
+int bind_local (const ip_address *, int *);
+int accept_connection (int);
 
-/* Flags for select_fd's WAIT argument. */
 enum {
-  WAIT_READ = 1,
-  WAIT_WRITE = 2
+  ENDPOINT_LOCAL,
+  ENDPOINT_PEER
 };
+int socket_ip_address (int, ip_address *, int);
 
-/* bindport flags */
-#define BIND_ON_IPV4_ONLY LH_IPV4_ONLY
-#define BIND_ON_IPV6_ONLY LH_IPV6_ONLY
-
-#ifndef ENABLE_IPV6
-# ifndef HAVE_SOCKADDR_STORAGE
-#  define sockaddr_storage sockaddr_in
-# endif
-#endif /* ENABLE_IPV6 */
-
-/* Function declarations */
-
-int connect_to_ip PARAMS ((const ip_address *, int, const char *));
-int connect_to_host PARAMS ((const char *, int));
-
-void sockaddr_get_data PARAMS ((const struct sockaddr *, ip_address *, int *));
-
-int test_socket_open PARAMS ((int));
-int select_fd PARAMS ((int, double, int));
-uerr_t bindport PARAMS ((const ip_address *, int *, int *));
-uerr_t acceptport PARAMS ((int, int *));
-int conaddr PARAMS ((int, ip_address *));
-
-int iread PARAMS ((int, char *, int));
-int iwrite PARAMS ((int, char *, int));
+int retryable_socket_connect_error (int);
 
+/* Flags for select_fd's WAIT_FOR argument. */
+enum {
+  WAIT_FOR_READ = 1,
+  WAIT_FOR_WRITE = 2
+};
+int select_fd (int, double, int);
+int test_socket_open (int);
+
+typedef int (*fd_reader_t) (int, char *, int, void *);
+typedef int (*fd_writer_t) (int, char *, int, void *);
+typedef int (*fd_poller_t) (int, double, int, void *);
+typedef int (*fd_peeker_t) (int, char *, int, void *);
+typedef void (*fd_closer_t) (int, void *);
+void fd_register_transport (int, fd_reader_t, fd_writer_t,
+                           fd_poller_t, fd_peeker_t, fd_closer_t, void *);
+void *fd_transport_context (int);
+
+int fd_read (int, char *, int, double);
+int fd_write (int, char *, int, double);
+int fd_peek (int, char *, int, double);
+void fd_close (int);
 #endif /* CONNECT_H */