diff mcabber/src/commands.c @ 47:7259a61e1a4b

[/trunk] Changeset 63 by mikael * Add commands.[ch] files, to deal with command lines. Move sendmessage() to commands.c * Update Makefile accordingly. * Create a scr_WriteMessage() function, layer between UI and the scr_WriteIncomingMessage() / scr_WriteOutgoingMessage(). (The last one is a new function)
author mikael
date Wed, 06 Apr 2005 10:07:59 +0000
parents
children 0bd578421ce9
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/mcabber/src/commands.c	Wed Apr 06 10:07:59 2005 +0000
@@ -0,0 +1,67 @@
+/*
+ * commands.c     -- user commands handling
+ * 
+ * Copyright (C) 2005 Mikael Berthe <bmikael@lists.lilotux.net>
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or (at
+ * your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+ * General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
+ * USA
+ */
+
+#include "commands.h"
+#include "jabglue.h"
+#include "screen.h"
+#include "utils.h"
+#include "buddies.h"
+#include "utf8.h"
+
+
+//  send_message(msg)
+// Write the message in the buddy's window and send the message on
+// the network.
+void send_message(char *msg)
+{
+  char *buffer;
+  buddy_entry_t *tmp = bud_SelectedInfo();
+
+  // UI part
+  scr_WriteOutgoingMessage(tmp->jid, msg);
+
+  // Network part
+  buffer = utf8_encode(msg);
+  jb_send_msg(tmp->jid, buffer);
+  free(buffer);
+}
+
+//  process_line(line)
+// Process a command/message line.
+// If this isn't a command, this is a message and it is sent to the
+// currently selected buddy.
+int process_line(char *line)
+{
+  if (*line != '/') {
+    send_message(line);
+    return 0;
+  }
+  if (!strcasecmp(line, "/quit")) {
+    return 255;
+  }
+  // Commands handling
+  // TODO
+  // say, send_raw...
+
+  scr_LogPrint("Unrecognised command, sorry.");
+  return 0;
+}
+