diff options
author | Haru <haru@dotalux.com> | 2017-06-28 23:48:19 +0200 |
---|---|---|
committer | Haru <haru@dotalux.com> | 2017-06-28 23:48:19 +0200 |
commit | abe64c3982a11c9834f2e16eaaf0dc940a903fdb (patch) | |
tree | 1ddcfd8fe9582ee869e4544524209d4a51b875f5 /src/map | |
parent | 44afefff8c3b09d47f7d1a7a3d386e83f8b2dcbd (diff) | |
download | hercules-abe64c3982a11c9834f2e16eaaf0dc940a903fdb.tar.gz hercules-abe64c3982a11c9834f2e16eaaf0dc940a903fdb.tar.bz2 hercules-abe64c3982a11c9834f2e16eaaf0dc940a903fdb.tar.xz hercules-abe64c3982a11c9834f2e16eaaf0dc940a903fdb.zip |
Fix a compile error on ARM (Raspberry Pi 3)
According to the C specifications, va_list isn't necessarily a pointer
(it can be an array of pointers, or just about anything). As such, we
can't cast NULL to va_list.
Fixes #1793
Related to 5fd40de233d3a897284f771338cbf8e657182261
Signed-off-by: Haru <haru@dotalux.com>
Diffstat (limited to 'src/map')
-rw-r--r-- | src/map/script.c | 25 | ||||
-rw-r--r-- | src/map/script.h | 3 |
2 files changed, 19 insertions, 9 deletions
diff --git a/src/map/script.c b/src/map/script.c index d993f7547..dbeae5fbc 100644 --- a/src/map/script.c +++ b/src/map/script.c @@ -15009,7 +15009,8 @@ BUILDIN(dispbottom) * All The Players Full Recovery * (HP/SP full restore and resurrect if need) *------------------------------------------*/ -int buildin_recovery_pc_sub(struct map_session_data *sd, va_list ap) { +int buildin_recovery_sub(struct map_session_data *sd) +{ nullpo_retr(0, sd); if (pc_isdead(sd)) { @@ -15021,11 +15022,18 @@ int buildin_recovery_pc_sub(struct map_session_data *sd, va_list ap) { return 0; } -int buildin_recovery_sub(struct block_list *bl, va_list ap) { - return script->buildin_recovery_pc_sub(BL_CAST(BL_PC, bl), ap); +int buildin_recovery_pc_sub(struct map_session_data *sd, va_list ap) +{ + return script->buildin_recovery_sub(sd); +} + +int buildin_recovery_bl_sub(struct block_list *bl, va_list ap) +{ + return script->buildin_recovery_sub(BL_CAST(BL_PC, bl)); } -BUILDIN(recovery) { +BUILDIN(recovery) +{ if (script_hasdata(st, 2)) { if (script_isstringtype(st, 2)) { int16 m = map->mapname2mapid(script_getstr(st, 2)); @@ -15040,15 +15048,15 @@ BUILDIN(recovery) { int16 y1 = script_getnum(st, 4); int16 x2 = script_getnum(st, 5); int16 y2 = script_getnum(st, 6); - map->foreachinarea(script->buildin_recovery_sub, m, x1, y1, x2, y2, BL_PC); + map->foreachinarea(script->buildin_recovery_bl_sub, m, x1, y1, x2, y2, BL_PC); } else { - map->foreachinmap(script->buildin_recovery_sub, m, BL_PC); + map->foreachinmap(script->buildin_recovery_bl_sub, m, BL_PC); } } else { struct map_session_data *sd = script->id2sd(st, script_getnum(st, 2)); - if (sd) { - script->buildin_recovery_pc_sub(sd, NULL); + if (sd != NULL) { + script->buildin_recovery_sub(sd); } } } else { @@ -24380,6 +24388,7 @@ void script_defaults(void) script->menu_countoptions = menu_countoptions; script->buildin_recovery_sub = buildin_recovery_sub; script->buildin_recovery_pc_sub = buildin_recovery_pc_sub; + script->buildin_recovery_bl_sub = buildin_recovery_bl_sub; script->buildin_areawarp_sub = buildin_areawarp_sub; script->buildin_areapercentheal_sub = buildin_areapercentheal_sub; script->buildin_delitem_delete = buildin_delitem_delete; diff --git a/src/map/script.h b/src/map/script.h index 6c9ad2b8c..189122230 100644 --- a/src/map/script.h +++ b/src/map/script.h @@ -854,8 +854,9 @@ struct script_interface { int (*db_free_code_sub) (union DBKey key, struct DBData *data, va_list ap); void (*add_autobonus) (const char *autobonus); int (*menu_countoptions) (const char *str, int max_count, int *total); + int (*buildin_recovery_sub) (struct map_session_data *sd); int (*buildin_recovery_pc_sub) (struct map_session_data *sd, va_list ap); - int (*buildin_recovery_sub) (struct block_list *bl, va_list ap); + int (*buildin_recovery_bl_sub) (struct block_list *bl, va_list ap); int (*buildin_areawarp_sub) (struct block_list *bl, va_list ap); int (*buildin_areapercentheal_sub) (struct block_list *bl, va_list ap); void (*buildin_delitem_delete) (struct map_session_data *sd, int idx, int *amount, bool delete_items); |