require "etc" # Bugfixed and interface-patched Nethack. # # This formula is based on the Nethack formula, and includes the # patches from same. The original notes from the Nethack formula # follow: # - @jterk # # Nethack the way God intended it to be played: from a terminal. # This build script was created referencing: # * https://nethackwiki.com/wiki/Compiling#On_Mac_OS_X # * https://nethackwiki.com/wiki/Pkgsrc#patch-ac_.28system.h.29 # and copious hacking until things compiled. # # The patch applied incorporates the patch-ac above, the OS X # instructions from the Wiki, and whatever else needed to be # done. # - @adamv class Nethacked < Formula desc "Bugfixed and interface-patched Nethack" homepage "https://nethacked.github.io/" url "https://github.com/nethacked/nethacked/archive/1.0.tar.gz" sha256 "4e3065a7b652d5fc21577e0b7ac3a60513cd30f4ee81c7f11431a71185b609aa" bottle do sha256 "d2c880eb02b32bc6a976b16502f400a94b395375b5cd59e731fb209580e3ceee" => :sierra sha256 "dcbe9a404fb0215e35dc9d08e73595ba8dadad55e6ca898078a66ce04c9dc11b" => :el_capitan sha256 "08b24568c94b14271e5d1b2880a0a78e6eea5cbbabfb9519347b5be1d2cc0893" => :yosemite end # Don't remove save folder skip_clean "libexec/save" patch :DATA def install # Build everything in-order; no multi builds. ENV.deparallelize # Symlink makefiles system "sh", "sys/unix/setup.sh" inreplace "include/config.h", /^#\s*define HACKDIR.*$/, "#define HACKDIR \"#{libexec}\"" # Enable wizard mode for the current user wizard = Etc.getpwuid.name inreplace "include/config.h", /^#\s*define\s+WIZARD\s+"wizard"/, "#define WIZARD \"#{wizard}\"" inreplace "include/config.h", /^#\s*define\s+WIZARD_NAME\s+"wizard"/, "#define WIZARD_NAME \"#{wizard}\"" cd "dat" do # Make the data first, before we munge the CFLAGS system "make" %w[perm logfile].each do |f| touch f libexec.install f end # Stage the data libexec.install %w[help hh cmdhelp history opthelp wizhelp dungeon license data oracles options rumors quest.dat] libexec.install Dir["*.lev"] end # Make the game ENV.append_to_cflags "-I../include" cd "src" do system "make" end bin.install "src/nethacked" (libexec+"save").mkpath # These need to be group-writable in multi-user situations chmod "g+w", libexec chmod "g+w", libexec+"save" end end __END__ diff --git a/include/system.h b/include/system.h index a4efff9..cfe96f1 100644 --- a/include/system.h +++ b/include/system.h @@ -79,10 +79,10 @@ typedef long off_t; # if !defined(__SC__) && !defined(LINUX) E long NDECL(random); # endif -# if (!defined(SUNOS4) && !defined(bsdi) && !defined(__FreeBSD__)) || defined(RANDOM) +# if (!defined(SUNOS4) && !defined(bsdi) && !defined(__NetBSD__) && !defined(__FreeBSD__) && !defined(__DragonFly__) && !defined(__APPLE__)) || defined(RANDOM) E void FDECL(srandom, (unsigned int)); # else -# if !defined(bsdi) && !defined(__FreeBSD__) +# if !defined(bsdi) && !defined(__NetBSD__) && !defined(__FreeBSD__) && !defined(__DragonFly__) && !defined(__APPLE__) E int FDECL(srandom, (unsigned int)); # endif # endif @@ -132,7 +132,7 @@ E void FDECL(perror, (const char *)); E void FDECL(qsort, (genericptr_t,size_t,size_t, int(*)(const genericptr,const genericptr))); #else -# if defined(BSD) || defined(ULTRIX) +# if defined(BSD) || defined(ULTRIX) && !defined(__NetBSD__) E int qsort(); # else # if !defined(LATTICE) && !defined(AZTEC_50) @@ -421,7 +421,7 @@ E size_t FDECL(strlen, (const char *)); # ifdef HPUX E unsigned int FDECL(strlen, (char *)); # else -# if !(defined(ULTRIX_PROTO) && defined(__GNUC__)) +# if !(defined(ULTRIX_PROTO) && defined(__GNUC__)) && !defined(__NetBSD__) E int FDECL(strlen, (const char *)); # endif # endif /* HPUX */ @@ -476,9 +476,9 @@ E char *sprintf(); # if !defined(SVR4) && !defined(apollo) # if !(defined(ULTRIX_PROTO) && defined(__GNUC__)) # if !(defined(SUNOS4) && defined(__STDC__)) /* Solaris unbundled cc (acc) */ -E int FDECL(vsprintf, (char *, const char *, va_list)); -E int FDECL(vfprintf, (FILE *, const char *, va_list)); -E int FDECL(vprintf, (const char *, va_list)); +// E int FDECL(vsprintf, (char *, const char *, va_list)); +// E int FDECL(vfprintf, (FILE *, const char *, va_list)); +// E int FDECL(vprintf, (const char *, va_list)); # endif # endif # endif @@ -521,7 +521,7 @@ E struct tm *FDECL(localtime, (const time_t *)); # endif # endif -# if defined(ULTRIX) || (defined(BSD) && defined(POSIX_TYPES)) || defined(SYSV) || defined(MICRO) || defined(VMS) || defined(MAC) || (defined(HPUX) && defined(_POSIX_SOURCE)) +# if defined(ULTRIX) || (defined(BSD) && defined(POSIX_TYPES)) || defined(SYSV) || defined(MICRO) || defined(VMS) || defined(MAC) || (defined(HPUX) && defined(_POSIX_SOURCE)) || defined(__NetBSD__) E time_t FDECL(time, (time_t *)); # else E long FDECL(time, (time_t *)); diff --git a/include/unixconf.h b/include/unixconf.h index fe1b006..3a195a6 100644 --- a/include/unixconf.h +++ b/include/unixconf.h @@ -19,20 +19,20 @@ */ /* define exactly one of the following four choices */ -/* #define BSD 1 */ /* define for 4.n/Free/Open/Net BSD */ +#define BSD 1 /* define for 4.n/Free/Open/Net BSD */ /* also for relatives like SunOS 4.x, DG/UX, and */ /* older versions of Linux */ /* #define ULTRIX */ /* define for Ultrix v3.0 or higher (but not lower) */ /* Use BSD for < v3.0 */ /* "ULTRIX" not to be confused with "ultrix" */ -#define SYSV /* define for System V, Solaris 2.x, newer versions */ +/* #define SYSV */ /* define for System V, Solaris 2.x, newer versions */ /* of Linux */ /* #define HPUX */ /* Hewlett-Packard's Unix, version 6.5 or higher */ /* use SYSV for < v6.5 */ /* define any of the following that are appropriate */ -#define SVR4 /* use in addition to SYSV for System V Release 4 */ +/* #define SVR4 */ /* use in addition to SYSV for System V Release 4 */ /* including Solaris 2+ */ #define NETWORK /* if running on a networked system */ /* e.g. Suns sharing a playground through NFS */ @@ -285,8 +285,8 @@ #if defined(BSD) || defined(ULTRIX) # if !defined(DGUX) && !defined(SUNOS4) -#define memcpy(d, s, n) bcopy(s, d, n) -#define memcmp(s1, s2, n) bcmp(s2, s1, n) +// #define memcpy(d, s, n) bcopy(s, d, n) +// #define memcmp(s1, s2, n) bcmp(s2, s1, n) # endif # ifdef SUNOS4 #include diff --git a/sys/unix/Makefile.src b/sys/unix/Makefile.src index 29ad99a..7842af2 100644 --- a/sys/unix/Makefile.src +++ b/sys/unix/Makefile.src @@ -151,8 +151,8 @@ GNOMEINC=-I/usr/lib/glib/include -I/usr/lib/gnome-libs/include -I../win/gnome # flags for debugging: # CFLAGS = -g -I../include -CFLAGS = -O -I../include -LFLAGS = +#CFLAGS = -O -I../include +#LFLAGS = # The Qt and Be window systems are written in C++, while the rest of # NetHack is standard C. If using Qt, uncomment the LINK line here to get @@ -230,8 +230,8 @@ WINOBJ = $(WINTTYOBJ) # WINTTYLIB = -ltermcap # WINTTYLIB = -lcurses # WINTTYLIB = -lcurses16 -# WINTTYLIB = -lncurses -WINTTYLIB = -ltermlib +WINTTYLIB = -lncurses +#WINTTYLIB = -ltermlib # # libraries for X11 # If USE_XPM is defined in config.h, you will also need -lXpm here. diff --git a/win/tty/termcap.c b/win/tty/termcap.c index 706e203..dadc9a9 100644 --- a/win/tty/termcap.c +++ b/win/tty/termcap.c @@ -835,7 +835,7 @@ cl_eos() /* free after Robert Viduya */ #include -#ifndef LINUX +#if !defined(LINUX) && !defined(__APPLE__) extern char *tparm(); #endif