From 139bc5ce0931b2d2bf096c1f2f90651fd15fa977 Mon Sep 17 00:00:00 2001 From: wm4 Date: Fri, 10 May 2013 15:20:40 +0200 Subject: command: add time-remaining property --- DOCS/man/en/input.rst | 1 + core/command.c | 14 ++++++++++++++ 2 files changed, 15 insertions(+) diff --git a/DOCS/man/en/input.rst b/DOCS/man/en/input.rst index 6d1072353f..638172289c 100644 --- a/DOCS/man/en/input.rst +++ b/DOCS/man/en/input.rst @@ -284,6 +284,7 @@ length length of the current file in seconds avsync last A/V synchronization difference percent-pos x position in current file (0-100) time-pos x position in current file in seconds +time-remaining estimated remaining length of the file in seconds chapter x current chapter number edition x current MKV edition number titles number of DVD titles diff --git a/core/command.c b/core/command.c index aea8fb2017..d9788084db 100644 --- a/core/command.c +++ b/core/command.c @@ -328,6 +328,19 @@ static int mp_property_time_pos(m_option_t *prop, int action, return M_PROPERTY_NOT_IMPLEMENTED; } +static int mp_property_remaining(m_option_t *prop, int action, + void *arg, MPContext *mpctx) +{ + double len = get_time_length(mpctx); + double pos = get_current_time(mpctx); + double start = get_start_time(mpctx); + + if (!(int)len) + return M_PROPERTY_UNAVAILABLE; + + return m_property_double_ro(prop, action, arg, len - (pos - start)); +} + /// Current chapter (RW) static int mp_property_chapter(m_option_t *prop, int action, void *arg, MPContext *mpctx) @@ -1373,6 +1386,7 @@ static const m_option_t mp_properties[] = { M_OPT_RANGE, 0, 100, NULL }, { "time-pos", mp_property_time_pos, CONF_TYPE_TIME, M_OPT_MIN, 0, 0, NULL }, + { "time-remaining", mp_property_remaining, CONF_TYPE_TIME }, { "chapter", mp_property_chapter, CONF_TYPE_INT, M_OPT_MIN, 0, 0, NULL }, M_OPTION_PROPERTY_CUSTOM("edition", mp_property_edition), -- cgit v1.2.3