Commit c1482fe5 authored by Rocky Bernstein's avatar Rocky Bernstein

intf.c, vcdplayer.c: Add code for multi-default selection lists. But

this required new libvcdinfo API - so change to configure.ac for
pending new libcdio/vcdimager releases.

Additional libvcdinfo routines also means less VCD twidling inside vlc
code, thus simplifying what is already a bit complicated and likely to
get more so.
parent 2d037953
dnl Autoconf settings for vlc dnl Autoconf settings for vlc
dnl $Id: configure.ac,v 1.117 2003/11/22 18:11:22 gbazin Exp $ dnl $Id: configure.ac,v 1.118 2003/11/23 03:58:33 rocky Exp $
AC_INIT(vlc,0.6.3-cvs) AC_INIT(vlc,0.6.3-cvs)
...@@ -1528,14 +1528,14 @@ AC_ARG_ENABLE(vcdx, ...@@ -1528,14 +1528,14 @@ AC_ARG_ENABLE(vcdx,
if test "${enable_vcdx}" != "no" if test "${enable_vcdx}" != "no"
then then
PKG_CHECK_MODULES(LIBCDIO, libcdio >= 0.63, PKG_CHECK_MODULES(LIBCDIO, libcdio >= 0.65,
[enable_cdda="no" [enable_cdda="no"
AX_ADD_LDFLAGS([cddax],[$LIBCDIO_LIBS]) AX_ADD_LDFLAGS([cddax],[$LIBCDIO_LIBS])
AX_ADD_CFLAGS([cddax],[$LIBCDIO_CFLAGS]) AX_ADD_CFLAGS([cddax],[$LIBCDIO_CFLAGS])
AX_ADD_PLUGINS([cddax])], AX_ADD_PLUGINS([cddax])],
[AC_MSG_WARN(libcdio library not found)]) [AC_MSG_WARN(libcdio library not found)])
PKG_CHECK_MODULES(VCDINFO, libvcdinfo >= 0.7.18-cdio, PKG_CHECK_MODULES(VCDINFO, libvcdinfo >= 0.7.20-cdio,
[enable_vcd="no" [enable_vcd="no"
AX_ADD_LDFLAGS([vcdx],[$VCDINFO_LIBS]) AX_ADD_LDFLAGS([vcdx],[$VCDINFO_LIBS])
AX_ADD_CFLAGS([vcdx],[$VCDINFO_CFLAGS]) AX_ADD_CFLAGS([vcdx],[$VCDINFO_CFLAGS])
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
* intf.c: Video CD interface to handle user interaction and still time * intf.c: Video CD interface to handle user interaction and still time
***************************************************************************** *****************************************************************************
* Copyright (C) 2002 VideoLAN * Copyright (C) 2002 VideoLAN
* $Id: intf.c,v 1.3 2003/11/09 18:06:11 rocky Exp $ * $Id: intf.c,v 1.4 2003/11/23 03:58:33 rocky Exp $
* *
* Authors: Rocky Bernstein <rocky@panix.com> * Authors: Rocky Bernstein <rocky@panix.com>
* from DVD code by Stphane Borel <stef@via.ecp.fr> * from DVD code by Stphane Borel <stef@via.ecp.fr>
...@@ -203,8 +203,9 @@ static void RunIntf( intf_thread_t *p_intf ) ...@@ -203,8 +203,9 @@ static void RunIntf( intf_thread_t *p_intf )
dbg_print( INPUT_DBG_EVENT, "ACTIONID_NAV_ACTIVATE" ); dbg_print( INPUT_DBG_EVENT, "ACTIONID_NAV_ACTIVATE" );
if ( vcdplayer_pbc_is_on( p_vcd ) && number_addend != 0 ) { if ( vcdplayer_pbc_is_on( p_vcd ) && number_addend != 0 ) {
lid_t next_num=vcdplayer_selection2lid(p_input, lid_t next_num=vcdinfo_selection_get_lid(p_vcd->vcd,
number_addend); itemid.num,
number_addend);
if (VCDINFO_INVALID_LID != next_num) { if (VCDINFO_INVALID_LID != next_num) {
itemid.num = next_num; itemid.num = next_num;
itemid.type = VCDINFO_ITEM_TYPE_LID; itemid.type = VCDINFO_ITEM_TYPE_LID;
......
...@@ -3,7 +3,7 @@ ...@@ -3,7 +3,7 @@
* using libcdio, libvcd and libvcdinfo * using libcdio, libvcd and libvcdinfo
***************************************************************************** *****************************************************************************
* Copyright (C) 2003 Rocky Bernstein <rocky@panix.com> * Copyright (C) 2003 Rocky Bernstein <rocky@panix.com>
* $Id: vcdplayer.c,v 1.2 2003/11/09 00:52:32 rocky Exp $ * $Id: vcdplayer.c,v 1.3 2003/11/23 03:58:33 rocky Exp $
* *
* This program is free software; you can redistribute it and/or modify * 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 * it under the terms of the GNU General Public License as published by
...@@ -50,61 +50,6 @@ vcdplayer_pbc_is_on(const thread_vcd_data_t *p_vcd) ...@@ -50,61 +50,6 @@ vcdplayer_pbc_is_on(const thread_vcd_data_t *p_vcd)
return VCDINFO_INVALID_ENTRY != p_vcd->cur_lid; return VCDINFO_INVALID_ENTRY != p_vcd->cur_lid;
} }
lid_t
vcdplayer_selection2lid ( input_thread_t *p_input, int entry_num )
{
/* FIXME: Some of this probably gets moved to vcdinfo. */
/* Convert selection number to lid and then entry number...*/
thread_vcd_data_t * p_vcd= (thread_vcd_data_t *)p_input->p_access_data;
unsigned int offset;
unsigned int bsn=vcdinf_get_bsn(p_vcd->pxd.psd);
vcdinfo_obj_t *obj = p_vcd->vcd;
dbg_print( (INPUT_DBG_CALL|INPUT_DBG_PBC),
"Called lid %u, entry_num %d bsn %d", p_vcd->cur_lid,
entry_num, bsn);
if ( (entry_num - bsn + 1) > 0) {
offset = vcdinfo_lid_get_offset(obj, p_vcd->cur_lid, entry_num-bsn+1);
} else {
LOG_ERR( "Selection number %u too small. bsn %u", entry_num, bsn );
return VCDINFO_INVALID_LID;
}
if (offset != VCDINFO_INVALID_OFFSET) {
vcdinfo_offset_t *ofs;
int old = entry_num;
switch (offset) {
case PSD_OFS_DISABLED:
LOG_ERR( "Selection %u disabled", entry_num );
return VCDINFO_INVALID_LID;
case PSD_OFS_MULTI_DEF:
LOG_ERR( "Selection %u multi_def", entry_num );
return VCDINFO_INVALID_LID;
case PSD_OFS_MULTI_DEF_NO_NUM:
LOG_ERR( "Selection %u multi_def_no_num", entry_num );
return VCDINFO_INVALID_LID;
default: ;
}
ofs = vcdinfo_get_offset_t(obj, offset);
if (NULL == ofs) {
LOG_ERR( "error in vcdinfo_get_offset" );
return -1;
}
dbg_print(INPUT_DBG_PBC,
"entry %u turned into selection lid %u",
old, ofs->lid);
return ofs->lid;
} else {
LOG_ERR( "invalid or unset entry %u", entry_num );
return VCDINFO_INVALID_LID;
}
}
static void static void
vcdplayer_update_entry( input_thread_t * p_input, uint16_t ofs, vcdplayer_update_entry( input_thread_t * p_input, uint16_t ofs,
uint16_t *entry, const char *label) uint16_t *entry, const char *label)
...@@ -294,7 +239,9 @@ vcdplayer_pbc_nav ( input_thread_t * p_input ) ...@@ -294,7 +239,9 @@ vcdplayer_pbc_nav ( input_thread_t * p_input )
unsigned int bsn=vcdinf_get_bsn(p_vcd->pxd.psd); unsigned int bsn=vcdinf_get_bsn(p_vcd->pxd.psd);
int rand_selection=bsn + int rand_selection=bsn +
(int) ((num_selections+0.0)*rand()/(RAND_MAX+1.0)); (int) ((num_selections+0.0)*rand()/(RAND_MAX+1.0));
lid_t rand_lid=vcdplayer_selection2lid (p_input, rand_selection); lid_t rand_lid=vcdinfo_selection_get_lid (p_vcd->vcd,
p_vcd->cur_lid,
rand_selection);
itemid.num = rand_lid; itemid.num = rand_lid;
itemid.type = VCDINFO_ITEM_TYPE_LID; itemid.type = VCDINFO_ITEM_TYPE_LID;
dbg_print(INPUT_DBG_PBC, "random selection %d, lid: %d", dbg_print(INPUT_DBG_PBC, "random selection %d, lid: %d",
...@@ -378,7 +325,6 @@ vcdplayer_play_default( input_thread_t * p_input ) ...@@ -378,7 +325,6 @@ vcdplayer_play_default( input_thread_t * p_input )
{ {
thread_vcd_data_t *p_vcd= (thread_vcd_data_t *)p_input->p_access_data; thread_vcd_data_t *p_vcd= (thread_vcd_data_t *)p_input->p_access_data;
vcdinfo_obj_t *obj = p_vcd->vcd;
vcdinfo_itemid_t itemid; vcdinfo_itemid_t itemid;
dbg_print( (INPUT_DBG_CALL|INPUT_DBG_PBC), dbg_print( (INPUT_DBG_CALL|INPUT_DBG_PBC),
...@@ -388,24 +334,18 @@ vcdplayer_play_default( input_thread_t * p_input ) ...@@ -388,24 +334,18 @@ vcdplayer_play_default( input_thread_t * p_input )
if (vcdplayer_pbc_is_on(p_vcd)) { if (vcdplayer_pbc_is_on(p_vcd)) {
vcdinfo_lid_get_pxd(obj, &(p_vcd->pxd), p_vcd->cur_lid); lid_t lid=vcdinfo_get_multi_default_lid(p_vcd->vcd, p_vcd->cur_lid,
itemid.num);
switch (p_vcd->pxd.descriptor_type) {
case PSD_TYPE_SELECTION_LIST:
case PSD_TYPE_EXT_SELECTION_LIST:
if (p_vcd->pxd.psd == NULL) return false;
vcdplayer_update_entry( p_input,
vcdinfo_get_default_offset(p_vcd->vcd,
p_vcd->cur_lid),
&itemid.num, "default");
break;
case PSD_TYPE_PLAY_LIST: if (VCDINFO_INVALID_LID != lid) {
case PSD_TYPE_END_LIST: itemid.num = lid;
case PSD_TYPE_COMMAND_LIST: itemid.type = VCDINFO_ITEM_TYPE_LID;
LOG_WARN( "There is no PBC 'default' selection here" ); dbg_print(INPUT_DBG_PBC, "DEFAULT to %d\n", itemid.num);
return false; } else {
dbg_print(INPUT_DBG_PBC, "no DEFAULT for LID %d\n", p_vcd->cur_lid);
} }
} else { } else {
/* PBC is not on. "default" selection beginning of current /* PBC is not on. "default" selection beginning of current
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment