changed Makefile; build all commands as an own file
[NeonServV5.git] / cmd_neonserv_voiceall.c
index a407cb75fbc52a4994aba4bd768c5945a538845e..e4de009e458edc3df0f95931c5b6e60e430ccdc9 100644 (file)
@@ -1,15 +1,48 @@
 
+#include "cmd_neonserv.h"
+
 /*
 * argv[0]    (optional) nick mask
 */
+static USERLIST_CALLBACK(neonserv_cmd_voiceall_userlist_lookup);
+static void neonserv_cmd_voiceall_async1(struct ClientSocket *client, struct ClientSocket *textclient, struct UserNode *user, struct ChanNode *chan, struct Event *event, char *nickmask);
+
+struct neonserv_cmd_voiceall_cache {
+    struct ClientSocket *client, *textclient;
+    struct UserNode *user;
+    struct Event *event;
+    char *nickmask;
+};
+
+CMD_BIND(neonserv_cmd_voiceall) {
+    struct neonserv_cmd_voiceall_cache *cache = malloc(sizeof(*cache));
+    if (!cache) {
+        perror("malloc() failed");
+        return;
+    }
+    cache->client = client;
+    cache->textclient = getTextBot();
+    cache->user = user;
+    cache->event = event;
+    if(argc > 0) {
+        cache->nickmask = strdup(argv[0]);
+    } else
+        cache->nickmask = NULL;
+    get_userlist_with_invisible(chan, neonserv_cmd_voiceall_userlist_lookup, cache);
+}
+
+static USERLIST_CALLBACK(neonserv_cmd_voiceall_userlist_lookup) {
+    struct neonserv_cmd_voiceall_cache *cache = data;
+    neonserv_cmd_voiceall_async1(cache->client, cache->textclient, cache->user, chan, cache->event, cache->nickmask);
+    if(cache->nickmask)
+        free(cache->nickmask);
+    free(cache);
+}
 
-static CMD_BIND(neonserv_cmd_voiceall) {
+static void neonserv_cmd_voiceall_async1(struct ClientSocket *client, struct ClientSocket *textclient, struct UserNode *user, struct ChanNode *chan, struct Event *event, char *nickmask) {
     int done_users = 0;
-    char *nickmask = NULL;
     struct ChanUser *chanuser;
     struct ModeBuffer *modeBuf;
-    if(argc > 0)
-        nickmask = argv[0];
     modeBuf = initModeBuffer(client, chan);
     for(chanuser = getChannelUsers(chan, NULL); chanuser; chanuser = getChannelUsers(chan, chanuser)) {
         if(nickmask && match(nickmask, chanuser->user->nick)) continue;
@@ -18,5 +51,7 @@ static CMD_BIND(neonserv_cmd_voiceall) {
         done_users++;
     }
     freeModeBuffer(modeBuf);
-    reply(getTextBot(), user, "NS_VOICEALL_DONE", done_users, chan->name);
+    reply(textclient, user, "NS_VOICEALL_DONE", done_users, chan->name);
+    if(done_users)
+        logEvent(event);
 }