Mercurial > hg > Members > koba > t_dandy
diff ppe/chara_state7.cc @ 31:ccb8d9956a1e
add multi container function.
author | koba <koba@cr.ie.u-ryukyu.ac.jp> |
---|---|
date | Fri, 31 Dec 2010 19:19:13 +0900 |
parents | c4210c1053e8 |
children | 39e643fc4f90 |
line wrap: on
line diff
--- a/ppe/chara_state7.cc Fri Dec 31 15:50:44 2010 +0900 +++ b/ppe/chara_state7.cc Fri Dec 31 19:19:13 2010 +0900 @@ -1,5 +1,6 @@ #include "task_base.h" #include "task_object.h" +#include "../ObjectType.h" SchedDefineTask(State7); @@ -7,17 +8,30 @@ run(SchedTask *smanager, void *rbuf, void *wbuf) { CHARACTER *p = (CHARACTER*)smanager->get_input(rbuf, 0); - TamaContainerPtr tama = (TamaContainerPtr)smanager->get_input(rbuf, 1); + int length = 1; + + smanager->set_outputSize(1, sizeof(ObjContainer)+sizeof(ObjData)*(length-1)); + smanager->setup_outputData(); + + CHARACTER *q = (CHARACTER*)smanager->get_output(wbuf, 0); + ObjContainerPtr tama = (ObjContainerPtr)smanager->get_output(wbuf, 1); + tama->flag = false; p->x += p->vx; p->y += p->vy; if((p->dt1 == 60) || (p->dt1 == 90) || (p->dt1 == 30)) { - Puttama(1, p->x, p->y, tama); + tama->flag = true; + tama->type = Tama; + tama->length = length; + + + Puttama(1, p->x, p->y, &tama->data[0]); } p->dt1++; p->task = STATE7; - smanager->swap(); + + *q = *p; return 0; }