*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
- * as published by the Free Software Foundation; either version 2.0
+ * as published by the Free Software Foundation; either version 2
* of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
- * You should have received a copy of the GNU Lesser General Public
+ * You should have received a copy of the GNU General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
****************************************************************************/
static int Open (vlc_object_t *);
static void Close(vlc_object_t *);
-#define XID_TEXT N_("ID of the video output X window")
-#define XID_LONGTEXT N_( \
- "VLC can embed its video output in an existing X11 window. " \
- "This is the X identifier of that window (0 means none).")
-
/*
* Module descriptor
*/
set_description (N_("Embedded window video"))
set_category (CAT_VIDEO)
set_subcategory (SUBCAT_VIDEO_VOUT)
- set_capability ("vout window xid", 70)
+ set_capability ("vout window hwnd", 0)
set_callbacks (Open, Close)
- add_integer ("drawable-xid", 0, NULL, XID_TEXT, XID_LONGTEXT, true)
- change_unsaveable ()
- //add_integer ("drawable-hwnd", 0, NULL, HWN_TEXT, HWND_LONGTEXT, true) /* How to ? */
- // change_unsaveable ()
+ add_shortcut ("embed-hwnd")
vlc_module_end ()
static int Control (vout_window_t *, int, va_list);
-/* TODO: move to vlc_variables.h */
-static inline void *var_GetAddress (vlc_object_t *o, const char *name)
-{
- vlc_value_t val;
- return var_Get (o, name, &val) ? NULL : val.p_address;
-}
-
static vlc_mutex_t serializer = VLC_STATIC_MUTEX;
/**
static int Open (vlc_object_t *obj)
{
vout_window_t *wnd = (vout_window_t *)obj;
- const char *varname;
- bool ptr;
-
- switch (wnd->cfg->type)
- {
- case VOUT_WINDOW_TYPE_XID:
- varname = "drawable-xid";
- ptr = false;
- break;
- case VOUT_WINDOW_TYPE_HWND:
- varname = "drawable-hwnd";
- ptr = true;
- break;
- default:
- return VLC_EGENERIC;
- }
-
void **used, *val;
size_t n = 0;
- if (var_Create (obj->p_libvlc, "drawables-in-use", VLC_VAR_ADDRESS)
- || var_Create (obj, varname, VLC_VAR_DOINHERIT
- | (ptr ? VLC_VAR_ADDRESS : VLC_VAR_INTEGER)))
+ if (var_Create (obj->p_libvlc, "hwnd-in-use", VLC_VAR_ADDRESS)
+ || var_Create (obj, "drawable-hwnd", VLC_VAR_DOINHERIT | VLC_VAR_ADDRESS))
return VLC_ENOMEM;
- if (ptr)
- val = var_GetAddress (obj, varname);
- else
- val = (void *)(uintptr_t)var_GetInteger (obj, varname);
- var_Destroy (obj, varname);
+ val = var_GetAddress (obj, "drawable-hwnd");
+ var_Destroy (obj, "drawable-hwnd");
/* Keep a list of busy drawables, so we don't overlap videos if there are
* more than one video track in the stream. */
vlc_mutex_lock (&serializer);
- /* TODO: per-type list of busy drawables */
- used = var_GetAddress (VLC_OBJECT (obj->p_libvlc), "drawables-in-use");
+ used = var_GetAddress (obj->p_libvlc, "hwnd-in-use");
if (used != NULL)
{
while (used[n] != NULL)
{
used[n] = val;
used[n + 1] = NULL;
- var_SetAddress (obj->p_libvlc, "drawables-in-use", used);
+ var_SetAddress (obj->p_libvlc, "hwnd-in-use", used);
}
else
{
skip:
- msg_Warn (wnd, "drawable %p is busy", val);
+ msg_Warn (wnd, "HWND %p is busy", val);
val = NULL;
}
vlc_mutex_unlock (&serializer);
if (val == NULL)
return VLC_EGENERIC;
- if (ptr)
- wnd->handle.hwnd = val;
- else
- wnd->handle.xid = (uintptr_t)val;
-
- /* FIXME: check that X server matches --x11-display (if specified) */
- /* FIXME: get window size (in platform-dependent ways) */
-
+ wnd->handle.hwnd = val;
wnd->control = Control;
wnd->sys = val;
return VLC_SUCCESS;
/* Remove this drawable from the list of busy ones */
vlc_mutex_lock (&serializer);
- used = var_GetAddress (VLC_OBJECT (obj->p_libvlc), "drawables-in-use");
+ used = var_GetAddress (obj->p_libvlc, "hwnd-in-use");
assert (used);
while (used[n] != val)
{
while (used[++n] != NULL);
if (n == 0)
- /* should not be needed (var_Destroy...) but better safe than sorry: */
- var_SetAddress (obj->p_libvlc, "drawables-in-use", NULL);
+ var_SetAddress (obj->p_libvlc, "hwnd-in-use", NULL);
vlc_mutex_unlock (&serializer);
if (n == 0)
free (used);
/* Variables are reference-counted... */
- var_Destroy (obj->p_libvlc, "drawables-in-use");
+ var_Destroy (obj->p_libvlc, "hwnd-in-use");
}
static int Control (vout_window_t *wnd, int query, va_list ap)
{
+ VLC_UNUSED( ap );
+
switch (query)
{
case VOUT_WINDOW_SET_SIZE: /* not allowed */
- case VOUT_WINDOW_SET_ON_TOP: /* not allowed either, would be ugly */
+ case VOUT_WINDOW_SET_STATE: /* not allowed either, would be ugly */
return VLC_EGENERIC;
default:
msg_Warn (wnd, "unsupported control query %d", query);