1
0
mirror of https://github.com/zenorogue/hyperrogue.git synced 2025-10-26 03:17:39 +00:00
Arthur O'Dwyer e59d22e399 Silence some pedantic format warnings from Clang.
rogueviz/rogueviz.cpp: In function ‘hr::color_t rogueviz::parse1(const string&)’:
    rogueviz/rogueviz.cpp:76:75: error: format ‘%x’ expects argument
    of type ‘unsigned int*’, but argument 3 has type ‘int*’ [-Werror=format=]
         sscanf(s.c_str(), "R%x,%x,%x,%d,%d", &mh, &minh, &alpha, &step, &start);
                                                                               ^

I believe these three variables should have been `color_t` all along.
I think this fix doesn't change any of the arithmetic, but I could be wrong.
2020-03-23 14:39:30 -04:00
2020-03-07 12:19:25 +01:00
2015-08-22 13:43:16 +02:00
2019-10-03 20:08:07 +02:00
2017-10-10 14:59:19 +02:00
2020-03-22 11:43:31 +01:00
2016-04-03 16:31:21 +02:00
2020-03-07 04:47:10 +01:00
2019-12-06 11:45:19 +01:00
2020-03-11 10:06:12 +01:00
2020-03-07 04:47:10 +01:00
2020-01-18 16:03:32 +01:00
2020-03-22 12:03:09 +01:00
2020-03-07 04:47:11 +01:00
2020-03-11 09:52:54 +01:00
2015-08-08 15:57:52 +02:00
2019-09-12 23:35:04 +02:00
2020-01-28 20:21:23 +01:00
2020-03-08 00:33:18 +01:00
2019-09-12 22:43:00 +02:00
2020-03-07 04:47:10 +01:00
2020-03-08 00:01:40 +01:00
2019-11-02 15:45:42 +01:00
2020-03-07 23:44:00 +01:00
2020-03-07 04:47:10 +01:00
2020-01-18 16:03:32 +01:00
2020-01-16 17:13:57 +01:00
2015-08-08 15:57:52 +02:00
2019-09-12 22:50:16 +02:00
2020-03-07 04:47:10 +01:00
2017-09-04 20:43:45 +02:00
2020-03-11 09:40:44 +01:00
2020-01-19 11:49:49 +01:00
2020-01-19 00:13:54 +01:00
2020-03-11 09:52:54 +01:00
2019-09-13 18:13:39 +02:00
2020-03-11 09:52:54 +01:00
2019-09-13 18:13:39 +02:00
2020-03-07 04:47:11 +01:00
2019-12-26 22:40:41 +01:00
2019-09-12 22:43:00 +02:00
2019-09-13 18:33:15 +02:00
2020-01-16 18:11:59 +01:00
2020-01-16 18:11:59 +01:00
2020-01-28 17:58:55 +01:00
2020-01-16 18:11:59 +01:00
2020-01-16 17:13:57 +01:00
2020-01-18 16:59:16 +01:00
2020-03-07 04:47:10 +01:00
2020-03-11 10:27:33 +01:00
2019-05-16 09:42:22 +02:00
2020-03-22 09:47:13 +01:00
2020-03-08 00:59:42 +01:00
2020-01-18 16:03:32 +01:00
2020-03-22 09:47:56 +01:00
2020-01-18 16:03:32 +01:00
2016-08-26 11:58:03 +02:00
2020-03-07 04:47:11 +01:00
2020-03-07 04:47:10 +01:00
2019-09-12 23:35:04 +02:00
2019-11-30 18:05:23 +01:00
2020-03-21 10:49:07 +01:00
2020-03-11 09:53:10 +01:00

HyperRogue

TravisCI badge TravisCI badge TravisCI badge

Current version: 11.3d

A puzzle roguelike in the hyperbolic plane. See the HyperRogue website for detailed and most up-to-date information. Compiled executables can be downloaded from itch.io and from the HyperRogue website.

Released under GNU General Public License, version 2. As such, it comes without any warranty.

If you would like to thank me for HyperRogue, you can support the development by buying paid versions (with more up-to-date content and some social and competitive features), or in other ways. You can contact me at zeno@attnam.com, or at my blog, or via Twitter.

The game

You are a lone outsider in a strange, non-Euclidean world. You can move with the numpad, vi keys (hjklyubn), or mouse. You can also skip turns by pressing ".".

As a Rogue, your goal is to collect as many treasures as possible. However, collecting treasures attracts dangerous monsters (on the other hand, killing the monsters allows more treasures to be generated).

You can kill most monsters by moving into them. Similarly, if the monster was next to you at the end of your turn, it would kill you. The game protects you from getting yourself killed accidentally by ignoring moves which lead to instant death (similar to the check rule from Chess).

Ultimately, you will probably run into a situation where monsters surround you. That means that your adventure is over, and you will have to teleport back to the Euclidean world to survive by pressing Escape (quit).

Collecting enough treasure also allows you to find rare magical orbs, which grant you one-time or time-limited special abilities.

The world is a combination of over 60 types of lands. Each land type has specific style (monsters, treasure, magical orbs, terrain features). Collecting treasures only attracts more monsters in lands of the same type, so you can try to collect lots of treasure in several different lands!

Some of these lands are available from the beginning, others can be found only if you have proven yourself (press ESC to know what you should do to access more lands). Ultimately, you will be able to access Hell, and look for the fabulous Orbs of Yendor which are hidden there. Get at least one of them to prove that you are a true winner! Only the best players will be able to face the challenges of Hell, but both the monsters and the challenges associated with the Orbs of Yendor are different than in the rest of the game, so it should be worth it.

You can see tooltips by placing the mouse over stuff. You can also right click to get more information about game objects.

Press v to configure the game. You can also rotate the world by pressing arrow keys, PageUp and PageDn (not numpad). You can center on the PC by pressing Home.

Your scores and other stats about your games are recorded to file hyperrogue.log (in Linux, ~/.hyperrogue.log). You can save your configuration to file hyperrogue.ini (in Linux, ~/.hyperrogue.ini).

The surface the game is played on is called a hyperbolic plane. It seems there is just a very small amount of games and other works of art which use hyperbolic geometry (the most well known are some works of M.C. Escher).

The game dynamically generates new parts of the world as you move. Due to nature of the hyperbolic plane, the chances that you get back to a place where you have been before are very low (unless you go back exactly the same way). See more information about the geometry used on the blog.

You can aim for the Orb of Yendor, or you can simply aim for as high score as possible.

Modifications

OK, now lots of the above can be changed. You can change the geometry and topology (to Euclidean, spherical, or even to nonisotropic 3D geometries). You can play challenges based on various in-game quests, and even try some other game genres in non-Euclidean spaces (roguelite aka shmup, racing, peaceful puzzles). Or use the engine for non-Euclidean computations and visualizations (see RogueViz). Have fun!

Technical information

You should be able to compile on Ubuntu (or similar) with something like this (you need SDL, SDL_ttf, and SDL_gfx):

sudo apt-get install gcc libsdl1.2-dev libsdl-ttf2.0-dev libsdl-gfx1.2-dev
git clone https://github.com/zenorogue/hyperrogue.git hyperrogue
cd hyperrogue
autoreconf -vi
./configure
make

There is also a standalone Makefile for Linux, OSX, and MinGW.

git clone https://github.com/zenorogue/hyperrogue.git
cd hyperrogue
make -f Makefile.simple

The mymake program builds HyperRogue in parts. It takes longer than the methods listed above, but when you change something, mymake will only recompile the changed file. Additionally, it can be easily configured, e.g., to produce an optimized build, or to include addons (see mymake.cpp for some example invocations, and devmods for some example addons).

make mymake && ./mymake

The source code is not documented very well. You can see the current state of the documentation, as generated by Doxygen, here.

Description
A SDL roguelike in a non-euclidean world.
Readme 136 MiB
Languages
C++ 97.3%
Ruby 1.6%
Java 0.8%
C 0.2%