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 1457 times, submitted by AnnieRuru.