Changeset 6026:d51b782b77c5 in roaraudio for libroar/vio_stream.c


Ignore:
Timestamp:
07/14/14 10:06:28 (10 years ago)
Author:
phi
Branch:
default
Phase:
public
Message:

wrote roar_stream_connect_to_advanced() that combines roar_stream_connect_to() and roar_stream_connect_to_ask() in peaparation for v1 CON_STREAM messages and make use of it

File:
1 edited

Legend:

Unmodified
Added
Removed
  • libroar/vio_stream.c

    r6023 r6026  
    164164 int    opt  = 1; 
    165165#endif 
     166#ifdef ROAR_HAVE_LIBDNET 
     167 struct dn_naddr      *binaddr; 
     168#endif 
    166169#ifdef ROAR_HAVE_IPV4 
    167170 struct sockaddr_in   socket_addr; 
     
    181184#endif 
    182185 struct roar_sockname sockname; 
     186 char socketaddr[80]; 
     187 ssize_t socketaddr_len = -1; 
    183188 
    184189 // make valgrind happy 
     
    214219 
    215220 if ( sockname.type == ROAR_SOCKET_TYPE_DECNET ) { 
    216   if ( roar_socket_get_local_nodename() ) { 
    217    snprintf(file, sizeof(file), "%s::roar$TMP%04x%02x", roar_socket_get_local_nodename(), getpid(), count++); 
     221#ifdef ROAR_HAVE_LIBDNET 
     222  if ( roar_socket_get_local_nodename() != NULL && (binaddr = getnodeadd()) != NULL ) { 
     223   snprintf(socketaddr+3, sizeof(socketaddr)-3, "roar$TMP%04x%02x", getpid(), count++); 
     224   snprintf(file, sizeof(file), "%s::%s", roar_socket_get_local_nodename(), socketaddr+3); 
     225   memcpy(socketaddr, binaddr->a_addr, 2); 
     226   socketaddr[2] = 0; // object 0. 
     227   socketaddr_len = 3 + roar_mm_strlen(socketaddr+3); 
    218228  } else { 
    219229   return -1; 
    220230  } 
     231#else 
     232  roar_err_set(ROAR_ERROR_NOSYS); 
     233  return -1; 
     234#endif 
    221235#ifdef ROAR_HAVE_IPV4 
    222236 } else { 
    223   strncpy(file, inet_ntoa(socket_addr.sin_addr), sizeof(file) - 1); 
     237  strncpy(file, sockname.addr, sizeof(file) - 1); 
     238  roar_err_set(ROAR_ERROR_NONE); 
     239  if ( inet_aton(sockname.addr, &socket_addr.sin_addr) == 0 ) { 
     240   roar_err_update(); 
     241   return -1; 
     242  } 
     243  memcpy(socketaddr, &socket_addr.sin_addr.s_addr, 4); 
     244  socketaddr_len = 6; 
    224245#endif 
    225246 } 
    226247 
    227248 if ( sockname.type != ROAR_SOCKET_TYPE_UNIX ) { 
     249  roar_libroar_nowarn(); 
    228250  if ( (listen = roar_socket_listen(sockname.type, file, port)) == -1 ) { 
     251   roar_libroar_warn(); 
    229252   return -1; 
    230253  } 
     254  roar_libroar_warn(); 
    231255 } 
    232256 
     
    239263   return -1; 
    240264  } 
     265  ((uint16_t*)socketaddr)[3] = socket_addr.sin_port; 
    241266  port = ROAR_NET2HOST16(socket_addr.sin_port); 
    242267  ROAR_DBG("roar_simple_new_stream_obj(*): port=%i", port); 
     
    262287 if ( sockname.type != ROAR_SOCKET_TYPE_UNIX ) { 
    263288#ifdef ROAR_HAVE_SELECT 
    264   if ( roar_stream_connect_to_ask(con, s, sockname.type, file, port) != -1 ) { 
     289  if ( roar_stream_connect_to_advanced(con, s, 0, 1, 0, sockname.type, socketaddr_len, socketaddr, ROAR_PROTO_NONE, -1, NULL, 0, NULL) != -1 ) { 
    265290 
    266291   FD_ZERO(&fds); 
     
    334359  close(listen); 
    335360#else 
     361  roar_err_set(ROAR_ERROR_NOSYS); 
    336362  return -1; 
    337363#endif 
Note: See TracChangeset for help on using the changeset viewer.