Fix bug with uninitialized variable.
[cascardo/chat.git] / tictactoe.c
index 700a269..e929663 100644 (file)
 #include "tcp_connect.h"
 #include "iksemel_extra.h"
 #include "xmpp.h"
-#include "sasl.h"
+#include "disco.h"
 
-int
-myhook (void *data, int type, iks *stanza)
-{
-  if (!iks_strcmp (iks_name (stanza), "stream:features"))
-    {
-      hc_xmpp_features (data, stanza);
-      if (hc_xmpp_is_sasl_supported (data))
-        {
-          hc_xmpp_sasl_authenticate (data);
-        }
-    }
-  else if (!iks_strcmp (iks_find_attrib (stanza, "xmlns"), HC_XMPP_NS_SASL))
-    {
-      hc_xmpp_sasl_iterate (data, stanza);
-      if (hc_xmpp_status (data) == HC_XMPP_AUTHENTICATED)
-        fprintf (stdout, "Authenticated\n");
-    }
-  else
-    {
-      fprintf (stderr, "Other: %s\n", iks_string (iks_stack (stanza), stanza));
-    }
-  return IKS_OK;
-}
-
-void
-write_stream (hc_xmpp_t *xmpp)
-{
-  char *buffer = NULL;
-  asprintf (&buffer, "<stream:stream xmlns='jabber:client' "
-                     "xmlns:stream='http://etherx.jabber.org/streams' "
-                     "version='1.0' to='%s'>", hc_xmpp_server (xmpp));
-  hc_xmpp_send_buffer (xmpp, buffer, 0);
-  free (buffer);
-}
-
-void
+static void
 loop (hc_xmpp_t *xmpp)
 {
   while (1)
@@ -73,13 +38,21 @@ loop (hc_xmpp_t *xmpp)
 int
 main (int argc, char **argv)
 {
-  char *server = "jabber-br.org";
-  char *user = "pubsub";
-  char *password = "pubsub";
+  char *server;
+  char *user;
+  char *password;
   hc_xmpp_t *xmpp;
+  if (argc < 4)
+    {
+      printf ("tictactoe server user password\n");
+      return 1;
+    }
+  server = argv[1];
+  user = argv[2];
+  password = argv[3];
   dns_init (NULL, 1);
-  xmpp = hc_xmpp_new (myhook, server, user, password);
-  write_stream (xmpp);
+  xmpp = hc_xmpp_new (hc_xmpp_hook, server, user, password);
+  hc_xmpp_send_stream (xmpp);
   loop (xmpp);
   return 0;
 }