#define SPRING_ROLL /* spring rolling off round things continues to roll */
-#define RANDOM (random_em = random_em << 31 | random_em >> 1)
+#define RANDOM_RAW (seed = seed << 31 | seed >> 1)
+#define RANDOM(x) (RANDOM_RAW & (x - 1))
-static unsigned int random_em;
+static unsigned int seed;
static int score;
static void set_nearest_player_xy(int x, int y, int *dx, int *dy)
Cave[y+1][x+1] != Xblank)
goto android_move;
- switch (RANDOM & 7)
+ switch (RANDOM(8))
{
/* randomly find an object to clone */
Next[y][x] = temp; /* the item we chose to clone */
play_element_sound(x, y, SOUND_android_clone, temp);
- switch (RANDOM & 7)
+ switch (RANDOM(8))
{
/* randomly find a direction to move */
Next[y][x] = Xblank; /* assume we will move */
temp = ((x < dx) + 1 - (x > dx)) + ((y < dy) + 1 - (y > dy)) * 3;
- if (RANDOM & 1)
+ if (RANDOM(2))
{
switch (temp)
{
return;
default:
- Next[y][x] = RANDOM & 1 ? Xeater_e : Xeater_w;
+ Next[y][x] = RANDOM(2) ? Xeater_e : Xeater_w;
play_element_sound(x, y, SOUND_eater, Xeater_n);
return;
}
return;
default:
- Next[y][x] = RANDOM & 1 ? Xeater_n : Xeater_s;
+ Next[y][x] = RANDOM(2) ? Xeater_n : Xeater_s;
play_element_sound(x, y, SOUND_eater, Xeater_e);
return;
}
return;
default:
- Next[y][x] = RANDOM & 1 ? Xeater_e : Xeater_w;
+ Next[y][x] = RANDOM(2) ? Xeater_e : Xeater_w;
play_element_sound(x, y, SOUND_eater, Xeater_s);
return;
}
return;
default:
- Next[y][x] = RANDOM & 1 ? Xeater_n : Xeater_s;
+ Next[y][x] = RANDOM(2) ? Xeater_n : Xeater_s;
play_element_sound(x, y, SOUND_eater, Xeater_w);
return;
}
set_nearest_player_xy(x, y, &dx, &dy);
}
- if (RANDOM & 1)
+ if (RANDOM(2))
{
if (y > dy)
{
case Xroundwall_2:
case Xroundwall_3:
case Xroundwall_4:
- if (RANDOM & 1)
+ if (RANDOM(2))
{
if (tab_blank[Cave[y][x+1]] && tab_acid[Cave[y+1][x+1]])
{
default:
if (++lev.shine_cnt > 50)
{
- lev.shine_cnt = RANDOM & 7;
+ lev.shine_cnt = RANDOM(8);
Cave[y][x] = Xemerald_shine;
}
case Xroundwall_2:
case Xroundwall_3:
case Xroundwall_4:
- if (RANDOM & 1)
+ if (RANDOM(2))
{
if (tab_blank[Cave[y][x+1]] && tab_acid[Cave[y+1][x+1]])
{
default:
if (++lev.shine_cnt > 50)
{
- lev.shine_cnt = RANDOM & 7;
+ lev.shine_cnt = RANDOM(8);
Cave[y][x] = Xdiamond_shine;
}
case Xacid_splash_w:
case Xplant:
case Yplant:
-#if 1
+#ifdef EM_ENGINE_USE_ADDITIONAL_ELEMENTS
case Xfake_acid_1:
case Xfake_acid_2:
case Xfake_acid_3:
case Xroundwall_2:
case Xroundwall_3:
case Xroundwall_4:
- if (RANDOM & 1)
+ if (RANDOM(2))
{
if (tab_blank[Cave[y][x+1]] && tab_acid[Cave[y+1][x+1]])
{
case Xblank:
case Xacid_splash_e:
case Xacid_splash_w:
-#if 1
+#ifdef EM_ENGINE_USE_ADDITIONAL_ELEMENTS
case Xfake_acid_1:
case Xfake_acid_2:
case Xfake_acid_3:
case Xacid_splash_e:
case Xacid_splash_w:
case Zplayer:
-#if 1
+#ifdef EM_ENGINE_USE_ADDITIONAL_ELEMENTS
case Xfake_acid_1:
case Xfake_acid_2:
case Xfake_acid_3:
return;
case Xspring:
- if (RANDOM & 1)
+ if (RANDOM(2))
{
switch (Cave[y+1][x+1])
{
case Xroundwall_2:
case Xroundwall_3:
case Xroundwall_4:
- if (RANDOM & 1)
+ if (RANDOM(2))
{
if (tab_blank[Cave[y][x+1]] && tab_acid[Cave[y+1][x+1]])
{
case Xroundwall_2:
case Xroundwall_3:
case Xroundwall_4:
- if (RANDOM & 1)
+ if (RANDOM(2))
{
if (tab_blank[Cave[y][x+1]] && tab_acid[Cave[y+1][x+1]])
{
case Xroundwall_2:
case Xroundwall_3:
case Xroundwall_4:
- if (RANDOM & 1)
+ if (RANDOM(2))
{
if (tab_blank[Cave[y][x+1]] && tab_acid[Cave[y+1][x+1]])
{
if (lev.ball_random)
{
- switch (RANDOM & 7)
+ switch (RANDOM(8))
{
case 0:
if (lev.ball_array[lev.ball_pos][0] != Xblank &&
return;
default:
- switch (RANDOM & 7)
+ switch (RANDOM(8))
{
- case 0:
- temp = Xamoeba_1;
- break;
-
- case 1:
- temp = Xamoeba_2;
- break;
-
- case 2:
- temp = Xamoeba_3;
- break;
-
- case 3:
- temp = Xamoeba_4;
- break;
-
- case 4:
- temp = Xamoeba_5;
- break;
-
- case 5:
- temp = Xamoeba_6;
- break;
-
- case 6:
- temp = Xamoeba_7;
- break;
-
- case 7:
- temp = Xamoeba_8;
- break;
+ case 0: temp = Xamoeba_1; break;
+ case 1: temp = Xamoeba_2; break;
+ case 2: temp = Xamoeba_3; break;
+ case 3: temp = Xamoeba_4; break;
+ case 4: temp = Xamoeba_5; break;
+ case 5: temp = Xamoeba_6; break;
+ case 6: temp = Xamoeba_7; break;
+ case 7: temp = Xamoeba_8; break;
}
Cave[y][x] = temp;
Next[y][x] = Xsand;
}
-#if 1
+#ifdef EM_ENGINE_USE_ADDITIONAL_ELEMENTS
static void Lsand_stonesand_quickout_1(int x, int y)
{
Next[y][x] = Xsand_stonesand_quickout_2;
if (lev.required > 0)
return;
- int temp = RANDOM & 63;
-
- if (temp < 21)
- {
- Cave[y][x] = Xexit_1;
- Next[y][x] = Xexit_2;
- }
- else if (temp < 42)
- {
- Cave[y][x] = Xexit_2;
- Next[y][x] = Xexit_3;
- }
- else
+ switch (RANDOM(64) / 21)
{
- Cave[y][x] = Xexit_3;
- Next[y][x] = Xexit_1;
+ case 0:
+ Cave[y][x] = Xexit_1;
+ Next[y][x] = Xexit_2;
+ break;
+
+ case 1:
+ Cave[y][x] = Xexit_2;
+ Next[y][x] = Xexit_3;
+ break;
+
+ default:
+ Cave[y][x] = Xexit_3;
+ Next[y][x] = Xexit_1;
+ break;
}
play_element_sound(x, y, SOUND_exit_open, Xexit);
Next[y][x] = Xacid_1;
}
+#ifdef EM_ENGINE_USE_ADDITIONAL_ELEMENTS
static void Lfake_acid_1(int x, int y)
{
Next[y][x] = Xfake_acid_2;
{
Next[y][x] = Xfake_acid_1;
}
+#endif
static void Lpause(int x, int y)
{
short *cave_cache = Cave[y]; /* might be a win */
int element;
- random_em = RandomEM;
+ seed = RandomEM;
score = 0;
loop:
case Xacid_7: Lacid_7(x, y); goto loop;
case Xacid_8: Lacid_8(x, y); goto loop;
+#ifdef EM_ENGINE_USE_ADDITIONAL_ELEMENTS
case Xfake_acid_1: Lfake_acid_1(x, y); goto loop;
case Xfake_acid_2: Lfake_acid_2(x, y); goto loop;
case Xfake_acid_3: Lfake_acid_3(x, y); goto loop;
case Xfake_acid_6: Lfake_acid_6(x, y); goto loop;
case Xfake_acid_7: Lfake_acid_7(x, y); goto loop;
case Xfake_acid_8: Lfake_acid_8(x, y); goto loop;
+#endif
case Xandroid: Landroid(x, y); goto loop;
case Xandroid_1_n: Landroid_1_n(x, y); goto loop;
case Xsand_stonesand_4: Lsand_stonesand_4(x, y); goto loop;
case Xsand_stoneout_1: Lsand_stoneout_1(x, y); goto loop;
case Xsand_stoneout_2: Lsand_stoneout_2(x, y); goto loop;
-#if 1
+#ifdef EM_ENGINE_USE_ADDITIONAL_ELEMENTS
case Xsand_stonesand_quickout_1:Lsand_stonesand_quickout_1(x, y);goto loop;
case Xsand_stonesand_quickout_2:Lsand_stonesand_quickout_2(x, y);goto loop;
#endif
goto loop;
}
-#undef RANDOM
-#undef PLAY
-#undef PLAY_FORCE
-
done:
if (ply[0].alive || ply[1].alive || ply[2].alive || ply[3].alive)
else
game_em.game_over = TRUE;
- RandomEM = random_em;
+ RandomEM = seed;
{
void *temp = Cave;