aboutsummaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authorGravatar wm4 <wm4@nowhere>2015-10-23 14:53:19 +0200
committerGravatar wm4 <wm4@nowhere>2015-10-23 14:53:19 +0200
commit955c6843b6b7a491d1707104e5fad048cd1ab72c (patch)
tree25a603abddfebabb46869a0cef8d11a10ac580ca
parentd1528e51d50002a67b692ec359b61aba9258d3c2 (diff)
command: do not return 0 for bitrates if unknown
This makes the bitrate properties unavailable, instead of returning 0 when: 1. No track is selected, or 2. Not enough packets have been read to have a bitrate estimate yet
-rw-r--r--demux/demux.c5
-rw-r--r--player/command.c2
2 files changed, 5 insertions, 2 deletions
diff --git a/demux/demux.c b/demux/demux.c
index 53fb5c6cad..3233541be2 100644
--- a/demux/demux.c
+++ b/demux/demux.c
@@ -1392,10 +1392,11 @@ static int cached_demux_control(struct demux_internal *in, int cmd, void *arg)
case DEMUXER_CTRL_GET_BITRATE_STATS: {
double *rates = arg;
for (int n = 0; n < STREAM_TYPE_COUNT; n++)
- rates[n] = 0;
+ rates[n] = -1;
for (int n = 0; n < in->d_user->num_streams; n++) {
struct demux_stream *ds = in->d_user->streams[n]->ds;
- rates[ds->type] += MPMAX(0, ds->bitrate);
+ if (ds->selected && ds->bitrate >= 0)
+ rates[ds->type] = MPMAX(0, rates[ds->type]) + ds->bitrate;
}
return DEMUXER_CTRL_OK;
}
diff --git a/player/command.c b/player/command.c
index 1bcf0c47e3..79e522c1d9 100644
--- a/player/command.c
+++ b/player/command.c
@@ -3093,6 +3093,8 @@ static int mp_property_packet_bitrate(void *ctx, struct m_property *prop,
double r[STREAM_TYPE_COUNT];
if (demux_control(mpctx->demuxer, DEMUXER_CTRL_GET_BITRATE_STATS, &r) < 1)
return M_PROPERTY_UNAVAILABLE;
+ if (r[type] < 0)
+ return M_PROPERTY_UNAVAILABLE;
// r[type] is in bytes/second -> bits
double rate = r[type] * 8;