mirror of
https://github.com/zenorogue/hyperrogue.git
synced 2025-01-12 02:10:34 +00:00
more rearrangement
This commit is contained in:
parent
8639a5b5e9
commit
00c9238bd6
@ -77,7 +77,7 @@ void upload_score(int id, int v);
|
|||||||
|
|
||||||
string achievementMessage[3];
|
string achievementMessage[3];
|
||||||
int achievementTimer;
|
int achievementTimer;
|
||||||
// vector<string> achievementsReceived;
|
vector<string> achievementsReceived;
|
||||||
|
|
||||||
bool wrongMode(char flags) {
|
bool wrongMode(char flags) {
|
||||||
if(cheater) return true;
|
if(cheater) return true;
|
||||||
|
20
cell.cpp
20
cell.cpp
@ -15,26 +15,6 @@ int dirdiff(int dd, int t) {
|
|||||||
return dd;
|
return dd;
|
||||||
}
|
}
|
||||||
|
|
||||||
struct cell : gcell {
|
|
||||||
char type; // 6 for hexagons, 7 for heptagons
|
|
||||||
|
|
||||||
// wall parameter, used for remaining power of Bonfires and Thumpers
|
|
||||||
char wparam;
|
|
||||||
|
|
||||||
// 'tmp' is used for:
|
|
||||||
// pathfinding algorithm used by monsters with atypical movement (which do not use pathdist)
|
|
||||||
// bugs' pathfinding algorithm
|
|
||||||
short aitmp;
|
|
||||||
|
|
||||||
uint32_t spintable;
|
|
||||||
int spin(int d) { return tspin(spintable, d); }
|
|
||||||
int spn(int d) { return tspin(spintable, d); }
|
|
||||||
int mirror(int d) { return tmirror(spintable, d); }
|
|
||||||
|
|
||||||
heptagon *master;
|
|
||||||
cell *mov[MAX_EDGE]; // meaning very similar to heptagon::move
|
|
||||||
};
|
|
||||||
|
|
||||||
int fixdir(int a, cell *c) { a %= c->type; if(a<0) a += c->type; return a; }
|
int fixdir(int a, cell *c) { a %= c->type; if(a<0) a += c->type; return a; }
|
||||||
|
|
||||||
int cellcount = 0;
|
int cellcount = 0;
|
||||||
|
@ -208,3 +208,5 @@ static const int SEE_ALL = 15;
|
|||||||
static const int FORBIDDEN = -1;
|
static const int FORBIDDEN = -1;
|
||||||
|
|
||||||
extern eGeometry geometry;
|
extern eGeometry geometry;
|
||||||
|
|
||||||
|
extern geometryinfo ginf[gGUARD];
|
||||||
|
@ -11,6 +11,8 @@
|
|||||||
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
const char* COLORBAR = "###";
|
||||||
|
|
||||||
namespace dialog {
|
namespace dialog {
|
||||||
|
|
||||||
namespace zoom {
|
namespace zoom {
|
||||||
|
3
game.cpp
3
game.cpp
@ -1072,6 +1072,9 @@ bool outlawNearby(cell *c, int dist) {
|
|||||||
// int monstersnear(cell *c, cell *nocount = NULL, eMonster who = moPlayer, cell *pushto = NULL) {
|
// int monstersnear(cell *c, cell *nocount = NULL, eMonster who = moPlayer, cell *pushto = NULL) {
|
||||||
|
|
||||||
namespace stalemate {
|
namespace stalemate {
|
||||||
|
vector<stalemate1> moves;
|
||||||
|
bool nextturn;
|
||||||
|
|
||||||
bool anyKilled() {
|
bool anyKilled() {
|
||||||
for(int i=0; i<size(moves); i++) if(moves[i].killed) return true;
|
for(int i=0; i<size(moves); i++) if(moves[i].killed) return true;
|
||||||
return false;
|
return false;
|
||||||
|
@ -16,14 +16,6 @@ cell *newCell(int type, heptagon *master);
|
|||||||
|
|
||||||
// spintable functions
|
// spintable functions
|
||||||
|
|
||||||
int tspin(uint32_t& t, int d) {
|
|
||||||
return (t >> (d<<2)) & 7;
|
|
||||||
}
|
|
||||||
|
|
||||||
int tmirror(uint32_t& t, int d) {
|
|
||||||
return (t >> ((d<<2)+3)) & 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
void tsetspin(uint32_t& t, int d, int spin) {
|
void tsetspin(uint32_t& t, int d, int spin) {
|
||||||
t &= ~(15 << (d<<2));
|
t &= ~(15 << (d<<2));
|
||||||
t |= spin << (d<<2);
|
t |= spin << (d<<2);
|
||||||
|
17
hyper.cpp
17
hyper.cpp
@ -15,22 +15,6 @@
|
|||||||
// along with this program; if not, write to the Free Software
|
// along with this program; if not, write to the Free Software
|
||||||
// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||||
|
|
||||||
#ifdef MAC
|
|
||||||
#define ISMAC 1
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef LINUX
|
|
||||||
#define ISLINUX 1
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef WINDOWS
|
|
||||||
#define ISWINDOWS 1
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if ISSTEAM
|
|
||||||
#define NOLICENSE
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include "init.cpp"
|
#include "init.cpp"
|
||||||
|
|
||||||
#if ISLINUX
|
#if ISLINUX
|
||||||
@ -473,6 +457,7 @@ hookset<int()> *hooks_args;
|
|||||||
|
|
||||||
namespace arg {
|
namespace arg {
|
||||||
int argc; char **argv;
|
int argc; char **argv;
|
||||||
|
int curphase;
|
||||||
|
|
||||||
auto ah = addHook(hooks_args, 0, readCommon);
|
auto ah = addHook(hooks_args, 0, readCommon);
|
||||||
|
|
||||||
|
94
hyper.h
94
hyper.h
@ -94,8 +94,32 @@ struct gcell {
|
|||||||
#define NOBARRIERS 9
|
#define NOBARRIERS 9
|
||||||
|
|
||||||
struct heptagon;
|
struct heptagon;
|
||||||
|
|
||||||
struct heptspin;
|
struct heptspin;
|
||||||
struct cell;
|
|
||||||
|
inline int tspin(uint32_t& t, int d) { return (t >> (d<<2)) & 7; }
|
||||||
|
inline int tmirror(uint32_t& t, int d) { return (t >> ((d<<2)+3)) & 1; }
|
||||||
|
|
||||||
|
struct cell : gcell {
|
||||||
|
char type; // 6 for hexagons, 7 for heptagons
|
||||||
|
|
||||||
|
// wall parameter, used for remaining power of Bonfires and Thumpers
|
||||||
|
char wparam;
|
||||||
|
|
||||||
|
// 'tmp' is used for:
|
||||||
|
// pathfinding algorithm used by monsters with atypical movement (which do not use pathdist)
|
||||||
|
// bugs' pathfinding algorithm
|
||||||
|
short aitmp;
|
||||||
|
|
||||||
|
uint32_t spintable;
|
||||||
|
int spin(int d) { return tspin(spintable, d); }
|
||||||
|
int spn(int d) { return tspin(spintable, d); }
|
||||||
|
int mirror(int d) { return tmirror(spintable, d); }
|
||||||
|
|
||||||
|
heptagon *master;
|
||||||
|
cell *mov[MAX_EDGE]; // meaning very similar to heptagon::move
|
||||||
|
};
|
||||||
|
|
||||||
struct cellwalker;
|
struct cellwalker;
|
||||||
|
|
||||||
// automaton state
|
// automaton state
|
||||||
@ -129,6 +153,7 @@ enum hstate { hsOrigin, hsA, hsB, hsError, hsA0, hsA1, hsB0, hsB1, hsC };
|
|||||||
|
|
||||||
string XLAT(string x);
|
string XLAT(string x);
|
||||||
string cts(char c);
|
string cts(char c);
|
||||||
|
string its(int i);
|
||||||
int hrand(int i);
|
int hrand(int i);
|
||||||
|
|
||||||
template<class T> int size(const T& x) {return int(x.size()); }
|
template<class T> int size(const T& x) {return int(x.size()); }
|
||||||
@ -172,7 +197,7 @@ void achievement_display();
|
|||||||
void achievement_pump();
|
void achievement_pump();
|
||||||
|
|
||||||
// achievements received this game
|
// achievements received this game
|
||||||
vector<string> achievementsReceived;
|
extern vector<string> achievementsReceived;
|
||||||
|
|
||||||
// game forward declarations
|
// game forward declarations
|
||||||
typedef unsigned long long flagtype;
|
typedef unsigned long long flagtype;
|
||||||
@ -314,7 +339,7 @@ namespace multi {
|
|||||||
void loadConfig(FILE *f);
|
void loadConfig(FILE *f);
|
||||||
void initConfig();
|
void initConfig();
|
||||||
|
|
||||||
charstyle scs[MAXPLAYER];
|
extern charstyle scs[MAXPLAYER];
|
||||||
|
|
||||||
bool playerActive(int p);
|
bool playerActive(int p);
|
||||||
int activePlayers();
|
int activePlayers();
|
||||||
@ -877,8 +902,8 @@ struct stalemate1 {
|
|||||||
};
|
};
|
||||||
|
|
||||||
namespace stalemate {
|
namespace stalemate {
|
||||||
vector<stalemate1> moves;
|
extern vector<stalemate1> moves;
|
||||||
bool nextturn;
|
extern bool nextturn;
|
||||||
|
|
||||||
bool isKilled(cell *c);
|
bool isKilled(cell *c);
|
||||||
|
|
||||||
@ -1251,7 +1276,7 @@ namespace arg {
|
|||||||
|
|
||||||
inline void init(int _argc, char **_argv) { argc=_argc-1; argv=_argv+1; }
|
inline void init(int _argc, char **_argv) { argc=_argc-1; argv=_argv+1; }
|
||||||
|
|
||||||
int curphase;
|
extern int curphase;
|
||||||
|
|
||||||
inline void phaseerror(int x) {
|
inline void phaseerror(int x) {
|
||||||
printf("Command line error: cannot read command '%s' from phase %d in phase %d\n", args(), x, curphase);
|
printf("Command line error: cannot read command '%s' from phase %d in phase %d\n", args(), x, curphase);
|
||||||
@ -1523,7 +1548,8 @@ void setAppropriateOverview();
|
|||||||
bool quitsaves();
|
bool quitsaves();
|
||||||
extern bool sidescreen;
|
extern bool sidescreen;
|
||||||
|
|
||||||
static const char* COLORBAR = "###";
|
extern const char* COLORBAR;
|
||||||
|
|
||||||
int textwidth(int siz, const string &str);
|
int textwidth(int siz, const string &str);
|
||||||
#define GLERR(call) glError(call, __FILE__, __LINE__)
|
#define GLERR(call) glError(call, __FILE__, __LINE__)
|
||||||
|
|
||||||
@ -1664,7 +1690,7 @@ void selectLanguageScreen();
|
|||||||
bool inscreenrange(cell *c);
|
bool inscreenrange(cell *c);
|
||||||
bool allowIncreasedSight();
|
bool allowIncreasedSight();
|
||||||
|
|
||||||
static bool orbProtection(eItem it) { return false; } // not implemented
|
static inline bool orbProtection(eItem it) { return false; } // not implemented
|
||||||
|
|
||||||
namespace windmap {
|
namespace windmap {
|
||||||
void create();
|
void create();
|
||||||
@ -1729,3 +1755,55 @@ int ctof(cell *c);
|
|||||||
|
|
||||||
void modalDebug(cell *c);
|
void modalDebug(cell *c);
|
||||||
int getDistLimit();
|
int getDistLimit();
|
||||||
|
|
||||||
|
void drawqueue();
|
||||||
|
|
||||||
|
#ifndef GL
|
||||||
|
typedef float GLfloat;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
struct qpoly {
|
||||||
|
transmatrix V;
|
||||||
|
GLfloat *tab;
|
||||||
|
int curveindex;
|
||||||
|
int cnt;
|
||||||
|
int outline;
|
||||||
|
double minwidth;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct qline {
|
||||||
|
hyperpoint H1, H2;
|
||||||
|
int prf;
|
||||||
|
double width;
|
||||||
|
};
|
||||||
|
|
||||||
|
#define MAXQCHR 40
|
||||||
|
|
||||||
|
struct qchr {
|
||||||
|
char str[MAXQCHR];
|
||||||
|
int x, y, shift, size, frame;
|
||||||
|
int align;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct qcir {
|
||||||
|
int x, y, size;
|
||||||
|
};
|
||||||
|
|
||||||
|
enum eKind { pkPoly, pkLine, pkString, pkCircle, pkShape, pkResetModel };
|
||||||
|
|
||||||
|
struct polytodraw {
|
||||||
|
eKind kind;
|
||||||
|
int prio, col;
|
||||||
|
union {
|
||||||
|
qpoly poly;
|
||||||
|
qline line;
|
||||||
|
qchr chr;
|
||||||
|
qcir cir;
|
||||||
|
double dvalue;
|
||||||
|
} u;
|
||||||
|
#if CAP_ROGUEVIZ
|
||||||
|
string* info;
|
||||||
|
polytodraw() { info = NULL; }
|
||||||
|
#endif
|
||||||
|
};
|
||||||
|
|
||||||
|
58
init.cpp
58
init.cpp
@ -1,3 +1,19 @@
|
|||||||
|
#ifdef MAC
|
||||||
|
#define ISMAC 1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef LINUX
|
||||||
|
#define ISLINUX 1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef WINDOWS
|
||||||
|
#define ISWINDOWS 1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if ISSTEAM
|
||||||
|
#define NOLICENSE
|
||||||
|
#endif
|
||||||
|
|
||||||
#define VER "10.1h"
|
#define VER "10.1h"
|
||||||
#define VERNUM 10108
|
#define VERNUM 10108
|
||||||
#define VERNUM_HEX 0xA088
|
#define VERNUM_HEX 0xA088
|
||||||
@ -179,7 +195,7 @@
|
|||||||
#define CAP_SHMUP_GOOD (!ISMOBWEB)
|
#define CAP_SHMUP_GOOD (!ISMOBWEB)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
int fontscale = 100;
|
extern int fontscale;
|
||||||
|
|
||||||
#if ISMOBILE
|
#if ISMOBILE
|
||||||
#define EXTRALICENSE "\n\nHyperRogue soundtrack by Shawn Parrotte (http://www.shawnparrotte.com), under the Creative Commons BY-SA 3.0 license, http://creativecommons.org/licenses/by-sa/3.0/"
|
#define EXTRALICENSE "\n\nHyperRogue soundtrack by Shawn Parrotte (http://www.shawnparrotte.com), under the Creative Commons BY-SA 3.0 license, http://creativecommons.org/licenses/by-sa/3.0/"
|
||||||
@ -306,9 +322,31 @@ inline Uint8 *SDL_GetKeyState(void *v) { static Uint8 tab[1024]; return tab; }
|
|||||||
|
|
||||||
using namespace std;
|
using namespace std;
|
||||||
|
|
||||||
string s0;
|
|
||||||
void addMessage(string s, char spamtype = 0);
|
void addMessage(string s, char spamtype = 0);
|
||||||
|
|
||||||
|
#define S7 ginf[geometry].sides
|
||||||
|
#define S3 ginf[geometry].vertex
|
||||||
|
#define weirdhyperbolic (S7 > 7 || S3 > 3)
|
||||||
|
#define S6 (S3*2)
|
||||||
|
#define S42 (S7*S6)
|
||||||
|
#define S12 (S6*2)
|
||||||
|
#define S14 (S7*2)
|
||||||
|
#define S21 (S7*S3)
|
||||||
|
#define S28 (S7*4)
|
||||||
|
#define S36 (S6*6)
|
||||||
|
#define S84 (S7*S6*2)
|
||||||
|
#define MAX_EDGE 8
|
||||||
|
#define MAX_S3 4
|
||||||
|
#define MAX_S84 240
|
||||||
|
|
||||||
|
#ifdef ONE_CU
|
||||||
|
#include "classes.h"
|
||||||
|
#include "hyper.h"
|
||||||
|
|
||||||
|
#else
|
||||||
|
|
||||||
|
int fontscale = 100;
|
||||||
|
|
||||||
#if ISANDROID
|
#if ISANDROID
|
||||||
FILE *debfile;
|
FILE *debfile;
|
||||||
#endif
|
#endif
|
||||||
@ -325,20 +363,7 @@ const char *musicfile = "";
|
|||||||
const char *loadlevel = NULL;
|
const char *loadlevel = NULL;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#define S7 ginf[geometry].sides
|
string s0;
|
||||||
#define S3 ginf[geometry].vertex
|
|
||||||
#define weirdhyperbolic (S7 > 7 || S3 > 3)
|
|
||||||
#define S6 (S3*2)
|
|
||||||
#define S42 (S7*S6)
|
|
||||||
#define S12 (S6*2)
|
|
||||||
#define S14 (S7*2)
|
|
||||||
#define S21 (S7*S3)
|
|
||||||
#define S28 (S7*4)
|
|
||||||
#define S36 (S6*6)
|
|
||||||
#define S84 (S7*S6*2)
|
|
||||||
#define MAX_EDGE 8
|
|
||||||
#define MAX_S3 4
|
|
||||||
#define MAX_S84 240
|
|
||||||
|
|
||||||
#include "classes.cpp"
|
#include "classes.cpp"
|
||||||
#include "hyper.h"
|
#include "hyper.h"
|
||||||
@ -788,3 +813,4 @@ void mobile_draw(MOBPAR_FORMAL) {
|
|||||||
void playSound(cell*, const string &s, int vol) { printf("play sound: %s vol %d\n", s.c_str(), vol); }
|
void playSound(cell*, const string &s, int vol) { printf("play sound: %s vol %d\n", s.c_str(), vol); }
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#endif
|
||||||
|
49
polygons.cpp
49
polygons.cpp
@ -28,55 +28,6 @@ struct hpcshape {
|
|||||||
|
|
||||||
hpcshape *last = NULL;
|
hpcshape *last = NULL;
|
||||||
|
|
||||||
#ifndef GL
|
|
||||||
typedef float GLfloat;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
struct qpoly {
|
|
||||||
transmatrix V;
|
|
||||||
GLfloat *tab;
|
|
||||||
int curveindex;
|
|
||||||
int cnt;
|
|
||||||
int outline;
|
|
||||||
double minwidth;
|
|
||||||
};
|
|
||||||
|
|
||||||
struct qline {
|
|
||||||
hyperpoint H1, H2;
|
|
||||||
int prf;
|
|
||||||
double width;
|
|
||||||
};
|
|
||||||
|
|
||||||
#define MAXQCHR 40
|
|
||||||
|
|
||||||
struct qchr {
|
|
||||||
char str[MAXQCHR];
|
|
||||||
int x, y, shift, size, frame;
|
|
||||||
int align;
|
|
||||||
};
|
|
||||||
|
|
||||||
struct qcir {
|
|
||||||
int x, y, size;
|
|
||||||
};
|
|
||||||
|
|
||||||
enum eKind { pkPoly, pkLine, pkString, pkCircle, pkShape, pkResetModel };
|
|
||||||
|
|
||||||
struct polytodraw {
|
|
||||||
eKind kind;
|
|
||||||
int prio, col;
|
|
||||||
union {
|
|
||||||
qpoly poly;
|
|
||||||
qline line;
|
|
||||||
qchr chr;
|
|
||||||
qcir cir;
|
|
||||||
double dvalue;
|
|
||||||
} u;
|
|
||||||
#if CAP_ROGUEVIZ
|
|
||||||
string* info;
|
|
||||||
polytodraw() { info = NULL; }
|
|
||||||
#endif
|
|
||||||
};
|
|
||||||
|
|
||||||
vector<polytodraw> ptds;
|
vector<polytodraw> ptds;
|
||||||
|
|
||||||
polytodraw& lastptd() { return ptds[size(ptds)-1]; }
|
polytodraw& lastptd() { return ptds[size(ptds)-1]; }
|
||||||
|
@ -21,6 +21,8 @@ namespace shmupballs {
|
|||||||
|
|
||||||
namespace multi {
|
namespace multi {
|
||||||
|
|
||||||
|
charstyle scs[MAXPLAYER];
|
||||||
|
|
||||||
int players = 1;
|
int players = 1;
|
||||||
cellwalker player[MAXPLAYER];
|
cellwalker player[MAXPLAYER];
|
||||||
vector<int> revive_queue; // queue for revival
|
vector<int> revive_queue; // queue for revival
|
||||||
|
Loading…
Reference in New Issue
Block a user