From 78816fc57d05c56b4cbf2f920b5679051e593197 Mon Sep 17 00:00:00 2001 From: Andrei Karas Date: Sun, 24 Jan 2016 21:02:25 +0300 Subject: Add support for cards in script funciton getitemlink. Example: getitemlink(1301, 5002) --- src/emap/init.c | 2 +- src/emap/script.c | 56 +++++++++++++++++++++++++++++++++++++++++++------------ 2 files changed, 45 insertions(+), 13 deletions(-) diff --git a/src/emap/init.c b/src/emap/init.c index 0e1463a..f9f264b 100644 --- a/src/emap/init.c +++ b/src/emap/init.c @@ -92,7 +92,7 @@ HPExport void plugin_init (void) addScriptCommand("npctalk3", "s", npcTalk3); addScriptCommand("closedialog", "", closeDialog); addScriptCommand("shop", "s", shop); - addScriptCommand("getitemlink", "v", getItemLink); + addScriptCommand("getitemlink", "v*", getItemLink); addScriptCommand("getinvindexlink", "i", getInvIndexLink); addScriptCommand("l", "s*", l); addScriptCommand("lg", "s*", lg); diff --git a/src/emap/script.c b/src/emap/script.c index bc8c7b2..26a0246 100644 --- a/src/emap/script.c +++ b/src/emap/script.c @@ -530,24 +530,27 @@ BUILDIN(shop) return true; } +#define paramToItem(param) \ + if (script_isstringtype(st, param)) \ + { \ + i_data = itemdb->search_name (script_getstr(st, param)); \ + } \ + else \ + { \ + item_id = script_getnum (st, param); \ + if (item_id) \ + i_data = itemdb->search (item_id); \ + } + BUILDIN(getItemLink) { struct item_data *i_data = NULL; char *item_name; int item_id = 0; - if (script_isstringtype(st, 2)) - { - i_data = itemdb->search_name (script_getstr(st, 2)); - } - else - { - item_id = script_getnum (st, 2); - if (item_id) - i_data = itemdb->search (item_id); - } + paramToItem(2); - item_name = (char *) aCalloc (100, sizeof (char)); + item_name = (char *) aCalloc (1000, sizeof (char)); TBL_PC *sd = script->rid2sd(st); if (sd) @@ -558,13 +561,40 @@ BUILDIN(getItemLink) version = data->clientVersion; if (i_data && version >= 7) - sprintf(item_name, "[@@%u|@@]", (unsigned)i_data->nameid); + { + if (!script_hasdata(st, 3)) + { + sprintf(item_name, "[@@%u|@@]", (unsigned)i_data->nameid); + } + else + { + sprintf(item_name, "[@@%u", (unsigned)i_data->nameid); + int f; + for (f = 3; f < 7 && script_hasdata(st, f); f ++) + { + paramToItem(f); + if (i_data) + { + char buf[100]; + sprintf(buf, ",%u", (unsigned)i_data->nameid); + strcat(item_name, buf); + } + } + strcat(item_name, "|@@]"); + } + } else if (i_data) + { sprintf(item_name, "[@@%u|%s@@]", (unsigned)i_data->nameid, lang_pctrans (i_data->jname, sd)); + } else if (item_id > 0) + { sprintf(item_name, "[@@%u|Unknown Item@@]", (unsigned)item_id); + } else + { sprintf(item_name, "[Unknown Item]"); + } } else { @@ -579,6 +609,8 @@ BUILDIN(getItemLink) return true; } +#undef paramToItem + BUILDIN(requestLang) { getSD(); -- cgit v1.2.3-70-g09d2