Allow MICRO and WIN32 code paths to diverge
There's still a lot of overlap for 3.4.1, but not 100% any longer and it facilitates some improvements - Allow error save files on WIN32
This commit is contained in:
@@ -130,7 +130,7 @@ long FDECL(dlb_ftell, (DLB_P));
|
||||
#else
|
||||
#define WRTMODE "w+"
|
||||
#endif
|
||||
#if (defined(MICRO) && !defined(AMIGA)) || defined(THINK_C) || defined(__MWERKS__)
|
||||
#if (defined(MICRO) && !defined(AMIGA)) || defined(THINK_C) || defined(__MWERKS__) || defined(WIN32)
|
||||
# define RDBMODE "rb"
|
||||
# define WRBMODE "w+b"
|
||||
#else
|
||||
|
||||
@@ -1176,7 +1176,7 @@ E struct monst *FDECL(mk_mplayer, (struct permonst *,XCHAR_P,
|
||||
E void FDECL(create_mplayers, (int,BOOLEAN_P));
|
||||
E void FDECL(mplayer_talk, (struct monst *));
|
||||
|
||||
#ifdef MICRO
|
||||
#if defined(MICRO) || defined(WIN32)
|
||||
|
||||
/* ### msdos.c,os2.c,tos.c,winnt.c ### */
|
||||
|
||||
@@ -1226,7 +1226,7 @@ E int NDECL((*nt_kbhit));
|
||||
E void FDECL(Delay, (int));
|
||||
# endif /* WIN32 */
|
||||
|
||||
#endif /* MICRO */
|
||||
#endif /* MICRO || WIN32 */
|
||||
|
||||
/* ### mthrowu.c ### */
|
||||
|
||||
@@ -1366,15 +1366,15 @@ E int NDECL(dohistory);
|
||||
|
||||
/* ### pcmain.c ### */
|
||||
|
||||
#if defined(MICRO)
|
||||
#if defined(MICRO) || defined(WIN32)
|
||||
# ifdef CHDIR
|
||||
E void FDECL(chdirx, (char *,BOOLEAN_P));
|
||||
# endif /* CHDIR */
|
||||
#endif /* MICRO */
|
||||
#endif /* MICRO || WIN32 */
|
||||
|
||||
/* ### pcsys.c ### */
|
||||
|
||||
#ifdef MICRO
|
||||
#if defined(MICRO) || defined(WIN32)
|
||||
E void NDECL(flushout);
|
||||
E int NDECL(dosh);
|
||||
# ifdef MFLOPPY
|
||||
@@ -1390,11 +1390,11 @@ E void FDECL(getreturn, (const char *));
|
||||
E void VDECL(msmsg, (const char *,...));
|
||||
# endif
|
||||
E FILE *FDECL(fopenp, (const char *,const char *));
|
||||
#endif /* MICRO */
|
||||
#endif /* MICRO || WIN32 */
|
||||
|
||||
/* ### pctty.c ### */
|
||||
|
||||
#if defined(MICRO)
|
||||
#if defined(MICRO) || defined(WIN32)
|
||||
E void NDECL(gettty);
|
||||
E void FDECL(settty, (const char *));
|
||||
E void NDECL(setftty);
|
||||
@@ -1402,7 +1402,7 @@ E void VDECL(error, (const char *,...));
|
||||
#if defined(TIMED_DELAY) && defined(_MSC_VER)
|
||||
E void FDECL(msleep, (unsigned));
|
||||
#endif
|
||||
#endif /* MICRO */
|
||||
#endif /* MICRO || WIN32 */
|
||||
|
||||
/* ### pcunix.c ### */
|
||||
|
||||
|
||||
@@ -225,7 +225,7 @@ typedef xchar boolean; /* 0 or 1 */
|
||||
#endif
|
||||
|
||||
#if defined(MICRO)
|
||||
#if !defined(AMIGA) && !defined(TOS) && !defined(OS2_HPFS) && !defined(WIN32)
|
||||
#if !defined(AMIGA) && !defined(TOS) && !defined(OS2_HPFS)
|
||||
#define SHORT_FILENAMES /* filenames are 8.3 */
|
||||
#endif
|
||||
#endif
|
||||
|
||||
@@ -18,9 +18,7 @@
|
||||
|
||||
#define PC_LOCKING /* Prevent overwrites of aborted or in-progress games */
|
||||
/* without first receiving confirmation. */
|
||||
#define NOCWD_ASSUMPTIONS /* Allow paths to be specified for HACKDIR,
|
||||
LEVELDIR, SAVEDIR, BONESDIR, DATADIR,
|
||||
SCOREDIR, LOCKDIR, and CONFIGDIR */
|
||||
|
||||
|
||||
/*
|
||||
* -----------------------------------------------------------------
|
||||
@@ -29,7 +27,15 @@
|
||||
*/
|
||||
/* #define SHORT_FILENAMES /* All NT filesystems support long names now */
|
||||
|
||||
#define MICRO /* always define this! */
|
||||
#ifdef MICRO
|
||||
#undef MICRO /* never define this! */
|
||||
#endif
|
||||
|
||||
#define NOCWD_ASSUMPTIONS /* Always define this. There are assumptions that
|
||||
it is defined for WIN32.
|
||||
Allow paths to be specified for HACKDIR,
|
||||
LEVELDIR, SAVEDIR, BONESDIR, DATADIR,
|
||||
SCOREDIR, LOCKDIR, and CONFIGDIR */
|
||||
#define NO_TERMS
|
||||
#define ASCIIGRAPH
|
||||
|
||||
@@ -104,11 +110,22 @@
|
||||
#define FILENAME_CMP stricmp /* case insensitive */
|
||||
#endif
|
||||
|
||||
#ifdef MICRO
|
||||
# ifndef MICRO_H
|
||||
#include "micro.h" /* contains necessary externs for [os_name].c */
|
||||
# endif
|
||||
#if 0
|
||||
#ifndef C
|
||||
#define C(c) (0x1f & (c))
|
||||
#endif
|
||||
#ifndef M
|
||||
#define M(c) (0x80 | (c))
|
||||
#endif
|
||||
extern char levels[], bones[], permbones[],
|
||||
#endif /* 0 */
|
||||
|
||||
/* this was part of the MICRO stuff in the past */
|
||||
extern const char *alllevels, *allbones;
|
||||
extern char hackdir[];
|
||||
#define ABORT C('a')
|
||||
#define getuid() 1
|
||||
#define getlogin() ((char *)0)
|
||||
|
||||
#include <fcntl.h>
|
||||
#ifndef __BORLANDC__
|
||||
|
||||
@@ -19,7 +19,7 @@ STATIC_DCL void NDECL(do_positionbar);
|
||||
void
|
||||
moveloop()
|
||||
{
|
||||
#ifdef MICRO
|
||||
#if defined(MICRO) || defined(WIN32)
|
||||
char ch;
|
||||
int abort_lev;
|
||||
#endif
|
||||
@@ -315,7 +315,7 @@ moveloop()
|
||||
flags.move = 1;
|
||||
|
||||
if(multi >= 0 && occupation) {
|
||||
#ifdef MICRO
|
||||
#if defined(MICRO) || defined(WIN32)
|
||||
abort_lev = 0;
|
||||
if (kbhit()) {
|
||||
if ((ch = Getchar()) == ABORT)
|
||||
@@ -331,14 +331,14 @@ moveloop()
|
||||
#endif
|
||||
occupation = 0;
|
||||
if(
|
||||
#ifdef MICRO
|
||||
#if defined(MICRO) || defined(WIN32)
|
||||
abort_lev ||
|
||||
#endif
|
||||
monster_nearby()) {
|
||||
stop_occupation();
|
||||
reset_eat();
|
||||
}
|
||||
#ifdef MICRO
|
||||
#if defined(MICRO) || defined(WIN32)
|
||||
if (!(++occtime % 7))
|
||||
display_nhwindow(WIN_MAP, FALSE);
|
||||
#endif
|
||||
|
||||
@@ -56,7 +56,7 @@ register unsigned int lth;
|
||||
|
||||
#if defined(MONITOR_HEAP) || defined(WIZARD)
|
||||
|
||||
# ifdef MICRO
|
||||
# if defined(MICRO) || defined(WIN32)
|
||||
/* we actually want to know which systems have an ANSI run-time library
|
||||
* to know which support the new %p format for printing pointers.
|
||||
* due to the presence of things like gcc, NHSTDC is not a good test.
|
||||
|
||||
@@ -77,10 +77,12 @@ NEARDATA long yn_number = 0L;
|
||||
|
||||
const char disclosure_options[] = "iavgc";
|
||||
|
||||
#ifdef MICRO
|
||||
#if defined(MICRO) || defined(WIN32)
|
||||
char hackdir[PATHLEN]; /* where rumors, help, record are */
|
||||
# ifdef MICRO
|
||||
char levels[PATHLEN]; /* where levels are */
|
||||
#endif /* MICRO */
|
||||
# endif
|
||||
#endif /* MICRO || WIN32 */
|
||||
|
||||
|
||||
#ifdef MFLOPPY
|
||||
|
||||
20
src/end.c
20
src/end.c
@@ -240,6 +240,10 @@ register struct monst *mtmp;
|
||||
return;
|
||||
}
|
||||
|
||||
#if defined(WIN32)
|
||||
#define NOTIFY_NETHACK_BUGS
|
||||
#endif
|
||||
|
||||
/*VARARGS1*/
|
||||
void
|
||||
panic VA_DECL(const char *, str)
|
||||
@@ -260,15 +264,25 @@ panic VA_DECL(const char *, str)
|
||||
"Program initialization has failed." :
|
||||
"Suddenly, the dungeon collapses.");
|
||||
#if defined(WIZARD) && !defined(MICRO)
|
||||
# if defined(NOTIFY_NETHACK_BUGS)
|
||||
if (!wizard)
|
||||
raw_printf("Report error to \"%s\".\n%s.\n",
|
||||
"nethack-bugs@nethack.org",
|
||||
!program_state.something_worth_saving ? "" :
|
||||
"An error save file will be created.\n");
|
||||
else if (program_state.something_worth_saving)
|
||||
raw_print("\nAn error save file will be created.\n");
|
||||
# else
|
||||
if (!wizard)
|
||||
raw_printf("Report error to \"%s\"%s.",
|
||||
# ifdef WIZARD_NAME /*(KR1ED)*/
|
||||
# ifdef WIZARD_NAME /*(KR1ED)*/
|
||||
WIZARD_NAME,
|
||||
# else
|
||||
# else
|
||||
WIZARD,
|
||||
# endif
|
||||
# endif
|
||||
!program_state.something_worth_saving ? "" :
|
||||
" and it may be possible to rebuild.");
|
||||
# endif
|
||||
if (program_state.something_worth_saving) {
|
||||
set_error_savefile();
|
||||
(void) dosave0();
|
||||
|
||||
24
src/files.c
24
src/files.c
@@ -238,7 +238,7 @@ int lev;
|
||||
set_levelfile_name(lock, lev);
|
||||
fq_lock = fqname(lock, LEVELPREFIX, 0);
|
||||
|
||||
#if defined(MICRO)
|
||||
#if defined(MICRO) || defined(WIN32)
|
||||
/* Use O_TRUNC to force the file to be shortened if it already
|
||||
* exists and is currently longer.
|
||||
*/
|
||||
@@ -249,7 +249,7 @@ int lev;
|
||||
# else
|
||||
fd = creat(fq_lock, FCMASK);
|
||||
# endif
|
||||
#endif /* MICRO */
|
||||
#endif /* MICRO || WIN32 */
|
||||
|
||||
if (fd >= 0)
|
||||
level_info[lev].flags |= LFILE_EXISTS;
|
||||
@@ -377,7 +377,7 @@ char **bonesid;
|
||||
file = set_bonestemp_name();
|
||||
file = fqname(file, BONESPREFIX, 0);
|
||||
|
||||
#ifdef MICRO
|
||||
#if defined(MICRO) || defined(WIN32)
|
||||
/* Use O_TRUNC to force the file to be shortened if it already
|
||||
* exists and is currently longer.
|
||||
*/
|
||||
@@ -399,7 +399,7 @@ char **bonesid;
|
||||
*/
|
||||
(void) chmod(file, FCMASK | 007); /* allow other users full access */
|
||||
# endif /* VMS && !SECURE */
|
||||
#endif /* MICRO */
|
||||
#endif /* MICRO || WIN32*/
|
||||
|
||||
return fd;
|
||||
}
|
||||
@@ -499,7 +499,7 @@ set_savefile_name()
|
||||
regularize(SAVEF+7);
|
||||
Strcat(SAVEF, ";1");
|
||||
#else
|
||||
# if defined(MICRO) && !defined(WIN32)
|
||||
# if defined(MICRO)
|
||||
Strcpy(SAVEF, SAVEP);
|
||||
# ifdef AMIGA
|
||||
strncat(SAVEF, bbs_id, PATHLEN);
|
||||
@@ -566,7 +566,7 @@ create_savefile()
|
||||
int fd;
|
||||
|
||||
fq_save = fqname(SAVEF, SAVEPREFIX, 0);
|
||||
#ifdef MICRO
|
||||
#if defined(MICRO) || defined(WIN32)
|
||||
fd = open(fq_save, O_WRONLY | O_BINARY | O_CREAT | O_TRUNC, FCMASK);
|
||||
#else
|
||||
# ifdef MAC
|
||||
@@ -1112,7 +1112,7 @@ const char *filename;
|
||||
}
|
||||
}
|
||||
|
||||
#if defined(MICRO) || defined(MAC) || defined(__BEOS__)
|
||||
#if defined(MICRO) || defined(MAC) || defined(__BEOS__) || defined(WIN32)
|
||||
if ((fp = fopenp(fqname(configfile, CONFIGPREFIX, 0), "r"))
|
||||
!= (FILE *)0)
|
||||
return(fp);
|
||||
@@ -1538,7 +1538,7 @@ const char *filename;
|
||||
#define tmp_levels (char *)0
|
||||
#define tmp_ramdisk (char *)0
|
||||
|
||||
#ifdef MICRO
|
||||
#if defined(MICRO) || defined(WIN32)
|
||||
#undef tmp_levels
|
||||
char tmp_levels[PATHLEN];
|
||||
# ifdef MFLOPPY
|
||||
@@ -1553,7 +1553,7 @@ const char *filename;
|
||||
|
||||
if (!(fp = fopen_config_file(filename))) return;
|
||||
|
||||
#ifdef MICRO
|
||||
#if defined(MICRO) || defined(WIN32)
|
||||
# ifdef MFLOPPY
|
||||
# ifndef AMIGA
|
||||
tmp_ramdisk[0] = 0;
|
||||
@@ -1735,7 +1735,7 @@ const char *dir;
|
||||
wait_synch();
|
||||
}
|
||||
#endif /* !UNIX && !VMS */
|
||||
#ifdef MICRO
|
||||
#if defined(MICRO) || defined(WIN32)
|
||||
char tmp[PATHLEN];
|
||||
|
||||
# ifdef OS2_CODEVIEW /* explicit path on opening for OS/2 */
|
||||
@@ -1768,7 +1768,7 @@ const char *dir;
|
||||
(void) close(fd);
|
||||
} else /* open succeeded */
|
||||
(void) close(fd);
|
||||
#else /* MICRO */
|
||||
#else /* MICRO || WIN32*/
|
||||
|
||||
# ifdef MAC
|
||||
/* Create the "record" file, if necessary */
|
||||
@@ -1777,7 +1777,7 @@ const char *dir;
|
||||
if (fd != -1) macclose (fd);
|
||||
# endif /* MAC */
|
||||
|
||||
#endif /* MICRO */
|
||||
#endif /* MICRO || WIN32*/
|
||||
}
|
||||
|
||||
/* ---------- END SCOREBOARD CREATION ----------- */
|
||||
|
||||
@@ -62,7 +62,7 @@ static struct Bool_Opt
|
||||
#else
|
||||
{"checkspace", (boolean *)0, FALSE, SET_IN_FILE},
|
||||
#endif
|
||||
# ifdef MICRO
|
||||
# if defined(MICRO) || defined(WIN32)
|
||||
{"color", &iflags.wc_color,TRUE, SET_IN_GAME}, /*WC*/
|
||||
# else /* systems that support multiple terminals, many monochrome */
|
||||
{"color", &iflags.wc_color, FALSE, SET_IN_GAME}, /*WC*/
|
||||
@@ -144,7 +144,7 @@ static struct Bool_Opt
|
||||
{"prayconfirm", &flags.prayconfirm, TRUE, SET_IN_GAME},
|
||||
{"preload_tiles", &iflags.wc_preload_tiles, TRUE, DISP_IN_GAME}, /*WC*/
|
||||
{"pushweapon", &flags.pushweapon, FALSE, SET_IN_GAME},
|
||||
#if defined(MICRO) && !defined(AMIGA) && !defined(MSWIN_GRAPHICS)
|
||||
#if defined(MICRO) && !defined(AMIGA)
|
||||
{"rawio", &iflags.rawio, FALSE, DISP_IN_GAME},
|
||||
#else
|
||||
{"rawio", (boolean *)0, FALSE, SET_IN_FILE},
|
||||
@@ -2198,7 +2198,7 @@ map_menu_cmd(ch)
|
||||
}
|
||||
|
||||
|
||||
#if defined(MICRO) || defined(MAC)
|
||||
#if defined(MICRO) || defined(MAC) || defined(WIN32)
|
||||
# define OPTIONS_HEADING "OPTIONS"
|
||||
#else
|
||||
# define OPTIONS_HEADING "NETHACKOPTIONS"
|
||||
|
||||
@@ -6,7 +6,7 @@
|
||||
#include "lev.h"
|
||||
#include "tcap.h" /* for TERMLIB and ASCIIGRAPH */
|
||||
|
||||
#ifdef MICRO
|
||||
#if defined(MICRO)
|
||||
extern int dotcnt; /* shared with save */
|
||||
extern int dotrow; /* shared with save */
|
||||
#endif
|
||||
|
||||
@@ -37,7 +37,7 @@ static long final_fpos;
|
||||
#define POINTSMIN 1 /* must be > 0 */
|
||||
#define ENTRYMAX 100 /* must be >= 10 */
|
||||
|
||||
#if !defined(MICRO) && !defined(MAC)
|
||||
#if !defined(MICRO) && !defined(MAC) && !defined(WIN32)
|
||||
#define PERS_IS_UID /* delete for PERSMAX per name; now per uid */
|
||||
#endif
|
||||
struct toptenentry {
|
||||
|
||||
@@ -56,7 +56,7 @@ STATIC_DCL boolean NDECL(comspec_exists);
|
||||
extern int GUILaunched; /* from nttty.c */
|
||||
#endif
|
||||
|
||||
#ifdef MICRO
|
||||
#if defined(MICRO) || defined(WIN32)
|
||||
|
||||
void
|
||||
flushout()
|
||||
@@ -528,25 +528,4 @@ static void msexit()
|
||||
#endif
|
||||
return;
|
||||
}
|
||||
#ifdef WIN32
|
||||
/*
|
||||
* This is a kludge. Just before the release of 3.3.0 the latest
|
||||
* version of a popular MAPI mail product was found to exhibit
|
||||
* a strange result where the current directory was changed out
|
||||
* from under NetHack resulting in a failure of all subsequent
|
||||
* file operations in NetHack. This routine is called prior
|
||||
* to all file open/renames/deletes in file.c.
|
||||
*
|
||||
* A more elegant solution will be sought after 3.3.0 is released.
|
||||
*/
|
||||
void dircheck()
|
||||
{
|
||||
char dirbuf[BUFSZ];
|
||||
dirbuf[0] = '\0';
|
||||
if (getcwd(dirbuf, sizeof dirbuf) != (char *)0)
|
||||
/* pline("%s,%s",dirbuf,hackdir); */
|
||||
if (strcmp(dirbuf,hackdir) != 0)
|
||||
chdir(hackdir); /* chdir, not chdirx */
|
||||
}
|
||||
#endif
|
||||
#endif /* MICRO || WIN32 || OS2 */
|
||||
|
||||
@@ -48,7 +48,7 @@ int fd;
|
||||
return(0);
|
||||
}
|
||||
# else
|
||||
# if defined(MICRO) && !defined(NO_FSTAT)
|
||||
# if (defined(MICRO) || defined(WIN32)) && !defined(NO_FSTAT)
|
||||
if(fstat(fd, &buf)) {
|
||||
if(moves > 1) pline("Cannot get status of saved level? ");
|
||||
else pline("Cannot get status of saved game");
|
||||
|
||||
@@ -47,7 +47,7 @@
|
||||
# define O_BINARY 0
|
||||
#endif
|
||||
|
||||
#ifdef MICRO
|
||||
#if defined(MICRO) || defined(WIN32)
|
||||
# define OMASK FCMASK
|
||||
#else
|
||||
# define OMASK 0644
|
||||
|
||||
@@ -703,7 +703,7 @@ static const char *build_opts[] = {
|
||||
#ifdef TERMINFO
|
||||
"terminal info library",
|
||||
#else
|
||||
# if defined(TERMLIB) || (!defined(MICRO) && defined(TTY_GRAPHICS))
|
||||
# if defined(TERMLIB) || ((!defined(MICRO) && !defined(WIN32)) && defined(TTY_GRAPHICS))
|
||||
"terminal capability library",
|
||||
# endif
|
||||
#endif
|
||||
|
||||
@@ -38,7 +38,7 @@ extern int NDECL(fclose_text_file);
|
||||
extern void NDECL(init_colormap);
|
||||
extern void NDECL(merge_colormap);
|
||||
|
||||
#if defined(MICRO)
|
||||
#if defined(MICRO) || defined(WIN32)
|
||||
#undef exit
|
||||
# if !defined(MSDOS) && !defined(WIN32)
|
||||
extern void FDECL(exit, (int));
|
||||
|
||||
@@ -13,7 +13,7 @@ const char * FDECL(tilename, (int, int));
|
||||
void NDECL(init_tilemap);
|
||||
void FDECL(process_substitutions, (FILE *));
|
||||
|
||||
#ifdef MICRO
|
||||
#if defined(MICRO) || defined(WIN32)
|
||||
#undef exit
|
||||
#if !defined(MSDOS) && !defined(WIN32)
|
||||
extern void FDECL(exit, (int));
|
||||
|
||||
Reference in New Issue
Block a user