How to compile
This page is a candidate for deletion. The given reason is: This stuff is so badly outdated, this just puts people on the wrong track. I suggest we remove all this, point to the github and forums. And keep any how to compile information off the wiki
This notice should remain for a minimum of 1 week after it was placed on the page. If discussion is still ongoing, it should remain until a consensus is reached, after which the page will either be deleted or this notice removed. If you disagree with its deletion, please discuss your reasons on this page or on its associated talk page, as applicable. Remember to check if anything links here and the page history before deleting. Administrators: delete this page Last edit by Soyweiser (talk · contrib) · Last edited on Tue, 23 Aug 2016 21:20:15 +0000 |
Note - Outdated
Please see [1] for much more up to date compilation instructions!
Windows
There are a few ways to run Cataclysm-DDA in Windows. The recommended way to compile cataclysm on windows is MinGW, as the Makefile is more likely to be updated than the CodeBlocks and VisualStudio project files. (Note: You can set up CodeBlocks to use the Makefile, instructions to do this may follow later)
Updated guide (incomplete but results in working executable)
Download MSYS Download and install experimental MinGW with new GCC version
In MSYS directory, go to etc subdirectory and create a file named fstab (no extension, all lowercaps). In mingw-w64 directory, find a subdirectory named mingw32. Copy its location to fstab and add " /mingw" (no quotes) to the end. fstab contents should look like that:
d:/mingw-w64/i686-4.9.1-win32-dwarf-rt_v3-rev0/mingw32 /mingw
Run msys.bat in MSYS directory. In MSYS terminal navigate to DDA's source directory and run "make NATIVE=win32 LOCALIZE=0". This will compile DDA with no tiles and no localization (those require additional libraries).
MinGW with MSYS
Outdated, please be patient as we clean this up.
First you need to download and install MinGW and MSYS.
In the installer, choose your preferred location (a path without spaces is recommended both for MinGW and CDDA).
All the other options can be left at their default.
Once installed, mingw-get-gui
will open, which will allow you to install and uninstall programs and libraries.
In "Basic Setup", mark mingw-developer-toolkit
, mingw32-base
and mingw32-gcc-g++
for installation by left-click the checkboxes.
Then install these components using "Installation -> Apply Changes".
http://i.imgur.com/XmuWAMA.png
Furthermore, we will need gettext and libintl. In "All Packages -> MinGW -> MinGW Autotools" ensure that mingw32-gettext and mingw32-libintl are installed.
Optionally, when compiling with TILES or LUA support, Cataclysm DDA will also need these libraries:
You can find a prepackaged version of these libraries here: http://46.102.243.119/public/CDDA-deps.zip Simply unzip this archive into your MinGW root directory.
Fixing the Makefile
The Makefile currently tries to produce a static build. This means that no .dll's are required to run the game. However, this doesn't work with the MinGW release of SDL_ttf and SDL_image, which ship with .dll's.
Open CDDA/Makefile in a text editor(e.g. notepad++) and look for the line "LDFLAGS += -static". Replace this line with the following and save the file: "LDFLAGS += -static-libgcc -static-libstdc++"
Compile
Once you have MinGW and all Cataclysm dependencies properly installed:
- Ensure you have downloaded the Cataclysm DDA source code.
- Navigate to
MinGW/msys/1.0/
and startmsys.bat
. - Add the MinGW toolchain to your
PATH
withexport PATH=$PATH:/c/MinGW/bin
. Replace/c/MinGW/
with the directory into which you installed MinGW (/c/
stands for driveC:
, so if it's inF:/foo/bar
, you'd use/f/foo/bar
). - Navigate to the CDDA source code directory using
cd /c/Users/blub/CDDA
, again, replace/c/Users/blub/CDDA
with the path where you extracted it. - Compile using
make TILES=1 NATIVE=win32 LOCALIZE=0
and unless there are problems, it should produce a CDDA binary for you. - Copy the .dll's in the "bin" directory in CDDA-deps.zip into your CDDA directory.
Cygwin
Cygwin is not currently compatible with SDL 1.2 and therefore is unable to do TILES builds.
Start off by downloading cygwin from the official site. Follow the download instructions on the site, and select all of the following packages when prompted to:
- make
- G++
- libncurses-dev
- libncursesw-dev
- libiconv
- libiconv2
- libintl
- gettext
- git
Compile
Once it's finished installing, run the program which should open a terminal window, from there, type:
# clone the repository git clone git://github.com/CleverRaven/Cataclysm-DDA.git # once downloaded, get into the source directory cd cataclysm-dda # start compiling (Where 'X' is a number equal to 1.5x the number of cores your computer has) make -j X # run the fresh executable ./cataclysm
Update
To update to the latest repository version, open the source directory and type:
# get into the source directory cd cataclysm-dda # update the source code to the lastest version git pull # purge unnecessary files make clean # recompile (Where 'X' is a number equal to 1.5x the number of cores your computer has) make -j X # run the fresh executable ./cataclysm
Code::Blocks
Outdated, please be patient as we clean this up.
- Download and install Code::Blocks, get the version with MinGW.
- Get the current git code using the steps discussed in the MinGW section above
- Load the codeblocks project.
- Press "build and run the active project" in the Code::blocks program.
Note: Sometimes Code::Blocks project file may be outdated, so check if all .cpp and .h files from the source folder are listed in your project.
For help building the tiles/SDL version, see these comments:
- Forum Post in Topic "Compiling SDL version"
- Forum Post in Topic "How do I Compile DDA with the Tilesets Working?"
Fighting with libintl_gettext errors
General advices include:
- go to http://ftp.gnome.org/pub/gnome/binaries/win32/dependencies/
- get the gettext-runtime and gettext-runtime-dev (the latest versions). Extract them to a folder somewhere.
- Point you library path to the \lib folder and your include path to the \include folder. For Code::Blocks right click on your project in the project tree and choose "Build options". Open "Linker" tab and add path to libintl.lib (with the file!) from gettext-runtime-dev.
- Place the .dll files into the same directory you create your Cataclysm.exe file in. You'll need intl.dll (not found in gettext-runtime-dev, download separately) and libintl.dll (found in gettext-runtime-dev).
Visual C++ 2010
Outdated, please be patient as we clean this up.
- If you don't already have Visual C++ 2010, download and install the Express edition.
- Get the current git code using the steps discussed in the MinGW section above.
- Browse to the "msvc100" directory and open Cataclysm.sln.
- Select the "Release" configuration and choose your architecture ("Win32" or "x64").
- Press the "Build Solution" toolbar button (or press F7).
- Browse to the appropriate output directory and copy Cataclysm.exe into the base directory.
Linux
Outdated, please see [2] Compilation instructions differ by distribution.
Get your friendly command-line terminal pumped and ready, grab some curdled popcorn, and pull up a mouldering chair.
Gentoo
Gentoo offers built-in support for installing Cataclysm: DDA straight from GitHub sources. Which is rather nice, really.
Installation
Run the following commands at your favorite command-line terminal as the superuser (i.e., root):
- Install layman, if not already.
- Add overlay raiagent.
- Unmask cataclysm-dda by adding the following line to /etc/portage/package.accept_keywords.
- Enable USE flags "ncurses" (installing an ncurses-based terminal interface) and/or "sdl" (installing an SDL-based tiles interface) by adding a line like the following to /etc/portage/package.use. (You probably want both as well as a Lua interpreter, so we default to that.)
- Emerge cataclysm-dda.
emerge layman
layman -a raiagent
>=games-roguelike/cataclysm-dda-0.4
games-roguelike/cataclysm-dda lua ncurses sdl
emerge cataclysm-dda
Assuming /usr/games/bin to be in your current ${PATH}, Cataclysm: DDA should now be runnable as either:
- cataclysm-dda-ncurses, assuming you enabled USE flag "ncurses" above.
- cataclysm-dda-sdl, assuming you enabled USE flag "sdl" above.
(A rehash may be required.)
raiagent also offers a live ebuild installing the most recent Cataclysm: DDA commit. Since such commits tend to be of "dubious stability," this ebuild is currently hard-masked with empty KEYWORDS. To unmask it, add the following line to /etc/portage/package.accept_keywords:
~games-roguelike/cataclysm-dda-9999 **
"Give 'em hell, kid."
Upgrading
- Move aside your old save/ subdirectory.
- Upgrade cataclysm-dda.
mv /usr/games/cataclysm-dda/save /tmp/
emerge cataclysm-dda
Since Cataclysm: DDA guarantees no backward compatibility with content saved by a prior version (e.g., characters, worlds, configuration files), failure to move aside your old save/ subdirectory often results in an STL exception on game startup resembling:
terminate called after throwing an instance of 'std::out_of_range' what(): basic_string::substr
Ubuntu
First, open the terminal. On Ubuntu, you can find it by typing 'Terminal' into the dash and.
In order to download the latest version of Cataclysm:DDA, we will need to install git. You'll probably need to type in your password.
sudo apt install git
Now to pull the source. You're likely in your "home" or "root" directory in the terminal. You can use ls to list the directories and cd to move into them. Once you are where you want the source to be, type:
git clone git://github.com/CleverRaven/Cataclysm-DDA.git
This'll make a directory called Cataclysm-DDA and pull the source into it. It might take a while.
Type cd Cataclysm-DDA to move into the directory.
ncurses (terminal)
To compile the terminal version you'll need to install some dependencies:
sudo apt install libncurses5-dev libncursesw5-dev g++
Now type make to compile it. If it fails, try make clean and retry make.
If it works, try running the game with ./cataclysm. If that also works, you're ready to mod.
Tiles (graphical)
To compile the graphical SDL version (for Ubuntu 14.04):
sudo apt install libsdl2-dev libsdl2-ttf-dev libsdl2-image-dev
(Ubuntu 12.04 "Precise Pangolin" uses libsdl-ttf-2.0-dev)
Compile with make TILES=1. To compile with improved performance, compile with make TILES=1 RELEASE=1.
Further activities
Lua scripting can be enabled by installing the dependency lua5.1-dev and adding LUA=1 to the make arguments.
Run the game with ./cataclysm-tiles. It should be mentioned that SDL version sometimes runs smoother and faster.
To update the game, move into the game directory and type "git pull". Afterwards, type make clean (which clears all object files and such) and make to build again. There, updated!
Mac
Mac is the least supported platform, due to almost nobody owning one. Still, it seems it's pretty much solid, some errors notwithstanding.
Fixing errors
You might get these errors when compiling:
error: no matching function for call to `player_activity::player_activity(player_activity)' note: candidates are: player_activity::player_activity(player_activity&)
This is due to non-const copy constructors (see this), which some C++ compilers just kludge for you with auto pointer magic... and others don't (like recent XCode GCC).
To fix this change:
pldata.h:113 player_activity(player_activity ©)
to:
pldata.h:113 player_activity(player_activity const ©)
You'll also need to change:
npc.h:197 npc_opinion(npc_opinion ©)
to:
npc.h:197 npc_opinion(npc_opinion const ©)
And, finally, force a 32-bit executable:
Makefile:8 OTHERS = -O3 -m32
Compile
Mac OS doesn't have apt-get, so you'll need Fink or MacPorts to install libraries (This guide will be using MacPorts). Other than that, the setup is pretty much the same as with Linux. Note: that this guide currently only supports non-SDL, non-tiles builds.
Now, let's install the dependencies we'll need. It may ask you to type in your password or Y to confirm. Do it and continue.
sudo port install ncurses git gettext
Download and install https://code.google.com/p/rudix/downloads/detail?name=libintl-0.18.1.1-4.pkg
This is it. Now to pull the source. You're likely in your "home" or "root" directory in the terminal. You can use "ls" to list the directories and "cd" to move into them. Once you are where you want the source to be, type:
git clone git://github.com/CleverRaven/Cataclysm-DDA.git
This'll make a directory called Cataclysm-DDA and pull the source into it. It might take a while.
Type:
cd Cataclysm-DDA
to move into the directory. Now type:
make NATIVE=osx
to compile it. OS 10.10, Yosemite, seems to require
make NATIVE=osx OSX_MIN=10.7 CLANG=1
or
make NATIVE=osx OSX_MIN=10.7 CLANG=1 MACPORTS=1
if you're using Macports to compile it. If it fails, try:
make clean
If it works, try running the game with:
./cataclysm
If that also works, you're ready to mod.
Note: Mac OS's terminal is normally set to 8-bit colors. Set it to 16-bit colors to get the colors needed for Cataclysm. An alternative may be to check the "display bright colours for bold text" on in terminal preferences / text tab.
To update the game, move into the game directory and write:
git pull
Afterwards, type:
make clean
Then:
make NATIVE=osx
There, updated!
Monospace fonts
While you can use fonts of any proportion to play the game, non-monospace fonts tend to distort the visual representation of the game world by stretching buildings, vehicles, creatures, etc vertically.
To avoid that you should use fonts specified as monospace instead. Here are some of them:
Changing the font
Windows
To change the font used by the game you'll need to edit the FONTDATA file, located in the Data directory. You can edit that file by using any text editor (Windows Notepad, Notepad++, etc). Or you could rename it and give it a .txt extension or open it a build in text editor. Don't forget to remove the .txt extension after editing it.
It'll display something like this:
Topaz-8 16 16
Change the first line to the name of the font you want to use. The other two lines are the size of the font. Cataclysm will stretch some fonts to make them bigger, where as with other fonts it will just increase the spacing between tiles. The numbers represent the size of the font in pixels, they do not have to be equal.
You'll have to experiment with different font and viewport sizes, by accessing the game's options menu (from the main menu scree or through ?, 2 while playing), until you get the game properly displayed at the size you want.
You may be able to try using fixedsys as it ships with cataclysm. If it does not work you will have to put the fixedsys.ttf font from your cataclysm\data\font folder into your windows font folder.
One more thing to mention, in order to use a font from your windows font folder with cataclysm you have to type the "name" of the font into FONTDATA. In order to find the font name you have to open the font, and look at the very top line of the file. Write down the name exactly as it appears except leave out any bits in ()'s. For example with the fixedsys font. You would type "Fixedsys TTF V5.00c" and NOT "Fixedsys TTF V5.00c (True Type)"
Linux and Mac
You can change the font and size in most terminals. Depending on the terminal you can do that by right clicking and selecting Options or a similar option, or by editing its config files.
If your terminal allows creating several profiles it'd be a good idea creating one for the only purpose of playing.
|