diff options
| author | Carl Hetherington <cth@carlh.net> | 2016-10-07 16:22:38 +0100 |
|---|---|---|
| committer | Carl Hetherington <cth@carlh.net> | 2016-11-17 01:06:31 +0000 |
| commit | 97d39f46795af78b84d5f7bc9118a188f2864781 (patch) | |
| tree | 354ad3d03ba0bf545fc76102c907dab2d31a0b08 /src/lib/decoder.cc | |
| parent | 987e2daa218ab39c6ddc3780667eedaab1c0872e (diff) | |
A possibly-better approach to seeking.
Before this commit, decoders try to guess whether they should
request a seek based on what they have in their buffers. This
seems reasonable for video and audio, which will always (I think)
have some data lying around to give an indication of where their
parent decoders are in the timeline.
It doesn't work so well for subtitles, as the storage of subs is
cleared out based on time (+/- 5s of "now") so there is a good chance
that the storage will be empty. This gives the subtitle decoder no
chance of knowing where its parent is, so it's very likely to seek.
This commit asks the parent decoder to seek if it wants to, and it
decides based on a knowledge of roughly where it is in the timeline.
Hence the sub-decoders just see if they have got the data that is being
requested, and if not they suggest to the parent that it might like
to seek. They then start calling pass(). Hence the parent should only
seek if some calls to pass() are not going to elicit the required data
in a reasonable time.
Diffstat (limited to 'src/lib/decoder.cc')
| -rw-r--r-- | src/lib/decoder.cc | 38 |
1 files changed, 38 insertions, 0 deletions
diff --git a/src/lib/decoder.cc b/src/lib/decoder.cc new file mode 100644 index 000000000..cba674d04 --- /dev/null +++ b/src/lib/decoder.cc @@ -0,0 +1,38 @@ +/* + Copyright (C) 2012-2015 Carl Hetherington <cth@carlh.net> + + This file is part of DCP-o-matic. + + DCP-o-matic is free software; you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation; either version 2 of the License, or + (at your option) any later version. + + DCP-o-matic is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with DCP-o-matic. If not, see <http://www.gnu.org/licenses/>. + +*/ + +#include "decoder.h" + +void +Decoder::maybe_seek (ContentTime time, bool accurate) +{ + if (!_position) { + /* A seek has just happened */ + return; + } + + if (time >= *_position && time < (*_position + ContentTime::from_seconds(1))) { + /* No need to seek: caller should just pass() */ + return; + } + + _position.reset (); + seek (time, accurate); +} |
