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;
 }