summaryrefslogtreecommitdiff
path: root/libavutil/eval.h
diff options
context:
space:
mode:
authorGyan Doshi <ffmpeg@gyani.pro>2019-11-17 11:02:10 +0530
committerGyan Doshi <ffmpeg@gyani.pro>2019-11-17 11:07:05 +0530
commit1c23abc88fef0a0c8486bf0ec3594f8e2d26d83f (patch)
treedf57ffda1f5b410dc8bdac004d3340e2814858a8 /libavutil/eval.h
parent487e7e9670032465e1850d54fd58c5248aa50be9 (diff)
downloadffmpeg-1c23abc88fef0a0c8486bf0ec3594f8e2d26d83f.tar.gz
avutil/eval: add function to track variable use
1)Some filters allow cross-referenced expressions e.g. x=y+10. In such cases, filters evaluate expressions multiple times for successful evaluation of all expressions. If the expression for one or more variables contains a RNG, the result may vary across evaluation leading to inconsistent values across the cross-referenced expressions. 2)A related case is circular expressions e.g. x=y+10 and y=x+10 which cannot be succesfully resolved. 3)Certain filter variables may only be applicable in specific eval modes and lead to a failure of evaluation in other modes e.g. pts is only relevant for frame eval mode. At present, there is no reliable means to identify these occurrences and thus the error messages provided are broad or inaccurate. The helper function introduced - av_expr_count_vars - allows developers to identify the use and count of variables in expressions and thus tailor the error message, allow for a graceful fallback and/or decide evaluation order.
Diffstat (limited to 'libavutil/eval.h')
-rw-r--r--libavutil/eval.h10
1 files changed, 10 insertions, 0 deletions
diff --git a/libavutil/eval.h b/libavutil/eval.h
index dacd22b96e..9bdb10cca2 100644
--- a/libavutil/eval.h
+++ b/libavutil/eval.h
@@ -87,6 +87,16 @@ int av_expr_parse(AVExpr **expr, const char *s,
double av_expr_eval(AVExpr *e, const double *const_values, void *opaque);
/**
+ * Track the presence of variables and their number of occurrences in a parsed expression
+ *
+ * @param counter a zero-initialized array where the count of each variable will be stored
+ * @param size size of array
+ * @return 0 on success, a negative value indicates that no expression or array was passed
+ * or size was zero
+ */
+int av_expr_count_vars(AVExpr *e, unsigned *counter, int size);
+
+/**
* Free a parsed expression previously created with av_expr_parse().
*/
void av_expr_free(AVExpr *e);