diff options
Diffstat (limited to 'src/map/itemdb.cpp')
-rw-r--r-- | src/map/itemdb.cpp | 328 |
1 files changed, 164 insertions, 164 deletions
diff --git a/src/map/itemdb.cpp b/src/map/itemdb.cpp index 03e59d6..8d0eb3b 100644 --- a/src/map/itemdb.cpp +++ b/src/map/itemdb.cpp @@ -18,7 +18,7 @@ #include "memwatch.hpp" #endif -#define MAX_RANDITEM 2000 +#define MAX_RANDITEM 2000 // ** ITEMDB_OVERRIDE_NAME_VERBOSE ** // 定義すると、itemdb.txtとgrfで名前が異なる場合、表示します. @@ -36,12 +36,12 @@ static int blue_box_default = 0, violet_box_default = 0, card_album_default = // Function declarations -static void itemdb_read (void); -static int itemdb_readdb (void); -static int itemdb_read_randomitem (void); -static int itemdb_read_itemavail (void); -static int itemdb_read_itemnametable (void); -static int itemdb_read_noequip (void); +static void itemdb_read(void); +static int itemdb_readdb(void); +static int itemdb_read_randomitem(void); +static int itemdb_read_itemavail(void); +static int itemdb_read_itemnametable(void); +static int itemdb_read_noequip(void); /*========================================== * 名前で検索用 @@ -49,15 +49,15 @@ static int itemdb_read_noequip (void); */ // name = item alias, so we should find items aliases first. if not found then look for "jname" (full name) static -void itemdb_searchname_sub (db_key_t key, db_val_t data, va_list ap) +void itemdb_searchname_sub(db_key_t key, db_val_t data, va_list ap) { struct item_data *item = (struct item_data *) data, **dst; char *str; - str = va_arg (ap, char *); - dst = va_arg (ap, struct item_data **); + str = va_arg(ap, char *); + dst = va_arg(ap, struct item_data **); // if( strcasecmp(item->name,str)==0 || strcmp(item->jname,str)==0 || // memcmp(item->name,str,24)==0 || memcmp(item->jname,str,24)==0 ) - if (strcasecmp (item->name, str) == 0) //by lupus + if (strcasecmp(item->name, str) == 0) //by lupus *dst = item; } @@ -66,13 +66,13 @@ void itemdb_searchname_sub (db_key_t key, db_val_t data, va_list ap) *------------------------------------------ */ static -int itemdb_searchjname_sub (void *key, void *data, va_list ap) +int itemdb_searchjname_sub(void *key, void *data, va_list ap) { struct item_data *item = (struct item_data *) data, **dst; char *str; - str = va_arg (ap, char *); - dst = va_arg (ap, struct item_data **); - if (strcasecmp (item->jname, str) == 0) + str = va_arg(ap, char *); + dst = va_arg(ap, struct item_data **); + if (strcasecmp(item->jname, str) == 0) *dst = item; return 0; } @@ -81,10 +81,10 @@ int itemdb_searchjname_sub (void *key, void *data, va_list ap) * 名前で検索 *------------------------------------------ */ -struct item_data *itemdb_searchname (const char *str) +struct item_data *itemdb_searchname(const char *str) { struct item_data *item = NULL; - numdb_foreach (item_db, itemdb_searchname_sub, str, &item); + numdb_foreach(item_db, itemdb_searchname_sub, str, &item); return item; } @@ -92,14 +92,14 @@ struct item_data *itemdb_searchname (const char *str) * 箱系アイテム検索 *------------------------------------------ */ -int itemdb_searchrandomid (int flags) +int itemdb_searchrandomid(int flags) { - int nameid = 0, i, index, count; + int nameid = 0, i, index, count; struct random_item_data *list = NULL; struct { - int nameid, count; + int nameid, count; struct random_item_data *list; } data[] = { @@ -126,8 +126,8 @@ int itemdb_searchrandomid (int flags) { for (i = 0; i < 1000; i++) { - index = MRAND (count); - if (MRAND (1000000) < list[index].per) + index = MRAND(count); + if (MRAND(1000000) < list[index].per) { nameid = list[index].nameid; break; @@ -142,23 +142,23 @@ int itemdb_searchrandomid (int flags) * DBの存在確認 *------------------------------------------ */ -struct item_data *itemdb_exists (int nameid) +struct item_data *itemdb_exists(int nameid) { - return (struct item_data *)numdb_search (item_db, nameid); + return (struct item_data *)numdb_search(item_db, nameid); } /*========================================== * DBの検索 *------------------------------------------ */ -struct item_data *itemdb_search (int nameid) +struct item_data *itemdb_search(int nameid) { - struct item_data *id = (struct item_data *)numdb_search (item_db, nameid); + struct item_data *id = (struct item_data *)numdb_search(item_db, nameid); if (id) return id; - id = (struct item_data *) calloc (1, sizeof (struct item_data)); - numdb_insert (item_db, nameid, id); + id = (struct item_data *) calloc(1, sizeof(struct item_data)); + numdb_insert(item_db, nameid, id); id->nameid = nameid; id->value_buy = 10; @@ -196,9 +196,9 @@ struct item_data *itemdb_search (int nameid) * *------------------------------------------ */ -int itemdb_isequip (int nameid) +int itemdb_isequip(int nameid) { - int type = itemdb_type (nameid); + int type = itemdb_type(nameid); if (type == 0 || type == 2 || type == 3 || type == 6 || type == 10) return 0; return 1; @@ -208,11 +208,11 @@ int itemdb_isequip (int nameid) * *------------------------------------------ */ -int itemdb_isequip2 (struct item_data *data) +int itemdb_isequip2(struct item_data *data) { if (data) { - int type = data->type; + int type = data->type; if (type == 0 || type == 2 || type == 3 || type == 6 || type == 10) return 0; else @@ -225,9 +225,9 @@ int itemdb_isequip2 (struct item_data *data) * *------------------------------------------ */ -int itemdb_isequip3 (int nameid) +int itemdb_isequip3(int nameid) { - int type = itemdb_type (nameid); + int type = itemdb_type(nameid); if (type == 4 || type == 5 || type == 8) return 1; return 0; @@ -237,7 +237,7 @@ int itemdb_isequip3 (int nameid) * 捨てられるアイテムは1、そうでないアイテムは0 *------------------------------------------ */ -int itemdb_isdropable (int nameid) +int itemdb_isdropable(int nameid) { //結婚指輪は捨てられない switch (nameid) @@ -257,30 +257,30 @@ int itemdb_isdropable (int nameid) * *------------------------------------------ */ -static int itemdb_read_itemslottable (void) +static int itemdb_read_itemslottable(void) { char *buf, *p; size_t s; - buf = (char *)grfio_reads ("data\\itemslottable.txt", &s); + buf = (char *)grfio_reads("data\\itemslottable.txt", &s); if (buf == NULL) return -1; buf[s] = 0; for (p = buf; p - buf < s;) { - int nameid, equip; - sscanf (p, "%d#%d#", &nameid, &equip); - itemdb_search (nameid)->equip = equip; - p = strchr (p, 10); + int nameid, equip; + sscanf(p, "%d#%d#", &nameid, &equip); + itemdb_search(nameid)->equip = equip; + p = strchr(p, 10); if (!p) break; p++; - p = strchr (p, 10); + p = strchr(p, 10); if (!p) break; p++; } - free (buf); + free(buf); return 0; } @@ -289,42 +289,42 @@ static int itemdb_read_itemslottable (void) * アイテムデータベースの読み込み *------------------------------------------ */ -static int itemdb_readdb (void) +static int itemdb_readdb(void) { FILE *fp; char line[1024]; - int ln = 0, lines = 0; - int nameid, j; + int ln = 0, lines = 0; + int nameid, j; char *str[32], *p, *np; struct item_data *id; - int i = 0; + int i = 0; const char *filename[] = { "db/item_db.txt", "db/item_db2.txt" }; for (i = 0; i < 2; i++) { - fp = fopen_ (filename[i], "r"); + fp = fopen_(filename[i], "r"); if (fp == NULL) { if (i > 0) continue; - printf ("can't read %s\n", filename[i]); - exit (1); + printf("can't read %s\n", filename[i]); + exit(1); } lines = 0; - while (fgets (line, 1020, fp)) + while (fgets(line, 1020, fp)) { lines++; if (line[0] == '/' && line[1] == '/') continue; - memset (str, 0, sizeof (str)); + memset(str, 0, sizeof(str)); for (j = 0, np = p = line; j < 17 && p; j++) { while (*p == '\t' || *p == ' ') p++; str[j] = p; - p = strchr (p, ','); + p = strchr(p, ','); if (p) { *p++ = 0; @@ -334,18 +334,18 @@ static int itemdb_readdb (void) if (str[0] == NULL) continue; - nameid = atoi (str[0]); + nameid = atoi(str[0]); if (nameid <= 0 || nameid >= 20000) continue; ln++; //ID,Name,Jname,Type,Price,Sell,Weight,ATK,DEF,Range,Slot,Job,Gender,Loc,wLV,eLV,View - id = itemdb_search (nameid); - memcpy (id->name, str[1], 24); - memcpy (id->jname, str[2], 24); - id->type = atoi (str[3]); - id->value_buy = atoi (str[4]); - id->value_sell = atoi (str[5]); + id = itemdb_search(nameid); + memcpy(id->name, str[1], 24); + memcpy(id->jname, str[2], 24); + id->type = atoi(str[3]); + id->value_buy = atoi(str[4]); + id->value_sell = atoi(str[5]); if (id->value_buy == 0 && id->value_sell == 0) { } @@ -357,17 +357,17 @@ static int itemdb_readdb (void) { id->value_sell = id->value_buy / 2; } - id->weight = atoi (str[6]); - id->atk = atoi (str[7]); - id->def = atoi (str[8]); - id->range = atoi (str[9]); - id->magic_bonus = atoi (str[10]); - id->slot = atoi (str[11]); - id->sex = atoi (str[12]); - id->equip = atoi (str[13]); - id->wlv = atoi (str[14]); - id->elv = atoi (str[15]); - id->look = atoi (str[16]); + id->weight = atoi(str[6]); + id->atk = atoi(str[7]); + id->def = atoi(str[8]); + id->range = atoi(str[9]); + id->magic_bonus = atoi(str[10]); + id->slot = atoi(str[11]); + id->sex = atoi(str[12]); + id->equip = atoi(str[13]); + id->wlv = atoi(str[14]); + id->elv = atoi(str[15]); + id->look = atoi(str[16]); id->flag.available = 1; id->flag.value_notdc = 0; id->flag.value_notoc = 0; @@ -376,16 +376,16 @@ static int itemdb_readdb (void) id->use_script = NULL; id->equip_script = NULL; - if ((p = strchr (np, '{')) == NULL) + if ((p = strchr(np, '{')) == NULL) continue; - id->use_script = parse_script (p, lines); + id->use_script = parse_script(p, lines); - if ((p = strchr (p + 1, '{')) == NULL) + if ((p = strchr(p + 1, '{')) == NULL) continue; - id->equip_script = parse_script (p, lines); + id->equip_script = parse_script(p, lines); } - fclose_ (fp); - printf ("read %s done (count=%d)\n", filename[i], ln); + fclose_(fp); + printf("read %s done (count=%d)\n", filename[i], ln); } return 0; } @@ -396,12 +396,12 @@ static int itemdb_readdb (void) * ランダムアイテム出現データの読み込み *------------------------------------------ */ -static int itemdb_read_randomitem (void) +static int itemdb_read_randomitem(void) { FILE *fp; char line[1024]; - int ln = 0; - int nameid, i, j; + int ln = 0; + int nameid, i, j; char *str[10], *p; const struct @@ -426,7 +426,7 @@ static int itemdb_read_randomitem (void) { "db/item_scroll.txt", scroll, &scroll_count, &scroll_default},}; - for (i = 0; i < sizeof (data) / sizeof (data[0]); i++) + for (i = 0; i < sizeof(data) / sizeof(data[0]); i++) { struct random_item_data *pd = data[i].pdata; int *pc = data[i].pcount; @@ -434,21 +434,21 @@ static int itemdb_read_randomitem (void) const char *fn = data[i].filename; *pdefault = 0; - if ((fp = fopen_ (fn, "r")) == NULL) + if ((fp = fopen_(fn, "r")) == NULL) { - printf ("can't read %s\n", fn); + printf("can't read %s\n", fn); continue; } - while (fgets (line, 1020, fp)) + while (fgets(line, 1020, fp)) { if (line[0] == '/' && line[1] == '/') continue; - memset (str, 0, sizeof (str)); + memset(str, 0, sizeof(str)); for (j = 0, p = line; j < 3 && p; j++) { str[j] = p; - p = strchr (p, ','); + p = strchr(p, ','); if (p) *p++ = 0; } @@ -456,28 +456,28 @@ static int itemdb_read_randomitem (void) if (str[0] == NULL) continue; - nameid = atoi (str[0]); + nameid = atoi(str[0]); if (nameid < 0 || nameid >= 20000) continue; if (nameid == 0) { if (str[2]) - *pdefault = atoi (str[2]); + *pdefault = atoi(str[2]); continue; } if (str[2]) { pd[*pc].nameid = nameid; - pd[(*pc)++].per = atoi (str[2]); + pd[(*pc)++].per = atoi(str[2]); } if (ln >= MAX_RANDITEM) break; ln++; } - fclose_ (fp); - printf ("read %s done (count=%d)\n", fn, *pc); + fclose_(fp); + printf("read %s done (count=%d)\n", fn, *pc); } return 0; @@ -487,30 +487,30 @@ static int itemdb_read_randomitem (void) * アイテム使用可能フラグのオーバーライド *------------------------------------------ */ -static int itemdb_read_itemavail (void) +static int itemdb_read_itemavail(void) { FILE *fp; char line[1024]; - int ln = 0; - int nameid, j, k; + int ln = 0; + int nameid, j, k; char *str[10], *p; - if ((fp = fopen_ ("db/item_avail.txt", "r")) == NULL) + if ((fp = fopen_("db/item_avail.txt", "r")) == NULL) { - printf ("can't read db/item_avail.txt\n"); + printf("can't read db/item_avail.txt\n"); return -1; } - while (fgets (line, 1020, fp)) + while (fgets(line, 1020, fp)) { struct item_data *id; if (line[0] == '/' && line[1] == '/') continue; - memset (str, 0, sizeof (str)); + memset(str, 0, sizeof(str)); for (j = 0, p = line; j < 2 && p; j++) { str[j] = p; - p = strchr (p, ','); + p = strchr(p, ','); if (p) *p++ = 0; } @@ -518,10 +518,10 @@ static int itemdb_read_itemavail (void) if (str[0] == NULL) continue; - nameid = atoi (str[0]); - if (nameid < 0 || nameid >= 20000 || !(id = itemdb_exists (nameid))) + nameid = atoi(str[0]); + if (nameid < 0 || nameid >= 20000 || !(id = itemdb_exists(nameid))) continue; - k = atoi (str[1]); + k = atoi(str[1]); if (k > 0) { id->flag.available = 1; @@ -531,8 +531,8 @@ static int itemdb_read_itemavail (void) id->flag.available = 0; ln++; } - fclose_ (fp); - printf ("read db/item_avail.txt done (count=%d)\n", ln); + fclose_(fp); + printf("read db/item_avail.txt done (count=%d)\n", ln); return 0; } @@ -540,12 +540,12 @@ static int itemdb_read_itemavail (void) * アイテムの名前テーブルを読み込む *------------------------------------------ */ -static int itemdb_read_itemnametable (void) +static int itemdb_read_itemnametable(void) { char *buf, *p; size_t s; - buf = (char *)grfio_reads ("data\\idnum2itemdisplaynametable.txt", &s); + buf = (char *)grfio_reads("data\\idnum2itemdisplaynametable.txt", &s); if (buf == NULL) return -1; @@ -553,31 +553,31 @@ static int itemdb_read_itemnametable (void) buf[s] = 0; for (p = buf; p - buf < s;) { - int nameid; + int nameid; char buf2[64]; - if (sscanf (p, "%d#%[^#]#", &nameid, buf2) == 2) + if (sscanf(p, "%d#%[^#]#", &nameid, buf2) == 2) { #ifdef ITEMDB_OVERRIDE_NAME_VERBOSE - if (itemdb_exists (nameid) && - strncmp (itemdb_search (nameid)->jname, buf2, 24) != 0) + if (itemdb_exists(nameid) && + strncmp(itemdb_search(nameid)->jname, buf2, 24) != 0) { - printf ("[override] %d %s => %s\n", nameid, - itemdb_search (nameid)->jname, buf2); + printf("[override] %d %s => %s\n", nameid, + itemdb_search(nameid)->jname, buf2); } #endif - memcpy (itemdb_search (nameid)->jname, buf2, 24); + memcpy(itemdb_search(nameid)->jname, buf2, 24); } - p = strchr (p, 10); + p = strchr(p, 10); if (!p) break; p++; } - free (buf); - printf ("read data\\idnum2itemdisplaynametable.txt done.\n"); + free(buf); + printf("read data\\idnum2itemdisplaynametable.txt done.\n"); return 0; } @@ -586,12 +586,12 @@ static int itemdb_read_itemnametable (void) * カードイラストのリソース名前テーブルを読み込む *------------------------------------------ */ -static int itemdb_read_cardillustnametable (void) +static int itemdb_read_cardillustnametable(void) { char *buf, *p; size_t s; - buf = (char *)grfio_reads ("data\\num2cardillustnametable.txt", &s); + buf = (char *)grfio_reads("data\\num2cardillustnametable.txt", &s); if (buf == NULL) return -1; @@ -599,23 +599,23 @@ static int itemdb_read_cardillustnametable (void) buf[s] = 0; for (p = buf; p - buf < s;) { - int nameid; + int nameid; char buf2[64]; - if (sscanf (p, "%d#%[^#]#", &nameid, buf2) == 2) + if (sscanf(p, "%d#%[^#]#", &nameid, buf2) == 2) { - strcat (buf2, ".bmp"); - memcpy (itemdb_search (nameid)->cardillustname, buf2, 64); + strcat(buf2, ".bmp"); + memcpy(itemdb_search(nameid)->cardillustname, buf2, 64); // printf("%d %s\n",nameid,itemdb_search(nameid)->cardillustname); } - p = strchr (p, 10); + p = strchr(p, 10); if (!p) break; p++; } - free (buf); - printf ("read data\\num2cardillustnametable.txt done.\n"); + free(buf); + printf("read data\\num2cardillustnametable.txt done.\n"); return 0; } @@ -624,46 +624,46 @@ static int itemdb_read_cardillustnametable (void) * 装備制限ファイル読み出し *------------------------------------------ */ -static int itemdb_read_noequip (void) +static int itemdb_read_noequip(void) { FILE *fp; char line[1024]; - int ln = 0; - int nameid, j; + int ln = 0; + int nameid, j; char *str[32], *p; struct item_data *id; - if ((fp = fopen_ ("db/item_noequip.txt", "r")) == NULL) + if ((fp = fopen_("db/item_noequip.txt", "r")) == NULL) { - printf ("can't read db/item_noequip.txt\n"); + printf("can't read db/item_noequip.txt\n"); return -1; } - while (fgets (line, 1020, fp)) + while (fgets(line, 1020, fp)) { if (line[0] == '/' && line[1] == '/') continue; - memset (str, 0, sizeof (str)); + memset(str, 0, sizeof(str)); for (j = 0, p = line; j < 2 && p; j++) { str[j] = p; - p = strchr (p, ','); + p = strchr(p, ','); if (p) *p++ = 0; } if (str[0] == NULL) continue; - nameid = atoi (str[0]); - if (nameid <= 0 || nameid >= 20000 || !(id = itemdb_exists (nameid))) + nameid = atoi(str[0]); + if (nameid <= 0 || nameid >= 20000 || !(id = itemdb_exists(nameid))) continue; - id->flag.no_equip = atoi (str[1]); + id->flag.no_equip = atoi(str[1]); ln++; } - fclose_ (fp); - printf ("read db/item_noequip.txt done (count=%d)\n", ln); + fclose_(fp); + printf("read db/item_noequip.txt done (count=%d)\n", ln); return 0; } @@ -671,20 +671,20 @@ static int itemdb_read_noequip (void) * *------------------------------------------ */ -static void itemdb_final (db_key_t key, db_val_t data, va_list ap) +static void itemdb_final(db_key_t key, db_val_t data, va_list ap) { struct item_data *id; - nullpo_retv (id = (struct item_data *)data); + nullpo_retv(id = (struct item_data *)data); if (id->use_script) - free (const_cast<ScriptCode *>(id->use_script)); + free(const_cast<ScriptCode *>(id->use_script)); if (id->equip_script) - free (const_cast<ScriptCode *>(id->equip_script)); - free (id); + free(const_cast<ScriptCode *>(id->equip_script)); + free(id); } -void itemdb_reload (void) +void itemdb_reload(void) { /* * @@ -693,18 +693,18 @@ void itemdb_reload (void) * */ - do_init_itemdb (); + do_init_itemdb(); } /*========================================== * *------------------------------------------ */ -void do_final_itemdb (void) +void do_final_itemdb(void) { if (item_db) { - numdb_final (item_db, itemdb_final); + numdb_final(item_db, itemdb_final); item_db = NULL; } } @@ -712,15 +712,15 @@ void do_final_itemdb (void) /* static FILE *dfp; static int itemdebug(void *key,void *data,va_list ap){ -// struct item_data *id=(struct item_data *)data; - fprintf(dfp,"%6d",(int)key); - return 0; +// struct item_data *id=(struct item_data *)data; + fprintf(dfp,"%6d", (int)key); + return 0; } void itemdebugtxt() { - dfp=fopen_("itemdebug.txt","wt"); - numdb_foreach(item_db,itemdebug); - fclose_(dfp); + dfp=fopen_("itemdebug.txt","wt"); + numdb_foreach(item_db,itemdebug); + fclose_(dfp); } */ @@ -728,27 +728,27 @@ void itemdebugtxt() * Removed item_value_db, don't re-add *------------------------------------ */ -static void itemdb_read (void) +static void itemdb_read(void) { - itemdb_read_itemslottable (); - itemdb_readdb (); - itemdb_read_randomitem (); - itemdb_read_itemavail (); - itemdb_read_noequip (); - itemdb_read_cardillustnametable (); + itemdb_read_itemslottable(); + itemdb_readdb(); + itemdb_read_randomitem(); + itemdb_read_itemavail(); + itemdb_read_noequip(); + itemdb_read_cardillustnametable(); if (!battle_config.item_name_override_grffile) - itemdb_read_itemnametable (); + itemdb_read_itemnametable(); } /*========================================== * *------------------------------------------ */ -int do_init_itemdb (void) +int do_init_itemdb(void) { - item_db = numdb_init (); + item_db = numdb_init(); - itemdb_read (); + itemdb_read(); return 0; } |