[Top][All Lists]
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Gnash-commit] gnash ChangeLog testsuite/misc-ming.all/action_...
From: |
Zou Lunkai |
Subject: |
[Gnash-commit] gnash ChangeLog testsuite/misc-ming.all/action_... |
Date: |
Fri, 16 Mar 2007 03:39:53 +0000 |
CVSROOT: /sources/gnash
Module name: gnash
Changes by: Zou Lunkai <zoulunkai> 07/03/16 03:39:53
Modified files:
. : ChangeLog
Added files:
testsuite/misc-ming.all: action_execution_order_test4.c
action_execution_order_test5.c
Log message:
2 more testcases to verify action execution order
CVSWeb URLs:
http://cvs.savannah.gnu.org/viewcvs/gnash/ChangeLog?cvsroot=gnash&r1=1.2606&r2=1.2607
http://cvs.savannah.gnu.org/viewcvs/gnash/testsuite/misc-ming.all/action_execution_order_test4.c?cvsroot=gnash&rev=1.1
http://cvs.savannah.gnu.org/viewcvs/gnash/testsuite/misc-ming.all/action_execution_order_test5.c?cvsroot=gnash&rev=1.1
Patches:
Index: ChangeLog
===================================================================
RCS file: /sources/gnash/gnash/ChangeLog,v
retrieving revision 1.2606
retrieving revision 1.2607
diff -u -b -r1.2606 -r1.2607
--- ChangeLog 15 Mar 2007 22:39:53 -0000 1.2606
+++ ChangeLog 16 Mar 2007 03:39:52 -0000 1.2607
@@ -1,3 +1,9 @@
+2007-03-16 Zou Lunkai <address@hidden>
+
+ * testsuite/misc-ming.all/action_execution_order_test4.c.
+ * testsuite/misc-ming.all/action_execution_order_test5.c.
+ add 2 more testcases to verify actions execution order.
+
2007-03-13 Sandro Santilli <address@hidden>
* server/as_value.h (to_number): null and undefined are converted
Index: testsuite/misc-ming.all/action_execution_order_test4.c
===================================================================
RCS file: testsuite/misc-ming.all/action_execution_order_test4.c
diff -N testsuite/misc-ming.all/action_execution_order_test4.c
--- /dev/null 1 Jan 1970 00:00:00 -0000
+++ testsuite/misc-ming.all/action_execution_order_test4.c 16 Mar 2007
03:39:53 -0000 1.1
@@ -0,0 +1,209 @@
+/*
+ * Copyright (C) 2005, 2006, 2007 Free Software Foundation, Inc.
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
+ *
+ */
+
+/*
+ * Zou Lunkai, address@hidden
+ *
+ * To verify that for all movieClips within the same timeline:
+ * (1) OnLoad: first added first called;
+ * (2) OnUnload: first removed first called;
+ * (3) OnEnterFrame: last added first called;
+ *
+ * 1st frame of _root:
+ * place mc_red1 at depth 10
+ * place mc_red2 at depth 12
+ * place mc_red3 at depth 11
+ *
+ * 4th frame of _root:
+ * remove mc_red1
+ * remove mc_red2
+ * remove mc_red3
+ *
+ * expected actions order:
+ * mc_red1.OnLoad; actions in 1st frame of mc_red1;
+ * mc_red2.OnLoad; actions in 1st frame of mc_red2;
+ * mc_red3.OnLoad; actions in 1st frame of mc_red3;
+ * mc_red3.OnEnterFrame; actions in 2nd frame of mc_red3;
+ * mc_red2.OnEnterFrame; actions in 2nd frame of mc_red2;
+ * mc_red1.OnEnterFrame; actions in 2nd frame of mc_red1;
+ * mc_red1.OnUnload;
+ * mc_red2.OnUnload;
+ * mc_red3.OnUnload;
+ *
+ * The actual order of tags are dependent on compiler, so you need to
+ * verify first if the order of tags is what you expect.
+ */
+
+#include <stdlib.h>
+#include <stdio.h>
+#include <ming.h>
+
+#include "ming_utils.h"
+
+#define OUTPUT_VERSION 6
+#define OUTPUT_FILENAME "action_execution_order_test4.swf"
+
+
+int
+main(int argc, char** argv)
+{
+ SWFMovie mo;
+ SWFMovieClip mc_red1, mc_red2, mc_red3, mc_red4, mc_red5, dejagnuclip;
+ SWFDisplayItem it_red1, it_red2, it_red3, it_red4, it_red5;
+ SWFShape sh_red;
+
+ const char *srcdir=".";
+ if ( argc>1 )
+ srcdir=argv[1];
+ else
+ {
+ fprintf(stderr, "Usage: %s <mediadir>\n", argv[0]);
+ return 1;
+ }
+
+ Ming_init();
+ mo = newSWFMovieWithVersion(OUTPUT_VERSION);
+ SWFMovie_setDimension(mo, 800, 600);
+ SWFMovie_setRate (mo, 12.0);
+
+ dejagnuclip = get_dejagnu_clip((SWFBlock)get_default_font(srcdir), 10, 0, 0,
800, 600);
+ SWFMovie_add(mo, (SWFBlock)dejagnuclip);
+ SWFMovie_nextFrame(mo); /* 1st frame */
+
+
+ mc_red1 = newSWFMovieClip();
+ sh_red = make_fill_square (0, 300, 60, 60, 255, 0, 0, 255, 0, 0);
+ SWFMovieClip_add(mc_red1, (SWFBlock)sh_red);
+ add_clip_actions(mc_red1, " _root.note('actions in 1st frame of mc_red1'); "
+ " _root.x1 += '2+'; ");
+ SWFMovieClip_nextFrame(mc_red1); /* mc_red1, 1st frame */
+ add_clip_actions(mc_red1, " _root.note('actions in 2nd frame of mc_red1'); "
+ " _root.x1 += '12+'; "
+ " stop(); ");
+ SWFMovieClip_nextFrame(mc_red1); /* mc_red1, 2nd frame */
+
+ mc_red2 = newSWFMovieClip();
+ sh_red = make_fill_square (80, 300, 60, 60, 255, 0, 0, 255, 0, 0);
+ SWFMovieClip_add(mc_red2, (SWFBlock)sh_red);
+ add_clip_actions(mc_red2, " _root.note('actions in 1st frame of mc_red2'); "
+ " _root.x1 += '4+'; ");
+ SWFMovieClip_nextFrame(mc_red2); /* mc_red2, 1st frame */
+ add_clip_actions(mc_red2, " _root.note('actions in 2nd frame of mc_red2'); "
+ " _root.x1 += '10+'; "
+ " stop(); ");
+ SWFMovieClip_nextFrame(mc_red2); /* mc_red2, 2nd frame */
+
+ mc_red3 = newSWFMovieClip();
+ sh_red = make_fill_square (160, 300, 60, 60, 255, 0, 0, 255, 0, 0);
+ SWFMovieClip_add(mc_red3, (SWFBlock)sh_red);
+ add_clip_actions(mc_red3, " _root.note('actions in 1st frame of mc_red3'); "
+ " _root.x1 += '6+';");
+ SWFMovieClip_nextFrame(mc_red3); /* mc_red3, 1st frame */
+ add_clip_actions(mc_red3, " _root.note('actions in 2nd frame of mc_red3'); "
+ " _root.x1 += '8+'; "
+ " stop(); ");
+ SWFMovieClip_nextFrame(mc_red3); /* mc_red3, 2nd frame */
+
+
+ /* add mc_red1 to _root and name it as "mc_red1" */
+ it_red1 = SWFMovie_add(mo, (SWFBlock)mc_red1);
+ SWFDisplayItem_setDepth(it_red1, 10);
+ SWFDisplayItem_setName(it_red1, "mc_red1");
+ /* Define onLoad ClipEvent */
+ SWFDisplayItem_addAction(it_red1,
+ compileSWFActionCode(" _root.note('mc_red1 onLoad called');"
+ " _root.x1 += '1+'; "),
+ SWFACTION_ONLOAD);
+ /* Define Unload ClipEvent */
+ SWFDisplayItem_addAction(it_red1,
+ compileSWFActionCode(" _root.note('mc_red1 onUnload called'); "
+ " _root.x1 += '13+'; "),
+ SWFACTION_UNLOAD);
+ /* Define onEnterFrame ClipEvent */
+ SWFDisplayItem_addAction(it_red1,
+ compileSWFActionCode(" _root.note('mc_red1 onEnterFrame called'); "
+ " _root.x1 += '11+'; "),
+ SWFACTION_ENTERFRAME);
+
+ /* add mc_red2 to _root and name it as "mc_red2" */
+ it_red2 = SWFMovie_add(mo, (SWFBlock)mc_red2);
+ SWFDisplayItem_setDepth(it_red2, 12);
+ SWFDisplayItem_setName(it_red2, "mc_red2");
+ /* Define onLoad ClipEvent */
+ SWFDisplayItem_addAction(it_red2,
+ compileSWFActionCode(" _root.note('mc_red2 onLoad called'); "
+ " _root.x1 += '3+'; "),
+ SWFACTION_ONLOAD);
+ /* Define Unload ClipEvent */
+ SWFDisplayItem_addAction(it_red2,
+ compileSWFActionCode(" _root.note('mc_red2 onUnload called'); "
+ " _root.x1 += '14+'; "),
+ SWFACTION_UNLOAD);
+ /* Define onEnterFrame ClipEvent */
+ SWFDisplayItem_addAction(it_red2,
+ compileSWFActionCode(" _root.note('mc_red2 onEnterFrame called'); "
+ " _root.x1 += '9+'; "),
+ SWFACTION_ENTERFRAME);
+
+ /* add mc_red3 to _root and name it as "mc_red3" */
+ it_red3 = SWFMovie_add(mo, (SWFBlock)mc_red3);
+ SWFDisplayItem_setDepth(it_red3, 11);
+ SWFDisplayItem_setName(it_red3, "mc_red3");
+ /* Define onLoad ClipEvent */
+ SWFDisplayItem_addAction(it_red3,
+ compileSWFActionCode(" _root.note('mc_red3 onLoad called'); "
+ " _root.x1 += '5+'; "),
+ SWFACTION_ONLOAD);
+ /* Define onUnload ClipEvent */
+ SWFDisplayItem_addAction(it_red3,
+ compileSWFActionCode(" _root.note('mc_red3 onUnload called'); "
+ " _root.x1 += '15+';" ),
+ SWFACTION_UNLOAD);
+ /* Define onEnterFrame ClipEvent */
+ SWFDisplayItem_addAction(it_red3,
+ compileSWFActionCode(" _root.note('mc_red3 onEnterFrame called'); "
+ " _root.x1 += '7+'; "),
+ SWFACTION_ENTERFRAME);
+
+ SWFMovie_nextFrame(mo); /* 2nd frame */
+
+
+ SWFMovie_nextFrame(mo); /* 3rd frame */
+
+ /* It's no use to change the order below.
+ After compile, Ming will re-organize them as
+ remove mc_red1; remove mc_red2; remove mc_red3;*/
+ SWFDisplayItem_remove(it_red3);
+ SWFDisplayItem_remove(it_red1);
+ SWFDisplayItem_remove(it_red2);
+ SWFMovie_nextFrame(mo); /* 4th frame */
+
+ xcheck_equals(mo, "_root.x1", "'1+2+3+4+5+6+7+8+9+10+11+12+13+14+15+'");
+ add_actions(mo, " _root.totals(); stop(); ");
+ SWFMovie_nextFrame(mo); /* 5th frame */
+
+
+ //Output movie
+ puts("Saving " OUTPUT_FILENAME );
+ SWFMovie_save(mo, OUTPUT_FILENAME);
+
+ return 0;
+}
+
+
+
Index: testsuite/misc-ming.all/action_execution_order_test5.c
===================================================================
RCS file: testsuite/misc-ming.all/action_execution_order_test5.c
diff -N testsuite/misc-ming.all/action_execution_order_test5.c
--- /dev/null 1 Jan 1970 00:00:00 -0000
+++ testsuite/misc-ming.all/action_execution_order_test5.c 16 Mar 2007
03:39:53 -0000 1.1
@@ -0,0 +1,240 @@
+/*
+ * Copyright (C) 2005, 2006, 2007 Free Software Foundation, Inc.
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
+ *
+ */
+
+/*
+ * Zou Lunkai, address@hidden
+ *
+ * For nested movieClips:
+ * (1) parent onLoad called first;
+ * (2) child unload called first;
+ * (3) child onEnterFrame called first;
+ *
+ * yes, parent could be a child of another parent,
+ * and child could be a parent of another child:)
+ * Just always keep (1)(2)(3) in mind.
+ *
+ * movieClips hiberarchy:
+ * _root (5 frames)
+ * |----dejagnuclip(placed at 1st frame of main timeline)
+ * |----mc1
+ * |----mc11
+ * |----mc12
+ * |----mc121
+ * |----mc1211
+ *
+ * expected onClipEvents order:
+ * mc1.OnLoad;
+ * mc11.OnLoad;
+ * mc12.OnLoad; mc121.OnLoad; mc1211.OnLoad;
+ * mc1211.OnEnterFrame; mc121.OnEnterFrame; mc12.OnEnterFrame
+ * mc11.OnEnterFrame;
+ * mc1.OnEnterFrame;
+ * mc1211.OnUnload; mc121.OnUnload; mc12.OnUnload;
+ * mc11.OnUnload;
+ * mc1.OnUnload;
+ *
+ * The actual order of tags are dependent on compiler, so you need to
+ * verify first if the order of tags is what you expect.
+ */
+
+#include <stdlib.h>
+#include <stdio.h>
+#include <ming.h>
+
+#include "ming_utils.h"
+
+#define OUTPUT_VERSION 6
+#define OUTPUT_FILENAME "action_execution_order_test5.swf"
+
+
+int
+main(int argc, char** argv)
+{
+ SWFMovie mo;
+ SWFMovieClip mc1, mc11, mc12, mc121, mc1211, dejagnuclip;
+ SWFDisplayItem it1, it11, it12, it121, it1211;
+
+ const char *srcdir=".";
+ if ( argc>1 )
+ srcdir=argv[1];
+ else
+ {
+ fprintf(stderr, "Usage: %s <mediadir>\n", argv[0]);
+ return 1;
+ }
+
+ Ming_init();
+ mo = newSWFMovieWithVersion(OUTPUT_VERSION);
+ SWFMovie_setDimension(mo, 800, 600);
+ SWFMovie_setRate (mo, 12.0);
+
+ dejagnuclip = get_dejagnu_clip((SWFBlock)get_default_font(srcdir), 10, 0, 0,
800, 600);
+ SWFMovie_add(mo, (SWFBlock)dejagnuclip);
+ SWFMovie_nextFrame(mo); /* 1st frame of _root */
+
+ /*===================== Start of defining movieClips
==========================*/
+
+ mc1211 = newSWFMovieClip();
+ SWFMovieClip_nextFrame(mc1211); /* mc1211, 1st frame */
+ SWFMovieClip_nextFrame(mc1211); /* mc1211, 2nd frame */
+
+ mc121 = newSWFMovieClip();
+
+ /* add mc1211 to mc121 and name it as "mc1211" */
+ it1211 = SWFMovieClip_add(mc121, (SWFBlock)mc1211);
+ SWFDisplayItem_setDepth(it1211, 1);
+ SWFDisplayItem_setName(it1211, "mc1211");
+
+ /* add onClipEvents */
+ SWFDisplayItem_addAction(it1211,
+ compileSWFActionCode(" _root.note('mc1211 onLoad called'); "
+ " _root.x1 += '5+'; "),
+ SWFACTION_ONLOAD);
+ SWFDisplayItem_addAction(it1211,
+ compileSWFActionCode(" _root.note('mc1211 onUnload called'); "
+ " _root.x1 += '11+'; "),
+ SWFACTION_UNLOAD);
+ SWFDisplayItem_addAction(it1211,
+ compileSWFActionCode(" _root.note('mc1211 onEnterFrame called'); "
+ " _root.x1 += '6+'; "),
+ SWFACTION_ENTERFRAME);
+
+ SWFMovieClip_nextFrame(mc121); /* mc121, 1st frame */
+ SWFMovieClip_nextFrame(mc121); /* mc121, 2nd frame */
+
+
+ mc12 = newSWFMovieClip();
+ /* add mc121 to mc12 and name it as "mc121" */
+ it121 = SWFMovieClip_add(mc12, (SWFBlock)mc121);
+ SWFDisplayItem_setDepth(it121, 1);
+ SWFDisplayItem_setName(it121, "mc121");
+
+ /* add onClipEvents */
+ SWFDisplayItem_addAction(it121,
+ compileSWFActionCode(" _root.note('mc121 onLoad called'); "
+ " _root.x1 += '4+'; "),
+ SWFACTION_ONLOAD);
+ SWFDisplayItem_addAction(it121,
+ compileSWFActionCode(" _root.note('mc121 onUnload called'); "
+ " _root.x1 += '12+'; "),
+ SWFACTION_UNLOAD);
+ SWFDisplayItem_addAction(it121,
+ compileSWFActionCode(" _root.note('mc121 onEnterFrame called'); "
+ " _root.x1 += '7+'; "),
+ SWFACTION_ENTERFRAME);
+
+ SWFMovieClip_nextFrame(mc12); /* mc12, 1st frame */
+ SWFMovieClip_nextFrame(mc12); /* mc12, 2nd frame */
+
+
+ mc11 = newSWFMovieClip();
+ SWFMovieClip_nextFrame(mc11); /* mc11, 1st frame */
+ SWFMovieClip_nextFrame(mc11); /* mc11, 2nd frame */
+
+
+ mc1 = newSWFMovieClip();
+
+ /* add mc11 to mc1 and name it as "mc11" */
+ it11 = SWFMovieClip_add(mc1, (SWFBlock)mc11);
+ SWFDisplayItem_setDepth(it11, 2);
+
+ /* add onClipEvents */
+ SWFDisplayItem_setName(it11, "mc11");
+ SWFDisplayItem_addAction(it11,
+ compileSWFActionCode(" _root.note('mc11 onLoad called'); "
+ " _root.x1 += '2+'; "),
+ SWFACTION_ONLOAD);
+ SWFDisplayItem_addAction(it11,
+ compileSWFActionCode(" _root.note('mc11 onUnload called'); "
+ " _root.x1 += '14+'; "),
+ SWFACTION_UNLOAD);
+ SWFDisplayItem_addAction(it11,
+ compileSWFActionCode(" _root.note('mc11 onEnterFrame called'); "
+ " _root.x1 += '9+'; "),
+ SWFACTION_ENTERFRAME);
+
+ /* add mc12 to mc1 and name it as "mc12" */
+ it12 = SWFMovieClip_add(mc1, (SWFBlock)mc12);
+ SWFDisplayItem_setDepth(it12, 1);
+ SWFDisplayItem_setName(it12, "mc12");
+
+ /* add onClipEvents */
+ SWFDisplayItem_addAction(it12,
+ compileSWFActionCode(" _root.note('mc12 onLoad called'); "
+ " _root.x1 += '3+'; "),
+ SWFACTION_ONLOAD);
+ SWFDisplayItem_addAction(it12,
+ compileSWFActionCode(" _root.note('mc12 onUnload called'); "
+ " _root.x1 += '13+'; "),
+ SWFACTION_UNLOAD);
+ SWFDisplayItem_addAction(it12,
+ compileSWFActionCode(" _root.note('mc12 onEnterFrame called'); "
+ " _root.x1 += '8+'; "),
+ SWFACTION_ENTERFRAME);
+
+ SWFMovieClip_nextFrame(mc1); /* mc1, 1st frame */
+ SWFMovieClip_nextFrame(mc1); /* mc1, 2nd frame */
+
+ /*===================== End of defining movieClips
==========================*/
+
+
+
+ it1 = SWFMovie_add(mo, (SWFBlock)mc1);
+
+ /* add onClipEvents */
+ SWFDisplayItem_addAction(it1,
+ compileSWFActionCode(" _root.note('mc1 onLoad called'); "
+ " _root.x1 += '1+'; "),
+ SWFACTION_ONLOAD);
+ SWFDisplayItem_addAction(it1,
+ compileSWFActionCode(" _root.note('mc1 onUnload called'); "
+ " _root.x1 += '15+'; "),
+ SWFACTION_UNLOAD);
+ SWFDisplayItem_addAction(it1,
+ compileSWFActionCode(" _root.note('mc1 onEnterFrame called'); "
+ " _root.x1 += '10+'; "),
+ SWFACTION_ENTERFRAME);
+
+
+ /* place _root.mc1 */
+ SWFDisplayItem_setDepth(it1, 10);
+ SWFDisplayItem_setName(it1, "mc1");
+ SWFMovie_nextFrame(mo); /* 2nd frame of _root */
+
+
+ SWFMovie_nextFrame(mo); /* 3rd frame of _root */
+
+ /* remove _root.mc1 */
+ SWFDisplayItem_remove(it1);
+ SWFMovie_nextFrame(mo); /* 4th frame of _root */
+
+ /* checks */
+ xcheck_equals(mo, "_root.x1", "'1+2+3+4+5+6+7+8+9+10+11+12+13+14+15+'");
+ add_actions(mo, " _root.totals(); stop(); ");
+ SWFMovie_nextFrame(mo); /* 5th frame of _root */
+
+
+ //Output movie
+ puts("Saving " OUTPUT_FILENAME );
+ SWFMovie_save(mo, OUTPUT_FILENAME);
+
+ return 0;
+}
+
+
+
- [Gnash-commit] gnash ChangeLog testsuite/misc-ming.all/action_..., Zou Lunkai, 2007/03/05
- [Gnash-commit] gnash ChangeLog testsuite/misc-ming.all/action_..., Sandro Santilli, 2007/03/05
- [Gnash-commit] gnash ChangeLog testsuite/misc-ming.all/action_..., Zou Lunkai, 2007/03/08
- [Gnash-commit] gnash ChangeLog testsuite/misc-ming.all/action_..., Zou Lunkai, 2007/03/12
- [Gnash-commit] gnash ChangeLog testsuite/misc-ming.all/action_...,
Zou Lunkai <=
- [Gnash-commit] gnash ChangeLog testsuite/misc-ming.all/action_..., Zou Lunkai, 2007/03/19
- [Gnash-commit] gnash ChangeLog testsuite/misc-ming.all/action_..., Zou Lunkai, 2007/03/21