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
5a1f0564
Commit
5a1f0564
authored
Jan 30, 2004
by
Laurent Aimar
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
* ts: use 0x0a descriptor to send language...
Now we can stream a (complete) dvd with language informations :)
parent
7f18d174
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
60 additions
and
2 deletions
+60
-2
modules/mux/mpeg/ts.c
modules/mux/mpeg/ts.c
+60
-2
No files found.
modules/mux/mpeg/ts.c
View file @
5a1f0564
...
@@ -2,7 +2,7 @@
...
@@ -2,7 +2,7 @@
* ts.c: MPEG-II TS Muxer
* ts.c: MPEG-II TS Muxer
*****************************************************************************
*****************************************************************************
* Copyright (C) 2001, 2002 VideoLAN
* Copyright (C) 2001, 2002 VideoLAN
* $Id: ts.c,v 1.4
2 2004/01/25 02:26:04
fenrir Exp $
* $Id: ts.c,v 1.4
3 2004/01/30 17:53:05
fenrir Exp $
*
*
* Authors: Laurent Aimar <fenrir@via.ecp.fr>
* Authors: Laurent Aimar <fenrir@via.ecp.fr>
* Eric Petit <titer@videolan.org>
* Eric Petit <titer@videolan.org>
...
@@ -32,7 +32,8 @@
...
@@ -32,7 +32,8 @@
#include <vlc/input.h>
#include <vlc/input.h>
#include <vlc/sout.h>
#include <vlc/sout.h>
#include "codecs.h"
#include "iso_lang.h"
#include "bits.h"
#include "bits.h"
#include "pes.h"
#include "pes.h"
#include "csa.h"
#include "csa.h"
...
@@ -175,6 +176,9 @@ typedef struct ts_stream_s
...
@@ -175,6 +176,9 @@ typedef struct ts_stream_s
int
i_decoder_specific_info
;
int
i_decoder_specific_info
;
uint8_t
*
p_decoder_specific_info
;
uint8_t
*
p_decoder_specific_info
;
/* language is iso639-2T */
uint8_t
lang
[
3
];
sout_buffer_chain_t
chain_pes
;
sout_buffer_chain_t
chain_pes
;
mtime_t
i_pes_dts
;
mtime_t
i_pes_dts
;
mtime_t
i_pes_length
;
mtime_t
i_pes_length
;
...
@@ -544,6 +548,40 @@ static int AddStream( sout_mux_t *p_mux, sout_input_t *p_input )
...
@@ -544,6 +548,40 @@ static int AddStream( sout_mux_t *p_mux, sout_input_t *p_input )
return
VLC_EGENERIC
;
return
VLC_EGENERIC
;
}
}
p_stream
->
lang
[
0
]
=
p_stream
->
lang
[
1
]
=
p_stream
->
lang
[
2
]
=
'\0'
;
if
(
p_input
->
p_fmt
->
psz_language
)
{
char
*
psz
=
p_input
->
p_fmt
->
psz_language
;
const
iso639_lang_t
*
pl
=
NULL
;
if
(
strlen
(
psz
)
==
2
)
{
pl
=
GetLang_1
(
psz
);
}
else
if
(
strlen
(
psz
)
==
3
)
{
pl
=
GetLang_2B
(
psz
);
if
(
!
strcmp
(
pl
->
psz_iso639_1
,
"??"
)
)
{
pl
=
GetLang_2T
(
psz
);
}
}
if
(
pl
&&
strcmp
(
pl
->
psz_iso639_1
,
"??"
)
)
{
p_stream
->
lang
[
0
]
=
pl
->
psz_iso639_2T
[
0
];
p_stream
->
lang
[
1
]
=
pl
->
psz_iso639_2T
[
1
];
p_stream
->
lang
[
2
]
=
pl
->
psz_iso639_2T
[
2
];
msg_Dbg
(
p_mux
,
" - lang=%c%c%c"
,
p_stream
->
lang
[
0
],
p_stream
->
lang
[
1
],
p_stream
->
lang
[
2
]
);
}
}
/* Copy extra data (VOL for MPEG-4 and extra BitMapInfoHeader for VFW */
/* Copy extra data (VOL for MPEG-4 and extra BitMapInfoHeader for VFW */
p_stream
->
i_decoder_specific_info
=
p_input
->
p_fmt
->
i_extra
;
p_stream
->
i_decoder_specific_info
=
p_input
->
p_fmt
->
i_extra
;
if
(
p_stream
->
i_decoder_specific_info
>
0
)
if
(
p_stream
->
i_decoder_specific_info
>
0
)
...
@@ -759,6 +797,12 @@ static int Mux( sout_mux_t *p_mux )
...
@@ -759,6 +797,12 @@ static int Mux( sout_mux_t *p_mux )
}
}
else
else
{
{
if
(
p_data
->
i_length
<
0
||
p_data
->
i_length
>
2000000
)
{
/* FIXME choose a better value, but anyway we should never
* have to do that */
p_data
->
i_length
=
1000
;
}
p_stream
->
i_pes_length
+=
p_data
->
i_length
;
p_stream
->
i_pes_length
+=
p_data
->
i_length
;
if
(
p_stream
->
i_pes_dts
==
0
)
if
(
p_stream
->
i_pes_dts
==
0
)
{
{
...
@@ -1626,6 +1670,20 @@ static void GetPMT( sout_mux_t *p_mux,
...
@@ -1626,6 +1670,20 @@ static void GetPMT( sout_mux_t *p_mux,
/* "registration" descriptor : "AC-3" */
/* "registration" descriptor : "AC-3" */
dvbpsi_PMTESAddDescriptor
(
p_es
,
0x05
,
4
,
format
);
dvbpsi_PMTESAddDescriptor
(
p_es
,
0x05
,
4
,
format
);
}
}
if
(
p_stream
->
lang
[
0
]
!=
0
)
{
uint8_t
data
[
4
];
/* I construct the content myself, way faster than looking at
* over complicated/mind broken libdvbpsi way */
data
[
0
]
=
p_stream
->
lang
[
0
];
data
[
1
]
=
p_stream
->
lang
[
1
];
data
[
2
]
=
p_stream
->
lang
[
2
];
data
[
3
]
=
0x00
;
/* audio type: 0x00 undefined */
dvbpsi_PMTESAddDescriptor
(
p_es
,
0x0a
,
4
,
data
);
}
}
}
p_section
=
dvbpsi_GenPMTSections
(
&
pmt
);
p_section
=
dvbpsi_GenPMTSections
(
&
pmt
);
...
...
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