diff options
Diffstat (limited to 'sub')
-rw-r--r-- | sub/dec_sub.c | 14 | ||||
-rw-r--r-- | sub/dec_sub.h | 2 |
2 files changed, 16 insertions, 0 deletions
diff --git a/sub/dec_sub.c b/sub/dec_sub.c index b9f04b3123..743a06ed14 100644 --- a/sub/dec_sub.c +++ b/sub/dec_sub.c @@ -29,6 +29,7 @@ #include "options/options.h" #include "common/global.h" #include "common/msg.h" +#include "common/recorder.h" #include "osdep/threads.h" extern const struct sd_functions sd_ass; @@ -49,6 +50,8 @@ struct dec_sub { struct mpv_global *global; struct MPOpts *opts; + struct mp_recorder_sink *recorder_sink; + struct attachment_list *attachments; struct sh_stream *sh; @@ -240,6 +243,9 @@ bool sub_read_packets(struct dec_sub *sub, double video_pts) break; } + if (sub->recorder_sink) + mp_recorder_feed_packet(sub->recorder_sink, pkt); + sub->last_pkt_pts = pkt->pts; if (is_new_segment(sub, pkt)) { @@ -323,3 +329,11 @@ int sub_control(struct dec_sub *sub, enum sd_ctrl cmd, void *arg) pthread_mutex_unlock(&sub->lock); return r; } + +void sub_set_recorder_sink(struct dec_sub *sub, struct mp_recorder_sink *sink) +{ + pthread_mutex_lock(&sub->lock); + sub->recorder_sink = sink; + pthread_mutex_unlock(&sub->lock); +} + diff --git a/sub/dec_sub.h b/sub/dec_sub.h index bdf6e35492..26781fd99f 100644 --- a/sub/dec_sub.h +++ b/sub/dec_sub.h @@ -9,6 +9,7 @@ struct sh_stream; struct mpv_global; struct demux_packet; +struct mp_recorder_sink; struct dec_sub; struct sd; @@ -40,6 +41,7 @@ void sub_get_bitmaps(struct dec_sub *sub, struct mp_osd_res dim, int format, char *sub_get_text(struct dec_sub *sub, double pts); void sub_reset(struct dec_sub *sub); void sub_select(struct dec_sub *sub, bool selected); +void sub_set_recorder_sink(struct dec_sub *sub, struct mp_recorder_sink *sink); int sub_control(struct dec_sub *sub, enum sd_ctrl cmd, void *arg); |