diff options
-rw-r--r-- | src/map/atcommand.c | 6 | ||||
-rw-r--r-- | src/map/pc.c | 2 | ||||
-rw-r--r-- | src/map/pc.h | 9 |
3 files changed, 16 insertions, 1 deletions
diff --git a/src/map/atcommand.c b/src/map/atcommand.c index 7de68236c..74021b3db 100644 --- a/src/map/atcommand.c +++ b/src/map/atcommand.c @@ -8337,6 +8337,12 @@ ACMD_FUNC(charcommands) } ACMD_FUNC(new_mount) { + + if( pc_cant_newmount(sd) && !(sd->sc.option&OPTION_MOUNTING) ) { + clif_displaymessage(sd->fd,"Your character cannot mount a new mount"); + return -1; + } + clif_displaymessage(sd->fd,"NOTICE: If you crash with mount your LUA is outdated"); if( !(sd->sc.option&OPTION_MOUNTING) ) { clif_displaymessage(sd->fd,"You have mounted."); diff --git a/src/map/pc.c b/src/map/pc.c index c277279c8..d5a7c65cc 100644 --- a/src/map/pc.c +++ b/src/map/pc.c @@ -6945,7 +6945,7 @@ int pc_setoption(struct map_session_data *sd,int type) status_calc_pc(sd,0); //Remove speed penalty. } - if (type&OPTION_MOUNTING && !(p_type&OPTION_MOUNTING) && ( sd->class_&MAPID_THIRDMASK ) != MAPID_RANGER ) { + if (type&OPTION_MOUNTING && !(p_type&OPTION_MOUNTING) && !pc_cant_newmount(sd) ) { clif_status_load_notick(&sd->bl,SI_ALL_RIDING,2,1,0,0); status_calc_pc(sd,0); } else if (!(type&OPTION_MOUNTING) && p_type&OPTION_MOUNTING) { diff --git a/src/map/pc.h b/src/map/pc.h index 1a3b54ac2..a035092b5 100644 --- a/src/map/pc.h +++ b/src/map/pc.h @@ -621,6 +621,15 @@ enum e_pc_permission { #define pc_iswug(sd) ( (sd)->sc.option&OPTION_WUG ) #define pc_isridingwug(sd) ( (sd)->sc.option&OPTION_WUGRIDER ) +/** + * New Mounts -- can this damn job not + **/ +#define pc_cant_newmount(sd) \ + ( \ + ( (sd)->class_&MAPID_THIRDMASK) == MAPID_RANGER || \ + ( ((sd)->class_&MAPID_BASEMASK) == MAPID_SWORDMAN && (sd)->status.class_ != JOB_SWORDMAN ) \ + ) + #define pc_stop_walking(sd, type) unit_stop_walking(&(sd)->bl, type) #define pc_stop_attack(sd) unit_stop_attack(&(sd)->bl) |