mirror of
https://github.com/ondra-novak/gates_of_skeldal.git
synced 2025-08-28 14:17:18 -04:00
new sse control commands, console direct control
This commit is contained in:
parent
4211f044ed
commit
bef06cd345
4 changed files with 72 additions and 27 deletions
|
@ -162,6 +162,7 @@ extern char immortality;
|
|||
extern char nohassle;
|
||||
extern char dead_food;
|
||||
extern char pass_all_mobs;
|
||||
extern char force_levitate;
|
||||
|
||||
|
||||
static char console_input_line[console_max_characters+1] = "";
|
||||
|
@ -316,6 +317,10 @@ static int process_on_off_command(const char *cmd, char on) {
|
|||
nofloors = on;
|
||||
return 1;
|
||||
}
|
||||
if (istrcmp(cmd, "levitation") == 0) {
|
||||
force_levitate = on;
|
||||
return 1;
|
||||
}
|
||||
if (istrcmp(cmd, "enemy-insight") == 0) {
|
||||
show_mob_info = on;
|
||||
return 1;
|
||||
|
@ -724,16 +729,9 @@ static void console_keyboard(EVENT_MSG *msg, void **_) {
|
|||
}
|
||||
msg->msg = -1;
|
||||
} else if (c == '\r') {
|
||||
console_command = console_input_line;
|
||||
PARSED_COMMAND cmd = parse_command(console_input_line);
|
||||
char ok = process_command(cmd);
|
||||
if (ok) {
|
||||
flush_console_command();
|
||||
console_top_line = 0;
|
||||
if (console_exec(console_input_line)) {
|
||||
console_input_line[0] = 0;
|
||||
}
|
||||
console_command = NULL;
|
||||
free(cmd.cmd_buffer);
|
||||
msg->msg = -1;
|
||||
} else if (c == 3 && !get_shift_key_state()) {
|
||||
console_copy_to_clipboard();
|
||||
|
@ -773,7 +771,18 @@ void console_show(char show) {
|
|||
if (show) wire_console();
|
||||
else unwire_console();
|
||||
}
|
||||
|
||||
}
|
||||
char console_exec(const char *cmd_text) {
|
||||
console_command = cmd_text;
|
||||
PARSED_COMMAND cmd = parse_command(cmd_text);
|
||||
char ok = process_command(cmd);
|
||||
if (ok) {
|
||||
flush_console_command();
|
||||
console_top_line = 0;
|
||||
}
|
||||
console_command = NULL;
|
||||
free(cmd.cmd_buffer);
|
||||
return ok;
|
||||
}
|
||||
|
||||
|
||||
|
|
|
@ -1836,6 +1836,7 @@ static __inline int quit_request_as_escape(int c) {
|
|||
|
||||
void draw_console_window(void);
|
||||
void console_show(char show);
|
||||
char console_exec(const char *cmd);
|
||||
char console_is_visible(void);
|
||||
|
||||
char *map_hash_to_string_impl(char *c, uint32_t h, int sz);
|
||||
|
|
|
@ -74,6 +74,7 @@ char datapath;
|
|||
D_ACTION *d_action={NULL};
|
||||
int end_ptr;
|
||||
char pass_all_mobs = 0; //cheat make all mobs passable
|
||||
char force_levitate = 0; //cheat
|
||||
uint8_t cur_group=1;
|
||||
uint8_t group_select=1;
|
||||
char cancel_pass=0;
|
||||
|
@ -1143,7 +1144,7 @@ void check_players_place(char mode) {
|
|||
int sect;
|
||||
int u1;
|
||||
|
||||
levitat = (h->vlastnosti[VLS_KOUZLA] & SPL_LEVITATION) != 0;
|
||||
levitat = force_levitate || ((h->vlastnosti[VLS_KOUZLA] & SPL_LEVITATION) != 0);
|
||||
sect = h->sektor;
|
||||
if (sect >= mapsize)
|
||||
continue;
|
||||
|
|
|
@ -1125,29 +1125,7 @@ void *map_keyboard(EVENT_MSG *msg,void **usr);
|
|||
|
||||
char doNotLoadMapState=0;
|
||||
|
||||
static int reload_map_handler(EVENT_MSG *msg,void **usr)
|
||||
{
|
||||
extern char running_battle;
|
||||
if (msg->msg==E_EXTERNAL_MSG)
|
||||
{
|
||||
const char *m = va_arg(msg->data, const char *);
|
||||
char fname[13];
|
||||
int sector;
|
||||
int side;
|
||||
int i;
|
||||
|
||||
if (sscanf(m, "RELOAD %12s %d %d", fname, §or, &side) == 3) {
|
||||
|
||||
reload_ddls();
|
||||
strcopy_n(loadlevel.name,fname,sizeof(loadlevel.name));
|
||||
loadlevel.start_pos=sector;
|
||||
loadlevel.dir = side;
|
||||
for(i=0;i<POCET_POSTAV;i++) if (postavy[i].used) {
|
||||
postavy[i].sektor=loadlevel.start_pos;
|
||||
postavy[i].direction=loadlevel.dir;
|
||||
postavy[i].groupnum = 1;
|
||||
}
|
||||
SEND_LOG("(WIZARD) Load map '%s' %d %d",loadlevel.name,loadlevel.start_pos, loadlevel.dir);
|
||||
static void reload_restart_map() {
|
||||
unwire_proc();
|
||||
if (battle) konec_kola();
|
||||
battle=0;
|
||||
|
@ -1163,8 +1141,64 @@ extern char running_battle;
|
|||
autosave_on_enter = 0;
|
||||
game_display_focus();
|
||||
send_message(E_CLOSE_MAP);
|
||||
|
||||
}
|
||||
|
||||
static int reload_map_handler(EVENT_MSG *msg,void **usr)
|
||||
{
|
||||
extern char running_battle;
|
||||
if (msg->msg==E_EXTERNAL_MSG)
|
||||
{
|
||||
const char *m = va_arg(msg->data, const char *);
|
||||
char fname[13];
|
||||
int sector;
|
||||
int side;
|
||||
int i;
|
||||
|
||||
if (strcmp(m, "RELOAD") == 0) {
|
||||
reload_ddls();
|
||||
loadlevel.start_pos=viewsector;
|
||||
loadlevel.dir=viewdir;
|
||||
strcopy_n(loadlevel.name, level_fname, sizeof(loadlevel.name));
|
||||
SEND_LOG("(WIZARD) Reload map");
|
||||
reload_restart_map();
|
||||
|
||||
} else if (sscanf(m, "TELEPORT %12s %d %d", fname, §or, &side) == 3) {
|
||||
|
||||
reload_ddls();
|
||||
strcopy_n(loadlevel.name,fname,sizeof(loadlevel.name));
|
||||
loadlevel.start_pos=sector;
|
||||
loadlevel.dir = side;
|
||||
for(i=0;i<POCET_POSTAV;i++) if (postavy[i].used) {
|
||||
postavy[i].sektor=loadlevel.start_pos;
|
||||
postavy[i].direction=loadlevel.dir;
|
||||
postavy[i].groupnum = 1;
|
||||
}
|
||||
SEND_LOG("(WIZARD) Load map '%s' %d %d",loadlevel.name,loadlevel.start_pos, loadlevel.dir);
|
||||
reload_restart_map();
|
||||
} else if (sscanf(m, "CONSOLE %d", &i) == 1) {
|
||||
console_show(i);
|
||||
game_display_focus();
|
||||
} else if (strncmp(m, "CONSOLE_CMD ", 12) == 0) {
|
||||
const char *cmd = m+12;
|
||||
if (strchr(cmd, '~') == NULL) {
|
||||
console_exec(cmd);
|
||||
} else {
|
||||
char *tmp = local_strdup(cmd);
|
||||
char *x = strchr(tmp,'~');
|
||||
while (x) {
|
||||
*x = 0;
|
||||
console_exec(tmp);
|
||||
tmp = x+1;
|
||||
x = strchr(tmp,'~');
|
||||
}
|
||||
if (*tmp) console_exec(tmp);
|
||||
}
|
||||
|
||||
game_display_focus();
|
||||
} else if (strncmp(m, "MESSAGE ", 8) == 0) {
|
||||
bott_disp_text(m+8);
|
||||
game_display_focus();
|
||||
}
|
||||
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue