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
a9b240f5
Commit
a9b240f5
authored
Nov 17, 2007
by
Jean-Baptiste Kempf
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Real Demuxer: Support for RM version 3. Tested and works \o/
parent
be8e0b44
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
87 additions
and
5 deletions
+87
-5
modules/demux/real.c
modules/demux/real.c
+87
-5
No files found.
modules/demux/real.c
View file @
a9b240f5
...
@@ -988,20 +988,98 @@ static int ReadCodecSpecificData( demux_t *p_demux, int i_len, int i_num )
...
@@ -988,20 +988,98 @@ static int ReadCodecSpecificData( demux_t *p_demux, int i_len, int i_num )
}
}
else
if
(
!
strncmp
(
(
char
*
)
p_peek
,
".ra
\xfd
"
,
4
)
)
else
if
(
!
strncmp
(
(
char
*
)
p_peek
,
".ra
\xfd
"
,
4
)
)
{
{
int
i_version
=
GetWBE
(
&
p_peek
[
4
]
);
int
i_header_size
,
i_flavor
,
i_coded_frame_size
,
i_subpacket_h
;
int
i_header_size
,
i_flavor
,
i_coded_frame_size
,
i_subpacket_h
;
int
i_frame_size
,
i_subpacket_size
;
int
i_frame_size
,
i_subpacket_size
;
int
i_version
=
GetWBE
(
&
p_peek
[
4
]
);
/* [0..3] = '.','r','a',0xfd */
msg_Dbg
(
p_demux
,
" - audio version=%d"
,
i_version
);
msg_Dbg
(
p_demux
,
" - audio version=%d"
,
i_version
);
p_peek
+=
6
;
p_peek
+=
6
;
/* 4 + version */
es_format_Init
(
&
fmt
,
AUDIO_ES
,
0
);
es_format_Init
(
&
fmt
,
AUDIO_ES
,
0
);
if
(
i_version
==
3
)
if
(
i_version
==
3
)
{
{
msg_Dbg
(
p_demux
,
" - audio version 3 is not supported!"
);
int
i_len
;
return
VLC_EGENERIC
;
char
*
psz
;
i_header_size
=
GetWBE
(
p_peek
);
p_peek
+=
2
;
/* Size from now */
p_peek
+=
10
;
/* Unknown */
p_peek
+=
4
;
/* Data Size */
/* Title */
i_len
=
*
p_peek
;
p_peek
++
;
if
(
i_len
>
0
)
{
psz
=
malloc
(
i_len
+
1
);
memcpy
(
psz
,
p_peek
,
i_len
);
psz
[
i_len
]
=
'\0'
;
msg_Dbg
(
p_demux
,
" - title=`%s'"
,
psz
);
EnsureUTF8
(
psz
);
asprintf
(
&
p_sys
->
psz_title
,
psz
);
free
(
psz
);
}
}
p_peek
+=
i_len
;
/* Authors */
i_len
=
*
p_peek
;
p_peek
++
;
if
(
i_len
>
0
)
{
psz
=
malloc
(
i_len
+
1
);
memcpy
(
psz
,
p_peek
,
i_len
);
psz
[
i_len
]
=
'\0'
;
msg_Dbg
(
p_demux
,
" - artist=`%s'"
,
psz
);
EnsureUTF8
(
psz
);
asprintf
(
&
p_sys
->
psz_artist
,
psz
);
free
(
psz
);
}
p_peek
+=
i_len
;
/* Copyright */
i_len
=
*
p_peek
;
p_peek
++
;
if
(
i_len
>
0
)
{
psz
=
malloc
(
i_len
+
1
);
memcpy
(
psz
,
p_peek
,
i_len
);
psz
[
i_len
]
=
'\0'
;
msg_Dbg
(
p_demux
,
" - Copyright=`%s'"
,
psz
);
EnsureUTF8
(
psz
);
asprintf
(
&
p_sys
->
psz_copyright
,
psz
);
free
(
psz
);
}
p_peek
+=
i_len
;
/* Comment */
i_len
=
*
p_peek
;
p_peek
++
;
if
(
i_len
>
0
)
{
psz
=
malloc
(
i_len
+
1
);
memcpy
(
psz
,
p_peek
,
i_len
);
psz
[
i_len
]
=
'\0'
;
msg_Dbg
(
p_demux
,
" - Comment=`%s'"
,
psz
);
EnsureUTF8
(
psz
);
asprintf
(
&
p_sys
->
psz_description
,
psz
);
free
(
psz
);
}
/* This might be unusefull */
p_peek
+=
i_len
;
p_peek
++
;
/* Unknown */
p_peek
++
;
/* FourCC length = 4 */
memcpy
(
(
char
*
)
&
fmt
.
i_codec
,
p_peek
,
4
);
p_peek
+=
4
;
/* Up to here :) */
fmt
.
audio
.
i_channels
=
1
;
/* This is always the case in rm3 */
fmt
.
audio
.
i_rate
=
8000
;
msg_Dbg
(
p_demux
,
" - audio codec=%4.4s channels=%d rate=%dHz"
,
(
char
*
)
&
fmt
.
i_codec
,
fmt
.
audio
.
i_channels
,
fmt
.
audio
.
i_rate
);
}
else
{
p_peek
+=
2
;
/* 00 00 */
p_peek
+=
2
;
/* 00 00 */
p_peek
+=
4
;
/* .ra4 or .ra5 */
p_peek
+=
4
;
/* .ra4 or .ra5 */
...
@@ -1043,6 +1121,7 @@ static int ReadCodecSpecificData( demux_t *p_demux, int i_len, int i_num )
...
@@ -1043,6 +1121,7 @@ static int ReadCodecSpecificData( demux_t *p_demux, int i_len, int i_num )
p_peek
+=
3
;
/* ?? */
p_peek
+=
3
;
/* ?? */
if
(
i_version
==
5
)
p_peek
++
;
if
(
i_version
==
5
)
p_peek
++
;
}
switch
(
fmt
.
i_codec
)
switch
(
fmt
.
i_codec
)
{
{
...
@@ -1083,6 +1162,9 @@ static int ReadCodecSpecificData( demux_t *p_demux, int i_len, int i_num )
...
@@ -1083,6 +1162,9 @@ static int ReadCodecSpecificData( demux_t *p_demux, int i_len, int i_num )
fmt
.
audio
.
i_bitspersample
=
sipr_fl2bps
[
i_flavor
];
fmt
.
audio
.
i_bitspersample
=
sipr_fl2bps
[
i_flavor
];
break
;
break
;
case
VLC_FOURCC
(
'l'
,
'p'
,
'c'
,
'J'
):
fmt
.
i_codec
=
VLC_FOURCC
(
'1'
,
'4'
,
'_'
,
'4'
);
default:
default:
msg_Dbg
(
p_demux
,
" - unknown audio codec=%4.4s"
,
msg_Dbg
(
p_demux
,
" - unknown audio codec=%4.4s"
,
(
char
*
)
&
fmt
.
i_codec
);
(
char
*
)
&
fmt
.
i_codec
);
...
...
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