Mercurial > hg > Members > koba > t_dandy
diff spe/chara_state3.cc @ 49:f4140672ef9f
fix.
author | koba <koba@cr.ie.u-ryukyu.ac.jp> |
---|---|
date | Fri, 21 Jan 2011 22:18:28 +0900 |
parents | c330ded6d728 |
children | cfd42ee2ad28 |
line wrap: on
line diff
--- a/spe/chara_state3.cc Sat Jan 15 19:13:03 2011 +0900 +++ b/spe/chara_state3.cc Fri Jan 21 22:18:28 2011 +0900 @@ -1,11 +1,13 @@ -#include "chara_state3.h" -#include "tobject.h" +#include "task_base.h" +#include "task_object.h" +#include "../ObjectType.h" -SchedDefineTask(STATE3); +SchedDefineTask1(State3, state3); static int -run(SchedTask *smanager, void *rbuf, void *wbuf) +state3(SchedTask *smanager, void *rbuf, void *wbuf) { + int length; CHARACTER *p = (CHARACTER*)smanager->get_input(rbuf, 0); p->x += p->vx; @@ -14,11 +16,20 @@ (p->dt1 == 90) || (p->dt1 == 30)) { - Puttama(0, p->x, p->y); + length = 1; + smanager->set_outputSize(1, sizeof(ObjContainer)+sizeof(ObjData)*(length-1)); + smanager->setup_outputData(); + ObjContainerPtr tama = (ObjContainerPtr)smanager->get_output(wbuf, 1); + tama->flag = true; + tama->length = length; + + Puttama(0, p->x, p->y, &tama->data[0]); } + CHARACTER *q = (CHARACTER*)smanager->get_output(wbuf, 0); + p->dt1++; - p->task = STATE3; - smanager->swap(); + + *q = *p; return 0; }