]> git.sesse.net Git - vlc/blobdiff - src/vlc.c
- <unistd.h> is needed for fork and execl
[vlc] / src / vlc.c
index fa6810cf383527a06e27158a45a75ce38028f554..b7870470188238afddd8e5202470d741f9af35d7 100644 (file)
--- a/src/vlc.c
+++ b/src/vlc.c
@@ -157,6 +157,9 @@ static void SigHandler( int i_signal )
 #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)
  *****************************************************************************/
@@ -166,17 +169,17 @@ int WINAPI WinMain( HINSTANCE hInstance, HINSTANCE hPrevInstance,
     char **argv, psz_cmdline[MAX_PATH];
     int argc, i_ret;
 
-    WideCharToMultiByte( CP_ACP, WC_DEFAULTCHAR, lpCmdLine, -1,
+    WideCharToMultiByte( CP_ACP, 0, lpCmdLine, -1,
                          psz_cmdline, MAX_PATH, NULL, NULL );
 
     argv = vlc_parse_cmdline( psz_cmdline, &argc );
     argv = realloc( argv, (argc + 1) * sizeof(char *) );
     if( !argv ) return -1;
 
-    if( argc ) memmove( argv + 1, argv, argc );
-    argv[0] = strdup(""); /* Fake program path */
+    if( argc ) memmove( argv + 1, argv, argc * sizeof(char *) );
+    argv[0] = ""; /* Fake program path */
 
-    i_ret = main( argc, argv );
+    i_ret = main( argc + 1, argv );
 
     /* No need to free the argv memory */
     return i_ret;