diff scn2k/scn2k_textimpl.cc @ 68:043d5db57474

Fix index_series implementation (still incomplete)
author Thibaut Girka <thib@sitedethib.com>
date Wed, 23 Feb 2011 16:19:11 +0100
parents 36d92d21300f
children c3d4f9ee2cf1
line wrap: on
line diff
--- a/scn2k/scn2k_textimpl.cc
+++ b/scn2k/scn2k_textimpl.cc
@@ -407,29 +407,41 @@ void Text::impl_index_series(Cmd& cmd)
 	// 
 	if (cmd.args.size() >= 7)
 	{
-		int val = cmd.args[0].value;
-		int offset = cmd.args[1].value;
-		int r_min = cmd.args[2].value;
-		int v_min = cmd.args[3].value;
-		int v_max = cmd.args[4].value;
-		int r_max = cmd.args[5].value;
-		int mode = cmd.args[6].value;
-		// rldev : mode == 1,3 : 'acceralating curve', 2,3: 'decelerating curve'
-		// 複数の引数リスト(r_minからmodeまでのリスト)もつこともあり、その場合は
-		// "cancel out in some way" らしい
-		if (mode == 1 || mode == 3)
-			val += offset;
-		else if (mode == 2 || mode == 4)
-			val -= offset;
-if (cmd.args.size() != 7)
-	fprintf(stderr,"\n%d/%d: cmd 01-04:0320 : XXXX NOT SUPPORTED LIST : DOUBLE RANGE CONVERSION!   XXXXXXXXXXX\n",cmd.scn,cmd.pos);
-		if (val < v_min)
-			val = v_min;
-		if (val > v_max)
-			val = v_max;
-		val = (r_max-r_min)*(val-v_min)/(v_max-v_min) + r_min;
+		int i, val;
+		int x, startval;
+		int start, end, endval, mode;
+
+		//TODO: why index and offset, and not x?
+		x = cmd.args[0].value + cmd.args[1].value;
+		startval = cmd.args[2].value;
+		start = end = 0;
+		val = endval = startval;
+		for (i=3; i < cmd.args.size(); i += 4)
+		{
+			startval = endval;
+			start = cmd.args[i].value;
+			end = cmd.args[i + 1].value;
+			endval = cmd.args[i + 2].value;
+			int mode = cmd.args[i + 3].value;
+			if (start <= x && x <= end)
+			{
+				// rldev : mode == 1,3 : 'acceralating curve', 2,3: 'decelerating curve'
+				// 複数の引数リスト(r_minからmodeまでのリスト)もつこともあり、その場合は
+				// "cancel out in some way" らしい
+				// Assume mode 0, as we only know of it
+				// TODO: find out how other mode works (exp/log?)
+				// TODO: "When two ranges overlap, they appear to cancel out in some way"
+				val = startval + (endval - startval) * (x - start) / (end - start);
+			}
+		}
+		if (i != cmd.args.size())
+			fprintf(stderr, "\n%d/%d: cmd 01-04:0320 : WARNING: %d unconsumed arguments\n", cmd.scn, cmd.pos, cmd.args.size() - i);
+		if (x > end)
+			x = endval;
 		cmd.SetSysvar(val);
 	}
+	else
+		fprintf(stderr, "\n%d/%d: cmd 01-04:0320 : Not enough arguments?!\n", cmd.scn, cmd.pos);
 }
 
 void Text::impl_constrain(Cmd& cmd)