Changeset 6026:d51b782b77c5 in roaraudio for libroar/vio_stream.c
- Timestamp:
- 07/14/14 10:06:28 (10 years ago)
- Branch:
- default
- Phase:
- public
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
libroar/vio_stream.c
r6023 r6026 164 164 int opt = 1; 165 165 #endif 166 #ifdef ROAR_HAVE_LIBDNET 167 struct dn_naddr *binaddr; 168 #endif 166 169 #ifdef ROAR_HAVE_IPV4 167 170 struct sockaddr_in socket_addr; … … 181 184 #endif 182 185 struct roar_sockname sockname; 186 char socketaddr[80]; 187 ssize_t socketaddr_len = -1; 183 188 184 189 // make valgrind happy … … 214 219 215 220 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); 218 228 } else { 219 229 return -1; 220 230 } 231 #else 232 roar_err_set(ROAR_ERROR_NOSYS); 233 return -1; 234 #endif 221 235 #ifdef ROAR_HAVE_IPV4 222 236 } 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; 224 245 #endif 225 246 } 226 247 227 248 if ( sockname.type != ROAR_SOCKET_TYPE_UNIX ) { 249 roar_libroar_nowarn(); 228 250 if ( (listen = roar_socket_listen(sockname.type, file, port)) == -1 ) { 251 roar_libroar_warn(); 229 252 return -1; 230 253 } 254 roar_libroar_warn(); 231 255 } 232 256 … … 239 263 return -1; 240 264 } 265 ((uint16_t*)socketaddr)[3] = socket_addr.sin_port; 241 266 port = ROAR_NET2HOST16(socket_addr.sin_port); 242 267 ROAR_DBG("roar_simple_new_stream_obj(*): port=%i", port); … … 262 287 if ( sockname.type != ROAR_SOCKET_TYPE_UNIX ) { 263 288 #ifdef ROAR_HAVE_SELECT 264 if ( roar_stream_connect_to_a sk(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 ) { 265 290 266 291 FD_ZERO(&fds); … … 334 359 close(listen); 335 360 #else 361 roar_err_set(ROAR_ERROR_NOSYS); 336 362 return -1; 337 363 #endif
Note: See TracChangeset
for help on using the changeset viewer.