+
+#ifndef SYS_BEOS
+/*****************************************************************************
+ * input_NetworkOpen : open a network socket
+ *****************************************************************************/
+void input_NetworkOpen( input_thread_t * p_input )
+{
+
+ int i_option_value, i_port;
+ struct sockaddr_in s_socket;
+ boolean_t b_broadcast;
+
+ /* FIXME : we don't handle channels for the moment */
+
+ /* Get the remote server */
+ if( p_input->p_source == NULL )
+ {
+ p_input->p_source = main_GetPszVariable( INPUT_SERVER_VAR,
+ INPUT_SERVER_DEFAULT );
+ }
+
+ /* Open a SOCK_DGRAM (UDP) socket, in the AF_INET domain, automatic (0)
+ * protocol */
+ p_input->i_handle = socket( AF_INET, SOCK_DGRAM, 0 );
+ if( p_input->i_handle == -1 )
+ {
+ intf_ErrMsg("NetworkOpen : can't create socket : %s", strerror(errno));
+ p_input->b_error = 1;
+ return;
+ }
+
+ /* We may want to reuse an already used socket */
+ i_option_value = 1;
+ if( setsockopt( p_input->i_handle, SOL_SOCKET, SO_REUSEADDR,
+ &i_option_value,sizeof( i_option_value ) ) == -1 )
+ {
+ intf_ErrMsg("NetworkOpen : can't configure socket (SO_REUSEADDR: %s)",
+ strerror(errno));
+ close( p_input->i_handle );
+ p_input->b_error = 1;
+ return;
+ }
+
+ /* Increase the receive buffer size to 1/2MB (8Mb/s during 1/2s) to avoid
+ * packet loss caused by scheduling problems */
+ i_option_value = 524288;
+ if( setsockopt( p_input->i_handle, SOL_SOCKET, SO_RCVBUF, &i_option_value,
+ sizeof( i_option_value ) ) == -1 )
+ {
+ intf_ErrMsg("NetworkOpen : can't configure socket (SO_RCVBUF: %s)",
+ strerror(errno));
+ close( p_input->i_handle );
+ p_input->b_error = 1;
+ return;
+ }
+
+ /* Get details about what we are supposed to do */
+ b_broadcast = (boolean_t)main_GetIntVariable( INPUT_BROADCAST_VAR, 0 );
+ i_port = main_GetIntVariable( INPUT_PORT_VAR, INPUT_PORT_DEFAULT );
+
+ /* TODO : here deal with channel stufs */
+
+ /* Build the local socket */
+ if ( network_BuildLocalAddr( &s_socket, i_port, b_broadcast )
+ == -1 )
+ {
+ close( p_input->i_handle );
+ p_input->b_error = 1;
+ return;
+ }
+
+ /* Bind it */
+ if( bind( p_input->i_handle, (struct sockaddr *)&s_socket,
+ sizeof( s_socket ) ) < 0 )
+ {
+ intf_ErrMsg("NetworkOpen: can't bind socket (%s)", strerror(errno));
+ close( p_input->i_handle );
+ p_input->b_error = 1;
+ return;
+ }
+
+ /* Build socket for remote connection */
+ if ( network_BuildRemoteAddr( &s_socket, p_input->p_source )
+ == -1 )
+ {
+ close( p_input->i_handle );
+ p_input->b_error = 1;
+ return;
+ }
+
+ /* And connect it ... should we really connect ? */
+ if( connect( p_input->i_handle, (struct sockaddr *) &s_socket,
+ sizeof( s_socket ) ) == (-1) )
+ {
+ intf_ErrMsg("NetworkOpen: can't connect socket" );
+ close( p_input->i_handle );
+ p_input->b_error = 1;
+ return;
+ }
+
+ /* We can't pace control, but FIXME : bug in meuuh's code to sync PCR
+ * with the server. */
+ p_input->stream.b_pace_control = 1;
+
+ return;
+}
+
+/*****************************************************************************
+ * input_NetworkClose : close a network socket
+ *****************************************************************************/
+void input_NetworkClose( input_thread_t * p_input )
+{
+ close( p_input->i_handle );
+ /* FIXME: deal with channels */
+}
+#endif