per_frame_eqn.c
上传用户:kjfoods
上传日期:2020-07-06
资源大小:29949k
文件大小:3k
源码类别:

midi

开发平台:

Unix_Linux

  1. /*****************************************************************************
  2.  * per_frame_eqn.c:
  3.  *****************************************************************************
  4.  * Copyright (C) 2004 the VideoLAN team
  5.  * $Id: 2cc067bb44109698497cf603d44cf766d39fc53d $
  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., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
  23.  *****************************************************************************/
  24. #include <stdio.h>
  25. #include <stdlib.h>
  26. #include <string.h>
  27. #include "fatal.h"
  28. #include "common.h"
  29. #include "param.h"
  30. #include "per_frame_eqn_types.h"
  31. #include "per_frame_eqn.h"
  32. #include "expr_types.h"
  33. #include "eval.h"
  34. /* Evaluate an equation */
  35. void eval_per_frame_eqn(per_frame_eqn_t * per_frame_eqn) {
  36.   if (per_frame_eqn == NULL)
  37.     return;
  38.      if (PER_FRAME_EQN_DEBUG) { 
  39.  printf("per_frame_%d=%s= ", per_frame_eqn->index, per_frame_eqn->param->name);
  40.  fflush(stdout);
  41.  }
  42.  
  43.     //*((double*)per_frame_eqn->param->engine_val) = eval_gen_expr(per_frame_eqn->gen_expr);
  44. set_param(per_frame_eqn->param, eval_gen_expr(per_frame_eqn->gen_expr));
  45.      if (PER_FRAME_EQN_DEBUG) printf(" = %.4fn", *((double*)per_frame_eqn->param->engine_val)); 
  46.  
  47. }
  48. /*
  49. void eval_per_frame_init_eqn(per_frame_eqn_t * per_frame_eqn) {
  50.    double val;
  51.    init_cond_t * init_cond;
  52.    if (per_frame_eqn == NULL)
  53.      return;
  54.      if (PER_FRAME_EQN_DEBUG) { 
  55.  printf("per_frame_init: %s = ", per_frame_eqn->param->name);
  56.  fflush(stdout);
  57.  }
  58.  
  59.     val = *((double*)per_frame_eqn->param->engine_val) = eval_gen_expr(per_frame_eqn->gen_expr);
  60.     if (PER_FRAME_EQN_DEBUG) printf(" = %fn", *((double*)per_frame_eqn->param->engine_val)); 
  61.      
  62. if (per_frame_eqn->param->flags & P_FLAG_QVAR) {
  63. per_frame_eqn->param->init_val.double_val = val;
  64. if ((init_cond = new_init_cond(per_frame_eqn->param)) == NULL)
  65. return;
  66. if ((list_append(init_cond_list, init_cond)) < 0) {
  67. free_init_cond(init_cond);
  68. return;
  69. }
  70.     }
  71. }
  72. */
  73. /* Frees perframe equation structure */
  74. void free_per_frame_eqn(per_frame_eqn_t * per_frame_eqn) {
  75. if (per_frame_eqn == NULL)
  76.   return;
  77.   free_gen_expr(per_frame_eqn->gen_expr);
  78.   free(per_frame_eqn);
  79. }
  80. /* Create a new per frame equation */
  81. per_frame_eqn_t * new_per_frame_eqn(int index, param_t * param, gen_expr_t * gen_expr) {
  82.   per_frame_eqn_t * per_frame_eqn;
  83.   per_frame_eqn = (per_frame_eqn_t*)malloc(sizeof(per_frame_eqn_t));
  84.   if (per_frame_eqn == NULL)
  85.     return NULL;
  86.   per_frame_eqn->param = param;
  87.   per_frame_eqn->gen_expr = gen_expr;
  88.   per_frame_eqn->index = index;
  89.   /* Set per frame eqn name */
  90.   //  memset(per_frame_eqn->name, 0, MAX_TOKEN_SIZE);
  91.   //strncpy(per_frame_eqn->name, name, MAX_TOKEN_SIZE-1);
  92.   return per_frame_eqn;
  93. }