Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc-2-2
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-2-2
Commits
f5de3aee
Commit
f5de3aee
authored
Feb 18, 2010
by
Rémi Denis-Courmont
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
dummy demux: implement seeking and positioning with
vlc://pause
parent
7e0df1f4
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
80 additions
and
8 deletions
+80
-8
modules/misc/dummy/input.c
modules/misc/dummy/input.c
+80
-8
No files found.
modules/misc/dummy/input.c
View file @
f5de3aee
...
@@ -44,18 +44,81 @@ static int DemuxNoOp( demux_t *demux )
...
@@ -44,18 +44,81 @@ static int DemuxNoOp( demux_t *demux )
return
0
;
return
0
;
}
}
struct
demux_sys_t
{
mtime_t
end
;
mtime_t
length
;
};
static
int
DemuxPause
(
demux_t
*
demux
)
static
int
DemuxPause
(
demux_t
*
demux
)
{
{
const
mtime_t
*
p_end
=
(
void
*
)
demux
->
p_sys
;
demux_sys_t
*
p_sys
=
demux
->
p_sys
;
mtime_t
now
=
mdate
();
mtime_t
now
=
mdate
();
if
(
now
>=
*
p_
end
)
if
(
now
>=
p_sys
->
end
)
return
0
;
return
0
;
msleep
(
10000
);
/* FIXME!!! */
msleep
(
10000
);
/* FIXME!!! */
return
1
;
return
1
;
}
}
static
int
ControlPause
(
demux_t
*
demux
,
int
query
,
va_list
args
)
{
demux_sys_t
*
p_sys
=
demux
->
p_sys
;
switch
(
query
)
{
case
DEMUX_GET_POSITION
:
{
double
*
ppos
=
va_arg
(
args
,
double
*
);
double
pos
;
mtime_t
now
=
mdate
();
pos
=
1
.
+
((
double
)(
now
-
p_sys
->
end
)
/
(
double
)
p_sys
->
length
);
*
ppos
=
(
pos
<=
1
.)
?
pos
:
1
.;
break
;
}
case
DEMUX_SET_POSITION
:
{
double
pos
=
va_arg
(
args
,
double
);
mtime_t
now
=
mdate
();
p_sys
->
end
=
now
+
(
p_sys
->
length
*
(
1
.
-
pos
));
break
;
}
case
DEMUX_GET_LENGTH
:
{
mtime_t
*
plen
=
va_arg
(
args
,
mtime_t
*
);
*
plen
=
p_sys
->
length
;
break
;
}
case
DEMUX_GET_TIME
:
{
mtime_t
*
ppos
=
va_arg
(
args
,
mtime_t
*
);
*
ppos
=
mdate
()
+
p_sys
->
length
-
p_sys
->
end
;
break
;
}
case
DEMUX_SET_TIME
:
{
mtime_t
pos
=
va_arg
(
args
,
mtime_t
);
p_sys
->
end
=
mdate
()
+
p_sys
->
length
-
pos
;
break
;
}
case
DEMUX_CAN_SEEK
:
*
va_arg
(
args
,
bool
*
)
=
true
;
break
;
default:
return
DemuxControl
(
demux
,
query
,
args
);
}
return
VLC_SUCCESS
;
}
/*****************************************************************************
/*****************************************************************************
* OpenDemux: initialize the target, ie. parse the command
* OpenDemux: initialize the target, ie. parse the command
*****************************************************************************/
*****************************************************************************/
...
@@ -64,14 +127,15 @@ int OpenDemux ( vlc_object_t *p_this )
...
@@ -64,14 +127,15 @@ int OpenDemux ( vlc_object_t *p_this )
demux_t
*
p_demux
=
(
demux_t
*
)
p_this
;
demux_t
*
p_demux
=
(
demux_t
*
)
p_this
;
char
*
psz_name
=
p_demux
->
psz_path
;
char
*
psz_name
=
p_demux
->
psz_path
;
p_demux
->
pf_control
=
DemuxControl
;
p_demux
->
p_sys
=
NULL
;
p_demux
->
p_sys
=
NULL
;
/* Check for a "vlc://nop" command */
/* Check for a "vlc://nop" command */
if
(
!
strcasecmp
(
psz_name
,
"nop"
)
)
if
(
!
strcasecmp
(
psz_name
,
"nop"
)
)
{
{
nop:
msg_Info
(
p_demux
,
"command `nop'"
);
msg_Info
(
p_demux
,
"command `nop'"
);
p_demux
->
pf_demux
=
DemuxNoOp
;
p_demux
->
pf_demux
=
DemuxNoOp
;
p_demux
->
pf_control
=
DemuxControl
;
return
VLC_SUCCESS
;
return
VLC_SUCCESS
;
}
}
...
@@ -80,6 +144,7 @@ int OpenDemux ( vlc_object_t *p_this )
...
@@ -80,6 +144,7 @@ int OpenDemux ( vlc_object_t *p_this )
{
{
msg_Info
(
p_demux
,
"command `quit'"
);
msg_Info
(
p_demux
,
"command `quit'"
);
p_demux
->
pf_demux
=
DemuxNoOp
;
p_demux
->
pf_demux
=
DemuxNoOp
;
p_demux
->
pf_control
=
DemuxControl
;
libvlc_Quit
(
p_demux
->
p_libvlc
);
libvlc_Quit
(
p_demux
->
p_libvlc
);
return
VLC_SUCCESS
;
return
VLC_SUCCESS
;
}
}
...
@@ -88,15 +153,22 @@ int OpenDemux ( vlc_object_t *p_this )
...
@@ -88,15 +153,22 @@ int OpenDemux ( vlc_object_t *p_this )
if
(
!
strncasecmp
(
psz_name
,
"pause:"
,
6
)
)
if
(
!
strncasecmp
(
psz_name
,
"pause:"
,
6
)
)
{
{
double
f
=
us_atof
(
psz_name
+
6
);
double
f
=
us_atof
(
psz_name
+
6
);
mtime_t
end
=
mdate
()
+
f
*
(
mtime_t
)
1000000
;
mtime_t
length
=
f
*
CLOCK_FREQ
;
msg_Info
(
p_demux
,
"command `pause %f'"
,
f
);
msg_Info
(
p_demux
,
"command `pause %f'"
,
f
);
p_demux
->
pf_demux
=
DemuxPause
;
if
(
length
==
0
)
goto
nop
;
/* avoid division by zero */
p_demux
->
p_sys
=
malloc
(
sizeof
(
end
)
);
demux_sys_t
*
p_sys
=
malloc
(
sizeof
(
*
p_sys
)
);
if
(
p_
demux
->
p_
sys
==
NULL
)
if
(
p_sys
==
NULL
)
return
VLC_ENOMEM
;
return
VLC_ENOMEM
;
memcpy
(
p_demux
->
p_sys
,
&
end
,
sizeof
(
end
)
);
p_sys
->
end
=
mdate
()
+
length
;
p_sys
->
length
=
length
;
p_demux
->
p_sys
=
p_sys
;
p_demux
->
pf_demux
=
DemuxPause
;
p_demux
->
pf_control
=
ControlPause
;
return
VLC_SUCCESS
;
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