/*****************************************************************************
* vlcshell.cpp: a VLC plugin for Mozilla
*****************************************************************************
- * Copyright (C) 2002 VideoLAN
+ * Copyright (C) 2002-2005 the VideoLAN team
* $Id$
*
* Authors: Samuel Hocevar <sam@zoy.org>
#include <nsISupports.h>
#include <nsMemory.h>
#include <npapi.h>
+
+/* This is from mozilla java, do we really need it? */
+#if 0
#include <jri.h>
+#endif
#if !defined(XP_MACOSX) && !defined(XP_UNIX) && !defined(XP_WIN)
#define XP_UNIX 1
# define WINDOW_TEXT "(no libvlc)"
#endif
+/* Enable/disable debugging printf's for X11 resizing */
+#undef X11_RESIZE_DEBUG
+
/*****************************************************************************
* Unix-only declarations
******************************************************************************/
# define VOUT_PLUGINS "xvideo,x11,dummy"
# define AOUT_PLUGINS "oss,dummy"
+static unsigned int i_previous_height = 100000;
+static unsigned int i_previous_width = 100000;
+
static void Redraw( Widget w, XtPointer closure, XEvent *event );
+static void Resize( Widget w, XtPointer closure, XEvent *event );
#endif
/*****************************************************************************
case NPPVpluginDescriptionString:
#if USE_LIBVLC
snprintf( psz_desc, 1000-1, PLUGIN_DESCRIPTION, VLC_Version() );
-#else
+#else /* USE_LIBVLC */
snprintf( psz_desc, 1000-1, PLUGIN_DESCRIPTION, "(disabled)" );
-#endif
+#endif /* USE_LIBVLC */
psz_desc[1000-1] = 0;
*((char **)value) = psz_desc;
return NPERR_NO_ERROR;
return eventHandled;
}
-#endif
+#endif /* XP_MACOSX */
/******************************************************************************
* General Plug-in Calls
vlc_value_t value;
int i_ret;
-#endif
+#endif /* USE_LIBVLC */
if( instance == NULL )
{
#ifdef XP_WIN
p_plugin->p_hwnd = NULL;
p_plugin->pf_wndproc = NULL;
-#endif
+#endif /* XP_WIN */
#ifdef XP_UNIX
p_plugin->window = 0;
p_plugin->p_display = NULL;
-#endif
+#endif /* XP_UNIX */
p_plugin->p_npwin = NULL;
p_plugin->i_npmode = mode;
if( !ppsz_argv[0] ) ppsz_argv[0] = "vlc";
-#else
+#else /* XP_MACOSX */
char *ppsz_argv[] =
{
"vlc"
/*, "--plugin-path", "/home/sam/videolan/vlc_MAIN/plugins"*/
};
-#endif
+#endif /* XP_MACOSX */
+
+ /* HACK: special case for loop, to have it set before playlist startup
+ */
+ for( i = 0; i < argc ; i++ )
+ {
+ if( !strcmp( argn[i], "loop" ) )
+ {
+ if( !strcmp( argv[i], "1" ) || !strcmp( argv[i], "yes" ) )
+ {
+ value.b_bool = VLC_TRUE;
+ VLC_VariableSet( p_plugin->i_vlc, "conf::loop", value );
+ }
+ }
+ }
i_ret = VLC_Init( p_plugin->i_vlc, sizeof(ppsz_argv)/sizeof(char*),
ppsz_argv );
free( home_user );
free( directory );
free( plugin_path );
-#endif
+#endif /* XP_MACOSX */
}
if( i_ret )
value.psz_string = AOUT_PLUGINS;
VLC_VariableSet( p_plugin->i_vlc, "conf::aout", value );
-#else
+#else /* USE_LIBVLC */
p_plugin->i_vlc = 1;
#endif /* USE_LIBVLC */
}
else if( !strcmp( argn[i], "autoplay" ) )
{
- if( !strcmp( argv[i], "yes" ) )
+ if( !strcmp( argv[i], "1" ) || !strcmp( argv[i], "yes" ) )
{
p_plugin->b_autoplay = 1;
}
}
#if USE_LIBVLC
- else if( !strcmp( argn[i], "loop" ) )
- {
- if( !strcmp( argv[i], "yes" ) )
- {
- value.b_bool = VLC_TRUE;
- VLC_VariableSet( p_plugin->i_vlc, "conf::loop", value );
- }
- }
else if( !strcmp( argn[i], "fullscreen" ) )
{
- if( !strcmp( argv[i], "yes" ) )
+ if( !strcmp( argv[i], "1" ) || !strcmp( argv[i], "yes" ) )
{
value.b_bool = VLC_TRUE;
VLC_VariableSet( p_plugin->i_vlc, "conf::fullscreen", value );
}
else if( !strcmp( argn[i], "mute" ) )
{
- if( !strcmp( argv[i], "yes" ) )
+ if( !strcmp( argv[i], "1" ) || !strcmp( argv[i], "yes" ) )
{
VLC_VolumeMute( p_plugin->i_vlc );
}
}
-#endif
+#endif /* USE_LIBVLC */
}
if( p_plugin->psz_target )
do
{
- fprintf( stderr, "FindWindow: %p\n", hwnd );
while( PeekMessage( &msg, (HWND)value.i_int, 0, 0, PM_REMOVE ) )
{
TranslateMessage(&msg);
}
while( (hwnd = FindWindowEx( (HWND)value.i_int, 0, 0, 0 )) );
}
-#endif
+#endif /* XP_WIN */
NPError NPP_Destroy( NPP instance, NPSavedData** save )
{
#if USE_LIBVLC
# ifdef XP_WIN
HackStopVout( p_plugin );
-# endif
+# endif /* XP_WIN */
VLC_CleanUp( p_plugin->i_vlc );
VLC_Destroy( p_plugin->i_vlc );
-#endif
+#endif /* USE_LIBVLC */
p_plugin->i_vlc = 0;
}
vlc_value_t valueporty;
Rect black_rect;
char * text;
-#endif
+#endif /* XP_MACOSX */
if( instance == NULL )
{
DrawText( text , 0 , strlen(text) );
free(text);
-#else
+#else /* XP_MACOSX */
/* FIXME: this cast sucks */
value.i_int = (int) (ptrdiff_t) (void *) window->window;
VLC_VariableSet( p_plugin->i_vlc, "drawable", value );
-#endif
+#endif /* XP_MACOSX */
-#endif
+#endif /* USE_LIBVLC */
/*
* PLUGIN DEVELOPERS:
#if !USE_LIBVLC
SetWindowLong( p_plugin->p_hwnd, GWL_WNDPROC,
(LONG)p_plugin->pf_wndproc );
-#endif
+#endif /* !USE_LIBVLC */
p_plugin->pf_wndproc = NULL;
p_plugin->p_hwnd = NULL;
}
#if !USE_LIBVLC
InvalidateRect( p_plugin->p_hwnd, NULL, TRUE );
UpdateWindow( p_plugin->p_hwnd );
-#endif
+#endif /* !USE_LIBVLC */
return NPERR_NO_ERROR;
}
#if !USE_LIBVLC
SetWindowLong( p_plugin->p_hwnd, GWL_WNDPROC,
(LONG)p_plugin->pf_wndproc );
-#endif
+#endif /* !USE_LIBVLC */
p_plugin->pf_wndproc = NULL;
p_plugin->p_hwnd = NULL;
}
#if !USE_LIBVLC
p_plugin->pf_wndproc = (WNDPROC)SetWindowLong( (HWND)window->window,
GWL_WNDPROC, (LONG)Manage );
-#endif
+#endif /* !USE_LIBVLC */
p_plugin->p_hwnd = (HWND)window->window;
SetProp( p_plugin->p_hwnd, "w00t", (HANDLE)p_plugin );
InvalidateRect( p_plugin->p_hwnd, NULL, TRUE );
UpdateWindow( p_plugin->p_hwnd );
-#endif
+#endif /* XP_WIN */
+
+ p_plugin->i_width = window->width;
+ p_plugin->i_height = window->height;
+ p_plugin->p_npwin = window;
#ifdef XP_UNIX
p_plugin->window = (Window) window->window;
- p_plugin->p_display = ((NPSetWindowCallbackStruct *)window->ws_info)->display;
+ p_plugin->p_display =
+ ((NPSetWindowCallbackStruct *)window->ws_info)->display;
+ XResizeWindow( p_plugin->p_display, p_plugin->window,
+ p_plugin->i_width, p_plugin->i_height );
Widget w = XtWindowToWidget( p_plugin->p_display, p_plugin->window );
+
XtAddEventHandler( w, ExposureMask, FALSE,
(XtEventHandler)Redraw, p_plugin );
+ XtAddEventHandler( w, StructureNotifyMask, FALSE,
+ (XtEventHandler)Resize, p_plugin );
Redraw( w, (XtPointer)p_plugin, NULL );
-#endif
-
- p_plugin->p_npwin = window;
-
- p_plugin->i_width = window->width;
- p_plugin->i_height = window->height;
+#endif /* XP_UNIX */
if( !p_plugin->b_stream )
{
{
#if USE_LIBVLC
VLC_AddTarget( p_plugin->i_vlc, p_plugin->psz_target,
- 0, 0, i_mode, PLAYLIST_END );
+ 0, 0, PLAYLIST_INSERT, 0 );
#endif
p_plugin->b_stream = VLC_TRUE;
}
VLC_AddTarget( p_plugin->i_vlc, fname, 0, 0,
PLAYLIST_APPEND | PLAYLIST_GO, PLAYLIST_END );
-#endif
+#endif /* USE_LIBVLC */
}
}
return 0;
}
-#endif
+#endif /* XP_WIN */
/******************************************************************************
* UNIX-only methods
XFreeGC( p_plugin->p_display, gc );
}
-#endif
+
+static void Resize ( Widget w, XtPointer closure, XEvent *event )
+{
+ VlcPlugin* p_plugin = (VlcPlugin*)closure;
+ int i_ret;
+ Window root_return, parent_return, * children_return;
+ Window base_window;
+ unsigned int i_nchildren;
+
+#ifdef X11_RESIZE_DEBUG
+ XWindowAttributes attr;
+
+ if( event && event->type == ConfigureNotify )
+ {
+ fprintf( stderr, "vlcshell::Resize() ConfigureNotify %d x %d, "
+ "send_event ? %s\n", event->xconfigure.width,
+ event->xconfigure.height,
+ event->xconfigure.send_event ? "TRUE" : "FALSE" );
+ }
+#endif /* X11_RESIZE_DEBUG */
+
+ if( p_plugin->i_height == i_previous_height &&
+ p_plugin->i_width == i_previous_width )
+ {
+ return;
+ }
+ i_previous_height = p_plugin->i_height;
+ i_previous_width = p_plugin->i_width;
+
+
+ i_ret = XResizeWindow( p_plugin->p_display, p_plugin->window,
+ p_plugin->i_width, p_plugin->i_height );
+
+#ifdef X11_RESIZE_DEBUG
+ fprintf( stderr,
+ "vlcshell::Resize() XResizeWindow(owner) returned %d\n", i_ret );
+
+ XGetWindowAttributes ( p_plugin->p_display, p_plugin->window, &attr );
+
+ /* X is asynchronous, so the current size reported here is not
+ necessarily the requested size as the Resize request may not
+ yet have been handled by the plugin host */
+ fprintf( stderr, "vlcshell::Resize() current (owner) size %d x %d\n",
+ attr.width, attr.height );
+#endif /* X11_RESIZE_DEBUG */
+
+ XQueryTree( p_plugin->p_display, p_plugin->window,
+ &root_return, &parent_return, &children_return,
+ &i_nchildren );
+
+ if( i_nchildren > 0 )
+ {
+ /* XXX: Make assumptions related to the window parenting structure in
+ vlc/modules/video_output/x11/xcommon.c */
+ base_window = children_return[i_nchildren - 1];
+
+#ifdef X11_RESIZE_DEBUG
+ fprintf( stderr, "vlcshell::Resize() got %d children\n", i_nchildren );
+ fprintf( stderr, "vlcshell::Resize() got base_window %p\n",
+ base_window );
+#endif /* X11_RESIZE_DEBUG */
+
+ i_ret = XResizeWindow( p_plugin->p_display, base_window,
+ p_plugin->i_width, p_plugin->i_height );
+
+#ifdef X11_RESIZE_DEBUG
+ fprintf( stderr,
+ "vlcshell::Resize() XResizeWindow(base) returned %d\n",
+ i_ret );
+
+ XGetWindowAttributes( p_plugin->p_display, base_window, &attr );
+
+ fprintf( stderr, "vlcshell::Resize() new size %d x %d\n",
+ attr.width, attr.height );
+#endif /* X11_RESIZE_DEBUG */
+ }
+}
+
+#endif /* XP_UNIX */