Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc-1.1
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Redmine
Redmine
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Operations
Operations
Metrics
Environments
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
videolan
vlc-1.1
Commits
e5858d4b
Commit
e5858d4b
authored
Dec 16, 2005
by
Clément Stenac
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Add multi-item support to cdda module (default enabled) - Refs:#459
parent
b020cf3a
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
214 additions
and
39 deletions
+214
-39
modules/access/cdda.c
modules/access/cdda.c
+214
-39
No files found.
modules/access/cdda.c
View file @
e5858d4b
...
@@ -33,6 +33,8 @@
...
@@ -33,6 +33,8 @@
#include "codecs.h"
#include "codecs.h"
#include "vcd/cdrom.h"
#include "vcd/cdrom.h"
#include <vlc_playlist.h>
/*****************************************************************************
/*****************************************************************************
* Module descriptior
* Module descriptior
*****************************************************************************/
*****************************************************************************/
...
@@ -55,6 +57,8 @@ vlc_module_begin();
...
@@ -55,6 +57,8 @@ vlc_module_begin();
add_usage_hint
(
N_
(
"[cdda:][device][@[track]]"
)
);
add_usage_hint
(
N_
(
"[cdda:][device][@[track]]"
)
);
add_integer
(
"cdda-caching"
,
DEFAULT_PTS_DELAY
/
1000
,
NULL
,
CACHING_TEXT
,
add_integer
(
"cdda-caching"
,
DEFAULT_PTS_DELAY
/
1000
,
NULL
,
CACHING_TEXT
,
CACHING_LONGTEXT
,
VLC_TRUE
);
CACHING_LONGTEXT
,
VLC_TRUE
);
add_bool
(
"cdda-separate-tracks"
,
VLC_TRUE
,
NULL
,
NULL
,
NULL
,
VLC_TRUE
);
add_integer
(
"cdda-track"
,
-
1
,
NULL
,
NULL
,
NULL
,
VLC_TRUE
);
add_shortcut
(
"cdda"
);
add_shortcut
(
"cdda"
);
add_shortcut
(
"cddasimple"
);
add_shortcut
(
"cddasimple"
);
vlc_module_end
();
vlc_module_end
();
...
@@ -82,12 +86,19 @@ struct access_sys_t
...
@@ -82,12 +86,19 @@ struct access_sys_t
/* Wave header for the output data */
/* Wave header for the output data */
WAVEHEADER
waveheader
;
WAVEHEADER
waveheader
;
vlc_bool_t
b_header
;
vlc_bool_t
b_header
;
vlc_bool_t
b_separate_items
;
vlc_bool_t
b_single_track
;
int
i_track
;
};
};
static
block_t
*
Block
(
access_t
*
);
static
block_t
*
Block
(
access_t
*
);
static
int
Seek
(
access_t
*
,
int64_t
);
static
int
Seek
(
access_t
*
,
int64_t
);
static
int
Control
(
access_t
*
,
int
,
va_list
);
static
int
Control
(
access_t
*
,
int
,
va_list
);
static
int
GetTracks
(
access_t
*
p_access
,
vlc_bool_t
b_separate
,
playlist_t
*
p_playlist
,
playlist_item_t
*
p_parent
);
/*****************************************************************************
/*****************************************************************************
* Open: open cdda
* Open: open cdda
*****************************************************************************/
*****************************************************************************/
...
@@ -98,7 +109,14 @@ static int Open( vlc_object_t *p_this )
...
@@ -98,7 +109,14 @@ static int Open( vlc_object_t *p_this )
vcddev_t
*
vcddev
;
vcddev_t
*
vcddev
;
char
*
psz_name
;
char
*
psz_name
;
int
i
;
vlc_bool_t
b_separate_requested
;
vlc_bool_t
b_play
=
VLC_FALSE
;
input_thread_t
*
p_input
;
playlist_item_t
*
p_item
=
NULL
;
playlist_t
*
p_playlist
=
NULL
;
int
i_ret
;
int
i_track
;
if
(
!
p_access
->
psz_path
||
!*
p_access
->
psz_path
)
if
(
!
p_access
->
psz_path
||
!*
p_access
->
psz_path
)
{
{
...
@@ -137,39 +155,73 @@ static int Open( vlc_object_t *p_this )
...
@@ -137,39 +155,73 @@ static int Open( vlc_object_t *p_this )
p_access
->
p_sys
=
p_sys
=
malloc
(
sizeof
(
access_sys_t
)
);
p_access
->
p_sys
=
p_sys
=
malloc
(
sizeof
(
access_sys_t
)
);
memset
(
p_sys
,
0
,
sizeof
(
access_sys_t
)
);
memset
(
p_sys
,
0
,
sizeof
(
access_sys_t
)
);
p_sys
->
vcddev
=
vcddev
;
p_sys
->
vcddev
=
vcddev
;
p_sys
->
b_separate_items
=
VLC_FALSE
;
p_sys
->
b_single_track
=
VLC_FALSE
;
p_sys
->
b_header
=
VLC_FALSE
;
p_sys
->
b_header
=
VLC_FALSE
;
/* We read the Table Of Content information */
b_separate_requested
=
var_CreateGetBool
(
p_access
,
p_sys
->
i_titles
=
ioctl_GetTracksMap
(
VLC_OBJECT
(
p_access
),
"cdda-separate-tracks"
);
p_sys
->
vcddev
,
&
p_sys
->
p_sectors
);
if
(
p_sys
->
i_titles
<
0
)
/* We only do separate items if the whole disc is requested -
* Dirty hack we access some private data ! */
p_input
=
(
input_thread_t
*
)(
p_access
->
p_parent
);
/* Do we play a single track ? */
i_track
=
var_CreateGetInteger
(
p_access
,
"cdda-track"
);
if
(
b_separate_requested
&&
p_input
->
input
.
i_title_start
==
-
1
&&
i_track
<=
0
)
{
{
msg_Err
(
p_access
,
"unable to count tracks"
);
p_sys
->
b_separate_items
=
VLC_TRUE
;
goto
error
;
}
}
else
if
(
p_sys
->
i_titles
<=
0
)
if
(
i_track
>
0
)
{
{
msg_Err
(
p_access
,
"no audio tracks found"
)
;
p_sys
->
b_single_track
=
VLC_TRUE
;
goto
error
;
p_sys
->
i_track
=
i_track
-
1
;
}
}
/* Build title table */
msg_Dbg
(
p_access
,
"Separate items : %i - Single track : %i"
,
for
(
i
=
0
;
i
<
p_sys
->
i_titles
;
i
++
)
p_sys
->
b_separate_items
,
p_sys
->
b_single_track
);
if
(
p_sys
->
b_separate_items
)
{
{
input_title_t
*
t
=
p_sys
->
title
[
i
]
=
vlc_input_title_New
();
p_playlist
=
(
playlist_t
*
)
vlc_object_find
(
p_access
,
VLC_OBJECT_PLAYLIST
,
FIND_ANYWHERE
);
msg_Dbg
(
p_access
,
"title[%d] start=%d"
,
i
,
p_sys
->
p_sectors
[
i
]
);
if
(
!
p_playlist
)
return
VLC_EGENERIC
;
msg_Dbg
(
p_access
,
"title[%d] end=%d"
,
i
,
p_sys
->
p_sectors
[
i
+
1
]
);
asprintf
(
&
t
->
psz_name
,
_
(
"Track %i"
),
i
+
1
);
/* Let's check if we need to play */
t
->
i_size
=
(
p_sys
->
p_sectors
[
i
+
1
]
-
p_sys
->
p_sectors
[
i
]
)
*
if
(
&
p_playlist
->
status
.
p_item
->
input
==
(
int64_t
)
CDDA_DATA_SIZE
;
((
input_thread_t
*
)
p_access
->
p_parent
)
->
input
.
p_item
)
{
p_item
=
p_playlist
->
status
.
p_item
;
b_play
=
VLC_TRUE
;
msg_Dbg
(
p_access
,
"starting Audio CD playback"
);
}
else
{
input_item_t
*
p_current
=
(
(
input_thread_t
*
)
p_access
->
p_parent
)
->
input
.
p_item
;
p_item
=
playlist_LockItemGetByInput
(
p_playlist
,
p_current
);
msg_Dbg
(
p_access
,
"not starting Audio CD playback"
);
t
->
i_length
=
I64C
(
1000000
)
*
t
->
i_size
/
44100
/
4
;
if
(
!
p_item
)
{
msg_Dbg
(
p_playlist
,
"unable to find item in playlist"
);
return
-
1
;
}
b_play
=
VLC_FALSE
;
}
}
}
p_sys
->
i_sector
=
p_sys
->
p_sectors
[
0
];
/* We read the Table Of Content information */
p_access
->
info
.
i_size
=
p_sys
->
title
[
0
]
->
i_size
;
if
(
!
p_sys
->
b_single_track
)
{
i_ret
=
GetTracks
(
p_access
,
p_sys
->
b_separate_items
,
p_playlist
,
p_item
);
if
(
i_ret
<
0
)
{
goto
error
;
}
}
/* Build a WAV header for the output data */
/* Build a WAV header for the output data */
memset
(
&
p_sys
->
waveheader
,
0
,
sizeof
(
WAVEHEADER
)
);
memset
(
&
p_sys
->
waveheader
,
0
,
sizeof
(
WAVEHEADER
)
);
...
@@ -189,10 +241,31 @@ static int Open( vlc_object_t *p_this )
...
@@ -189,10 +241,31 @@ static int Open( vlc_object_t *p_this )
p_sys
->
waveheader
.
DataChunkID
=
VLC_FOURCC
(
'd'
,
'a'
,
't'
,
'a'
);
p_sys
->
waveheader
.
DataChunkID
=
VLC_FOURCC
(
'd'
,
'a'
,
't'
,
'a'
);
p_sys
->
waveheader
.
DataLength
=
0
;
/* we just don't know */
p_sys
->
waveheader
.
DataLength
=
0
;
/* we just don't know */
p_access
->
info
.
i_update
|=
INPUT_UPDATE_META
;
/* Only update META if we are in old mode */
if
(
!
p_sys
->
b_separate_items
&&
!
p_sys
->
b_single_track
)
{
p_access
->
info
.
i_update
|=
INPUT_UPDATE_META
;
}
/* Position on the right sector and update size */
if
(
p_sys
->
b_single_track
)
{
p_sys
->
i_sector
=
p_sys
->
p_sectors
[
p_sys
->
i_track
];
p_access
->
info
.
i_size
=
(
p_sys
->
p_sectors
[
p_sys
->
i_track
+
1
]
-
p_sys
->
p_sectors
[
p_sys
->
i_track
]
)
*
(
int64_t
)
CDDA_DATA_SIZE
;
}
/* PTS delay */
/* PTS delay */
var_Create
(
p_access
,
"cdda-caching"
,
VLC_VAR_INTEGER
|
VLC_VAR_DOINHERIT
);
var_Create
(
p_access
,
"cdda-caching"
,
VLC_VAR_INTEGER
|
VLC_VAR_DOINHERIT
);
if
(
b_play
)
{
playlist_Control
(
p_playlist
,
PLAYLIST_VIEWPLAY
,
p_playlist
->
status
.
i_view
,
p_playlist
->
status
.
p_item
,
NULL
);
}
return
VLC_SUCCESS
;
return
VLC_SUCCESS
;
error:
error:
...
@@ -228,6 +301,8 @@ static block_t *Block( access_t *p_access )
...
@@ -228,6 +301,8 @@ static block_t *Block( access_t *p_access )
int
i_blocks
=
CDDA_BLOCKS_ONCE
;
int
i_blocks
=
CDDA_BLOCKS_ONCE
;
block_t
*
p_block
;
block_t
*
p_block
;
if
(
p_sys
->
b_separate_items
)
p_access
->
info
.
b_eof
=
VLC_TRUE
;
/* Check end of file */
/* Check end of file */
if
(
p_access
->
info
.
b_eof
)
return
NULL
;
if
(
p_access
->
info
.
b_eof
)
return
NULL
;
...
@@ -240,28 +315,45 @@ static block_t *Block( access_t *p_access )
...
@@ -240,28 +315,45 @@ static block_t *Block( access_t *p_access )
return
p_block
;
return
p_block
;
}
}
/* Check end of title */
/* Check end of title
- Single track
*/
while
(
p_sys
->
i_sector
>=
p_sys
->
p_sectors
[
p_access
->
info
.
i_title
+
1
]
)
if
(
p_sys
->
b_single_track
)
{
{
if
(
p_
access
->
info
.
i_title
+
1
>=
p_sys
->
i_titles
)
if
(
p_
sys
->
i_sector
>=
p_sys
->
p_sectors
[
p_sys
->
i_track
+
1
]
)
{
{
p_access
->
info
.
b_eof
=
VLC_TRUE
;
p_access
->
info
.
b_eof
=
VLC_TRUE
;
return
NULL
;
return
NULL
;
}
}
/* Don't read too far */
p_access
->
info
.
i_update
|=
INPUT_UPDATE_TITLE
|
INPUT_UPDATE_SIZE
|
if
(
p_sys
->
i_sector
+
i_blocks
>=
INPUT_UPDATE_META
;
p_sys
->
p_sectors
[
p_sys
->
i_track
+
1
]
)
p_access
->
info
.
i_title
++
;
{
p_access
->
info
.
i_size
=
p_sys
->
title
[
p_access
->
info
.
i_title
]
->
i_size
;
i_blocks
=
p_sys
->
p_sectors
[
p_sys
->
i_track
+
1
]
-
p_sys
->
i_sector
;
p_access
->
info
.
i_pos
=
0
;
}
}
}
else
/* Don't read after the end of a title */
if
(
p_sys
->
i_sector
+
i_blocks
>=
p_sys
->
p_sectors
[
p_access
->
info
.
i_title
+
1
]
)
{
{
i_blocks
=
p_sys
->
p_sectors
[
p_access
->
info
.
i_title
+
1
]
-
/* Check end of title - Normal */
p_sys
->
i_sector
;
while
(
p_sys
->
i_sector
>=
p_sys
->
p_sectors
[
p_access
->
info
.
i_title
+
1
]
)
{
if
(
p_access
->
info
.
i_title
+
1
>=
p_sys
->
i_titles
)
{
p_access
->
info
.
b_eof
=
VLC_TRUE
;
return
NULL
;
}
p_access
->
info
.
i_update
|=
INPUT_UPDATE_TITLE
|
INPUT_UPDATE_SIZE
|
INPUT_UPDATE_META
;
p_access
->
info
.
i_title
++
;
p_access
->
info
.
i_size
=
p_sys
->
title
[
p_access
->
info
.
i_title
]
->
i_size
;
p_access
->
info
.
i_pos
=
0
;
}
/* Don't read too far */
if
(
p_sys
->
i_sector
+
i_blocks
>=
p_sys
->
p_sectors
[
p_access
->
info
.
i_title
+
1
]
)
{
i_blocks
=
p_sys
->
p_sectors
[
p_access
->
info
.
i_title
+
1
]
-
p_sys
->
i_sector
;
}
}
}
/* Do the actual reading */
/* Do the actual reading */
...
@@ -299,8 +391,12 @@ static int Seek( access_t *p_access, int64_t i_pos )
...
@@ -299,8 +391,12 @@ static int Seek( access_t *p_access, int64_t i_pos )
access_sys_t
*
p_sys
=
p_access
->
p_sys
;
access_sys_t
*
p_sys
=
p_access
->
p_sys
;
/* Next sector to read */
/* Next sector to read */
p_sys
->
i_sector
=
p_sys
->
p_sectors
[
p_access
->
info
.
i_title
]
+
p_sys
->
i_sector
=
p_sys
->
p_sectors
[
i_pos
/
CDDA_DATA_SIZE
;
(
p_sys
->
b_single_track
?
p_sys
->
i_track
:
p_access
->
info
.
i_title
+
1
)
]
+
i_pos
/
CDDA_DATA_SIZE
;
p_access
->
info
.
i_pos
=
i_pos
;
p_access
->
info
.
i_pos
=
i_pos
;
return
VLC_SUCCESS
;
return
VLC_SUCCESS
;
...
@@ -347,6 +443,8 @@ static int Control( access_t *p_access, int i_query, va_list args )
...
@@ -347,6 +443,8 @@ static int Control( access_t *p_access, int i_query, va_list args )
break
;
break
;
case
ACCESS_GET_TITLE_INFO
:
case
ACCESS_GET_TITLE_INFO
:
if
(
p_sys
->
b_single_track
)
return
VLC_EGENERIC
;
ppp_title
=
(
input_title_t
***
)
va_arg
(
args
,
input_title_t
***
);
ppp_title
=
(
input_title_t
***
)
va_arg
(
args
,
input_title_t
***
);
pi_int
=
(
int
*
)
va_arg
(
args
,
int
*
);
pi_int
=
(
int
*
)
va_arg
(
args
,
int
*
);
*
((
int
*
)
va_arg
(
args
,
int
*
))
=
1
;
/* Title offset */
*
((
int
*
)
va_arg
(
args
,
int
*
))
=
1
;
/* Title offset */
...
@@ -361,6 +459,7 @@ static int Control( access_t *p_access, int i_query, va_list args )
...
@@ -361,6 +459,7 @@ static int Control( access_t *p_access, int i_query, va_list args )
break
;
break
;
case
ACCESS_SET_TITLE
:
case
ACCESS_SET_TITLE
:
if
(
p_sys
->
b_single_track
)
return
VLC_EGENERIC
;
i
=
(
int
)
va_arg
(
args
,
int
);
i
=
(
int
)
va_arg
(
args
,
int
);
if
(
i
!=
p_access
->
info
.
i_title
)
if
(
i
!=
p_access
->
info
.
i_title
)
{
{
...
@@ -377,6 +476,7 @@ static int Control( access_t *p_access, int i_query, va_list args )
...
@@ -377,6 +476,7 @@ static int Control( access_t *p_access, int i_query, va_list args )
break
;
break
;
case
ACCESS_GET_META
:
case
ACCESS_GET_META
:
if
(
p_sys
->
b_single_track
)
return
VLC_EGENERIC
;
psz_title
=
malloc
(
strlen
(
_
(
"Audio CD - Track "
)
)
+
5
);
psz_title
=
malloc
(
strlen
(
_
(
"Audio CD - Track "
)
)
+
5
);
snprintf
(
psz_title
,
100
,
_
(
"Audio CD - Track %i"
),
snprintf
(
psz_title
,
100
,
_
(
"Audio CD - Track %i"
),
p_access
->
info
.
i_title
+
1
);
p_access
->
info
.
i_title
+
1
);
...
@@ -397,3 +497,78 @@ static int Control( access_t *p_access, int i_query, va_list args )
...
@@ -397,3 +497,78 @@ static int Control( access_t *p_access, int i_query, va_list args )
}
}
return
VLC_SUCCESS
;
return
VLC_SUCCESS
;
}
}
static
int
GetTracks
(
access_t
*
p_access
,
vlc_bool_t
b_separate
,
playlist_t
*
p_playlist
,
playlist_item_t
*
p_parent
)
{
access_sys_t
*
p_sys
=
p_access
->
p_sys
;
int
i
;
playlist_item_t
*
p_item
;
p_sys
->
i_titles
=
ioctl_GetTracksMap
(
VLC_OBJECT
(
p_access
),
p_sys
->
vcddev
,
&
p_sys
->
p_sectors
);
if
(
p_sys
->
i_titles
<
0
)
{
msg_Err
(
p_access
,
"unable to count tracks"
);
return
VLC_EGENERIC
;;
}
else
if
(
p_sys
->
i_titles
<=
0
)
{
msg_Err
(
p_access
,
"no audio tracks found"
);
return
VLC_EGENERIC
;
}
if
(
b_separate
)
{
if
(
p_parent
->
i_children
==
-
1
)
{
playlist_LockItemToNode
(
p_playlist
,
p_parent
);
}
}
/* Build title table */
for
(
i
=
0
;
i
<
p_sys
->
i_titles
;
i
++
)
{
msg_Dbg
(
p_access
,
"track[%d] start=%d"
,
i
,
p_sys
->
p_sectors
[
i
]
);
if
(
!
b_separate
)
{
input_title_t
*
t
=
p_sys
->
title
[
i
]
=
vlc_input_title_New
();
asprintf
(
&
t
->
psz_name
,
_
(
"Track %i"
),
i
+
1
);
t
->
i_size
=
(
p_sys
->
p_sectors
[
i
+
1
]
-
p_sys
->
p_sectors
[
i
]
)
*
(
int64_t
)
CDDA_DATA_SIZE
;
t
->
i_length
=
I64C
(
1000000
)
*
t
->
i_size
/
44100
/
4
;
}
else
{
char
*
psz_uri
;
int
i_path_len
=
p_access
->
psz_path
?
strlen
(
p_access
->
psz_path
)
:
0
;
char
*
psz_name
=
malloc
(
strlen
(
_
(
"Audio CD - Track "
)
)
+
5
);
char
*
psz_opt
=
(
char
*
)
malloc
(
14
);
psz_uri
=
(
char
*
)
malloc
(
i_path_len
+
13
);
snprintf
(
psz_uri
,
i_path_len
+
13
,
"cdda://%s"
,
p_access
->
psz_path
?
p_access
->
psz_path
:
""
);
snprintf
(
psz_name
,
100
,
_
(
"Audio CD - Track %i"
),
(
i
+
1
)
);
snprintf
(
psz_opt
,
14
,
"cdda-track=%i"
,
i
+
1
);
/* Create playlist items */
p_item
=
playlist_ItemNewWithType
(
VLC_OBJECT
(
p_playlist
),
psz_uri
,
psz_name
,
ITEM_TYPE_DISC
);
playlist_ItemAddOption
(
p_item
,
psz_opt
);
playlist_NodeAddItem
(
p_playlist
,
p_item
,
p_parent
->
pp_parents
[
0
]
->
i_view
,
p_parent
,
PLAYLIST_APPEND
,
PLAYLIST_END
);
free
(
psz_uri
);
free
(
psz_opt
);
}
}
p_sys
->
i_sector
=
p_sys
->
p_sectors
[
0
];
if
(
p_sys
->
b_separate_items
)
{
p_sys
->
i_titles
=
0
;
}
return
VLC_SUCCESS
;
}
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment