diff --git a/modules/gui/wxwindows/interface.cpp b/modules/gui/wxwindows/interface.cpp
index 951e2110f5744182c70a450a4997b67677df45de..7ebdcf69adbaffe04743ff9bdd971a1667386dc6 100644
--- a/modules/gui/wxwindows/interface.cpp
+++ b/modules/gui/wxwindows/interface.cpp
@@ -2,7 +2,7 @@
  * interface.cpp : wxWindows plugin for vlc
  *****************************************************************************
  * Copyright (C) 2000-2001 VideoLAN
- * $Id: interface.cpp,v 1.62 2003/10/06 17:41:47 gbazin Exp $
+ * $Id: interface.cpp,v 1.63 2003/10/08 10:07:22 zorglub Exp $
  *
  * Authors: Gildas Bazin <gbazin@netcourrier.com>
  *
@@ -31,6 +31,7 @@
 
 #include <vlc/vlc.h>
 #include <vlc/aout.h>
+#include <vlc/vout.h>
 #include <vlc/intf.h>
 #include "stream_control.h"
 
@@ -498,9 +499,9 @@ void Interface::CreateOurExtraPanel()
     hue_slider = new wxSlider ( extra_frame, Hue_Event, 0, 0,
                                 360, wxDefaultPosition, wxDefaultSize );
 
-   hue_sizer->Add(hue_text,1, 0 ,0);
-   hue_sizer->Add(hue_slider,1, 0 ,0);
-   hue_sizer->Layout();
+    hue_sizer->Add(hue_text,1, 0 ,0);
+    hue_sizer->Add(hue_slider,1, 0 ,0);
+    hue_sizer->Layout();
 
     wxBoxSizer *contrast_sizer = new wxBoxSizer( wxHORIZONTAL );
     wxStaticText *contrast_text = new wxStaticText( extra_frame, -1,
@@ -598,6 +599,21 @@ void Interface::CreateOurExtraPanel()
         hue_slider->Disable();
     }
 
+    int i_value = config_GetInt( p_intf, "hue" );
+    if( i_value > 0 && i_value < 360 )
+        hue_slider->SetValue( i_value );
+
+    float f_value;
+    f_value = config_GetFloat( p_intf, "saturation" );
+    if( f_value > 0 && f_value < 3 )
+        saturation_slider->SetValue( (int)(100 * f_value) );
+    f_value = config_GetFloat( p_intf, "contrast" );
+    if( f_value > 0 && f_value < 2 )
+        contrast_slider->SetValue( (int)(100 * f_value) );
+    f_value = config_GetFloat( p_intf, "brightness" );
+    if( f_value > 0 && f_value < 2 )
+        brightness_slider->SetValue( (int)(100 * f_value) );
+
     extra_frame->Hide();
     free(psz_filters);
 }
@@ -859,7 +875,17 @@ void Interface::OnEnableAdjust(wxCommandEvent& event)
             sprintf( psz_new, "%s:adjust", psz_filters);
         }
         config_PutPsz( p_intf, "filter", psz_new );
-
+        vlc_value_t val;
+        vout_thread_t *p_vout =
+           (vout_thread_t *)vlc_object_find( p_intf, VLC_OBJECT_VOUT,
+                                       FIND_ANYWHERE );
+        if( p_vout != NULL )
+        {
+            val.psz_string = strdup( psz_new );
+            var_Set( p_vout, "filter", val);
+            vlc_object_release( p_vout );
+        }
+        if( val.psz_string ) free( val.psz_string );
         brightness_slider->Enable();
         saturation_slider->Enable();
         contrast_slider->Enable();
@@ -890,6 +916,17 @@ void Interface::OnEnableAdjust(wxCommandEvent& event)
                 }
             }
             config_PutPsz( p_intf, "filter", psz_filters);
+            vlc_value_t val;
+            val.psz_string = strdup( psz_filters );
+            vout_thread_t *p_vout =
+               (vout_thread_t *)vlc_object_find( p_intf, VLC_OBJECT_VOUT,
+                                       FIND_ANYWHERE );
+            if( p_vout != NULL )
+            {
+                var_Set( p_vout, "filter", val);
+                vlc_object_release( p_vout );
+            }
+            if( val.psz_string ) free( val.psz_string );
         }
         brightness_slider->Disable();
         saturation_slider->Disable();
diff --git a/modules/misc/httpd.c b/modules/misc/httpd.c
index 666800367821d1a0f4b0aa9c21ad89bb1dd30095..90d5ffffc9e9877ec3f30675129aa763a94d7aca 100644
--- a/modules/misc/httpd.c
+++ b/modules/misc/httpd.c
@@ -2,7 +2,7 @@
  * httpd.c
  *****************************************************************************
  * Copyright (C) 2001-2003 VideoLAN
- * $Id: httpd.c,v 1.27 2003/08/26 00:40:27 fenrir Exp $
+ * $Id: httpd.c,v 1.28 2003/10/08 10:07:22 zorglub Exp $
  *
  * Authors: Laurent Aimar <fenrir@via.ecp.fr>
  *
@@ -114,7 +114,9 @@ static httpd_file_t     *RegisterFile   ( httpd_t *,
                                           httpd_file_callback_args_t *p_args );
 static void             UnregisterFile  ( httpd_t *, httpd_file_t * );
 
-//#define httpd_stream_t              httpd_file_t
+#if 0
+ #define httpd_stream_t              httpd_file_t
+#endif
 static httpd_stream_t   *RegisterStream ( httpd_t *,
                                          char *psz_file, char *psz_mime,
                                          char *psz_user, char *psz_password );
@@ -143,7 +145,9 @@ enum httpd_authenticate_e
     HTTPD_AUTHENTICATE_BASIC = 1
 };
 
-//typedef httpd_file_t httpd_stream_t;
+#if 0
+  typedef httpd_file_t httpd_stream_t;
+#endif
 
 struct httpd_file_t
 {
@@ -207,12 +211,12 @@ typedef struct httpd_connection_s
     int    i_state;
     int    i_method;       /* get/post */
 
-    char    *psz_file;      // file to be send
-    int     i_http_error;   // error to be send with the file
-    char    *psz_user;      // if Authorization in the request header
+    char    *psz_file;      /* file to be send */
+    int     i_http_error;   /* error to be send with the file */
+    char    *psz_user;      /* if Authorization in the request header */
     char    *psz_password;
 
-    uint8_t *p_request;     // whith get: ?<*>, with post: main data
+    uint8_t *p_request;     /* whith get: ?<*>, with post: main data */
     int      i_request_size;
 
     httpd_file_t    *p_file;
@@ -288,19 +292,36 @@ static int Open( vlc_object_t *p_this )
     p_httpt->b_error= 0;
 
     /* init httpt_t structure */
-    vlc_mutex_init( p_httpd, &p_httpt->host_lock );
+    if( vlc_mutex_init( p_httpd, &p_httpt->host_lock ) )
+    {
+        msg_Err( p_httpd, "Error in mutex creation");
+        return( VLC_EGENERIC );
+    }
     p_httpt->i_host_count = 0;
     p_httpt->host = NULL;
 
-    vlc_mutex_init( p_httpd, &p_httpt->file_lock );
+    if( vlc_mutex_init( p_httpd, &p_httpt->file_lock ) )
+    {
+        msg_Err( p_httpd, "Error in mutex creation");
+        return( VLC_EGENERIC );
+    }
     p_httpt->i_file_count = 0;
     p_httpt->file = NULL;
 
-    vlc_mutex_init( p_httpd, &p_httpt->connection_lock );
+    if( vlc_mutex_init( p_httpd, &p_httpt->connection_lock ) )
+    {
+        msg_Err( p_httpd, "Error in mutex creation");
+        return( VLC_EGENERIC );
+    }
     p_httpt->i_connection_count = 0;
     p_httpt->p_first_connection = NULL;
 
-    vlc_mutex_init( p_httpd, &p_httpt->ban_lock );
+    if( vlc_mutex_init( p_httpd, &p_httpt->ban_lock ) )
+    {
+        msg_Err( p_httpd, "Error in mutex creation");
+        return( VLC_EGENERIC );
+    }
+
     p_httpt->i_banned_ip_count = 0;
     p_httpt->p_first_banned_ip = NULL;
 
@@ -559,9 +580,24 @@ static httpd_host_t *_RegisterHost( httpd_sys_t *p_httpt, char *psz_host_addr, i
     {
         p_httpt->host = malloc( sizeof( httpd_host_t *) );
     }
+    if( !p_httpt->host )
+    {
+        msg_Err( p_httpt, "Out of memory" );
+        return NULL;
+    }
     p_host                = malloc( sizeof( httpd_host_t ) );
+    if( !p_host )
+    {
+        msg_Err( p_httpt, "Out of memory" );
+        return NULL;
+    }
     p_host->i_ref         = 1;
     p_host->psz_host_addr = strdup( psz_host_addr );
+    if( !p_host->psz_host_addr )
+    {
+        msg_Err( p_httpt, "Out of memory" );
+        return NULL;
+    }
     p_host->i_port        = i_port;
     p_host->sock          = sock;
     p_host->fd            = fd;
@@ -642,6 +678,11 @@ static void            _UnregisterHost( httpd_sys_t *p_httpt, httpd_host_t *p_ho
         p_httpt->i_host_count--;
         p_httpt->host = realloc( p_httpt->host,
                                  p_httpt->i_host_count * sizeof( httpd_host_t * ) );
+        if( !p_httpt->p_host )
+        {
+            msg_Err( p_httpt, "Out of memory" );
+            return NULL;
+        }
     }
 
     vlc_mutex_unlock( &p_httpt->host_lock );
@@ -663,7 +704,10 @@ static void __RegisterFile( httpd_sys_t *p_httpt, httpd_file_t *p_file )
     {
         p_httpt->file = malloc( sizeof( httpd_file_t *) );
     }
-
+    if( !p_httpt->file )
+    {
+        return;
+    }
     p_httpt->file[p_httpt->i_file_count++] = p_file;
 }
 
@@ -693,14 +737,29 @@ static httpd_file_t    *_RegisterFile( httpd_sys_t *p_httpt,
     }
 
     p_file              = malloc( sizeof( httpd_file_t ) );
+    if( !p_file )
+    {
+        msg_Err( p_httpt, "Out of memory" );
+        return NULL;
+    }
     p_file->i_ref       = 0;
     p_file->psz_file    = strdup( psz_file );
     p_file->psz_mime    = strdup( psz_mime );
+    if( !p_file->psz_file || !p_file->psz_mime )
+    {
+        msg_Err( p_httpt, "Out of memory" );
+        return NULL;
+    }
     if( psz_user && *psz_user )
     {
         p_file->i_authenticate_method = HTTPD_AUTHENTICATE_BASIC;
         p_file->psz_user              = strdup( psz_user );
         p_file->psz_password          = strdup( psz_password );
+        if( !p_file->psz_user || !p_file->psz_password )
+        {
+            msg_Err( p_httpt, "Out of memory" );
+            return NULL;
+        }
     }
     else
     {
@@ -763,14 +822,29 @@ static httpd_stream_t  *_RegisterStream( httpd_sys_t *p_httpt,
     }
 
     p_stream              = malloc( sizeof( httpd_stream_t ) );
+    if( !p_stream )
+    {
+        msg_Err( p_httpt, "Out of memory" );
+        return NULL;
+    }
     p_stream->i_ref       = 0;
     p_stream->psz_file    = strdup( psz_file );
     p_stream->psz_mime    = strdup( psz_mime );
+    if( !p_file->psz_file || !p_file->psz_mime )
+    {
+        msg_Err( p_httpt, "Out of memory" );
+        return NULL;
+    }
     if( psz_user && *psz_user )
     {
         p_stream->i_authenticate_method = HTTPD_AUTHENTICATE_BASIC;
         p_stream->psz_user              = strdup( psz_user );
         p_stream->psz_password          = strdup( psz_password );
+        if( !p_file->psz_user || !p_file->psz_password )
+        {
+            msg_Err( p_httpt, "Out of memory" );
+            return NULL;
+        }
     }
     else
     {
@@ -788,6 +862,11 @@ static httpd_stream_t  *_RegisterStream( httpd_sys_t *p_httpt,
     p_stream->i_buffer_pos      = 0;
     p_stream->i_buffer_last_pos = 0;
     p_stream->p_buffer        = malloc( p_stream->i_buffer_size );
+    if( !p_stream->p_buffer )
+    {
+        msg_Err( p_httpt, "Out of memory" );
+        return NULL;
+    }
 
     p_stream->i_header_size   = 0;
     p_stream->p_header        = NULL;
@@ -900,8 +979,9 @@ static int             _SendStream( httpd_sys_t *p_httpt, httpd_stream_t *p_stre
     {
         return( VLC_SUCCESS );
     }
-    //fprintf( stderr, "## i_data=%d pos=%lld\n", i_data, p_stream->i_buffer_pos );
-
+#if 0
+    fprintf( stderr, "## i_data=%d pos=%lld\n", i_data, p_stream->i_buffer_pos );
+#endif
     vlc_mutex_lock( &p_httpt->file_lock );
 
     /* save this pointer (to be used by new connection) */
@@ -915,6 +995,7 @@ static int             _SendStream( httpd_sys_t *p_httpt, httpd_stream_t *p_stre
 
         i_copy = __MIN( i_count, p_stream->i_buffer_size - i_pos );
 
+        /* Ok, we can't go past the end of our buffer */
         memcpy( &p_stream->p_buffer[i_pos],
                 p_data,
                 i_copy );
@@ -929,6 +1010,7 @@ static int             _SendStream( httpd_sys_t *p_httpt, httpd_stream_t *p_stre
 
     return( VLC_SUCCESS );
 }
+
 static int             SendStream( httpd_t *p_httpd, httpd_stream_t *p_stream, uint8_t *p_data, int i_data )
 {
     return( _SendStream( p_httpd->p_sys, p_stream, p_data, i_data ) );
@@ -949,6 +1031,11 @@ static int             HeaderStream( httpd_t *p_httpd, httpd_stream_t *p_stream,
     {
         p_stream->i_header_size = i_data;
         p_stream->p_header = malloc( i_data );
+        if( !p_stream->p_header )
+        {
+            msg_Err( p_httpt, "Out of memory" );
+            return( VLC_ENOMEM );
+        }
         memcpy( p_stream->p_header,
                 p_data,
                 i_data );
@@ -970,14 +1057,22 @@ static void httpd_info_add_ss( httpd_info_t *p_info, char *name, char *value )
             realloc( p_info->info,
                      sizeof( httpd_val_t ) * ( p_info->i_count + 1 ) );
     }
+    if( !p_info->info )
+    {
+        return;
+    }
     p_info->info[p_info->i_count].psz_name  = strdup( name );
+    if( ! p_info->info[p_info->i_count].psz_name )
+    {
+        return;
+    }
     p_info->info[p_info->i_count].psz_value = strdup( value ? value : "(null)");
     p_info->i_count++;
 }
 
 static void httpd_info_add_si( httpd_info_t *p_info, char *name, int i_value )
 {
-    char v[40];
+    char v[40]; /* Ok, int is not so long */
 
     sprintf( v, "%d", i_value );
     httpd_info_add_ss( p_info, name, v );
@@ -1101,7 +1196,10 @@ static int  httpd_page_400_get( httpd_file_callback_args_t *p_args,
     char *p;
 
     p = *pp_data = malloc( 1024 );
-
+    if( !p )
+    {
+        return VLC_ENOMEM ;
+    }
     p += sprintf( p, "<html>\n" );
     p += sprintf( p, "<head>\n" );
     p += sprintf( p, "<title>Error 400</title>\n" );
@@ -1125,6 +1223,10 @@ static int  httpd_page_401_get( httpd_file_callback_args_t *p_args,
     char *p;
 
     p = *pp_data = malloc( 1024 );
+    if( !p )
+    {
+        return VLC_ENOMEM ;
+    }
 
     p += sprintf( p, "<html>\n" );
     p += sprintf( p, "<head>\n" );
@@ -1148,6 +1250,10 @@ static int  httpd_page_404_get( httpd_file_callback_args_t *p_args,
     char *p;
 
     p = *pp_data = malloc( 1024 );
+    if( !p )
+    {
+        return VLC_ENOMEM ;
+    }
 
     p += sprintf( p, "<html>\n" );
     p += sprintf( p, "<head>\n" );
@@ -1276,6 +1382,11 @@ static void httpd_ConnnectionNew( httpd_sys_t *p_httpt, int fd, struct sockaddr_
 
     /* create a new connection and link it */
     p_con = malloc( sizeof( httpd_connection_t ) );
+    if( !p_con )
+    {
+        msg_Err( p_httpt, "Out of memory" );
+        return;
+    }
     p_con->i_state  = HTTPD_CONNECTION_RECEIVING_REQUEST;
     p_con->fd       = fd;
     p_con->i_last_activity_date = mdate();
@@ -1293,8 +1404,13 @@ static void httpd_ConnnectionNew( httpd_sys_t *p_httpt, int fd, struct sockaddr_
     p_con->i_buffer = 0;
     p_con->i_buffer_size = 8096;
     p_con->p_buffer = malloc( p_con->i_buffer_size );
+    if( !p_con->p_buffer )
+    {
+        msg_Err( p_httpt, "Out of memory");
+        return ;
+    }
 
-    p_con->i_stream_pos = 0; // updated by httpd_thread */
+    p_con->i_stream_pos = 0; /* updated by httpd_thread */
     p_con->p_next = NULL;
 
     if( p_httpt->p_first_connection )
@@ -1395,7 +1511,7 @@ static int httpd_RequestNextLine( char **pp_buffer, char *p_end )
     return VLC_EGENERIC;
 }
 
-//char b64[] = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
+/*char b64[] = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";*/
 static void b64_decode( char *dest, char *src )
 {
     int  i_level;
@@ -1460,6 +1576,7 @@ static void httpd_ConnectionParseRequest( httpd_sys_t *p_httpt, httpd_connection
 
     int  i;
     int  b_xplaystream = VLC_FALSE;
+    /* Size is checked for all of these */
     char command[32];
     char url[1024];
     char version[32];
@@ -1475,8 +1592,9 @@ static void httpd_ConnectionParseRequest( httpd_sys_t *p_httpt, httpd_connection
     httpd_RequestGetWord( command, 32, &p, p_end );
     httpd_RequestGetWord( url, 1024, &p, p_end );
     httpd_RequestGetWord( version, 32, &p, p_end );
-    //msg_Dbg( p_httpt, "ask =%s= =%s= =%s=", command, url, version );
-
+#if 0
+    msg_Dbg( p_httpt, "ask =%s= =%s= =%s=", command, url, version );
+#endif
     p_con->p_request      = NULL;
     p_con->i_request_size = 0;
     if( !strcmp( command, "GET" ) )
@@ -1515,11 +1633,14 @@ static void httpd_ConnectionParseRequest( httpd_sys_t *p_httpt, httpd_connection
 
         if( httpd_RequestNextLine( &p, p_end ) )
         {
-            //msg_Dbg( p_httpt, "failled new line" );
+#if 0
+            msg_Dbg( p_httpt, "failled new line" );
+#endif
             break;;
         }
-        //msg_Dbg( p_httpt, "new line=%s", p );
-
+#if 0
+        msg_Dbg( p_httpt, "new line=%s", p );
+#endif
         httpd_RequestGetWord( header, 1024, &p, p_end );
         if( !strcmp( header, "\r\n" ) || !strcmp( header, "\n" ) )
         {
@@ -1537,9 +1658,13 @@ static void httpd_ConnectionParseRequest( httpd_sys_t *p_httpt, httpd_connection
                 char decoded[1024];
 
                 httpd_RequestGetWord( basic, 1024, &p, p_end );
-//                msg_Dbg( p_httpt, "Authorization: basic:%s", basic );
+#if 0
+                msg_Dbg( p_httpt, "Authorization: basic:%s", basic );
+#endif
                 b64_decode( decoded, basic );
-//                msg_Dbg( p_httpt, "Authorization: decoded:%s", decoded );
+#if 0
+                msg_Dbg( p_httpt, "Authorization: decoded:%s", decoded );
+#endif
                 if( strchr( decoded, ':' ) )
                 {
                     char *p = strchr( decoded, ':' );
@@ -1595,7 +1720,11 @@ static void httpd_ConnectionParseRequest( httpd_sys_t *p_httpt, httpd_connection
         {
             p_con->i_request_size = p_end - p_request;
             p_con->p_request = malloc( p_con->i_request_size + 1);
-
+            if( !p_con->p_request)
+            {
+                msg_Err( p_httpt, "Out of memory" );
+                return;
+            }
             memcpy( p_con->p_request,
                     p_request,
                     p_con->i_request_size );
@@ -1606,17 +1735,23 @@ static void httpd_ConnectionParseRequest( httpd_sys_t *p_httpt, httpd_connection
     p_con->i_http_error = 200;
 
 create_header:
-    //msg_Dbg( p_httpt, "ask %s %s %d", command, p_con->psz_file, p_con->i_http_error );
+#if 0
+    msg_Dbg( p_httpt, "ask %s %s %d", command, p_con->psz_file, p_con->i_http_error );
+#endif
     FREE( p_con->p_buffer );
     p_con->i_buffer = 0;
     p_con->i_buffer_size = 0;
 
-    //vlc_mutex_lock( &p_httpt->file_lock );
+#if 0
+    vlc_mutex_lock( &p_httpt->file_lock );
+#endif
 search_file:
     /* search file */
     p_con->p_file = NULL;
     for( i = 0; i < p_httpt->i_file_count; i++ )
     {
+        /* Our strdup call failed */
+        if( !p_con->psz_file ) return;
         if( !strcmp( p_httpt->file[i]->psz_file, p_con->psz_file ) )
         {
             if( p_httpt->file[i]->b_stream ||
@@ -1664,7 +1799,9 @@ search_file:
     }
 
     p_con->p_file->i_ref++;
-//    vlc_mutex_unlock( &p_httpt->file_lock );
+#if 0
+    vlc_mutex_unlock( &p_httpt->file_lock );
+#endif
 
     switch( p_con->i_http_error )
     {
@@ -1694,7 +1831,11 @@ search_file:
     }
 
     p = p_con->p_buffer = malloc( p_con->i_buffer_size );
-
+    if( !p)
+    {
+        msg_Err( p_httpt, "Out of memory" );
+        return;
+    }
     p += sprintf( p, "HTTP/1.0 %d %s\r\n", p_con->i_http_error, psz_status );
 
     /* Special mmsh case cludgy but ...*/
@@ -1752,7 +1893,9 @@ search_file:
     {
         p_con->i_method = HTTPD_CONNECTION_METHOD_HEAD;
     }
-    //msg_Dbg( p_httpt, "answer=\n%s", p_con->p_buffer );
+#if 0
+    msg_Dbg( p_httpt, "answer=\n%s", p_con->p_buffer );
+#endif
 }
 #define HTTPD_STREAM_PACKET 10000
 static void httpd_Thread( httpd_sys_t *p_httpt )
@@ -1961,7 +2104,9 @@ static void httpd_Thread( httpd_sys_t *p_httpt )
                 {
                     i_len = 0;
                 }
-//                msg_Warn( p_httpt, "on %d send %d bytes %s", p_con->i_buffer_size, i_len, p_con->p_buffer + p_con->i_buffer );
+#if 0
+                msg_Warn( p_httpt, "on %d send %d bytes %s", p_con->i_buffer_size, i_len, p_con->p_buffer + p_con->i_buffer );
+#endif
 
 #if defined( WIN32 ) || defined( UNDER_CE )
                 if( ( i_len < 0 && WSAGetLastError() != WSAEWOULDBLOCK ) || ( i_len == 0 ) )
@@ -1989,7 +2134,7 @@ static void httpd_Thread( httpd_sys_t *p_httpt )
 
                             if( !p_con->p_file->b_stream || p_con->i_method == HTTPD_CONNECTION_METHOD_HEAD )
                             {
-                                p_con->i_state = HTTPD_CONNECTION_SENDING_FILE; // be sure to out from HTTPD_CONNECTION_SENDING_HEADER
+                                p_con->i_state = HTTPD_CONNECTION_SENDING_FILE; /* be sure to out from HTTPD_CONNECTION_SENDING_HEADER */
                                 if( p_con->i_method == HTTPD_CONNECTION_METHOD_GET )
                                 {
                                     p_con->p_file->pf_get( p_con->p_file->p_sys,
diff --git a/modules/misc/sap.c b/modules/misc/sap.c
index 1fbd5644e7db476a8479c2db6299309114f38fd8..590eee4f9f2039bc6d002c00619b8837ddb458c1 100644
--- a/modules/misc/sap.c
+++ b/modules/misc/sap.c
@@ -2,7 +2,7 @@
  * sap.c :  SAP interface module
  *****************************************************************************
  * Copyright (C) 2001 VideoLAN
- * $Id: sap.c,v 1.24 2003/10/06 16:23:30 zorglub Exp $
+ * $Id: sap.c,v 1.25 2003/10/08 10:07:22 zorglub Exp $
  *
  * Authors: Arnaud Schauly <gitan@via.ecp.fr>
  *          Clément Stenac <zorglub@via.ecp.fr>
@@ -116,7 +116,7 @@ static void free_sd( sess_descr_t * );
 static int  ismult( char * );
 
 /* The struct that contains sdp informations */
-struct  sess_descr_t 
+struct  sess_descr_t
 {
     char *psz_version;
     char *psz_origin;
@@ -136,13 +136,13 @@ struct  sess_descr_t
 };
 
 /* All this informations are not useful yet.  */
-struct media_descr_t 
+struct media_descr_t
 {
     char *psz_medianame;
     char *psz_mediaconnection;
 };
 
-struct attr_descr_t 
+struct attr_descr_t
 {
     char *psz_field;
     char *psz_value;
@@ -212,11 +212,11 @@ static void Run( intf_thread_t *p_intf )
     char *psz_network = NULL;
     int fd            = - 1;
     int fdv6          = -1;
-    
+
     int no_sap_ipv4      = config_GetInt( p_intf, "no-sap-ipv4" );
     int sap_ipv6         = config_GetInt( p_intf, "sap-ipv6" );
     char *sap_ipv6_scope = config_GetPsz( p_intf, "sap-ipv6-scope" );
-    
+
     char buffer[MAX_SAP_BUFFER + 1];
 
     module_t            *p_network;
@@ -227,15 +227,15 @@ static void Run( intf_thread_t *p_intf )
         msg_Warn( p_intf, "Unable to parse module configuration" );
         return;
     }
-    
+
     /* Prepare IPv4 Networking */
     if ( no_sap_ipv4 == 0)
     {
         if( !(psz_addr = config_GetPsz( p_intf, "sap-addr" ) ) )
-        { 
+        {
             psz_addr = strdup( HELLO_GROUP );
-        } 
-            
+        }
+
         /* Prepare the network_socket_t structure */
         socket_desc.i_type            = NETWORK_UDP;
         socket_desc.psz_bind_addr     = psz_addr;
@@ -245,10 +245,10 @@ static void Run( intf_thread_t *p_intf )
         socket_desc.i_ttl             = 0;
         p_intf->p_private = (void*) &socket_desc;
 
-        psz_network = "ipv4"; 
+        psz_network = "ipv4";
 
        /* Create, Bind the socket, ... with the appropriate module  */
- 
+
         if( !( p_network = module_Need( p_intf, "network", psz_network ) ) )
         {
             msg_Warn( p_intf, "failed to open a connection (udp)" );
@@ -264,12 +264,17 @@ static void Run( intf_thread_t *p_intf )
     {
         /* Prepare the network_socket_t structure */
 
-        psz_addrv6=(char *)malloc(sizeof(char)*38); 
+        psz_addrv6=(char *)malloc(sizeof(char)*38);
+
+        if( !psz_addrv6)
+        {
+            msg_Warn( p_intf, "Out of memory !" );
+        }
         /* Max size of an IPv6 address */
-        
+
         sprintf(psz_addrv6,"[%s%c%s]",IPV6_ADDR_1,
                         sap_ipv6_scope[0],IPV6_ADDR_2);
-        
+
         socket_desc.i_type            = NETWORK_UDP;
         socket_desc.psz_bind_addr     = psz_addrv6;
         socket_desc.i_bind_port       = HELLO_PORT;
@@ -278,10 +283,10 @@ static void Run( intf_thread_t *p_intf )
         socket_desc.i_ttl             = 0;
         p_intf->p_private = (void*) &socket_desc;
 
-        psz_network = "ipv6"; 
+        psz_network = "ipv6";
 
        /* Create, Bind the socket, ... with the appropriate module  */
- 
+
         if( !( p_network = module_Need( p_intf, "network", psz_network ) ) )
         {
             msg_Warn( p_intf, "failed to open a connection (udp)" );
@@ -292,7 +297,7 @@ static void Run( intf_thread_t *p_intf )
         fdv6 = socket_desc.i_handle;
     }
 
-    
+
     /* read SAP packets */
     while( !p_intf->b_die )
     {
@@ -317,7 +322,20 @@ static void Run( intf_thread_t *p_intf )
     }
 
     /* Closing socket */
-    close( socket_desc.i_handle );
+    if( fd )
+    {
+        if( close( fd ) )
+        {
+            msg_Warn( p_intf, "Ohoh, unable to close the socket") ;
+        }
+    }
+    if( fdv6 )
+    {
+        if( close( fdv6 ) )
+        {
+            msg_Warn( p_intf, "Ohoh, unable to close the socket") ;
+        }
+    }
 }
 
 /********************************************************************
@@ -415,7 +433,7 @@ static int sess_toitem( intf_thread_t * p_intf, sess_descr_t * p_sd )
             if(!strcasecmp( p_sd->pp_attributes[i]->psz_field , "http-path"))
             {
                 psz_http_path = strdup(  p_sd->pp_attributes[i]->psz_value );
-                
+
             }
         }
 
@@ -606,7 +624,7 @@ static int parse_sap( char *p_packet )
         for(;p_packet[i_hlen] != 'v' && p_packet[i_hlen+1] != '=' ; i_hlen++);
         return i_hlen-1;
     }
-     
+
     return(i_hlen);
 }
 
@@ -649,8 +667,8 @@ static sess_descr_t *  parse_sdp( intf_thread_t * p_intf, char *p_packet )
 {
     sess_descr_t *  sd;
     char *psz_eof;
-   
-    unsigned int i; 
+
+    unsigned int i;
     // According to RFC 2327, the first bytes should be exactly "v="
     if((p_packet[0] != 'v') || (p_packet[1] != '='))
     {
@@ -676,11 +694,11 @@ static sess_descr_t *  parse_sdp( intf_thread_t * p_intf, char *p_packet )
     sd->psz_repeat = NULL;
     sd->psz_attribute = NULL;
     sd->psz_connection = NULL;
-    
-    
+
+
     sd->i_media      = 0;
     sd->i_attributes = 0;
-    
+
     while( *p_packet != '\0'  )
     {
 #define FIELD_COPY( p ) \
@@ -740,30 +758,41 @@ static sess_descr_t *  parse_sdp( intf_thread_t * p_intf, char *p_packet )
                     {
                         sd->pp_attributes =
                             realloc( sd->pp_attributes,
-                                    sizeof( attr_descr_t ) * 
+                                    sizeof( attr_descr_t ) *
                                     ( sd->i_attributes +1 ) );
                     }
                     else
                     {
                         sd->pp_attributes = malloc( sizeof( void * ) );
                     }
+                    if( !sd->pp_attributes )
+                    {
+                        msg_Warn( p_intf, "Out of memory !" );
+                        return NULL;
+                    }
                     sd->pp_attributes[sd->i_attributes] =
                             malloc( sizeof( attr_descr_t ) );
+                    if( ! sd->pp_attributes[sd->i_attributes])
+                    {
+                        msg_Warn( p_intf, "Out of memory !" );
+                        return NULL;
+                    }
+
                     p_packet += 2;
                     psz_eof = strchr( p_packet, ':');
                     if(psz_eof)
                         *psz_eof = '\0';
                     sd->pp_attributes[sd->i_attributes]->psz_field =
                             strdup( p_packet );
-                    sd->pp_attributes[sd->i_attributes]->psz_value = 
+                    sd->pp_attributes[sd->i_attributes]->psz_value =
                             strdup( ++psz_eof );
-                    for( i=0 ; i< 
+                    for( i=0 ; i<
                       strlen(sd->pp_attributes[sd->i_attributes]->psz_value) ;
                              i++ )
                     {
                         if(sd->pp_attributes[sd->i_attributes]->psz_value[i]
                                         =='\n' )
-                          sd->pp_attributes[sd->i_attributes]->psz_value[i]                                            =0;                    
+                          sd->pp_attributes[sd->i_attributes]->psz_value[i]                                            =0;
                     }
                     sd->i_attributes++;
                     break;
@@ -779,13 +808,17 @@ static sess_descr_t *  parse_sdp( intf_thread_t * p_intf, char *p_packet )
                     {
                         sd->pp_media = malloc( sizeof( void * ) );
                     }
-
-                    
+                    if( !sd->pp_media )
+                    {
+                        msg_Warn( p_intf, "Out of memory !" );
+                        return NULL;
+                    }
                     sd->pp_media[sd->i_media] =
                             malloc( sizeof( media_descr_t ) );
                     sd->pp_media[sd->i_media]->psz_medianame = NULL;
                     sd->pp_media[sd->i_media]->psz_mediaconnection = NULL;
-                    sd->pp_media[sd->i_media]->psz_medianame = strndup( &p_packet[2], i_field_len );
+                    sd->pp_media[sd->i_media]->psz_medianame =
+                                   strndup( &p_packet[2], i_field_len );
 
                     sd->i_media++;
                     break;
@@ -863,14 +896,14 @@ static int ismult( char *psz_uri )
     i_value = strtol( psz_uri, &psz_end, 0 );
 
     /* IPv6 */
-    if( psz_uri[0] == '[') 
+    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 ); 
-    } 
+            return( VLC_FALSE );
+    }
 
     if( *psz_end != '.' ) { return( VLC_FALSE ); }
 
@@ -885,7 +918,7 @@ static int ismult( char *psz_uri )
  * Taken from udp.c
  ******************************************************************************/
 static ssize_t NetRead( intf_thread_t *p_intf,
-                        int i_handle, int i_handle_v6, 
+                        int i_handle, int i_handle_v6,
                         byte_t *p_buffer, size_t i_len)
 {
 #ifdef UNDER_CE
@@ -898,14 +931,14 @@ static ssize_t NetRead( intf_thread_t *p_intf,
     int             i_max_handle;
 
     ssize_t i_recv=-1;
-    
+
     /* Get the max handle for select */
     if( i_handle_v6 > i_handle )
         i_max_handle = i_handle_v6;
     else
         i_max_handle = i_handle;
 
-    
+
     /* Initialize file descriptor set */
     FD_ZERO( &fds );
     if(   i_handle > 0   ) FD_SET( i_handle, &fds );
@@ -926,7 +959,7 @@ static ssize_t NetRead( intf_thread_t *p_intf,
     }
     else if( i_ret > 0 )
    {
-      /* Get the data */     
+      /* Get the data */
       if(i_handle >0)
       {
          if(FD_ISSET( i_handle, &fds ))
@@ -941,7 +974,7 @@ static ssize_t NetRead( intf_thread_t *p_intf,
             i_recv = recv( i_handle_v6, p_buffer, i_len, 0 );
          }
       }
-      
+
        if( i_recv < 0 )
         {
            msg_Err( p_intf, "recv failed (%s)", strerror(errno) );
diff --git a/src/video_output/video_output.c b/src/video_output/video_output.c
index 8eea701e54e53d1c600bb0463eaef2f2f4562ab3..334a1a8b0111d6cf7b861d2ab992ada8bc824933 100644
--- a/src/video_output/video_output.c
+++ b/src/video_output/video_output.c
@@ -5,7 +5,7 @@
  * thread, and destroy a previously oppened video output thread.
  *****************************************************************************
  * Copyright (C) 2000-2001 VideoLAN
- * $Id: video_output.c,v 1.237 2003/10/05 23:03:35 gbazin Exp $
+ * $Id: video_output.c,v 1.238 2003/10/08 10:07:22 zorglub Exp $
  *
  * Authors: Vincent Seguin <seguin@via.ecp.fr>
  *
@@ -62,6 +62,8 @@ static int FullscreenCallback( vlc_object_t *, char const *,
                                vlc_value_t, vlc_value_t, void * );
 static int DeinterlaceCallback( vlc_object_t *, char const *,
                                 vlc_value_t, vlc_value_t, void * );
+static int FilterCallback( vlc_object_t *, char const *,
+                           vlc_value_t, vlc_value_t, void * );
 
 /*****************************************************************************
  * vout_Request: find a video output thread, create one, or destroy one.
@@ -399,12 +401,12 @@ vout_thread_t * __vout_Create( vlc_object_t *p_parent,
         return NULL;
     }
 
-    p_vout->p_text_renderer_module = module_Need( p_vout, "text renderer", 
-						  NULL );
+    p_vout->p_text_renderer_module = module_Need( p_vout, "text renderer",
+                                                  NULL );
     if( p_vout->p_text_renderer_module == NULL )
     {
-	msg_Warn( p_vout, "no suitable text renderer module" );
-	p_vout->pf_add_string = NULL;
+        msg_Warn( p_vout, "no suitable text renderer module" );
+        p_vout->pf_add_string = NULL;
     }
 
     /* Create a few object variables for interface interaction */
@@ -440,6 +442,17 @@ vout_thread_t * __vout_Create( vlc_object_t *p_parent,
     }
     var_AddCallback( p_vout, "deinterlace", DeinterlaceCallback, NULL );
 
+
+    var_Create( p_vout, "filter", VLC_VAR_STRING );
+    text.psz_string = _("Filters");
+    var_Change( p_vout, "filter", VLC_VAR_SETTEXT, &text, NULL );
+    var_Change( p_vout, "filter", VLC_VAR_INHERITVALUE, &val, NULL );
+    if( var_Get( p_vout, "filter", &val ) == VLC_SUCCESS )
+    {
+        var_Set( p_vout, "filter", val );
+    }
+    var_AddCallback( p_vout, "filter", FilterCallback, NULL );
+
     /* Calculate delay created by internal caching */
     p_input_thread = (input_thread_t *)vlc_object_find( p_vout,
                                            VLC_OBJECT_INPUT, FIND_ANYWHERE );
@@ -1363,3 +1376,45 @@ static int DeinterlaceCallback( vlc_object_t *p_this, char const *psz_cmd,
     var_Set( p_vout, "intf-change", val );
     return VLC_SUCCESS;
 }
+
+static int FilterCallback( vlc_object_t *p_this, char const *psz_cmd,
+                       vlc_value_t oldval, vlc_value_t newval, void *p_data )
+{
+    vout_thread_t *p_vout = (vout_thread_t *)p_this;
+    input_thread_t *p_input;
+    vlc_value_t val;
+    unsigned int i;
+
+    p_input = (input_thread_t *)vlc_object_find( p_this, VLC_OBJECT_INPUT,
+                                                 FIND_PARENT );
+
+    if (!p_input)
+    {
+        msg_Err( p_vout, "Input not found" );
+        return( VLC_EGENERIC );
+    }
+    /* Restart the video stream */
+    vlc_mutex_lock( &p_input->stream.stream_lock );
+
+    p_vout->b_filter_change = VLC_TRUE;
+
+#define ES p_input->stream.pp_es[i]
+
+    for( i = 0 ; i < p_input->stream.i_es_number ; i++ )
+    {
+        if( ( ES->i_cat == VIDEO_ES ) && ES->p_decoder_fifo != NULL )
+        {
+            input_UnselectES( p_input, ES );
+            input_SelectES( p_input, ES );
+        }
+#undef ES
+    }
+    vlc_mutex_unlock( &p_input->stream.stream_lock );
+
+    vlc_object_release( p_input );
+
+    val.b_bool = VLC_TRUE;
+    var_Set( p_vout, "intf-change", val );
+    return VLC_SUCCESS;
+}
+