Hengband Application for macOS

Binaries | English screen shot | Japanese screen shot | Feedback | Source code | 3.0.0 Changes | 2.2.1.7 Changes | 1.6.2 Changes

Source Code

If you want to compile the code yourself or examine the changes I made, you can get one of the packaged source code archives, hengband-3.0.1-Beta6.tar.gz, hengband-2.2.1.7i.tar.gz, or hengband-1.6.2e.tar.gz from https://github.com/backwardsEric/hengband/releases . The first of those is based on Hengband's current development branch. The second is based on Hengband's development branch from 2019. The third is based on Hengband's last stable release. Alternately, you can clone the git repository, https://github.com/backwardsEric/hengband.git . Within the git repository, the macos-develop branch tracks Hengband's most recent upstream development (available as the develop branch). The macos-3-0-0 branch corresponds to the releases made for macOS with the 3.0.0 development code. The macos-2-2-1 branch corresponds to the version based on 2.2.1.7. The macos-1-6-2 branch corresponds to the version based on 1.6.2.

If you cloned the git repository and want to compile the code, you'll first need to create the configure script and some of the files it uses. If you're using the master, develop, or macos-develop branches, you'll need to set up the submodule that's used to handle the lib/xtra directory before creating the configure script. To do that, run this in the top-level directory of the directory tree with the source code (also note that because the macos-develop branch uses a different version of the submodule and the macos-2-2-1 and macos-1-6-2 branches do not use the submodule, switching to or from those branches or branches based on them can require updating the submodule or moving the existing lib/xtra out of the way):

  1. git submodule init
  2. git submodule update

Now run this in the top-level directory of the directory tree with the source code to create the configure script (you'll need to have autoconf and automake in the path; at least for macOS 11 or 12 it is recommended to use autoconf 2.69 since the version of m4, GNU M4 1.4.6, included with macOS doesn't work well with autoconf 2.71):

  1. ./bootstrap

To compile the changed code and generate an English version of the game which uses the Cocoa user interface for macOS, run these commands from the top-level directory of the directory tree with the source code:

  1. ./configure --disable-japanese --enable-cocoa
  2. make install

That will create the full application, hengband.app, in the top-level directory. You can move that wherever you want. If you want the curses interface or, if you have the X11 libraries installed, the X11 interface, do not specify --enable-cocoa when running configure. The curses or X11 interface will not use hengband.app. Instead you'll get an executable, hengband, in the directory where you ran configure and that executable will pull information from the lib subdirectory there. To get the Japanese version, do not specify --disable-japanese when running configure. Compilation of the Japanese version requires the utility, nkf, unless you are building the code based on Hengband 1.6.2. Source code for that utility is available from https://osdn.net/projects/nkf/.

To compile an English version that will run natively on either x86_64 or arm machines, you can use these commands from the top-level directory of the directory tree with the source code if the source code is prior to the move to C++ (2021 March 6th; 3.0.0 Alpha 10):

  1. env CFLAGS="-g -O2 -arch x86_64 -arch arm64" OBJCFLAGS="-g -O2 -arch x86_64 -arch arm64" LDFLAGS="-arch x86_64 -arch arm64" ./configure --disable-dependency-tracking --enable-cocoa --disable-japanese
  2. make install
For the C++-based code, these commands will work (needs source code newer than 2021 March 30th for the --disable-pch option to configure):
  1. env CFLAGS="-g -O2 -arch x86_64 -arch arm64" CXXFLAGS="-g -O2 -arch x86_64 -arch arm64" OBJCXXFLAGS="-g -O2 -arch x86_64 -arch arm64" LDFLAGS="-arch x86_64 -arch arm64" ./configure --disable-dependency-tracking --disable-pch --enable-cocoa --disable-japanese
  2. make install

For a Japanese version with a universal binary, the steps are much the same. The only difference is to omit --disable-japanese when running configure.

Eventually, the hope is that the changes made here will be incorporated into the standard version of Hengband and you can get both the source code and binaries from them.