217 lines
7.2 KiB
Ruby
217 lines
7.2 KiB
Ruby
|
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:
|
||
|
# * http://nethackwiki.com/wiki/Compiling#On_Mac_OS_X
|
||
|
# * http://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"
|
||
|
|
||
|
# 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 <memory.h>
|
||
|
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 <curses.h>
|
||
|
|
||
|
-#ifndef LINUX
|
||
|
+#if !defined(LINUX) && !defined(__APPLE__)
|
||
|
extern char *tparm();
|
||
|
#endif
|