Refactored client event if-else cascade to switch statement
This commit is contained in:
parent
d3131aeae7
commit
e7246d3f0d
234
src/game.cpp
234
src/game.cpp
@ -3046,7 +3046,10 @@ void Game::processClientEvents(CameraOrientation *cam)
|
|||||||
|
|
||||||
for ( ; event.type != CE_NONE; event = client->getClientEvent()) {
|
for ( ; event.type != CE_NONE; event = client->getClientEvent()) {
|
||||||
|
|
||||||
if (event.type == CE_PLAYER_DAMAGE && client->getHP() != 0) {
|
switch (event.type) {
|
||||||
|
case CE_PLAYER_DAMAGE:
|
||||||
|
if (client->getHP() == 0)
|
||||||
|
break;
|
||||||
if (client->moddingEnabled()) {
|
if (client->moddingEnabled()) {
|
||||||
client->getScript()->on_damage_taken(event.player_damage.amount);
|
client->getScript()->on_damage_taken(event.player_damage.amount);
|
||||||
}
|
}
|
||||||
@ -3058,12 +3061,15 @@ void Game::processClientEvents(CameraOrientation *cam)
|
|||||||
player->hurt_tilt_strength =
|
player->hurt_tilt_strength =
|
||||||
rangelim(event.player_damage.amount / 4, 1.0, 4.0);
|
rangelim(event.player_damage.amount / 4, 1.0, 4.0);
|
||||||
|
|
||||||
MtEvent *e = new SimpleTriggerEvent("PlayerDamage");
|
client->event()->put(new SimpleTriggerEvent("PlayerDamage"));
|
||||||
client->event()->put(e);
|
break;
|
||||||
} else if (event.type == CE_PLAYER_FORCE_MOVE) {
|
|
||||||
|
case CE_PLAYER_FORCE_MOVE:
|
||||||
cam->camera_yaw = event.player_force_move.yaw;
|
cam->camera_yaw = event.player_force_move.yaw;
|
||||||
cam->camera_pitch = event.player_force_move.pitch;
|
cam->camera_pitch = event.player_force_move.pitch;
|
||||||
} else if (event.type == CE_DEATHSCREEN) {
|
break;
|
||||||
|
|
||||||
|
case CE_DEATHSCREEN:
|
||||||
// This should be enabled for death formspec in builtin
|
// This should be enabled for death formspec in builtin
|
||||||
client->getScript()->on_death();
|
client->getScript()->on_death();
|
||||||
|
|
||||||
@ -3071,8 +3077,9 @@ void Game::processClientEvents(CameraOrientation *cam)
|
|||||||
runData.damage_flash = 0;
|
runData.damage_flash = 0;
|
||||||
player->hurt_tilt_timer = 0;
|
player->hurt_tilt_timer = 0;
|
||||||
player->hurt_tilt_strength = 0;
|
player->hurt_tilt_strength = 0;
|
||||||
|
break;
|
||||||
|
|
||||||
} else if (event.type == CE_SHOW_FORMSPEC) {
|
case CE_SHOW_FORMSPEC:
|
||||||
if (*(event.show_formspec.formspec) == "") {
|
if (*(event.show_formspec.formspec) == "") {
|
||||||
if (current_formspec && ( *(event.show_formspec.formname) == "" || *(event.show_formspec.formname) == cur_formname) ){
|
if (current_formspec && ( *(event.show_formspec.formname) == "" || *(event.show_formspec.formname) == cur_formname) ){
|
||||||
current_formspec->quitMenu();
|
current_formspec->quitMenu();
|
||||||
@ -3088,54 +3095,65 @@ void Game::processClientEvents(CameraOrientation *cam)
|
|||||||
cur_formname = *(event.show_formspec.formname);
|
cur_formname = *(event.show_formspec.formname);
|
||||||
}
|
}
|
||||||
|
|
||||||
delete(event.show_formspec.formspec);
|
|
||||||
delete(event.show_formspec.formname);
|
|
||||||
} else if (event.type == CE_SHOW_LOCAL_FORMSPEC) {
|
|
||||||
FormspecFormSource *fs_src = new FormspecFormSource(*event.show_formspec.formspec);
|
|
||||||
LocalFormspecHandler *txt_dst = new LocalFormspecHandler(*event.show_formspec.formname, client);
|
|
||||||
create_formspec_menu(¤t_formspec, client, device, &input->joystick,
|
|
||||||
fs_src, txt_dst);
|
|
||||||
delete event.show_formspec.formspec;
|
delete event.show_formspec.formspec;
|
||||||
delete event.show_formspec.formname;
|
delete event.show_formspec.formname;
|
||||||
} else if ((event.type == CE_SPAWN_PARTICLE) ||
|
break;
|
||||||
(event.type == CE_ADD_PARTICLESPAWNER) ||
|
|
||||||
(event.type == CE_DELETE_PARTICLESPAWNER)) {
|
case CE_SHOW_LOCAL_FORMSPEC:
|
||||||
|
{
|
||||||
|
FormspecFormSource *fs_src = new FormspecFormSource(*event.show_formspec.formspec);
|
||||||
|
LocalFormspecHandler *txt_dst = new LocalFormspecHandler(*event.show_formspec.formname, client);
|
||||||
|
create_formspec_menu(¤t_formspec, client, device, &input->joystick,
|
||||||
|
fs_src, txt_dst);
|
||||||
|
}
|
||||||
|
delete event.show_formspec.formspec;
|
||||||
|
delete event.show_formspec.formname;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case CE_SPAWN_PARTICLE:
|
||||||
|
case CE_ADD_PARTICLESPAWNER:
|
||||||
|
case CE_DELETE_PARTICLESPAWNER:
|
||||||
client->getParticleManager()->handleParticleEvent(&event, client,
|
client->getParticleManager()->handleParticleEvent(&event, client,
|
||||||
smgr, player);
|
smgr, player);
|
||||||
} else if (event.type == CE_HUDADD) {
|
break;
|
||||||
u32 id = event.hudadd.id;
|
|
||||||
HudElement *e = player->getHud(id);
|
|
||||||
|
|
||||||
if (e != NULL) {
|
case CE_HUDADD:
|
||||||
delete event.hudadd.pos;
|
{
|
||||||
delete event.hudadd.name;
|
u32 id = event.hudadd.id;
|
||||||
delete event.hudadd.scale;
|
|
||||||
delete event.hudadd.text;
|
HudElement *e = player->getHud(id);
|
||||||
delete event.hudadd.align;
|
|
||||||
delete event.hudadd.offset;
|
if (e != NULL) {
|
||||||
delete event.hudadd.world_pos;
|
delete event.hudadd.pos;
|
||||||
delete event.hudadd.size;
|
delete event.hudadd.name;
|
||||||
continue;
|
delete event.hudadd.scale;
|
||||||
|
delete event.hudadd.text;
|
||||||
|
delete event.hudadd.align;
|
||||||
|
delete event.hudadd.offset;
|
||||||
|
delete event.hudadd.world_pos;
|
||||||
|
delete event.hudadd.size;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
e = new HudElement;
|
||||||
|
e->type = (HudElementType)event.hudadd.type;
|
||||||
|
e->pos = *event.hudadd.pos;
|
||||||
|
e->name = *event.hudadd.name;
|
||||||
|
e->scale = *event.hudadd.scale;
|
||||||
|
e->text = *event.hudadd.text;
|
||||||
|
e->number = event.hudadd.number;
|
||||||
|
e->item = event.hudadd.item;
|
||||||
|
e->dir = event.hudadd.dir;
|
||||||
|
e->align = *event.hudadd.align;
|
||||||
|
e->offset = *event.hudadd.offset;
|
||||||
|
e->world_pos = *event.hudadd.world_pos;
|
||||||
|
e->size = *event.hudadd.size;
|
||||||
|
|
||||||
|
u32 new_id = player->addHud(e);
|
||||||
|
//if this isn't true our huds aren't consistent
|
||||||
|
sanity_check(new_id == id);
|
||||||
}
|
}
|
||||||
|
|
||||||
e = new HudElement;
|
|
||||||
e->type = (HudElementType)event.hudadd.type;
|
|
||||||
e->pos = *event.hudadd.pos;
|
|
||||||
e->name = *event.hudadd.name;
|
|
||||||
e->scale = *event.hudadd.scale;
|
|
||||||
e->text = *event.hudadd.text;
|
|
||||||
e->number = event.hudadd.number;
|
|
||||||
e->item = event.hudadd.item;
|
|
||||||
e->dir = event.hudadd.dir;
|
|
||||||
e->align = *event.hudadd.align;
|
|
||||||
e->offset = *event.hudadd.offset;
|
|
||||||
e->world_pos = *event.hudadd.world_pos;
|
|
||||||
e->size = *event.hudadd.size;
|
|
||||||
|
|
||||||
u32 new_id = player->addHud(e);
|
|
||||||
//if this isn't true our huds aren't consistent
|
|
||||||
sanity_check(new_id == id);
|
|
||||||
|
|
||||||
delete event.hudadd.pos;
|
delete event.hudadd.pos;
|
||||||
delete event.hudadd.name;
|
delete event.hudadd.name;
|
||||||
delete event.hudadd.scale;
|
delete event.hudadd.scale;
|
||||||
@ -3144,74 +3162,84 @@ void Game::processClientEvents(CameraOrientation *cam)
|
|||||||
delete event.hudadd.offset;
|
delete event.hudadd.offset;
|
||||||
delete event.hudadd.world_pos;
|
delete event.hudadd.world_pos;
|
||||||
delete event.hudadd.size;
|
delete event.hudadd.size;
|
||||||
} else if (event.type == CE_HUDRM) {
|
break;
|
||||||
HudElement *e = player->removeHud(event.hudrm.id);
|
|
||||||
|
|
||||||
if (e != NULL)
|
case CE_HUDRM:
|
||||||
delete(e);
|
{
|
||||||
} else if (event.type == CE_HUDCHANGE) {
|
HudElement *e = player->removeHud(event.hudrm.id);
|
||||||
u32 id = event.hudchange.id;
|
|
||||||
HudElement *e = player->getHud(id);
|
|
||||||
|
|
||||||
if (e == NULL) {
|
if (e != NULL)
|
||||||
delete event.hudchange.v3fdata;
|
delete e;
|
||||||
delete event.hudchange.v2fdata;
|
|
||||||
delete event.hudchange.sdata;
|
|
||||||
delete event.hudchange.v2s32data;
|
|
||||||
continue;
|
|
||||||
}
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
switch (event.hudchange.stat) {
|
case CE_HUDCHANGE:
|
||||||
case HUD_STAT_POS:
|
{
|
||||||
e->pos = *event.hudchange.v2fdata;
|
u32 id = event.hudchange.id;
|
||||||
break;
|
HudElement *e = player->getHud(id);
|
||||||
|
|
||||||
case HUD_STAT_NAME:
|
if (e == NULL) {
|
||||||
e->name = *event.hudchange.sdata;
|
delete event.hudchange.v3fdata;
|
||||||
break;
|
delete event.hudchange.v2fdata;
|
||||||
|
delete event.hudchange.sdata;
|
||||||
|
delete event.hudchange.v2s32data;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
case HUD_STAT_SCALE:
|
switch (event.hudchange.stat) {
|
||||||
e->scale = *event.hudchange.v2fdata;
|
case HUD_STAT_POS:
|
||||||
break;
|
e->pos = *event.hudchange.v2fdata;
|
||||||
|
break;
|
||||||
|
|
||||||
case HUD_STAT_TEXT:
|
case HUD_STAT_NAME:
|
||||||
e->text = *event.hudchange.sdata;
|
e->name = *event.hudchange.sdata;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case HUD_STAT_NUMBER:
|
case HUD_STAT_SCALE:
|
||||||
e->number = event.hudchange.data;
|
e->scale = *event.hudchange.v2fdata;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case HUD_STAT_ITEM:
|
case HUD_STAT_TEXT:
|
||||||
e->item = event.hudchange.data;
|
e->text = *event.hudchange.sdata;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case HUD_STAT_DIR:
|
case HUD_STAT_NUMBER:
|
||||||
e->dir = event.hudchange.data;
|
e->number = event.hudchange.data;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case HUD_STAT_ALIGN:
|
case HUD_STAT_ITEM:
|
||||||
e->align = *event.hudchange.v2fdata;
|
e->item = event.hudchange.data;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case HUD_STAT_OFFSET:
|
case HUD_STAT_DIR:
|
||||||
e->offset = *event.hudchange.v2fdata;
|
e->dir = event.hudchange.data;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case HUD_STAT_WORLD_POS:
|
case HUD_STAT_ALIGN:
|
||||||
e->world_pos = *event.hudchange.v3fdata;
|
e->align = *event.hudchange.v2fdata;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case HUD_STAT_SIZE:
|
case HUD_STAT_OFFSET:
|
||||||
e->size = *event.hudchange.v2s32data;
|
e->offset = *event.hudchange.v2fdata;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case HUD_STAT_WORLD_POS:
|
||||||
|
e->world_pos = *event.hudchange.v3fdata;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case HUD_STAT_SIZE:
|
||||||
|
e->size = *event.hudchange.v2s32data;
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
delete event.hudchange.v3fdata;
|
delete event.hudchange.v3fdata;
|
||||||
delete event.hudchange.v2fdata;
|
delete event.hudchange.v2fdata;
|
||||||
delete event.hudchange.sdata;
|
delete event.hudchange.sdata;
|
||||||
delete event.hudchange.v2s32data;
|
delete event.hudchange.v2s32data;
|
||||||
} else if (event.type == CE_SET_SKY) {
|
break;
|
||||||
|
|
||||||
|
case CE_SET_SKY:
|
||||||
sky->setVisible(false);
|
sky->setVisible(false);
|
||||||
|
|
||||||
if (skybox) {
|
if (skybox) {
|
||||||
@ -3245,10 +3273,18 @@ void Game::processClientEvents(CameraOrientation *cam)
|
|||||||
delete event.set_sky.bgcolor;
|
delete event.set_sky.bgcolor;
|
||||||
delete event.set_sky.type;
|
delete event.set_sky.type;
|
||||||
delete event.set_sky.params;
|
delete event.set_sky.params;
|
||||||
} else if (event.type == CE_OVERRIDE_DAY_NIGHT_RATIO) {
|
break;
|
||||||
bool enable = event.override_day_night_ratio.do_override;
|
|
||||||
u32 value = event.override_day_night_ratio.ratio_f * 1000;
|
case CE_OVERRIDE_DAY_NIGHT_RATIO:
|
||||||
client->getEnv().setDayNightRatioOverride(enable, value);
|
client->getEnv().setDayNightRatioOverride(
|
||||||
|
event.override_day_night_ratio.do_override,
|
||||||
|
event.override_day_night_ratio.ratio_f * 1000);
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
// unknown or unhandled type
|
||||||
|
break;
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user