[TOC]
libtcod is a free, fast, portable and uncomplicated API for roguelike developers providing an advanced true color console, input, and lots of other utilities frequently used in roguelikes.
If you want to get a quick overview of the features that libtcod provides, check out the Features page.
If you want to get a quick overview of games which have used libtcod, check out the Projects page.
libtcod is also well known for it's easy to follow tutorial, which many people have used to get started developing a roguelike. Follow the relevant links the tutorial gives, and it will point you to the right locations.
Currently, only Windows binaries are available from the Bitbucket download section for this project. If you are programming in C or C++, various sample projects are included within the source code which can be used as examples of various features. For those who wish to program in Python which is the only scripting language support that has been contributed so far, the basics are described in part 1 of the tutorial.
Two builds are currently provided for each release:
- 32 bit (Win32, SDL2 only) binaries also including source code.
- 64 bit (x64, SDL2 only) binaries also including source code.
Warning: If you download these builds, run samples.exe
as your very first action. If you are unable to and get an error about vcruntime140.dll
being missing, you need to install the two Visual Studio 2015 runtimes. Make sure you install the 32-bit runtime. And make sure you also install the 64-bit runtime. Then run samples.exe
again, and it should now work. Whether you plan to develop in C, C++, Python or some other language, this is required.
These are the recommended places to obtain the source code from:
- The latest source code release snapshot on the downloads page.
- Clone the repository with Mercurial and checkout the tag for the latest version in the
default
branch. - Clone the repository and checkout the bleeding edge from the tip in the default branch.
All compilation methods, whether Windows or autotools, are located within the build/
subdirectory.
Windows users can either run the top-level 'build.bat' script, or locate and open the provided solution directly using Visual Studio. The solution is currently for Visual Studio 2015, and the free community edition is highly recommended.
For all other platforms, you need to make use of the autotools
support. This is a standard approach used for decades, and if you are not familiar with it, you can Bing (or Google) the topic and learn more. Explicit instructions for Linux, which should be relevant, are provided here.
SDL2 is the latest version of SDL. Release 2.0.5 (changeset 007dfe83abf8) of SDL2, is currently used for the official Windows builds. If you choose to use a different version of SDL2, please be sure to mention it in any issues you create. And if you are using the bleeding edge (the latest unreleased/untagged changes), please rule out that this is the cause of any problems you encounter, before creating issues.
libtcod comes with a sample application, implementations of which are provided in each of C (samples_c.c), C++ (samples_cpp.cpp) and Python (samples_py.py). This provides a decent overview of the basic features, in an interactive fashion. Each should be identical for the most part, so if you are using Windows, downloading the precompiled binaries and running the included samples.exe
which is compiled from the C source code, should be representative of the other versions.
The popular Python tutorial is a good way to both build up a simple roguelike, and get familiar with the basics of libtcod.