]> git.sesse.net Git - vlc/blob - modules/visualization/galaktos/per_frame_eqn.c
* all: first implementation of a MilkDrop-compatible visualization plugin,
[vlc] / modules / visualization / galaktos / per_frame_eqn.c
1 /*****************************************************************************
2  * per_frame_eqn.c:
3  *****************************************************************************
4  * Copyright (C) 2004 VideoLAN
5  * $Id$
6  *
7  * Authors: Cyril Deguet <asmax@videolan.org>
8  *          code from projectM http://xmms-projectm.sourceforge.net
9  *
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.
14  *
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.
19  *
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., 59 Temple Place - Suite 330, Boston, MA  02111, USA.
23  *****************************************************************************/
24
25
26
27 #include <stdio.h>
28 #include <stdlib.h>
29 #include <string.h>
30
31 #include "fatal.h"
32 #include "common.h"
33 #include "per_frame_eqn_types.h"
34 #include "per_frame_eqn.h"
35
36 #include "expr_types.h"
37 #include "eval.h"
38
39 /* Evaluate an equation */
40 void eval_per_frame_eqn(per_frame_eqn_t * per_frame_eqn) {
41
42   if (per_frame_eqn == NULL)
43     return;
44
45      if (PER_FRAME_EQN_DEBUG) { 
46                  printf("per_frame_%d=%s= ", per_frame_eqn->index, per_frame_eqn->param->name);
47                  fflush(stdout);
48          }
49          
50     //*((double*)per_frame_eqn->param->engine_val) = eval_gen_expr(per_frame_eqn->gen_expr);
51         set_param(per_frame_eqn->param, eval_gen_expr(per_frame_eqn->gen_expr));
52      if (PER_FRAME_EQN_DEBUG) printf(" = %.4f\n", *((double*)per_frame_eqn->param->engine_val)); 
53                  
54 }
55
56 /*
57 void eval_per_frame_init_eqn(per_frame_eqn_t * per_frame_eqn) {
58
59    double val;
60    init_cond_t * init_cond;
61    if (per_frame_eqn == NULL)
62      return;
63
64      if (PER_FRAME_EQN_DEBUG) { 
65                  printf("per_frame_init: %s = ", per_frame_eqn->param->name);
66                  fflush(stdout);
67          }
68                         
69         
70     val = *((double*)per_frame_eqn->param->engine_val) = eval_gen_expr(per_frame_eqn->gen_expr);
71     if (PER_FRAME_EQN_DEBUG) printf(" = %f\n", *((double*)per_frame_eqn->param->engine_val)); 
72      
73         if (per_frame_eqn->param->flags & P_FLAG_QVAR) {
74                 
75                 per_frame_eqn->param->init_val.double_val = val;
76                 if ((init_cond = new_init_cond(per_frame_eqn->param)) == NULL)
77                         return;
78                 
79                 if ((list_append(init_cond_list, init_cond)) < 0) {
80                         free_init_cond(init_cond);
81                         return;
82                 }
83     }
84 }
85 */
86
87 /* Frees perframe equation structure */
88 void free_per_frame_eqn(per_frame_eqn_t * per_frame_eqn) {
89
90         if (per_frame_eqn == NULL)
91           return;
92         
93   free_gen_expr(per_frame_eqn->gen_expr);
94   free(per_frame_eqn);
95 }
96
97 /* Create a new per frame equation */
98 per_frame_eqn_t * new_per_frame_eqn(int index, param_t * param, gen_expr_t * gen_expr) {
99
100   per_frame_eqn_t * per_frame_eqn;
101
102   per_frame_eqn = (per_frame_eqn_t*)malloc(sizeof(per_frame_eqn_t));
103
104   if (per_frame_eqn == NULL)
105     return NULL;
106
107   per_frame_eqn->param = param;
108   per_frame_eqn->gen_expr = gen_expr;
109   per_frame_eqn->index = index;
110   /* Set per frame eqn name */
111   //  memset(per_frame_eqn->name, 0, MAX_TOKEN_SIZE);
112   //strncpy(per_frame_eqn->name, name, MAX_TOKEN_SIZE-1);
113   return per_frame_eqn;
114
115 }