// Copyright (c) Copyright (c) Hercules Dev Team, licensed under GNU GPL. // Copyright (c) 2014 Evol developers #include #include #include #include "../../../common/HPMi.h" #include "../../../common/malloc.h" #include "../../../common/mmo.h" #include "../../../common/socket.h" #include "../../../common/strlib.h" #include "../../../map/clif.h" #include "../../../map/npc.h" #include "../../../map/pc.h" #include "../../../map/script.h" #include "map/script.h" #include "map/scriptdefines.h" #include "map/send.h" #include "map/session.h" #include "map/sessionext.h" BUILDIN(l) { // for now not translate and not use format parameters script_pushstr(st, aStrdup(script_getstr(st, 2))); return true; } BUILDIN(getClientVersion) { getDataReturn(0); script_pushint(st, data->clientVersion); return true; } BUILDIN(getLang) { getDataReturn(0); script_pushint(st, data->language); return true; } BUILDIN(setLang) { getData(); data->language = script_getnum(st, 2); return true; } BUILDIN(setCamNpc) { getSD(); struct npc_data *nd = NULL; int x = 0; int y = 0; if (script_hasdata(st, 2)) { nd = npc->name2id (script_getstr(st, 2)); } else { if (!st->oid) return false; nd = (struct npc_data *) map->id2bl (st->oid); } if (!nd || sd->bl.m != nd->bl.m) return false; if (script_hasdata(st, 3) && script_hasdata(st, 4)) { x = script_getnum(st, 3); y = script_getnum(st, 4); } send_npccommand2(script->rid2sd (st), st->oid, 2, nd->bl.id, x, y); return true; } BUILDIN(restoreCam) { getSD(); send_npccommand(sd, st->oid, 3); return true; } BUILDIN(npcTalk3) { getSD(); char *str; char *msg; struct npc_data *nd = NULL; if (script_hasdata(st, 3)) { nd = npc->name2id (script_getstr(st, 2)); str = script_getstr(st, 3); } else { nd = (struct npc_data *) map->id2bl (st->oid); str = script_getstr(st, 2); } if (!nd) return false; msg = nd->name; // +++ after restore lang support need translate here /* if (sd) msg = (char*)lang_pctrans (nd->name, sd); else msg = nd->name; */ if (strlen(str) + strlen(msg) > 450) return false; if (nd) { char message[500]; strcpy (message, msg); strcat (message, " : "); strcat (message, str); send_local_message (sd, &(nd->bl), message); } return true; }