1 /*****************************************************************************
3 *****************************************************************************
4 * Copyright (C) 2004 the VideoLAN team
7 * Authors: Cyril Deguet <asmax@videolan.org>
8 * code from projectM http://xmms-projectm.sourceforge.net
10 * This program is free software; you can redistribute it and/or modify
11 * it under the terms of the GNU General Public License as published by
12 * the Free Software Foundation; either version 2 of the License, or
13 * (at your option) any later version.
15 * This program is distributed in the hope that it will be useful,
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 * GNU General Public License for more details.
20 * You should have received a copy of the GNU General Public License
21 * along with this program; if not, write to the Free Software
22 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
23 *****************************************************************************/
32 #include "per_frame_eqn_types.h"
33 #include "per_frame_eqn.h"
35 #include "expr_types.h"
38 /* Evaluate an equation */
39 void eval_per_frame_eqn(per_frame_eqn_t * per_frame_eqn) {
41 if (per_frame_eqn == NULL)
44 if (PER_FRAME_EQN_DEBUG) {
45 printf("per_frame_%d=%s= ", per_frame_eqn->index, per_frame_eqn->param->name);
49 //*((double*)per_frame_eqn->param->engine_val) = eval_gen_expr(per_frame_eqn->gen_expr);
50 set_param(per_frame_eqn->param, eval_gen_expr(per_frame_eqn->gen_expr));
51 if (PER_FRAME_EQN_DEBUG) printf(" = %.4f\n", *((double*)per_frame_eqn->param->engine_val));
56 void eval_per_frame_init_eqn(per_frame_eqn_t * per_frame_eqn) {
59 init_cond_t * init_cond;
60 if (per_frame_eqn == NULL)
63 if (PER_FRAME_EQN_DEBUG) {
64 printf("per_frame_init: %s = ", per_frame_eqn->param->name);
69 val = *((double*)per_frame_eqn->param->engine_val) = eval_gen_expr(per_frame_eqn->gen_expr);
70 if (PER_FRAME_EQN_DEBUG) printf(" = %f\n", *((double*)per_frame_eqn->param->engine_val));
72 if (per_frame_eqn->param->flags & P_FLAG_QVAR) {
74 per_frame_eqn->param->init_val.double_val = val;
75 if ((init_cond = new_init_cond(per_frame_eqn->param)) == NULL)
78 if ((list_append(init_cond_list, init_cond)) < 0) {
79 free_init_cond(init_cond);
86 /* Frees perframe equation structure */
87 void free_per_frame_eqn(per_frame_eqn_t * per_frame_eqn) {
89 if (per_frame_eqn == NULL)
92 free_gen_expr(per_frame_eqn->gen_expr);
96 /* Create a new per frame equation */
97 per_frame_eqn_t * new_per_frame_eqn(int index, param_t * param, gen_expr_t * gen_expr) {
99 per_frame_eqn_t * per_frame_eqn;
101 per_frame_eqn = (per_frame_eqn_t*)malloc(sizeof(per_frame_eqn_t));
103 if (per_frame_eqn == NULL)
106 per_frame_eqn->param = param;
107 per_frame_eqn->gen_expr = gen_expr;
108 per_frame_eqn->index = index;
109 /* Set per frame eqn name */
110 // memset(per_frame_eqn->name, 0, MAX_TOKEN_SIZE);
111 //strncpy(per_frame_eqn->name, name, MAX_TOKEN_SIZE-1);
112 return per_frame_eqn;