/***********************************************************
* 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 *
*----------------------------------------------------------*
* main.c *
***********************************************************/
#include "main.h"
#include "init.h"
+#include "game.h"
#include "events.h"
#include "sound.h"
#include "joystick.h"
+#include "misc.h"
#ifdef MSDOS
#include <fcntl.h>
Visual *visual;
int screen;
Window window;
-GC gc, clip_gc[NUM_PIXMAPS];
+GC gc, clip_gc[NUM_PIXMAPS], tile_clip_gc;
Pixmap pix[NUM_PIXMAPS];
-Pixmap clipmask[NUM_PIXMAPS];
+Pixmap clipmask[NUM_PIXMAPS], tile_clipmask[NUM_TILES];
#ifdef XPM_INCLUDE_FILE
XpmAttributes xpm_att[NUM_PICTURES];
char *joystick_device_name[2] = { DEV_JOYSTICK_0, DEV_JOYSTICK_1 };
char *level_directory = LEVEL_PATH;
int width, height;
-unsigned long pen_fg, pen_bg;
+
+char *display_name = NULL;
+char *server_host = NULL;
+int server_port = 0;
+int networking = FALSE;
+int standalone = TRUE;
+int verbose = FALSE;
int game_status = MAINMENU;
int game_emulation = EMU_NONE;
int MovDelay[MAX_LEV_FIELDX][MAX_LEV_FIELDY];
int Store[MAX_LEV_FIELDX][MAX_LEV_FIELDY];
int Store2[MAX_LEV_FIELDX][MAX_LEV_FIELDY];
+int StorePlayer[MAX_LEV_FIELDX][MAX_LEV_FIELDY];
int Frame[MAX_LEV_FIELDX][MAX_LEV_FIELDY];
int Stop[MAX_LEV_FIELDX][MAX_LEV_FIELDY];
int JustHit[MAX_LEV_FIELDX][MAX_LEV_FIELDY];
int level_nr, leveldir_nr, num_leveldirs;
int lev_fieldx,lev_fieldy, scroll_x,scroll_y;
-int FX = SX, FY = SY, ScreenMovPos = 0, ScrollStepSize = TILEX/8;
+int FX = SX, FY = SY, ScrollStepSize = TILEX/8;
+int ScreenMovDir = MV_NO_MOVING, ScreenMovPos = 0;
+int ScreenGfxPos = 0;
+int GameFrameDelay = GAME_FRAME_DELAY, MoveSpeed = 8;
int BX1 = 0, BY1 = 0, BX2 = SCR_FIELDX-1, BY2 = SCR_FIELDY-1;
-int JX,JY, lastJX,lastJY, ZX,ZY, ExitX,ExitY;
-int PlayerMovDir, PlayerMovPos, PlayerPushing;
-int PlayerFrame, PlayerGfxPos;
-int PlayerGone, LevelSolved, GameOver;
-int FrameCounter, TimeFrames, TimeLeft, Score;
-int Gems, SokobanFields, Lights, Friends;
-int Dynamite, Key[4], MampferNr;
-int DynaBombCount, DynaBombSize, DynaBombsLeft, DynaBombXL;
-int SiebAktiv;
+int ZX,ZY, ExitX,ExitY;
+int AllPlayersGone;
+int FrameCounter, TimeFrames, TimeLeft;
+int MampferNr, SiebAktiv;
+
+int TestPlayer = 0;
struct LevelDirInfo leveldir[MAX_LEVDIR_ENTRIES];
struct LevelInfo level;
-struct PlayerInfo player;
+struct PlayerInfo stored_player[MAX_PLAYERS+1];
+struct PlayerInfo *local_player;
struct HiScore highscore[MAX_SCORE_ENTRIES];
struct SoundInfo Sound[NUM_SOUNDS];
struct RecordingInfo tape;
};
int num_bg_loops = sizeof(background_loop)/sizeof(int);
-char *progname;
+char *program_name;
+
+#define MAX_OPTION_LEN 1024
+
+static void fatal_option()
+{
+ fprintf(stderr,"Try '%s --help' for more information.\n",
+ program_name);
+ exit(1);
+}
+
+static void fatal_unrecognized_option(char *option)
+{
+ fprintf(stderr,"%s: unrecognized option '%s'\n",
+ program_name, option);
+ fatal_option();
+}
+
+static void fatal_option_requires_argument(char *option)
+{
+ fprintf(stderr,"%s: option '%s' requires an argument\n",
+ program_name, option);
+ fatal_option();
+}
+
+static void fatal_invalid_option_argument(char *option)
+{
+ fprintf(stderr,"%s: option '%s' has invalid argument\n",
+ program_name, option);
+ fatal_option();
+}
+
+static void fatal_too_many_arguments()
+{
+ fprintf(stderr,"%s: too many arguments\n",
+ program_name);
+ fatal_option();
+}
+
+extern void fatal(char *);
int main(int argc, char *argv[])
{
- progname = argv[0];
+ char **options_left = &argv[1];
+
+ program_name = (strrchr(argv[0],'/') ? strrchr(argv[0],'/') + 1 : argv[0]);
+
+ while (*options_left)
+ {
+ char option_str[MAX_OPTION_LEN];
+ char *option = options_left[0];
+ char *next_option = options_left[1];
+ char *option_arg = NULL;
+ int option_len = strlen(option);
+ strcpy(option_str, option); /* copy argument into buffer */
+ option = option_str;
+
+ if (strcmp(option, "--") == 0) /* stop scanning arguments */
+ break;
+
+ if (option_len >= MAX_OPTION_LEN)
+ fatal_unrecognized_option(option);
+
+ if (strncmp(option, "--", 2) == 0) /* treat '--' like '-' */
+ option++;
+
+ option_arg = strchr(option, '=');
+ if (option_arg == NULL) /* no '=' in option */
+ option_arg = next_option;
+ else
+ {
+ *option_arg++ = '\0'; /* cut argument from option */
+ if (*option_arg == '\0') /* no argument after '=' */
+ fatal_invalid_option_argument(option);
+ }
+
+ option_len = strlen(option);
+
+ if (strcmp(option, "-") == 0)
+ fatal_unrecognized_option(option);
+ else if (strncmp(option, "-help", option_len) == 0)
+ {
+ printf("Usage: %s [options] [server.name [port]]\n"
+ "Options:\n"
+ " -d, --display machine:0 X server display\n"
+ " -l, --levels directory alternative level directory\n"
+ " -v, --verbose verbose mode\n",
+ program_name);
+ exit(0);
+ }
+ else if (strncmp(option, "-display", option_len) == 0)
+ {
+ if (option_arg == NULL)
+ fatal_option_requires_argument(option_str);
+
+ display_name = option_arg;
+ if (option_arg == next_option)
+ options_left++;
+
+ printf("--display == '%s'\n", display_name);
+ }
+ else if (strncmp(option, "-levels", option_len) == 0)
+ {
+ if (option_arg == NULL)
+ fatal_option_requires_argument(option_str);
+
+ level_directory = option_arg;
+ if (option_arg == next_option)
+ options_left++;
+
+ printf("--levels == '%s'\n", level_directory);
+ }
+ else if (strncmp(option, "-verbose", option_len) == 0)
+ {
+ printf("--verbose\n");
+
+ verbose = TRUE;
+ }
+ else if (*option == '-')
+ fatal_unrecognized_option(option_str);
+ else if (server_host == NULL)
+ {
+ server_host = *options_left;
+
+ printf("server.name == '%s'\n", server_host);
+ }
+ else if (server_port == 0)
+ {
+ server_port = atoi(*options_left);
+ if (server_port < 1024)
+ fatal("Bad port number");
+
+ printf("port == %d\n", server_port);
+ }
+ else
+ fatal_too_many_arguments();
+
+ options_left++;
+ }
+
+ /*
+ printf("All went fine -- exiting\n");
+ exit(0);
+ */
+
+ /*
if (argc>1)
level_directory = argv[1];
+ */
+
+
+ /*
+ if (argc > 1)
+ server_host = argv[1];
+
+ if (argc > 2)
+ server_port = atoi(argv[2]);
+ */
+
#ifdef MSDOS
_fmode = O_BINARY;