diff options
author | mekolat <mekolat@users.noreply.github.com> | 2017-10-20 15:32:26 -0400 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-10-20 15:32:26 -0400 |
commit | 018f1ffc77c8f690a6a5643365f64794451c9aa9 (patch) | |
tree | cb2413045d91d9fcdfad100b019793554c2d18b8 /src | |
parent | 6b1fe2d069cb0251bc5798767f97454ab63a47c0 (diff) | |
parent | 7bc1b1c09e3c3e7d0c4460803d16dfc01cd56a22 (diff) | |
download | hercules-018f1ffc77c8f690a6a5643365f64794451c9aa9.tar.gz hercules-018f1ffc77c8f690a6a5643365f64794451c9aa9.tar.bz2 hercules-018f1ffc77c8f690a6a5643365f64794451c9aa9.tar.xz hercules-018f1ffc77c8f690a6a5643365f64794451c9aa9.zip |
Merge pull request #1843 from mekolat/logmes2
Diffstat (limited to 'src')
-rw-r--r-- | src/map/script.c | 40 |
1 files changed, 31 insertions, 9 deletions
diff --git a/src/map/script.c b/src/map/script.c index 367c9927d..da079c082 100644 --- a/src/map/script.c +++ b/src/map/script.c @@ -15785,19 +15785,37 @@ BUILDIN(getmapxy) return true; } +enum logmes_type { + LOGMES_NPC, + LOGMES_ATCOMMAND +}; + /*========================================== - * Allows player to write NPC logs (i.e. Bank NPC, etc) [Lupus] + * Allows player to write logs (i.e. Bank NPC, etc) [Lupus] *------------------------------------------*/ -BUILDIN(logmes) -{ - const char *str; +BUILDIN(logmes) { + const char *str = script_getstr(st, 2); struct map_session_data *sd = script->rid2sd(st); + enum logmes_type type = LOGMES_NPC; + nullpo_retr(sd, false); - if (sd == NULL) - return true; + if (script_hasdata(st, 3)) { + type = script_getnum(st, 3); + } + + switch (type) { + case LOGMES_ATCOMMAND: + logs->atcommand(sd, str); + break; + case LOGMES_NPC: + logs->npc(sd, str); + break; + default: + ShowError("script:logmes: Unknown log type!\n"); + st->state = END; + return false; + } - str = script_getstr(st,2); - logs->npc(sd,str); return true; } @@ -24070,7 +24088,7 @@ void script_parse_builtin(void) { BUILDIN_DEF(checkoption2,"i?"), BUILDIN_DEF(guildgetexp,"i"), BUILDIN_DEF(guildchangegm,"is"), - BUILDIN_DEF(logmes,"s"), //this command actls as MES but rints info into LOG file either SQL/TXT [Lupus] + BUILDIN_DEF(logmes,"s?"), //this command actls as MES but rints info into LOG file either SQL/TXT [Lupus] BUILDIN_DEF(summon,"si??"), // summons a slave monster [Celest] BUILDIN_DEF(isnight,""), // check whether it is night time [Celest] BUILDIN_DEF(isequipped,"i*"), // check whether another item/card has been equipped [Celest] @@ -24597,6 +24615,10 @@ void script_hardcoded_constants(void) script->set_constant("DATATYPE_VAR", DATATYPE_VAR, false, false); script->set_constant("DATATYPE_LABEL", DATATYPE_LABEL, false, false); + script->constdb_comment("Logmes types"); + script->set_constant("LOGMES_NPC", LOGMES_NPC, false, false); + script->set_constant("LOGMES_ATCOMMAND", LOGMES_ATCOMMAND, false, false); + script->constdb_comment("Item Subtypes (Weapon types)"); script->set_constant("W_FIST", W_FIST, false, false); script->set_constant("W_DAGGER", W_DAGGER, false, false); |