]> git.sesse.net Git - vlc/blobdiff - modules/misc/screensaver.c
Removes trailing spaces. Removes tabs.
[vlc] / modules / misc / screensaver.c
index 28b6196a4b63875e7cf24fe94f207aaa36a7f395..f252d66f808a586085667d94908c23a46b85c26f 100644 (file)
 /*****************************************************************************
  * Preamble
  *****************************************************************************/
-#include <stdlib.h>
 
 #include <vlc/vlc.h>
-#include <vlc/intf.h>
-#include <vlc/aout.h>
-#include <vlc/vout.h>
+#include <vlc_input.h>
+#include <vlc_interface.h>
+#include <vlc_aout.h>
+#include <vlc_vout.h>
 
 #ifdef HAVE_DBUS
 
@@ -111,7 +111,7 @@ static void Deactivate( vlc_object_t *p_this )
     if( p_intf->p_sys->p_connection )
     {
 #  ifdef HAVE_DBUS_2
-        dbus_connection_close( p_intf->p_sys->p_connection );
+        dbus_connection_unref( p_intf->p_sys->p_connection );
 #  else
         dbus_connection_disconnect( p_intf->p_sys->p_connection );
 #  endif
@@ -145,28 +145,36 @@ static void Run( intf_thread_t *p_intf )
         msleep( INTF_IDLE_SLEEP*5 ); // 250ms
 
         /* Check screensaver every 30 seconds */
-        if( ++i_lastcall > 300 )
+        if( ++i_lastcall > 120 )
         {
             vlc_object_t *p_vout;
             p_vout = vlc_object_find( p_intf, VLC_OBJECT_VOUT, FIND_ANYWHERE );
             /* If there is a video output, disable xscreensaver */
             if( p_vout )
             {
+                input_thread_t *p_input = vlc_object_find( p_vout, VLC_OBJECT_INPUT, FIND_PARENT );
                 vlc_object_release( p_vout );
+                if( p_input )
+                {
+                    if( PLAYING_S == p_input->i_state )
+                    {
+                        /* http://www.jwz.org/xscreensaver/faq.html#dvd */
 
-                /* http://www.jwz.org/xscreensaver/faq.html#dvd */
-                system( "xscreensaver-command -deactivate >&- 2>&- &" );
+                        system( "xscreensaver-command -deactivate >&- 2>&- &" );
 
-/* If we have dbug support, let's communicate directly with gnome-screensaver
-   else, run gnome-screensaver-command */
+                        /* If we have dbus support, let's communicate directly
+                           with gnome-screensave else, run
+                           gnome-screensaver-command */
 #ifdef HAVE_DBUS
-                poke_screensaver( p_intf, p_intf->p_sys->p_connection );
+                        poke_screensaver( p_intf, p_intf->p_sys->p_connection );
 #else
-                system( "gnome-screensaver-command --poke >&- 2>&- &" );
+                        system( "gnome-screensaver-command --poke >&- 2>&- &" );
 #endif
-                /* FIXME: add support for other screensavers */
+                        /* FIXME: add support for other screensavers */
+                    }
+                    vlc_object_release( p_input );
+                }
             }
-
             i_lastcall = 0;
         }
     }
@@ -200,7 +208,10 @@ static void poke_screensaver( intf_thread_t *p_intf,
 #   ifdef SCREENSAVER_DEBUG
         msg_Dbg( p_intf, "found a running gnome-screensaver instance" );
 #   endif
+        /* gnome-screensaver changed it's D-Bus interface, so we need both */
         screensaver_send_message_void( p_intf, p_connection, "Poke" );
+        screensaver_send_message_void( p_intf, p_connection,
+                "SimulateUserActivity" );
     }
 #   ifdef SCREENSAVER_DEBUG
     else