# HG changeset patch # User takis # Date 1159386379 0 # Node ID 8e1ed8300165c63e9a7c02ee5896b0237c72bd67 # Parent 699bceae338c5b775a774cd36dec74e68e35db62 Make ratecontrol use ff_eval2(). diff -r 699bceae338c -r 8e1ed8300165 mpegvideo.h --- a/mpegvideo.h Wed Sep 27 11:09:35 2006 +0000 +++ b/mpegvideo.h Wed Sep 27 19:46:19 2006 +0000 @@ -991,10 +991,16 @@ float ff_rate_estimate_qscale(MpegEncContext *s, int dry_run); void ff_write_pass1_stats(MpegEncContext *s); void ff_rate_control_uninit(MpegEncContext *s); +#if LIBAVCODEC_VERSION_INT < ((52<<16)+(0<<8)+0) double ff_eval(char *s, double *const_value, const char **const_name, double (**func1)(void *, double), const char **func1_name, double (**func2)(void *, double, double), char **func2_name, void *opaque); +#endif +double ff_eval2(char *s, double *const_value, const char **const_name, + double (**func1)(void *, double), const char **func1_name, + double (**func2)(void *, double, double), char **func2_name, + void *opaque, char **error); int ff_vbv_update(MpegEncContext *s, int frame_size); void ff_get_2pass_fcode(MpegEncContext *s); diff -r 699bceae338c -r 8e1ed8300165 ratecontrol.c --- a/ratecontrol.c Wed Sep 27 11:09:35 2006 +0000 +++ b/ratecontrol.c Wed Sep 27 19:46:19 2006 +0000 @@ -259,6 +259,7 @@ const int pict_type= rce->new_pict_type; const double mb_num= s->mb_num; int i; + char *error = NULL; double const_values[]={ M_PI, @@ -325,9 +326,9 @@ NULL }; - bits= ff_eval(s->avctx->rc_eq, const_values, const_names, func1, func1_names, NULL, NULL, rce); + bits= ff_eval2(s->avctx->rc_eq, const_values, const_names, func1, func1_names, NULL, NULL, rce, &error); if (isnan(bits)) { - av_log(s->avctx, AV_LOG_ERROR, "Unable to parse rc_eq \"%s\".\n", s->avctx->rc_eq); + av_log(s->avctx, AV_LOG_ERROR, "Error evaluating rc_eq \"%s\": %s\n", s->avctx->rc_eq, error? error : ""); return -1; }