]> git.sesse.net Git - vlc/commitdiff
* sap.c: Improved IPv6 multicast detection
authorClément Stenac <zorglub@videolan.org>
Sat, 5 Jul 2003 15:00:28 +0000 (15:00 +0000)
committerClément Stenac <zorglub@videolan.org>
Sat, 5 Jul 2003 15:00:28 +0000 (15:00 +0000)
* announce.c:
- coding style fixes
- fixed port detection in IPv6 addresses (with ':' inside)

include/announce.h
modules/misc/sap.c
modules/stream_out/standard.c
src/stream_output/announce.c

index 0da8ef04c7e38998f5ea0f52b2c9935324b63f9a..b6fed0db2a90350bf181d7af2813d9023a2b5a58 100644 (file)
@@ -2,7 +2,7 @@
  * announce.h : Session announcement
  *****************************************************************************
  * Copyright (C) 2002 VideoLAN
- * $Id: announce.h,v 1.5 2003/06/25 21:03:16 zorglub Exp $
+ * $Id: announce.h,v 1.6 2003/07/05 15:00:28 zorglub Exp $
  *
  * Authors: Clément Stenac <zorglub@via.ecp.fr>
  *
@@ -61,6 +61,6 @@ struct sap_session_t
 /*****************************************************************************
  * Prototypes
  *****************************************************************************/
-VLC_EXPORT( sap_session_t *,            sout_SAPNew,         ( sout_instance_t *,char * , char * , char * ,int , char *) );
+VLC_EXPORT( sap_session_t *,            sout_SAPNew,         ( sout_instance_t *,char * , char * , int , char *) );
 VLC_EXPORT( void,            sout_SAPSend,        ( sout_instance_t *,sap_session_t *) );
 VLC_EXPORT( void,            sout_SAPDelete,      ( sout_instance_t *,sap_session_t * ) );
index 49af7c79d9c494ac521b3c61123e563bc5fffa96..7865943e2c8e5468295346908ad29479d2611743 100644 (file)
@@ -2,7 +2,7 @@
  * sap.c :  SAP interface module
  *****************************************************************************
  * Copyright (C) 2001 VideoLAN
- * $Id: sap.c,v 1.17 2003/07/02 18:44:27 zorglub Exp $
+ * $Id: sap.c,v 1.18 2003/07/05 15:00:28 zorglub Exp $
  *
  * Authors: Arnaud Schauly <gitan@via.ecp.fr>
  *          Clément Stenac <zorglub@via.ecp.fr>
@@ -754,7 +754,8 @@ static int ismult( char *psz_uri )
     /* IPv6 */
     if( psz_uri[0] == '[') 
     {
-        if( strncasecmp( &psz_uri[1], "FF0" , 3) )
+      if( strncasecmp( &psz_uri[1], "FF0" , 3) || 
+          strncasecmp( &psz_uri[2], "FF0" , 3))
             return( VLC_TRUE );
         else
             return( VLC_FALSE ); 
index 077dc115be3c6c183f4bbec12d70a507d7680630..4b70ec95e6f32a9d3c85c5355196c03a0f12e37d 100644 (file)
@@ -2,7 +2,7 @@
  * standard.c
  *****************************************************************************
  * Copyright (C) 2001, 2002 VideoLAN
- * $Id: standard.c,v 1.6 2003/06/23 13:45:30 zorglub Exp $
+ * $Id: standard.c,v 1.7 2003/07/05 15:00:28 zorglub Exp $
  *
  * Authors: Laurent Aimar <fenrir@via.ecp.fr>
  *
@@ -81,8 +81,6 @@ static int Open( vlc_object_t *p_this )
     
     char                *psz_sap = NULL;
 
-    char                *psz_port = "1234";
-    
     sap_session_t       *p_sap = NULL;
     
     sout_access_out_t *p_access;
@@ -142,7 +140,7 @@ static int Open( vlc_object_t *p_this )
     if(p_sys->b_sap)
     {        
         msg_Dbg( p_sout , "Creating SAP with IPv%i",atoi(psz_ipv) );
-        p_sap = sout_SAPNew( p_sout , psz_url , psz_port , psz_sap, atoi(psz_ipv), psz_v6_scope );
+        p_sap = sout_SAPNew( p_sout , psz_url , psz_sap, atoi(psz_ipv), psz_v6_scope );
         if(!p_sap)
         {
                 msg_Err( p_sout,"Unable to initialize SAP. SAP disabled");
index 8540063c88998b5c9f5701ba888a540a2e3c055e..5afdeba65908edbc2a006797e61f420ea8bf713c 100644 (file)
 #define SAP_IPV6_ADDR_1 "FF0"
 #define SAP_IPV6_ADDR_2 "::2:7FFE"
 
+#define DEFAULT_PORT "1234"
+
 /****************************************************************************
  *  Split : split a string into two parts: the one which is before the delim
  *               and the one which is after.
  *               NULL is returned if delim is not found
  ****************************************************************************/
 
-static char * split( char *p_in, char *p_out1, char *p_out2, char delim)
+static char * split( char *psz_in, char *psz_out1, char *psz_out2, char delim)
 {
-    unsigned int i_count=0; /*pos in input string*/
-    unsigned int i_pos1=0; /*pos in out2 string */
-    unsigned int i_pos2=0; 
-    char *p_cur; /*store the pos of the first delim found */
+    unsigned int i_count = 0; /*pos in input string*/
+    unsigned int i_pos1  = 0; /*pos in out2 string */
+    unsigned int i_pos2  = 0; 
+    char *psz_cur; /*store the pos of the first delim found */
     
     /*skip spaces at the beginning*/
-    while(p_in[i_count] == ' ' && i_count < strlen(p_in))
+    while(psz_in[i_count] == ' ' && i_count < strlen(psz_in))
     {
         i_count++;
     }
-    if(i_count == strlen(p_in))
+    if(i_count == strlen(psz_in))
         return NULL;
     
     /*Look for delim*/
-    while(p_in[i_count] != delim && i_count < strlen(p_in))
+    while(psz_in[i_count] != delim && i_count < strlen(psz_in))
     {
-        p_out1[i_pos1] = p_in[i_count];
+        psz_out1[i_pos1] = psz_in[i_count];
         i_count++;
         i_pos1++;
     }
     /* Mark the end of out1 */
-    p_out1[i_pos1] = 0;
+    psz_out1[i_pos1] = 0;
     
-    if(i_count == strlen(p_in))
+    if(i_count == strlen(psz_in))
         return NULL;
     
     /*store pos of the first delim*/
-    p_cur = &p_in[i_count];
+    psz_cur = &psz_in[i_count];
     
     
     
     /*skip all delim and all spaces*/
-    while((p_in[i_count] == ' ' || p_in[i_count] == delim) && i_count < strlen(p_in))
+    while( (psz_in[i_count] == ' ' || 
+            psz_in[i_count] == delim) 
+           && i_count < strlen(psz_in))
     {
         i_count++;
     }
     
-    if(i_count == strlen(p_in))
-        return p_cur;
+    if(i_count == strlen(psz_in))
+        return psz_cur;
     
     /*Store the second string*/
-    while(i_count < strlen(p_in))
+    while(i_count < strlen(psz_in))
     {
-        p_out2[i_pos2] = p_in[i_count];
+        psz_out2[i_pos2] = psz_in[i_count];
         i_pos2++;
         i_count++;
     }
-    p_out2[i_pos2] = 0;
+    psz_out2[i_pos2] = 0;
     
-    return p_cur;
+    return psz_cur;
 }
 
 /*****************************************************************************
  * sout_SAPNew: Creates a SAP Session
  *****************************************************************************/
 sap_session_t * sout_SAPNew ( sout_instance_t *p_sout ,
-                char * psz_url_arg , char *psz_port_arg ,
+                char * psz_url_arg,
                 char * psz_name_arg, int ip_version,
                 char * psz_v6_scope )
 {
@@ -119,7 +123,9 @@ sap_session_t * sout_SAPNew ( sout_instance_t *p_sout ,
     network_socket_t    socket_desc; /* Socket descriptor */
     char                psz_network[6]; /* IPv4 or IPv6 */
     char                *sap_ipv6_addr=NULL; /* IPv6 built address */
-
+    char                *psz_eol; /* Used to parse IPv6 URIs */
+    int                 i_port; /* Port in numerical format */
+    
     /* Allocate the SAP structure */
     p_new = (sap_session_t *)malloc( sizeof ( sap_session_t ) ) ;
     if ( !p_new )
@@ -129,12 +135,55 @@ sap_session_t * sout_SAPNew ( sout_instance_t *p_sout ,
     }
     
     /* Fill the information in the structure */
-    split(psz_url_arg,p_new->psz_url,p_new->psz_port,':');   
-    // sprintf ( p_new->psz_url , "%s" , psz_url_arg );
-    sprintf ( p_new->psz_name , "%s" , psz_name_arg );
+    if( strstr( psz_url_arg , "[" ) )
+    {      /* We have an IPv6 address. Do not use ':' as the port separator */
+        psz_eol = strchr( psz_url_arg, ']' );
+        if( !psz_eol ) /* No matching ] ! Aborting */
+        {
+            msg_Warn( p_sout , "No matching ]. Unable to parse URI");
+            return NULL;
+        }
+        if(!psz_eol++)
+        {
+              sprintf (p_new->psz_url, "%s", psz_url_arg);
+              sprintf (p_new->psz_port, "%s", DEFAULT_PORT);
+        }
+        else
+        {
+            *psz_eol = '\0';
+            sprintf (p_new->psz_url, "%s", psz_url_arg);
+            psz_eol++;
+            if(psz_eol)
+            {
+                  sprintf (p_new->psz_port, "%s", psz_eol);
+            }
+        }    
+    }
+    else
+    {
+        split(psz_url_arg,p_new->psz_url,p_new->psz_port,':');   
+    }
+  
+    /* Check if we have a port */
+    if( !strlen(p_new->psz_port) )
+    {
+        sprintf (p_new->psz_port, "%s", DEFAULT_PORT);
+    }
+  
+    /* Make sure our port is valid and atoi it*/
+    i_port = atoi( p_new->psz_port );
+    
+    if( !i_port )
+    {
+        sprintf (p_new->psz_port, "%s", DEFAULT_PORT);
+    }
+    else
+    {
+       sprintf (p_new->psz_port, "%i", i_port); 
+    }
 
-    /* Port is not implemented in sout */
-    //sprintf ( p_new->psz_port, "%s" , psz_port_arg );
+    /* The name that we send */ 
+    sprintf ( p_new->psz_name , "%s" , psz_name_arg );
 
     p_new->i_ip_version = ip_version;
 
@@ -226,7 +275,7 @@ sap_session_t * sout_SAPNew ( sout_instance_t *p_sout ,
  *****************************************************************************/
 void sout_SAPDelete( sout_instance_t *p_sout , sap_session_t * p_this )
 {
-    if( close(p_this->socket) )
+    if( close( p_this->socket ) )
     {
         msg_Err ( p_sout, "Unable to close SAP socket");
     }
@@ -287,7 +336,6 @@ void sout_SAPSend( sout_instance_t *p_sout, sap_session_t * p_this)
                           "a=type:test\n",
                  p_this->psz_name , p_this->psz_port , p_this->psz_url );
         
-        fprintf(stderr,"Sending : <%s>\n",sap_msg);
         i_msg_size = strlen( sap_msg );
         i_size = i_msg_size + i_header_size;