1
0
Fork 0
mirror of https://github.com/TerryCavanagh/VVVVVV.git synced 2025-01-08 18:09:45 +01:00

Move everything to the editor state system

This commit moves everything left out of the previous commit to the
state system. This means a bunch of new functions were added as well,
to avoid the code in each function becoming too huge. A lot of cleanup
was done as well, simplifying logic, merging duplicated code, etc.

This commit does NOT touch "script hooks", script editor logic and
autotiling, as those seem to be their own separate beasts.
This commit is contained in:
AllyTally 2023-03-05 14:59:36 -04:00 committed by Misa Elizabeth Kai
parent 7b5ef40926
commit 7ac405c831
4 changed files with 1974 additions and 2048 deletions

File diff suppressed because it is too large Load diff

View file

@ -47,7 +47,9 @@ enum EditorSubStates
EditorSubState_DRAW_BOX, EditorSubState_DRAW_BOX,
EditorSubState_DRAW_WARPTOKEN, EditorSubState_DRAW_WARPTOKEN,
EditorSubState_SCRIPTS_EDIT EditorSubState_SCRIPTS_EDIT,
EditorSubState_MENU_INPUT
}; };
enum TileTypes enum TileTypes
@ -62,11 +64,18 @@ enum BoxTypes
{ {
BoxType_SCRIPT, BoxType_SCRIPT,
BoxType_ENEMY, BoxType_ENEMY,
BoxType_PLATFORM BoxType_PLATFORM,
BoxType_COPY
};
enum BoxCorner
{
BoxCorner_FIRST,
BoxCorner_LAST
}; };
// Text entry field type // Text entry field type
enum textmode enum TextMode
{ {
TEXT_NONE, TEXT_NONE,
@ -81,7 +90,9 @@ enum textmode
// Settings-mode text fields // Settings-mode text fields
TEXT_TITLE, TEXT_TITLE,
TEXT_DESC, TEXT_DESC1,
TEXT_DESC2,
TEXT_DESC3,
TEXT_WEBSITE, TEXT_WEBSITE,
TEXT_CREATOR, TEXT_CREATOR,
NUM_TEXTMODES, NUM_TEXTMODES,
@ -118,45 +129,38 @@ public:
void entity_clicked(int index); void entity_clicked(int index);
void tool_place(); void tool_place();
void getlin(const enum textmode mode, const std::string& prompt, std::string* ptr); void get_input_line(const enum TextMode mode, const std::string& prompt, std::string* ptr);
void addedentity(int xp, int yp, int tp, int p1 = 0, int p2 = 0, int p3 = 0, int p4 = 0, int p5 = 320, int p6 = 240); void show_note(const char* text);
void removeedentity(int t); void add_entity(int xp, int yp, int tp, int p1 = 0, int p2 = 0, int p3 = 0, int p4 = 0, int p5 = 320, int p6 = 240);
int edentat(int xp, int yp); void remove_entity(int t);
void settile(int x, int y, int t); int get_entity_at(int xp, int yp);
int base(int x, int y); void set_tile(int x, int y, int t);
int backbase(int x, int y); int autotiling_base(int x, int y);
int autotiling_background_base(int x, int y);
int at(int x, int y); TileTypes get_abs_tile_type(int x, int y, bool wrap);
TileTypes get_tile_type(int x, int y, bool wrap);
int tile_type_wrap(int x, int y);
int backonlyfree(int x, int y);
bool is_background(int x, int y);
int backfree(int x, int y); int backfree(int x, int y);
bool lines_can_pass(int x, int y);
int spikefree(int x, int y);
int free(int x, int y); int free(int x, int y);
int match(int x, int y); int match(int x, int y);
int outsidematch(int x, int y); int outsidematch(int x, int y);
int backmatch(int x, int y); int backmatch(int x, int y);
int edgetile(int x, int y); int edgetile(int x, int y);
int outsideedgetile(int x, int y); int outsideedgetile(int x, int y);
int backedgetile(int x, int y); int backedgetile(int x, int y);
int labspikedir(int x, int y, int t); int labspikedir(int x, int y, int t);
int spikedir(int x, int y); int spikedir(int x, int y);
int getenemyframe(int t); int get_enemy_tile(int t);
void switch_tileset(const bool reversed); void switch_tileset(const bool reversed);
void switch_tilecol(const bool reversed); void switch_tilecol(const bool reversed);
@ -167,20 +171,25 @@ public:
EditorStates state; EditorStates state;
EditorSubStates substate; EditorSubStates substate;
const char* toolnames[NUM_EditorTools]; const char* tool_names[NUM_EditorTools];
const char* toolkeychar[NUM_EditorTools]; const char* tool_key_chars[NUM_EditorTools];
SDL_KeyCode toolkey[NUM_EditorTools]; SDL_KeyCode tool_keys[NUM_EditorTools];
bool toolshift[NUM_EditorTools]; bool tool_requires_shift[NUM_EditorTools];
EditorTools current_tool; EditorTools current_tool;
BoxTypes box_type;
BoxCorner box_corner;
SDL_Point box_point;
int entcol; int entcol;
SDL_Color entcolreal; SDL_Color entcolreal;
int kludgewarpdir[customlevelclass::numrooms]; int kludgewarpdir[customlevelclass::numrooms];
int notedelay; int note_timer;
int oldnotedelay; int old_note_timer;
std::string note; std::string note;
std::string keybuffer; std::string keybuffer;
std::string filename; std::string filename;
@ -194,36 +203,30 @@ public:
int entframe, entframedelay; int entframe, entframedelay;
int scripttexttype; int scripttexttype;
std::string oldenttext; std::string old_entity_text;
enum textmode textmod; // In text entry enum TextMode current_text_mode; // In text entry
std::string* textptr; // Pointer to text we're changing std::string* current_text_ptr; // Pointer to text we're changing
std::string textdesc; // Description (for editor mode text fields) std::string current_text_desc; // Description (for editor mode text fields)
union union
{ {
int desc; // Which description row we're changing int desc; // Which description row we're changing
int textent; // Entity ID for text prompt int textent; // Entity ID for text prompt
}; };
bool xmod, zmod, cmod, vmod, bmod, hmod, spacemod, warpmod; bool xmod, zmod, cmod, vmod, bmod, hmod, spacemod;
bool titlemod, creatormod, desc1mod, desc2mod, desc3mod, websitemod;
int roomnamehide; int roomnamehide;
bool saveandquit; bool saveandquit;
bool shiftmenu, shiftkey; bool shiftmenu, shiftkey;
bool settingsmod, settingskey; bool settingskey;
int warpent; int warpent;
bool updatetiles, changeroom; bool updatetiles, changeroom;
int deletekeyheld; bool deletekeyheld;
int boundarymod, boundarytype;
int boundx1, boundx2, boundy1, boundy2;
//Script editor stuff //Script editor stuff
void removeline(int t); void removeline(int t);
void insertline(int t); void insertline(int t);
bool scripteditmod;
int scripthelppage, scripthelppagedelay;
std::vector<std::string> sb; std::vector<std::string> sb;
std::string sbscript; std::string sbscript;
int sbx, sby; int sbx, sby;

View file

@ -7219,8 +7219,8 @@ void Game::returntoeditor(void)
ed.keydelay = 6; ed.keydelay = 6;
ed.settingskey = true; ed.settingskey = true;
ed.oldnotedelay = 0; ed.old_note_timer = 0;
ed.notedelay = 0; ed.note_timer = 0;
ed.roomnamehide = 0; ed.roomnamehide = 0;
// Might've been changed in a script // Might've been changed in a script

View file

@ -1450,8 +1450,7 @@ void scriptclass::run(void)
if (map.custommode && !map.custommodeforreal) if (map.custommode && !map.custommodeforreal)
{ {
game.returntoeditor(); game.returntoeditor();
ed.note = loc::gettext("Rolled credits"); ed.show_note(loc::gettext("Rolled credits"));
ed.notedelay = 45;
} }
else else
#endif #endif