summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorgumi <git@gumi.ca>2020-04-26 20:27:54 -0400
committergumi <git@gumi.ca>2020-04-26 20:27:54 -0400
commitb3f44a8e8ef767617c5e09ba689c16aa3c00d448 (patch)
treeb4b1076ca9f5f5cb3f36257de6ea7b6a46520ec4
parent229ddd2afb47cf2aeeae42f5ce6064d59e69ac42 (diff)
downloadplugin-b3f44a8e8ef767617c5e09ba689c16aa3c00d448.tar.gz
plugin-b3f44a8e8ef767617c5e09ba689c16aa3c00d448.tar.bz2
plugin-b3f44a8e8ef767617c5e09ba689c16aa3c00d448.tar.xz
plugin-b3f44a8e8ef767617c5e09ba689c16aa3c00d448.zip
add buildin getnpcsubtype() to get nd->subtype
-rw-r--r--src/emap/init.c1
-rw-r--r--src/emap/script.c7
-rw-r--r--src/emap/script_buildins.c24
-rw-r--r--src/emap/script_buildins.h1
4 files changed, 33 insertions, 0 deletions
diff --git a/src/emap/init.c b/src/emap/init.c
index c2699dd..9bc0324 100644
--- a/src/emap/init.c
+++ b/src/emap/init.c
@@ -215,6 +215,7 @@ HPExport void plugin_init (void)
addScriptCommand("setitemoptionbyindex", "iii*", setItemOptionByIndex);
addScriptCommand("isinstance", "i", isInstance);
addScriptCommand("readbattleparam","ii",readBattleParam);
+ addScriptCommand("getnpcsubtype", "?", getNpcSubtype);
do_init_langs();
diff --git a/src/emap/script.c b/src/emap/script.c
index 9e6add6..eec0df3 100644
--- a/src/emap/script.c
+++ b/src/emap/script.c
@@ -96,6 +96,13 @@ void escript_hardcoded_constants_pre(void)
script->set_constant("GENDER_FEMALE", GENDER_FEMALE, false, false);
script->set_constant("GENDER_MALE", GENDER_MALE, false, false);
script->set_constant("GENDER_HIDDEN", GENDER_HIDDEN, false, false);
+
+ // npc subtypes
+ script->set_constant("NPCSUBTYPE_WARP", WARP, false, false);
+ script->set_constant("NPCSUBTYPE_SHOP", SHOP, false, false);
+ script->set_constant("NPCSUBTYPE_SCRIPT", SCRIPT, false, false);
+ script->set_constant("NPCSUBTYPE_CASHSHOP", CASHSHOP, false, false);
+ script->set_constant("NPCSUBTYPE_TOMB", TOMB, false, false);
script->constdb_comment(NULL);
eskill_addskill_conststants();
}
diff --git a/src/emap/script_buildins.c b/src/emap/script_buildins.c
index 2899cc3..94ed92d 100644
--- a/src/emap/script_buildins.c
+++ b/src/emap/script_buildins.c
@@ -2349,6 +2349,30 @@ BUILDIN(isInstance)
return true;
}
+BUILDIN(getNpcSubtype)
+{
+ TBL_NPC *nd = map->id2bl(st->oid);
+
+ if (script_hasdata(st, 2))
+ {
+ if (script_isstringtype(st, 2)) {
+ nd = npc->name2id(script_getstr(st, 2));
+ } else {
+ nd = map->id2bl(script_getnum(st, 2));
+ }
+ }
+
+ if (!nd)
+ {
+ ShowWarning("npc not found\n");
+ script->reportsrc(st);
+ return false;
+ }
+
+ script_pushint(st, nd->subtype);
+ return true;
+}
+
/*==========================================
* return the battle stats of a structure
* Supported values are most of UDT_* ones
diff --git a/src/emap/script_buildins.h b/src/emap/script_buildins.h
index 6c31909..8895abe 100644
--- a/src/emap/script_buildins.h
+++ b/src/emap/script_buildins.h
@@ -100,5 +100,6 @@ BUILDIN(getItemOptionParamByIndex);
BUILDIN(setItemOptionByIndex);
BUILDIN(isInstance);
BUILDIN(readBattleParam);
+BUILDIN(getNpcSubtype);
#endif // EVOL_MAP_SCRIPT_BUILDINS