]> git.sesse.net Git - vlc/blobdiff - src/vlc.c
* modules/video_output/directx/directx.c,glwin32.c: revert backport of 13050 for...
[vlc] / src / vlc.c
index 068f226e9f834d411b3666baffc086abb6e9d3ac..52be84bc9b36d3b54db041543c3e9a8e47b64b19 100644 (file)
--- a/src/vlc.c
+++ b/src/vlc.c
@@ -1,12 +1,14 @@
 /*****************************************************************************
  * vlc.c: the vlc player
  *****************************************************************************
- * Copyright (C) 1998-2001 VideoLAN
- * $Id: vlc.c,v 1.3 2002/07/03 19:40:49 sam Exp $
+ * Copyright (C) 1998-2004 the VideoLAN team
+ * $Id$
  *
  * Authors: Vincent Seguin <seguin@via.ecp.fr>
  *          Samuel Hocevar <sam@zoy.org>
- *          Gildas Bazin <gbazin@netcourrier.com>
+ *          Gildas Bazin <gbazin@videolan.org>
+ *          Derk-Jan Hartman <hartman at videolan dot org>
+ *          Lots of other people, see the libvlc AUTHORS file
  *
  * This program is free software; you can redistribute it and/or modify
  * it under the terms of the GNU General Public License as published by
  * along with this program; if not, write to the Free Software
  * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111, USA.
  *****************************************************************************/
-#include <signal.h>                               /* SIGHUP, SIGINT, SIGKILL */
+
+#include "config.h"
+
 #include <stdio.h>                                              /* fprintf() */
 #include <stdlib.h>                                  /* putenv(), strtol(),  */
+#ifdef HAVE_SIGNAL_H
+#   include <signal.h>                            /* SIGHUP, SIGINT, SIGKILL */
+#endif
+#ifdef HAVE_TIME_H
+#   include <time.h>                                               /* time() */
+#endif
 
 #include <vlc/vlc.h>
 
 /*****************************************************************************
- * main: parse command line, start interface and spawn threads
+ * Local prototypes.
+ *****************************************************************************/
+#if !defined(WIN32) && !defined(UNDER_CE)
+static void SigHandler  ( int i_signal );
+#endif
+
+/*****************************************************************************
+ * main: parse command line, start interface and spawn threads.
  *****************************************************************************/
-int main(int i_argc, char *ppsz_argv[], char *ppsz_env[])
+int main( int i_argc, char *ppsz_argv[] )
 {
-    vlc_t *p_vlc;
-    vlc_error_t err;
+    int i_ret;
+
+#ifndef SYS_DARWIN
+    /* This clutters OSX GUI error logs */
+    fprintf( stderr, "VLC media player %s\n", VLC_Version() );
+#endif
 
-#ifdef SYS_LINUX
+#ifdef HAVE_PUTENV
 #   ifdef DEBUG
     /* Activate malloc checking routines to detect heap corruptions. */
     putenv( "MALLOC_CHECK_=2" );
@@ -44,54 +65,123 @@ int main(int i_argc, char *ppsz_argv[], char *ppsz_env[])
     /* Disable the ugly Gnome crash dialog so that we properly segfault */
     putenv( "GNOME_DISABLE_CRASH_DIALOG=1" );
 #   endif
+
+    /* If the user isn't using VLC_VERBOSE, set it to 0 by default */
+    if( getenv( "VLC_VERBOSE" ) == NULL )
+    {
+        putenv( "VLC_VERBOSE=0" );
+    }
 #endif
 
-    /* Create the vlc structure */
-    p_vlc = vlc_create();
-    if( p_vlc == NULL )
+    /* Create a libvlc structure */
+    i_ret = VLC_Create();
+    if( i_ret < 0 )
     {
-        return -1;
+        return i_ret;
     }
 
-    /* Initialize vlc */
-    err = vlc_init( p_vlc, i_argc, ppsz_argv );
-    if( err != VLC_SUCCESS )
+#if !defined(WIN32) && !defined(UNDER_CE)
+    /* Set the signal handlers. SIGTERM is not intercepted, because we need at
+     * least one method to kill the program when all other methods failed, and
+     * when we don't want to use SIGKILL.
+     * Note that we set the signals after the vlc_create call. */
+    signal( SIGINT,  SigHandler );
+    signal( SIGHUP,  SigHandler );
+    signal( SIGQUIT, SigHandler );
+
+    /* Other signals */
+    signal( SIGALRM, SIG_IGN );
+    signal( SIGPIPE, SIG_IGN );
+#endif
+
+    /* Initialize libvlc */
+    i_ret = VLC_Init( 0, i_argc, ppsz_argv );
+    if( i_ret < 0 )
     {
-        vlc_destroy( p_vlc );
-        return err;
+        VLC_Destroy( 0 );
+        return i_ret;
     }
 
-    //vlc_add( p_vlc, "/home/sam/videolan/streams/mpeg/axe.mpeg" );
+    i_ret = VLC_AddIntf( 0, NULL, VLC_TRUE, VLC_TRUE );
+
+    /* Finish the threads */
+    VLC_CleanUp( 0 );
+
+    /* Destroy the libvlc structure */
+    VLC_Destroy( 0 );
+
+    return i_ret;
+}
+
+#if !defined(WIN32) && !defined(UNDER_CE)
+/*****************************************************************************
+ * SigHandler: system signal handler
+ *****************************************************************************
+ * This function is called when a fatal signal is received by the program.
+ * It tries to end the program in a clean way.
+ *****************************************************************************/
+static void SigHandler( int i_signal )
+{
+    static time_t abort_time = 0;
+    static volatile vlc_bool_t b_die = VLC_FALSE;
+
+    /* Once a signal has been trapped, the termination sequence will be
+     * armed and subsequent signals will be ignored to avoid sending signals
+     * to a libvlc structure having been destroyed */
 
-    /* Run vlc, in non-blocking mode */
-    err = vlc_run( p_vlc );
+    if( !b_die )
+    {
+        b_die = VLC_TRUE;
+        abort_time = time( NULL );
 
-    /* Add background interfaces */
-    //{ int i; for( i=10; i--; ) vlc_add_intf( p_vlc, "dummy", 0 ); }
-    vlc_add_intf( p_vlc, "dummy", VLC_FALSE );
-    vlc_add_intf( p_vlc, "logger", VLC_FALSE );
-    //vlc_add_intf( p_vlc, "xosd", VLC_FALSE );
-    //vlc_add_intf( p_vlc, "kde", VLC_FALSE );
-    vlc_add_intf( p_vlc, "rc", VLC_FALSE );
+        fprintf( stderr, "signal %d received, terminating vlc - do it "
+                         "again in case it gets stuck\n", i_signal );
 
-    /* Add a blocking interface */
-    err = vlc_add_intf( p_vlc, NULL, VLC_TRUE );
-    if( err != VLC_SUCCESS )
+        /* Acknowledge the signal received */
+        VLC_Die( 0 );
+    }
+    else if( time( NULL ) > abort_time + 2 )
     {
-        vlc_end( p_vlc );
-        vlc_destroy( p_vlc );
-        return err;
+        /* If user asks again 1 or 2 seconds later, die badly */
+        signal( SIGINT,  SIG_DFL );
+        signal( SIGHUP,  SIG_DFL );
+        signal( SIGQUIT, SIG_DFL );
+        signal( SIGALRM, SIG_DFL );
+        signal( SIGPIPE, SIG_DFL );
+
+        fprintf( stderr, "user insisted too much, dying badly\n" );
+
+        abort();
     }
+}
+#endif
+
+#if defined(UNDER_CE)
+#   if defined( _MSC_VER ) && defined( UNDER_CE )
+#       include "vlc_common.h"
+#   endif
+/*****************************************************************************
+ * WinMain: parse command line, start interface and spawn threads. (WinCE only)
+ *****************************************************************************/
+int WINAPI WinMain( HINSTANCE hInstance, HINSTANCE hPrevInstance,
+                    LPTSTR lpCmdLine, int nCmdShow )
+{
+    char **argv, psz_cmdline[MAX_PATH];
+    int argc, i_ret;
 
-    /* Finish the interface */
-    vlc_stop( p_vlc );
+    WideCharToMultiByte( CP_ACP, 0, lpCmdLine, -1,
+                         psz_cmdline, MAX_PATH, NULL, NULL );
 
-    /* Finish all threads */
-    vlc_end( p_vlc );
+    argv = vlc_parse_cmdline( psz_cmdline, &argc );
+    argv = realloc( argv, (argc + 1) * sizeof(char *) );
+    if( !argv ) return -1;
 
-    /* Destroy the vlc structure */
-    vlc_destroy( p_vlc );
+    if( argc ) memmove( argv + 1, argv, argc * sizeof(char *) );
+    argv[0] = ""; /* Fake program path */
 
-    return 0;
-}
+    i_ret = main( argc + 1, argv );
 
+    /* No need to free the argv memory */
+    return i_ret;
+}
+#endif