mirror of
https://github.com/profanity-im/profanity.git
synced 2024-12-04 14:46:46 -05:00
Pulled out command module
This commit is contained in:
parent
dbfb1551d6
commit
a7df149ee9
5
Makefile
5
Makefile
@ -3,7 +3,7 @@ WARNS = -Werror -Wall -Wextra -Wno-unused-parameter -Wno-unused-but-set-variable
|
|||||||
LIBS = -lxml2 -lssl -lresolv -lncurses -lstrophe
|
LIBS = -lxml2 -lssl -lresolv -lncurses -lstrophe
|
||||||
CFLAGS = -O3 $(WARNS) $(LIBS)
|
CFLAGS = -O3 $(WARNS) $(LIBS)
|
||||||
OBJS = log.o windows.o title_bar.o input_bar.o input_win.o jabber.o \
|
OBJS = log.o windows.o title_bar.o input_bar.o input_win.o jabber.o \
|
||||||
profanity.o util.o main.o
|
profanity.o util.o command.o main.o
|
||||||
|
|
||||||
profanity: $(OBJS)
|
profanity: $(OBJS)
|
||||||
$(CC) -o profanity $(OBJS) $(LIBS)
|
$(CC) -o profanity $(OBJS) $(LIBS)
|
||||||
@ -14,8 +14,9 @@ title_bar.o: windows.h
|
|||||||
input_bar.o: windows.h
|
input_bar.o: windows.h
|
||||||
input_win.o: windows.h
|
input_win.o: windows.h
|
||||||
jabber.o: jabber.h log.h windows.h
|
jabber.o: jabber.h log.h windows.h
|
||||||
profanity.o: log.h windows.h jabber.h
|
profanity.o: log.h windows.h jabber.h command.h
|
||||||
util.o: util.h
|
util.o: util.h
|
||||||
|
command.o: command.h
|
||||||
main.o: log.h windows.h profanity.h
|
main.o: log.h windows.h profanity.h
|
||||||
|
|
||||||
.PHONY: clean
|
.PHONY: clean
|
||||||
|
104
command.c
Normal file
104
command.c
Normal file
@ -0,0 +1,104 @@
|
|||||||
|
#include <string.h>
|
||||||
|
#include <ncurses.h>
|
||||||
|
#include "command.h"
|
||||||
|
#include "jabber.h"
|
||||||
|
#include "windows.h"
|
||||||
|
|
||||||
|
static int cmd_quit(void);
|
||||||
|
static int cmd_help(void);
|
||||||
|
static int cmd_who(void);
|
||||||
|
static int cmd_msg(char *cmd);
|
||||||
|
static int cmd_close(char *cmd);
|
||||||
|
static int cmd_default(char *cmd);
|
||||||
|
|
||||||
|
int handle_command(char *cmd)
|
||||||
|
{
|
||||||
|
int result = FALSE;
|
||||||
|
if (strcmp(cmd, "/quit") == 0) {
|
||||||
|
result = cmd_quit();
|
||||||
|
} else if (strncmp(cmd, "/help", 5) == 0) {
|
||||||
|
result = cmd_help();
|
||||||
|
} else if (strncmp(cmd, "/who", 4) == 0) {
|
||||||
|
result = cmd_who();
|
||||||
|
} else if (strncmp(cmd, "/msg ", 5) == 0) {
|
||||||
|
result = cmd_msg(cmd);
|
||||||
|
} else if (strncmp(cmd, "/close", 6) == 0) {
|
||||||
|
result = cmd_close(cmd);
|
||||||
|
} else {
|
||||||
|
result = cmd_default(cmd);
|
||||||
|
}
|
||||||
|
|
||||||
|
return result;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
static int cmd_quit(void)
|
||||||
|
{
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int cmd_help(void)
|
||||||
|
{
|
||||||
|
cons_help();
|
||||||
|
inp_clear();
|
||||||
|
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int cmd_who(void)
|
||||||
|
{
|
||||||
|
jabber_roster_request();
|
||||||
|
inp_clear();
|
||||||
|
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int cmd_msg(char *cmd)
|
||||||
|
{
|
||||||
|
char *usr_msg = NULL;
|
||||||
|
char *usr = NULL;
|
||||||
|
char *msg = NULL;
|
||||||
|
|
||||||
|
usr_msg = strndup(cmd+5, strlen(cmd)-5);
|
||||||
|
usr = strtok(usr_msg, " ");
|
||||||
|
if (usr != NULL) {
|
||||||
|
msg = strndup(cmd+5+strlen(usr)+1, strlen(cmd)-(5+strlen(usr)+1));
|
||||||
|
if (msg != NULL) {
|
||||||
|
jabber_send(msg, usr);
|
||||||
|
show_outgoing_msg("me", usr, msg);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
inp_clear();
|
||||||
|
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int cmd_close(char *cmd)
|
||||||
|
{
|
||||||
|
if (in_chat()) {
|
||||||
|
close_win();
|
||||||
|
} else {
|
||||||
|
cons_bad_command(cmd);
|
||||||
|
}
|
||||||
|
|
||||||
|
inp_clear();
|
||||||
|
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int cmd_default(char *cmd)
|
||||||
|
{
|
||||||
|
if (in_chat()) {
|
||||||
|
char recipient[100] = "";
|
||||||
|
get_recipient(recipient);
|
||||||
|
jabber_send(cmd, recipient);
|
||||||
|
show_outgoing_msg("me", recipient, cmd);
|
||||||
|
} else {
|
||||||
|
cons_bad_command(cmd);
|
||||||
|
}
|
||||||
|
|
||||||
|
inp_clear();
|
||||||
|
|
||||||
|
return TRUE;
|
||||||
|
}
|
6
command.h
Normal file
6
command.h
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
#ifndef COMMAND_H
|
||||||
|
#define COMMAND_H
|
||||||
|
|
||||||
|
int handle_command(char *cmd);
|
||||||
|
|
||||||
|
#endif
|
73
profanity.c
73
profanity.c
@ -7,14 +7,13 @@
|
|||||||
#include "log.h"
|
#include "log.h"
|
||||||
#include "windows.h"
|
#include "windows.h"
|
||||||
#include "jabber.h"
|
#include "jabber.h"
|
||||||
|
#include "command.h"
|
||||||
|
|
||||||
#define AWAIT_COMMAND 1
|
#define AWAIT_COMMAND 1
|
||||||
#define START_MAIN 2
|
#define START_MAIN 2
|
||||||
#define QUIT_PROF 3
|
#define QUIT_PROF 3
|
||||||
#define CONTINUE_EVENT_LOOP 4
|
|
||||||
|
|
||||||
static int handle_start_command(char *cmd);
|
static int handle_start_command(char *cmd);
|
||||||
static int handle_main_command(char *cmd);
|
|
||||||
|
|
||||||
static void profanity_main(void);
|
static void profanity_main(void);
|
||||||
static void profanity_event_loop(int *ch, char *cmd, int *size);
|
static void profanity_event_loop(int *ch, char *cmd, int *size);
|
||||||
@ -36,10 +35,10 @@ void profanity_start(void)
|
|||||||
|
|
||||||
static void profanity_main(void)
|
static void profanity_main(void)
|
||||||
{
|
{
|
||||||
int cmd_result = CONTINUE_EVENT_LOOP;
|
int cmd_result = TRUE;
|
||||||
|
|
||||||
inp_non_block();
|
inp_non_block();
|
||||||
while(cmd_result == CONTINUE_EVENT_LOOP) {
|
while(cmd_result == TRUE) {
|
||||||
int ch = ERR;
|
int ch = ERR;
|
||||||
char cmd[100];
|
char cmd[100];
|
||||||
int size = 0;
|
int size = 0;
|
||||||
@ -48,7 +47,7 @@ static void profanity_main(void)
|
|||||||
profanity_event_loop(&ch, cmd, &size);
|
profanity_event_loop(&ch, cmd, &size);
|
||||||
|
|
||||||
cmd[size++] = '\0';
|
cmd[size++] = '\0';
|
||||||
cmd_result = handle_main_command(cmd);
|
cmd_result = handle_command(cmd);
|
||||||
}
|
}
|
||||||
|
|
||||||
jabber_disconnect();
|
jabber_disconnect();
|
||||||
@ -118,67 +117,3 @@ static int handle_start_command(char *cmd)
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int handle_main_command(char *cmd)
|
|
||||||
{
|
|
||||||
int result;
|
|
||||||
|
|
||||||
// /quit command -> exit
|
|
||||||
if (strcmp(cmd, "/quit") == 0) {
|
|
||||||
result = QUIT_PROF;
|
|
||||||
|
|
||||||
// /help -> print help to console
|
|
||||||
} else if (strncmp(cmd, "/help", 5) == 0) {
|
|
||||||
cons_help();
|
|
||||||
inp_clear();
|
|
||||||
result = CONTINUE_EVENT_LOOP;
|
|
||||||
|
|
||||||
// /who -> request roster
|
|
||||||
} else if (strncmp(cmd, "/who", 4) == 0) {
|
|
||||||
jabber_roster_request();
|
|
||||||
inp_clear();
|
|
||||||
result = CONTINUE_EVENT_LOOP;
|
|
||||||
|
|
||||||
// /msg -> send message to a user
|
|
||||||
} else if (strncmp(cmd, "/msg ", 5) == 0) {
|
|
||||||
char *usr_msg = NULL;
|
|
||||||
char *usr = NULL;
|
|
||||||
char *msg = NULL;
|
|
||||||
|
|
||||||
usr_msg = strndup(cmd+5, strlen(cmd)-5);
|
|
||||||
usr = strtok(usr_msg, " ");
|
|
||||||
if (usr != NULL) {
|
|
||||||
msg = strndup(cmd+5+strlen(usr)+1, strlen(cmd)-(5+strlen(usr)+1));
|
|
||||||
if (msg != NULL) {
|
|
||||||
jabber_send(msg, usr);
|
|
||||||
show_outgoing_msg("me", usr, msg);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
inp_clear();
|
|
||||||
result = CONTINUE_EVENT_LOOP;
|
|
||||||
|
|
||||||
// /close -> close the current chat window, if in chat
|
|
||||||
} else if (strncmp(cmd, "/close", 6) == 0) {
|
|
||||||
if (in_chat()) {
|
|
||||||
close_win();
|
|
||||||
} else {
|
|
||||||
cons_bad_command(cmd);
|
|
||||||
}
|
|
||||||
inp_clear();
|
|
||||||
result = CONTINUE_EVENT_LOOP;
|
|
||||||
|
|
||||||
// send message to recipient, if in chat
|
|
||||||
} else {
|
|
||||||
if (in_chat()) {
|
|
||||||
char recipient[100] = "";
|
|
||||||
get_recipient(recipient);
|
|
||||||
jabber_send(cmd, recipient);
|
|
||||||
show_outgoing_msg("me", recipient, cmd);
|
|
||||||
} else {
|
|
||||||
cons_bad_command(cmd);
|
|
||||||
}
|
|
||||||
inp_clear();
|
|
||||||
result = CONTINUE_EVENT_LOOP;
|
|
||||||
}
|
|
||||||
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
Loading…
Reference in New Issue
Block a user