mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2025-01-13 21:28:01 +02:00
ogg: propagate return values and return more meaningful error values
Signed-off-by: Diego Biurrun <diego@biurrun.de>
This commit is contained in:
parent
5029a40633
commit
9cec1bbd14
@ -192,7 +192,7 @@ static int ogg_read_page(AVFormatContext *s, int *str)
|
||||
AVIOContext *bc = s->pb;
|
||||
struct ogg *ogg = s->priv_data;
|
||||
struct ogg_stream *os;
|
||||
int i = 0;
|
||||
int ret, i = 0;
|
||||
int flags, nsegs;
|
||||
uint64_t gp;
|
||||
uint32_t serial;
|
||||
@ -200,8 +200,9 @@ static int ogg_read_page(AVFormatContext *s, int *str)
|
||||
uint8_t sync[4];
|
||||
int sp = 0;
|
||||
|
||||
if (avio_read (bc, sync, 4) < 4)
|
||||
return -1;
|
||||
ret = avio_read(bc, sync, 4);
|
||||
if (ret < 4)
|
||||
return ret < 0 ? ret : AVERROR_EOF;
|
||||
|
||||
do{
|
||||
int c;
|
||||
@ -213,17 +214,17 @@ static int ogg_read_page(AVFormatContext *s, int *str)
|
||||
|
||||
c = avio_r8(bc);
|
||||
if (bc->eof_reached)
|
||||
return -1;
|
||||
return AVERROR_EOF;
|
||||
sync[sp++ & 3] = c;
|
||||
}while (i++ < MAX_PAGE_SIZE);
|
||||
|
||||
if (i >= MAX_PAGE_SIZE){
|
||||
av_log (s, AV_LOG_INFO, "ogg, can't find sync word\n");
|
||||
return -1;
|
||||
return AVERROR_INVALIDDATA;
|
||||
}
|
||||
|
||||
if (avio_r8(bc) != 0) /* version */
|
||||
return -1;
|
||||
return AVERROR_INVALIDDATA;
|
||||
|
||||
flags = avio_r8(bc);
|
||||
gp = avio_rl64 (bc);
|
||||
@ -248,7 +249,7 @@ static int ogg_read_page(AVFormatContext *s, int *str)
|
||||
idx = ogg_new_stream(s, serial, 1);
|
||||
}
|
||||
if (idx < 0)
|
||||
return -1;
|
||||
return idx;
|
||||
}
|
||||
|
||||
os = ogg->streams + idx;
|
||||
@ -257,8 +258,9 @@ static int ogg_read_page(AVFormatContext *s, int *str)
|
||||
if(os->psize > 0)
|
||||
ogg_new_buf(ogg, idx);
|
||||
|
||||
if (avio_read (bc, os->segments, nsegs) < nsegs)
|
||||
return -1;
|
||||
ret = avio_read(bc, os->segments, nsegs);
|
||||
if (ret < nsegs)
|
||||
return ret < 0 ? ret : AVERROR_EOF;
|
||||
|
||||
os->nsegs = nsegs;
|
||||
os->segp = 0;
|
||||
@ -289,8 +291,9 @@ static int ogg_read_page(AVFormatContext *s, int *str)
|
||||
os->buf = nb;
|
||||
}
|
||||
|
||||
if (avio_read (bc, os->buf + os->bufpos, size) < size)
|
||||
return -1;
|
||||
ret = avio_read(bc, os->buf + os->bufpos, size);
|
||||
if (ret < size)
|
||||
return ret < 0 ? ret : AVERROR_EOF;
|
||||
|
||||
os->bufpos += size;
|
||||
os->granule = gp;
|
||||
@ -306,7 +309,7 @@ static int ogg_packet(AVFormatContext *s, int *str, int *dstart, int *dsize,
|
||||
int64_t *fpos)
|
||||
{
|
||||
struct ogg *ogg = s->priv_data;
|
||||
int idx, i;
|
||||
int idx, i, ret;
|
||||
struct ogg_stream *os;
|
||||
int complete = 0;
|
||||
int segp = 0, psize = 0;
|
||||
@ -317,8 +320,9 @@ static int ogg_packet(AVFormatContext *s, int *str, int *dstart, int *dsize,
|
||||
idx = ogg->curidx;
|
||||
|
||||
while (idx < 0){
|
||||
if (ogg_read_page (s, &idx) < 0)
|
||||
return -1;
|
||||
ret = ogg_read_page(s, &idx);
|
||||
if (ret < 0)
|
||||
return ret;
|
||||
}
|
||||
|
||||
os = ogg->streams + idx;
|
||||
@ -330,6 +334,7 @@ static int ogg_packet(AVFormatContext *s, int *str, int *dstart, int *dsize,
|
||||
if (os->header < 0){
|
||||
os->codec = ogg_find_codec (os->buf, os->bufpos);
|
||||
if (!os->codec){
|
||||
av_log(s, AV_LOG_WARNING, "Codec not found\n");
|
||||
os->header = 0;
|
||||
return 0;
|
||||
}
|
||||
@ -428,10 +433,12 @@ static int ogg_packet(AVFormatContext *s, int *str, int *dstart, int *dsize,
|
||||
static int ogg_get_headers(AVFormatContext *s)
|
||||
{
|
||||
struct ogg *ogg = s->priv_data;
|
||||
int ret;
|
||||
|
||||
do{
|
||||
if (ogg_packet (s, NULL, NULL, NULL, NULL) < 0)
|
||||
return -1;
|
||||
ret = ogg_packet(s, NULL, NULL, NULL, NULL);
|
||||
if (ret < 0)
|
||||
return ret;
|
||||
}while (!ogg->headers);
|
||||
|
||||
av_dlog(s, "found headers\n");
|
||||
@ -478,12 +485,12 @@ static int ogg_get_length(AVFormatContext *s)
|
||||
static int ogg_read_header(AVFormatContext *s, AVFormatParameters *ap)
|
||||
{
|
||||
struct ogg *ogg = s->priv_data;
|
||||
int i;
|
||||
int ret, i;
|
||||
ogg->curidx = -1;
|
||||
//linear headers seek from start
|
||||
if (ogg_get_headers (s) < 0){
|
||||
return -1;
|
||||
}
|
||||
ret = ogg_get_headers(s);
|
||||
if (ret < 0)
|
||||
return ret;
|
||||
|
||||
for (i = 0; i < ogg->nstreams; i++)
|
||||
if (ogg->streams[i].header < 0)
|
||||
@ -530,15 +537,16 @@ static int ogg_read_packet(AVFormatContext *s, AVPacket *pkt)
|
||||
{
|
||||
struct ogg *ogg;
|
||||
struct ogg_stream *os;
|
||||
int idx = -1;
|
||||
int idx = -1, ret;
|
||||
int pstart, psize;
|
||||
int64_t fpos, pts, dts;
|
||||
|
||||
//Get an ogg packet
|
||||
retry:
|
||||
do{
|
||||
if (ogg_packet (s, &idx, &pstart, &psize, &fpos) < 0)
|
||||
return AVERROR(EIO);
|
||||
ret = ogg_packet(s, &idx, &pstart, &psize, &fpos);
|
||||
if (ret < 0)
|
||||
return ret;
|
||||
}while (idx < 0 || !s->streams[idx]);
|
||||
|
||||
ogg = s->priv_data;
|
||||
@ -552,8 +560,9 @@ retry:
|
||||
os->keyframe_seek = 0;
|
||||
|
||||
//Alloc a pkt
|
||||
if (av_new_packet (pkt, psize) < 0)
|
||||
return AVERROR(EIO);
|
||||
ret = av_new_packet(pkt, psize);
|
||||
if (ret < 0)
|
||||
return ret;
|
||||
pkt->stream_index = idx;
|
||||
memcpy (pkt->data, os->buf + pstart, psize);
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user