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:
commit
b1cb66e468
@ -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)); }
|
||||||
|
|
||||||
|
@ -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)
|
||||||
|
@ -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);
|
||||||
|
@ -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},
|
||||||
|
@ -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;
|
||||||
|
@ -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));
|
||||||
|
@ -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;
|
||||||
|
|
||||||
|
1
hyper.h
1
hyper.h
@ -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;
|
||||||
|
@ -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;
|
||||||
|
@ -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);
|
||||||
|
6
reg3.cpp
6
reg3.cpp
@ -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;
|
||||||
|
|
||||||
|
@ -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;
|
||||||
|
|
||||||
|
@ -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;
|
||||||
|
|
||||||
|
@ -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
|
||||||
|
@ -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;
|
||||||
|
|
||||||
|
@ -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",
|
||||||
|
5
sky.cpp
5
sky.cpp
@ -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)
|
||||||
|
@ -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
|
||||||
|
Loading…
Reference in New Issue
Block a user