fourxm->fps = 1.0;
/* skip the first 3 32-bit numbers */
- avio_seek(pb, 12, SEEK_CUR);
+ avio_skip(pb, 12);
/* check for LIST-HEAD */
GET_LIST_HEADER();
fourxm->tracks[track_number].audio_pts += audio_frame_count;
} else {
- avio_seek(pb, size, SEEK_CUR);
+ avio_skip(pb, size);
}
break;
default:
- avio_seek(pb, size, SEEK_CUR);
+ avio_skip(pb, size);
break;
}
}
return AVERROR(ENOMEM);
/* Parse the amount of channels and skip to pos 2048(0x800) */
- avio_seek(s->pb, 264, SEEK_CUR);
+ avio_skip(s->pb, 264);
st->codec->channels = avio_r8(s->pb);
- avio_seek(s->pb, 1783, SEEK_CUR);
+ avio_skip(s->pb, 1783);
st->codec->codec_type = AVMEDIA_TYPE_AUDIO;
int res;
if (!str) {
- avio_seek(s->pb, size, SEEK_CUR);
+ avio_skip(s->pb, size);
return;
}
/* Chunk is over */
if (size)
- avio_seek(pb, size, SEEK_CUR);
+ avio_skip(pb, size);
return num_frames;
}
av_log(s, AV_LOG_ERROR, "file is not seekable\n");
return -1;
}
- avio_seek(pb, size - 8, SEEK_CUR);
+ avio_skip(pb, size - 8);
break;
case MKTAG('w', 'a', 'v', 'e'):
if ((uint64_t)size > (1<<30))
default: /* Jump */
if (size & 1) /* Always even aligned */
size++;
- avio_seek(pb, size, SEEK_CUR);
+ avio_skip(pb, size);
}
}
AVStream *st;
int i, ret;
- avio_seek(pb, 4, SEEK_CUR); /* magic number */
+ avio_skip(pb, 4); /* magic number */
if (avio_rl16(pb) != MAX_PAGES) {
av_log_ask_for_sample(s, "max_pages != " AV_STRINGIFY(MAX_PAGES) "\n");
return AVERROR_INVALIDDATA;
anm->nb_pages = avio_rl16(pb);
anm->nb_records = avio_rl32(pb);
- avio_seek(pb, 2, SEEK_CUR); /* max records per page */
+ avio_skip(pb, 2); /* max records per page */
anm->page_table_offset = avio_rl16(pb);
if (avio_rl32(pb) != ANIM_TAG)
return AVERROR_INVALIDDATA;
st->codec->height = avio_rl16(pb);
if (avio_r8(pb) != 0)
goto invalid;
- avio_seek(pb, 1, SEEK_CUR); /* frame rate multiplier info */
+ avio_skip(pb, 1); /* frame rate multiplier info */
/* ignore last delta record (used for looping) */
if (avio_r8(pb)) /* has_last_delta */
anm->nb_records = FFMAX(anm->nb_records - 1, 0);
- avio_seek(pb, 1, SEEK_CUR); /* last_delta_valid */
+ avio_skip(pb, 1); /* last_delta_valid */
if (avio_r8(pb) != 0)
goto invalid;
if (avio_r8(pb) != 1)
goto invalid;
- avio_seek(pb, 1, SEEK_CUR); /* other recs per frame */
+ avio_skip(pb, 1); /* other recs per frame */
if (avio_r8(pb) != 1)
goto invalid;
- avio_seek(pb, 32, SEEK_CUR); /* record_types */
+ avio_skip(pb, 32); /* record_types */
st->nb_frames = avio_rl32(pb);
av_set_pts_info(st, 64, 1, avio_rl16(pb));
- avio_seek(pb, 58, SEEK_CUR);
+ avio_skip(pb, 58);
/* color cycling and palette data */
st->codec->extradata_size = 16*8 + 4*256;
/* parse page header */
if (anm->record < 0) {
avio_seek(pb, anm->page_table_offset + MAX_PAGES*6 + (anm->page<<16), SEEK_SET);
- avio_seek(pb, 8 + 2*p->nb_records, SEEK_CUR);
+ avio_skip(pb, 8 + 2*p->nb_records);
anm->record = 0;
}
/* Skip any unknown bytes at the end of the descriptor.
This is for future compatibility */
if (ape->descriptorlength > 52)
- avio_seek(pb, ape->descriptorlength - 52, SEEK_CUR);
+ avio_skip(pb, ape->descriptorlength - 52);
/* Read header data */
ape->compressiontype = avio_rl16(pb);
ape->finalframeblocks = avio_rl32(pb);
if (ape->formatflags & MAC_FORMAT_FLAG_HAS_PEAK_LEVEL) {
- avio_seek(pb, 4, SEEK_CUR); /* Skip the peak level */
+ avio_skip(pb, 4); /* Skip the peak level */
ape->headerlength += 4;
}
/* Skip any stored wav header */
if (!(ape->formatflags & MAC_FORMAT_FLAG_CREATE_WAV_HEADER))
- avio_seek(pb, ape->wavheaderlength, SEEK_CUR);
+ avio_skip(pb, ape->wavheaderlength);
}
if(!ape->totalframes){
avio_rl16(pb); /* panes */
st->codec->bits_per_coded_sample = avio_rl16(pb); /* depth */
tag1 = avio_rl32(pb);
- avio_seek(pb, 20, SEEK_CUR);
+ avio_skip(pb, 20);
// av_log(s, AV_LOG_DEBUG, "size:%d tsize:%d sizeX:%d\n", size, total_size, sizeX);
if (sizeX > 40) {
st->codec->extradata_size = sizeX - 40;
st->need_parsing = AVSTREAM_PARSE_FULL_ONCE;
}
pos2 = avio_tell(pb);
- avio_seek(pb, size - (pos2 - pos1 + 24), SEEK_CUR);
+ avio_skip(pb, size - (pos2 - pos1 + 24));
return 0;
}
for (i=0; i<stream_ct; i++){
avio_rl16(pb);
ext_len = avio_rl16(pb);
- avio_seek(pb, ext_len, SEEK_CUR);
+ avio_skip(pb, ext_len);
}
for (i=0; i<payload_ext_ct; i++){
ff_get_guid(pb, &g);
ext_d=avio_rl16(pb);
ext_len=avio_rl32(pb);
- avio_seek(pb, ext_len, SEEK_CUR);
+ avio_skip(pb, ext_len);
}
return 0;
get_tag(s, "author" , 0, len2);
get_tag(s, "copyright", 0, len3);
get_tag(s, "comment" , 0, len4);
- avio_seek(pb, len5, SEEK_CUR);
+ avio_skip(pb, len5);
return 0;
}
if (name_len%2) // must be even, broken lavf versions wrote len-1
name_len += 1;
if ((ret = avio_get_str16le(pb, name_len, name, sizeof(name))) < name_len)
- avio_seek(pb, name_len - ret, SEEK_CUR);
+ avio_skip(pb, name_len - ret);
value_type = avio_rl16(pb);
value_len = avio_rl16(pb);
if (!value_type && value_len%2)
char lang[6];
unsigned int lang_len = avio_r8(pb);
if ((ret = avio_get_str16le(pb, lang_len, lang, sizeof(lang))) < lang_len)
- avio_seek(pb, lang_len - ret, SEEK_CUR);
+ avio_skip(pb, lang_len - ret);
if (j < 128)
av_strlcpy(asf->stream_languages[j], lang, sizeof(*asf->stream_languages));
}
value_len= avio_rl32(pb);
if ((ret = avio_get_str16le(pb, name_len, name, sizeof(name))) < name_len)
- avio_seek(pb, name_len - ret, SEEK_CUR);
+ avio_skip(pb, name_len - ret);
//av_log(s, AV_LOG_ERROR, "%d %d %d %d %d <%s>\n", i, stream_num, name_len, value_type, value_len, name);
value_num= avio_rl16(pb);//we should use get_value() here but it does not work 2 is le16 here but le32 elsewhere
- avio_seek(pb, value_len - 2, SEEK_CUR);
+ avio_skip(pb, value_len - 2);
if(stream_num<128){
if (!strcmp(name, "AspectRatioX")) asf->dar[stream_num].num= value_num;
avio_rl32(pb); // flags
name_len = avio_rl32(pb); // name length
if ((ret = avio_get_str16le(pb, name_len * 2, name, sizeof(name))) < name_len)
- avio_seek(pb, name_len - ret, SEEK_CUR);
+ avio_skip(pb, name_len - ret);
ff_new_chapter(s, i, (AVRational){1, 10000000}, pres_time, AV_NOPTS_VALUE, name );
}
// for(i=0; i<asf->packet_replic_size-8; i++)
// av_log(s, AV_LOG_DEBUG, "%02X ",avio_r8(pb));
// av_log(s, AV_LOG_DEBUG, "\n");
- avio_seek(pb, 10, SEEK_CUR);
+ avio_skip(pb, 10);
ts0= avio_rl64(pb);
ts1= avio_rl64(pb);
- avio_seek(pb, 12, SEEK_CUR);
+ avio_skip(pb, 12);
avio_rl32(pb);
- avio_seek(pb, asf->packet_replic_size - 8 - 38 - 4, SEEK_CUR);
+ avio_skip(pb, asf->packet_replic_size - 8 - 38 - 4);
if(ts0!= -1) asf->packet_frag_timestamp= ts0/10000;
else asf->packet_frag_timestamp= AV_NOPTS_VALUE;
}else
- avio_seek(pb, asf->packet_replic_size - 8, SEEK_CUR);
+ avio_skip(pb, asf->packet_replic_size - 8);
rsize += asf->packet_replic_size; // FIXME - check validity
} else if (asf->packet_replic_size==1){
// multipacket - frag_offset is beginning timestamp
//printf("PacketLeftSize:%d Pad:%d Pos:%"PRId64"\n", asf->packet_size_left, asf->packet_padsize, avio_tell(pb));
assert(ret>=0);
/* fail safe */
- avio_seek(pb, ret, SEEK_CUR);
+ avio_skip(pb, ret);
asf->packet_pos= avio_tell(pb);
if (asf->data_object_size != (uint64_t)-1 &&
) {
asf->packet_time_start = 0;
/* unhandled packet (should not happen) */
- avio_seek(pb, asf->packet_frag_size, SEEK_CUR);
+ avio_skip(pb, asf->packet_frag_size);
asf->packet_size_left -= asf->packet_frag_size;
if(asf->stream_index < 0)
av_log(s, AV_LOG_ERROR, "ff asf skip %d (unknown stream)\n", asf->packet_frag_size);
if (asf->packet_multi_size < asf->packet_obj_size)
{
asf->packet_time_start = 0;
- avio_seek(pb, asf->packet_multi_size, SEEK_CUR);
+ avio_skip(pb, asf->packet_multi_size);
asf->packet_size_left -= asf->packet_multi_size;
continue;
}
avio_seek(s->pb, current_pos, SEEK_SET);
return;
}
- avio_seek(s->pb, gsize-24, SEEK_CUR);
+ avio_skip(s->pb, gsize-24);
ff_get_guid(s->pb, &g);
}
if (size >= 24) {
/* skip unused data */
- avio_seek(pb, size - 24, SEEK_CUR);
+ avio_skip(pb, size - 24);
}
/* now we are ready: build format streams */
}
if (name)
av_metadata_set2(&s->metadata, name, buffer, 0);
- avio_seek(s->pb, size, SEEK_CUR);
+ avio_skip(s->pb, size);
}
break;
}
default:
- avio_seek(s->pb, size, SEEK_CUR);
+ avio_skip(s->pb, size);
break;
}
}
unsigned char date[64] = {0};
size += (size & 1);
size -= avio_read(pb, date, FFMIN(size, sizeof(date)-1));
- avio_seek(pb, size, SEEK_CUR);
+ avio_skip(pb, size);
avi_metadata_creation_time(&s->metadata, date);
break;
}
case MKTAG('d', 'm', 'l', 'h'):
avi->is_odml = 1;
- avio_seek(pb, size + (size & 1), SEEK_CUR);
+ avio_skip(pb, size + (size & 1));
break;
case MKTAG('a', 'm', 'v', 'h'):
amv_file_format=1;
avio_rl32(pb);
avi->non_interleaved |= avio_rl32(pb) & AVIF_MUSTUSEINDEX;
- avio_seek(pb, 2 * 4, SEEK_CUR);
+ avio_skip(pb, 2 * 4);
avio_rl32(pb);
avio_rl32(pb);
avih_width=avio_rl32(pb);
avih_height=avio_rl32(pb);
- avio_seek(pb, size - 10 * 4, SEEK_CUR);
+ avio_skip(pb, size - 10 * 4);
break;
case MKTAG('s', 't', 'r', 'h'):
/* stream header */
handler = avio_rl32(pb); /* codec tag */
if(tag1 == MKTAG('p', 'a', 'd', 's')){
- avio_seek(pb, size - 8, SEEK_CUR);
+ avio_skip(pb, size - 8);
break;
}else{
stream_index++;
goto fail;
}
s->streams[0]->priv_data = ast;
- avio_seek(pb, 3 * 4, SEEK_CUR);
+ avio_skip(pb, 3 * 4);
ast->scale = avio_rl32(pb);
ast->rate = avio_rl32(pb);
- avio_seek(pb, 4, SEEK_CUR); /* start time */
+ avio_skip(pb, 4); /* start time */
dv_dur = avio_rl32(pb);
if (ast->scale > 0 && ast->rate > 0 && dv_dur > 0) {
*/
stream_index = s->nb_streams - 1;
- avio_seek(pb, size - 9*4, SEEK_CUR);
+ avio_skip(pb, size - 9*4);
break;
}
if(ast->sample_size == 0)
st->duration = st->nb_frames;
ast->frame_offset= ast->cum_len;
- avio_seek(pb, size - 12 * 4, SEEK_CUR);
+ avio_skip(pb, size - 12 * 4);
break;
case MKTAG('s', 't', 'r', 'f'):
/* stream header */
if (stream_index >= (unsigned)s->nb_streams || avi->dv_demux) {
- avio_seek(pb, size, SEEK_CUR);
+ avio_skip(pb, size);
} else {
uint64_t cur_pos = avio_tell(pb);
if (cur_pos < list_end)
st->codec->height=avih_height;
st->codec->codec_type = AVMEDIA_TYPE_VIDEO;
st->codec->codec_id = CODEC_ID_AMV;
- avio_seek(pb, size, SEEK_CUR);
+ avio_skip(pb, size);
break;
}
tag1 = ff_get_bmp_header(pb, st);
}
st->codec->height= FFABS(st->codec->height);
-// avio_seek(pb, size - 5 * 4, SEEK_CUR);
+// avio_skip(pb, size - 5 * 4);
break;
case AVMEDIA_TYPE_AUDIO:
ff_get_wav_header(pb, st->codec, size);
ast->sample_size= st->codec->block_align;
}
if (size&1) /* 2-aligned (fix for Stargate SG-1 - 3x18 - Shades of Grey.avi) */
- avio_seek(pb, 1, SEEK_CUR);
+ avio_skip(pb, 1);
/* Force parsing as several audio frames can be in
* one packet and timestamps refer to packet start. */
st->need_parsing = AVSTREAM_PARSE_TIMESTAMPS;
st->codec->codec_type = AVMEDIA_TYPE_DATA;
st->codec->codec_id= CODEC_ID_NONE;
st->codec->codec_tag= 0;
- avio_seek(pb, size, SEEK_CUR);
+ avio_skip(pb, size);
break;
}
}
}
size -= 9*4;
}
- avio_seek(pb, size, SEEK_CUR);
+ avio_skip(pb, size);
break;
case MKTAG('s', 't', 'r', 'n'):
if(s->nb_streams){
}
/* skip tag */
size += (size & 1);
- avio_seek(pb, size, SEEK_CUR);
+ avio_skip(pb, size);
break;
}
}
goto error;
ret = avio_get_str16le(pb, desc_len, desc, sizeof(desc));
- avio_seek(pb, desc_len - ret, SEEK_CUR);
+ avio_skip(pb, desc_len - ret);
if (*desc)
av_metadata_set2(&st->metadata, "title", desc, 0);
//parse JUNK
||(d[0] == 'J' && d[1] == 'U' && d[2] == 'N' && d[3] == 'K')
||(d[0] == 'i' && d[1] == 'd' && d[2] == 'x' && d[3] == '1')){
- avio_seek(pb, size, SEEK_CUR);
+ avio_skip(pb, size);
//av_log(s, AV_LOG_DEBUG, "SKIP\n");
goto resync;
}
//parse stray LIST
if(d[0] == 'L' && d[1] == 'I' && d[2] == 'S' && d[3] == 'T'){
- avio_seek(pb, 4, SEEK_CUR);
+ avio_skip(pb, 4);
goto resync;
}
//detect ##ix chunk and skip
if(d[2] == 'i' && d[3] == 'x' && n < s->nb_streams){
- avio_seek(pb, size, SEEK_CUR);
+ avio_skip(pb, size);
goto resync;
}
/*|| (st->discard >= AVDISCARD_NONKEY && !(pkt->flags & AV_PKT_FLAG_KEY))*/ //FIXME needs a little reordering
|| st->discard >= AVDISCARD_ALL){
ast->frame_offset += get_duration(ast, size);
- avio_seek(pb, size, SEEK_CUR);
+ avio_skip(pb, size);
goto resync;
}
default:
skip:
size += (size & 1);
- if (avio_seek(pb, size, SEEK_CUR) < 0)
+ if (avio_skip(pb, size) < 0)
goto the_end; // something is wrong here
break;
}
/* Updating one entry in the AVI OpenDML master index */
avio_seek(pb, avist->indexes.indx_start - 8, SEEK_SET);
ffio_wfourcc(pb, "indx"); /* enabling this entry */
- avio_seek(pb, 8, SEEK_CUR);
+ avio_skip(pb, 8);
avio_wl32(pb, avi->riff_id); /* nEntriesInUse */
- avio_seek(pb, 16*avi->riff_id, SEEK_CUR);
+ avio_skip(pb, 16*avi->riff_id);
avio_wl64(pb, ix); /* qwOffset */
avio_wl32(pb, pos - ix); /* dwSize */
avio_wl32(pb, avist->indexes.entry); /* dwDuration */
file_size = avio_tell(pb);
avio_seek(pb, avi->odml_list - 8, SEEK_SET);
ffio_wfourcc(pb, "LIST"); /* Making this AVI OpenDML one */
- avio_seek(pb, 16, SEEK_CUR);
+ avio_skip(pb, 16);
for (n=nb_frames=0;n<s->nb_streams;n++) {
AVCodecContext *stream = s->streams[n]->codec;
s->ctx_flags |= AVFMTCTX_NOHEADER;
- avio_seek(s->pb, 4, SEEK_CUR);
+ avio_skip(s->pb, 4);
avs->width = avio_rl16(s->pb);
avs->height = avio_rl16(s->pb);
avs->bits_per_sample = avio_rl16(s->pb);
break;
default:
- avio_seek(s->pb, size - 4, SEEK_CUR);
+ avio_skip(s->pb, size - 4);
}
}
}
* bytes: 'V' 'I' 'D'
* int16s: always_512, nframes, width, height, delay, always_14
*/
- avio_seek(pb, 5, SEEK_CUR);
+ avio_skip(pb, 5);
vid->nframes = avio_rl16(pb);
stream = av_new_stream(s, 0);
return AVERROR(ENOMEM);
/* Set the total number of frames. */
- avio_seek(pb, 8, SEEK_CUR);
+ avio_skip(pb, 8);
chunk_header = avio_rl32(pb);
bfi->nframes = avio_rl32(pb);
avio_rl32(pb);
avio_rl32(pb);
avio_rl32(pb);
fps = avio_rl32(pb);
- avio_seek(pb, 12, SEEK_CUR);
+ avio_skip(pb, 12);
vstream->codec->width = avio_rl32(pb);
vstream->codec->height = avio_rl32(pb);
/*Load the palette to extradata */
- avio_seek(pb, 8, SEEK_CUR);
+ avio_skip(pb, 8);
vstream->codec->extradata = av_malloc(768);
vstream->codec->extradata_size = 768;
avio_read(pb, vstream->codec->extradata,
return AVERROR(EIO);
}
- avio_seek(pb, 4, SEEK_CUR);
+ avio_skip(pb, 4);
vst->codec->width = avio_rl32(pb);
vst->codec->height = avio_rl32(pb);
}
if (bink->num_audio_tracks) {
- avio_seek(pb, 4 * bink->num_audio_tracks, SEEK_CUR);
+ avio_skip(pb, 4 * bink->num_audio_tracks);
for (i = 0; i < bink->num_audio_tracks; i++) {
ast = av_new_stream(s, 1);
keyframe ? AVINDEX_KEYFRAME : 0);
}
- avio_seek(pb, 4, SEEK_CUR);
+ avio_skip(pb, 4);
bink->current_track = -1;
return 0;
AV_RL32(pkt->data) / (2 * s->streams[bink->current_track]->codec->channels);
return 0;
} else {
- avio_seek(pb, audio_size, SEEK_CUR);
+ avio_skip(pb, audio_size);
}
}
return AVERROR(ENOMEM);
c93->audio->codec->codec_type = AVMEDIA_TYPE_AUDIO;
}
- avio_seek(pb, 26, SEEK_CUR); /* VOC header */
+ avio_skip(pb, 26); /* VOC header */
ret = voc_get_packet(s, pkt, c93->audio, datasize - 26);
if (ret > 0) {
pkt->stream_index = 1;
av_log(s, AV_LOG_ERROR, "invalid AAC magic cookie\n");
return AVERROR_INVALIDDATA;
}
- avio_seek(pb, skip, SEEK_CUR);
+ avio_skip(pb, skip);
} else if (st->codec->codec_id == CODEC_ID_ALAC) {
#define ALAC_PREAMBLE 12
#define ALAC_HEADER 36
if (size < ALAC_PREAMBLE + ALAC_HEADER) {
av_log(s, AV_LOG_ERROR, "invalid ALAC magic cookie\n");
- avio_seek(pb, size, SEEK_CUR);
+ avio_skip(pb, size);
return AVERROR_INVALIDDATA;
}
- avio_seek(pb, ALAC_PREAMBLE, SEEK_CUR);
+ avio_skip(pb, ALAC_PREAMBLE);
st->codec->extradata = av_mallocz(ALAC_HEADER + FF_INPUT_BUFFER_PADDING_SIZE);
if (!st->codec->extradata)
return AVERROR(ENOMEM);
avio_read(pb, st->codec->extradata, ALAC_HEADER);
st->codec->extradata_size = ALAC_HEADER;
- avio_seek(pb, size - ALAC_PREAMBLE - ALAC_HEADER, SEEK_CUR);
+ avio_skip(pb, size - ALAC_PREAMBLE - ALAC_HEADER);
} else {
st->codec->extradata = av_mallocz(size + FF_INPUT_BUFFER_PADDING_SIZE);
if (!st->codec->extradata)
int found_data, ret;
int64_t size;
- avio_seek(pb, 8, SEEK_CUR); /* magic, version, file flags */
+ avio_skip(pb, 8); /* magic, version, file flags */
/* audio description chunk */
if (avio_rb32(pb) != MKBETAG('d','e','s','c')) {
switch (tag) {
case MKBETAG('d','a','t','a'):
- avio_seek(pb, 4, SEEK_CUR); /* edit count */
+ avio_skip(pb, 4); /* edit count */
caf->data_start = avio_tell(pb);
caf->data_size = size < 0 ? -1 : size - 4;
if (caf->data_size > 0 && !url_is_streamed(pb))
- avio_seek(pb, caf->data_size, SEEK_CUR);
+ avio_skip(pb, caf->data_size);
found_data = 1;
break;
case MKBETAG('f','r','e','e'):
if (size < 0)
return AVERROR_INVALIDDATA;
- avio_seek(pb, size, SEEK_CUR);
+ avio_skip(pb, size);
break;
}
}
c->has_sound = 1;
size = avio_rb32(pb);
c->vidpos = avio_tell(pb) + size;
- avio_seek(pb, 16, SEEK_CUR);
+ avio_skip(pb, 16);
fsize = avio_rl32(pb);
ast = av_new_stream(s, 0);
tag = avio_rl32(pb);
fsize = avio_rl32(pb);
if(tag == MKTAG('d', 'a', 't', 'a')) break;
- avio_seek(pb, fsize, SEEK_CUR);
+ avio_skip(pb, fsize);
}
c->bpc = (fsize + c->frames - 1) / c->frames;
if(ast->codec->block_align)
};
sample_rate = avio_rb16(pb);
- avio_seek(pb, 12, SEEK_CUR);
+ avio_skip(pb, 12);
st = av_new_stream(s, 0);
if (!st)
ea->bytes = avio_r8(pb); /* 1=8-bit, 2=16-bit */
ea->num_channels = avio_r8(pb);
compression_type = avio_r8(pb);
- avio_seek(pb, 13, SEEK_CUR);
+ avio_skip(pb, 13);
switch (compression_type) {
case 0:
{
EaDemuxContext *ea = s->priv_data;
AVIOContext *pb = s->pb;
- avio_seek(pb, 4, SEEK_CUR);
+ avio_skip(pb, 4);
ea->width = avio_rl16(pb);
ea->height = avio_rl16(pb);
ea->time_base = (AVRational){1,15};
EaDemuxContext *ea = s->priv_data;
AVIOContext *pb = s->pb;
- avio_seek(pb, 16, SEEK_CUR);
+ avio_skip(pb, 16);
ea->time_base.den = avio_rl32(pb);
ea->time_base.num = avio_rl32(pb);
ea->video_codec = CODEC_ID_VP6;
case SHEN_TAG :
blockid = avio_rl32(pb);
if (blockid == GSTR_TAG) {
- avio_seek(pb, 4, SEEK_CUR);
+ avio_skip(pb, 4);
} else if ((blockid & 0xFFFF)!=PT00_TAG) {
av_log (s, AV_LOG_ERROR, "unknown SCHl headerid\n");
return 0;
/* audio data */
case ISNh_TAG:
/* header chunk also contains data; skip over the header portion*/
- avio_seek(pb, 32, SEEK_CUR);
+ avio_skip(pb, 32);
chunk_size -= 32;
case ISNd_TAG:
case SCDl_TAG:
case SNDC_TAG:
case SDEN_TAG:
if (!ea->audio_codec) {
- avio_seek(pb, chunk_size, SEEK_CUR);
+ avio_skip(pb, chunk_size);
break;
} else if (ea->audio_codec == CODEC_ID_PCM_S16LE_PLANAR ||
ea->audio_codec == CODEC_ID_MP3) {
num_samples = avio_rl32(pb);
- avio_seek(pb, 8, SEEK_CUR);
+ avio_skip(pb, 8);
chunk_size -= 12;
}
ret = av_get_packet(pb, pkt, chunk_size);
goto get_video_packet;
case mTCD_TAG:
- avio_seek(pb, 8, SEEK_CUR); // skip ea dct header
+ avio_skip(pb, 8); // skip ea dct header
chunk_size -= 8;
goto get_video_packet;
break;
default:
- avio_seek(pb, chunk_size, SEEK_CUR);
+ avio_skip(pb, chunk_size);
break;
}
}
int64_t dts;
ffm_seek1(s, pos);
- avio_seek(pb, 4, SEEK_CUR);
+ avio_skip(pb, 4);
dts = avio_rb64(pb);
#ifdef DEBUG_SEEK
av_log(s, AV_LOG_DEBUG, "dts=%0.6f\n", dts / 1000000.0);
return AVERROR_INVALIDDATA;
}
- avio_seek(pb, 2, SEEK_CUR);
+ avio_skip(pb, 2);
st->codec->codec_type = AVMEDIA_TYPE_VIDEO;
st->codec->codec_id = CODEC_ID_RAWVIDEO;
st->codec->pix_fmt = PIX_FMT_RGBA;
return AVERROR(EIO);
pkt->dts = avio_tell(s->pb) / (st->codec->width * (st->codec->height + film->leading) * 4);
pkt->size = av_get_packet(s->pb, pkt, st->codec->width * st->codec->height * 4);
- avio_seek(s->pb, st->codec->width * film->leading * 4, SEEK_CUR);
+ avio_skip(s->pb, st->codec->width * film->leading * 4);
if (pkt->size < 0)
return pkt->size;
pkt->flags |= AV_PKT_FLAG_KEY;
break;
/* skip metadata block for unsupported types */
default:
- ret = avio_seek(s->pb, metadata_size, SEEK_CUR);
+ ret = avio_skip(s->pb, metadata_size);
if (ret < 0)
return ret;
}
}
/* skip useless 10B sub-header (yes, it's not accounted for in the chunk header) */
- avio_seek(pb, 10, SEEK_CUR);
+ avio_skip(pb, 10);
pkt->stream_index = flic->audio_stream_index;
pkt->pos = avio_tell(pb);
packet_read = 1;
} else {
/* not interested in this chunk */
- avio_seek(pb, size - 6, SEEK_CUR);
+ avio_skip(pb, size - 6);
}
}
static int amf_get_string(AVIOContext *ioc, char *buffer, int buffsize) {
int length = avio_rb16(ioc);
if(length >= buffsize) {
- avio_seek(ioc, length, SEEK_CUR);
+ avio_skip(ioc, length);
return -1;
}
unsigned int keylen;
while(avio_tell(ioc) < max_pos - 2 && (keylen = avio_rb16(ioc))) {
- avio_seek(ioc, keylen, SEEK_CUR); //skip key string
+ avio_skip(ioc, keylen); //skip key string
if(amf_parse_object(s, NULL, NULL, NULL, max_pos, depth + 1) < 0)
return -1; //if we couldn't skip, bomb out.
}
case AMF_DATA_TYPE_UNSUPPORTED:
break; //these take up no additional space
case AMF_DATA_TYPE_MIXEDARRAY:
- avio_seek(ioc, 4, SEEK_CUR); //skip 32-bit max array index
+ avio_skip(ioc, 4); //skip 32-bit max array index
while(avio_tell(ioc) < max_pos - 2 && amf_get_string(ioc, str_val, sizeof(str_val)) > 0) {
//this is the only case in which we would want a nested parse to not skip over the object
if(amf_parse_object(s, astream, vstream, str_val, max_pos, depth + 1) < 0)
}
break;
case AMF_DATA_TYPE_DATE:
- avio_seek(ioc, 8 + 2, SEEK_CUR); //timestamp (double) and UTC offset (int16)
+ avio_skip(ioc, 8 + 2); //timestamp (double) and UTC offset (int16)
break;
default: //unsupported type, we couldn't skip
return -1;
{
int offset, flags;
- avio_seek(s->pb, 4, SEEK_CUR);
+ avio_skip(s->pb, 4);
flags = avio_r8(s->pb);
/* old flvtool cleared this field */
/* FIXME: better fix needed */
offset = avio_rb32(s->pb);
avio_seek(s->pb, offset, SEEK_SET);
- avio_seek(s->pb, 4, SEEK_CUR);
+ avio_skip(s->pb, 4);
s->start_time = 0;
int64_t dts, pts = AV_NOPTS_VALUE;
AVStream *st = NULL;
- for(;;avio_seek(s->pb, 4, SEEK_CUR)){ /* pkt size is repeated at end. skip it */
+ for(;;avio_skip(s->pb, 4)){ /* pkt size is repeated at end. skip it */
pos = avio_tell(s->pb);
type = avio_r8(s->pb);
size = avio_rb24(s->pb);
// av_log(s, AV_LOG_DEBUG, "type:%d, size:%d, dts:%d\n", type, size, dts);
if (s->pb->eof_reached)
return AVERROR_EOF;
- avio_seek(s->pb, 3, SEEK_CUR); /* stream id, always 0 */
+ avio_skip(s->pb, 3); /* stream id, always 0 */
flags = 0;
if(size == 0)
pkt->flags |= AV_PKT_FLAG_KEY;
leave:
- avio_seek(s->pb, 4, SEEK_CUR);
+ avio_skip(s->pb, 4);
return ret;
}
data_size= avio_tell(pb) - metadata_size_pos - 10;
avio_seek(pb, metadata_size_pos, SEEK_SET);
avio_wb24(pb, data_size);
- avio_seek(pb, data_size + 10 - 3, SEEK_CUR);
+ avio_skip(pb, data_size + 10 - 3);
avio_wb32(pb, data_size + 11);
for (i = 0; i < s->nb_streams; i++) {
data_size = avio_tell(pb) - pos;
avio_seek(pb, -data_size - 10, SEEK_CUR);
avio_wb24(pb, data_size);
- avio_seek(pb, data_size + 10 - 3, SEEK_CUR);
+ avio_skip(pb, data_size + 10 - 3);
avio_wb32(pb, data_size + 11); // previous tag size
}
}
else if (tag == MAT_LAST_FIELD)
si->last_field = value;
} else
- avio_seek(pb, tlen, SEEK_CUR);
+ avio_skip(pb, tlen);
}
}
else if (tag == TRACK_FPF && (value == 1 || value == 2))
si->fields_per_frame = value;
} else
- avio_seek(pb, tlen, SEEK_CUR);
+ avio_skip(pb, tlen);
}
}
int i;
pkt_len -= 8;
if (s->flags & AVFMT_FLAG_IGNIDX) {
- avio_seek(pb, pkt_len, SEEK_CUR);
+ avio_skip(pb, pkt_len);
return;
}
if (map_cnt > 1000) {
}
if (pkt_len < 4 * map_cnt) {
av_log(s, AV_LOG_ERROR, "invalid index length\n");
- avio_seek(pb, pkt_len, SEEK_CUR);
+ avio_skip(pb, pkt_len);
return;
}
pkt_len -= 4 * map_cnt;
for (i = 0; i < map_cnt; i++)
av_add_index_entry(st, (uint64_t)avio_rl32(pb) * 1024,
i * (uint64_t)fields_per_map + 1, 0, 0, 0);
- avio_seek(pb, pkt_len, SEEK_CUR);
+ avio_skip(pb, pkt_len);
}
static int gxf_header(AVFormatContext *s, AVFormatParameters *ap) {
}
map_len -= len;
gxf_material_tags(pb, &len, &si);
- avio_seek(pb, len, SEEK_CUR);
+ avio_skip(pb, len);
map_len -= 2;
len = avio_rb16(pb); // length of track description
if (len > map_len) {
track_len = avio_rb16(pb);
len -= track_len;
gxf_track_tags(pb, &track_len, &si);
- avio_seek(pb, track_len, SEEK_CUR);
+ avio_skip(pb, track_len);
if (!(track_type & 0x80)) {
av_log(s, AV_LOG_ERROR, "invalid track type %x\n", track_type);
continue;
if (len < 0)
av_log(s, AV_LOG_ERROR, "invalid track description length specified\n");
if (map_len)
- avio_seek(pb, map_len, SEEK_CUR);
+ avio_skip(pb, map_len);
if (!parse_packet_header(pb, &pkt_type, &len)) {
av_log(s, AV_LOG_ERROR, "sync lost in header\n");
return -1;
if (len >= 0x39) {
AVRational fps;
len -= 0x39;
- avio_seek(pb, 5, SEEK_CUR); // preamble
- avio_seek(pb, 0x30, SEEK_CUR); // payload description
+ avio_skip(pb, 5); // preamble
+ avio_skip(pb, 0x30); // payload description
fps = fps_umf2avr(avio_rl32(pb));
if (!main_timebase.num || !main_timebase.den) {
// this may not always be correct, but simply the best we can get
av_log(s, AV_LOG_INFO, "UMF packet too short\n");
} else
av_log(s, AV_LOG_INFO, "UMF packet missing\n");
- avio_seek(pb, len, SEEK_CUR);
+ avio_skip(pb, len);
// set a fallback value, 60000/1001 is specified for audio-only files
// so use that regardless of why we do not know the video frame rate.
if (!main_timebase.num || !main_timebase.den)
continue;
}
if (pkt_type != PKT_MEDIA) {
- avio_seek(pb, pkt_len, SEEK_CUR);
+ avio_skip(pb, pkt_len);
continue;
}
if (pkt_len < 16) {
int last = field_info & 0xffff; // last is exclusive
int bps = av_get_bits_per_sample(st->codec->codec_id)>>3;
if (first <= last && last*bps <= pkt_len) {
- avio_seek(pb, first*bps, SEEK_CUR);
+ avio_skip(pb, first*bps);
skip = pkt_len - last*bps;
pkt_len = (last-first)*bps;
} else
}
ret = av_get_packet(pb, pkt, pkt_len);
if (skip)
- avio_seek(pb, skip, SEEK_CUR);
+ avio_skip(pb, skip);
pkt->stream_index = stream_index;
pkt->dts = field_nr;
return ret;
unsync = flags & 0x80;
if (isv34 && flags & 0x40) /* Extended header present, just skip over it */
- avio_seek(s->pb, get_size(s->pb, 4), SEEK_CUR);
+ avio_skip(s->pb, get_size(s->pb, 4));
while (len >= taghdrlen) {
unsigned int tflags;
if (tflags & (ID3v2_FLAG_ENCRYPTION | ID3v2_FLAG_COMPRESSION)) {
av_log(s, AV_LOG_WARNING, "Skipping encrypted/compressed ID3v2 frame %s.\n", tag);
- avio_seek(s->pb, tlen, SEEK_CUR);
+ avio_skip(s->pb, tlen);
} else if (tag[0] == 'T') {
if (unsync || tunsync) {
int i, j;
else if (!tag[0]) {
if (tag[1])
av_log(s, AV_LOG_WARNING, "invalid frame id, assuming padding");
- avio_seek(s->pb, tlen, SEEK_CUR);
+ avio_skip(s->pb, tlen);
break;
}
/* Skip to end of tag */
if (len > 0) {
/* Skip padding */
- avio_seek(s->pb, len, SEEK_CUR);
+ avio_skip(s->pb, len);
}
if (version == 4 && flags & 0x10) /* Footer preset, always 10 bytes, skip over it */
- avio_seek(s->pb, 10, SEEK_CUR);
+ avio_skip(s->pb, 10);
av_free(buffer);
return;
chunk_size = avio_rl32(pb);
/* skip the number of decoded bytes (always equal to width * height) */
- avio_seek(pb, 4, SEEK_CUR);
+ avio_skip(pb, 4);
chunk_size -= 4;
ret= av_get_packet(pb, pkt, chunk_size);
if (ret < 0)
break;
}
/* don't care about this chunk anymore */
- avio_seek(pb, RoQ_CHUNK_PREAMBLE_SIZE, SEEK_CUR);
+ avio_skip(pb, RoQ_CHUNK_PREAMBLE_SIZE);
break;
case RoQ_QUAD_CODEBOOK:
/* packet needs to contain both this codebook and next VQ chunk */
codebook_offset = avio_tell(pb) - RoQ_CHUNK_PREAMBLE_SIZE;
codebook_size = chunk_size;
- avio_seek(pb, codebook_size, SEEK_CUR);
+ avio_skip(pb, codebook_size);
if (avio_read(pb, preamble, RoQ_CHUNK_PREAMBLE_SIZE) !=
RoQ_CHUNK_PREAMBLE_SIZE)
return AVERROR(EIO);
return AVERROR(ENOMEM);
st->codec->channels = 1;
- avio_seek(pb, 8, SEEK_CUR);
+ avio_skip(pb, 8);
// codec_tag used by ByteRun1 decoder to distinguish progressive (PBM) and interlaced (ILBM) content
st->codec->codec_tag = avio_rl32(pb);
if (data_size < 14)
return AVERROR_INVALIDDATA;
- avio_seek(pb, 12, SEEK_CUR);
+ avio_skip(pb, 12);
st->codec->sample_rate = avio_rb16(pb);
if (data_size >= 16) {
- avio_seek(pb, 1, SEEK_CUR);
+ avio_skip(pb, 1);
compression = avio_r8(pb);
}
break;
return AVERROR_INVALIDDATA;
st->codec->width = avio_rb16(pb);
st->codec->height = avio_rb16(pb);
- avio_seek(pb, 4, SEEK_CUR); // x, y offset
+ avio_skip(pb, 4); // x, y offset
st->codec->bits_per_coded_sample = avio_r8(pb);
if (data_size >= 11) {
- avio_seek(pb, 1, SEEK_CUR); // masking
+ avio_skip(pb, 1); // masking
compression = avio_r8(pb);
}
if (data_size >= 16) {
- avio_seek(pb, 3, SEEK_CUR); // paddding, transparent
+ avio_skip(pb, 3); // paddding, transparent
st->sample_aspect_ratio.num = avio_r8(pb);
st->sample_aspect_ratio.den = avio_r8(pb);
}
return res;
}
}
- avio_seek(pb, data_size - (avio_tell(pb) - orig_pos) + (data_size & 1), SEEK_CUR);
+ avio_skip(pb, data_size - (avio_tell(pb) - orig_pos) + (data_size & 1));
}
avio_seek(pb, iff->body_pos, SEEK_SET);
w = avio_rl16(s->pb);
h = avio_rl16(s->pb);
- avio_seek(s->pb, 8, SEEK_CUR); // zero + size (padded?)
- avio_seek(s->pb, 2, SEEK_CUR);
+ avio_skip(s->pb, 8); // zero + size (padded?)
+ avio_skip(s->pb, 2);
unk1 = avio_rl16(s->pb);
unk2 = avio_rl16(s->pb);
- avio_seek(s->pb, 22, SEEK_CUR); // ASCII timestamp
+ avio_skip(s->pb, 22); // ASCII timestamp
av_log(s, AV_LOG_DEBUG, "Ingenient packet: size=%d, width=%d, height=%d, unk1=%d unk2=%d\n",
size, w, h, unk1, unk2);
case OPCODE_END_OF_STREAM:
debug_ipmovie("end of stream\n");
- avio_seek(pb, opcode_size, SEEK_CUR);
+ avio_skip(pb, opcode_size);
break;
case OPCODE_END_OF_CHUNK:
debug_ipmovie("end of chunk\n");
- avio_seek(pb, opcode_size, SEEK_CUR);
+ avio_skip(pb, opcode_size);
break;
case OPCODE_CREATE_TIMER:
case OPCODE_START_STOP_AUDIO:
debug_ipmovie("start/stop audio\n");
- avio_seek(pb, opcode_size, SEEK_CUR);
+ avio_skip(pb, opcode_size);
break;
case OPCODE_INIT_VIDEO_BUFFERS:
case OPCODE_UNKNOWN_14:
case OPCODE_UNKNOWN_15:
debug_ipmovie("unknown (but documented) opcode %02X\n", opcode_type);
- avio_seek(pb, opcode_size, SEEK_CUR);
+ avio_skip(pb, opcode_size);
break;
case OPCODE_SEND_BUFFER:
debug_ipmovie("send buffer\n");
- avio_seek(pb, opcode_size, SEEK_CUR);
+ avio_skip(pb, opcode_size);
break;
case OPCODE_AUDIO_FRAME:
/* log position and move on for now */
s->audio_chunk_offset = avio_tell(pb);
s->audio_chunk_size = opcode_size;
- avio_seek(pb, opcode_size, SEEK_CUR);
+ avio_skip(pb, opcode_size);
break;
case OPCODE_SILENCE_FRAME:
debug_ipmovie("silence frame\n");
- avio_seek(pb, opcode_size, SEEK_CUR);
+ avio_skip(pb, opcode_size);
break;
case OPCODE_INIT_VIDEO_MODE:
debug_ipmovie("initialize video mode\n");
- avio_seek(pb, opcode_size, SEEK_CUR);
+ avio_skip(pb, opcode_size);
break;
case OPCODE_CREATE_GRADIENT:
debug_ipmovie("create gradient\n");
- avio_seek(pb, opcode_size, SEEK_CUR);
+ avio_skip(pb, opcode_size);
break;
case OPCODE_SET_PALETTE:
case OPCODE_SET_PALETTE_COMPRESSED:
debug_ipmovie("set palette compressed\n");
- avio_seek(pb, opcode_size, SEEK_CUR);
+ avio_skip(pb, opcode_size);
break;
case OPCODE_SET_DECODING_MAP:
/* log position and move on for now */
s->decode_map_chunk_offset = avio_tell(pb);
s->decode_map_chunk_size = opcode_size;
- avio_seek(pb, opcode_size, SEEK_CUR);
+ avio_skip(pb, opcode_size);
break;
case OPCODE_VIDEO_DATA:
/* log position and move on for now */
s->video_chunk_offset = avio_tell(pb);
s->video_chunk_size = opcode_size;
- avio_seek(pb, opcode_size, SEEK_CUR);
+ avio_skip(pb, opcode_size);
break;
default:
return -1;
if(type==258){
- avio_seek(s->pb, size, SEEK_CUR);
+ avio_skip(s->pb, size);
goto retry;
}
if ((ret = av_get_packet(pb, pkt, frame_size)) <= 0)
return AVERROR(EIO);
- avio_seek(pb, padding, SEEK_CUR);
+ avio_skip(pb, padding);
switch (frame_type) {
case LMLM4_I_FRAME:
case 0:
//video
//skip VBI data and metadata
- avio_seek(pb, (int64_t)(uint32_t)AV_RL32(&header[44]) +
- (int64_t)(uint32_t)AV_RL32(&header[52]), SEEK_CUR);
+ avio_skip(pb, (int64_t)(uint32_t)AV_RL32(&header[44]) +
+ (int64_t)(uint32_t)AV_RL32(&header[52]));
break;
case 1:
//audio
if (format == 1) {
//skip extended field data
- avio_seek(s->pb, (uint32_t)AV_RL32(&header[40]), SEEK_CUR);
+ avio_skip(s->pb, (uint32_t)AV_RL32(&header[40]));
}
return 0;
return ebml_parse_nest(matroska, syntax->def.n, data);
case EBML_PASS: return ebml_parse_id(matroska, syntax->def.n, id, data);
case EBML_STOP: return 1;
- default: return avio_seek(pb,length,SEEK_CUR)<0 ? AVERROR(EIO) : 0;
+ default: return avio_skip(pb,length)<0 ? AVERROR(EIO) : 0;
}
if (res == AVERROR_INVALIDDATA)
av_log(matroska->ctx, AV_LOG_ERROR, "Invalid element\n");
int flavor;
ffio_init_context(&b, track->codec_priv.data,track->codec_priv.size,
0, NULL, NULL, NULL, NULL);
- avio_seek(&b, 22, SEEK_CUR);
+ avio_skip(&b, 22);
flavor = avio_rb16(&b);
track->audio.coded_framesize = avio_rb32(&b);
- avio_seek(&b, 12, SEEK_CUR);
+ avio_skip(&b, 12);
track->audio.sub_packet_h = avio_rb16(&b);
track->audio.frame_size = avio_rb16(&b);
track->audio.sub_packet_size = avio_rb16(&b);
avio_rl16(pb); /* ibm-pc video bios mode */
width = avio_rl16(pb);
height = avio_rl16(pb);
- avio_seek(pb, length - 10, SEEK_CUR); /* unknown data */
+ avio_skip(pb, length - 10); /* unknown data */
/* video stream */
st = av_new_stream(s, 0);
default :
av_log(s, AV_LOG_INFO, "unknown chunk type 0x%x\n", type);
- avio_seek(pb, length, SEEK_CUR);
+ avio_skip(pb, length);
}
}
file_size = avio_rb32(pb);
/* Skip some unused chunks that may or may not be present */
- for(;; avio_seek(pb, size, SEEK_CUR)) {
+ for(;; avio_skip(pb, size)) {
tag = avio_rl32(pb);
size = avio_rb32(pb);
if(tag == MKTAG('C','N','T','I')) continue;
avio_r8(pb); /* time base g */
/* Skip some unused chunks that may or may not be present */
- for(;; avio_seek(pb, size, SEEK_CUR)) {
+ for(;; avio_skip(pb, size)) {
tag = avio_rl32(pb);
size = avio_rb32(pb);
if(tag == MKTAG('A','t','s','q')) continue;
parse = mov_read_udta_string;
if (!parse) { /* skip leaf atoms data */
- avio_seek(pb, a.size, SEEK_CUR);
+ avio_skip(pb, a.size);
} else {
int64_t start_pos = avio_tell(pb);
int64_t left;
return 0;
left = a.size - avio_tell(pb) + start_pos;
if (left > 0) /* skip garbage at atom end */
- avio_seek(pb, left, SEEK_CUR);
+ avio_skip(pb, left);
}
total_size += a.size;
}
if (total_size < atom.size && atom.size < 0x7ffff)
- avio_seek(pb, atom.size - total_size, SEEK_CUR);
+ avio_skip(pb, atom.size - total_size);
return 0;
}
uint16_t volume_len, len;
int16_t type;
- avio_seek(pb, 10, SEEK_CUR);
+ avio_skip(pb, 10);
volume_len = avio_r8(pb);
volume_len = FFMIN(volume_len, 27);
dref->volume[volume_len] = 0;
av_log(c->fc, AV_LOG_DEBUG, "volume %s, len %d\n", dref->volume, volume_len);
- avio_seek(pb, 12, SEEK_CUR);
+ avio_skip(pb, 12);
len = avio_r8(pb);
len = FFMIN(len, 63);
dref->filename[len] = 0;
av_log(c->fc, AV_LOG_DEBUG, "filename %s, len %d\n", dref->filename, len);
- avio_seek(pb, 16, SEEK_CUR);
+ avio_skip(pb, 16);
/* read next level up_from_alias/down_to_target */
dref->nlvl_from = avio_rb16(pb);
av_log(c->fc, AV_LOG_DEBUG, "nlvl from %d, nlvl to %d\n",
dref->nlvl_from, dref->nlvl_to);
- avio_seek(pb, 16, SEEK_CUR);
+ avio_skip(pb, 16);
for (type = 0; type != -1 && avio_tell(pb) < next; ) {
type = avio_rb16(pb);
dref->dir[j] = '/';
av_log(c->fc, AV_LOG_DEBUG, "dir %s\n", dref->dir);
} else
- avio_seek(pb, len, SEEK_CUR);
+ avio_skip(pb, len);
}
}
avio_seek(pb, next, SEEK_SET);
avio_rb16(pb); /* preferred volume */
- avio_seek(pb, 10, SEEK_CUR); /* reserved */
+ avio_skip(pb, 10); /* reserved */
- avio_seek(pb, 36, SEEK_CUR); /* display matrix */
+ avio_skip(pb, 36); /* display matrix */
avio_rb32(pb); /* preview time */
avio_rb32(pb); /* preview duration */
if (mov_read_default(c, pb, atom) < 0)
return -1;
} else
- avio_seek(pb, atom.size, SEEK_CUR);
+ avio_skip(pb, atom.size);
return 0;
}
if (!st->codec->extradata)
return AVERROR(ENOMEM);
st->codec->extradata_size = atom.size - 40;
- avio_seek(pb, 40, SEEK_CUR);
+ avio_skip(pb, 40);
avio_read(pb, st->codec->extradata, atom.size - 40);
return 0;
}
* in the MOV demuxer, patch welcome. */
multiple_stsd:
av_log(c->fc, AV_LOG_WARNING, "multiple fourcc not supported\n");
- avio_seek(pb, size - (avio_tell(pb) - start_pos), SEEK_CUR);
+ avio_skip(pb, size - (avio_tell(pb) - start_pos));
continue;
}
/* we cannot demux concatenated h264 streams because of different extradata */
len = 31;
mov_read_mac_string(c, pb, len, st->codec->codec_name, 32);
if (len < 31)
- avio_seek(pb, 31 - len, SEEK_CUR);
+ avio_skip(pb, 31 - len);
/* codec_tag YV12 triggers an UV swap in rawdec.c */
if (!memcmp(st->codec->codec_name, "Planar Y'CbCr 8-bit 4:2:0", 25))
st->codec->codec_tag=MKTAG('I', '4', '2', '0');
st->codec->height = sc->height;
} else {
/* other codec type, just skip (rtp, mp4s, tmcd ...) */
- avio_seek(pb, size - (avio_tell(pb) - start_pos), SEEK_CUR);
+ avio_skip(pb, size - (avio_tell(pb) - start_pos));
}
/* this will read extra atoms at the end (wave, alac, damr, avcC, SMI ...) */
a.size = size - (avio_tell(pb) - start_pos);
if (mov_read_default(c, pb, a) < 0)
return -1;
} else if (a.size > 0)
- avio_seek(pb, a.size, SEEK_CUR);
+ avio_skip(pb, a.size);
}
if(st->codec->codec_type==AVMEDIA_TYPE_AUDIO && st->codec->sample_rate==0 && sc->time_scale>1)
if (atom.size < 8)
return 0; /* continue */
if (avio_rb32(pb) != 0) { /* 0 sized mdat atom... use the 'wide' atom size */
- avio_seek(pb, atom.size - 4, SEEK_CUR);
+ avio_skip(pb, atom.size - 4);
return 0;
}
atom.type = avio_rl32(pb);
atom.size -= 8;
if (atom.type != MKTAG('m','d','a','t')) {
- avio_seek(pb, atom.size, SEEK_CUR);
+ avio_skip(pb, atom.size);
return 0;
}
err = mov_read_mdat(c, pb, atom);
/* Check tag version */
if(avio_rb16(s->pb) == 1) {
/* skip delay and quality */
- avio_seek(s->pb, 4, SEEK_CUR);
+ avio_skip(s->pb, 4);
frames = avio_rb32(s->pb);
size = avio_rb32(s->pb);
}
avio_seek(pb, pos, SEEK_SET);
break;
default:
- avio_seek(pb, size, SEEK_CUR);
+ avio_skip(pb, size);
}
}
return -1;
}
pos = avio_tell(pb);
- avio_seek(pb, 4, SEEK_CUR); //CRC
+ avio_skip(pb, 4); //CRC
c->ver = avio_r8(pb);
if(c->ver != 8){
av_log(s, AV_LOG_ERROR, "Unknown stream version %d\n", c->ver);
ps_info_length = avio_rb16(pb);
/* skip program_stream_info */
- avio_seek(pb, ps_info_length, SEEK_CUR);
+ avio_skip(pb, ps_info_length);
es_map_length = avio_rb16(pb);
/* at least one es available? */
/* remember mapping from stream id to stream type */
m->psm_es_type[es_id] = type;
/* skip program_stream_info */
- avio_seek(pb, es_info_length, SEEK_CUR);
+ avio_skip(pb, es_info_length);
es_map_length -= 4 + es_info_length;
}
avio_rb32(pb); /* crc32 */
if (startcode == SYSTEM_HEADER_START_CODE)
goto redo;
if (startcode == PADDING_STREAM) {
- avio_seek(s->pb, avio_rb16(s->pb), SEEK_CUR);
+ avio_skip(s->pb, avio_rb16(s->pb));
goto redo;
}
if (startcode == PRIVATE_STREAM_2) {
}
m->sofdec -= !m->sofdec;
}
- avio_seek(s->pb, len, SEEK_CUR);
+ avio_skip(s->pb, len);
goto redo;
}
if (startcode == PROGRAM_STREAM_MAP) {
av_log(s, AV_LOG_WARNING, "pes_ext %X is invalid\n", pes_ext);
pes_ext=skip=0;
}
- avio_seek(s->pb, skip, SEEK_CUR);
+ avio_skip(s->pb, skip);
header_len -= skip;
if (pes_ext & 0x01) { /* PES extension 2 */
}
if(header_len < 0)
goto error_redo;
- avio_seek(s->pb, header_len, SEEK_CUR);
+ avio_skip(s->pb, header_len);
}
else if( c!= 0xf )
goto redo;
if(startcode == 0x1bd) {
dvdaudio_substream_type = avio_r8(s->pb);
- avio_seek(s->pb, 3, SEEK_CUR);
+ avio_skip(s->pb, 3);
len -= 4;
}
} else {
skip:
/* skip packet */
- avio_seek(s->pb, len, SEEK_CUR);
+ avio_skip(s->pb, len);
goto redo;
}
/* no stream found: add a new stream */
dts != AV_NOPTS_VALUE) {
break;
}
- avio_seek(s->pb, len, SEEK_CUR);
+ avio_skip(s->pb, len);
}
#ifdef DEBUG_SEEK
printf("pos=0x%"PRIx64" dts=0x%"PRIx64" %0.3f\n", pos, dts, dts / 90000.0);
} else {
skip = raw_packet_size - TS_PACKET_SIZE;
if (skip > 0)
- avio_seek(pb, skip, SEEK_CUR);
+ avio_skip(pb, skip);
break;
}
}
uint16_t keyframe;
uint32_t size, timestamp;
- avio_seek(pb, 1, SEEK_CUR); /* one byte has been read ahead */
- avio_seek(pb, 2, SEEK_CUR);
- avio_seek(pb, 2, SEEK_CUR);
+ avio_skip(pb, 1); /* one byte has been read ahead */
+ avio_skip(pb, 2);
+ avio_skip(pb, 2);
keyframe = avio_rl16(pb);
size = avio_rl32(pb);
- avio_seek(pb, 4, SEEK_CUR);
- avio_seek(pb, 4, SEEK_CUR);
+ avio_skip(pb, 4);
+ avio_skip(pb, 4);
timestamp = avio_rl32(pb);
if(!size || av_get_packet(pb, pkt, size) != size)
return -1;
- avio_seek(pb, 1, SEEK_CUR); /* Read ahead one byte of struct size like read_header */
+ avio_skip(pb, 1); /* Read ahead one byte of struct size like read_header */
pkt->pts = timestamp;
pkt->dts = timestamp;
AVStream *st;
unsigned int audio_subsegments;
- avio_seek(pb, 3, SEEK_CUR);
+ avio_skip(pb, 3);
mtv->file_size = avio_rl32(pb);
mtv->segments = avio_rl32(pb);
- avio_seek(pb, 32, SEEK_CUR);
+ avio_skip(pb, 32);
mtv->audio_identifier = avio_rl24(pb);
mtv->audio_br = avio_rl16(pb);
mtv->img_colorfmt = avio_rl24(pb);
mtv->img_height=mtv->img_segment_size / (mtv->img_bpp>>3)
/ mtv->img_width;
- avio_seek(pb, 4, SEEK_CUR);
+ avio_skip(pb, 4);
audio_subsegments = avio_rl16(pb);
mtv->full_segment_size =
audio_subsegments * (MTV_AUDIO_PADDING_SIZE + MTV_ASUBCHUNK_DATA_SIZE) +
if((avio_tell(pb) - s->data_offset + mtv->img_segment_size) % mtv->full_segment_size)
{
- avio_seek(pb, MTV_AUDIO_PADDING_SIZE, SEEK_CUR);
+ avio_skip(pb, MTV_AUDIO_PADDING_SIZE);
ret = av_get_packet(pb, pkt, MTV_ASUBCHUNK_DATA_SIZE);
if(ret < 0)
av_aes_init(mxf->aesc, s->key, 128, 1);
}
// crypto context
- avio_seek(pb, klv_decode_ber_length(pb), SEEK_CUR);
+ avio_skip(pb, klv_decode_ber_length(pb));
// plaintext offset
klv_decode_ber_length(pb);
plaintext_size = avio_rb64(pb);
&pkt->data[plaintext_size], size >> 4, ivec, 1);
pkt->size = orig_size;
pkt->stream_index = index;
- avio_seek(pb, end - avio_tell(pb), SEEK_CUR);
+ avio_skip(pb, end - avio_tell(pb));
return 0;
}
return 0;
} else
skip:
- avio_seek(s->pb, klv.length, SEEK_CUR);
+ avio_skip(s->pb, klv.length);
}
return AVERROR_EOF;
}
mxf->packages_refs = av_malloc(mxf->packages_count * sizeof(UID));
if (!mxf->packages_refs)
return -1;
- avio_seek(pb, 4, SEEK_CUR); /* useless size of objects, always 16 according to specs */
+ avio_skip(pb, 4); /* useless size of objects, always 16 according to specs */
avio_read(pb, (uint8_t *)mxf->packages_refs, mxf->packages_count * sizeof(UID));
break;
}
break;
case 0x1101:
/* UMID, only get last 16 bytes */
- avio_seek(pb, 16, SEEK_CUR);
+ avio_skip(pb, 16);
avio_read(pb, source_clip->source_package_uid, 16);
break;
case 0x1102:
package->tracks_refs = av_malloc(package->tracks_count * sizeof(UID));
if (!package->tracks_refs)
return -1;
- avio_seek(pb, 4, SEEK_CUR); /* useless size of objects, always 16 according to specs */
+ avio_skip(pb, 4); /* useless size of objects, always 16 according to specs */
avio_read(pb, (uint8_t *)package->tracks_refs, package->tracks_count * sizeof(UID));
break;
}
sequence->structural_components_refs = av_malloc(sequence->structural_components_count * sizeof(UID));
if (!sequence->structural_components_refs)
return -1;
- avio_seek(pb, 4, SEEK_CUR); /* useless size of objects, always 16 according to specs */
+ avio_skip(pb, 4); /* useless size of objects, always 16 according to specs */
avio_read(pb, (uint8_t *)sequence->structural_components_refs, sequence->structural_components_count * sizeof(UID));
break;
}
package->tracks_refs = av_malloc(package->tracks_count * sizeof(UID));
if (!package->tracks_refs)
return -1;
- avio_seek(pb, 4, SEEK_CUR); /* useless size of objects, always 16 according to specs */
+ avio_skip(pb, 4); /* useless size of objects, always 16 according to specs */
avio_read(pb, (uint8_t *)package->tracks_refs, package->tracks_count * sizeof(UID));
break;
case 0x4401:
/* UMID, only get last 16 bytes */
- avio_seek(pb, 16, SEEK_CUR);
+ avio_skip(pb, 16);
avio_read(pb, package->package_uid, 16);
break;
case 0x4701:
descriptor->sub_descriptors_refs = av_malloc(descriptor->sub_descriptors_count * sizeof(UID));
if (!descriptor->sub_descriptors_refs)
return -1;
- avio_seek(pb, 4, SEEK_CUR); /* useless size of objects, always 16 according to specs */
+ avio_skip(pb, 4); /* useless size of objects, always 16 according to specs */
avio_read(pb, (uint8_t *)descriptor->sub_descriptors_refs, descriptor->sub_descriptors_count * sizeof(UID));
break;
case 0x3004:
}
}
if (!metadata->read)
- avio_seek(s->pb, klv.length, SEEK_CUR);
+ avio_skip(s->pb, klv.length);
}
return mxf_parse_structural_metadata(mxf);
}
avio_r8(s->pb);
size = avio_rl16(s->pb);
- avio_seek(s->pb, 9, SEEK_CUR);
+ avio_skip(s->pb, 9);
if (size == 0) {
av_log(s, AV_LOG_DEBUG, "Next packet size is zero\n");
((auxtag >> 16) & 0x0ff),
((auxtag >> 24) & 0x0ff),
auxsize);
- avio_seek(pb, auxsize, SEEK_CUR);
+ avio_skip(pb, auxsize);
vsize -= auxsize + sizeof(uint16_t) + sizeof(uint32_t); /* that's becoming braindead */
}
||(discard >= AVDISCARD_BIDIR && last_IP_pts != AV_NOPTS_VALUE && last_IP_pts > pts)
|| discard >= AVDISCARD_ALL
|| stc->skip_until_key_frame){
- avio_seek(bc, size, SEEK_CUR);
+ avio_skip(bc, size);
return 1;
}
case STREAM_STARTCODE:
case INDEX_STARTCODE:
skip= get_packetheader(nut, bc, 0, tmp);
- avio_seek(bc, skip, SEEK_CUR);
+ avio_skip(bc, skip);
break;
case INFO_STARTCODE:
if(decode_info_header(nut)<0)
switch (frametype) {
case NUV_EXTRADATA:
subtype = avio_r8(pb);
- avio_seek(pb, 6, SEEK_CUR);
+ avio_skip(pb, 6);
size = PKTSIZE(avio_rl32(pb));
if (vst && subtype == 'R') {
vst->codec->extradata_size = size;
}
break;
case NUV_MYTHEXT:
- avio_seek(pb, 7, SEEK_CUR);
+ avio_skip(pb, 7);
size = PKTSIZE(avio_rl32(pb));
if (size != 128 * 4)
break;
if (vst->codec->codec_tag == MKTAG('R', 'J', 'P', 'G'))
vst->codec->codec_id = CODEC_ID_NUV;
} else
- avio_seek(pb, 4, SEEK_CUR);
+ avio_skip(pb, 4);
if (ast) {
ast->codec->codec_tag = avio_rl32(pb);
ast->codec->bits_per_coded_sample);
ast->need_parsing = AVSTREAM_PARSE_FULL;
} else
- avio_seek(pb, 4 * 4, SEEK_CUR);
+ avio_skip(pb, 4 * 4);
size -= 6 * 4;
- avio_seek(pb, size, SEEK_CUR);
+ avio_skip(pb, size);
return 1;
case NUV_SEEKP:
size = 11;
break;
default:
- avio_seek(pb, 7, SEEK_CUR);
+ avio_skip(pb, 7);
size = PKTSIZE(avio_rl32(pb));
break;
}
- avio_seek(pb, size, SEEK_CUR);
+ avio_skip(pb, size);
}
return 0;
}
AVStream *vst = NULL, *ast = NULL;
avio_read(pb, id_string, 12);
is_mythtv = !memcmp(id_string, "MythTVVideo", 12);
- avio_seek(pb, 5, SEEK_CUR); // version string
- avio_seek(pb, 3, SEEK_CUR); // padding
+ avio_skip(pb, 5); // version string
+ avio_skip(pb, 3); // padding
width = avio_rl32(pb);
height = avio_rl32(pb);
avio_rl32(pb); // unused, "desiredwidth"
avio_rl32(pb); // unused, "desiredheight"
avio_r8(pb); // 'P' == progressive, 'I' == interlaced
- avio_seek(pb, 3, SEEK_CUR); // padding
+ avio_skip(pb, 3); // padding
aspect = av_int2dbl(avio_rl64(pb));
if (aspect > 0.9999 && aspect < 1.0001)
aspect = 4.0 / 3.0;
switch (frametype) {
case NUV_EXTRADATA:
if (!ctx->rtjpg_video) {
- avio_seek(pb, size, SEEK_CUR);
+ avio_skip(pb, size);
break;
}
case NUV_VIDEO:
if (ctx->v_id < 0) {
av_log(s, AV_LOG_ERROR, "Video packet in file without video stream!\n");
- avio_seek(pb, size, SEEK_CUR);
+ avio_skip(pb, size);
break;
}
ret = av_new_packet(pkt, copyhdrsize + size);
case NUV_AUDIO:
if (ctx->a_id < 0) {
av_log(s, AV_LOG_ERROR, "Audio packet in file without audio stream!\n");
- avio_seek(pb, size, SEEK_CUR);
+ avio_skip(pb, size);
break;
}
ret = av_get_packet(pb, pkt, size);
// contains no data, size value is invalid
break;
default:
- avio_seek(pb, size, SEEK_CUR);
+ avio_skip(pb, size);
break;
}
}
if (pes_signal != 1) {
pva_log(s, AV_LOG_WARNING, "expected signaled PES packet, "
"trying to recover\n");
- avio_seek(pb, length - 9, SEEK_CUR);
+ avio_skip(pb, length - 9);
if (!read_packet)
return AVERROR(EIO);
goto recover;
avio_rb32(pb); // "RIFF"
s->file_size = avio_rl32(pb) + 8;
- avio_seek(pb, 8 + 4 + 1 + 1, SEEK_CUR); // "QLCMfmt " + chunk-size + major-version + minor-version
+ avio_skip(pb, 8 + 4 + 1 + 1); // "QLCMfmt " + chunk-size + major-version + minor-version
st->codec->codec_type = AVMEDIA_TYPE_AUDIO;
st->codec->channels = 1;
av_log(s, AV_LOG_ERROR, "Unknown codec GUID.\n");
return AVERROR_INVALIDDATA;
}
- avio_seek(pb, 2 + 80, SEEK_CUR); // codec-version + codec-name
+ avio_skip(pb, 2 + 80); // codec-version + codec-name
st->codec->bit_rate = avio_rl16(pb);
s->packet_size = avio_rl16(pb);
- avio_seek(pb, 2, SEEK_CUR); // block-size
+ avio_skip(pb, 2); // block-size
st->codec->sample_rate = avio_rl16(pb);
- avio_seek(pb, 2, SEEK_CUR); // sample-size
+ avio_skip(pb, 2); // sample-size
memset(c->rates_per_mode, -1, sizeof(c->rates_per_mode));
nb_rates = avio_rl32(pb);
} else
c->rates_per_mode[mode] = size;
}
- avio_seek(pb, 16 - 2*nb_rates + 20, SEEK_CUR); // empty entries of rate-map-table + reserved
+ avio_skip(pb, 16 - 2*nb_rates + 20); // empty entries of rate-map-table + reserved
return 0;
}
case MKTAG('v', 'r', 'a', 't'):
if (avio_rl32(pb)) // var-rate-flag
s->packet_size = 0;
- avio_seek(pb, 4, SEEK_CUR); // size-in-packets
+ avio_skip(pb, 4); // size-in-packets
break;
case MKTAG('d', 'a', 't', 'a'):
c->data_size = chunk_size;
break;
default:
- avio_seek(pb, chunk_size, SEEK_CUR);
+ avio_skip(pb, chunk_size);
}
}
return AVERROR_EOF;
tmp = avio_rb32(s->pb); // filenum
av_dlog(s, "filenum %d\n", tmp);
- avio_seek(s->pb, 32, SEEK_CUR); // unknown
+ avio_skip(s->pb, 32); // unknown
st->codec->width = avio_rb32(s->pb);
st->codec->height = avio_rb32(s->pb);
tmp = avio_rb32(s->pb);
av_dlog(s, "num audio chunks %d\n", tmp);
- avio_seek(s->pb, 6*4, SEEK_CUR);
+ avio_skip(s->pb, 6*4);
}
static int r3d_read_header(AVFormatContext *s, AVFormatParameters *ap)
break;
default:
skip:
- avio_seek(s->pb, atom.size-8, SEEK_CUR);
+ avio_skip(s->pb, atom.size-8);
}
}
return err;
num = avio_rb16(&pb);
if (rule_nr < 0 || rule_nr >= num)
return -1;
- avio_seek(&pb, rule_nr * 2, SEEK_CUR);
+ avio_skip(&pb, rule_nr * 2);
chunk_nr = avio_rb16(&pb);
- avio_seek(&pb, (num - 1 - rule_nr) * 2, SEEK_CUR);
+ avio_skip(&pb, (num - 1 - rule_nr) * 2);
/* read MDPR chunks */
num = avio_rb16(&pb);
if (chunk_nr >= num)
return -1;
while (chunk_nr--)
- avio_seek(&pb, avio_rb32(&pb), SEEK_CUR);
+ avio_skip(&pb, avio_rb32(&pb));
size = avio_rb32(&pb);
} else {
size = rdt->mlti_data_size;
codec->bits_per_coded_sample = avio_rl16(pb);
codec->channel_layout = avio_rl32(pb); /* dwChannelMask */
id = avio_rl32(pb); /* 4 first bytes of GUID */
- avio_seek(pb, 12, SEEK_CUR); /* skip end of GUID */
+ avio_skip(pb, 12); /* skip end of GUID */
cbSize -= 22;
size -= 22;
}
/* It is possible for the chunk to contain garbage at the end */
if (size > 0)
- avio_seek(pb, size, SEEK_CUR);
+ avio_skip(pb, size);
}
codec->codec_id = ff_wav_codec_get_id(id, codec->bits_per_coded_sample);
if (codec->codec_id == CODEC_ID_AAC_LATM) {
int i;
int ret = 0;
- avio_seek(pb,4, SEEK_CUR); /* skip FORM tag */
+ avio_skip(pb,4); /* skip FORM tag */
back_size = avio_rl32(pb); /**< get size of the background frame */
signature = avio_rb32(pb);
data_size = avio_rb32(pb);
if (version == 3) {
int header_size = avio_rb16(pb);
int64_t startpos = avio_tell(pb);
- avio_seek(pb, 14, SEEK_CUR);
+ avio_skip(pb, 14);
rm_read_metadata(s, 0);
if ((startpos + header_size) >= avio_tell(pb) + 2) {
// fourcc (should always be "lpcJ")
}
// Skip extra header crap (this should never happen)
if ((startpos + header_size) > avio_tell(pb))
- avio_seek(pb, header_size + startpos - avio_tell(pb), SEEK_CUR);
+ avio_skip(pb, header_size + startpos - avio_tell(pb));
st->codec->sample_rate = 8000;
st->codec->channels = 1;
st->codec->codec_type = AVMEDIA_TYPE_AUDIO;
int flavor, sub_packet_h, coded_framesize, sub_packet_size;
int codecdata_length;
/* old version (4) */
- avio_seek(pb, 2, SEEK_CUR); /* unused */
+ avio_skip(pb, 2); /* unused */
avio_rb32(pb); /* .ra4 */
avio_rb32(pb); /* data size */
avio_rb16(pb); /* version2 */
skip:
/* skip codec info */
size = avio_tell(pb) - codec_pos;
- avio_seek(pb, codec_data_size - size, SEEK_CUR);
+ avio_skip(pb, codec_data_size - size);
return 0;
}
size = avio_rb32(pb);
if (size < 20)
return -1;
- avio_seek(pb, 2, SEEK_CUR);
+ avio_skip(pb, 2);
n_pkts = avio_rb32(pb);
str_id = avio_rb16(pb);
next_off = avio_rb32(pb);
goto skip;
for (n = 0; n < n_pkts; n++) {
- avio_seek(pb, 2, SEEK_CUR);
+ avio_skip(pb, 2);
pts = avio_rb32(pb);
pos = avio_rb32(pb);
- avio_seek(pb, 4, SEEK_CUR); /* packet no. */
+ avio_skip(pb, 4); /* packet no. */
av_add_index_entry(st, pos, pts, 0, 0, AVINDEX_KEYFRAME);
}
goto header_end;
default:
/* unknown tag: skip it */
- avio_seek(pb, tag_size - 10, SEEK_CUR);
+ avio_skip(pb, tag_size - 10);
break;
}
}
if(state == MKBETAG('I', 'N', 'D', 'X')){
int n_pkts, expected_len;
len = avio_rb32(pb);
- avio_seek(pb, 2, SEEK_CUR);
+ avio_skip(pb, 2);
n_pkts = avio_rb32(pb);
expected_len = 20 + n_pkts * 14;
if (len == 20)
if (i == s->nb_streams) {
skip:
/* skip packet if unknown number */
- avio_seek(pb, len, SEEK_CUR);
+ avio_skip(pb, len);
rm->remaining_len = 0;
continue;
}
break;
}
- avio_seek(s->pb, len, SEEK_CUR);
+ avio_skip(s->pb, len);
}
*ppos = pos;
return dts;
flags |= RTP_FLAG_KEY;
len_off = avio_rb24(pb);
if (mflags & 0x20) /**< relative timestamp */
- avio_seek(pb, 4, SEEK_CUR);
+ avio_skip(pb, 4);
if (mflags & 0x10) /**< has duration */
- avio_seek(pb, 4, SEEK_CUR);
+ avio_skip(pb, 4);
if (mflags & 0x8) /**< has location ID */
- avio_seek(pb, 4, SEEK_CUR);
+ avio_skip(pb, 4);
off = avio_tell(pb);
if (!(mflags & 0x40)) {
return AVERROR(EIO);
avio_write(asf->pktbuf, buf + off, len - off);
- avio_seek(pb, len - off, SEEK_CUR);
+ avio_skip(pb, len - off);
if (!(flags & RTP_FLAG_MARKER))
return -1;
out_len = url_close_dyn_buf(asf->pktbuf, &asf->buf);
asf->buf = av_realloc(asf->buf, out_len);
memcpy(asf->buf + prev_len, buf + off,
FFMIN(cur_len, len - off));
- avio_seek(pb, cur_len, SEEK_CUR);
+ avio_skip(pb, cur_len);
}
}
break;
}
default:
- avio_seek(&pb, tlv_len, SEEK_CUR);
+ avio_skip(&pb, tlv_len);
break;
}
}
/* 32-bit alignment */
- avio_seek(&pb, ((avio_tell(&pb) + 3) & ~3) - avio_tell(&pb), SEEK_CUR);
+ avio_skip(&pb, ((avio_tell(&pb) + 3) & ~3) - avio_tell(&pb));
} else
avio_seek(&pb, 4, SEEK_SET);
GET_SAUCE_META("artist", 20)
GET_SAUCE_META("publisher", 20)
GET_SAUCE_META("date", 8)
- avio_seek(pb, 4, SEEK_CUR);
+ avio_skip(pb, 4);
datatype = avio_r8(pb);
filetype = avio_r8(pb);
t1 = avio_rl16(pb);
t2 = avio_rl16(pb);
nb_comments = avio_r8(pb);
flags = avio_r8(pb);
- avio_seek(pb, 4, SEEK_CUR);
+ avio_skip(pb, 4);
GET_SAUCE_META("encoder", 22);
if (got_width && datatype && filetype) {
}
width = avio_rl16(pb);
height = avio_rl16(pb);
- avio_seek(pb, 4, SEEK_CUR);
+ avio_skip(pb, 4);
c->frames = avio_rl16(pb);
if(!c->frames){
av_log(s, AV_LOG_ERROR, "File contains no frames ???\n");
c->rate = avio_rl16(pb);
c->block_align = c->rate * (c->bits >> 3);
- avio_seek(pb, 16, SEEK_CUR); //zeroes
+ avio_skip(pb, 16); //zeroes
st = av_new_stream(s, 0);
if (!st)
av_log(s, AV_LOG_ERROR, "Header chunk size is incorrect\n");
return -1;
}
- avio_seek(pb, 4, SEEK_CUR); //unknown value
+ avio_skip(pb, 4); //unknown value
c->rate = avio_rl16(pb);
c->bits = avio_rl16(pb);
c->block_align = c->rate * (c->bits >> 3);
if (avio_rl32(pb) != TAG_SIFF)
return -1;
- avio_seek(pb, 4, SEEK_CUR); //ignore size
+ avio_skip(pb, 4); //ignore size
tag = avio_rl32(pb);
if (tag != TAG_VBV1 && tag != TAG_SOUN){
av_log(s, AV_LOG_ERROR, "'BODY' chunk is missing\n");
return -1;
}
- avio_seek(pb, 4, SEEK_CUR); //ignore size
+ avio_skip(pb, 4); //ignore size
return 0;
}
if (avio_rl32(pb) == SOX_TAG) {
st->codec->codec_id = CODEC_ID_PCM_S32LE;
header_size = avio_rl32(pb);
- avio_seek(pb, 8, SEEK_CUR); /* sample count */
+ avio_skip(pb, 8); /* sample count */
sample_rate = av_int2dbl(avio_rl64(pb));
st->codec->channels = avio_rl32(pb);
comment_size = avio_rl32(pb);
} else {
st->codec->codec_id = CODEC_ID_PCM_S32BE;
header_size = avio_rb32(pb);
- avio_seek(pb, 8, SEEK_CUR); /* sample count */
+ avio_skip(pb, 8); /* sample count */
sample_rate = av_int2dbl(avio_rb64(pb));
st->codec->channels = avio_rb32(pb);
comment_size = avio_rb32(pb);
AV_METADATA_DONT_STRDUP_VAL);
}
- avio_seek(pb, header_size - SOX_FIXED_HDR - comment_size, SEEK_CUR);
+ avio_skip(pb, header_size - SOX_FIXED_HDR - comment_size);
st->codec->sample_rate = sample_rate;
st->codec->bits_per_coded_sample = 32;
}
/* skip over the padding to the beginning of the next frame */
- avio_seek(pb, offset - pkt->size - BURST_HEADER_SIZE, SEEK_CUR);
+ avio_skip(pb, offset - pkt->size - BURST_HEADER_SIZE);
if (!s->nb_streams) {
/* first packet, create a stream */
/* skip rectangle size */
nbits = avio_r8(pb) >> 3;
len = (4 * nbits - 3 + 7) / 8;
- avio_seek(pb, len, SEEK_CUR);
+ avio_skip(pb, len);
swf->frame_rate = avio_rl16(pb); /* 8.8 fixed */
avio_rl16(pb); /* frame count */
st = s->streams[i];
if (st->codec->codec_type == AVMEDIA_TYPE_AUDIO && st->id == -1) {
if (st->codec->codec_id == CODEC_ID_MP3) {
- avio_seek(pb, 4, SEEK_CUR);
+ avio_skip(pb, 4);
av_get_packet(pb, pkt, len-4);
} else { // ADPCM, PCM
av_get_packet(pb, pkt, len);
return pkt->size;
}
skip:
- avio_seek(pb, len, SEEK_CUR);
+ avio_skip(pb, len);
}
return 0;
}
ret = av_get_packet(pb, pkt, pkt_size);
if (tmv->stream_index)
- avio_seek(pb, tmv->padding, SEEK_CUR);
+ avio_skip(pb, tmv->padding);
pkt->stream_index = tmv->stream_index;
tmv->stream_index ^= 1;
if (avio_rl32(s->pb) != AV_RL32("TTA1"))
return -1; // not tta file
- avio_seek(s->pb, 2, SEEK_CUR); // FIXME: flags
+ avio_skip(s->pb, 2); // FIXME: flags
channels = avio_rl16(s->pb);
bps = avio_rl16(s->pb);
samplerate = avio_rl32(s->pb);
return -1;
}
- avio_seek(s->pb, 4, SEEK_CUR); // header crc
+ avio_skip(s->pb, 4); // header crc
framelen = samplerate*256/245;
c->totalframes = datalen / framelen + ((datalen % framelen) ? 1 : 0);
av_add_index_entry(st, framepos, i*framelen, size, 0, AVINDEX_KEYFRAME);
framepos += size;
}
- avio_seek(s->pb, 4, SEEK_CUR); // seektable crc
+ avio_skip(s->pb, 4); // seektable crc
st->codec->codec_type = AVMEDIA_TYPE_AUDIO;
st->codec->codec_id = CODEC_ID_TTA;
if (chunk_size > 100)
break;
case TXD_EXTRA:
- avio_seek(s->pb, chunk_size, SEEK_CUR);
+ avio_skip(s->pb, chunk_size);
case TXD_FILE:
case TXD_TEXTURE:
goto next_chunk;
st->codec->width = avio_rl32(pb);
if(avio_rl32(pb) != 0xC)
return -1;
- avio_seek(pb, 8, SEEK_CUR);
+ avio_skip(pb, 8);
fps = avio_rl32(pb);
if(fps == 0xFFFFFFFF)
av_set_pts_info(st, 32, 1, 1000);
int header_size;
AVStream *st;
- avio_seek(pb, 20, SEEK_CUR);
+ avio_skip(pb, 20);
header_size = avio_rl16(pb) - 22;
if (header_size != 4) {
av_log(s, AV_LOG_ERROR, "unknown header size: %d\n", header_size);
return AVERROR(ENOSYS);
}
- avio_seek(pb, header_size, SEEK_CUR);
+ avio_skip(pb, header_size);
st = av_new_stream(s, 0);
if (!st)
return AVERROR(ENOMEM);
dec->bits_per_coded_sample = avio_r8(pb);
dec->channels = avio_r8(pb);
tmp_codec = avio_rl16(pb);
- avio_seek(pb, 4, SEEK_CUR);
+ avio_skip(pb, 4);
voc->remaining_size -= 12;
max_size -= 12;
break;
default:
- avio_seek(pb, voc->remaining_size, SEEK_CUR);
+ avio_skip(pb, voc->remaining_size);
max_size -= voc->remaining_size;
voc->remaining_size = 0;
break;
if (!st)
return AVERROR(ENOMEM);
- avio_seek(s->pb, 12, SEEK_CUR);
+ avio_skip(s->pb, 12);
header_size = avio_rb32(s->pb);
st->codec->channels = avio_rb32(s->pb) + 1;
read_bitrate = avio_rb32(s->pb);
rate_flag = avio_rb32(s->pb);
- avio_seek(s->pb, len-12, SEEK_CUR);
+ avio_skip(s->pb, len-12);
st->codec->bit_rate = read_bitrate*1000;
st->codec->bits_per_coded_sample = 16;
av_log(s, AV_LOG_ERROR, "Unknown chunk: %c%c%c%c\n",
((char*)&chunk_tag)[0], ((char*)&chunk_tag)[1],
((char*)&chunk_tag)[2], ((char*)&chunk_tag)[3]);
- avio_seek(s->pb, FFMIN(len, header_size), SEEK_CUR);
+ avio_skip(s->pb, FFMIN(len, header_size));
break;
}
size = next_tag(pb, &tag);
if (tag == tag1)
break;
- avio_seek(pb, size, SEEK_CUR);
+ avio_skip(pb, size);
}
return size;
}
avio_rl64(pb); /* RIFF size */
data_size = avio_rl64(pb);
sample_count = avio_rl64(pb);
- avio_seek(pb, size - 16, SEEK_CUR); /* skip rest of ds64 chunk */
+ avio_skip(pb, size - 16); /* skip rest of ds64 chunk */
}
/* parse fmt header */
sample_count = avio_rl32(pb);
size -= 4;
}
- avio_seek(pb, size, SEEK_CUR);
+ avio_skip(pb, size);
}
if (rf64)
size = data_size;
return -1;
if (!memcmp(guid, guid1, 16))
return size;
- avio_seek(pb, FFALIGN(size, INT64_C(8)) - 24, SEEK_CUR);
+ avio_skip(pb, FFALIGN(size, INT64_C(8)) - 24);
}
return -1;
}
/* subtract chunk header size - normal wav file doesn't count it */
ff_get_wav_header(pb, st->codec, size - 24);
- avio_seek(pb, FFALIGN(size, INT64_C(8)) - size, SEEK_CUR);
+ avio_skip(pb, FFALIGN(size, INT64_C(8)) - size);
st->need_parsing = AVSTREAM_PARSE_FULL;
wc3->vpkt.data = NULL; wc3->vpkt.size = 0;
/* skip the first 3 32-bit numbers */
- avio_seek(pb, 12, SEEK_CUR);
+ avio_skip(pb, 12);
/* traverse through the chunks and load the header information before
* the first BRCH tag */
case SOND_TAG:
case INDX_TAG:
/* SOND unknown, INDX unnecessary; ignore both */
- avio_seek(pb, size, SEEK_CUR);
+ avio_skip(pb, size);
break;
case PC__TAG:
/* number of palettes, unneeded */
- avio_seek(pb, 12, SEEK_CUR);
+ avio_skip(pb, 12);
break;
case BNAM_TAG:
case TEXT_TAG:
/* subtitle chunk */
#if 0
- avio_seek(pb, size, SEEK_CUR);
+ avio_skip(pb, size);
#else
if ((unsigned)size > sizeof(text) || (ret = avio_read(pb, text, size)) != size)
ret = AVERROR(EIO);
break;
}
- avio_seek(pb, chunk_size, SEEK_CUR);
+ avio_skip(pb, chunk_size);
} while (chunk_tag != FINF_TAG);
return 0;
}
/* stay on 16-bit alignment */
if (skip_byte)
- avio_seek(pb, 1, SEEK_CUR);
+ avio_skip(pb, 1);
return ret;
} else {
default:
av_log(s, AV_LOG_INFO, "Skipping unknown chunk 0x%08X\n", chunk_type);
}
- avio_seek(pb, chunk_size + skip_byte, SEEK_CUR);
+ avio_skip(pb, chunk_size + skip_byte);
}
}
} else {
av_freep(&buf);
av_log(s, AV_LOG_WARNING, "unsupported metadata entry; key:%s, type:%d, length:0x%x\n", key, type, length);
- avio_seek(pb, length, SEEK_CUR);
+ avio_skip(pb, length);
return;
}
WtvContext *wtv = s->priv_data;
AVIOContext *pb = wtv->pb;
- avio_seek(pb, 72, SEEK_CUR); // picture aspect ratio is unreliable
+ avio_skip(pb, 72); // picture aspect ratio is unreliable
ff_get_bmp_header(pb, st);
return 72 + 40;
if (size < 32) {
av_log(s, AV_LOG_WARNING, "format buffer size underflow\n");
- avio_seek(pb, size, SEEK_CUR);
+ avio_skip(pb, size);
return NULL;
}
- avio_seek(pb, size - 32, SEEK_CUR);
+ avio_skip(pb, size - 32);
ff_get_guid(pb, &actual_subtype);
ff_get_guid(pb, &actual_formattype);
avio_seek(pb, -size, SEEK_CUR);
st = parse_media_type(s, st, sid, mediatype, actual_subtype, actual_formattype, size - 32);
- avio_seek(pb, 32, SEEK_CUR);
+ avio_skip(pb, 32);
return st;
} else if (!ff_guidcmp(mediatype, mediatype_audio)) {
st = new_stream(s, st, sid, AVMEDIA_TYPE_AUDIO);
} else {
if (ff_guidcmp(formattype, format_none))
av_log(s, AV_LOG_WARNING, "unknown formattype:"PRI_GUID"\n", ARG_GUID(formattype));
- avio_seek(pb, size, SEEK_CUR);
+ avio_skip(pb, size);
}
if (!memcmp(subtype + 4, (const uint8_t[]){MEDIASUBTYPE_BASE_GUID}, 12)) {
} else {
if (ff_guidcmp(formattype, format_none))
av_log(s, AV_LOG_WARNING, "unknown formattype:"PRI_GUID"\n", ARG_GUID(formattype));
- avio_seek(pb, size, SEEK_CUR);
+ avio_skip(pb, size);
}
if (!memcmp(subtype + 4, (const uint8_t[]){MEDIASUBTYPE_BASE_GUID}, 12)) {
return NULL;
if (ff_guidcmp(formattype, format_none))
av_log(s, AV_LOG_WARNING, "unknown formattype:"PRI_GUID"\n", ARG_GUID(formattype));
- avio_seek(pb, size, SEEK_CUR);
+ avio_skip(pb, size);
st->codec->codec_id = CODEC_ID_DVB_SUBTITLE;
return st;
} else if (!ff_guidcmp(mediatype, mediatype_mstvcaption) &&
return NULL;
if (ff_guidcmp(formattype, format_none))
av_log(s, AV_LOG_WARNING, "unknown formattype:"PRI_GUID"\n", ARG_GUID(formattype));
- avio_seek(pb, size, SEEK_CUR);
+ avio_skip(pb, size);
st->codec->codec_id = CODEC_ID_DVB_TELETEXT;
return st;
} else if (!ff_guidcmp(mediatype, mediatype_mpeg2_sections) &&
!ff_guidcmp(subtype, mediasubtype_mpeg2_sections)) {
if (ff_guidcmp(formattype, format_none))
av_log(s, AV_LOG_WARNING, "unknown formattype:"PRI_GUID"\n", ARG_GUID(formattype));
- avio_seek(pb, size, SEEK_CUR);
+ avio_skip(pb, size);
return NULL;
}
av_log(s, AV_LOG_WARNING, "unknown media type, mediatype:"PRI_GUID
", subtype:"PRI_GUID", formattype:"PRI_GUID"\n",
ARG_GUID(mediatype), ARG_GUID(subtype), ARG_GUID(formattype));
- avio_seek(pb, size, SEEK_CUR);
+ avio_skip(pb, size);
return NULL;
}
if (len < 32)
break;
sid = avio_rl32(pb) & 0x7FFF;
- avio_seek(pb, 8, SEEK_CUR);
+ avio_skip(pb, 8);
consumed = 32;
if (!ff_guidcmp(g, stream_guid)) {
if (ff_find_stream_index(s, sid) < 0) {
ff_asf_guid mediatype, subtype, formattype;
int size;
- avio_seek(pb, 28, SEEK_CUR);
+ avio_skip(pb, 28);
ff_get_guid(pb, &mediatype);
ff_get_guid(pb, &subtype);
- avio_seek(pb, 12, SEEK_CUR);
+ avio_skip(pb, 12);
ff_get_guid(pb, &formattype);
size = avio_rl32(pb);
parse_media_type(s, 0, sid, mediatype, subtype, formattype, size);
if (stream_index >= 0 && !((WtvStream*)s->streams[stream_index]->priv_data)->seen_data) {
ff_asf_guid mediatype, subtype, formattype;
int size;
- avio_seek(pb, 12, SEEK_CUR);
+ avio_skip(pb, 12);
ff_get_guid(pb, &mediatype);
ff_get_guid(pb, &subtype);
- avio_seek(pb, 12, SEEK_CUR);
+ avio_skip(pb, 12);
ff_get_guid(pb, &formattype);
size = avio_rl32(pb);
parse_media_type(s, s->streams[stream_index], sid, mediatype, subtype, formattype, size);
const uint8_t *pbuf = buf;
int buf_size;
- avio_seek(pb, 8, SEEK_CUR);
+ avio_skip(pb, 8);
consumed += 8;
if (!ff_guidcmp(g, EVENTID_CtxADescriptorSpanningEvent) ||
!ff_guidcmp(g, EVENTID_CSDescriptorSpanningEvent)) {
- avio_seek(pb, 6, SEEK_CUR);
+ avio_skip(pb, 6);
consumed += 6;
}
if (stream_index >= 0) {
AVStream *st = s->streams[stream_index];
int audio_type;
- avio_seek(pb, 8, SEEK_CUR);
+ avio_skip(pb, 8);
audio_type = avio_r8(pb);
if (audio_type == 2)
st->disposition |= AV_DISPOSITION_HEARING_IMPAIRED;
} else if (!ff_guidcmp(g, EVENTID_DVBScramblingControlSpanningEvent)) {
int stream_index = ff_find_stream_index(s, sid);
if (stream_index >= 0) {
- avio_seek(pb, 12, SEEK_CUR);
+ avio_skip(pb, 12);
if (avio_rl32(pb))
av_log(s, AV_LOG_WARNING, "DVB scrambled stream detected (st:%d), decoding will likely fail\n", stream_index);
consumed += 16;
if (stream_index >= 0) {
AVStream *st = s->streams[stream_index];
uint8_t language[4];
- avio_seek(pb, 12, SEEK_CUR);
+ avio_skip(pb, 12);
avio_read(pb, language, 3);
if (language[0]) {
language[3] = 0;
} else if (!ff_guidcmp(g, timestamp_guid)) {
int stream_index = ff_find_stream_index(s, sid);
if (stream_index >= 0) {
- avio_seek(pb, 8, SEEK_CUR);
+ avio_skip(pb, 8);
wtv->pts = avio_rl64(pb);
consumed += 16;
if (wtv->pts == -1)
wtv->epoch = wtv->pts;
if (mode == SEEK_TO_PTS && wtv->pts >= seekts) {
#define WTV_PAD8(x) (((x) + 7) & ~7)
- avio_seek(pb, WTV_PAD8(len) - consumed, SEEK_CUR);
+ avio_skip(pb, WTV_PAD8(len) - consumed);
return 0;
}
}
} else
av_log(s, AV_LOG_WARNING, "unsupported chunk:"PRI_GUID"\n", ARG_GUID(g));
- avio_seek(pb, WTV_PAD8(len) - consumed, SEEK_CUR);
+ avio_skip(pb, WTV_PAD8(len) - consumed);
}
return AVERROR_EOF;
}
wtv->last_valid_pts = AV_NOPTS_VALUE;
/* read root directory sector */
- avio_seek(s->pb, 0x30, SEEK_CUR);
+ avio_skip(s->pb, 0x30);
root_size = avio_rl32(s->pb);
if (root_size > sizeof(root)) {
av_log(s, AV_LOG_ERROR, "root directory size exceeds sector size\n");
return AVERROR_INVALIDDATA;
}
- avio_seek(s->pb, 4, SEEK_CUR);
+ avio_skip(s->pb, 4);
root_sector = avio_rl32(s->pb);
avio_seek(s->pb, root_sector << WTV_SECTOR_BITS, SEEK_SET);
return ret;
pkt->stream_index = stream_index;
pkt->pts = wtv->pts;
- avio_seek(pb, WTV_PAD8(len) - len, SEEK_CUR);
+ avio_skip(pb, WTV_PAD8(len) - len);
return 0;
}
chmask = avio_rl32(pb);
break;
case 5:
- avio_seek(pb, 1, SEEK_CUR);
+ avio_skip(pb, 1);
chan |= (avio_r8(pb) & 0xF) << 8;
chmask = avio_rl24(pb);
break;
rate = avio_rl24(pb);
break;
default:
- avio_seek(pb, size, SEEK_CUR);
+ avio_skip(pb, size);
}
if(id&0x40)
- avio_seek(pb, 1, SEEK_CUR);
+ avio_skip(pb, 1);
}
if(rate == -1){
av_log(ctx, AV_LOG_ERROR, "Cannot determine custom sampling rate\n");
st->codec->codec_type = AVMEDIA_TYPE_AUDIO;
st->codec->codec_id = CODEC_ID_ADPCM_EA_MAXIS_XA;
- avio_seek(pb, 4, SEEK_CUR); /* Skip the XA ID */
+ avio_skip(pb, 4); /* Skip the XA ID */
xa->out_size = avio_rl32(pb);
- avio_seek(pb, 2, SEEK_CUR); /* Skip the tag */
+ avio_skip(pb, 2); /* Skip the tag */
st->codec->channels = avio_rl16(pb);
st->codec->sample_rate = avio_rl32(pb);
/* Value in file is average byte rate*/
video_dec->codec_type = AVMEDIA_TYPE_VIDEO;
video_dec->codec_id = CODEC_ID_YOP;
- avio_seek(pb, 6, SEEK_CUR);
+ avio_skip(pb, 6);
frame_rate = avio_r8(pb);
yop->frame_size = avio_r8(pb) * 2048;
// Set position to the start of the frame
pkt->pos = yop->video_packet.pos;
- avio_seek(pb, yop->audio_block_length - ret, SEEK_CUR);
+ avio_skip(pb, yop->audio_block_length - ret);
ret = avio_read(pb, yop->video_packet.data + yop->palette_size,
actual_video_data_size);