/***********************************************************
* Rocks'n'Diamonds -- McDuffin Strikes Back! *
*----------------------------------------------------------*
-* ©1995 Artsoft Development *
-* Holger Schemel *
-* 33659 Bielefeld-Senne *
-* Telefon: (0521) 493245 *
-* eMail: aeglos@valinor.owl.de *
-* aeglos@uni-paderborn.de *
-* q99492@pbhrzx.uni-paderborn.de *
+* (c) 1995-98 Artsoft Entertainment *
+* Holger Schemel *
+* Oststrasse 11a *
+* 33604 Bielefeld *
+* phone: ++49 +521 290471 *
+* email: aeglos@valinor.owl.de *
*----------------------------------------------------------*
* editor.c *
***********************************************************/
#define CHOICE_DELAY_VALUE 100
static int level_xpos,level_ypos;
-static BOOL edit_mode;
-static BOOL name_typing;
+static boolean edit_mode;
+static boolean name_typing;
static int new_element1 = EL_MAUERWERK;
static int new_element2 = EL_LEERRAUM;
static int new_element3 = EL_ERDREICH;
EL_DRACHE,
EL_SONDE,
- EL_LEERRAUM,
- EL_LEERRAUM,
- EL_LEERRAUM,
+ EL_MAUER_X,
+ EL_MAUER_Y,
+ EL_MAUER_XY,
EL_CHAR_A + ('S' - 'A'),
EL_CHAR_A + ('O' - 'A'),
static int check[4][2] = { {-1,0}, {0,-1}, {1,0}, {0,1} };
static int safety = 0;
+ /* check if starting field still has the desired content */
+ if (Feld[from_x][from_y] == fill_element)
+ return;
+
safety++;
- if (safety>lev_fieldx*lev_fieldy)
- {
- fprintf(stderr,"Something went wrong in 'FloodFill()'. Please debug.\n");
- exit(-1);
- }
+ if (safety > lev_fieldx*lev_fieldy)
+ Error(ERR_EXIT, "Something went wrong in 'FloodFill()'. Please debug.");
old_element = Feld[from_x][from_y];
Feld[from_x][from_y] = fill_element;
for(i=0;i<4;i++)
{
- x = from_x+check[i][0];
- y = from_y+check[i][1];
+ x = from_x + check[i][0];
+ y = from_y + check[i][1];
- if (IN_LEV_FIELD(x,y) && Feld[x][y]==old_element)
- FloodFill(x,y,fill_element);
+ if (IN_LEV_FIELD(x,y) && Feld[x][y] == old_element)
+ FloodFill(x, y, fill_element);
}
safety--;
{
static int last_button = 0;
static int in_field_pressed = FALSE;
- static BOOL use_floodfill = FALSE;
+ static boolean use_floodfill = FALSE;
int x = (mx-SX)/MINI_TILEX;
int y = (my-SY)/MINI_TILEY;
edit_mode = FALSE;
break;
case ED_BUTTON_FILL:
- AreYouSure("Caution ! Flood fill mode ! Choose area !",AYS_OPEN);
+ Request("Caution ! Flood fill mode ! Choose area !",REQ_OPEN);
use_floodfill = TRUE;
return;
break;
edit_mode = TRUE;
break;
case ED_BUTTON_CLEAR:
- if (AreYouSure("Are you sure to clear this level ?",AYS_ASK))
+ if (Request("Are you sure to clear this level ?",REQ_ASK))
{
for(x=0;x<MAX_LEV_FIELDX;x++)
for(y=0;y<MAX_LEV_FIELDY;y++)
break;
case ED_BUTTON_UNDO:
if (leveldir[leveldir_nr].readonly ||
- AreYouSure("Exit without saving ?",AYS_ASK | AYS_STAY_OPEN))
+ Request("Exit without saving ?",REQ_ASK | REQ_STAY_OPEN))
{
CloseDoor(DOOR_CLOSE_BOTH);
game_status=MAINMENU;
if (leveldir[leveldir_nr].readonly)
{
- AreYouSure("This level is read only !",AYS_CONFIRM);
+ Request("This level is read only !",REQ_CONFIRM);
break;
}
figur_vorhanden = TRUE;
if (!figur_vorhanden)
- AreYouSure("No Level without Gregor Mc Duffin please !",
- AYS_CONFIRM);
+ Request("No Level without Gregor Mc Duffin please !",
+ REQ_CONFIRM);
else
{
- if (AreYouSure("Save this level and kill the old ?",
- AYS_ASK | AYS_STAY_OPEN))
+ if (Request("Save this level and kill the old ?",
+ REQ_ASK | REQ_STAY_OPEN))
{
for(x=0;x<lev_fieldx;x++)
for(y=0;y<lev_fieldy;y++)