viewing paste topic/11292- OnPCStatCalcEvent_1.1 | C

Posted on the | Last edited on
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71
//===== Hercules Plugin ======================================
//= OnPCStatCalcEvent
//===== By: ==================================================
//= AnnieRuru
//= originally by QQfoolsorellina
//===== Current Version: =====================================
//= 1.1
//===== Compatible With: =====================================
//= Hercules 2018-02-06
//===== Description: =========================================
//= give player permanent bonus
//===== Topic ================================================
//= http://herc.ws/board/topic/11292-OnPCStatCalcEvent/
//===== Additional Comments: =================================  
//= finally found a trick to get the status to recalculate ~
//============================================================
 
#include "common/hercules.h"
#include "map/pc.h"
#include "map/npc.h"
#include "map/chrif.h"
#include "map/script.h"
#include "map/status.h"
#include "common/timer.h"
#include "common/nullpo.h"
#include "plugins/HPMHooking.h"
#include "common/HPMDataCheck.h"
 
HPExport struct hplugin_info pinfo = {
        "OnPCStatCalcEvent",
        SERVER_TYPE_MAP,
        "1.1",
        HPM_VERSION,
};
 
void status_calc_pc_additional_pre( struct map_session_data **sd, enum e_status_calc_opt *opt ) {
        nullpo_retv(*sd);
        npc->event_doall_id( "OnPCStatCalcEvent", (*sd)->bl.id );
        return;
}
 
int recalculate_countdown( int tid, int64 tick, int id, intptr data ) {
        struct map_session_data *sd = map->id2sd(id);
        status_calc_pc(sd, SCO_FORCE);
        return 0;
}
 
BUILDIN(recalculatestat) {
        struct map_session_data *sd;
        if ( script_hasdata(st,2) ) {
                if ( data_isstring( script_getdata(st,2) ) )
                        sd = map->nick2sd( script_getstr(st,2) );
                else
                        sd = map->id2sd( script_getnum(st,2) );
        } else
                sd = script->rid2sd(st);
        if (sd)
                timer->add( timer->gettick() +1, recalculate_countdown, sd->bl.id, 0 ); // another trick ... although not thread-safe, but whatever ~
        return true;
}
 
ACMD(recalculatestat) {
        status_calc_pc(sd, SCO_FORCE);
        return true;
}
 
HPExport void plugin_init (void) {
        addHookPre( status, calc_pc_additional, status_calc_pc_additional_pre );
        addScriptCommand( "recalculatestat", "?", recalculatestat );
        addAtcommand( "recalculatestat", recalculatestat );
}
Viewed 517 times, submitted by AnnieRuru.