Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc
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
Commits
5c59e3cf
Commit
5c59e3cf
authored
Dec 04, 2005
by
Rémi Denis-Courmont
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Enable timeshifting automatically with SAP - closes #450
(can be disabled with an advanced option)
parent
c315e228
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
28 additions
and
12 deletions
+28
-12
modules/services_discovery/sap.c
modules/services_discovery/sap.c
+28
-12
No files found.
modules/services_discovery/sap.c
View file @
5c59e3cf
...
@@ -106,6 +106,10 @@ static const char ipv6_scopes[] = "1456789ABCDE";
...
@@ -106,6 +106,10 @@ static const char ipv6_scopes[] = "1456789ABCDE";
"If this option is selected, a SAP caching mechanism will be used. " \
"If this option is selected, a SAP caching mechanism will be used. " \
"This will result in lower SAP startup time, but you could end up " \
"This will result in lower SAP startup time, but you could end up " \
"with items corresponding to legacy streams." )
"with items corresponding to legacy streams." )
#define SAP_TIMESHIFT_TEXT N_("Allow timeshifting")
#define SAP_TIMESHIFT_LONGTEXT N_( \
"Enable timeshifting automatically for streams " \
"discovered through SAP announcements." )
/* Callbacks */
/* Callbacks */
static
int
Open
(
vlc_object_t
*
);
static
int
Open
(
vlc_object_t
*
);
...
@@ -133,6 +137,8 @@ vlc_module_begin();
...
@@ -133,6 +137,8 @@ vlc_module_begin();
SAP_STRICT_TEXT
,
SAP_STRICT_LONGTEXT
,
VLC_TRUE
);
SAP_STRICT_TEXT
,
SAP_STRICT_LONGTEXT
,
VLC_TRUE
);
add_bool
(
"sap-cache"
,
0
,
NULL
,
add_bool
(
"sap-cache"
,
0
,
NULL
,
SAP_CACHE_TEXT
,
SAP_CACHE_LONGTEXT
,
VLC_TRUE
);
SAP_CACHE_TEXT
,
SAP_CACHE_LONGTEXT
,
VLC_TRUE
);
add_bool
(
"sap-timeshift"
,
0
,
NULL
,
SAP_TIMESHIFT_TEXT
,
SAP_TIMESHIFT_LONGTEXT
,
VLC_TRUE
);
set_capability
(
"services_discovery"
,
0
);
set_capability
(
"services_discovery"
,
0
);
set_callbacks
(
Open
,
Close
);
set_callbacks
(
Open
,
Close
);
...
@@ -221,6 +227,7 @@ struct services_discovery_sys_t
...
@@ -221,6 +227,7 @@ struct services_discovery_sys_t
/* Modes */
/* Modes */
vlc_bool_t
b_strict
;
vlc_bool_t
b_strict
;
vlc_bool_t
b_parse
;
vlc_bool_t
b_parse
;
vlc_bool_t
b_timeshift
;
int
i_timeout
;
int
i_timeout
;
};
};
...
@@ -322,6 +329,10 @@ static int Open( vlc_object_t *p_this )
...
@@ -322,6 +329,10 @@ static int Open( vlc_object_t *p_this )
return
VLC_EGENERIC
;
return
VLC_EGENERIC
;
}
}
/* Cache sap_timeshift value */
p_sys
->
b_timeshift
=
var_CreateGetInteger
(
p_sd
,
"sap-timeshift"
)
?
VLC_TRUE
:
VLC_FALSE
;
/* Create our playlist node */
/* Create our playlist node */
p_sys
->
p_playlist
=
(
playlist_t
*
)
vlc_object_find
(
p_sd
,
p_sys
->
p_playlist
=
(
playlist_t
*
)
vlc_object_find
(
p_sd
,
VLC_OBJECT_PLAYLIST
,
VLC_OBJECT_PLAYLIST
,
...
@@ -765,18 +776,20 @@ sap_announce_t *CreateAnnounce( services_discovery_t *p_sd, uint16_t i_hash,
...
@@ -765,18 +776,20 @@ sap_announce_t *CreateAnnounce( services_discovery_t *p_sd, uint16_t i_hash,
char
*
psz_value
;
char
*
psz_value
;
sap_announce_t
*
p_sap
=
(
sap_announce_t
*
)
malloc
(
sap_announce_t
*
p_sap
=
(
sap_announce_t
*
)
malloc
(
sizeof
(
sap_announce_t
)
);
sizeof
(
sap_announce_t
)
);
services_discovery_sys_t
*
p_sys
;
if
(
p_sap
==
NULL
)
if
(
p_sap
==
NULL
)
return
NULL
;
return
NULL
;
p_sys
=
p_sd
->
p_sys
;
EnsureUTF8
(
p_sdp
->
psz_sessionname
);
EnsureUTF8
(
p_sdp
->
psz_sessionname
);
p_sap
->
i_last
=
mdate
();
p_sap
->
i_last
=
mdate
();
p_sap
->
i_hash
=
i_hash
;
p_sap
->
i_hash
=
i_hash
;
p_sap
->
p_sdp
=
p_sdp
;
p_sap
->
p_sdp
=
p_sdp
;
p_sap
->
i_item_id
=
-
1
;
p_sap
->
i_item_id
=
-
1
;
/* Create the playlist item here */
/* Create the actual playlist item here */
p_item
=
playlist_ItemNew
(
p_sd
,
p_sap
->
p_sdp
->
psz_uri
,
p_item
=
playlist_ItemNew
(
p_sd
,
p_sap
->
p_sdp
->
psz_uri
,
p_sdp
->
psz_sessionname
);
p_sdp
->
psz_sessionname
);
if
(
!
p_item
)
if
(
!
p_item
)
{
{
...
@@ -784,6 +797,9 @@ sap_announce_t *CreateAnnounce( services_discovery_t *p_sd, uint16_t i_hash,
...
@@ -784,6 +797,9 @@ sap_announce_t *CreateAnnounce( services_discovery_t *p_sd, uint16_t i_hash,
return
NULL
;
return
NULL
;
}
}
if
(
p_sys
->
b_timeshift
)
playlist_ItemAddOption
(
p_item
,
":access-filter=timeshift"
);
psz_value
=
GetAttribute
(
p_sap
->
p_sdp
,
"tool"
);
psz_value
=
GetAttribute
(
p_sap
->
p_sdp
,
"tool"
);
if
(
psz_value
!=
NULL
)
if
(
psz_value
!=
NULL
)
{
{
...
@@ -803,35 +819,35 @@ sap_announce_t *CreateAnnounce( services_discovery_t *p_sd, uint16_t i_hash,
...
@@ -803,35 +819,35 @@ sap_announce_t *CreateAnnounce( services_discovery_t *p_sd, uint16_t i_hash,
psz_value
=
GetAttribute
(
p_sap
->
p_sdp
,
"plgroup"
);
psz_value
=
GetAttribute
(
p_sap
->
p_sdp
,
"plgroup"
);
}
}
/* Find or Create the group playlist non-playable item */
if
(
psz_value
!=
NULL
)
if
(
psz_value
!=
NULL
)
{
{
EnsureUTF8
(
psz_value
);
EnsureUTF8
(
psz_value
);
p_child
=
playlist_ChildSearchName
(
p_s
d
->
p_s
ys
->
p_node
,
psz_value
);
p_child
=
playlist_ChildSearchName
(
p_sys
->
p_node
,
psz_value
);
if
(
p_child
==
NULL
)
if
(
p_child
==
NULL
)
{
{
p_child
=
playlist_NodeCreate
(
p_s
d
->
p_s
ys
->
p_playlist
,
p_child
=
playlist_NodeCreate
(
p_sys
->
p_playlist
,
VIEW_CATEGORY
,
psz_value
,
VIEW_CATEGORY
,
psz_value
,
p_s
d
->
p_s
ys
->
p_node
);
p_sys
->
p_node
);
p_child
->
i_flags
&=
~
PLAYLIST_SKIP_FLAG
;
p_child
->
i_flags
&=
~
PLAYLIST_SKIP_FLAG
;
}
}
}
}
else
else
{
{
p_child
=
p_s
d
->
p_s
ys
->
p_node
;
p_child
=
p_sys
->
p_node
;
}
}
p_item
->
i_flags
&=
~
PLAYLIST_SKIP_FLAG
;
p_item
->
i_flags
&=
~
PLAYLIST_SKIP_FLAG
;
p_item
->
i_flags
&=
~
PLAYLIST_SAVE_FLAG
;
p_item
->
i_flags
&=
~
PLAYLIST_SAVE_FLAG
;
playlist_NodeAddItem
(
p_s
d
->
p_sys
->
p_playlist
,
p_item
,
VIEW_CATEGORY
,
playlist_NodeAddItem
(
p_s
ys
->
p_playlist
,
p_item
,
VIEW_CATEGORY
,
p_child
,
p_child
,
PLAYLIST_APPEND
,
PLAYLIST_END
);
PLAYLIST_APPEND
,
PLAYLIST_END
);
p_sap
->
i_item_id
=
p_item
->
input
.
i_id
;
p_sap
->
i_item_id
=
p_item
->
input
.
i_id
;
TAB_APPEND
(
p_sd
->
p_sys
->
i_announces
,
TAB_APPEND
(
p_sys
->
i_announces
,
p_sys
->
pp_announces
,
p_sap
);
p_sd
->
p_sys
->
pp_announces
,
p_sap
);
return
p_sap
;
return
p_sap
;
}
}
...
...
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