X-Git-Url: https://git.artsoft.org/?a=blobdiff_plain;f=src%2Fmain.c;h=66f85d38f8505d7c5405c917ec9e27cf2be0cdf4;hb=29014045f4de045f8452fdf7ab32622c94b37eef;hp=4f178700577979f0f3bc013c16d2954cb02c9a52;hpb=19e3dfa321d39a822bda8fa489fb76f25f9f9165;p=rocksndiamonds.git diff --git a/src/main.c b/src/main.c index 4f178700..66f85d38 100644 --- a/src/main.c +++ b/src/main.c @@ -1,29 +1,35 @@ /*********************************************************** * 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 +#endif Display *display; +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]; @@ -39,7 +45,13 @@ int joystick_device = 0; 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; @@ -72,6 +84,7 @@ int MovDir[MAX_LEV_FIELDX][MAX_LEV_FIELDY]; 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]; @@ -82,21 +95,22 @@ long Elementeigenschaften[MAX_ELEMENTS]; int level_nr, leveldir_nr, num_leveldirs; int lev_fieldx,lev_fieldy, scroll_x,scroll_y; -int FX = SX, FY = SY, ScreenMovPos = 0, ScrollSteps = TILEX/4; +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; @@ -179,14 +193,170 @@ int background_loop[] = }; 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; +#endif OpenAll(argc,argv); EventLoop();