Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Contribute to GitLab
Sign in / Register
Toggle navigation
F
ffmpeg.wasm-core
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Linshizhi
ffmpeg.wasm-core
Commits
21d4d5da
Commit
21d4d5da
authored
Nov 03, 2006
by
Michael Niedermayer
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
doxy
Originally committed as revision 6893 to
svn://svn.ffmpeg.org/ffmpeg/trunk
parent
b1d196db
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
34 additions
and
0 deletions
+34
-0
eval.h
libavcodec/eval.h
+34
-0
No files found.
libavcodec/eval.h
View file @
21d4d5da
...
@@ -34,16 +34,50 @@ double ff_eval(char *s, double *const_value, const char **const_name,
...
@@ -34,16 +34,50 @@ double ff_eval(char *s, double *const_value, const char **const_name,
double
(
**
func2
)(
void
*
,
double
,
double
),
char
**
func2_name
,
double
(
**
func2
)(
void
*
,
double
,
double
),
char
**
func2_name
,
void
*
opaque
);
void
*
opaque
);
#endif
#endif
/**
* Parses and evaluates an expression.
* Note, this is significantly slower then ff_parse_eval()
* @param s expression as a zero terminated string for example "1+2^3+5*5+sin(2/3)"
* @param func1 NULL terminated array of function pointers for functions which take 1 argument
* @param func2 NULL terminated array of function pointers for functions which take 2 arguments
* @param const_name NULL terminated array of zero terminated strings of constant identifers for example {"PI", "E", 0}
* @param func1_name NULL terminated array of zero terminated strings of func1 identifers
* @param func2_name NULL terminated array of zero terminated strings of func2 identifers
* @param error pointer to a char* which is set to an error message if something goes wrong
* @param const_value a zero terminated array of values for the identifers from const_name
* @param opaque a pointer which will be passed to all functions from func1 and func2
* @return the value of the expression
*/
double
ff_eval2
(
char
*
s
,
double
*
const_value
,
const
char
**
const_name
,
double
ff_eval2
(
char
*
s
,
double
*
const_value
,
const
char
**
const_name
,
double
(
**
func1
)(
void
*
,
double
),
const
char
**
func1_name
,
double
(
**
func1
)(
void
*
,
double
),
const
char
**
func1_name
,
double
(
**
func2
)(
void
*
,
double
,
double
),
char
**
func2_name
,
double
(
**
func2
)(
void
*
,
double
,
double
),
char
**
func2_name
,
void
*
opaque
,
char
**
error
);
void
*
opaque
,
char
**
error
);
typedef
struct
ff_expr_s
AVEvalExpr
;
typedef
struct
ff_expr_s
AVEvalExpr
;
/**
* Parses a expression.
* @param s expression as a zero terminated string for example "1+2^3+5*5+sin(2/3)"
* @param func1 NULL terminated array of function pointers for functions which take 1 argument
* @param func2 NULL terminated array of function pointers for functions which take 2 arguments
* @param const_name NULL terminated array of zero terminated strings of constant identifers for example {"PI", "E", 0}
* @param func1_name NULL terminated array of zero terminated strings of func1 identifers
* @param func2_name NULL terminated array of zero terminated strings of func2 identifers
* @param error pointer to a char* which is set to an error message if something goes wrong
* @return AVEvalExpr which must be freed with ff_eval_free by the user when its not needed anymore
* NULL if anything went wrong
*/
AVEvalExpr
*
ff_parse
(
char
*
s
,
const
char
**
const_name
,
AVEvalExpr
*
ff_parse
(
char
*
s
,
const
char
**
const_name
,
double
(
**
func1
)(
void
*
,
double
),
const
char
**
func1_name
,
double
(
**
func1
)(
void
*
,
double
),
const
char
**
func1_name
,
double
(
**
func2
)(
void
*
,
double
,
double
),
char
**
func2_name
,
double
(
**
func2
)(
void
*
,
double
,
double
),
char
**
func2_name
,
char
**
error
);
char
**
error
);
/**
* Evaluates a previously parsed expression.
* @param const_value a zero terminated array of values for the identifers from ff_parse const_name
* @param opaque a pointer which will be passed to all functions from func1 and func2
* @return the value of the expression
*/
double
ff_parse_eval
(
AVEvalExpr
*
e
,
double
*
const_value
,
void
*
opaque
);
double
ff_parse_eval
(
AVEvalExpr
*
e
,
double
*
const_value
,
void
*
opaque
);
void
ff_eval_free
(
AVEvalExpr
*
e
);
void
ff_eval_free
(
AVEvalExpr
*
e
);
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment