+2005-11-25 Bryan Worth <bryan@theworths.org>
+ * TODO: checked off MESSAGE
+
+ *src/ttt-client.c: (_ttt_client_execute_message): Implement MESSAGE
+ *(_execute_request): changed arg_required to behave as a minimum
+ instead of an absolute number to allow optional arguments such as
+ multi-word messages
+
2005-11-25 Richard D. Worth <richard@theworths.org>
* TODO: checked off WHO, QUIT, ERROR SYNTAX
char **args,
int num_args);
+static ttt_error_t
+_ttt_client_execute_message (ttt_client_t *client,
+ char **args,
+ int num_args);
+
+
+
typedef struct _ttt_command_description {
const char *command;
int args_required;
} ttt_command_description_t;
ttt_command_description_t command_descriptions[] = {
- {"HELO", 1, _ttt_client_execute_helo},
- {"WHO", 0, _ttt_client_execute_who },
- {"QUIT", 0, _ttt_client_execute_quit}
+ {"HELO", 1, _ttt_client_execute_helo},
+ {"WHO", 0, _ttt_client_execute_who },
+ {"QUIT", 0, _ttt_client_execute_quit},
+ {"MESSAGE", 1, _ttt_client_execute_message}
};
+
#define ARRAY_SIZE(arr) (sizeof(arr)/sizeof(arr[0]))
static ttt_error_t
char **args,
int num_args)
{
- const char *response;
+ char *response;
assert (num_args == 0);
}
static ttt_error_t
-_ttt_client_execute_quit (ttt_client_t *client,
- char **args,
- int num_args)
+_ttt_client_execute_quit (ttt_client_t *client,
+ char **args,
+ int num_args)
{
assert (num_args == 0);
return TTT_ERROR_QUIT_REQUESTED;
}
+static ttt_error_t
+_ttt_client_execute_message (ttt_client_t *client,
+ char **args,
+ int num_args)
+{
+ char *response;
+ int i;
+
+ assert (num_args > 0);
+
+ xasprintf(&response, "MESSAGE\n");
+ ttt_client_send (client, response);
+
+ xasprintf(&response, "NOTICE MESSAGE %s", client->name);
+ for (i=0; i<num_args; i++){
+ xasprintf(&response, "%s %s",response,args[i]);
+
+ }
+ xasprintf(&response, "%s\n",response);
+ ttt_server_broadcast (client->server,response);
+
+ free (response);
+ return TTT_ERROR_NONE;
+
+
+}
+
static void
_free_request (ttt_client_t *client);
for (i=0; i < ARRAY_SIZE(command_descriptions); i++) {
desc = &command_descriptions[i];
if (strcmp(command, desc->command) == 0) {
- if (num_args != desc->args_required)
+ if (num_args < desc->args_required)
return TTT_ERROR_SYNTAX;
return (desc->execute) (client, &client->request_strings[1], num_args);
}