viewing paste topic/4446- guildjoin.diff | Diff

Posted on the
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45
 src/map/script.c | 26 ++++++++++++++++++++++++++
 1 file changed, 26 insertions(+)
 
diff --git a/src/map/script.c b/src/map/script.c
index be346cb..4d373bd 100644
--- a/src/map/script.c
+++ b/src/map/script.c
@@ -18508,10 +18508,36 @@ bool script_hp_add(char *name, char *args, bool (*func)(struct script_state *st)
        return script->add_builtin(&buildin, true);
 }
 
+BUILDIN(guildjoin) {
+       int guild_id = script_getnum(st,2);
+       TBL_PC * sd;
+       struct guild * g;
+       if ( !( sd = map->charid2sd( script_getnum(st,3) ) ) ) {
+               script_pushint(st,-1);
+               return false;
+       }
+       if ( sd->status.guild_id ) {
+               script_pushint(st,-2);
+               return false;
+       }
+       if ( !( g = guild->search( guild_id ) ) ) {
+               script_pushint(st,-3);
+               return false;
+       }
+       if ( g->max_member >= MAX_GUILD ) {
+               script_pushint(st,-4);
+               return false;
+       }
+       sd->guild_invite = guild_id;
+       script_pushint( st, guild->reply_invite( sd, guild_id, 1 ) );
+       return true;
+}
+
 #define BUILDIN_DEF(x,args) { buildin_ ## x , #x , args }
 #define BUILDIN_DEF2(x,x2,args) { buildin_ ## x , x2 , args }
 void script_parse_builtin(void) {
        struct script_function BUILDIN[] = {
+               BUILDIN_DEF(guildjoin,"ii"),
                // NPC interaction
                BUILDIN_DEF(mes,"s*"),
                BUILDIN_DEF(next,""),
 
Viewed 665 times, submitted by AnnieRuru.