Explorar o código

fixed STEAL. 8) and tested at lhz_dun03

git-svn-id: https://svn.code.sf.net/p/rathena/svn/trunk@6399 54d463be-8e91-2dee-dedb-b68131a5f0ec
Lupus %!s(int64=19) %!d(string=hai) anos
pai
achega
d880305708
Modificáronse 2 ficheiros con 5 adicións e 6 borrados
  1. 1 0
      Changelog-Trunk.txt
  2. 4 6
      src/map/pc.c

+ 1 - 0
Changelog-Trunk.txt

@@ -4,6 +4,7 @@ AS OF SVN REV. 5091, WE ARE NOW USING TRUNK.  ALL UNTESTED BUGFIXES/FEATURES GO
 IF YOU HAVE A WORKING AND TESTED BUGFIX PUT IT INTO STABLE AS WELL AS TRUNK.
 
 2006/04/30
+	* Fixed and enabled STEAL skill [Lupus]
 	* Implemented NJ_SHADOWJUMP. [blackhole89]
 	* Moved the soul-drain code to skill_counter_additionaleffect [Skotlex]
 	* Fixed fake NPC missing code. Thanks to Skotlex for pointing out. [Lance]

+ 4 - 6
src/map/pc.c

@@ -2925,10 +2925,8 @@ int pc_steal_item(struct map_session_data *sd,struct block_list *bl)
 
 	if(!sd || !bl || bl->type != BL_MOB)
 		return 0;
-	
-	md=(struct mob_data *)bl;
-//temp steal disable [Lupus]
-	if(1 || md->state.steal_flag>battle_config.skill_steal_max_tries || status_get_mode(bl)&MD_BOSS || md->master_id ||
+
+	if(md->state.steal_flag>battle_config.skill_steal_max_tries || status_get_mode(bl)&MD_BOSS || md->master_id ||
 		(md->class_>=1324 && md->class_<1364) || // prevent stealing from treasure boxes [Valaris]
 		map[md->bl.m].flag.nomobloot ||        // check noloot map flag [Lorky]
 		md->sc.data[SC_STONE].timer != -1 || md->sc.data[SC_FREEZE].timer != -1 //status change check
@@ -2950,12 +2948,12 @@ int pc_steal_item(struct map_session_data *sd,struct block_list *bl)
 		itemid = md->db->dropitem[i].nameid;
 		if(itemid <= 0 || (itemid>4000 && itemid<5000 && pc_checkskill(sd,TF_STEAL) <= 5))
 			continue;
-		if(rand() % 10000 > ((md->db->dropitem[i].p * skill) / 100 + sd->add_steal_rate))
+		if(rand() % 10000 <= ((md->db->dropitem[i].p * skill) / 100 + sd->add_steal_rate))
 			break;
 	}
 	if (i == MAX_MOB_DROP)
 		return 0;
-
+	
 	md->state.steal_flag = 255; //you can't steal from this mob any more
 	
 	memset(&tmp_item,0,sizeof(tmp_item));