double *weights;
int channels;
- int delay;
int eof;
int64_t pts;
init_gaussian_filter(s);
s->channels = inlink->channels;
- s->delay = s->filter_size;
return 0;
}
}
}
- s->delay--;
return filter_frame(inlink, out);
}
s->pts = out->pts;
ret = ff_filter_frame(outlink, out);
- s->delay = s->queue.available;
}
return ret;
s->eof = 1;
}
- if (s->eof && s->delay > 0)
+ if (s->eof && s->queue.available)
return flush(outlink);
- if (s->eof && s->delay <= 0) {
+ if (s->eof && !s->queue.available) {
ff_outlink_set_status(outlink, AVERROR_EOF, s->pts);
return 0;
}