dsys2

changeset 6:80f86f0f67ec

I think I've done most of it...
author John Tsiombikas <nuclear@siggraph.org>
date Fri, 02 Sep 2011 04:49:18 +0300 (2011-09-02)
parents 94ce16dd20c0
children 3258d163cfbc
files src/dsys.c src/dsys2.h src/dsys_impl.h
diffstat 3 files changed, 74 insertions(+), 15 deletions(-) [+]
line diff
     1.1 --- a/src/dsys.c	Fri Sep 02 01:57:00 2011 +0300
     1.2 +++ b/src/dsys.c	Fri Sep 02 04:49:18 2011 +0300
     1.3 @@ -8,6 +8,8 @@
     1.4  
     1.5  static int read_script(struct dsys_demo *demo, FILE *fp, const char *fname);
     1.6  
     1.7 +static void proc_event(struct dsys_event *ev, demotime_t tm);
     1.8 +static void link_callback(struct dsys_event *ev, void *cls);
     1.9  static void free_event(struct dsys_event *ev);
    1.10  
    1.11  static struct dsys_event *sort_evlist(struct dsys_event *list, int num_ev);
    1.12 @@ -131,7 +133,7 @@
    1.13  		}
    1.14  		strcpy(ev->name, tok);
    1.15  
    1.16 -		ev->eval_func = t0 == t1 ? dsys_eval_step : dsys_eval_lerp;
    1.17 +		ev->eval = t0 == t1 ? dsys_eval_step : dsys_eval_lerp;
    1.18  
    1.19  		ev->next = demo->evlist;
    1.20  		ev->prev = 0;
    1.21 @@ -150,17 +152,46 @@
    1.22  
    1.23  void dsys_update(struct dsys_demo *demo, demotime_t tm)
    1.24  {
    1.25 +	struct dsys_event *ev;
    1.26 +
    1.27  	demo->src_tm = tm;
    1.28  
    1.29  	if(demo->start_tm == -1) {
    1.30  		dsys_start(demo);
    1.31  	}
    1.32  
    1.33 -	if(demo->running) {
    1.34 -		demo->tm = tm - demo->start_tm - demo->stoppage_tm;
    1.35 +	if(!demo->running) {
    1.36 +		return;	/* nothing changes */
    1.37  	}
    1.38  
    1.39 -	/* TODO check the events list etc etc */
    1.40 +	demo->tm = tm - demo->start_tm - demo->stoppage_tm;
    1.41 +
    1.42 +	while(demo->active->t1 < demo->tm) {
    1.43 +		proc_event(demo->active, demo->tm);
    1.44 +		demo->active = demo->active->next;
    1.45 +	}
    1.46 +
    1.47 +	ev = demo->active;
    1.48 +	while(ev->t0 <= demo->tm) {
    1.49 +		proc_event(ev, demo->tm);
    1.50 +		ev = ev->next;
    1.51 +	}
    1.52 +	demo->nextev = ev;
    1.53 +}
    1.54 +
    1.55 +static void proc_event(struct dsys_event *ev, demotime_t tm)
    1.56 +{
    1.57 +	float val = ev->eval(ev, tm);
    1.58 +
    1.59 +	if(ev->val != val) {
    1.60 +		struct callback *cb = ev->cblist;
    1.61 +
    1.62 +		while(cb) {
    1.63 +			cb->func(ev, cb->cls);
    1.64 +			cb = cb->next;
    1.65 +		}
    1.66 +		ev->val = val;
    1.67 +	}
    1.68  }
    1.69  
    1.70  void dsys_start(struct dsys_demo *demo)
    1.71 @@ -171,6 +202,7 @@
    1.72  
    1.73  	if(demo->start_tm == -1) {
    1.74  		demo->start_tm = demo->src_tm;
    1.75 +		demo->nextev = demo->active = demo->evlist;
    1.76  	} else {
    1.77  		demo->stoppage_tm += demo->src_tm - demo->stop_tm;
    1.78  	}
    1.79 @@ -212,7 +244,8 @@
    1.80  /* seek without continuity */
    1.81  void dsys_seek(struct dsys_demo *demo, demotime_t tm)
    1.82  {
    1.83 -	/* TODO */
    1.84 +	demo->start_tm = demo->src_tm - tm;
    1.85 +	demo->stoppage_tm = 0;
    1.86  }
    1.87  
    1.88  void dsys_seek_norm(struct dsys_demo *demo, float t)
    1.89 @@ -221,8 +254,15 @@
    1.90  }
    1.91  
    1.92  /* seek by accelerating time */
    1.93 -void dsys_warp(struct dsys_demo *demo, demotime_t tm);
    1.94 -void dsys_warp_norm(struct dsys_demo *demo, float t);
    1.95 +void dsys_warp(struct dsys_demo *demo, demotime_t tm)
    1.96 +{
    1.97 +	fprintf(stderr, "dsys_warp not implemented yet\n");
    1.98 +}
    1.99 +
   1.100 +void dsys_warp_norm(struct dsys_demo *demo, float t)
   1.101 +{
   1.102 +	dsys_warp(demo, t * demo->duration);
   1.103 +}
   1.104  
   1.105  
   1.106  /* events */
   1.107 @@ -246,14 +286,33 @@
   1.108  
   1.109  float dsys_event_value(struct dsys_event *ev)
   1.110  {
   1.111 -	return ev->value;
   1.112 +	return ev->val;
   1.113  }
   1.114  
   1.115 -void dsys_event_callback(struct dsys_event *ev, void (*func)(void*), void *cls)
   1.116 +int dsys_event_callback(struct dsys_event *ev, void (*func)(struct dsys_event*, void*), void *cls)
   1.117  {
   1.118 +	struct callback *cb;
   1.119 +
   1.120 +	if(!(cb = malloc(sizeof *cb))) {
   1.121 +		perror("failed to allocate memory");
   1.122 +		return -1;
   1.123 +	}
   1.124 +	cb->func = func;
   1.125 +	cb->cls = cls;
   1.126 +	cb->next = ev->cblist;
   1.127 +	ev->cblist = cb;
   1.128 +	return 0;
   1.129  }
   1.130  
   1.131 -void dsys_event_link(struct dsys_event *ev, float *link);
   1.132 +int dsys_event_link(struct dsys_event *ev, float *link)
   1.133 +{
   1.134 +	return dsys_event_callback(ev, link_callback, link);
   1.135 +}
   1.136 +
   1.137 +static void link_callback(struct dsys_event *ev, void *cls)
   1.138 +{
   1.139 +	*(float*)cls = ev->val;
   1.140 +}
   1.141  
   1.142  
   1.143  /* time conversion */
     2.1 --- a/src/dsys2.h	Fri Sep 02 01:57:00 2011 +0300
     2.2 +++ b/src/dsys2.h	Fri Sep 02 04:49:18 2011 +0300
     2.3 @@ -45,8 +45,8 @@
     2.4  enum dsys_evtype dsys_event_type(struct dsys_event *ev);
     2.5  float dsys_event_value(struct dsys_event *ev);
     2.6  
     2.7 -void dsys_event_callback(struct dsys_event *ev, void (*func)(void*), void *cls);
     2.8 -void dsys_event_link(struct dsys_event *ev, float *link);
     2.9 +int dsys_event_callback(struct dsys_event *ev, void (*func)(struct dsys_event*, void*), void *cls);
    2.10 +int dsys_event_link(struct dsys_event *ev, float *link);
    2.11  
    2.12  /* event evaluators */
    2.13  float dsys_eval_step(struct dsys_event *ev, demotime_t t);
    2.14 @@ -56,11 +56,9 @@
    2.15  /* time conversion */
    2.16  demotime_t dsys_sec_to_dtime(float sec);
    2.17  demotime_t dsys_msec_to_dtime(unsigned long msec);
    2.18 -demotime_t dsys_norm_to_dtime(float t);
    2.19  
    2.20  float dsys_dtime_to_sec(demotime_t tm);
    2.21  unsigned long dsys_dtime_to_msec(demotime_t tm);
    2.22 -float dsys_dtime_to_norm(demotime_t tm);
    2.23  
    2.24  
    2.25  #endif	/* DSYS2_H_ */
     3.1 --- a/src/dsys_impl.h	Fri Sep 02 01:57:00 2011 +0300
     3.2 +++ b/src/dsys_impl.h	Fri Sep 02 04:49:18 2011 +0300
     3.3 @@ -10,6 +10,8 @@
     3.4  	struct dsys_event *evlist;
     3.5  	int num_ev;
     3.6  
     3.7 +	struct dsys_event *nextev, *active;
     3.8 +
     3.9  	int running;
    3.10  };
    3.11  
    3.12 @@ -28,7 +30,7 @@
    3.13  	demotime_t t0, t1;
    3.14  	float val;
    3.15  
    3.16 -	float (*eval_func)(struct dsys_event*, demotime_t);
    3.17 +	float (*eval)(struct dsys_event*, demotime_t);
    3.18  
    3.19  	struct callback *cblist;
    3.20