diff options
Diffstat (limited to 'testing')
-rw-r--r-- | testing/DHT_test.c | 4 | ||||
-rw-r--r-- | testing/nTox.c | 21 | ||||
-rw-r--r-- | testing/toxic/CMakeLists.txt | 2 | ||||
-rw-r--r-- | testing/toxic/chat.c | 9 | ||||
-rw-r--r-- | testing/toxic/chat.h | 6 | ||||
-rw-r--r-- | testing/toxic/dhtstatus.c | 89 | ||||
-rw-r--r-- | testing/toxic/dhtstatus.h | 8 | ||||
-rw-r--r-- | testing/toxic/friendlist.c | 18 | ||||
-rw-r--r-- | testing/toxic/friendlist.h | 12 | ||||
-rw-r--r-- | testing/toxic/main.c | 414 | ||||
-rw-r--r-- | testing/toxic/prompt.c | 23 | ||||
-rw-r--r-- | testing/toxic/prompt.h | 14 | ||||
-rw-r--r-- | testing/toxic/windows.c | 239 | ||||
-rw-r--r-- | testing/toxic/windows.h | 25 |
14 files changed, 503 insertions, 381 deletions
diff --git a/testing/DHT_test.c b/testing/DHT_test.c index 350093fd..c5b367cf 100644 --- a/testing/DHT_test.c +++ b/testing/DHT_test.c | |||
@@ -53,10 +53,10 @@ void print_clientlist() | |||
53 | uint32_t i, j; | 53 | uint32_t i, j; |
54 | IP_Port p_ip; | 54 | IP_Port p_ip; |
55 | printf("___________________CLOSE________________________________\n"); | 55 | printf("___________________CLOSE________________________________\n"); |
56 | for(i = 0; i < 4; i++) { | 56 | for(i = 0; i < 32; i++) { |
57 | printf("ClientID: "); | 57 | printf("ClientID: "); |
58 | for(j = 0; j < 32; j++) { | 58 | for(j = 0; j < 32; j++) { |
59 | printf("%hhX", close_clientlist[i].client_id[j]); | 59 | printf("%02hhX", close_clientlist[i].client_id[j]); |
60 | } | 60 | } |
61 | p_ip = close_clientlist[i].ip_port; | 61 | p_ip = close_clientlist[i].ip_port; |
62 | printf("\nIP: %u.%u.%u.%u Port: %u",p_ip.ip.c[0],p_ip.ip.c[1],p_ip.ip.c[2],p_ip.ip.c[3],ntohs(p_ip.port)); | 62 | printf("\nIP: %u.%u.%u.%u Port: %u",p_ip.ip.c[0],p_ip.ip.c[1],p_ip.ip.c[2],p_ip.ip.c[3],ntohs(p_ip.port)); |
diff --git a/testing/nTox.c b/testing/nTox.c index cab2d158..ead4fd21 100644 --- a/testing/nTox.c +++ b/testing/nTox.c | |||
@@ -52,28 +52,15 @@ uint8_t num_requests = 0; | |||
52 | 52 | ||
53 | void get_id(Messenger *m, char *data) | 53 | void get_id(Messenger *m, char *data) |
54 | { | 54 | { |
55 | char idstring0[200]; | 55 | sprintf(data, "[i] ID: "); |
56 | char idstring1[FRIEND_ADDRESS_SIZE][5]; | 56 | int offset = strlen(data); |
57 | char idstring2[FRIEND_ADDRESS_SIZE][5]; | ||
58 | int i = 0; | 57 | int i = 0; |
59 | uint8_t address[FRIEND_ADDRESS_SIZE]; | 58 | uint8_t address[FRIEND_ADDRESS_SIZE]; |
60 | getaddress(m, address); | 59 | getaddress(m, address); |
61 | for(i = 0; i < FRIEND_ADDRESS_SIZE; i++) | 60 | for(; i < FRIEND_ADDRESS_SIZE; i++) |
62 | { | 61 | { |
63 | if (address[i] < (FRIEND_ADDRESS_SIZE / 2)) | 62 | sprintf(data + 2*i + offset, "%02X ", address[i]); |
64 | strcpy(idstring1[i],"0"); | ||
65 | else | ||
66 | strcpy(idstring1[i], ""); | ||
67 | sprintf(idstring2[i], "%hhX",address[i]); | ||
68 | } | 63 | } |
69 | strcpy(idstring0,"[i] ID: "); | ||
70 | int j = 0; | ||
71 | for (j = 0; j < FRIEND_ADDRESS_SIZE; j++) { | ||
72 | strcat(idstring0,idstring1[j]); | ||
73 | strcat(idstring0,idstring2[j]); | ||
74 | } | ||
75 | |||
76 | memcpy(data, idstring0, strlen(idstring0)); | ||
77 | } | 64 | } |
78 | 65 | ||
79 | void new_lines(char *line) | 66 | void new_lines(char *line) |
diff --git a/testing/toxic/CMakeLists.txt b/testing/toxic/CMakeLists.txt index 13b8692d..9ee7020e 100644 --- a/testing/toxic/CMakeLists.txt +++ b/testing/toxic/CMakeLists.txt | |||
@@ -8,8 +8,10 @@ set(exe_name toxic) | |||
8 | 8 | ||
9 | add_executable(${exe_name} | 9 | add_executable(${exe_name} |
10 | main.c | 10 | main.c |
11 | windows.c | ||
11 | prompt.c | 12 | prompt.c |
12 | friendlist.c | 13 | friendlist.c |
14 | dhtstatus.c | ||
13 | chat.c | 15 | chat.c |
14 | configdir.c) | 16 | configdir.c) |
15 | 17 | ||
diff --git a/testing/toxic/chat.c b/testing/toxic/chat.c index 1b5e743d..d5edf956 100644 --- a/testing/toxic/chat.c +++ b/testing/toxic/chat.c | |||
@@ -13,6 +13,8 @@ | |||
13 | #include "../../core/network.h" | 13 | #include "../../core/network.h" |
14 | 14 | ||
15 | #include "windows.h" | 15 | #include "windows.h" |
16 | #include "friendlist.h" | ||
17 | #include "chat.h" | ||
16 | 18 | ||
17 | #define CURS_Y_OFFSET 3 | 19 | #define CURS_Y_OFFSET 3 |
18 | 20 | ||
@@ -24,10 +26,6 @@ typedef struct { | |||
24 | WINDOW* linewin; | 26 | WINDOW* linewin; |
25 | } ChatContext; | 27 | } ChatContext; |
26 | 28 | ||
27 | extern int active_window; | ||
28 | |||
29 | extern void del_window(ToxWindow *w, int f_num); | ||
30 | extern void fix_name(uint8_t *name); | ||
31 | void print_help(ChatContext *self); | 29 | void print_help(ChatContext *self); |
32 | void execute(ToxWindow *self, ChatContext *ctx, Messenger *m, char *cmd); | 30 | void execute(ToxWindow *self, ChatContext *ctx, Messenger *m, char *cmd); |
33 | 31 | ||
@@ -316,11 +314,10 @@ void execute(ToxWindow *self, ChatContext *ctx, Messenger *m, char *cmd) | |||
316 | snprintf(xx, sizeof(xx), "%02X", address[i] & 0xff); | 314 | snprintf(xx, sizeof(xx), "%02X", address[i] & 0xff); |
317 | strcat(id, xx); | 315 | strcat(id, xx); |
318 | } | 316 | } |
319 | wprintw(ctx->history, "Your ID: %s\n", id); | 317 | wprintw(ctx->history, "%s\n", id); |
320 | } | 318 | } |
321 | 319 | ||
322 | else if (strcmp(ctx->line, "/close") == 0) { | 320 | else if (strcmp(ctx->line, "/close") == 0) { |
323 | active_window = 0; // Go to prompt screen | ||
324 | int f_num = ctx->friendnum; | 321 | int f_num = ctx->friendnum; |
325 | delwin(ctx->linewin); | 322 | delwin(ctx->linewin); |
326 | del_window(self, f_num); | 323 | del_window(self, f_num); |
diff --git a/testing/toxic/chat.h b/testing/toxic/chat.h new file mode 100644 index 00000000..7599d462 --- /dev/null +++ b/testing/toxic/chat.h | |||
@@ -0,0 +1,6 @@ | |||
1 | #ifndef CHAT_H_6489PZ13 | ||
2 | #define CHAT_H_6489PZ13 | ||
3 | |||
4 | ToxWindow new_chat(Messenger *m, int friendnum); | ||
5 | |||
6 | #endif /* end of include guard: CHAT_H_6489PZ13 */ | ||
diff --git a/testing/toxic/dhtstatus.c b/testing/toxic/dhtstatus.c new file mode 100644 index 00000000..66268900 --- /dev/null +++ b/testing/toxic/dhtstatus.c | |||
@@ -0,0 +1,89 @@ | |||
1 | #include "dhtstatus.h" | ||
2 | #include "string.h" | ||
3 | #include "../../core/network.h" | ||
4 | #include "../../core/DHT.h" | ||
5 | |||
6 | typedef uint8_t ipbuf[3*4+3+1]; | ||
7 | static int num_selected = 0; | ||
8 | |||
9 | static void printip(ipbuf buf, IP ip) | ||
10 | { | ||
11 | sprintf((char*)buf, "%u.%u.%u.%u", ip.c[0], ip.c[1], ip.c[2], ip.c[3]); | ||
12 | } | ||
13 | |||
14 | static void dhtstatus_onKey(ToxWindow *self, Messenger *m, int key) | ||
15 | { | ||
16 | switch(key) { | ||
17 | case KEY_UP: | ||
18 | case 'k': | ||
19 | if (--num_selected < 0) | ||
20 | num_selected = CLIENT_ID_SIZE-1; | ||
21 | break; | ||
22 | |||
23 | case KEY_DOWN: | ||
24 | case 'j': | ||
25 | num_selected = (num_selected+1) % CLIENT_ID_SIZE; | ||
26 | break; | ||
27 | |||
28 | case '\n': | ||
29 | break; | ||
30 | |||
31 | default: | ||
32 | break; | ||
33 | } | ||
34 | } | ||
35 | |||
36 | static void dhtstatus_onDraw(ToxWindow *self) | ||
37 | { | ||
38 | Client_data * close_clientlist = DHT_get_close_list(); | ||
39 | curs_set(0); | ||
40 | werase(self->window); | ||
41 | |||
42 | uint64_t now = unix_time(); | ||
43 | uint32_t i, j; | ||
44 | ipbuf ipbuf; | ||
45 | wprintw(self->window,"\n%llu ______________________ CLOSE LIST ________________________ ___ IP ADDR ___ _PRT_ LST PNG ____ SELF ____ _PRT_ LST\n\n", now); | ||
46 | for(i = 0; i < CLIENT_ID_SIZE; i++) { | ||
47 | Client_data * client = close_clientlist + i; | ||
48 | if (i == num_selected) wattron(self->window, COLOR_PAIR(3)); | ||
49 | wprintw(self->window,"[%02i] ", i); | ||
50 | uint16_t port = ntohs(client->ip_port.port); | ||
51 | if(port) { | ||
52 | for(j = 0; j < 32; j++) | ||
53 | wprintw(self->window, "%02hhx", client->client_id[j]); | ||
54 | |||
55 | printip(ipbuf, client->ip_port.ip); | ||
56 | wprintw(self->window, " %15s %5u ", ipbuf, port); | ||
57 | wprintw(self->window, " %3llu ", now - client->timestamp); | ||
58 | wprintw(self->window, " %3llu ", now - client->last_pinged); | ||
59 | |||
60 | port = ntohs(client->ret_ip_port.port); | ||
61 | if(port) { | ||
62 | printip(ipbuf, client->ret_ip_port.ip); | ||
63 | wprintw(self->window, " %15s %5u %3llu", ipbuf, port, now - close_clientlist[i].ret_timestamp); | ||
64 | } | ||
65 | } | ||
66 | wprintw(self->window, "\n"); | ||
67 | if (i == num_selected) wattroff(self->window, COLOR_PAIR(3)); | ||
68 | } | ||
69 | |||
70 | wrefresh(self->window); | ||
71 | } | ||
72 | |||
73 | static void dhtstatus_onInit(ToxWindow *self, Messenger *m) | ||
74 | { | ||
75 | |||
76 | } | ||
77 | |||
78 | ToxWindow new_dhtstatus() | ||
79 | { | ||
80 | ToxWindow ret; | ||
81 | memset(&ret, 0, sizeof(ret)); | ||
82 | |||
83 | ret.onKey = &dhtstatus_onKey; | ||
84 | ret.onDraw = &dhtstatus_onDraw; | ||
85 | ret.onInit = &dhtstatus_onInit; | ||
86 | |||
87 | strcpy(ret.title, "[dht status]"); | ||
88 | return ret; | ||
89 | } | ||
diff --git a/testing/toxic/dhtstatus.h b/testing/toxic/dhtstatus.h new file mode 100644 index 00000000..2b30e5a3 --- /dev/null +++ b/testing/toxic/dhtstatus.h | |||
@@ -0,0 +1,8 @@ | |||
1 | #ifndef _dhtstatus_h | ||
2 | #define _dhtstatus_h | ||
3 | |||
4 | #include "windows.h" | ||
5 | |||
6 | ToxWindow new_dhtstatus(); | ||
7 | |||
8 | #endif | ||
diff --git a/testing/toxic/friendlist.c b/testing/toxic/friendlist.c index 56061cf9..e7504fbf 100644 --- a/testing/toxic/friendlist.c +++ b/testing/toxic/friendlist.c | |||
@@ -11,12 +11,9 @@ | |||
11 | #include "../../core/network.h" | 11 | #include "../../core/network.h" |
12 | 12 | ||
13 | #include "windows.h" | 13 | #include "windows.h" |
14 | #include "friendlist.h" | ||
14 | 15 | ||
15 | extern char WINDOW_STATUS[TOXWINDOWS_MAX_NUM]; | 16 | static char * WINDOW_STATUS; |
16 | extern int add_window(ToxWindow w, int n); | ||
17 | extern ToxWindow new_chat(Messenger *m, int friendnum); | ||
18 | |||
19 | extern int active_window; | ||
20 | 17 | ||
21 | typedef struct { | 18 | typedef struct { |
22 | uint8_t name[MAX_NAME_LENGTH]; | 19 | uint8_t name[MAX_NAME_LENGTH]; |
@@ -54,8 +51,7 @@ void friendlist_onMessage(ToxWindow *self, Messenger *m, int num, uint8_t *str, | |||
54 | for (i = N_DEFAULT_WINS; i < MAX_WINDOW_SLOTS; ++i) { | 51 | for (i = N_DEFAULT_WINS; i < MAX_WINDOW_SLOTS; ++i) { |
55 | if (WINDOW_STATUS[i] == -1) { | 52 | if (WINDOW_STATUS[i] == -1) { |
56 | WINDOW_STATUS[i] = num; | 53 | WINDOW_STATUS[i] = num; |
57 | add_window(new_chat(m, num), i); | 54 | add_window(m, new_chat(m, num), i); |
58 | active_window = i; | ||
59 | break; | 55 | break; |
60 | } | 56 | } |
61 | } | 57 | } |
@@ -111,7 +107,7 @@ static void friendlist_onKey(ToxWindow *self, Messenger *m, int key) | |||
111 | int i; | 107 | int i; |
112 | for (i = N_DEFAULT_WINS; i < MAX_WINDOW_SLOTS; ++i) { | 108 | for (i = N_DEFAULT_WINS; i < MAX_WINDOW_SLOTS; ++i) { |
113 | if (WINDOW_STATUS[i] == num_selected) { | 109 | if (WINDOW_STATUS[i] == num_selected) { |
114 | active_window = i; | 110 | set_active_window(i); |
115 | break; | 111 | break; |
116 | } | 112 | } |
117 | } | 113 | } |
@@ -121,8 +117,7 @@ static void friendlist_onKey(ToxWindow *self, Messenger *m, int key) | |||
121 | if (WINDOW_STATUS[i] == -1) { | 117 | if (WINDOW_STATUS[i] == -1) { |
122 | WINDOW_STATUS[i] = num_selected; | 118 | WINDOW_STATUS[i] = num_selected; |
123 | friends[num_selected].chatwin = num_selected; | 119 | friends[num_selected].chatwin = num_selected; |
124 | add_window(new_chat(m, num_selected), i); | 120 | add_window(m, new_chat(m, num_selected), i); |
125 | active_window = i; | ||
126 | break; | 121 | break; |
127 | } | 122 | } |
128 | } | 123 | } |
@@ -169,7 +164,8 @@ static void friendlist_onInit(ToxWindow *self, Messenger *m) | |||
169 | 164 | ||
170 | } | 165 | } |
171 | 166 | ||
172 | ToxWindow new_friendlist() { | 167 | ToxWindow new_friendlist(char * ws) { |
168 | WINDOW_STATUS = ws; | ||
173 | ToxWindow ret; | 169 | ToxWindow ret; |
174 | memset(&ret, 0, sizeof(ret)); | 170 | memset(&ret, 0, sizeof(ret)); |
175 | 171 | ||
diff --git a/testing/toxic/friendlist.h b/testing/toxic/friendlist.h new file mode 100644 index 00000000..c3d8dac7 --- /dev/null +++ b/testing/toxic/friendlist.h | |||
@@ -0,0 +1,12 @@ | |||
1 | #ifndef FRIENDLIST_H_53I41IM | ||
2 | #define FRIENDLIST_H_53I41IM | ||
3 | |||
4 | #include "windows.h" | ||
5 | #include "chat.h" | ||
6 | |||
7 | ToxWindow new_friendlist(char * ws); | ||
8 | int friendlist_onFriendAdded(Messenger *m, int num); | ||
9 | void disable_chatwin(int f_num); | ||
10 | void fix_name(uint8_t *name); | ||
11 | |||
12 | #endif /* end of include guard: FRIENDLIST_H_53I41IM */ | ||
diff --git a/testing/toxic/main.c b/testing/toxic/main.c index e9d285cc..aa025a1a 100644 --- a/testing/toxic/main.c +++ b/testing/toxic/main.c | |||
@@ -8,6 +8,7 @@ | |||
8 | #include <stdlib.h> | 8 | #include <stdlib.h> |
9 | #include <stdbool.h> | 9 | #include <stdbool.h> |
10 | #include <stdint.h> | 10 | #include <stdint.h> |
11 | #include <signal.h> | ||
11 | 12 | ||
12 | #ifdef _win32 | 13 | #ifdef _win32 |
13 | #include <direct.h> | 14 | #include <direct.h> |
@@ -21,104 +22,21 @@ | |||
21 | 22 | ||
22 | #include "configdir.h" | 23 | #include "configdir.h" |
23 | #include "windows.h" | 24 | #include "windows.h" |
25 | #include "prompt.h" | ||
26 | #include "friendlist.h" | ||
24 | 27 | ||
25 | extern ToxWindow new_prompt(); | ||
26 | extern ToxWindow new_friendlist(); | ||
27 | 28 | ||
28 | extern int friendlist_onFriendAdded(Messenger *m, int num); | 29 | void on_window_resize(int sig) |
29 | extern void disable_chatwin(int f_num); | ||
30 | extern int add_req(uint8_t *public_key); // XXX | ||
31 | extern unsigned char *hex_string_to_bin(char hex_string[]); | ||
32 | |||
33 | static int store_data(char*); | ||
34 | |||
35 | /* Holds status of chat windows */ | ||
36 | char WINDOW_STATUS[MAX_WINDOW_SLOTS]; | ||
37 | |||
38 | #ifndef TOXICVER | ||
39 | #define TOXICVER "NOVER" //Use the -D flag to set this | ||
40 | #endif | ||
41 | |||
42 | static ToxWindow windows[MAX_WINDOW_SLOTS]; | ||
43 | static ToxWindow* prompt; | ||
44 | |||
45 | static Messenger *m; | ||
46 | static char *DATA_FILE; | ||
47 | |||
48 | int w_num; | ||
49 | int active_window; | ||
50 | |||
51 | /* CALLBACKS START */ | ||
52 | void on_request(uint8_t *public_key, uint8_t *data, uint16_t length, void* userdata) | ||
53 | { | ||
54 | int n = add_req(public_key); | ||
55 | wprintw(prompt->window, "\nFriend request from:\n"); | ||
56 | |||
57 | int i; | ||
58 | for (i = 0; i < KEY_SIZE_BYTES; ++i) { | ||
59 | wprintw(prompt->window, "%02x", public_key[i] & 0xff); | ||
60 | } | ||
61 | |||
62 | wprintw(prompt->window, "\nWith the message: %s\n", data); | ||
63 | wprintw(prompt->window, "\nUse \"accept %d\" to accept it.\n", n); | ||
64 | |||
65 | for (i = 0; i < MAX_WINDOW_SLOTS; ++i) { | ||
66 | if (windows[i].onFriendRequest != NULL) | ||
67 | windows[i].onFriendRequest(&windows[i], public_key, data, length); | ||
68 | } | ||
69 | } | ||
70 | |||
71 | void on_message(Messenger *m, int friendnumber, uint8_t *string, uint16_t length, void* userdata) | ||
72 | { | ||
73 | int i; | ||
74 | for (i = 0; i < MAX_WINDOW_SLOTS; ++i) { | ||
75 | if (windows[i].onMessage != NULL) | ||
76 | windows[i].onMessage(&windows[i], m, friendnumber, string, length); | ||
77 | } | ||
78 | } | ||
79 | |||
80 | void on_action(Messenger *m, int friendnumber, uint8_t *string, uint16_t length, void* userdata) | ||
81 | { | ||
82 | int i; | ||
83 | for (i = 0; i < MAX_WINDOW_SLOTS; ++i) { | ||
84 | if (windows[i].onAction != NULL) | ||
85 | windows[i].onAction(&windows[i], m, friendnumber, string, length); | ||
86 | } | ||
87 | } | ||
88 | |||
89 | void on_nickchange(Messenger *m, int friendnumber, uint8_t *string, uint16_t length, void* userdata) | ||
90 | { | ||
91 | wprintw(prompt->window, "\n(nickchange) %d: %s\n", friendnumber, string); | ||
92 | int i; | ||
93 | for (i = 0; i < MAX_WINDOW_SLOTS; ++i) { | ||
94 | if (windows[i].onNickChange != NULL) | ||
95 | windows[i].onNickChange(&windows[i], friendnumber, string, length); | ||
96 | } | ||
97 | } | ||
98 | |||
99 | void on_statuschange(Messenger *m, int friendnumber, uint8_t *string, uint16_t length, void* userdata) | ||
100 | { | ||
101 | wprintw(prompt->window, "\n(statuschange) %d: %s\n", friendnumber, string); | ||
102 | int i; | ||
103 | for (i=0; i<MAX_WINDOW_SLOTS; ++i) { | ||
104 | if (windows[i].onStatusChange != NULL) | ||
105 | windows[i].onStatusChange(&windows[i], friendnumber, string, length); | ||
106 | } | ||
107 | } | ||
108 | |||
109 | void on_friendadded(int friendnumber) | ||
110 | { | 30 | { |
111 | friendlist_onFriendAdded(m, friendnumber); | 31 | endwin(); |
112 | int st; | 32 | refresh(); |
113 | if ((st = store_data(DATA_FILE)) != 0) { | 33 | clear(); |
114 | wprintw(prompt->window, "\nCould not store messenger, error code: %d\n", st); | ||
115 | } | ||
116 | } | 34 | } |
117 | /* CALLBACKS END */ | ||
118 | 35 | ||
119 | static void init_term() | 36 | static void init_term() |
120 | { | 37 | { |
121 | /* Setup terminal */ | 38 | /* Setup terminal */ |
39 | signal(SIGWINCH, on_window_resize); | ||
122 | initscr(); | 40 | initscr(); |
123 | cbreak(); | 41 | cbreak(); |
124 | keypad(stdscr, 1); | 42 | keypad(stdscr, 1); |
@@ -136,10 +54,10 @@ static void init_term() | |||
136 | refresh(); | 54 | refresh(); |
137 | } | 55 | } |
138 | 56 | ||
139 | static void init_tox() | 57 | static Messenger *init_tox() |
140 | { | 58 | { |
141 | /* Init core */ | 59 | /* Init core */ |
142 | m = initMessenger(); | 60 | Messenger *m = initMessenger(); |
143 | 61 | ||
144 | /* Callbacks */ | 62 | /* Callbacks */ |
145 | m_callback_friendrequest(m, on_request, NULL); | 63 | m_callback_friendrequest(m, on_request, NULL); |
@@ -154,6 +72,7 @@ static void init_tox() | |||
154 | #else | 72 | #else |
155 | setname(m, (uint8_t*) "Hipster", sizeof("Hipster")); | 73 | setname(m, (uint8_t*) "Hipster", sizeof("Hipster")); |
156 | #endif | 74 | #endif |
75 | return m; | ||
157 | } | 76 | } |
158 | 77 | ||
159 | #define MAXLINE 90 /* Approx max number of chars in a sever line (IP + port + key) */ | 78 | #define MAXLINE 90 /* Approx max number of chars in a sever line (IP + port + key) */ |
@@ -202,67 +121,7 @@ int init_connection(void) | |||
202 | return 0; | 121 | return 0; |
203 | } | 122 | } |
204 | 123 | ||
205 | void init_window_status() | 124 | static void do_tox(Messenger *m, ToxWindow * prompt) |
206 | { | ||
207 | /* Default window values decrement from -2 */ | ||
208 | int i; | ||
209 | for (i = 0; i < N_DEFAULT_WINS; ++i) | ||
210 | WINDOW_STATUS[i] = -(i+2); | ||
211 | |||
212 | int j; | ||
213 | for (j = N_DEFAULT_WINS; j < MAX_WINDOW_SLOTS; j++) | ||
214 | WINDOW_STATUS[j] = -1; | ||
215 | } | ||
216 | |||
217 | int add_window(ToxWindow w, int n) | ||
218 | { | ||
219 | if (w_num >= TOXWINDOWS_MAX_NUM) | ||
220 | return -1; | ||
221 | |||
222 | if (LINES < 2) | ||
223 | return -1; | ||
224 | |||
225 | w.window = newwin(LINES - 2, COLS, 0, 0); | ||
226 | if (w.window == NULL) | ||
227 | return -1; | ||
228 | |||
229 | windows[n] = w; | ||
230 | w.onInit(&w, m); | ||
231 | w_num++; | ||
232 | return n; | ||
233 | } | ||
234 | |||
235 | /* Deletes window w and cleans up */ | ||
236 | void del_window(ToxWindow *w, int f_num) | ||
237 | { | ||
238 | delwin(w->window); | ||
239 | int i; | ||
240 | for (i = N_DEFAULT_WINS; i < MAX_WINDOW_SLOTS; ++i) { | ||
241 | if (WINDOW_STATUS[i] == f_num) { | ||
242 | WINDOW_STATUS[i] = -1; | ||
243 | disable_chatwin(f_num); | ||
244 | break; | ||
245 | } | ||
246 | } | ||
247 | clear(); | ||
248 | refresh(); | ||
249 | } | ||
250 | |||
251 | static void init_windows() | ||
252 | { | ||
253 | w_num = 0; | ||
254 | int n_prompt = 0; | ||
255 | int n_friendslist = 1; | ||
256 | if (add_window(new_prompt(), n_prompt) == -1 | ||
257 | || add_window(new_friendlist(), n_friendslist) == -1) { | ||
258 | fprintf(stderr, "add_window() failed.\n"); | ||
259 | endwin(); | ||
260 | exit(1); | ||
261 | } | ||
262 | prompt = &windows[n_prompt]; | ||
263 | } | ||
264 | |||
265 | static void do_tox() | ||
266 | { | 125 | { |
267 | static int conn_try = 0; | 126 | static int conn_try = 0; |
268 | static int conn_err = 0; | 127 | static int conn_err = 0; |
@@ -286,190 +145,69 @@ static void do_tox() | |||
286 | doMessenger(m); | 145 | doMessenger(m); |
287 | } | 146 | } |
288 | 147 | ||
289 | static void populate_friends() | 148 | static void load_data(Messenger *m, char *path) |
290 | { | 149 | { |
291 | wprintw(prompt->window, "Populating friends...\n"); | 150 | FILE *fd; |
292 | uint32_t i; | 151 | size_t len; |
293 | for (i = 0; i < m->numfriends; i++) { | 152 | uint8_t *buf; |
294 | wprintw(prompt->window, "Added friend %d\n", i); | ||
295 | friendlist_onFriendAdded(m, i); | ||
296 | } | ||
297 | } | ||
298 | 153 | ||
299 | /* | 154 | if ((fd = fopen(path, "r")) != NULL) { |
300 | * Store Messenger data to path | 155 | fseek(fd, 0, SEEK_END); |
301 | * Return 0 Messenger stored successfully | 156 | len = ftell(fd); |
302 | * Return 1 malloc failed | 157 | fseek(fd, 0, SEEK_SET); |
303 | * Return 2 fopen failed | ||
304 | * Return 3 fwrite failed | ||
305 | */ | ||
306 | static int store_data(char *path) | ||
307 | { | ||
308 | FILE *fd; | ||
309 | size_t len; | ||
310 | uint8_t *buf; | ||
311 | 158 | ||
159 | buf = malloc(len); | ||
160 | if (buf == NULL) { | ||
161 | fprintf(stderr, "malloc() failed.\n"); | ||
162 | fclose(fd); | ||
163 | endwin(); | ||
164 | exit(1); | ||
165 | } | ||
166 | if (fread(buf, len, 1, fd) != 1){ | ||
167 | fprintf(stderr, "fread() failed.\n"); | ||
168 | free(buf); | ||
169 | fclose(fd); | ||
170 | endwin(); | ||
171 | exit(1); | ||
172 | } | ||
173 | Messenger_load(m, buf, len); | ||
174 | } | ||
175 | else { | ||
312 | len = Messenger_size(m); | 176 | len = Messenger_size(m); |
313 | buf = malloc(len); | 177 | buf = malloc(len); |
314 | if (buf == NULL) { | 178 | if (buf == NULL) { |
315 | return 1; | 179 | fprintf(stderr, "malloc() failed.\n"); |
180 | endwin(); | ||
181 | exit(1); | ||
316 | } | 182 | } |
317 | Messenger_save(m, buf); | 183 | Messenger_save(m, buf); |
318 | 184 | ||
319 | fd = fopen(path, "w"); | 185 | fd = fopen(path, "w"); |
320 | if (fd == NULL) { | 186 | if (fd == NULL) { |
321 | free(buf); | 187 | fprintf(stderr, "fopen() failed.\n"); |
322 | return 2; | 188 | free(buf); |
323 | } | 189 | endwin(); |
324 | 190 | exit(1); | |
325 | if (fwrite(buf, len, 1, fd) != 1) { | ||
326 | free(buf); | ||
327 | fclose(fd); | ||
328 | return 3; | ||
329 | } | ||
330 | |||
331 | free(buf); | ||
332 | fclose(fd); | ||
333 | |||
334 | wprintw(prompt->window, "Messenger stored\n"); | ||
335 | |||
336 | return 0; | ||
337 | } | ||
338 | |||
339 | static void load_data(char *path) { | ||
340 | FILE *fd; | ||
341 | size_t len; | ||
342 | uint8_t *buf; | ||
343 | |||
344 | if ((fd = fopen(path, "r")) != NULL) { | ||
345 | fseek(fd, 0, SEEK_END); | ||
346 | len = ftell(fd); | ||
347 | fseek(fd, 0, SEEK_SET); | ||
348 | |||
349 | buf = malloc(len); | ||
350 | if (buf == NULL) { | ||
351 | fprintf(stderr, "malloc() failed.\n"); | ||
352 | fclose(fd); | ||
353 | endwin(); | ||
354 | exit(1); | ||
355 | } | ||
356 | if (fread(buf, len, 1, fd) != 1) { | ||
357 | fprintf(stderr, "fread() failed.\n"); | ||
358 | free(buf); | ||
359 | fclose(fd); | ||
360 | endwin(); | ||
361 | exit(1); | ||
362 | } | ||
363 | if (Messenger_load(m, buf, len) != 0) { | ||
364 | fprintf(stderr, "Problem while loading messenger"); | ||
365 | } | ||
366 | free(buf); | ||
367 | fclose(fd); | ||
368 | } else { | ||
369 | int st; | ||
370 | if ((st = store_data(path)) != 0) { | ||
371 | fprintf(stderr, "storing messenger failed with error code: %d", st); | ||
372 | endwin(); | ||
373 | exit(1); | ||
374 | } | ||
375 | } | ||
376 | } | ||
377 | |||
378 | static void draw_bar() | ||
379 | { | ||
380 | static int odd = 0; | ||
381 | int blinkrate = 30; | ||
382 | |||
383 | attron(COLOR_PAIR(4)); | ||
384 | mvhline(LINES - 2, 0, '_', COLS); | ||
385 | attroff(COLOR_PAIR(4)); | ||
386 | |||
387 | move(LINES - 1, 0); | ||
388 | |||
389 | attron(COLOR_PAIR(4) | A_BOLD); | ||
390 | printw(" TOXIC " TOXICVER "|"); | ||
391 | attroff(COLOR_PAIR(4) | A_BOLD); | ||
392 | |||
393 | int i; | ||
394 | for (i = 0; i < (MAX_WINDOW_SLOTS); ++i) { | ||
395 | if (WINDOW_STATUS[i] != -1) { | ||
396 | if (i == active_window) | ||
397 | attron(A_BOLD); | ||
398 | |||
399 | odd = (odd+1) % blinkrate; | ||
400 | if (windows[i].blink && (odd < (blinkrate/2))) | ||
401 | attron(COLOR_PAIR(3)); | ||
402 | |||
403 | printw(" %s", windows[i].title); | ||
404 | if (windows[i].blink && (odd < (blinkrate/2))) | ||
405 | attroff(COLOR_PAIR(3)); | ||
406 | |||
407 | if (i == active_window) { | ||
408 | attroff(A_BOLD); | ||
409 | } | ||
410 | } | 191 | } |
411 | } | ||
412 | refresh(); | ||
413 | } | ||
414 | 192 | ||
415 | void prepare_window(WINDOW *w) | 193 | if (fwrite(buf, len, 1, fd) != 1){ |
416 | { | 194 | fprintf(stderr, "fwrite() failed.\n"); |
417 | mvwin(w, 0, 0); | 195 | free(buf); |
418 | wresize(w, LINES-2, COLS); | 196 | fclose(fd); |
419 | } | 197 | endwin(); |
420 | 198 | exit(1); | |
421 | /* Shows next window when tab or back-tab is pressed */ | ||
422 | void set_active_window(int ch) | ||
423 | { | ||
424 | int f_inf = 0; | ||
425 | int max = MAX_WINDOW_SLOTS-1; | ||
426 | if (ch == '\t') { | ||
427 | int i = (active_window + 1) % max; | ||
428 | while (true) { | ||
429 | if (WINDOW_STATUS[i] != -1) { | ||
430 | active_window = i; | ||
431 | return; | ||
432 | } | ||
433 | i = (i + 1) % max; | ||
434 | if (f_inf++ > max) { // infinite loop check | ||
435 | endwin(); | ||
436 | exit(2); | ||
437 | } | ||
438 | } | ||
439 | }else { | ||
440 | int i = active_window - 1; | ||
441 | if (i < 0) i = max; | ||
442 | while (true) { | ||
443 | if (WINDOW_STATUS[i] != -1) { | ||
444 | active_window = i; | ||
445 | return; | ||
446 | } | ||
447 | if (--i < 0) i = max; | ||
448 | if (f_inf++ > max) { | ||
449 | endwin(); | ||
450 | exit(2); | ||
451 | } | ||
452 | } | 199 | } |
453 | } | 200 | } |
201 | free(buf); | ||
202 | fclose(fd); | ||
454 | } | 203 | } |
455 | 204 | ||
456 | int main(int argc, char *argv[]) | 205 | int main(int argc, char *argv[]) |
457 | { | 206 | { |
458 | int ch; | ||
459 | ToxWindow* a; | ||
460 | char *user_config_dir = get_user_config_dir(); | 207 | char *user_config_dir = get_user_config_dir(); |
461 | int config_err = create_user_config_dir(user_config_dir); | 208 | char *DATA_FILE = NULL; |
462 | if(config_err) { | 209 | int config_err = 0; |
463 | DATA_FILE = "data"; | ||
464 | } else { | ||
465 | DATA_FILE = malloc(strlen(user_config_dir) + strlen(CONFIGDIR) + strlen("data") + 1); | ||
466 | strcpy(DATA_FILE, user_config_dir); | ||
467 | strcat(DATA_FILE, CONFIGDIR); | ||
468 | strcat(DATA_FILE, "data"); | ||
469 | } | ||
470 | free(user_config_dir); | ||
471 | 210 | ||
472 | /* This is broken */ | ||
473 | int f_loadfromfile = 1; | 211 | int f_loadfromfile = 1; |
474 | int f_flag = 0; | 212 | int f_flag = 0; |
475 | int i = 0; | 213 | int i = 0; |
@@ -479,7 +217,7 @@ int main(int argc, char *argv[]) | |||
479 | else if (argv[i][0] == '-') { | 217 | else if (argv[i][0] == '-') { |
480 | if (argv[i][1] == 'f') { | 218 | if (argv[i][1] == 'f') { |
481 | if (argv[i + 1] != NULL) | 219 | if (argv[i + 1] != NULL) |
482 | DATA_FILE = argv[i + 1]; | 220 | DATA_FILE = strdup(argv[i + 1]); |
483 | else | 221 | else |
484 | f_flag = -1; | 222 | f_flag = -1; |
485 | } else if (argv[i][1] == 'n') { | 223 | } else if (argv[i][1] == 'n') { |
@@ -488,15 +226,27 @@ int main(int argc, char *argv[]) | |||
488 | } | 226 | } |
489 | } | 227 | } |
490 | 228 | ||
229 | if (DATA_FILE == NULL ) { | ||
230 | config_err = create_user_config_dir(user_config_dir); | ||
231 | if (config_err) { | ||
232 | DATA_FILE = strdup("data"); | ||
233 | } else { | ||
234 | DATA_FILE = malloc(strlen(user_config_dir) + strlen(CONFIGDIR) + strlen("data") + 1); | ||
235 | strcpy(DATA_FILE, user_config_dir); | ||
236 | strcat(DATA_FILE, CONFIGDIR); | ||
237 | strcat(DATA_FILE, "data"); | ||
238 | } | ||
239 | } | ||
240 | free(user_config_dir); | ||
241 | |||
491 | init_term(); | 242 | init_term(); |
492 | init_tox(); | 243 | Messenger *m = init_tox(); |
493 | init_windows(); | 244 | ToxWindow *prompt = init_windows(m); |
494 | init_window_status(); | 245 | init_window_status(); |
495 | 246 | ||
496 | if(f_loadfromfile) { | 247 | if(f_loadfromfile) |
497 | load_data(DATA_FILE); | 248 | load_data(m, DATA_FILE); |
498 | populate_friends(); | 249 | free(DATA_FILE); |
499 | } | ||
500 | 250 | ||
501 | if (f_flag == -1) { | 251 | if (f_flag == -1) { |
502 | attron(COLOR_PAIR(3) | A_BOLD); | 252 | attron(COLOR_PAIR(3) | A_BOLD); |
@@ -513,25 +263,11 @@ int main(int argc, char *argv[]) | |||
513 | } | 263 | } |
514 | while(true) { | 264 | while(true) { |
515 | /* Update tox */ | 265 | /* Update tox */ |
516 | do_tox(); | 266 | do_tox(m, prompt); |
517 | 267 | ||
518 | /* Draw */ | 268 | /* Draw */ |
519 | a = &windows[active_window]; | 269 | draw_active_window(m); |
520 | prepare_window(a->window); | ||
521 | a->blink = false; | ||
522 | draw_bar(); | ||
523 | a->onDraw(a); | ||
524 | |||
525 | /* Handle input */ | ||
526 | ch = getch(); | ||
527 | if (ch == '\t' || ch == KEY_BTAB) | ||
528 | set_active_window(ch); | ||
529 | else if (ch != ERR) | ||
530 | a->onKey(a, m, ch); | ||
531 | } | 270 | } |
532 | |||
533 | cleanupMessenger(m); | 271 | cleanupMessenger(m); |
534 | free(DATA_FILE); | ||
535 | |||
536 | return 0; | 272 | return 0; |
537 | } | 273 | } |
diff --git a/testing/toxic/prompt.c b/testing/toxic/prompt.c index e1a7d75c..b84773af 100644 --- a/testing/toxic/prompt.c +++ b/testing/toxic/prompt.c | |||
@@ -11,11 +11,12 @@ | |||
11 | #include "../../core/network.h" | 11 | #include "../../core/network.h" |
12 | 12 | ||
13 | #include "windows.h" | 13 | #include "windows.h" |
14 | #include "prompt.h" | ||
14 | 15 | ||
15 | uint8_t pending_requests[MAX_STR_SIZE][CLIENT_ID_SIZE]; // XXX | 16 | uint8_t pending_requests[MAX_STR_SIZE][CLIENT_ID_SIZE]; // XXX |
16 | uint8_t num_requests=0; // XXX | 17 | uint8_t num_requests=0; // XXX |
17 | 18 | ||
18 | extern void on_friendadded(int friendnumber); | 19 | static friendAddedFn *on_friendadded; |
19 | static char prompt_buf[MAX_STR_SIZE] = {0}; | 20 | static char prompt_buf[MAX_STR_SIZE] = {0}; |
20 | static int prompt_buf_pos = 0; | 21 | static int prompt_buf_pos = 0; |
21 | 22 | ||
@@ -87,7 +88,7 @@ void cmd_accept(ToxWindow *self, Messenger *m, char **args) | |||
87 | wprintw(self->window, "Failed to add friend.\n"); | 88 | wprintw(self->window, "Failed to add friend.\n"); |
88 | else { | 89 | else { |
89 | wprintw(self->window, "Friend accepted as: %d.\n", num); | 90 | wprintw(self->window, "Friend accepted as: %d.\n", num); |
90 | on_friendadded(num); | 91 | on_friendadded(m, num); |
91 | } | 92 | } |
92 | } | 93 | } |
93 | 94 | ||
@@ -121,6 +122,11 @@ void cmd_add(ToxWindow *self, Messenger *m, char **args) | |||
121 | } | 122 | } |
122 | id_bin[i] = x; | 123 | id_bin[i] = x; |
123 | } | 124 | } |
125 | |||
126 | for (i = 0; i < FRIEND_ADDRESS_SIZE; i++) { | ||
127 | id[i] = toupper(id[i]); | ||
128 | } | ||
129 | |||
124 | int num = m_addfriend(m, id_bin, (uint8_t*) msg, strlen(msg)+1); | 130 | int num = m_addfriend(m, id_bin, (uint8_t*) msg, strlen(msg)+1); |
125 | switch (num) { | 131 | switch (num) { |
126 | case FAERR_TOOLONG: | 132 | case FAERR_TOOLONG: |
@@ -138,9 +144,15 @@ void cmd_add(ToxWindow *self, Messenger *m, char **args) | |||
138 | case FAERR_UNKNOWN: | 144 | case FAERR_UNKNOWN: |
139 | wprintw(self->window, "Undefined error when adding friend.\n"); | 145 | wprintw(self->window, "Undefined error when adding friend.\n"); |
140 | break; | 146 | break; |
147 | case FAERR_BADCHECKSUM: | ||
148 | wprintw(self->window, "Bad checksum in address.\n"); | ||
149 | break; | ||
150 | case FAERR_SETNEWNOSPAM: | ||
151 | wprintw(self->window, "Nospam was different.\n"); | ||
152 | break; | ||
141 | default: | 153 | default: |
142 | wprintw(self->window, "Friend added as %d.\n", num); | 154 | wprintw(self->window, "Friend added as %d.\n", num); |
143 | on_friendadded(num); | 155 | on_friendadded(m, num); |
144 | break; | 156 | break; |
145 | } | 157 | } |
146 | } | 158 | } |
@@ -226,7 +238,7 @@ void cmd_myid(ToxWindow *self, Messenger *m, char **args) | |||
226 | snprintf(xx, sizeof(xx), "%02X", address[i] & 0xff); | 238 | snprintf(xx, sizeof(xx), "%02X", address[i] & 0xff); |
227 | strcat(id, xx); | 239 | strcat(id, xx); |
228 | } | 240 | } |
229 | wprintw(self->window, "Your ID: %s\n", id); | 241 | wprintw(self->window, "%s\n", id); |
230 | } | 242 | } |
231 | 243 | ||
232 | void cmd_nick(ToxWindow *self, Messenger *m, char **args) | 244 | void cmd_nick(ToxWindow *self, Messenger *m, char **args) |
@@ -422,8 +434,9 @@ static void prompt_onInit(ToxWindow *self, Messenger *m) | |||
422 | wclrtoeol(self->window); | 434 | wclrtoeol(self->window); |
423 | } | 435 | } |
424 | 436 | ||
425 | ToxWindow new_prompt() | 437 | ToxWindow new_prompt(friendAddedFn *f) |
426 | { | 438 | { |
439 | on_friendadded = f; | ||
427 | ToxWindow ret; | 440 | ToxWindow ret; |
428 | memset(&ret, 0, sizeof(ret)); | 441 | memset(&ret, 0, sizeof(ret)); |
429 | ret.onKey = &prompt_onKey; | 442 | ret.onKey = &prompt_onKey; |
diff --git a/testing/toxic/prompt.h b/testing/toxic/prompt.h new file mode 100644 index 00000000..6c5320ab --- /dev/null +++ b/testing/toxic/prompt.h | |||
@@ -0,0 +1,14 @@ | |||
1 | #ifndef PROMPT_H_UZYGWFFL | ||
2 | #define PROMPT_H_UZYGWFFL | ||
3 | |||
4 | #include "windows.h" | ||
5 | |||
6 | typedef void (friendAddedFn)(Messenger *m, int friendnumber); | ||
7 | |||
8 | ToxWindow new_prompt(friendAddedFn *f); | ||
9 | int add_req(uint8_t *public_key); | ||
10 | unsigned char *hex_string_to_bin(char hex_string[]); | ||
11 | |||
12 | #endif /* end of include guard: PROMPT_H_UZYGWFFL */ | ||
13 | |||
14 | |||
diff --git a/testing/toxic/windows.c b/testing/toxic/windows.c new file mode 100644 index 00000000..6de50741 --- /dev/null +++ b/testing/toxic/windows.c | |||
@@ -0,0 +1,239 @@ | |||
1 | #include "friendlist.h" | ||
2 | #include "prompt.h" | ||
3 | #include "dhtstatus.h" | ||
4 | #include "windows.h" | ||
5 | |||
6 | /* Holds status of chat windows */ | ||
7 | char WINDOW_STATUS[MAX_WINDOW_SLOTS]; | ||
8 | |||
9 | static int w_num; | ||
10 | static ToxWindow windows[MAX_WINDOW_SLOTS]; | ||
11 | static Messenger *m; | ||
12 | int active_window; | ||
13 | |||
14 | static ToxWindow* prompt; | ||
15 | |||
16 | /* CALLBACKS START */ | ||
17 | void on_request(uint8_t *public_key, uint8_t *data, uint16_t length, void* userdata) | ||
18 | { | ||
19 | int n = add_req(public_key); | ||
20 | wprintw(prompt->window, "\nFriend request from:\n"); | ||
21 | |||
22 | int i; | ||
23 | for (i = 0; i < KEY_SIZE_BYTES; ++i) { | ||
24 | wprintw(prompt->window, "%02x", public_key[i] & 0xff); | ||
25 | } | ||
26 | |||
27 | wprintw(prompt->window, "\nWith the message: %s\n", data); | ||
28 | wprintw(prompt->window, "\nUse \"accept %d\" to accept it.\n", n); | ||
29 | |||
30 | for (i = 0; i < MAX_WINDOW_SLOTS; ++i) { | ||
31 | if (windows[i].onFriendRequest != NULL) | ||
32 | windows[i].onFriendRequest(&windows[i], public_key, data, length); | ||
33 | } | ||
34 | } | ||
35 | |||
36 | void on_message(Messenger *m, int friendnumber, uint8_t *string, uint16_t length, void* userdata) | ||
37 | { | ||
38 | int i; | ||
39 | for (i = 0; i < MAX_WINDOW_SLOTS; ++i) { | ||
40 | if (windows[i].onMessage != NULL) | ||
41 | windows[i].onMessage(&windows[i], m, friendnumber, string, length); | ||
42 | } | ||
43 | } | ||
44 | |||
45 | void on_action(Messenger *m, int friendnumber, uint8_t *string, uint16_t length, void* userdata) | ||
46 | { | ||
47 | int i; | ||
48 | for (i = 0; i < MAX_WINDOW_SLOTS; ++i) { | ||
49 | if (windows[i].onAction != NULL) | ||
50 | windows[i].onAction(&windows[i], m, friendnumber, string, length); | ||
51 | } | ||
52 | } | ||
53 | |||
54 | void on_nickchange(Messenger *m, int friendnumber, uint8_t *string, uint16_t length, void* userdata) | ||
55 | { | ||
56 | wprintw(prompt->window, "\n(nickchange) %d: %s\n", friendnumber, string); | ||
57 | int i; | ||
58 | for (i = 0; i < MAX_WINDOW_SLOTS; ++i) { | ||
59 | if (windows[i].onNickChange != NULL) | ||
60 | windows[i].onNickChange(&windows[i], friendnumber, string, length); | ||
61 | } | ||
62 | } | ||
63 | |||
64 | void on_statuschange(Messenger *m, int friendnumber, uint8_t *string, uint16_t length, void* userdata) | ||
65 | { | ||
66 | wprintw(prompt->window, "\n(statuschange) %d: %s\n", friendnumber, string); | ||
67 | int i; | ||
68 | for (i=0; i<MAX_WINDOW_SLOTS; ++i) { | ||
69 | if (windows[i].onStatusChange != NULL) | ||
70 | windows[i].onStatusChange(&windows[i], friendnumber, string, length); | ||
71 | } | ||
72 | } | ||
73 | |||
74 | void on_friendadded(Messenger *m, int friendnumber) | ||
75 | { | ||
76 | friendlist_onFriendAdded(m, friendnumber); | ||
77 | } | ||
78 | /* CALLBACKS END */ | ||
79 | |||
80 | int add_window(Messenger *m, ToxWindow w, int n) | ||
81 | { | ||
82 | if (w_num >= TOXWINDOWS_MAX_NUM) | ||
83 | return -1; | ||
84 | |||
85 | if (LINES < 2) | ||
86 | return -1; | ||
87 | |||
88 | w.window = newwin(LINES - 2, COLS, 0, 0); | ||
89 | if (w.window == NULL) | ||
90 | return -1; | ||
91 | |||
92 | windows[n] = w; | ||
93 | w.onInit(&w, m); | ||
94 | w_num++; | ||
95 | active_window = n; | ||
96 | return n; | ||
97 | } | ||
98 | |||
99 | /* Deletes window w and cleans up */ | ||
100 | void del_window(ToxWindow *w, int f_num) | ||
101 | { | ||
102 | active_window = 0; // Go to prompt screen | ||
103 | delwin(w->window); | ||
104 | int i; | ||
105 | for (i = N_DEFAULT_WINS; i < MAX_WINDOW_SLOTS; ++i) { | ||
106 | if (WINDOW_STATUS[i] == f_num) { | ||
107 | WINDOW_STATUS[i] = -1; | ||
108 | disable_chatwin(f_num); | ||
109 | break; | ||
110 | } | ||
111 | } | ||
112 | clear(); | ||
113 | refresh(); | ||
114 | } | ||
115 | |||
116 | /* Shows next window when tab or back-tab is pressed */ | ||
117 | void set_active_window(int ch) | ||
118 | { | ||
119 | int f_inf = 0; | ||
120 | int max = MAX_WINDOW_SLOTS-1; | ||
121 | if (ch == '\t') { | ||
122 | int i = (active_window + 1) % max; | ||
123 | while (true) { | ||
124 | if (WINDOW_STATUS[i] != -1) { | ||
125 | active_window = i; | ||
126 | return; | ||
127 | } | ||
128 | i = (i + 1) % max; | ||
129 | if (f_inf++ > max) { // infinite loop check | ||
130 | endwin(); | ||
131 | exit(2); | ||
132 | } | ||
133 | } | ||
134 | }else { | ||
135 | int i = active_window - 1; | ||
136 | if (i < 0) i = max; | ||
137 | while (true) { | ||
138 | if (WINDOW_STATUS[i] != -1) { | ||
139 | active_window = i; | ||
140 | return; | ||
141 | } | ||
142 | if (--i < 0) i = max; | ||
143 | if (f_inf++ > max) { | ||
144 | endwin(); | ||
145 | exit(2); | ||
146 | } | ||
147 | } | ||
148 | } | ||
149 | } | ||
150 | |||
151 | void init_window_status() | ||
152 | { | ||
153 | /* Default window values decrement from -2 */ | ||
154 | int i; | ||
155 | for (i = 0; i < N_DEFAULT_WINS; ++i) | ||
156 | WINDOW_STATUS[i] = -(i+2); | ||
157 | |||
158 | int j; | ||
159 | for (j = N_DEFAULT_WINS; j < MAX_WINDOW_SLOTS; j++) | ||
160 | WINDOW_STATUS[j] = -1; | ||
161 | } | ||
162 | |||
163 | ToxWindow *init_windows() | ||
164 | { | ||
165 | w_num = 0; | ||
166 | int n_prompt = 0; | ||
167 | int n_friendslist = 1; | ||
168 | int n_dhtstatus = 2; | ||
169 | if (add_window(m, new_prompt(on_friendadded), n_prompt) == -1 | ||
170 | || add_window(m, new_friendlist(WINDOW_STATUS), n_friendslist) == -1 | ||
171 | || add_window(m, new_dhtstatus(), n_dhtstatus) == -1) { | ||
172 | fprintf(stderr, "add_window() failed.\n"); | ||
173 | endwin(); | ||
174 | exit(1); | ||
175 | } | ||
176 | active_window = n_prompt; | ||
177 | prompt = &windows[n_prompt]; | ||
178 | return prompt; | ||
179 | } | ||
180 | |||
181 | static void draw_bar() | ||
182 | { | ||
183 | static int odd = 0; | ||
184 | int blinkrate = 30; | ||
185 | |||
186 | attron(COLOR_PAIR(4)); | ||
187 | mvhline(LINES - 2, 0, '_', COLS); | ||
188 | attroff(COLOR_PAIR(4)); | ||
189 | |||
190 | move(LINES - 1, 0); | ||
191 | |||
192 | attron(COLOR_PAIR(4) | A_BOLD); | ||
193 | printw(" TOXIC " TOXICVER "|"); | ||
194 | attroff(COLOR_PAIR(4) | A_BOLD); | ||
195 | |||
196 | int i; | ||
197 | for (i = 0; i < (MAX_WINDOW_SLOTS); ++i) { | ||
198 | if (WINDOW_STATUS[i] != -1) { | ||
199 | if (i == active_window) | ||
200 | attron(A_BOLD); | ||
201 | |||
202 | odd = (odd+1) % blinkrate; | ||
203 | if (windows[i].blink && (odd < (blinkrate/2))) | ||
204 | attron(COLOR_PAIR(3)); | ||
205 | |||
206 | printw(" %s", windows[i].title); | ||
207 | if (windows[i].blink && (odd < (blinkrate/2))) | ||
208 | attroff(COLOR_PAIR(3)); | ||
209 | |||
210 | if (i == active_window) { | ||
211 | attroff(A_BOLD); | ||
212 | } | ||
213 | } | ||
214 | } | ||
215 | refresh(); | ||
216 | } | ||
217 | |||
218 | void prepare_window(WINDOW *w) | ||
219 | { | ||
220 | mvwin(w, 0, 0); | ||
221 | wresize(w, LINES-2, COLS); | ||
222 | } | ||
223 | |||
224 | void draw_active_window(Messenger *m) | ||
225 | { | ||
226 | |||
227 | ToxWindow *a = &windows[active_window]; | ||
228 | prepare_window(a->window); | ||
229 | a->blink = false; | ||
230 | draw_bar(); | ||
231 | a->onDraw(a); | ||
232 | |||
233 | /* Handle input */ | ||
234 | int ch = getch(); | ||
235 | if (ch == '\t' || ch == KEY_BTAB) | ||
236 | set_active_window(ch); | ||
237 | else if (ch != ERR) | ||
238 | a->onKey(a, m, ch); | ||
239 | } | ||
diff --git a/testing/toxic/windows.h b/testing/toxic/windows.h index 648243d0..893ccf6f 100644 --- a/testing/toxic/windows.h +++ b/testing/toxic/windows.h | |||
@@ -1,19 +1,28 @@ | |||
1 | /* | 1 | /* |
2 | * Toxic -- Tox Curses Client | 2 | * Toxic -- Tox Curses Client |
3 | */ | 3 | */ |
4 | #ifndef _windows_h | ||
5 | #define _windows_h | ||
4 | 6 | ||
7 | #include <curses.h> | ||
8 | #include <stdint.h> | ||
5 | #include <stdbool.h> | 9 | #include <stdbool.h> |
10 | #include "../../core/Messenger.h" | ||
6 | #define TOXWINDOWS_MAX_NUM 32 | 11 | #define TOXWINDOWS_MAX_NUM 32 |
7 | #define MAX_FRIENDS_NUM 100 | 12 | #define MAX_FRIENDS_NUM 100 |
8 | #define MAX_STR_SIZE 256 | 13 | #define MAX_STR_SIZE 256 |
9 | #define KEY_SIZE_BYTES 32 | 14 | #define KEY_SIZE_BYTES 32 |
10 | 15 | ||
11 | /* number of permanent default windows */ | 16 | /* number of permanent default windows */ |
12 | #define N_DEFAULT_WINS 2 | 17 | #define N_DEFAULT_WINS 3 |
13 | 18 | ||
14 | /* maximum window slots for WINDOW_STATUS array */ | 19 | /* maximum window slots for WINDOW_STATUS array */ |
15 | #define MAX_WINDOW_SLOTS N_DEFAULT_WINS+MAX_FRIENDS_NUM | 20 | #define MAX_WINDOW_SLOTS N_DEFAULT_WINS+MAX_FRIENDS_NUM |
16 | 21 | ||
22 | #ifndef TOXICVER | ||
23 | #define TOXICVER "NOVER" //Use the -D flag to set this | ||
24 | #endif | ||
25 | |||
17 | typedef struct ToxWindow_ ToxWindow; | 26 | typedef struct ToxWindow_ ToxWindow; |
18 | 27 | ||
19 | struct ToxWindow_ { | 28 | struct ToxWindow_ { |
@@ -32,3 +41,17 @@ struct ToxWindow_ { | |||
32 | 41 | ||
33 | WINDOW* window; | 42 | WINDOW* window; |
34 | }; | 43 | }; |
44 | |||
45 | void on_request(uint8_t *public_key, uint8_t *data, uint16_t length, void* userdata); | ||
46 | void on_message(Messenger *m, int friendnumber, uint8_t *string, uint16_t length, void* userdata); | ||
47 | void on_action(Messenger *m, int friendnumber, uint8_t *string, uint16_t length, void* userdata); | ||
48 | void on_nickchange(Messenger *m, int friendnumber, uint8_t *string, uint16_t length, void* userdata); | ||
49 | void on_statuschange(Messenger *m, int friendnumber, uint8_t *string, uint16_t length, void* userdata); | ||
50 | void init_window_status(); | ||
51 | ToxWindow * init_windows(); | ||
52 | void draw_active_window(Messenger * m); | ||
53 | int add_window(Messenger *m, ToxWindow w, int n); | ||
54 | void del_window(ToxWindow *w, int f_num); | ||
55 | void set_active_window(int ch); | ||
56 | #endif | ||
57 | |||