diff options
Diffstat (limited to 'world/map/npc/commands/divorce.txt')
-rw-r--r-- | world/map/npc/commands/divorce.txt | 28 |
1 files changed, 28 insertions, 0 deletions
diff --git a/world/map/npc/commands/divorce.txt b/world/map/npc/commands/divorce.txt new file mode 100644 index 00000000..954e4e92 --- /dev/null +++ b/world/map/npc/commands/divorce.txt @@ -0,0 +1,28 @@ +-|script|@divorce|32767 +{ + callfunc "argv_splitter"; + set .@n$, if_then_else(@argv$[1] != "", "char", "") + "divorce"; + if (GM < CMD_DIVORCE && GM < G_SYSOP) goto L_GM; // check if you can use it on self + set .@target_id, BL_ID; + if (@argv$[1] != "") set .@target_id, getcharid(3, @argv$[1]); + if (@argv$[1] != "" && !(isloggedin(.@target_id))) goto L_Failed; // do NOT fallback to self + if (@argv$[1] != "" && GM < CMD_CHARDIVORCE && GM < G_SYSOP) goto L_GM; // when target is not self, use chardivorce permission + + set PARTNER, 0, .@target_id; + gmlog "@"+.@n$+" " + @args$; + message strcharinfo(0), .@n$+" : The operation succeeded."; + end; + +L_Failed: + message strcharinfo(0), .@n$+" : Impossible to attach to the target player. Did you try putting the name in \"quotation marks\"?"; + end; + +L_GM: + message strcharinfo(0), .@n$+" : GM command is level "+ if_then_else(@argv$[1] != "", CMD_CHARDIVORCE, CMD_DIVORCE) +", but you are level " + GM; + end; + +OnInit: + registercmd chr(ATCMD_SYMBOL) + "divorce", strnpcinfo(0); + registercmd chr(ATCMD_SYMBOL) + "chardivorce", strnpcinfo(0); + end; +} |