1
0
mirror of https://github.com/zenorogue/hyperrogue.git synced 2025-01-11 18:00:34 +00:00

Merge pull request #129 from Quuxplusone/unordered-map

Remove USE_UNORDERED_MAP because it has bit-rotted.
This commit is contained in:
Zeno Rogue 2020-11-05 20:03:13 +01:00 committed by GitHub
commit b1cb66e468
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
18 changed files with 26 additions and 38 deletions

View File

@ -136,8 +136,8 @@ EX transmatrix adjmatrix(int i) {
} }
struct hrmap_asonov : hrmap { struct hrmap_asonov : hrmap {
unordered_map<coord, heptagon*> at; map<coord, heptagon*> at;
unordered_map<heptagon*, coord> coords; map<heptagon*, coord> coords;
heptagon *getOrigin() override { return get_at(coord(0,0,0)); } heptagon *getOrigin() override { return get_at(coord(0,0,0)); }

View File

@ -22,7 +22,7 @@ struct display_data {
/** The view relative to the player character. */ /** The view relative to the player character. */
shiftmatrix player_matrix; shiftmatrix player_matrix;
/** On-screen coordinates for all the visible cells. */ /** On-screen coordinates for all the visible cells. */
unordered_map<cell*, shiftmatrix> cellmatrices, old_cellmatrices; map<cell*, shiftmatrix> cellmatrices, old_cellmatrices;
/** Position of the current map view, relative to the screen (0 to 1). */ /** Position of the current map view, relative to the screen (0 to 1). */
ld xmin, ymin, xmax, ymax; ld xmin, ymin, xmax, ymax;
/** Position of the current map view, in pixels. */ /** Position of the current map view, in pixels. */
@ -50,7 +50,7 @@ struct display_data {
/** Which copy of the player cell? */ /** Which copy of the player cell? */
transmatrix which_copy; transmatrix which_copy;
/** On-screen coordinates for all the visible cells. */ /** On-screen coordinates for all the visible cells. */
unordered_map<cell*, vector<shiftmatrix>> all_drawn_copies; map<cell*, vector<shiftmatrix>> all_drawn_copies;
}; };
#define View (::hr::current_display->view_matrix) #define View (::hr::current_display->view_matrix)

View File

@ -3356,7 +3356,7 @@ EX namespace ca {
EX eWall wlive = waFloorA; EX eWall wlive = waFloorA;
EX unordered_set<cell*> changed; EX set<cell*> changed;
EX void list_adj(cell *c) { EX void list_adj(cell *c) {
changed.insert(c); changed.insert(c);

View File

@ -2710,7 +2710,7 @@ EX int read_gamemode_args() {
auto ah_config = addHook(hooks_args, 0, read_config_args) + addHook(hooks_args, 0, read_gamemode_args) + addHook(hooks_args, 0, read_color_args); auto ah_config = addHook(hooks_args, 0, read_config_args) + addHook(hooks_args, 0, read_gamemode_args) + addHook(hooks_args, 0, read_color_args);
#endif #endif
EX unordered_map<string, ld&> params = { EX map<string, ld&> params = {
{"linewidth", vid.linewidth}, {"linewidth", vid.linewidth},
{"patternlinewidth", linepatterns::width}, {"patternlinewidth", linepatterns::width},
{"scale", pconf.scale}, {"scale", pconf.scale},

View File

@ -471,7 +471,7 @@ struct hrmap_crystal : hrmap_standard {
map<coord, heptagon*> heptagon_at; map<coord, heptagon*> heptagon_at;
map<int, eLand> landmemo; map<int, eLand> landmemo;
map<coord, eLand> landmemo4; map<coord, eLand> landmemo4;
unordered_map<cell*, unordered_map<cell*, int>> distmemo; map<cell*, map<cell*, int>> distmemo;
map<cell*, ldcoord> sgc; map<cell*, ldcoord> sgc;
cell *camelot_center; cell *camelot_center;
ldcoord camelot_coord; ldcoord camelot_coord;

View File

@ -2119,7 +2119,7 @@ EX void sort_drawqueue() {
int siz = isize(ptds); int siz = isize(ptds);
#if MINIMIZE_GL_CALLS #if MINIMIZE_GL_CALLS
unordered_map<color_t, vector<unique_ptr<drawqueueitem>>> subqueue; map<color_t, vector<unique_ptr<drawqueueitem>>> subqueue;
for(auto& p: ptds) subqueue[(p->prio == PPR::CIRCLE || p->prio == PPR::OUTCIRCLE) ? 0 : p->outline_group()].push_back(move(p)); for(auto& p: ptds) subqueue[(p->prio == PPR::CIRCLE || p->prio == PPR::OUTCIRCLE) ? 0 : p->outline_group()].push_back(move(p));
ptds.clear(); ptds.clear();
for(auto& p: subqueue) for(auto& r: p.second) ptds.push_back(move(r)); for(auto& p: subqueue) for(auto& r: p.second) ptds.push_back(move(r));

View File

@ -100,7 +100,7 @@ EX namespace euc {
/** ? */ /** ? */
intmatrix inverse_axes; intmatrix inverse_axes;
/** for canonicalization on tori */ /** for canonicalization on tori */
unordered_map<coord, int> hash; map<coord, int> hash;
vector<coord> seq; vector<coord> seq;
int index; int index;

View File

@ -48,7 +48,6 @@ template<class T, class V, class... U> bool among(T x, V y, U... u) { return x==
using std::vector; using std::vector;
using std::map; using std::map;
using std::array; using std::array;
using std::unordered_map;
using std::sort; using std::sort;
using std::multimap; using std::multimap;
using std::set; using std::set;

View File

@ -1095,8 +1095,8 @@ EX namespace mapeditor {
displayButton(8, vid.yres-8-fs*2, XLAT("ESC = return to the game"), SDLK_ESCAPE, 0); displayButton(8, vid.yres-8-fs*2, XLAT("ESC = return to the game"), SDLK_ESCAPE, 0);
} }
EX unordered_set<cell*> affected; EX set<cell*> affected;
EX unordered_set<int> affected_id; EX set<int> affected_id;
EX void showMapEditor() { EX void showMapEditor() {
cmode = sm::MAP; cmode = sm::MAP;

View File

@ -236,8 +236,8 @@ EX namespace sn {
struct hrmap_solnih : hrmap { struct hrmap_solnih : hrmap {
hrmap *binary_map; hrmap *binary_map;
hrmap *ternary_map; /* nih only */ hrmap *ternary_map; /* nih only */
unordered_map<pair<heptagon*, heptagon*>, heptagon*> at; map<pair<heptagon*, heptagon*>, heptagon*> at;
unordered_map<heptagon*, pair<heptagon*, heptagon*>> coords; map<heptagon*, pair<heptagon*, heptagon*>> coords;
heptagon *origin; heptagon *origin;
@ -872,8 +872,8 @@ EX namespace nilv {
} }
struct hrmap_nil : hrmap { struct hrmap_nil : hrmap {
unordered_map<mvec, heptagon*> at; map<mvec, heptagon*> at;
unordered_map<heptagon*, mvec> coords; map<heptagon*, mvec> coords;
heptagon *getOrigin() override { return get_at(mvec_zero); } heptagon *getOrigin() override { return get_at(mvec_zero); }
@ -2065,7 +2065,7 @@ EX namespace rots {
return spin(beta) * uxpush(distance/2) * spin(-beta+alpha); return spin(beta) * uxpush(distance/2) * spin(-beta+alpha);
} }
std::unordered_map<int, transmatrix> saved_matrices_ray; std::map<int, transmatrix> saved_matrices_ray;
EX transmatrix ray_iadj(cell *c1, int i) { EX transmatrix ray_iadj(cell *c1, int i) {
if(i == c1->type-1) return uzpush(-cgi.plevel) * spin(-2*cgi.plevel); if(i == c1->type-1) return uzpush(-cgi.plevel) * spin(-2*cgi.plevel);
@ -2097,7 +2097,7 @@ EX namespace rots {
struct hrmap_rotation_space : hybrid::hrmap_hybrid { struct hrmap_rotation_space : hybrid::hrmap_hybrid {
std::unordered_map<int, transmatrix> saved_matrices; std::map<int, transmatrix> saved_matrices;
transmatrix adj(cell *c1, int i) override { transmatrix adj(cell *c1, int i) override {
if(i == c1->type-2) return uzpush(-cgi.plevel) * spin(-2*cgi.plevel); if(i == c1->type-2) return uzpush(-cgi.plevel) * spin(-2*cgi.plevel);

View File

@ -601,8 +601,8 @@ EX namespace reg3 {
hrmap *binary_map; hrmap *binary_map;
hrmap_quotient3 *quotient_map; hrmap_quotient3 *quotient_map;
unordered_map<heptagon*, pair<heptagon*, transmatrix>> reg_gmatrix; map<heptagon*, pair<heptagon*, transmatrix>> reg_gmatrix;
unordered_map<heptagon*, vector<pair<heptagon*, transmatrix> > > altmap; map<heptagon*, vector<pair<heptagon*, transmatrix> > > altmap;
vector<cell*> spherecells; vector<cell*> spherecells;
@ -1439,7 +1439,7 @@ ld adistance(cell *c) {
return regmap()->reg_gmatrix[c->master].first->distance * log(2) - h[0]; return regmap()->reg_gmatrix[c->master].first->distance * log(2) - h[0];
} }
unordered_map<pair<cell*, cell*>, int> memo; map<pair<cell*, cell*>, int> memo;
bool cdd; bool cdd;

View File

@ -29,7 +29,7 @@ struct jmatrix : array<array<int, 7>, 7> {
}; };
vector<jmatrix> jms; vector<jmatrix> jms;
std::unordered_map<jmatrix, int> ids; std::map<jmatrix, int> ids;
jmatrix J, Z, id; jmatrix J, Z, id;

View File

@ -74,7 +74,7 @@ void make() {
for(int i=0; i<magmav; i++) vertices.push_back(vertices[i]); for(int i=0; i<magmav; i++) vertices.push_back(vertices[i]);
for(int i=0; i<magmav; i++) vertices.push_back(vertices[i]); for(int i=0; i<magmav; i++) vertices.push_back(vertices[i]);
unordered_map<pair<int, int>, int> counts; map<pair<int, int>, int> counts;
int big = v - 2; int big = v - 2;

View File

@ -11,7 +11,7 @@
#endif #endif
#define main nconf_main #define main nconf_main
#undef unordered_map #undef map
#undef self #undef self
#include "nconf.cpp" #include "nconf.cpp"
#undef main #undef main

View File

@ -546,7 +546,7 @@ void queuedisk(const shiftmatrix& V, const colorpair& cp, bool legend, const str
} }
} }
unordered_map<pair<edgeinfo*, int>, int> drawn_edges; map<pair<edgeinfo*, int>, int> drawn_edges;
map<pair<cell*, cell*>, transmatrix> relmatrices; map<pair<cell*, cell*>, transmatrix> relmatrices;

View File

@ -2527,7 +2527,7 @@ EX void turn(int delta) {
if(doall) if(doall)
for(cell *c: currentmap->allcells()) activateMonstersAt(c); for(cell *c: currentmap->allcells()) activateMonstersAt(c);
else else
for(unordered_map<cell*, shiftmatrix>::iterator it = gmatrix.begin(); it != gmatrix.end(); it++) for(map<cell*, shiftmatrix>::iterator it = gmatrix.begin(); it != gmatrix.end(); it++)
activateMonstersAt(it->first); activateMonstersAt(it->first);
/* printf("size: gmatrix = %ld, active = %ld, monstersAt = %ld, delta = %d\n", /* printf("size: gmatrix = %ld, active = %ld, monstersAt = %ld, delta = %d\n",

View File

@ -55,10 +55,7 @@ void dqi_sky::draw() {
int sk = get_skybrightness(); int sk = get_skybrightness();
unordered_map<cell*, pair<color_t, color_t>> colors; map<cell*, pair<color_t, color_t>> colors;
#ifdef USE_UNORDERED_MAP
colors.reserve(isize(sky));
#endif
for(sky_item& si: sky) colors[si.c] = for(sky_item& si: sky) colors[si.c] =
make_pair(darkena(gradient(0, si.color, 0, sk, 255), 0, 0xFF), make_pair(darkena(gradient(0, si.color, 0, sk, 255), 0, 0xFF),
darkena(si.skycolor, 0, 0xFF) darkena(si.skycolor, 0, 0xFF)

View File

@ -491,14 +491,6 @@ typedef unsigned GLuint;
#endif #endif
#endif #endif
#ifdef USE_UNORDERED_MAP
#include <unordered_map>
#include <unordered_set>
#else
#define unordered_map map
#define unordered_set set
#endif
#include <stdint.h> #include <stdint.h>
#if ISWINDOWS #if ISWINDOWS