Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc-gpu
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-gpu
Commits
7cb0b7cc
Commit
7cb0b7cc
authored
Aug 13, 2006
by
Dennis van Amerongen
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
* shout.c: add support for protocol selection (icy for shoutcast and http for icecast)
parent
d56de488
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
35 additions
and
6 deletions
+35
-6
modules/access_output/shout.c
modules/access_output/shout.c
+35
-6
No files found.
modules/access_output/shout.c
View file @
7cb0b7cc
...
@@ -57,7 +57,7 @@ static void Close( vlc_object_t * );
...
@@ -57,7 +57,7 @@ static void Close( vlc_object_t * );
#define NAME_TEXT N_("Stream name")
#define NAME_TEXT N_("Stream name")
#define NAME_LONGTEXT N_("Name to give to this stream/channel on the " \
#define NAME_LONGTEXT N_("Name to give to this stream/channel on the " \
"icecast server." )
"
shoutcast/
icecast server." )
#define DESCRIPTION_TEXT N_("Stream description")
#define DESCRIPTION_TEXT N_("Stream description")
#define DESCRIPTION_LONGTEXT N_("Description of the stream content or " \
#define DESCRIPTION_LONGTEXT N_("Description of the stream content or " \
...
@@ -66,8 +66,14 @@ static void Close( vlc_object_t * );
...
@@ -66,8 +66,14 @@ static void Close( vlc_object_t * );
#define MP3_TEXT N_("Stream MP3")
#define MP3_TEXT N_("Stream MP3")
#define MP3_LONGTEXT N_("You normally have to feed the shoutcast module " \
#define MP3_LONGTEXT N_("You normally have to feed the shoutcast module " \
"with Ogg streams. It is also possible to stream " \
"with Ogg streams. It is also possible to stream " \
"MP3 instead, so you can "\
"MP3 instead, so you can forward MP3 streams to " \
"forward MP3 streams to the icecast server." )
"the shoutcast/icecast server." )
#define PROTOCOL_TEXT N_("Shoutcast protocol")
#define PROTOCOL_LONGTEXT N_("Shoutcast header protocol to use when communicating " \
"with the server. Shoutcast servers need 'icy', " \
"icecast 1.x needs 'xaudiocast', and icecast 2.x " \
"needs 'http'. " )
vlc_module_begin
();
vlc_module_begin
();
set_description
(
_
(
"IceCAST output"
)
);
set_description
(
_
(
"IceCAST output"
)
);
...
@@ -84,6 +90,8 @@ vlc_module_begin();
...
@@ -84,6 +90,8 @@ vlc_module_begin();
DESCRIPTION_TEXT
,
DESCRIPTION_LONGTEXT
,
VLC_FALSE
);
DESCRIPTION_TEXT
,
DESCRIPTION_LONGTEXT
,
VLC_FALSE
);
add_bool
(
SOUT_CFG_PREFIX
"mp3"
,
VLC_FALSE
,
NULL
,
add_bool
(
SOUT_CFG_PREFIX
"mp3"
,
VLC_FALSE
,
NULL
,
MP3_TEXT
,
MP3_LONGTEXT
,
VLC_TRUE
);
MP3_TEXT
,
MP3_LONGTEXT
,
VLC_TRUE
);
add_string
(
SOUT_CFG_PREFIX
"protocol"
,
"http"
,
NULL
,
PROTOCOL_TEXT
,
PROTOCOL_LONGTEXT
,
VLC_FALSE
);
set_callbacks
(
Open
,
Close
);
set_callbacks
(
Open
,
Close
);
vlc_module_end
();
vlc_module_end
();
...
@@ -91,7 +99,7 @@ vlc_module_end();
...
@@ -91,7 +99,7 @@ vlc_module_end();
* Exported prototypes
* Exported prototypes
*****************************************************************************/
*****************************************************************************/
static
const
char
*
ppsz_sout_options
[]
=
{
static
const
char
*
ppsz_sout_options
[]
=
{
"name"
,
"description"
,
"mp3"
,
NULL
"name"
,
"description"
,
"mp3"
,
"protocol"
,
NULL
};
};
...
@@ -127,6 +135,7 @@ static int Open( vlc_object_t *p_this )
...
@@ -127,6 +135,7 @@ static int Open( vlc_object_t *p_this )
char
*
psz_mount
=
NULL
;
char
*
psz_mount
=
NULL
;
char
*
psz_name
=
NULL
;
char
*
psz_name
=
NULL
;
char
*
psz_description
=
NULL
;
char
*
psz_description
=
NULL
;
char
*
psz_protocol
=
NULL
;
char
*
tmp_port
=
NULL
;
char
*
tmp_port
=
NULL
;
sout_CfgParse
(
p_access
,
SOUT_CFG_PREFIX
,
ppsz_sout_options
,
p_access
->
p_cfg
);
sout_CfgParse
(
p_access
,
SOUT_CFG_PREFIX
,
ppsz_sout_options
,
p_access
->
p_cfg
);
...
@@ -180,8 +189,6 @@ static int Open( vlc_object_t *p_this )
...
@@ -180,8 +189,6 @@ static int Open( vlc_object_t *p_this )
p_shout
=
p_sys
->
p_shout
=
shout_new
();
p_shout
=
p_sys
->
p_shout
=
shout_new
();
if
(
!
p_shout
if
(
!
p_shout
||
shout_set_host
(
p_shout
,
psz_host
)
!=
SHOUTERR_SUCCESS
||
shout_set_host
(
p_shout
,
psz_host
)
!=
SHOUTERR_SUCCESS
||
shout_set_protocol
(
p_shout
,
SHOUT_PROTOCOL_HTTP
)
!=
SHOUTERR_SUCCESS
||
shout_set_port
(
p_shout
,
i_port
)
!=
SHOUTERR_SUCCESS
||
shout_set_port
(
p_shout
,
i_port
)
!=
SHOUTERR_SUCCESS
||
shout_set_password
(
p_shout
,
psz_pass
)
!=
SHOUTERR_SUCCESS
||
shout_set_password
(
p_shout
,
psz_pass
)
!=
SHOUTERR_SUCCESS
||
shout_set_mount
(
p_shout
,
psz_mount
)
!=
SHOUTERR_SUCCESS
||
shout_set_mount
(
p_shout
,
psz_mount
)
!=
SHOUTERR_SUCCESS
...
@@ -216,6 +223,28 @@ static int Open( vlc_object_t *p_this )
...
@@ -216,6 +223,28 @@ static int Open( vlc_object_t *p_this )
return
VLC_EGENERIC
;
return
VLC_EGENERIC
;
}
}
var_Get
(
p_access
,
SOUT_CFG_PREFIX
"protocol"
,
&
val
);
if
(
!
strcmp
(
val
.
psz_string
,
"icy"
)
)
{
i_ret
=
shout_set_protocol
(
p_shout
,
SHOUT_PROTOCOL_ICY
);
}
else
if
(
!
strcmp
(
val
.
psz_string
,
"xaudiocast"
)
)
{
i_ret
=
shout_set_protocol
(
p_shout
,
SHOUT_PROTOCOL_XAUDIOCAST
);
}
else
if
(
!
strcmp
(
val
.
psz_string
,
"http"
)
)
{
i_ret
=
shout_set_protocol
(
p_shout
,
SHOUT_PROTOCOL_HTTP
);
}
if
(
i_ret
!=
SHOUTERR_SUCCESS
)
{
msg_Err
(
p_access
,
"failed to set the shoutcast header protocol"
);
free
(
p_access
->
p_sys
);
free
(
psz_protocol
);
return
VLC_EGENERIC
;
}
i_ret
=
shout_open
(
p_shout
);
i_ret
=
shout_open
(
p_shout
);
if
(
i_ret
==
SHOUTERR_SUCCESS
)
if
(
i_ret
==
SHOUTERR_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