diff options
Diffstat (limited to 'src/emap/itemdb.c')
-rw-r--r-- | src/emap/itemdb.c | 91 |
1 files changed, 91 insertions, 0 deletions
diff --git a/src/emap/itemdb.c b/src/emap/itemdb.c new file mode 100644 index 0000000..34905a9 --- /dev/null +++ b/src/emap/itemdb.c @@ -0,0 +1,91 @@ +// Copyright (c) Copyright (c) Hercules Dev Team, licensed under GNU GPL. +// Copyright (c) 2014 Evol developers + +#include <stdio.h> +#include <stdlib.h> +#include <string.h> + +#include "common/HPMi.h" +#include "common/malloc.h" +#include "common/mmo.h" +#include "common/socket.h" +#include "common/strlib.h" +#include "map/itemdb.h" +#include "map/map.h" +#include "map/npc.h" +#include "map/pc.h" + +#include "emap/data/itemd.h" +#include "emap/struct/itemdext.h" +#include "emap/npc.h" + +bool eitemdb_is_item_usable(struct item_data *item) +{ + hookStop(); + if (!item) + return false; + return item->type == IT_HEALING || item->type == IT_USABLE || item->type == IT_CASH || item->type == IT_PETEGG; +} + +void eitemdb_readdb_additional_fields(int *itemid, + config_setting_t *it, + int *n __attribute__ ((unused)), + const char *source __attribute__ ((unused))) +{ + struct item_data *item = itemdb->exists(*itemid); + int i32 = 0; + if (!item) + { + hookStop(); + return; + } + struct ItemdExt *data = itemd_get(item); + if (!data) + { + hookStop(); + return; + } + + config_setting_t *t = NULL; + + if (libconfig->setting_lookup_int(it, "FloorLifeTime", &i32) && i32 >= 0) + data->floorLifeTime = i32; + if ((t = libconfig->setting_get_member(it, "AllowPickup"))) + data->allowPickup = libconfig->setting_get_bool(t) ? 1 : 0; + if (libconfig->setting_lookup_int(it, "RequiredStr", &i32) && i32 >= 0) + data->requiredStr = i32; + if (libconfig->setting_lookup_int(it, "RequiredAgi", &i32) && i32 >= 0) + data->requiredAgi = i32; + if (libconfig->setting_lookup_int(it, "RequiredVit", &i32) && i32 >= 0) + data->requiredVit = i32; + if (libconfig->setting_lookup_int(it, "RequiredInt", &i32) && i32 >= 0) + data->requiredInt = i32; + if (libconfig->setting_lookup_int(it, "RequiredDex", &i32) && i32 >= 0) + data->requiredDex = i32; + if (libconfig->setting_lookup_int(it, "RequiredLuk", &i32) && i32 >= 0) + data->requiredLuk = i32; + if (libconfig->setting_lookup_int(it, "RequiredMaxHp", &i32) && i32 >= 0) + data->requiredMaxHp = i32; + if (libconfig->setting_lookup_int(it, "RequiredMaxSp", &i32) && i32 >= 0) + data->requiredMaxSp = i32; + if (libconfig->setting_lookup_int(it, "RequiredAtk", &i32) && i32 >= 0) + data->requiredAtk = i32; + if (libconfig->setting_lookup_int(it, "RequiredMAtkMin", &i32) && i32 >= 0) + data->requiredMAtkMin = i32; + if (libconfig->setting_lookup_int(it, "RequiredMAtkMax", &i32) && i32 >= 0) + data->requiredMAtkMax = i32; + if (libconfig->setting_lookup_int(it, "RequiredDef", &i32) && i32 >= 0) + data->requiredDef = i32; + if (libconfig->setting_lookup_int(it, "RequiredMDef", &i32) && i32 >= 0) + data->requiredMDef = i32; + + if (itemdb->lookup_const(it, "UseEffect", &i32)) + data->useEffect = i32; + if (itemdb->lookup_const(it, "UseFailEffect", &i32)) + data->useFailEffect = i32; + if (itemdb->lookup_const(it, "UnequipEffect", &i32)) + data->unequipEffect = i32; + if (itemdb->lookup_const(it, "UnequipFailEffect", &i32)) + data->unequipFailEffect = i32; + hookStop(); +} |