mirror of
https://github.com/zenorogue/hyperrogue.git
synced 2025-01-12 02:10:34 +00:00
export everything: modules compiled separately
This commit is contained in:
parent
e96d24e8c2
commit
848eb8f48b
@ -21,9 +21,9 @@ ld eyepos;
|
|||||||
|
|
||||||
hyperpoint shcenter;
|
hyperpoint shcenter;
|
||||||
|
|
||||||
hyperpoint front_leg, rear_leg;
|
EX hyperpoint front_leg, rear_leg;
|
||||||
transmatrix front_leg_move, rear_leg_move, front_leg_move_inverse, rear_leg_move_inverse;
|
EX transmatrix front_leg_move, rear_leg_move, front_leg_move_inverse, rear_leg_move_inverse;
|
||||||
ld leg_length;
|
EX ld leg_length;
|
||||||
|
|
||||||
vector<hyperpoint> geometry_information::get_shape(hpcshape sh) {
|
vector<hyperpoint> geometry_information::get_shape(hpcshape sh) {
|
||||||
vector<hyperpoint> res;
|
vector<hyperpoint> res;
|
||||||
@ -43,7 +43,7 @@ hyperpoint get_center(const vector<hyperpoint>& vh) {
|
|||||||
return normalize_flat(h);
|
return normalize_flat(h);
|
||||||
}
|
}
|
||||||
|
|
||||||
ld zc(ld z) {
|
EX ld zc(ld z) {
|
||||||
if(WDIM == 2 && GDIM == 3)
|
if(WDIM == 2 && GDIM == 3)
|
||||||
return geom3::lev_to_factor(cgi.human_height * z);
|
return geom3::lev_to_factor(cgi.human_height * z);
|
||||||
return cgi.human_height * (z - 0.5) * revZ;
|
return cgi.human_height * (z - 0.5) * revZ;
|
||||||
@ -787,7 +787,7 @@ void geometry_information::shift_last_straight(ld z) {
|
|||||||
for(int i=last->s; i<isize(hpc); i++) hpc[i] = zpush(z) * hpc[i];
|
for(int i=last->s; i<isize(hpc); i++) hpc[i] = zpush(z) * hpc[i];
|
||||||
}
|
}
|
||||||
|
|
||||||
void queueball(const transmatrix& V, ld rad, color_t col, eItem what) {
|
EX void queueball(const transmatrix& V, ld rad, color_t col, eItem what) {
|
||||||
if(what == itOrbSpeed) {
|
if(what == itOrbSpeed) {
|
||||||
transmatrix V1 = V * cspin(1, 2, M_PI/2);
|
transmatrix V1 = V * cspin(1, 2, M_PI/2);
|
||||||
ld tt = ptick(100);
|
ld tt = ptick(100);
|
||||||
|
@ -1056,7 +1056,7 @@ archimedean_tiling edited;
|
|||||||
|
|
||||||
bool symbol_editing;
|
bool symbol_editing;
|
||||||
|
|
||||||
void next_variation() {
|
EX void next_variation() {
|
||||||
set_variation(
|
set_variation(
|
||||||
PURE ? eVariation::dual :
|
PURE ? eVariation::dual :
|
||||||
DUAL ? eVariation::bitruncated :
|
DUAL ? eVariation::bitruncated :
|
||||||
|
@ -107,7 +107,7 @@ bool eqs(const char* x, const char* y) {
|
|||||||
return *y? *x==*y?eqs(x+1,y+1):false:true;
|
return *y? *x==*y?eqs(x+1,y+1):false:true;
|
||||||
}
|
}
|
||||||
|
|
||||||
int getnext(const char* s, int& i) {
|
EX int getnext(const char* s, int& i) {
|
||||||
|
|
||||||
int siz = utfsize(s[i]);
|
int siz = utfsize(s[i]);
|
||||||
// if(fontdeb) printf("s=%s i=%d siz=%d\n", s, i, siz);
|
// if(fontdeb) printf("s=%s i=%d siz=%d\n", s, i, siz);
|
||||||
@ -128,7 +128,7 @@ TTF_Font *font[256];
|
|||||||
EX SDL_Surface *s;
|
EX SDL_Surface *s;
|
||||||
EX SDL_Surface *s_screen;
|
EX SDL_Surface *s_screen;
|
||||||
|
|
||||||
color_t qpixel_pixel_outside;
|
EX color_t qpixel_pixel_outside;
|
||||||
|
|
||||||
EX color_t& qpixel(SDL_Surface *surf, int x, int y) {
|
EX color_t& qpixel(SDL_Surface *surf, int x, int y) {
|
||||||
if(x<0 || y<0 || x >= surf->w || y >= surf->h) return qpixel_pixel_outside;
|
if(x<0 || y<0 || x >= surf->w || y >= surf->h) return qpixel_pixel_outside;
|
||||||
@ -142,7 +142,7 @@ EX color_t& qpixel(SDL_Surface *surf, int x, int y) {
|
|||||||
|
|
||||||
#if CAP_SDLTTF
|
#if CAP_SDLTTF
|
||||||
|
|
||||||
string fontpath = ISWEB ? "sans-serif" : HYPERPATH "DejaVuSans-Bold.ttf";
|
EX string fontpath = ISWEB ? "sans-serif" : HYPERPATH "DejaVuSans-Bold.ttf";
|
||||||
|
|
||||||
void loadfont(int siz) {
|
void loadfont(int siz) {
|
||||||
if(!font[siz]) {
|
if(!font[siz]) {
|
||||||
@ -245,7 +245,7 @@ EX void start_projection(int ed, bool perspective) {
|
|||||||
glhr::projection_multiply(glhr::translate(tx, -ty, 0));
|
glhr::projection_multiply(glhr::translate(tx, -ty, 0));
|
||||||
}
|
}
|
||||||
|
|
||||||
void eyewidth_translate(int ed) {
|
EX void eyewidth_translate(int ed) {
|
||||||
if(ed) glhr::projection_multiply(glhr::translate(-ed * current_display->eyewidth(), 0, 0));
|
if(ed) glhr::projection_multiply(glhr::translate(-ed * current_display->eyewidth(), 0, 0));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1000,9 +1000,9 @@ struct msginfo {
|
|||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
vector<msginfo> msgs;
|
EX vector<msginfo> msgs;
|
||||||
|
|
||||||
vector<msginfo> gamelog;
|
EX vector<msginfo> gamelog;
|
||||||
|
|
||||||
EX void flashMessages() {
|
EX void flashMessages() {
|
||||||
for(int i=0; i<isize(msgs); i++)
|
for(int i=0; i<isize(msgs); i++)
|
||||||
@ -1012,7 +1012,7 @@ EX void flashMessages() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
string fullmsg(msginfo& m) {
|
EX string fullmsg(msginfo& m) {
|
||||||
string s = m.msg;
|
string s = m.msg;
|
||||||
if(m.quantity > 1) s += " (x" + its(m.quantity) + ")";
|
if(m.quantity > 1) s += " (x" + its(m.quantity) + ")";
|
||||||
return s;
|
return s;
|
||||||
@ -1443,8 +1443,8 @@ EX int calcfps() {
|
|||||||
|
|
||||||
EX namespace subscreens {
|
EX namespace subscreens {
|
||||||
|
|
||||||
vector<display_data> player_displays;
|
EX vector<display_data> player_displays;
|
||||||
bool in;
|
EX bool in;
|
||||||
EX int current_player;
|
EX int current_player;
|
||||||
|
|
||||||
EX bool is_current_player(int id) {
|
EX bool is_current_player(int id) {
|
||||||
|
@ -11,6 +11,7 @@ namespace hr {
|
|||||||
EX namespace binary {
|
EX namespace binary {
|
||||||
#if CAP_BT
|
#if CAP_BT
|
||||||
|
|
||||||
|
#if HDR
|
||||||
enum bindir {
|
enum bindir {
|
||||||
bd_right = 0,
|
bd_right = 0,
|
||||||
bd_up_right = 1,
|
bd_up_right = 1,
|
||||||
@ -21,6 +22,7 @@ EX namespace binary {
|
|||||||
bd_down_left = 5, /* for cells of degree 7 */
|
bd_down_left = 5, /* for cells of degree 7 */
|
||||||
bd_down_right = 6 /* for cells of degree 7 */
|
bd_down_right = 6 /* for cells of degree 7 */
|
||||||
};
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
EX int type_of(heptagon *h) {
|
EX int type_of(heptagon *h) {
|
||||||
return h->c7->type;
|
return h->c7->type;
|
||||||
|
@ -425,7 +425,7 @@ monstertype minf[motypes] = {
|
|||||||
#include "content.cpp"
|
#include "content.cpp"
|
||||||
};
|
};
|
||||||
|
|
||||||
genderswitch_t genderswitch[NUM_GS] = {
|
EX genderswitch_t genderswitch[NUM_GS] = {
|
||||||
{ GEN_F, moFalsePrincess, "False Princess",
|
{ GEN_F, moFalsePrincess, "False Princess",
|
||||||
"Don't be fooled by this red-haired girl, or you will be stabbed if you come too close!"},
|
"Don't be fooled by this red-haired girl, or you will be stabbed if you come too close!"},
|
||||||
{ GEN_M, moFalsePrincess, "False Prince",
|
{ GEN_M, moFalsePrincess, "False Prince",
|
||||||
|
@ -67,7 +67,7 @@ EX namespace arg {
|
|||||||
EX int pos;
|
EX int pos;
|
||||||
|
|
||||||
EX void lshift() { pos++; }
|
EX void lshift() { pos++; }
|
||||||
void unshift() { pos--; }
|
EX void unshift() { pos--; }
|
||||||
|
|
||||||
EX void shift() {
|
EX void shift() {
|
||||||
lshift(); if(pos >= isize(argument)) { printf("Missing parameter\n"); exit(1); }
|
lshift(); if(pos >= isize(argument)) { printf("Missing parameter\n"); exit(1); }
|
||||||
|
28
complex.cpp
28
complex.cpp
@ -53,7 +53,7 @@ EX namespace whirlwind {
|
|||||||
}
|
}
|
||||||
|
|
||||||
cell *where;
|
cell *where;
|
||||||
int dfrom[2], dto[2];
|
EX int dfrom[2], dto[2];
|
||||||
EX int qdirs;
|
EX int qdirs;
|
||||||
|
|
||||||
int gdist(int d, int e) { return dirdiff(d-e, where->type); }
|
int gdist(int d, int e) { return dirdiff(d-e, where->type); }
|
||||||
@ -963,7 +963,7 @@ EX namespace whirlpool {
|
|||||||
|
|
||||||
// next == +1 -> next
|
// next == +1 -> next
|
||||||
// next == -1 -> prev
|
// next == -1 -> prev
|
||||||
cell *get(cell *c, int next) {
|
EX cell *get(cell *c, int next) {
|
||||||
int i = 0;
|
int i = 0;
|
||||||
if(!eubinary && !c->master->alt) return NULL;
|
if(!eubinary && !c->master->alt) return NULL;
|
||||||
int d = celldistAlt(c);
|
int d = celldistAlt(c);
|
||||||
@ -1319,7 +1319,7 @@ EX namespace mirror {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void createHere(cellwalker cw, int cpid) {
|
EX void createHere(cellwalker cw, int cpid) {
|
||||||
if(!cw.at) return;
|
if(!cw.at) return;
|
||||||
if(cw.at->wall == waCloud)
|
if(cw.at->wall == waCloud)
|
||||||
createMirages(cw, cpid);
|
createMirages(cw, cpid);
|
||||||
@ -1327,7 +1327,7 @@ EX namespace mirror {
|
|||||||
createMirrors(cw, cpid);
|
createMirrors(cw, cpid);
|
||||||
}
|
}
|
||||||
|
|
||||||
void breakMirror(cellwalker cw, int pid) {
|
EX void breakMirror(cellwalker cw, int pid) {
|
||||||
if(!cw.at) return;
|
if(!cw.at) return;
|
||||||
cell *c = cw.at;
|
cell *c = cw.at;
|
||||||
if(c->wall == waMirror || c->wall == waCloud) {
|
if(c->wall == waMirror || c->wall == waCloud) {
|
||||||
@ -1434,7 +1434,7 @@ EX namespace mirror {
|
|||||||
list();
|
list();
|
||||||
}
|
}
|
||||||
|
|
||||||
int mirrordir(cell *c) {
|
EX int mirrordir(cell *c) {
|
||||||
if(c->type == 7) return c->bardir;
|
if(c->type == 7) return c->bardir;
|
||||||
|
|
||||||
int icount = 0, isum = 0;
|
int icount = 0, isum = 0;
|
||||||
@ -1621,7 +1621,7 @@ EX namespace hive {
|
|||||||
vector<cell*> deadbug;
|
vector<cell*> deadbug;
|
||||||
vector<cell*> bugcellq;
|
vector<cell*> bugcellq;
|
||||||
|
|
||||||
int bugcount[BUGCOLORS];
|
EX int bugcount[BUGCOLORS];
|
||||||
|
|
||||||
bool isBugEnemy(cell *c, int k) {
|
bool isBugEnemy(cell *c, int k) {
|
||||||
if(isPlayerOn(c) && !invismove) return true;
|
if(isPlayerOn(c) && !invismove) return true;
|
||||||
@ -2438,7 +2438,7 @@ EX namespace tortoise {
|
|||||||
return bi;
|
return bi;
|
||||||
}
|
}
|
||||||
|
|
||||||
int getBit(int bits, int id) { return (bits >> id) & 1; }
|
EX int getBit(int bits, int id) { return (bits >> id) & 1; }
|
||||||
|
|
||||||
EX int getRandomBits() { return hrand(1 << numbits); }
|
EX int getRandomBits() { return hrand(1 << numbits); }
|
||||||
|
|
||||||
@ -2455,7 +2455,7 @@ EX namespace tortoise {
|
|||||||
else val = target;
|
else val = target;
|
||||||
}
|
}
|
||||||
|
|
||||||
void updateVals(int delta) {
|
EX void updateVals(int delta) {
|
||||||
int currbits = getBits(cwt.at);
|
int currbits = getBits(cwt.at);
|
||||||
for(int i=0; i<numbits; i++)
|
for(int i=0; i<numbits; i++)
|
||||||
update(seekval[i], seek() && !(peace::on && !peace::hint) ? getBit(seekbits, i) : .5, delta);
|
update(seekval[i], seek() && !(peace::on && !peace::hint) ? getBit(seekbits, i) : .5, delta);
|
||||||
@ -2463,7 +2463,7 @@ EX namespace tortoise {
|
|||||||
update(currval[i], getBit(currbits, i), delta);
|
update(currval[i], getBit(currbits, i), delta);
|
||||||
}
|
}
|
||||||
|
|
||||||
double getScent(int bits) {
|
EX double getScent(int bits) {
|
||||||
double res = 0;
|
double res = 0;
|
||||||
for(int i=0; i<numbits; i++)
|
for(int i=0; i<numbits; i++)
|
||||||
/* if(getBit(bits, i) != getBit(getBits(cwt.at), i))
|
/* if(getBit(bits, i) != getBit(getBits(cwt.at), i))
|
||||||
@ -2540,7 +2540,7 @@ EX namespace dragon {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
int bodypart(cell *c, cell *head) {
|
EX int bodypart(cell *c, cell *head) {
|
||||||
int i = 0, j = 0;
|
int i = 0, j = 0;
|
||||||
int maxlen = 1000;
|
int maxlen = 1000;
|
||||||
while(maxlen-->0) {
|
while(maxlen-->0) {
|
||||||
@ -2685,7 +2685,7 @@ EX namespace sword {
|
|||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
int sword_angles;
|
EX int sword_angles;
|
||||||
|
|
||||||
EX array<sworddir, MAXPLAYER> dir;
|
EX array<sworddir, MAXPLAYER> dir;
|
||||||
|
|
||||||
@ -2706,7 +2706,7 @@ EX namespace sword {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
cell *pos2(cell *c, int s) {
|
EX cell *pos2(cell *c, int s) {
|
||||||
int t = c->type;
|
int t = c->type;
|
||||||
if(hybri) t -= 2;
|
if(hybri) t -= 2;
|
||||||
s *= 2;
|
s *= 2;
|
||||||
@ -3081,7 +3081,7 @@ EX namespace prairie {
|
|||||||
return 15^c->LHU.fi.rval;
|
return 15^c->LHU.fi.rval;
|
||||||
}
|
}
|
||||||
|
|
||||||
cell *next(cell *c, int pv=1) {
|
EX cell *next(cell *c, int pv IS(1)) {
|
||||||
for(int i=0; i<c->type; i++) {
|
for(int i=0; i<c->type; i++) {
|
||||||
cell *c1 = createMov(c, i);
|
cell *c1 = createMov(c, i);
|
||||||
cell *c2 = createMov(c, (i+pv+c->type)%c->type);
|
cell *c2 = createMov(c, (i+pv+c->type)%c->type);
|
||||||
@ -3384,7 +3384,7 @@ EX namespace windmap {
|
|||||||
return id-1;
|
return id-1;
|
||||||
}
|
}
|
||||||
|
|
||||||
vector<unsigned char> windcodes;
|
EX vector<unsigned char> windcodes;
|
||||||
|
|
||||||
void wcheck(cell *a, cell *b) {
|
void wcheck(cell *a, cell *b) {
|
||||||
int i = getId(a);
|
int i = getId(a);
|
||||||
|
@ -112,7 +112,7 @@ EX namespace brownian {
|
|||||||
recurse(c, FAT);
|
recurse(c, FAT);
|
||||||
}
|
}
|
||||||
|
|
||||||
void init_further(cell *c) {
|
EX void init_further(cell *c) {
|
||||||
if(!hyperbolic) return;
|
if(!hyperbolic) return;
|
||||||
int dl = getDistLimit();
|
int dl = getDistLimit();
|
||||||
dynamicval<bool> be(generatingEquidistant, true);
|
dynamicval<bool> be(generatingEquidistant, true);
|
||||||
@ -177,7 +177,7 @@ EX namespace brownian {
|
|||||||
|
|
||||||
EX colortable colors = { 0x603000, 0x804000, 0xA05000, 0xC09050, 0xE0D0A0 };
|
EX colortable colors = { 0x603000, 0x804000, 0xA05000, 0xC09050, 0xE0D0A0 };
|
||||||
|
|
||||||
color_t get_color(int y) {
|
EX color_t get_color(int y) {
|
||||||
return
|
return
|
||||||
y < level ? gradient(colors[0], colors[1], 1, y, level-1) :
|
y < level ? gradient(colors[0], colors[1], 1, y, level-1) :
|
||||||
y < 2 * level ? colors[2] :
|
y < 2 * level ? colors[2] :
|
||||||
@ -214,7 +214,7 @@ EX namespace westwall {
|
|||||||
placeLocalOrbs(c);
|
placeLocalOrbs(c);
|
||||||
}
|
}
|
||||||
|
|
||||||
int coastvalEdge1(cell *c) {
|
EX int coastvalEdge1(cell *c) {
|
||||||
if(c->land == laWestWall && !c->landparam) buildEquidistant(c);
|
if(c->land == laWestWall && !c->landparam) buildEquidistant(c);
|
||||||
return coastvalEdge(c);
|
return coastvalEdge(c);
|
||||||
}
|
}
|
||||||
|
10
config.cpp
10
config.cpp
@ -111,7 +111,7 @@ template<> struct saver<ld> : dsaver<ld> {
|
|||||||
EX ld bounded_mine_percentage = 0.1;
|
EX ld bounded_mine_percentage = 0.1;
|
||||||
EX int bounded_mine_quantity, bounded_mine_max;
|
EX int bounded_mine_quantity, bounded_mine_max;
|
||||||
|
|
||||||
const char *conffile = "hyperrogue.ini";
|
EX const char *conffile = "hyperrogue.ini";
|
||||||
|
|
||||||
EX array<ld, gGUARD> sightranges;
|
EX array<ld, gGUARD> sightranges;
|
||||||
|
|
||||||
@ -141,7 +141,7 @@ struct charstyle_old {
|
|||||||
bool lefthanded;
|
bool lefthanded;
|
||||||
};
|
};
|
||||||
|
|
||||||
void hread(hstream& hs, charstyle& cs) {
|
EX void hread(hstream& hs, charstyle& cs) {
|
||||||
// before 0xA61A there was no eyecolor
|
// before 0xA61A there was no eyecolor
|
||||||
if(hs.get_vernum() < 0xA61A) {
|
if(hs.get_vernum() < 0xA61A) {
|
||||||
charstyle_old cso;
|
charstyle_old cso;
|
||||||
@ -159,7 +159,7 @@ void hread(hstream& hs, charstyle& cs) {
|
|||||||
else hread_raw(hs, cs);
|
else hread_raw(hs, cs);
|
||||||
}
|
}
|
||||||
|
|
||||||
void hwrite(hstream& hs, const charstyle& cs) {
|
EX void hwrite(hstream& hs, const charstyle& cs) {
|
||||||
hwrite_raw(hs, cs);
|
hwrite_raw(hs, cs);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -198,7 +198,7 @@ EX int lang() {
|
|||||||
return default_language;
|
return default_language;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool autojoy = true;
|
EX bool autojoy = true;
|
||||||
|
|
||||||
#if CAP_CONFIG
|
#if CAP_CONFIG
|
||||||
saverlist savers;
|
saverlist savers;
|
||||||
@ -214,7 +214,7 @@ template<class T, class U> void addsaverenum(T& i, U name) {}
|
|||||||
template<class T, class U> void addsaverenum(T& i, U name, T dft) {}
|
template<class T, class U> void addsaverenum(T& i, U name, T dft) {}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
void addsaver(charstyle& cs, string s) {
|
EX void addsaver(charstyle& cs, string s) {
|
||||||
addsaver(cs.charid, s + ".charid");
|
addsaver(cs.charid, s + ".charid");
|
||||||
addsaver(cs.skincolor, s + ".skincolor");
|
addsaver(cs.skincolor, s + ".skincolor");
|
||||||
addsaver(cs.eyecolor, s + ".eyecolor");
|
addsaver(cs.eyecolor, s + ".eyecolor");
|
||||||
|
16
control.cpp
16
control.cpp
@ -8,8 +8,8 @@
|
|||||||
#include "hyper.h"
|
#include "hyper.h"
|
||||||
namespace hr {
|
namespace hr {
|
||||||
|
|
||||||
int frames;
|
EX int frames;
|
||||||
bool outoffocus = false;
|
EX bool outoffocus = false;
|
||||||
|
|
||||||
EX int mousex, mousey;
|
EX int mousex, mousey;
|
||||||
EX hyperpoint mouseh, mouseoh;
|
EX hyperpoint mouseh, mouseoh;
|
||||||
@ -40,7 +40,7 @@ EX bool mousepressed = false;
|
|||||||
EX bool mousemoved = false;
|
EX bool mousemoved = false;
|
||||||
EX bool actonrelease = false;
|
EX bool actonrelease = false;
|
||||||
|
|
||||||
bool mousepan, oldmousepan;
|
EX bool mousepan, oldmousepan;
|
||||||
#if CAP_MOUSEGRAB
|
#if CAP_MOUSEGRAB
|
||||||
EX ld mouseaim_x, mouseaim_y;
|
EX ld mouseaim_x, mouseaim_y;
|
||||||
#endif
|
#endif
|
||||||
@ -57,9 +57,9 @@ EX movedir mousedest;
|
|||||||
EX ld shiftmul = 1;
|
EX ld shiftmul = 1;
|
||||||
|
|
||||||
EX cell *mouseover, *mouseover2, *lmouseover;
|
EX cell *mouseover, *mouseover2, *lmouseover;
|
||||||
ld modist, modist2, centdist;
|
EX ld modist, modist2, centdist;
|
||||||
|
|
||||||
int lastt;
|
EX int lastt;
|
||||||
|
|
||||||
EX bool mouseout() {
|
EX bool mouseout() {
|
||||||
if((getcstat != '-' && getcstat) || (lgetcstat && lgetcstat != '-')) return true;
|
if((getcstat != '-' && getcstat) || (lgetcstat && lgetcstat != '-')) return true;
|
||||||
@ -1093,7 +1093,7 @@ EX bool handleCompass() {
|
|||||||
// orientation sensitivity
|
// orientation sensitivity
|
||||||
EX namespace ors {
|
EX namespace ors {
|
||||||
|
|
||||||
int mode;
|
EX int mode;
|
||||||
double sensitivity = 1;
|
double sensitivity = 1;
|
||||||
|
|
||||||
int when_enabled;
|
int when_enabled;
|
||||||
@ -1204,11 +1204,11 @@ transmatrix change_geometry(const transmatrix& T) {
|
|||||||
return U;
|
return U;
|
||||||
}
|
}
|
||||||
|
|
||||||
void unrotate(transmatrix& T) {
|
EX void unrotate(transmatrix& T) {
|
||||||
if(mode == 1) T = inverse(relative_matrix) * T;
|
if(mode == 1) T = inverse(relative_matrix) * T;
|
||||||
}
|
}
|
||||||
|
|
||||||
void rerotate(transmatrix& T) {
|
EX void rerotate(transmatrix& T) {
|
||||||
if(mode == 1) T = (relative_matrix) * T;
|
if(mode == 1) T = (relative_matrix) * T;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1459,7 +1459,7 @@ void transform_euclid_to_crystal () {
|
|||||||
if(pmodel == mdPerspective) pmodel = mdDisk;
|
if(pmodel == mdPerspective) pmodel = mdDisk;
|
||||||
}
|
}
|
||||||
|
|
||||||
void add_crystal_transform(char c) {
|
EX void add_crystal_transform(char c) {
|
||||||
if(shmup::on) return;
|
if(shmup::on) return;
|
||||||
if(cryst && ginf[gCrystal].sides == 6) {
|
if(cryst && ginf[gCrystal].sides == 6) {
|
||||||
dialog::addItem("convert Crystal to 3D", c);
|
dialog::addItem("convert Crystal to 3D", c);
|
||||||
|
@ -26,7 +26,7 @@ void limitgen(T... args) {
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
cell *pathTowards(cell *pf, cell *pt) {
|
EX cell *pathTowards(cell *pf, cell *pt) {
|
||||||
|
|
||||||
while(celldist(pt) > celldist(pf)) {
|
while(celldist(pt) > celldist(pf)) {
|
||||||
if(isNeighbor(pf, pt)) return pt;
|
if(isNeighbor(pf, pt)) return pt;
|
||||||
@ -42,7 +42,7 @@ cell *pathTowards(cell *pf, cell *pt) {
|
|||||||
|
|
||||||
bool errorReported = false;
|
bool errorReported = false;
|
||||||
|
|
||||||
void describeCell(cell *c) {
|
EX void describeCell(cell *c) {
|
||||||
if(!c) { printf("NULL\n"); return; }
|
if(!c) { printf("NULL\n"); return; }
|
||||||
printf("describe %p: ", c);
|
printf("describe %p: ", c);
|
||||||
printf("%-15s", linf[c->land].name);
|
printf("%-15s", linf[c->land].name);
|
||||||
@ -93,14 +93,14 @@ eItem randomTreasure2(int cv) {
|
|||||||
|
|
||||||
EX eLand cheatdest;
|
EX eLand cheatdest;
|
||||||
|
|
||||||
void cheatMoveTo(eLand l) {
|
EX void cheatMoveTo(eLand l) {
|
||||||
cheatdest = l;
|
cheatdest = l;
|
||||||
if(l == laCrossroads5) l = laCrossroads;
|
if(l == laCrossroads5) l = laCrossroads;
|
||||||
activateSafety(l);
|
activateSafety(l);
|
||||||
cheatdest = laNone;
|
cheatdest = laNone;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool applyCheat(char u, cell *c = NULL) {
|
EX bool applyCheat(char u, cell *c IS(NULL)) {
|
||||||
|
|
||||||
if(u == 'L') {
|
if(u == 'L') {
|
||||||
do {
|
do {
|
||||||
|
@ -111,7 +111,8 @@ EX namespace dialog {
|
|||||||
if(ev.type == SDL_MOUSEBUTTONDOWN) initzoom();
|
if(ev.type == SDL_MOUSEBUTTONDOWN) initzoom();
|
||||||
if(ev.type == SDL_MOUSEBUTTONUP && zoomf > 1) stopzoom();
|
if(ev.type == SDL_MOUSEBUTTONUP && zoomf > 1) stopzoom();
|
||||||
}
|
}
|
||||||
#else
|
#endif
|
||||||
|
#if !(CAP_MENUSCALING && CAP_SDL)
|
||||||
EX void handleZooming(SDL_Event &ev) {}
|
EX void handleZooming(SDL_Event &ev) {}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -341,7 +342,7 @@ EX namespace dialog {
|
|||||||
|
|
||||||
EX int tothei, dialogwidth, dfsize, dfspace, leftwidth, rightwidth, innerwidth, itemx, keyx, valuex;
|
EX int tothei, dialogwidth, dfsize, dfspace, leftwidth, rightwidth, innerwidth, itemx, keyx, valuex;
|
||||||
|
|
||||||
string highlight_text;
|
EX string highlight_text;
|
||||||
|
|
||||||
EX void measure() {
|
EX void measure() {
|
||||||
tothei = 0;
|
tothei = 0;
|
||||||
|
@ -126,7 +126,7 @@ EX int shapes_merged;
|
|||||||
color_t triangle_color, line_color;
|
color_t triangle_color, line_color;
|
||||||
vector<glvertex> triangle_vertices;
|
vector<glvertex> triangle_vertices;
|
||||||
vector<glvertex> line_vertices;
|
vector<glvertex> line_vertices;
|
||||||
void glapplymatrix(const transmatrix& V);
|
EX void glapplymatrix(const transmatrix& V);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
EX void glflush() {
|
EX void glflush() {
|
||||||
@ -475,7 +475,7 @@ void drawTexturedTriangle(SDL_Surface *s, int *px, int *py, glvertex *tv, color_
|
|||||||
|
|
||||||
#if CAP_GL
|
#if CAP_GL
|
||||||
|
|
||||||
void glapplymatrix(const transmatrix& V) {
|
EX void glapplymatrix(const transmatrix& V) {
|
||||||
GLfloat mat[16];
|
GLfloat mat[16];
|
||||||
int id = 0;
|
int id = 0;
|
||||||
|
|
||||||
@ -1746,11 +1746,13 @@ EX void drawqueue() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if HDR
|
||||||
template<class T, class... U> T& queuea(PPR prio, U... u) {
|
template<class T, class... U> T& queuea(PPR prio, U... u) {
|
||||||
ptds.push_back(unique_ptr<T>(new T (u...)));
|
ptds.push_back(unique_ptr<T>(new T (u...)));
|
||||||
ptds.back()->prio = prio;
|
ptds.back()->prio = prio;
|
||||||
return (T&) *ptds.back();
|
return (T&) *ptds.back();
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
#if CAP_SHAPES
|
#if CAP_SHAPES
|
||||||
EX dqi_poly& queuepolyat(const transmatrix& V, const hpcshape& h, color_t col, PPR prio) {
|
EX dqi_poly& queuepolyat(const transmatrix& V, const hpcshape& h, color_t col, PPR prio) {
|
||||||
|
22
euclid.cpp
22
euclid.cpp
@ -80,8 +80,8 @@ EX namespace torusconfig {
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
// new values to change
|
// new values to change
|
||||||
int newqty, newdy, newsdx, newsdy;
|
EX int newqty, newdy, newsdx, newsdy;
|
||||||
int torus_cx, torus_cy;
|
EX int torus_cx, torus_cy;
|
||||||
|
|
||||||
EX vector<torusmode_info> tmodes = {
|
EX vector<torusmode_info> tmodes = {
|
||||||
{"single row (hex)", TF_SINGLE | TF_HEX},
|
{"single row (hex)", TF_SINGLE | TF_HEX},
|
||||||
@ -98,10 +98,10 @@ EX namespace torusconfig {
|
|||||||
};
|
};
|
||||||
|
|
||||||
EX eTorusMode torus_mode;
|
EX eTorusMode torus_mode;
|
||||||
eTorusMode newmode;
|
EX eTorusMode newmode;
|
||||||
EX flagtype tmflags() { return tmodes[torus_mode].flags; }
|
EX flagtype tmflags() { return tmodes[torus_mode].flags; }
|
||||||
|
|
||||||
int getqty() {
|
EX int getqty() {
|
||||||
if(tmflags() & TF_SINGLE)
|
if(tmflags() & TF_SINGLE)
|
||||||
return qty;
|
return qty;
|
||||||
else
|
else
|
||||||
@ -205,11 +205,11 @@ EX namespace torusconfig {
|
|||||||
return 2 * (e1.first * e2.first + e1.second*e2.second) + (S3 == 3 ? e1.first*e2.second + e2.first * e1.second : 0);
|
return 2 * (e1.first * e2.first + e1.second*e2.second) + (S3 == 3 ? e1.first*e2.second + e2.first * e1.second : 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
int dcross(gp::loc e1, gp::loc e2) {
|
EX int dcross(gp::loc e1, gp::loc e2) {
|
||||||
return e1.first * e2.second - e1.second*e2.first;
|
return e1.first * e2.second - e1.second*e2.first;
|
||||||
}
|
}
|
||||||
|
|
||||||
gp::loc sdxy() { return gp::loc(sdx, sdy); }
|
EX gp::loc sdxy() { return gp::loc(sdx, sdy); }
|
||||||
|
|
||||||
EX int mobius_dir_basic() {
|
EX int mobius_dir_basic() {
|
||||||
int dscalars[6];
|
int dscalars[6];
|
||||||
@ -223,7 +223,7 @@ EX namespace torusconfig {
|
|||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool mobius_symmetric(bool square, int dx, int dy) {
|
EX bool mobius_symmetric(bool square, int dx, int dy) {
|
||||||
dynamicval<eGeometry> g(geometry, square ? gEuclidSquare : gEuclid);
|
dynamicval<eGeometry> g(geometry, square ? gEuclidSquare : gEuclid);
|
||||||
dynamicval<int> gx(sdx, dx);
|
dynamicval<int> gx(sdx, dx);
|
||||||
dynamicval<int> gy(sdy, dy);
|
dynamicval<int> gy(sdy, dy);
|
||||||
@ -305,7 +305,7 @@ EX namespace torusconfig {
|
|||||||
}
|
}
|
||||||
EX }
|
EX }
|
||||||
|
|
||||||
int euclid_getvec(int dx, int dy) {
|
EX int euclid_getvec(int dx, int dy) {
|
||||||
if(euwrap) return torusconfig::getvec(dx, dy);
|
if(euwrap) return torusconfig::getvec(dx, dy);
|
||||||
else return pair_to_vec(dx, dy);
|
else return pair_to_vec(dx, dy);
|
||||||
}
|
}
|
||||||
@ -474,7 +474,7 @@ struct hrmap_euclidean : hrmap_euclid_any {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
cellwalker vec_to_cellwalker(int vec) {
|
EX cellwalker vec_to_cellwalker(int vec) {
|
||||||
if(!fulltorus) {
|
if(!fulltorus) {
|
||||||
auto p = euclideanAtCreate(vec);
|
auto p = euclideanAtCreate(vec);
|
||||||
if(p.second)
|
if(p.second)
|
||||||
@ -771,7 +771,7 @@ EX namespace euclid3 {
|
|||||||
return new hrmap_euclid3;
|
return new hrmap_euclid3;
|
||||||
}
|
}
|
||||||
|
|
||||||
transmatrix move_matrix(cell *c, int i) {
|
EX transmatrix move_matrix(cell *c, int i) {
|
||||||
return cubemap()->get_move(c, i);
|
return cubemap()->get_move(c, i);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1057,7 +1057,7 @@ EX namespace euclid3 {
|
|||||||
return canonical_seq[canonical_hash[cat]];
|
return canonical_seq[canonical_hash[cat]];
|
||||||
}
|
}
|
||||||
|
|
||||||
void prepare_torus3() {
|
EX void prepare_torus3() {
|
||||||
T_edit = T0;
|
T_edit = T0;
|
||||||
twisted_edit = twisted0;
|
twisted_edit = twisted0;
|
||||||
}
|
}
|
||||||
|
@ -624,7 +624,9 @@ EX namespace ts {
|
|||||||
EX }
|
EX }
|
||||||
|
|
||||||
EX bool viewdists = false;
|
EX bool viewdists = false;
|
||||||
bool use_color_codes = true, use_analyzer = true, show_distance_lists = true;
|
EX bool use_color_codes = true;
|
||||||
|
EX bool use_analyzer = true;
|
||||||
|
EX bool show_distance_lists = true;
|
||||||
|
|
||||||
int first_distance = 0, scrolltime = 0;
|
int first_distance = 0, scrolltime = 0;
|
||||||
bool scrolling_distances = false;
|
bool scrolling_distances = false;
|
||||||
@ -638,7 +640,7 @@ color_t distribute_color(int id) {
|
|||||||
return v;
|
return v;
|
||||||
}
|
}
|
||||||
|
|
||||||
void do_viewdist(cell *c, const transmatrix& V, color_t& wcol, color_t& fcol) {
|
EX void do_viewdist(cell *c, const transmatrix& V, color_t& wcol, color_t& fcol) {
|
||||||
if(behindsphere(V)) return;
|
if(behindsphere(V)) return;
|
||||||
|
|
||||||
int cd = (use_color_codes || number_coding == ncDistance || number_coding == ncDebug) ? curr_dist(c) : 0;
|
int cd = (use_color_codes || number_coding == ncDistance || number_coding == ncDebug) ? curr_dist(c) : 0;
|
||||||
@ -680,7 +682,7 @@ void do_viewdist(cell *c, const transmatrix& V, color_t& wcol, color_t& fcol) {
|
|||||||
queuestr(V, (isize(label) > 1 ? .6 : 1), label, 0xFF000000 + dc, 1);
|
queuestr(V, (isize(label) > 1 ? .6 : 1), label, 0xFF000000 + dc, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
void viewdist_configure_dialog() {
|
EX void viewdist_configure_dialog() {
|
||||||
dialog::init("");
|
dialog::init("");
|
||||||
cmode |= sm::SIDE | sm::MAYDARK | sm::EXPANSION;
|
cmode |= sm::SIDE | sm::MAYDARK | sm::EXPANSION;
|
||||||
gamescreen(0);
|
gamescreen(0);
|
||||||
@ -832,7 +834,7 @@ void expansion_analyzer::view_distances_dialog() {
|
|||||||
dialog::display();
|
dialog::display();
|
||||||
}
|
}
|
||||||
|
|
||||||
void enable_viewdists() {
|
EX void enable_viewdists() {
|
||||||
first_distance = 0;
|
first_distance = 0;
|
||||||
scrolltime = 0;
|
scrolltime = 0;
|
||||||
viewdists = true;
|
viewdists = true;
|
||||||
|
@ -28,9 +28,6 @@ struct fgeomextra {
|
|||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
extern int subpathid;
|
|
||||||
extern int subpathorder;
|
|
||||||
|
|
||||||
bool isprime(int n) {
|
bool isprime(int n) {
|
||||||
for(int k=2; k<n; k++) if(n%k == 0) return false;
|
for(int k=2; k<n; k++) if(n%k == 0) return false;
|
||||||
return true;
|
return true;
|
||||||
@ -733,7 +730,7 @@ void fpattern::findsubpath() {
|
|||||||
|
|
||||||
fpattern fp43(43);
|
fpattern fp43(43);
|
||||||
|
|
||||||
void info() {
|
EX void info() {
|
||||||
fpattern fp(0);
|
fpattern fp(0);
|
||||||
int cases = 0, hard = 0;
|
int cases = 0, hard = 0;
|
||||||
for(int p=0; p<500; p++) {
|
for(int p=0; p<500; p++) {
|
||||||
@ -798,6 +795,10 @@ EX struct fpattern& getcurrfp() {
|
|||||||
return fp_invalid;
|
return fp_invalid;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// todo undefined behavior
|
||||||
|
EX int subpathid = currfp.matcode[currfp.strtomatrix("RRRPRRRRRPRRRP")];
|
||||||
|
EX int subpathorder = currfp.order(currfp.matrices[subpathid]);
|
||||||
|
|
||||||
// extra information for field quotient extra configuration
|
// extra information for field quotient extra configuration
|
||||||
|
|
||||||
EX vector<fgeomextra> fgeomextras = {
|
EX vector<fgeomextra> fgeomextras = {
|
||||||
@ -815,7 +816,7 @@ EX vector<fgeomextra> fgeomextras = {
|
|||||||
|
|
||||||
EX int current_extra = 0;
|
EX int current_extra = 0;
|
||||||
|
|
||||||
void nextPrime(fgeomextra& ex) {
|
EX void nextPrime(fgeomextra& ex) {
|
||||||
dynamicval<eGeometry> g(geometry, ex.base);
|
dynamicval<eGeometry> g(geometry, ex.base);
|
||||||
int nextprime;
|
int nextprime;
|
||||||
if(isize(ex.primes))
|
if(isize(ex.primes))
|
||||||
@ -835,7 +836,7 @@ void nextPrime(fgeomextra& ex) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void nextPrimes(fgeomextra& ex) {
|
EX void nextPrimes(fgeomextra& ex) {
|
||||||
while(isize(ex.primes) < 4)
|
while(isize(ex.primes) < 4)
|
||||||
nextPrime(ex);
|
nextPrime(ex);
|
||||||
}
|
}
|
||||||
|
@ -745,21 +745,21 @@ EX namespace gp {
|
|||||||
|
|
||||||
qfloorinfo qfi;
|
qfloorinfo qfi;
|
||||||
|
|
||||||
void set_no_floor() {
|
EX void set_no_floor() {
|
||||||
qfi.fshape = NULL;
|
qfi.fshape = NULL;
|
||||||
qfi.shape = NULL;
|
qfi.shape = NULL;
|
||||||
qfi.tinf = NULL;
|
qfi.tinf = NULL;
|
||||||
qfi.usershape = -1;
|
qfi.usershape = -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
void set_floor(floorshape& sh) {
|
EX void set_floor(floorshape& sh) {
|
||||||
qfi.fshape = &sh;
|
qfi.fshape = &sh;
|
||||||
qfi.shape = NULL;
|
qfi.shape = NULL;
|
||||||
qfi.tinf = NULL;
|
qfi.tinf = NULL;
|
||||||
qfi.usershape = -1;
|
qfi.usershape = -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
void set_floor(hpcshape& sh) {
|
EX void set_floor(hpcshape& sh) {
|
||||||
qfi.shape = &sh;
|
qfi.shape = &sh;
|
||||||
qfi.fshape = NULL;
|
qfi.fshape = NULL;
|
||||||
qfi.spin = Id;
|
qfi.spin = Id;
|
||||||
@ -767,7 +767,7 @@ void set_floor(hpcshape& sh) {
|
|||||||
qfi.usershape = -1;
|
qfi.usershape = -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
void set_floor(const transmatrix& spin, hpcshape& sh) {
|
EX void set_floor(const transmatrix& spin, hpcshape& sh) {
|
||||||
qfi.shape = &sh;
|
qfi.shape = &sh;
|
||||||
qfi.fshape = NULL;
|
qfi.fshape = NULL;
|
||||||
qfi.spin = spin;
|
qfi.spin = spin;
|
||||||
@ -801,7 +801,7 @@ EX int shvid(cell *c) {
|
|||||||
return ctof(c);
|
return ctof(c);
|
||||||
}
|
}
|
||||||
|
|
||||||
dqi_poly *draw_shapevec(cell *c, const transmatrix& V, const vector<hpcshape> &shv, color_t col, PPR prio = PPR::DEFAULT) {
|
EX struct dqi_poly *draw_shapevec(cell *c, const transmatrix& V, const vector<hpcshape> &shv, color_t col, PPR prio IS(PPR::DEFAULT)) {
|
||||||
if(!c) return &queuepolyat(V, shv[0], col, prio);
|
if(!c) return &queuepolyat(V, shv[0], col, prio);
|
||||||
else if(WDIM == 3) return NULL;
|
else if(WDIM == 3) return NULL;
|
||||||
#if CAP_GP
|
#if CAP_GP
|
||||||
@ -837,7 +837,7 @@ dqi_poly *draw_shapevec(cell *c, const transmatrix& V, const vector<hpcshape> &s
|
|||||||
return &queuepolyat(V, shv[shvid(c)], col, prio);
|
return &queuepolyat(V, shv[shvid(c)], col, prio);
|
||||||
}
|
}
|
||||||
|
|
||||||
void draw_floorshape(cell *c, const transmatrix& V, const floorshape &fsh, color_t col, PPR prio = PPR::DEFAULT) {
|
EX void draw_floorshape(cell *c, const transmatrix& V, const floorshape &fsh, color_t col, PPR prio IS(PPR::DEFAULT)) {
|
||||||
draw_shapevec(c, V, fsh.b, col, prio);
|
draw_shapevec(c, V, fsh.b, col, prio);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -859,8 +859,8 @@ EX void draw_qfi(cell *c, const transmatrix& V, color_t col, PPR prio IS(PPR::DE
|
|||||||
else draw_shapevec(c, V, (qfi.fshape->*tab), col, prio);
|
else draw_shapevec(c, V, (qfi.fshape->*tab), col, prio);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool floorshape_debug;
|
EX bool floorshape_debug;
|
||||||
void viewmat() {
|
EX void viewmat() {
|
||||||
if(floorshape_debug) {
|
if(floorshape_debug) {
|
||||||
transmatrix V = ggmatrix(cwt.at);
|
transmatrix V = ggmatrix(cwt.at);
|
||||||
|
|
||||||
|
29
game.cpp
29
game.cpp
@ -106,7 +106,7 @@ EX void createNoise(int t) {
|
|||||||
|
|
||||||
EX int currentLocalTreasure;
|
EX int currentLocalTreasure;
|
||||||
|
|
||||||
bool landvisited[landtypes];
|
EX bool landvisited[landtypes];
|
||||||
|
|
||||||
bool eq(short a, short b) { return a==b; }
|
bool eq(short a, short b) { return a==b; }
|
||||||
|
|
||||||
@ -140,7 +140,7 @@ EX vector<cell*> offscreen;
|
|||||||
EX vector<cell*> pathqm;
|
EX vector<cell*> pathqm;
|
||||||
|
|
||||||
/** list of cells that the monsters are targetting (PCs, allies, Thumpers, etc.) */
|
/** list of cells that the monsters are targetting (PCs, allies, Thumpers, etc.) */
|
||||||
vector<cell*> targets;
|
EX vector<cell*> targets;
|
||||||
|
|
||||||
/** monsters of specific types to move */
|
/** monsters of specific types to move */
|
||||||
vector<cell*> worms, ivies, ghosts, golems, hexsnakes;
|
vector<cell*> worms, ivies, ghosts, golems, hexsnakes;
|
||||||
@ -175,7 +175,7 @@ EX inline bool singleused() { return !(shmup::on || multi::players > 1); }
|
|||||||
*
|
*
|
||||||
* This ensures that the game should unfold exactly the same if given the same seed and the same input.
|
* This ensures that the game should unfold exactly the same if given the same seed and the same input.
|
||||||
*/
|
*/
|
||||||
std::mt19937 hrngen;
|
EX std::mt19937 hrngen;
|
||||||
|
|
||||||
/** initialize \link hrngen \endlink */
|
/** initialize \link hrngen \endlink */
|
||||||
EX void shrand(int i) {
|
EX void shrand(int i) {
|
||||||
@ -448,7 +448,7 @@ enum eGravity { gsNormal, gsLevitation, gsAnti };
|
|||||||
#endif
|
#endif
|
||||||
EX eGravity gravity_state, last_gravity_state;
|
EX eGravity gravity_state, last_gravity_state;
|
||||||
|
|
||||||
bool bird_disruption(cell *c) {
|
EX bool bird_disruption(cell *c) {
|
||||||
return c->cpdist <= 5 && items[itOrbGravity];
|
return c->cpdist <= 5 && items[itOrbGravity];
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1473,8 +1473,6 @@ EX bool monstersnear(stalemate1& sm) {
|
|||||||
return !!res;
|
return !!res;
|
||||||
}
|
}
|
||||||
|
|
||||||
namespace multi { bool aftermove; }
|
|
||||||
|
|
||||||
EX bool monstersnear2();
|
EX bool monstersnear2();
|
||||||
|
|
||||||
EX int lastkills;
|
EX int lastkills;
|
||||||
@ -1497,7 +1495,10 @@ EX bool multimove() {
|
|||||||
return b;
|
return b;
|
||||||
}
|
}
|
||||||
|
|
||||||
namespace multi { bool checkonly = false; }
|
EX namespace multi {
|
||||||
|
EX bool checkonly = false;
|
||||||
|
EX bool aftermove;
|
||||||
|
EX }
|
||||||
|
|
||||||
EX bool swordConflict(const stalemate1& sm1, const stalemate1& sm2) {
|
EX bool swordConflict(const stalemate1& sm1, const stalemate1& sm2) {
|
||||||
if(items[itOrbSword] || items[itOrbSword2])
|
if(items[itOrbSword] || items[itOrbSword2])
|
||||||
@ -2834,7 +2835,7 @@ EX void findWormIvy(cell *c) {
|
|||||||
|
|
||||||
bool bugsfighting;
|
bool bugsfighting;
|
||||||
|
|
||||||
bool keepLightning = false;
|
EX bool keepLightning = false;
|
||||||
|
|
||||||
EX int statuecount;
|
EX int statuecount;
|
||||||
|
|
||||||
@ -6633,7 +6634,7 @@ EX void activateSafety(eLand l) {
|
|||||||
restartGraph();
|
restartGraph();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool legalmoves[MAX_EDGE+1];
|
EX bool legalmoves[MAX_EDGE+1];
|
||||||
|
|
||||||
EX bool hasSafeOrb(cell *c) {
|
EX bool hasSafeOrb(cell *c) {
|
||||||
return
|
return
|
||||||
@ -7584,7 +7585,7 @@ EX void knightFlavorMessage(cell *c2) {
|
|||||||
msgid++;
|
msgid++;
|
||||||
}
|
}
|
||||||
|
|
||||||
int mine_adjacency_rule = 0;
|
EX int mine_adjacency_rule = 0;
|
||||||
|
|
||||||
EX map<cell*, vector<cell*>> adj_memo;
|
EX map<cell*, vector<cell*>> adj_memo;
|
||||||
|
|
||||||
@ -7677,7 +7678,7 @@ EX bool uncoverMines(cell *c, int lev, int dist, bool just_checking) {
|
|||||||
return b;
|
return b;
|
||||||
}
|
}
|
||||||
|
|
||||||
namespace orbbull {
|
EX namespace orbbull {
|
||||||
cell *prev[MAXPLAYER];
|
cell *prev[MAXPLAYER];
|
||||||
eLastmovetype prevtype[MAXPLAYER];
|
eLastmovetype prevtype[MAXPLAYER];
|
||||||
int count;
|
int count;
|
||||||
@ -7688,7 +7689,7 @@ namespace orbbull {
|
|||||||
return lp >= 0 && ln >= 0 && anglestraight(c2, lp, ln);
|
return lp >= 0 && ln >= 0 && anglestraight(c2, lp, ln);
|
||||||
}
|
}
|
||||||
|
|
||||||
void gainBullPowers() {
|
EX void gainBullPowers() {
|
||||||
items[itOrbShield]++; orbused[itOrbShield] = true;
|
items[itOrbShield]++; orbused[itOrbShield] = true;
|
||||||
items[itOrbThorns]++; orbused[itOrbThorns] = true;
|
items[itOrbThorns]++; orbused[itOrbThorns] = true;
|
||||||
items[itOrbHorns]++; orbused[itOrbHorns] = true;
|
items[itOrbHorns]++; orbused[itOrbHorns] = true;
|
||||||
@ -7725,7 +7726,7 @@ namespace orbbull {
|
|||||||
}
|
}
|
||||||
else count = 0;
|
else count = 0;
|
||||||
}
|
}
|
||||||
}
|
EX }
|
||||||
|
|
||||||
#if HDR
|
#if HDR
|
||||||
// predictable or not
|
// predictable or not
|
||||||
@ -7951,7 +7952,7 @@ EX bool havePushConflict(cell *pushto, bool checkonly) {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
cell *global_pushto;
|
EX cell *global_pushto;
|
||||||
|
|
||||||
EX void killFriendlyIvy() {
|
EX void killFriendlyIvy() {
|
||||||
forCellEx(c2, cwt.at) if(c2->monst == moFriendlyIvy)
|
forCellEx(c2, cwt.at) if(c2->monst == moFriendlyIvy)
|
||||||
|
@ -281,7 +281,7 @@ void validity_info() {
|
|||||||
dialog::addBreak(100);
|
dialog::addBreak(100);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool showquotients;
|
EX bool showquotients;
|
||||||
|
|
||||||
string validclasses[4] = {" (X)", " (½)", "", " (!)"};
|
string validclasses[4] = {" (X)", " (½)", "", " (!)"};
|
||||||
|
|
||||||
|
@ -648,7 +648,7 @@ EX namespace geom3 {
|
|||||||
if(GDIM == 3) return vid.depth - lev;
|
if(GDIM == 3) return vid.depth - lev;
|
||||||
return projection_to_factor(lev_to_projection(lev));
|
return projection_to_factor(lev_to_projection(lev));
|
||||||
}
|
}
|
||||||
ld factor_to_lev(ld fac) {
|
EX ld factor_to_lev(ld fac) {
|
||||||
if(prod) return -fac;
|
if(prod) return -fac;
|
||||||
if(GDIM == 3) return fac;
|
if(GDIM == 3) return fac;
|
||||||
return vid.depth - projection_to_abslev(factor_to_projection(fac));
|
return vid.depth - projection_to_abslev(factor_to_projection(fac));
|
||||||
@ -666,7 +666,7 @@ EX namespace geom3 {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// how should we scale at level lev
|
// how should we scale at level lev
|
||||||
ld scale_at_lev(ld lev) {
|
EX ld scale_at_lev(ld lev) {
|
||||||
if(sphere || euclid) return 1;
|
if(sphere || euclid) return 1;
|
||||||
return cosh(vid.depth - lev);
|
return cosh(vid.depth - lev);
|
||||||
}
|
}
|
||||||
|
@ -10,14 +10,14 @@ namespace hr {
|
|||||||
|
|
||||||
transmatrix &ggmatrix(cell *c);
|
transmatrix &ggmatrix(cell *c);
|
||||||
|
|
||||||
void fixelliptic(transmatrix& at) {
|
EX void fixelliptic(transmatrix& at) {
|
||||||
if(elliptic && at[LDIM][LDIM] < 0) {
|
if(elliptic && at[LDIM][LDIM] < 0) {
|
||||||
for(int i=0; i<MDIM; i++) for(int j=0; j<MDIM; j++)
|
for(int i=0; i<MDIM; i++) for(int j=0; j<MDIM; j++)
|
||||||
at[i][j] = -at[i][j];
|
at[i][j] = -at[i][j];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void fixelliptic(hyperpoint& h) {
|
EX void fixelliptic(hyperpoint& h) {
|
||||||
if(elliptic && h[LDIM] < 0)
|
if(elliptic && h[LDIM] < 0)
|
||||||
for(int i=0; i<MDIM; i++) h[i] = -h[i];
|
for(int i=0; i<MDIM; i++) h[i] = -h[i];
|
||||||
}
|
}
|
||||||
|
@ -74,9 +74,9 @@ EX bool auraNOGL; // aura without GL
|
|||||||
int axestate;
|
int axestate;
|
||||||
|
|
||||||
EX int ticks;
|
EX int ticks;
|
||||||
int frameid;
|
EX int frameid;
|
||||||
|
|
||||||
bool camelotcheat;
|
EX bool camelotcheat;
|
||||||
EX bool nomap;
|
EX bool nomap;
|
||||||
|
|
||||||
EX eItem orbToTarget;
|
EX eItem orbToTarget;
|
||||||
@ -3489,7 +3489,6 @@ void setcolors(cell *c, color_t& wcol, color_t& fcol) {
|
|||||||
|
|
||||||
#if CAP_COMPLEX2
|
#if CAP_COMPLEX2
|
||||||
case laBrownian: {
|
case laBrownian: {
|
||||||
using brownian::level;
|
|
||||||
fcol = wcol =
|
fcol = wcol =
|
||||||
/*
|
/*
|
||||||
c->landparam == 0 ? 0x0000F0 :
|
c->landparam == 0 ? 0x0000F0 :
|
||||||
@ -7528,7 +7527,7 @@ EX void drawmovestar(double dx, double dy) {
|
|||||||
|
|
||||||
// old style joystick control
|
// old style joystick control
|
||||||
|
|
||||||
bool dronemode;
|
EX bool dronemode;
|
||||||
|
|
||||||
purehookset hooks_calcparam;
|
purehookset hooks_calcparam;
|
||||||
|
|
||||||
|
14
help.cpp
14
help.cpp
@ -224,7 +224,7 @@ string princedesc() {
|
|||||||
return XLAT("Apparently a princess is kept locked somewhere, but you won't ever find her in this hyperbolic palace. ");
|
return XLAT("Apparently a princess is kept locked somewhere, but you won't ever find her in this hyperbolic palace. ");
|
||||||
}
|
}
|
||||||
|
|
||||||
string helptitle(string s, color_t col) {
|
EX string helptitle(string s, color_t col) {
|
||||||
return "@" + its(col) + "\t" + s + "\n";
|
return "@" + its(col) + "\t" + s + "\n";
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -482,7 +482,7 @@ void addMinefieldExplanation(string& s) {
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
string generateHelpForWall(eWall w) {
|
EX string generateHelpForWall(eWall w) {
|
||||||
|
|
||||||
string s = helptitle(XLATN(winf[w].name), winf[w].color);
|
string s = helptitle(XLATN(winf[w].name), winf[w].color);
|
||||||
|
|
||||||
@ -502,7 +502,7 @@ void buteol(string& s, int current, int req) {
|
|||||||
s += buf; s += "\n";
|
s += buf; s += "\n";
|
||||||
}
|
}
|
||||||
|
|
||||||
string generateHelpForMonster(eMonster m) {
|
EX string generateHelpForMonster(eMonster m) {
|
||||||
string s = helptitle(XLATN(minf[m].name), minf[m].color);
|
string s = helptitle(XLATN(minf[m].name), minf[m].color);
|
||||||
|
|
||||||
if(m == moPlayer) {
|
if(m == moPlayer) {
|
||||||
@ -705,7 +705,7 @@ string generateHelpForLand(eLand l) {
|
|||||||
return s;
|
return s;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool instat;
|
EX bool instat;
|
||||||
|
|
||||||
string turnstring(int i) {
|
string turnstring(int i) {
|
||||||
if(i == 1) return XLAT("1 turn");
|
if(i == 1) return XLAT("1 turn");
|
||||||
@ -713,7 +713,7 @@ string turnstring(int i) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
reaction_t helpgenerator;
|
reaction_t helpgenerator;
|
||||||
string bygen(reaction_t h) {
|
EX string bygen(reaction_t h) {
|
||||||
helpgenerator = h;
|
helpgenerator = h;
|
||||||
return "HELPGEN";
|
return "HELPGEN";
|
||||||
}
|
}
|
||||||
@ -732,7 +732,7 @@ void gotoHelpFor(eMonster m) {
|
|||||||
help = generateHelpForMonster(m);
|
help = generateHelpForMonster(m);
|
||||||
};
|
};
|
||||||
|
|
||||||
void appendHelp(string s) {
|
EX void appendHelp(string s) {
|
||||||
auto h = helpgenerator;
|
auto h = helpgenerator;
|
||||||
if(help == "HELPGEN")
|
if(help == "HELPGEN")
|
||||||
bygen([h,s] { h(); help += s; });
|
bygen([h,s] { h(); help += s; });
|
||||||
@ -954,7 +954,7 @@ EX void showHelp() {
|
|||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
hookset<bool()> *hooks_default_help;
|
EX hookset<bool()> *hooks_default_help;
|
||||||
|
|
||||||
EX void gotoHelp(const string& h) {
|
EX void gotoHelp(const string& h) {
|
||||||
help = h;
|
help = h;
|
||||||
|
@ -24,7 +24,7 @@ cell *newCell(int type, heptagon *master);
|
|||||||
* and sometimes in direction 5
|
* and sometimes in direction 5
|
||||||
*/
|
*/
|
||||||
|
|
||||||
hstate transition(hstate s, int dir) {
|
EX hstate transition(hstate s, int dir) {
|
||||||
if(sphere) {
|
if(sphere) {
|
||||||
if(S7 == 4) {
|
if(S7 == 4) {
|
||||||
if(s == hsOrigin) return dir == 0 ? hsB0 : hsB1;
|
if(s == hsOrigin) return dir == 0 ? hsB0 : hsB1;
|
||||||
|
@ -347,7 +347,7 @@ EX namespace history {
|
|||||||
void restoreBack();
|
void restoreBack();
|
||||||
|
|
||||||
#if CAP_SDL
|
#if CAP_SDL
|
||||||
void createImage(bool dospiral) {
|
EX void createImage(bool dospiral) {
|
||||||
int segid = 1;
|
int segid = 1;
|
||||||
if(includeHistory) restore();
|
if(includeHistory) restore();
|
||||||
|
|
||||||
@ -569,7 +569,7 @@ EX namespace history {
|
|||||||
else if(doexiton(sym, uni)) popScreen();
|
else if(doexiton(sym, uni)) popScreen();
|
||||||
}
|
}
|
||||||
|
|
||||||
set<cell*> inmovehistory, inkillhistory, infindhistory;
|
EX set<cell*> inmovehistory, inkillhistory, infindhistory;
|
||||||
|
|
||||||
EX void restore() {
|
EX void restore() {
|
||||||
inmovehistory.clear();
|
inmovehistory.clear();
|
||||||
|
10
hypgraph.cpp
10
hypgraph.cpp
@ -21,7 +21,7 @@ void ghcheck(hyperpoint &ret, const hyperpoint &H) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void camrotate(ld& hx, ld& hy) {
|
EX void camrotate(ld& hx, ld& hy) {
|
||||||
ld cam = vid.camera_angle * degree;
|
ld cam = vid.camera_angle * degree;
|
||||||
GLfloat cc = cos(cam);
|
GLfloat cc = cos(cam);
|
||||||
GLfloat ss = sin(cam);
|
GLfloat ss = sin(cam);
|
||||||
@ -845,7 +845,7 @@ EX transmatrix mirrorif(const transmatrix& V, bool b) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// -1 if away, 0 if not away
|
// -1 if away, 0 if not away
|
||||||
int away(const transmatrix& V2) {
|
EX int away(const transmatrix& V2) {
|
||||||
return (intval(C0, V2 * xpush0(.1)) > intval(C0, tC0(V2))) ? -1 : 0;
|
return (intval(C0, V2 * xpush0(.1)) > intval(C0, tC0(V2))) ? -1 : 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -856,7 +856,7 @@ int away(const transmatrix& V2) {
|
|||||||
return lev_to_factor(fo1 + (fo2-fo1) * nom / den);
|
return lev_to_factor(fo1 + (fo2-fo1) * nom / den);
|
||||||
} */
|
} */
|
||||||
|
|
||||||
double zgrad0(double l1, double l2, int nom, int den) {
|
EX double zgrad0(double l1, double l2, int nom, int den) {
|
||||||
using namespace geom3;
|
using namespace geom3;
|
||||||
return lev_to_factor(l1 + (l2-l1) * nom / den);
|
return lev_to_factor(l1 + (l2-l1) * nom / den);
|
||||||
}
|
}
|
||||||
@ -883,7 +883,7 @@ ld to01(ld a0, ld a1, ld x) {
|
|||||||
return (x-a0) / (a1-a0);
|
return (x-a0) / (a1-a0);
|
||||||
}
|
}
|
||||||
|
|
||||||
ld spherity(const hyperpoint& h) {
|
EX ld spherity(const hyperpoint& h) {
|
||||||
if(!sphere) return 1;
|
if(!sphere) return 1;
|
||||||
|
|
||||||
if(vid.alpha > 1) {
|
if(vid.alpha > 1) {
|
||||||
@ -901,7 +901,7 @@ EX bool behindsphere(const transmatrix& V) {
|
|||||||
return behindsphere(tC0(V));
|
return behindsphere(tC0(V));
|
||||||
}
|
}
|
||||||
|
|
||||||
ld spherity(const transmatrix& V) {
|
EX ld spherity(const transmatrix& V) {
|
||||||
return spherity(tC0(V));
|
return spherity(tC0(V));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -87,7 +87,7 @@ bool clockwise(hyperpoint h1, hyperpoint h2) {
|
|||||||
return h1[0] * h2[1] > h1[1] * h2[0];
|
return h1[0] * h2[1] > h1[1] * h2[0];
|
||||||
}
|
}
|
||||||
|
|
||||||
map<heptagon*, vector<int> > cells_of_heptagon;
|
EX map<heptagon*, vector<int> > cells_of_heptagon;
|
||||||
|
|
||||||
int runlevel;
|
int runlevel;
|
||||||
vector<ld> edgelens, distlens;
|
vector<ld> edgelens, distlens;
|
||||||
|
@ -22,15 +22,18 @@ EX namespace mapeditor {
|
|||||||
eFront front_config;
|
eFront front_config;
|
||||||
ld front_step = 0.1;
|
ld front_step = 0.1;
|
||||||
|
|
||||||
|
#if HDR
|
||||||
struct editwhat {
|
struct editwhat {
|
||||||
double dist;
|
double dist;
|
||||||
int rotid, symid, pointid;
|
int rotid, symid, pointid;
|
||||||
bool side;
|
bool side;
|
||||||
cell *c;
|
cell *c;
|
||||||
} ew, ewsearch;
|
};
|
||||||
bool autochoose = ISMOBILE;
|
#endif
|
||||||
|
EX editwhat ew, ewsearch;
|
||||||
|
EX bool autochoose = ISMOBILE;
|
||||||
|
|
||||||
void scaleall(ld z) {
|
EX void scaleall(ld z) {
|
||||||
|
|
||||||
// (mx,my) = (xcb,ycb) + ss * (xpos,ypos) + (mrx,mry) * scale
|
// (mx,my) = (xcb,ycb) + ss * (xpos,ypos) + (mrx,mry) * scale
|
||||||
|
|
||||||
@ -1094,7 +1097,7 @@ namespace mapeditor {
|
|||||||
// fake key sent to change the color
|
// fake key sent to change the color
|
||||||
static const int COLORKEY = (-10000);
|
static const int COLORKEY = (-10000);
|
||||||
|
|
||||||
transmatrix drawtrans, drawtransnew;
|
EX transmatrix drawtrans, drawtransnew;
|
||||||
|
|
||||||
#if CAP_POLY
|
#if CAP_POLY
|
||||||
void loadShape(int sg, int id, hpcshape& sh, int d, int layer) {
|
void loadShape(int sg, int id, hpcshape& sh, int d, int layer) {
|
||||||
@ -1106,7 +1109,7 @@ namespace mapeditor {
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
void drawGhosts(cell *c, const transmatrix& V, int ct) {
|
EX void drawGhosts(cell *c, const transmatrix& V, int ct) {
|
||||||
}
|
}
|
||||||
|
|
||||||
hyperpoint ccenter = C0;
|
hyperpoint ccenter = C0;
|
||||||
@ -1158,7 +1161,7 @@ namespace mapeditor {
|
|||||||
int parallels = 12, meridians = 6;
|
int parallels = 12, meridians = 6;
|
||||||
ld equi_range = 1;
|
ld equi_range = 1;
|
||||||
|
|
||||||
void drawGrid() {
|
EX void drawGrid() {
|
||||||
color_t lightgrid = gridcolor;
|
color_t lightgrid = gridcolor;
|
||||||
lightgrid -= (lightgrid & 0xFF) / 2;
|
lightgrid -= (lightgrid & 0xFF) / 2;
|
||||||
transmatrix d2 = drawtrans * rgpushxto0(ccenter) * rspintox(gpushxto0(ccenter) * coldcenter);
|
transmatrix d2 = drawtrans * rgpushxto0(ccenter) * rspintox(gpushxto0(ccenter) * coldcenter);
|
||||||
@ -2102,7 +2105,7 @@ namespace mapeditor {
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if CAP_POLY
|
#if CAP_POLY
|
||||||
bool haveUserShape(eShapegroup group, int id) {
|
EX bool haveUserShape(eShapegroup group, int id) {
|
||||||
#if !CAP_EDIT
|
#if !CAP_EDIT
|
||||||
return false;
|
return false;
|
||||||
#else
|
#else
|
||||||
@ -2112,7 +2115,7 @@ namespace mapeditor {
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if CAP_TEXTURE
|
#if CAP_TEXTURE
|
||||||
void draw_texture_ghosts(cell *c, const transmatrix& V) {
|
EX void draw_texture_ghosts(cell *c, const transmatrix& V) {
|
||||||
if(!c) return;
|
if(!c) return;
|
||||||
if(holdmouse && !lstartcell) return;
|
if(holdmouse && !lstartcell) return;
|
||||||
cell *ls = lstartcell ? lstartcell : lmouseover;
|
cell *ls = lstartcell ? lstartcell : lmouseover;
|
||||||
|
@ -643,7 +643,7 @@ EX bool showHalloween() {
|
|||||||
|
|
||||||
int daily_mode;
|
int daily_mode;
|
||||||
|
|
||||||
purehookset hooks_startmenu;
|
EX purehookset hooks_startmenu;
|
||||||
|
|
||||||
EX void showStartMenu() {
|
EX void showStartMenu() {
|
||||||
if(!daily_mode) {
|
if(!daily_mode) {
|
||||||
@ -923,8 +923,8 @@ EX named_functionality get_o_key() {
|
|||||||
return named_dialog(XLAT("world overview"), showOverview);
|
return named_dialog(XLAT("world overview"), showOverview);
|
||||||
}
|
}
|
||||||
|
|
||||||
int messagelogpos;
|
EX int messagelogpos;
|
||||||
int timeformat;
|
EX int timeformat;
|
||||||
EX int stampbase;
|
EX int stampbase;
|
||||||
|
|
||||||
EX string gettimestamp(msginfo& m) {
|
EX string gettimestamp(msginfo& m) {
|
||||||
|
14
models.cpp
14
models.cpp
@ -104,7 +104,7 @@ EX namespace polygonal {
|
|||||||
return make_pair(real(res), imag(res));
|
return make_pair(real(res), imag(res));
|
||||||
}
|
}
|
||||||
|
|
||||||
pair<ld, ld> compute(ld x, ld y) { return compute(x,y,deg); }
|
EX pair<ld, ld> compute(ld x, ld y) { return compute(x,y,deg); }
|
||||||
EX }
|
EX }
|
||||||
|
|
||||||
#if HDR
|
#if HDR
|
||||||
@ -152,13 +152,13 @@ EX namespace models {
|
|||||||
int spiral_id = 7;
|
int spiral_id = 7;
|
||||||
EX bool use_atan = false;
|
EX bool use_atan = false;
|
||||||
|
|
||||||
cld spiral_multiplier;
|
EX cld spiral_multiplier;
|
||||||
ld right_spiral_multiplier = 1;
|
EX ld right_spiral_multiplier = 1;
|
||||||
ld any_spiral_multiplier = 1;
|
EX ld any_spiral_multiplier = 1;
|
||||||
ld sphere_spiral_multiplier = 2;
|
EX ld sphere_spiral_multiplier = 2;
|
||||||
EX ld spiral_cone = 360;
|
EX ld spiral_cone = 360;
|
||||||
ld spiral_cone_rad;
|
EX ld spiral_cone_rad;
|
||||||
bool ring_not_spiral;
|
EX bool ring_not_spiral;
|
||||||
|
|
||||||
EX void configure() {
|
EX void configure() {
|
||||||
ld ball = -vid.ballangle * degree;
|
ld ball = -vid.ballangle * degree;
|
||||||
|
34
multi.cpp
34
multi.cpp
@ -55,10 +55,10 @@ EX namespace multi {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
transmatrix whereis[MAXPLAYER];
|
EX transmatrix whereis[MAXPLAYER];
|
||||||
transmatrix crosscenter[MAXPLAYER];
|
EX transmatrix crosscenter[MAXPLAYER];
|
||||||
double ccdist[MAXPLAYER];
|
EX double ccdist[MAXPLAYER];
|
||||||
cell *ccat[MAXPLAYER];
|
EX cell *ccat[MAXPLAYER];
|
||||||
|
|
||||||
bool combo[MAXPLAYER];
|
bool combo[MAXPLAYER];
|
||||||
|
|
||||||
@ -67,7 +67,7 @@ EX namespace multi {
|
|||||||
|
|
||||||
EX movedir whereto[MAXPLAYER]; // player's target cell
|
EX movedir whereto[MAXPLAYER]; // player's target cell
|
||||||
|
|
||||||
double mdx[MAXPLAYER], mdy[MAXPLAYER]; // movement vector for the next move
|
EX double mdx[MAXPLAYER], mdy[MAXPLAYER]; // movement vector for the next move
|
||||||
|
|
||||||
static const int CMDS = 15;
|
static const int CMDS = 15;
|
||||||
static const int CMDS_PAN = 11;
|
static const int CMDS_PAN = 11;
|
||||||
@ -109,9 +109,11 @@ EX namespace multi {
|
|||||||
"scroll forward", "scroll backward"
|
"scroll forward", "scroll backward"
|
||||||
};
|
};
|
||||||
|
|
||||||
|
#if HDR
|
||||||
#define SHMUPAXES_BASE 4
|
#define SHMUPAXES_BASE 4
|
||||||
#define SHMUPAXES ((SHMUPAXES_BASE) + 4 * (MAXPLAYER))
|
#define SHMUPAXES ((SHMUPAXES_BASE) + 4 * (MAXPLAYER))
|
||||||
#define SHMUPAXES_CUR ((SHMUPAXES_BASE) + 4 * playercfg)
|
#define SHMUPAXES_CUR ((SHMUPAXES_BASE) + 4 * playercfg)
|
||||||
|
#endif
|
||||||
|
|
||||||
const char* axemodes[SHMUPAXES] = {
|
const char* axemodes[SHMUPAXES] = {
|
||||||
"do nothing",
|
"do nothing",
|
||||||
@ -155,7 +157,7 @@ const char* axemodes3[4] = {
|
|||||||
"camera rotate Y"
|
"camera rotate Y"
|
||||||
};
|
};
|
||||||
|
|
||||||
int centerplayer = -1;
|
EX int centerplayer = -1;
|
||||||
|
|
||||||
char* axeconfigs[24]; int numaxeconfigs;
|
char* axeconfigs[24]; int numaxeconfigs;
|
||||||
int* dzconfigs[24];
|
int* dzconfigs[24];
|
||||||
@ -195,7 +197,7 @@ string dsc(int id) {
|
|||||||
return buf;
|
return buf;
|
||||||
}
|
}
|
||||||
|
|
||||||
void resetScores() {
|
EX void resetScores() {
|
||||||
for(int i=0; i<MAXPLAYER; i++)
|
for(int i=0; i<MAXPLAYER; i++)
|
||||||
multi::treasures[i] = multi::kills[i] = multi::deaths[i] = 0;
|
multi::treasures[i] = multi::kills[i] = multi::deaths[i] = 0;
|
||||||
}
|
}
|
||||||
@ -204,7 +206,7 @@ bool configdead;
|
|||||||
|
|
||||||
void handleConfig(int sym, int uni);
|
void handleConfig(int sym, int uni);
|
||||||
|
|
||||||
string player_count_name(int p) {
|
EX string player_count_name(int p) {
|
||||||
return XLAT(
|
return XLAT(
|
||||||
p == 2 ? "two players" :
|
p == 2 ? "two players" :
|
||||||
p == 3 ? "three players" :
|
p == 3 ? "three players" :
|
||||||
@ -300,6 +302,8 @@ struct key_configurer {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
EX reaction_t get_key_configurer(int sc, vector<string>& sct) { return key_configurer(sc, sct); }
|
||||||
|
|
||||||
#if CAP_SDLJOY
|
#if CAP_SDLJOY
|
||||||
struct joy_configurer {
|
struct joy_configurer {
|
||||||
|
|
||||||
@ -510,6 +514,7 @@ EX void showConfigureMultiplayer() {
|
|||||||
dialog::display();
|
dialog::display();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if HDR
|
||||||
#define NUMACT 128
|
#define NUMACT 128
|
||||||
|
|
||||||
enum pcmds {
|
enum pcmds {
|
||||||
@ -518,15 +523,16 @@ enum pcmds {
|
|||||||
pcFire, pcFace, pcFaceFire,
|
pcFire, pcFace, pcFaceFire,
|
||||||
pcDrop, pcCenter, pcOrbPower, pcOrbKey
|
pcDrop, pcCenter, pcOrbPower, pcOrbKey
|
||||||
};
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
int actionspressed[NUMACT], axespressed[SHMUPAXES], lactionpressed[NUMACT];
|
EX int actionspressed[NUMACT], axespressed[SHMUPAXES], lactionpressed[NUMACT];
|
||||||
|
|
||||||
void pressaction(int id) {
|
void pressaction(int id) {
|
||||||
if(id >= 0 && id < NUMACT)
|
if(id >= 0 && id < NUMACT)
|
||||||
actionspressed[id]++;
|
actionspressed[id]++;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool notremapped(int sym) {
|
EX bool notremapped(int sym) {
|
||||||
int k = scfg.keyaction[sym];
|
int k = scfg.keyaction[sym];
|
||||||
if(k == 0) return true;
|
if(k == 0) return true;
|
||||||
k /= 16;
|
k /= 16;
|
||||||
@ -652,7 +658,7 @@ EX void initConfig() {
|
|||||||
for(int i=0; i<7; i++) addsaver(multi::scs[i], "player"+its(i));
|
for(int i=0; i<7; i++) addsaver(multi::scs[i], "player"+its(i));
|
||||||
}
|
}
|
||||||
|
|
||||||
void handleInput(int delta) {
|
EX void handleInput(int delta) {
|
||||||
#if CAP_SDL
|
#if CAP_SDL
|
||||||
double d = delta / 500.;
|
double d = delta / 500.;
|
||||||
|
|
||||||
@ -750,7 +756,7 @@ void handleInput(int delta) {
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
int tableid[7] = {1, 2, 4, 5, 6, 7, 8};
|
EX int tableid[7] = {1, 2, 4, 5, 6, 7, 8};
|
||||||
|
|
||||||
EX void leaveGame(int i) {
|
EX void leaveGame(int i) {
|
||||||
multi::player[i].at = NULL;
|
multi::player[i].at = NULL;
|
||||||
@ -795,7 +801,7 @@ void handleInput(int delta) {
|
|||||||
|
|
||||||
bool needinput = true;
|
bool needinput = true;
|
||||||
|
|
||||||
void handleMulti(int delta) {
|
EX void handleMulti(int delta) {
|
||||||
multi::handleInput(delta);
|
multi::handleInput(delta);
|
||||||
|
|
||||||
transmatrix bcwtV = cwtV;
|
transmatrix bcwtV = cwtV;
|
||||||
@ -929,7 +935,7 @@ void handleInput(int delta) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void mousemovement(cell *c) {
|
EX void mousemovement(cell *c) {
|
||||||
if(!c) return;
|
if(!c) return;
|
||||||
int countplayers = 0;
|
int countplayers = 0;
|
||||||
int countplayers_undecided = 0;
|
int countplayers_undecided = 0;
|
||||||
|
14
netgen.cpp
14
netgen.cpp
@ -7,7 +7,9 @@
|
|||||||
|
|
||||||
#include "hyper.h"
|
#include "hyper.h"
|
||||||
#if CAP_MODEL
|
#if CAP_MODEL
|
||||||
namespace hr { namespace netgen {
|
namespace hr {
|
||||||
|
|
||||||
|
EX namespace netgen {
|
||||||
|
|
||||||
// We need a two-dimensional vector class for this.
|
// We need a two-dimensional vector class for this.
|
||||||
|
|
||||||
@ -70,9 +72,9 @@ namespace hr { namespace netgen {
|
|||||||
|
|
||||||
// Use HyperRogue to generate the data (ct, vx, nei).
|
// Use HyperRogue to generate the data (ct, vx, nei).
|
||||||
|
|
||||||
int mode = 0;
|
EX int mode = 0;
|
||||||
|
|
||||||
void buildVertexInfo(cell *c, transmatrix V) {
|
EX void buildVertexInfo(cell *c, transmatrix V) {
|
||||||
|
|
||||||
if(mode == 1)
|
if(mode == 1)
|
||||||
for(int ii=0; ii<CELLS; ii++) if(dcal[ii] == c) {
|
for(int ii=0; ii<CELLS; ii++) if(dcal[ii] == c) {
|
||||||
@ -699,7 +701,7 @@ namespace hr { namespace netgen {
|
|||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
void run() {
|
EX void run() {
|
||||||
if(euclid)
|
if(euclid)
|
||||||
addMessage("Useless in Euclidean geometry.");
|
addMessage("Useless in Euclidean geometry.");
|
||||||
else if(sphere)
|
else if(sphere)
|
||||||
@ -707,5 +709,7 @@ namespace hr { namespace netgen {
|
|||||||
else
|
else
|
||||||
pushScreen(show);
|
pushScreen(show);
|
||||||
}
|
}
|
||||||
}}
|
EX }
|
||||||
|
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
|
@ -785,7 +785,7 @@ EX namespace product {
|
|||||||
|
|
||||||
EX int cwall_offset, cwall_mask, actual_view_level;
|
EX int cwall_offset, cwall_mask, actual_view_level;
|
||||||
|
|
||||||
void drawcell_stack(cell *c, transmatrix V, int spinv, bool mirrored) {
|
EX void drawcell_stack(cell *c, transmatrix V, int spinv, bool mirrored) {
|
||||||
if(sphere) gmatrix[c] = V; /* some computations need gmatrix0 for underlying geometry */
|
if(sphere) gmatrix[c] = V; /* some computations need gmatrix0 for underlying geometry */
|
||||||
bool s = sphere;
|
bool s = sphere;
|
||||||
hybrid::in_actual([&] {
|
hybrid::in_actual([&] {
|
||||||
|
11
pattern2.cpp
11
pattern2.cpp
@ -428,9 +428,6 @@ EX int fieldval_uniq_rand(cell *c, int randval) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
int subpathid = currfp.matcode[currfp.strtomatrix("RRRPRRRRRPRRRP")];
|
|
||||||
int subpathorder = currfp.order(currfp.matrices[subpathid]);
|
|
||||||
|
|
||||||
pair<int, int> subval(cell *c, int _subpathid = subpathid, int _subpathorder = subpathorder) {
|
pair<int, int> subval(cell *c, int _subpathid = subpathid, int _subpathorder = subpathorder) {
|
||||||
if(!ctof(c)) {
|
if(!ctof(c)) {
|
||||||
auto m = subval(createMov(c, 0));
|
auto m = subval(createMov(c, 0));
|
||||||
@ -642,7 +639,7 @@ EX namespace patterns {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
int downdir(cell *c, const cellfunction& cf) {
|
EX int downdir(cell *c, const cellfunction& cf) {
|
||||||
return parent_id(c, 1, cf) + 1;
|
return parent_id(c, 1, cf) + 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1781,7 +1778,7 @@ EX namespace patterns {
|
|||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
void showPrePattern() { showPrePatternP(true); }
|
EX void showPrePattern() { showPrePatternP(true); }
|
||||||
EX void showPrePatternNoninstant() { showPrePatternP(false); }
|
EX void showPrePatternNoninstant() { showPrePatternP(false); }
|
||||||
|
|
||||||
|
|
||||||
@ -2180,7 +2177,7 @@ EX namespace patterns {
|
|||||||
}
|
}
|
||||||
EX }
|
EX }
|
||||||
|
|
||||||
bool is_master(cell *c) {
|
EX bool is_master(cell *c) {
|
||||||
if(euclid) return pseudohept(c);
|
if(euclid) return pseudohept(c);
|
||||||
else return c->master->c7 == c;
|
else return c->master->c7 == c;
|
||||||
}
|
}
|
||||||
@ -2269,7 +2266,7 @@ EX namespace linepatterns {
|
|||||||
{patParallels, "parallels", 0xFFFFFF00, 1},
|
{patParallels, "parallels", 0xFFFFFF00, 1},
|
||||||
};
|
};
|
||||||
|
|
||||||
void clearAll() {
|
EX void clearAll() {
|
||||||
for(auto& lp: patterns) lp.color &= ~255;
|
for(auto& lp: patterns) lp.color &= ~255;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -15,8 +15,6 @@ static constexpr ld NEWSHAPE = (-13.5);
|
|||||||
#endif
|
#endif
|
||||||
static constexpr ld WOLF = (-15.5);
|
static constexpr ld WOLF = (-15.5);
|
||||||
|
|
||||||
EX long double polydata[];
|
|
||||||
|
|
||||||
void geometry_information::hpcpush(hyperpoint h) {
|
void geometry_information::hpcpush(hyperpoint h) {
|
||||||
if(sphere) h = mid(h,h);
|
if(sphere) h = mid(h,h);
|
||||||
ld threshold = (GDIM == 3 || last->flags & POLY_TRIANGLES) ? 100 : (sphere ? (ISMOBWEB || NONSTDVAR ? .04 : .001) : 0.1) * pow(.25, vid.linequality);
|
ld threshold = (GDIM == 3 || last->flags & POLY_TRIANGLES) ? 100 : (sphere ? (ISMOBWEB || NONSTDVAR ? .04 : .001) : 0.1) * pow(.25, vid.linequality);
|
||||||
@ -1529,7 +1527,7 @@ void geometry_information::prepare_shapes() {
|
|||||||
initPolyForGL();
|
initPolyForGL();
|
||||||
}
|
}
|
||||||
|
|
||||||
long double polydata[] = {
|
EX vector<long double> polydata = {
|
||||||
// shStarFloor[0] (6x1)
|
// shStarFloor[0] (6x1)
|
||||||
NEWSHAPE, 1,6,1, 0.267355,0.153145, 0.158858,0.062321, 0.357493,-0.060252,
|
NEWSHAPE, 1,6,1, 0.267355,0.153145, 0.158858,0.062321, 0.357493,-0.060252,
|
||||||
// shStarFloor[1] (7x1)
|
// shStarFloor[1] (7x1)
|
||||||
|
@ -39,7 +39,8 @@ EX namespace quotientspace {
|
|||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
int rvadd = 0, rvdir = 1;
|
EX int rvadd = 0;
|
||||||
|
EX int rvdir = 1;
|
||||||
|
|
||||||
int rv(int x) { return (rvadd+x*rvdir) % S7; }
|
int rv(int x) { return (rvadd+x*rvdir) % S7; }
|
||||||
|
|
||||||
|
18
racing.cpp
18
racing.cpp
@ -42,7 +42,7 @@ vector<race_cellinfo> rti;
|
|||||||
EX vector<cell*> track;
|
EX vector<cell*> track;
|
||||||
map<cell*, int> rti_id;
|
map<cell*, int> rti_id;
|
||||||
|
|
||||||
int trophy[MAXPLAYER];
|
EX int trophy[MAXPLAYER];
|
||||||
|
|
||||||
EX string track_code = "OFFICIAL";
|
EX string track_code = "OFFICIAL";
|
||||||
|
|
||||||
@ -685,7 +685,7 @@ bool inrec = false;
|
|||||||
|
|
||||||
EX ld race_angle = 90;
|
EX ld race_angle = 90;
|
||||||
|
|
||||||
bool set_view() {
|
EX bool set_view() {
|
||||||
|
|
||||||
multi::cpid = subscreens::in ? subscreens::current_player : 0;
|
multi::cpid = subscreens::in ? subscreens::current_player : 0;
|
||||||
|
|
||||||
@ -1066,20 +1066,20 @@ void race_projection() {
|
|||||||
|
|
||||||
dialog::addBoolItem_action(XLAT("guiding line"), guiding, 'g');
|
dialog::addBoolItem_action(XLAT("guiding line"), guiding, 'g');
|
||||||
|
|
||||||
dialog::addItem(shmup::player_count_name(playercfg), 'n');
|
dialog::addItem(multi::player_count_name(playercfg), 'n');
|
||||||
dialog::add_action([/*this*/] () {
|
dialog::add_action([/*this*/] () {
|
||||||
playercfg = playercfg == 1 ? 2 : 1;
|
playercfg = playercfg == 1 ? 2 : 1;
|
||||||
});
|
});
|
||||||
|
|
||||||
dialog::addItem(XLAT("configure player 1"), '1');
|
dialog::addItem(XLAT("configure player 1"), '1');
|
||||||
dialog::add_action([] () {
|
dialog::add_action([] () {
|
||||||
pushScreen(shmup::key_configurer(1, playercmds_race));
|
pushScreen(multi::get_key_configurer(1, playercmds_race));
|
||||||
});
|
});
|
||||||
|
|
||||||
if(playercfg >= 2) {
|
if(playercfg >= 2) {
|
||||||
dialog::addItem(XLAT("configure player 2"), '2');
|
dialog::addItem(XLAT("configure player 2"), '2');
|
||||||
dialog::add_action([] () {
|
dialog::add_action([] () {
|
||||||
pushScreen(shmup::key_configurer(2, playercmds_race));
|
pushScreen(multi::get_key_configurer(2, playercmds_race));
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
else dialog::addBreak(100);
|
else dialog::addBreak(100);
|
||||||
@ -1271,11 +1271,11 @@ transmatrix racerel(ld rel) {
|
|||||||
return atscreenpos(bsize, vid.yres - bsize - rel * (vid.yres - bsize*2) / 100, bsize) * spin(M_PI/2);
|
return atscreenpos(bsize, vid.yres - bsize - rel * (vid.yres - bsize*2) / 100, bsize) * spin(M_PI/2);
|
||||||
}
|
}
|
||||||
|
|
||||||
int get_percentage(cell *c) {
|
EX int get_percentage(cell *c) {
|
||||||
return min(get_info(c).completion * 100 / (isize(track) - DROP), 100);
|
return min(get_info(c).completion * 100 / (isize(track) - DROP), 100);
|
||||||
}
|
}
|
||||||
|
|
||||||
int get_percentage(int i) {
|
EX int get_percentage(int i) {
|
||||||
return get_percentage(shmup::pc[i]->base);
|
return get_percentage(shmup::pc[i]->base);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1286,7 +1286,7 @@ void draw_ghost_state(ghost& ghost) {
|
|||||||
draw_ghost_at(ghost, w, racerel(result), p);
|
draw_ghost_at(ghost, w, racerel(result), p);
|
||||||
}
|
}
|
||||||
|
|
||||||
void drawStats() {
|
EX void drawStats() {
|
||||||
|
|
||||||
if(!racing::on) return;
|
if(!racing::on) return;
|
||||||
|
|
||||||
@ -1314,7 +1314,7 @@ void drawStats() {
|
|||||||
quickqueue();
|
quickqueue();
|
||||||
}
|
}
|
||||||
|
|
||||||
void markers() {
|
EX void markers() {
|
||||||
if(!racing::on) return;
|
if(!racing::on) return;
|
||||||
if(guiding && WDIM == 2) for(int i=0; i<multi::players; i++) {
|
if(guiding && WDIM == 2) for(int i=0; i<multi::players; i++) {
|
||||||
shmup::monster *m = shmup::pc[i];
|
shmup::monster *m = shmup::pc[i];
|
||||||
|
2
reg3.cpp
2
reg3.cpp
@ -32,7 +32,7 @@ EX namespace reg3 {
|
|||||||
return int(x * 10 + 100000.5) - 100000;
|
return int(x * 10 + 100000.5) - 100000;
|
||||||
}
|
}
|
||||||
|
|
||||||
int bucketer(hyperpoint h) {
|
EX int bucketer(hyperpoint h) {
|
||||||
return bucketer(h[0]) + 1000 * bucketer(h[1]) + 1000000 * bucketer(h[2]);
|
return bucketer(h[0]) + 1000 * bucketer(h[1]) + 1000000 * bucketer(h[2]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
18
rug.cpp
18
rug.cpp
@ -115,7 +115,7 @@ EX ld anticusp_dist;
|
|||||||
|
|
||||||
EX ld err_zero = 1e-3, err_zero_current, current_total_error;
|
EX ld err_zero = 1e-3, err_zero_current, current_total_error;
|
||||||
|
|
||||||
int queueiter, qvalid, dt;
|
EX int queueiter, qvalid, dt;
|
||||||
|
|
||||||
EX rugpoint *finger_center;
|
EX rugpoint *finger_center;
|
||||||
EX ld finger_range = .1;
|
EX ld finger_range = .1;
|
||||||
@ -123,7 +123,7 @@ EX ld finger_force = 1;
|
|||||||
|
|
||||||
EX int rugdim;
|
EX int rugdim;
|
||||||
|
|
||||||
bool rug_perspective = ISANDROID;
|
EX bool rug_perspective = ISANDROID;
|
||||||
|
|
||||||
// extra geometry functions
|
// extra geometry functions
|
||||||
//--------------------------
|
//--------------------------
|
||||||
@ -225,7 +225,7 @@ void push_point(hyperpoint& h, int coord, ld val) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void push_all_points(int coord, ld val) {
|
EX void push_all_points(int coord, ld val) {
|
||||||
if(!val) return;
|
if(!val) return;
|
||||||
else for(int i=0; i<isize(points); i++)
|
else for(int i=0; i<isize(points); i++)
|
||||||
push_point(points[i]->flat, coord, val);
|
push_point(points[i]->flat, coord, val);
|
||||||
@ -407,7 +407,7 @@ bool psort(rugpoint *a, rugpoint *b) {
|
|||||||
return hdist0(a->h) < hdist0(b->h);
|
return hdist0(a->h) < hdist0(b->h);
|
||||||
}
|
}
|
||||||
|
|
||||||
void sort_rug_points() {
|
EX void sort_rug_points() {
|
||||||
sort(points.begin(), points.end(), psort);
|
sort(points.begin(), points.end(), psort);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -738,7 +738,8 @@ EX void buildRug() {
|
|||||||
// rug physics
|
// rug physics
|
||||||
|
|
||||||
queue<rugpoint*> pqueue;
|
queue<rugpoint*> pqueue;
|
||||||
void enqueue(rugpoint *m) {
|
|
||||||
|
EX void enqueue(rugpoint *m) {
|
||||||
if(m->inqueue) return;
|
if(m->inqueue) return;
|
||||||
pqueue.push(m);
|
pqueue.push(m);
|
||||||
m->inqueue = true;
|
m->inqueue = true;
|
||||||
@ -1368,11 +1369,12 @@ double xview, yview;
|
|||||||
|
|
||||||
EX bool no_fog;
|
EX bool no_fog;
|
||||||
|
|
||||||
EX ld lowrug = 1e-2, hirug = 1e3;
|
EX ld lowrug = 1e-2;
|
||||||
|
EX ld hirug = 1e3;
|
||||||
|
|
||||||
GLuint alternate_texture;
|
EX GLuint alternate_texture;
|
||||||
|
|
||||||
bool invert_depth;
|
EX bool invert_depth;
|
||||||
|
|
||||||
EX void drawRugScene() {
|
EX void drawRugScene() {
|
||||||
glbuf->use_as_texture();
|
glbuf->use_as_texture();
|
||||||
|
@ -183,7 +183,7 @@ EX void set_if_removed(cell*& c, cell *val) {
|
|||||||
|
|
||||||
typedef array<char, 1048576> reserve_block;
|
typedef array<char, 1048576> reserve_block;
|
||||||
|
|
||||||
int reserve_count = 0;
|
EX int reserve_count = 0;
|
||||||
EX int reserve_limit = 128;
|
EX int reserve_limit = 128;
|
||||||
|
|
||||||
const int max_reserve = 4096;
|
const int max_reserve = 4096;
|
||||||
@ -226,7 +226,7 @@ EX void apply_memory_reserve() {
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
void memory_for_lib() {
|
EX void memory_for_lib() {
|
||||||
if(reserve_count) { reserve_count--; delete reserve[reserve_count]; }
|
if(reserve_count) { reserve_count--; delete reserve[reserve_count]; }
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -284,7 +284,7 @@ EX void show_memory_menu() {
|
|||||||
dialog::display();
|
dialog::display();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool protect_memory() {
|
EX bool protect_memory() {
|
||||||
if(!CAP_MEMORY_RESERVE) return false;
|
if(!CAP_MEMORY_RESERVE) return false;
|
||||||
apply_memory_reserve();
|
apply_memory_reserve();
|
||||||
if(reserve_limit && reserve_count < reserve_limit && !ignored_memory_warning) {
|
if(reserve_limit && reserve_count < reserve_limit && !ignored_memory_warning) {
|
||||||
@ -298,7 +298,7 @@ bool protect_memory() {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool memory_issues() {
|
EX bool memory_issues() {
|
||||||
return reserve_limit && reserve_count < 16;
|
return reserve_limit && reserve_count < 16;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -39,7 +39,7 @@ EX namespace svg {
|
|||||||
}
|
}
|
||||||
|
|
||||||
int svgsize;
|
int svgsize;
|
||||||
int divby = 10;
|
EX int divby = 10;
|
||||||
|
|
||||||
const char* coord(int val) {
|
const char* coord(int val) {
|
||||||
static char buf[10][20];
|
static char buf[10][20];
|
||||||
@ -586,7 +586,7 @@ bool needs_highqual;
|
|||||||
|
|
||||||
bool joukowsky_anim;
|
bool joukowsky_anim;
|
||||||
|
|
||||||
void reflect_view() {
|
EX void reflect_view() {
|
||||||
if(centerover.at) {
|
if(centerover.at) {
|
||||||
transmatrix T = Id;
|
transmatrix T = Id;
|
||||||
cell *mbase = centerover.at;
|
cell *mbase = centerover.at;
|
||||||
|
@ -29,7 +29,7 @@ EX void glError(const char* GLcall, const char* file, const int line) {
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if CAP_SHADER && CAP_NOSHADER
|
#if CAP_SHADER && CAP_NOSHADER
|
||||||
#define WITHSHADER(x, y) if(noshaders) y else x
|
#define WITHSHADER(x, y) if(glhr::noshaders) y else x
|
||||||
#else
|
#else
|
||||||
#if CAP_NOSHADER
|
#if CAP_NOSHADER
|
||||||
#define WITHSHADER(x, y) if(1) y
|
#define WITHSHADER(x, y) if(1) y
|
||||||
@ -498,7 +498,7 @@ EX void color2(color_t color, ld scale IS(1)) {
|
|||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
void colorClear(color_t color) {
|
EX void colorClear(color_t color) {
|
||||||
glClearColor(part(color, 3) / 255.0, part(color, 2) / 255.0, part(color, 1) / 255.0, part(color, 0) / 255.0);
|
glClearColor(part(color, 3) / 255.0, part(color, 2) / 255.0, part(color, 1) / 255.0, part(color, 0) / 255.0);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1022,14 +1022,14 @@ EX vector<glhr::textured_vertex> text_vertices;
|
|||||||
|
|
||||||
EX void texture_vertices(GLfloat *f, int qty, int stride IS(2)) {
|
EX void texture_vertices(GLfloat *f, int qty, int stride IS(2)) {
|
||||||
WITHSHADER(
|
WITHSHADER(
|
||||||
glVertexAttribPointer(aTexture, stride, GL_FLOAT, GL_FALSE, stride * sizeof(GLfloat), f);,
|
glVertexAttribPointer(glhr::aTexture, stride, GL_FLOAT, GL_FALSE, stride * sizeof(GLfloat), f);,
|
||||||
glTexCoordPointer(stride, GL_FLOAT, 0, f);
|
glTexCoordPointer(stride, GL_FLOAT, 0, f);
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
EX void oldvertices(GLfloat *f, int qty) {
|
EX void oldvertices(GLfloat *f, int qty) {
|
||||||
WITHSHADER(
|
WITHSHADER(
|
||||||
glVertexAttribPointer(aPosition, SHDIM, GL_FLOAT, GL_FALSE, SHDIM * sizeof(GLfloat), f);,
|
glVertexAttribPointer(glhr::aPosition, SHDIM, GL_FLOAT, GL_FALSE, SHDIM * sizeof(GLfloat), f);,
|
||||||
glVertexPointer(SHDIM, GL_FLOAT, 0, f);
|
glVertexPointer(SHDIM, GL_FLOAT, 0, f);
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
20
shmup.cpp
20
shmup.cpp
@ -9,17 +9,17 @@
|
|||||||
namespace hr {
|
namespace hr {
|
||||||
|
|
||||||
// joysticks for controlling the mobile shmup mode
|
// joysticks for controlling the mobile shmup mode
|
||||||
namespace shmupballs {
|
EX namespace shmupballs {
|
||||||
int xmove, xfire, yb, rad;
|
EX int xmove, xfire, yb, rad;
|
||||||
|
|
||||||
void calc() {
|
EX void calc() {
|
||||||
int rr = int(realradius());
|
int rr = int(realradius());
|
||||||
rad = int(rr * (vid.mobilecompasssize ? vid.mobilecompasssize : 14) / 100);
|
rad = int(rr * (vid.mobilecompasssize ? vid.mobilecompasssize : 14) / 100);
|
||||||
xmove = max(current_display->xcenter - rr - rad, rad);
|
xmove = max(current_display->xcenter - rr - rad, rad);
|
||||||
xfire = min(current_display->xcenter + rr + rad, vid.xres - rad);
|
xfire = min(current_display->xcenter + rr + rad, vid.xres - rad);
|
||||||
yb = current_display->ycenter + rr - rad;
|
yb = current_display->ycenter + rr - rad;
|
||||||
}
|
}
|
||||||
}
|
EX }
|
||||||
|
|
||||||
ld sqdist(hyperpoint a, hyperpoint b) {
|
ld sqdist(hyperpoint a, hyperpoint b) {
|
||||||
if(prod) return pow(hdist(a, b), 2);
|
if(prod) return pow(hdist(a, b), 2);
|
||||||
@ -38,8 +38,10 @@ void profile(const char *buf) {
|
|||||||
}
|
}
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#if HDR
|
||||||
#define SCALE cgi.scalefactor
|
#define SCALE cgi.scalefactor
|
||||||
#define SCALE2 (SCALE*SCALE)
|
#define SCALE2 (SCALE*SCALE)
|
||||||
|
#endif
|
||||||
|
|
||||||
EX namespace shmup {
|
EX namespace shmup {
|
||||||
|
|
||||||
@ -103,7 +105,9 @@ bool lastdead = false;
|
|||||||
|
|
||||||
EX multimap<cell*, monster*> monstersAt;
|
EX multimap<cell*, monster*> monstersAt;
|
||||||
|
|
||||||
|
#if HDR
|
||||||
typedef multimap<cell*, monster*>::iterator mit;
|
typedef multimap<cell*, monster*>::iterator mit;
|
||||||
|
#endif
|
||||||
|
|
||||||
vector<monster*> active, nonvirtual, additional;
|
vector<monster*> active, nonvirtual, additional;
|
||||||
|
|
||||||
@ -293,7 +297,7 @@ EX void degradeDemons() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// we need these for the Mimics!
|
// we need these for the Mimics!
|
||||||
double playerturn[MAXPLAYER], playergo[MAXPLAYER], playerstrafe[MAXPLAYER], playerturny[MAXPLAYER], playergoturn[MAXPLAYER], godir[MAXPLAYER];
|
EX double playerturn[MAXPLAYER], playergo[MAXPLAYER], playerstrafe[MAXPLAYER], playerturny[MAXPLAYER], playergoturn[MAXPLAYER], godir[MAXPLAYER];
|
||||||
bool playerfire[MAXPLAYER];
|
bool playerfire[MAXPLAYER];
|
||||||
|
|
||||||
void awakenMimics(monster *m, cell *c2) {
|
void awakenMimics(monster *m, cell *c2) {
|
||||||
@ -565,7 +569,7 @@ ld getSwordSize() { return cgi.sword_size; }
|
|||||||
ld getHornsSize() { return cgi.scalefactor * 0.33; }
|
ld getHornsSize() { return cgi.scalefactor * 0.33; }
|
||||||
|
|
||||||
// used in 3D
|
// used in 3D
|
||||||
transmatrix swordmatrix[MAXPLAYER];
|
EX transmatrix swordmatrix[MAXPLAYER];
|
||||||
|
|
||||||
hyperpoint swordpos(int id, bool rev, double frac) {
|
hyperpoint swordpos(int id, bool rev, double frac) {
|
||||||
if(WDIM == 3)
|
if(WDIM == 3)
|
||||||
@ -1292,7 +1296,7 @@ void movePlayer(monster *m, int delta) {
|
|||||||
dropGreenStone(m->base);
|
dropGreenStone(m->base);
|
||||||
}
|
}
|
||||||
|
|
||||||
monster *getPlayer() {
|
EX monster *getPlayer() {
|
||||||
return pc[cpid];
|
return pc[cpid];
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2728,7 +2732,7 @@ EX bool boatAt(cell *c) {
|
|||||||
|
|
||||||
EX hookset<bool(const transmatrix&, cell*, shmup::monster*)> *hooks_draw;
|
EX hookset<bool(const transmatrix&, cell*, shmup::monster*)> *hooks_draw;
|
||||||
|
|
||||||
bool drawMonster(const transmatrix& V, cell *c, const transmatrix*& Vboat, transmatrix& Vboat0, const transmatrix *Vdp) {
|
EX bool drawMonster(const transmatrix& V, cell *c, const transmatrix*& Vboat, transmatrix& Vboat0, const transmatrix *Vdp) {
|
||||||
#if CAP_SHAPES
|
#if CAP_SHAPES
|
||||||
|
|
||||||
pair<mit, mit> p =
|
pair<mit, mit> p =
|
||||||
|
47
system.cpp
47
system.cpp
@ -52,11 +52,11 @@ EX int savecount;
|
|||||||
EX bool showoff = false;
|
EX bool showoff = false;
|
||||||
EX bool doCross = false;
|
EX bool doCross = false;
|
||||||
|
|
||||||
bool gamegen_failure;
|
EX bool gamegen_failure;
|
||||||
|
|
||||||
EX eLand top_land;
|
EX eLand top_land;
|
||||||
|
|
||||||
bool verless(string v, string cmp) {
|
EX bool verless(string v, string cmp) {
|
||||||
if(isdigit(v[0]) && isdigit(v[1]))
|
if(isdigit(v[0]) && isdigit(v[1]))
|
||||||
v = "A" + v;
|
v = "A" + v;
|
||||||
if(isdigit(cmp[0]) && isdigit(cmp[1]))
|
if(isdigit(cmp[0]) && isdigit(cmp[1]))
|
||||||
@ -70,9 +70,9 @@ bool do_use_special_land() {
|
|||||||
(peace::on || tactic::on || geometry || NONSTDVAR || randomPatternsMode || yendor::on || racing::on);
|
(peace::on || tactic::on || geometry || NONSTDVAR || randomPatternsMode || yendor::on || racing::on);
|
||||||
}
|
}
|
||||||
|
|
||||||
hookset<bool()> *hooks_welcome_message;
|
EX hookset<bool()> *hooks_welcome_message;
|
||||||
|
|
||||||
void welcomeMessage() {
|
EX void welcomeMessage() {
|
||||||
if(callhandlers(false, hooks_welcome_message)) return;
|
if(callhandlers(false, hooks_welcome_message)) return;
|
||||||
else if(tactic::trailer) return;
|
else if(tactic::trailer) return;
|
||||||
#if CAP_TOUR
|
#if CAP_TOUR
|
||||||
@ -137,7 +137,7 @@ int trailer_cash0 = 5;
|
|||||||
int trailer_cash1 = 15;
|
int trailer_cash1 = 15;
|
||||||
bool trailer_safety = true;
|
bool trailer_safety = true;
|
||||||
|
|
||||||
hookset<void()> *hooks_initgame;
|
EX hookset<void()> *hooks_initgame;
|
||||||
|
|
||||||
// initialize the game
|
// initialize the game
|
||||||
EX void initgame() {
|
EX void initgame() {
|
||||||
@ -386,20 +386,22 @@ EX void initgame() {
|
|||||||
bool havesave = true;
|
bool havesave = true;
|
||||||
|
|
||||||
#if CAP_SAVE
|
#if CAP_SAVE
|
||||||
|
|
||||||
|
#if HDR
|
||||||
#define MAXBOX 500
|
#define MAXBOX 500
|
||||||
#define POSSCORE 371 // update this when new boxes are added!
|
#define POSSCORE 371 // update this when new boxes are added!
|
||||||
|
|
||||||
struct score {
|
struct score {
|
||||||
string ver;
|
string ver;
|
||||||
int box[MAXBOX];
|
int box[MAXBOX];
|
||||||
};
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
int savebox[MAXBOX], boxid;
|
EX int savebox[MAXBOX], boxid;
|
||||||
bool saving, loading, loadingHi;
|
EX bool saving, loading, loadingHi;
|
||||||
|
|
||||||
string boxname[MAXBOX];
|
EX string boxname[MAXBOX];
|
||||||
bool fakebox[MAXBOX];
|
EX bool fakebox[MAXBOX];
|
||||||
bool monsbox[MAXBOX];
|
EX bool monsbox[MAXBOX];
|
||||||
|
|
||||||
void applyBox(int& t) {
|
void applyBox(int& t) {
|
||||||
if(saving) savebox[boxid++] = t;
|
if(saving) savebox[boxid++] = t;
|
||||||
@ -477,7 +479,7 @@ void applyBoxM(eMonster m, bool f = false) {
|
|||||||
applyBox(kills[m]);
|
applyBox(kills[m]);
|
||||||
}
|
}
|
||||||
|
|
||||||
void applyBoxes() {
|
EX void applyBoxes() {
|
||||||
invorb.clear();
|
invorb.clear();
|
||||||
|
|
||||||
eLand lostin = laNone;
|
eLand lostin = laNone;
|
||||||
@ -811,7 +813,7 @@ void applyBoxes() {
|
|||||||
if(POSSCORE != boxid) printf("ERROR: %d boxes\n", boxid);
|
if(POSSCORE != boxid) printf("ERROR: %d boxes\n", boxid);
|
||||||
}
|
}
|
||||||
|
|
||||||
void saveBox() {
|
EX void saveBox() {
|
||||||
boxid = 0; saving = true; applyBoxes(); saving = false;
|
boxid = 0; saving = true; applyBoxes(); saving = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -848,24 +850,29 @@ void loadBoxHigh() {
|
|||||||
|
|
||||||
// certify that saves and achievements were received
|
// certify that saves and achievements were received
|
||||||
// in an official version of HyperRogue
|
// in an official version of HyperRogue
|
||||||
|
|
||||||
|
EX namespace anticheat {
|
||||||
|
EX int certify(const string& s, int a, int b, int c, int d IS(0));
|
||||||
|
EX }
|
||||||
|
|
||||||
#if CAP_CERTIFY
|
#if CAP_CERTIFY
|
||||||
#include "private/certify.cpp"
|
#include "private/certify.cpp"
|
||||||
#else
|
#endif
|
||||||
|
|
||||||
namespace anticheat {
|
#if !CAP_CERTIFY
|
||||||
bool tampered;
|
EX namespace anticheat {
|
||||||
|
EX bool tampered;
|
||||||
void save(FILE *f) {}
|
void save(FILE *f) {}
|
||||||
bool load(FILE *f, score& sc, const string& ver) {return true; }
|
bool load(FILE *f, score& sc, const string& ver) {return true; }
|
||||||
int certify(const string& s, int a, int b, int c, int d=0) { return d; }
|
int certify(const string& s, int a, int b, int c, int d) { return d; }
|
||||||
int check(int cv, const string& ver, const string& s, int a, int b, int c, int d=0) { return cv==d; }
|
int check(int cv, const string& ver, const string& s, int a, int b, int c, int d=0) { return cv==d; }
|
||||||
void nextid(int& tid, const string& ver, int cert) { tid++; }
|
void nextid(int& tid, const string& ver, int cert) { tid++; }
|
||||||
};
|
EX }
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
long long saveposition = -1;
|
long long saveposition = -1;
|
||||||
|
|
||||||
void remove_emergency_save() {
|
EX void remove_emergency_save() {
|
||||||
#if !ISWINDOWS
|
#if !ISWINDOWS
|
||||||
if(saveposition >= 0) {
|
if(saveposition >= 0) {
|
||||||
if(truncate(scorefile, saveposition)) {}
|
if(truncate(scorefile, saveposition)) {}
|
||||||
|
2
tour.cpp
2
tour.cpp
@ -12,7 +12,7 @@ EX namespace tour {
|
|||||||
|
|
||||||
EX bool on;
|
EX bool on;
|
||||||
|
|
||||||
bool texts = true;
|
EX bool texts = true;
|
||||||
|
|
||||||
EX string tourhelp;
|
EX string tourhelp;
|
||||||
|
|
||||||
|
12
yendor.cpp
12
yendor.cpp
@ -167,8 +167,10 @@ EX namespace yendor {
|
|||||||
|
|
||||||
EX vector<yendorinfo> yi;
|
EX vector<yendorinfo> yi;
|
||||||
|
|
||||||
|
#if HDR
|
||||||
#define NOYENDOR 999999
|
#define NOYENDOR 999999
|
||||||
int yii = NOYENDOR;
|
#endif
|
||||||
|
EX int yii = NOYENDOR;
|
||||||
|
|
||||||
EX int hardness() {
|
EX int hardness() {
|
||||||
if(peace::on) return 15; // just to generate monsters
|
if(peace::on) return 15; // just to generate monsters
|
||||||
@ -607,7 +609,7 @@ EX namespace yendor {
|
|||||||
};
|
};
|
||||||
vector<scoredata> scoreboard;
|
vector<scoredata> scoreboard;
|
||||||
|
|
||||||
const char *chelp =
|
EX const char *chelp =
|
||||||
"There are many possible solutions to the Yendor Quest. In the Yendor "
|
"There are many possible solutions to the Yendor Quest. In the Yendor "
|
||||||
"Challenge, you will try many of them!\n\n"
|
"Challenge, you will try many of them!\n\n"
|
||||||
"Each challenge takes part in a specific land, and you have to use what "
|
"Each challenge takes part in a specific land, and you have to use what "
|
||||||
@ -640,7 +642,7 @@ EX namespace yendor {
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
void showMenu() {
|
EX void showMenu() {
|
||||||
set_priority_board(LB_YENDOR_CHALLENGE);
|
set_priority_board(LB_YENDOR_CHALLENGE);
|
||||||
int s = vid.fsize;
|
int s = vid.fsize;
|
||||||
vid.fsize = vid.fsize * 4/5;
|
vid.fsize = vid.fsize * 4/5;
|
||||||
@ -874,7 +876,7 @@ EX namespace tactic {
|
|||||||
uploadScoreCode(4, LB_PURE_TACTICS_COOP);
|
uploadScoreCode(4, LB_PURE_TACTICS_COOP);
|
||||||
}
|
}
|
||||||
|
|
||||||
void showMenu() {
|
EX void showMenu() {
|
||||||
|
|
||||||
int xc = modecode();
|
int xc = modecode();
|
||||||
|
|
||||||
@ -1307,7 +1309,7 @@ EX namespace peace {
|
|||||||
}
|
}
|
||||||
EX }
|
EX }
|
||||||
|
|
||||||
void showMenu() {
|
EX void showMenu() {
|
||||||
listLevels();
|
listLevels();
|
||||||
dialog::init(XLAT(otherpuzzles ? "puzzles and exploration" : "memory game"), 0x40A040, 150, 100);
|
dialog::init(XLAT(otherpuzzles ? "puzzles and exploration" : "memory game"), 0x40A040, 150, 100);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user