diff options
author | ultramage <ultramage@54d463be-8e91-2dee-dedb-b68131a5f0ec> | 2009-01-31 19:31:30 +0000 |
---|---|---|
committer | ultramage <ultramage@54d463be-8e91-2dee-dedb-b68131a5f0ec> | 2009-01-31 19:31:30 +0000 |
commit | 97eec218a3f43cd6929ed2a4d530140dc352d515 (patch) | |
tree | f8ae84bf230bc2633bb2421eca75525eef500f0e /src | |
parent | 64b6e20b84aa3dca07228df923e73c0703b3d5af (diff) | |
download | hercules-97eec218a3f43cd6929ed2a4d530140dc352d515.tar.gz hercules-97eec218a3f43cd6929ed2a4d530140dc352d515.tar.bz2 hercules-97eec218a3f43cd6929ed2a4d530140dc352d515.tar.xz hercules-97eec218a3f43cd6929ed2a4d530140dc352d515.zip |
Added skillunit_db for efficient execution of skill_unit_timer() (followup to r13503).
git-svn-id: https://rathena.svn.sourceforge.net/svnroot/rathena/trunk@13504 54d463be-8e91-2dee-dedb-b68131a5f0ec
Diffstat (limited to 'src')
-rw-r--r-- | src/map/skill.c | 22 |
1 files changed, 11 insertions, 11 deletions
diff --git a/src/map/skill.c b/src/map/skill.c index 7187cc37b..c7bd3f998 100644 --- a/src/map/skill.c +++ b/src/map/skill.c @@ -51,6 +51,8 @@ static struct eri *skill_unit_ers = NULL; //For handling skill_unit's [Skotlex] static struct eri *skill_timer_ers = NULL; //For handling skill_timerskills [Skotlex] +DBMap* skillunit_db = NULL; // int id -> struct skill_unit* + DBMap* skilldb_name2id = NULL; struct s_skill_db skill_db[MAX_SKILL_DB]; struct s_skill_produce_db skill_produce_db[MAX_SKILL_PRODUCE_DB]; @@ -9514,6 +9516,7 @@ struct skill_unit *skill_initunit (struct skill_unit_group *group, int idx, int unit->val1=val1; unit->val2=val2; + idb_put(skillunit_db, unit->bl.id, unit); map_addiddb(&unit->bl); map_addblock(&unit->bl); @@ -9584,6 +9587,7 @@ int skill_delunit (struct skill_unit* unit) unit->group=NULL; unit->alive=0; + idb_remove(skillunit_db, unit->bl.id); map_delblock(&unit->bl); // don't free yet if(--group->alive_count==0) skill_delunitgroup(NULL, group); @@ -9745,7 +9749,7 @@ int skill_delunitgroup (struct block_list *src, struct skill_unit_group *group) group->valstr = NULL; } - map_freeblock(&group->unit->bl); + map_freeblock(&group->unit->bl); // schedules deallocation of whole array (HACK) idb_remove(group_db, group->group_id); group->unit=NULL; group->group_id=0; @@ -9850,18 +9854,13 @@ int skill_unit_timer_sub_onplace (struct block_list* bl, va_list ap) /*========================================== * *------------------------------------------*/ -int skill_unit_timer_sub (struct block_list* bl, va_list ap) +static int skill_unit_timer_sub (DBKey key, void* data, va_list ap) { + struct skill_unit* unit = (struct skill_unit*)data; + struct skill_unit_group* group = unit->group; unsigned int tick = va_arg(ap,unsigned int); - struct skill_unit* unit; - struct skill_unit_group* group; bool dissonance; - - if( bl->type != BL_SKILL ) - return 0; - - unit = (struct skill_unit *)bl; - group = unit->group; + struct block_list* bl = &unit->bl; if( !unit->alive ) return 0; @@ -10018,7 +10017,7 @@ int skill_unit_timer(int tid, unsigned int tick, int id, intptr data) { map_freeblock_lock(); - map_foreachiddb( skill_unit_timer_sub, tick ); + skillunit_db->foreach(skillunit_db, skill_unit_timer_sub, tick); map_freeblock_unlock(); @@ -11386,6 +11385,7 @@ int do_init_skill (void) skill_readdb(); group_db = idb_alloc(DB_OPT_BASE); + skillunit_db = idb_alloc(DB_OPT_BASE); skill_unit_ers = ers_new(sizeof(struct skill_unit_group)); skill_timer_ers = ers_new(sizeof(struct skill_timerskill)); |