From 8f1cae217b2ddf1d893ab4dd7456f8c7f4f5dcac Mon Sep 17 00:00:00 2001 From: skotlex Date: Sat, 20 Jan 2007 08:14:40 +0000 Subject: - Updated merc_reset_stats to handle resetting skill tree and points as well. - Updated @homshuffle so that the skill tree and current skill points are not messed up. git-svn-id: https://rathena.svn.sourceforge.net/svnroot/rathena/trunk@9678 54d463be-8e91-2dee-dedb-b68131a5f0ec --- src/map/atcommand.c | 7 ++++++- src/map/mercenary.c | 2 ++ 2 files changed, 8 insertions(+), 1 deletion(-) (limited to 'src/map') diff --git a/src/map/atcommand.c b/src/map/atcommand.c index f4be3b421..4f821d3f1 100644 --- a/src/map/atcommand.c +++ b/src/map/atcommand.c @@ -10012,8 +10012,9 @@ int atcommand_homshuffle( const char* command, const char* message) { struct homun_data *hd; - int lv, i; + int lv, i, skillpts; unsigned int exp; + struct skill b_skill; TBL_PC* tsd = sd; nullpo_retr(-1, sd); @@ -10042,6 +10043,8 @@ int atcommand_homshuffle( lv = hd->homunculus.level; exp = hd->homunculus.exp; + memcpy(&b_skill, &hd->homunculus.hskill, sizeof(b_skill)); + skillpts = hd->homunculus.skillpts; //Reset values to level 1. merc_reset_stats(hd); //Level it back up @@ -10050,6 +10053,8 @@ int atcommand_homshuffle( merc_hom_levelup(hd); } hd->homunculus.exp = exp; + memcpy(&hd->homunculus.hskill, &b_skill, sizeof(b_skill)); + hd->homunculus.skillpts = skillpts; status_calc_homunculus(hd,0); status_percent_heal(&hd->bl, 100, 100); clif_misceffect2(&hd->bl,568); diff --git a/src/map/mercenary.c b/src/map/mercenary.c index 61df02132..b776ed4b5 100644 --- a/src/map/mercenary.c +++ b/src/map/mercenary.c @@ -748,6 +748,8 @@ void merc_reset_stats(struct homun_data *hd) hom->luk = db->baseLUK*10; hom->exp = 0; hd->exp_next = hexptbl[0]; + memset(&hd->homunculus.hskill, 0, sizeof hd->homunculus.hskill); + hd->homunculus.skillpts = 0; } int read_homunculusdb(void) -- cgit v1.2.3-60-g2f50