2014-02-25 08:28:24 +01:00
|
|
|
/* windows.c
|
|
|
|
*
|
|
|
|
*
|
|
|
|
* Copyright (C) 2014 Toxic All Rights Reserved.
|
|
|
|
*
|
|
|
|
* This file is part of Toxic.
|
|
|
|
*
|
|
|
|
* Toxic 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 3 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* Toxic 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 Toxic. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2013-08-23 23:03:44 +02:00
|
|
|
#include <stdlib.h>
|
|
|
|
#include <string.h>
|
2014-03-13 11:06:53 +01:00
|
|
|
#include <pthread.h>
|
2014-06-22 03:41:38 +02:00
|
|
|
#include <ctype.h>
|
2013-08-23 23:03:44 +02:00
|
|
|
|
2013-08-13 02:21:03 +02:00
|
|
|
#include "friendlist.h"
|
|
|
|
#include "prompt.h"
|
2014-06-12 00:06:55 +02:00
|
|
|
#include "toxic.h"
|
|
|
|
#include "windows.h"
|
2014-02-26 11:23:11 +01:00
|
|
|
#include "groupchat.h"
|
2014-06-22 03:41:38 +02:00
|
|
|
#include "chat.h"
|
|
|
|
#include "line_info.h"
|
2014-10-03 23:53:50 +02:00
|
|
|
#include "misc_tools.h"
|
2013-08-13 02:21:03 +02:00
|
|
|
|
2014-07-28 01:06:25 +02:00
|
|
|
#include "settings.h"
|
2013-08-15 12:11:48 +02:00
|
|
|
extern char *DATA_FILE;
|
2014-09-23 03:24:45 +02:00
|
|
|
extern struct Winthread Winthread;
|
2013-08-17 15:40:30 +02:00
|
|
|
static ToxWindow windows[MAX_WINDOWS_NUM];
|
2013-08-17 10:00:19 +02:00
|
|
|
static ToxWindow *active_window;
|
2013-11-30 11:35:25 +01:00
|
|
|
|
|
|
|
extern ToxWindow *prompt;
|
2014-09-23 03:24:45 +02:00
|
|
|
extern struct user_settings *user_settings;
|
2013-08-13 02:21:03 +02:00
|
|
|
|
2014-03-07 01:39:57 +01:00
|
|
|
static int num_active_windows;
|
2014-07-30 02:10:28 +02:00
|
|
|
|
2013-08-13 02:21:03 +02:00
|
|
|
/* CALLBACKS START */
|
2014-06-12 02:04:20 +02:00
|
|
|
void on_request(Tox *m, const uint8_t *public_key, const uint8_t *data, uint16_t length, void *userdata)
|
2013-08-13 02:21:03 +02:00
|
|
|
{
|
2014-10-03 23:53:50 +02:00
|
|
|
char msg[MAX_STR_SIZE + 1];
|
|
|
|
length = copy_tox_str(msg, sizeof(msg), (const char *) data, length);
|
|
|
|
|
2013-08-16 19:11:09 +02:00
|
|
|
int i;
|
2014-03-30 22:40:13 +02:00
|
|
|
|
2014-03-18 03:18:04 +01:00
|
|
|
for (i = 0; i < MAX_WINDOWS_NUM; ++i) {
|
2013-08-16 19:11:09 +02:00
|
|
|
if (windows[i].onFriendRequest != NULL)
|
2014-10-03 23:53:50 +02:00
|
|
|
windows[i].onFriendRequest(&windows[i], m, (const char *) public_key, msg, length);
|
2013-08-16 19:11:09 +02:00
|
|
|
}
|
2013-08-13 02:21:03 +02:00
|
|
|
}
|
|
|
|
|
2014-03-19 02:48:26 +01:00
|
|
|
void on_connectionchange(Tox *m, int32_t friendnumber, uint8_t status, void *userdata)
|
2013-09-05 03:25:59 +02:00
|
|
|
{
|
|
|
|
int i;
|
|
|
|
|
2014-03-18 03:18:04 +01:00
|
|
|
for (i = 0; i < MAX_WINDOWS_NUM; ++i) {
|
2013-09-05 03:25:59 +02:00
|
|
|
if (windows[i].onConnectionChange != NULL)
|
|
|
|
windows[i].onConnectionChange(&windows[i], m, friendnumber, status);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-03-21 01:50:48 +01:00
|
|
|
void on_typing_change(Tox *m, int32_t friendnumber, uint8_t is_typing, void *userdata)
|
2014-02-23 10:28:33 +01:00
|
|
|
{
|
2014-09-23 03:24:45 +02:00
|
|
|
if (user_settings->show_typing_other == SHOW_TYPING_OFF)
|
2014-07-30 02:10:28 +02:00
|
|
|
return;
|
|
|
|
|
2014-02-23 10:28:33 +01:00
|
|
|
int i;
|
|
|
|
|
2014-03-18 03:18:04 +01:00
|
|
|
for (i = 0; i < MAX_WINDOWS_NUM; ++i) {
|
2014-02-23 10:28:33 +01:00
|
|
|
if (windows[i].onTypingChange != NULL)
|
|
|
|
windows[i].onTypingChange(&windows[i], m, friendnumber, is_typing);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-07-02 23:30:31 +02:00
|
|
|
void on_message(Tox *m, int32_t friendnumber, const uint8_t *string, uint16_t length, void *userdata)
|
2013-08-13 02:21:03 +02:00
|
|
|
{
|
2014-10-03 23:53:50 +02:00
|
|
|
char msg[MAX_STR_SIZE + 1];
|
|
|
|
length = copy_tox_str(msg, sizeof(msg), (const char *) string, length);
|
|
|
|
|
2013-08-16 19:11:09 +02:00
|
|
|
int i;
|
|
|
|
|
2014-03-18 03:18:04 +01:00
|
|
|
for (i = 0; i < MAX_WINDOWS_NUM; ++i) {
|
2013-08-16 19:11:09 +02:00
|
|
|
if (windows[i].onMessage != NULL)
|
2014-10-03 23:53:50 +02:00
|
|
|
windows[i].onMessage(&windows[i], m, friendnumber, msg, length);
|
2013-08-16 19:11:09 +02:00
|
|
|
}
|
2013-08-13 02:21:03 +02:00
|
|
|
}
|
|
|
|
|
2014-07-02 23:30:31 +02:00
|
|
|
void on_action(Tox *m, int32_t friendnumber, const uint8_t *string, uint16_t length, void *userdata)
|
2013-08-13 02:21:03 +02:00
|
|
|
{
|
2014-10-03 23:53:50 +02:00
|
|
|
char msg[MAX_STR_SIZE + 1];
|
|
|
|
length = copy_tox_str(msg, sizeof(msg), (const char *) string, length);
|
|
|
|
|
2013-08-16 19:11:09 +02:00
|
|
|
int i;
|
|
|
|
|
2014-03-18 03:18:04 +01:00
|
|
|
for (i = 0; i < MAX_WINDOWS_NUM; ++i) {
|
2013-08-16 19:11:09 +02:00
|
|
|
if (windows[i].onAction != NULL)
|
2014-10-04 03:08:33 +02:00
|
|
|
windows[i].onAction(&windows[i], m, friendnumber, msg, length);
|
2013-08-16 19:11:09 +02:00
|
|
|
}
|
2013-08-13 02:21:03 +02:00
|
|
|
}
|
|
|
|
|
2014-07-02 23:30:31 +02:00
|
|
|
void on_nickchange(Tox *m, int32_t friendnumber, const uint8_t *string, uint16_t length, void *userdata)
|
2013-08-13 02:21:03 +02:00
|
|
|
{
|
2014-10-03 23:53:50 +02:00
|
|
|
char nick[TOXIC_MAX_NAME_LENGTH + 1];
|
|
|
|
length = copy_tox_str(nick, sizeof(nick), (const char *) string, length);
|
|
|
|
|
2013-08-16 19:11:09 +02:00
|
|
|
int i;
|
|
|
|
|
2014-03-18 03:18:04 +01:00
|
|
|
for (i = 0; i < MAX_WINDOWS_NUM; ++i) {
|
2013-09-04 08:05:36 +02:00
|
|
|
if (windows[i].onNickChange != NULL)
|
2014-10-03 23:53:50 +02:00
|
|
|
windows[i].onNickChange(&windows[i], m, friendnumber, nick, length);
|
2013-08-16 19:11:09 +02:00
|
|
|
}
|
2013-09-09 06:56:47 +02:00
|
|
|
|
2014-07-09 06:05:13 +02:00
|
|
|
store_data(m, DATA_FILE);
|
2013-08-13 02:21:03 +02:00
|
|
|
}
|
|
|
|
|
2014-07-02 23:30:31 +02:00
|
|
|
void on_statusmessagechange(Tox *m, int32_t friendnumber, const uint8_t *string, uint16_t length, void *userdata)
|
2013-08-13 02:21:03 +02:00
|
|
|
{
|
2014-10-03 23:53:50 +02:00
|
|
|
char msg[TOX_MAX_STATUSMESSAGE_LENGTH + 1];
|
|
|
|
length = copy_tox_str(msg, sizeof(msg), (const char *) string, length);
|
|
|
|
|
2013-08-16 19:11:09 +02:00
|
|
|
int i;
|
|
|
|
|
2014-03-18 03:18:04 +01:00
|
|
|
for (i = 0; i < MAX_WINDOWS_NUM; ++i) {
|
2013-09-03 05:27:34 +02:00
|
|
|
if (windows[i].onStatusMessageChange != NULL)
|
2014-10-03 23:53:50 +02:00
|
|
|
windows[i].onStatusMessageChange(&windows[i], friendnumber, msg, length);
|
2013-08-16 19:11:09 +02:00
|
|
|
}
|
2013-08-13 02:21:03 +02:00
|
|
|
}
|
|
|
|
|
2014-03-19 02:48:26 +01:00
|
|
|
void on_statuschange(Tox *m, int32_t friendnumber, uint8_t status, void *userdata)
|
2013-09-05 03:25:59 +02:00
|
|
|
{
|
|
|
|
int i;
|
|
|
|
|
2014-03-18 03:18:04 +01:00
|
|
|
for (i = 0; i < MAX_WINDOWS_NUM; ++i) {
|
2013-09-05 03:25:59 +02:00
|
|
|
if (windows[i].onStatusChange != NULL)
|
|
|
|
windows[i].onStatusChange(&windows[i], m, friendnumber, status);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-03-19 02:48:26 +01:00
|
|
|
void on_friendadded(Tox *m, int32_t friendnumber, bool sort)
|
2013-08-13 02:21:03 +02:00
|
|
|
{
|
2013-11-15 20:59:49 +01:00
|
|
|
int i;
|
|
|
|
|
2014-03-18 03:18:04 +01:00
|
|
|
for (i = 0; i < MAX_WINDOWS_NUM; ++i) {
|
2013-11-15 20:59:49 +01:00
|
|
|
if (windows[i].onFriendAdded != NULL)
|
2013-12-04 07:08:26 +01:00
|
|
|
windows[i].onFriendAdded(&windows[i], m, friendnumber, sort);
|
2013-11-15 20:59:49 +01:00
|
|
|
}
|
2013-08-16 19:11:09 +02:00
|
|
|
|
2014-07-09 06:05:13 +02:00
|
|
|
store_data(m, DATA_FILE);
|
2013-08-13 02:21:03 +02:00
|
|
|
}
|
2013-09-15 22:38:38 +02:00
|
|
|
|
2014-07-02 23:30:31 +02:00
|
|
|
void on_groupmessage(Tox *m, int groupnumber, int peernumber, const uint8_t *message, uint16_t length,
|
2013-10-11 10:42:30 +02:00
|
|
|
void *userdata)
|
2013-09-15 22:38:38 +02:00
|
|
|
{
|
2014-10-03 23:53:50 +02:00
|
|
|
char msg[MAX_STR_SIZE + 1];
|
|
|
|
length = copy_tox_str(msg, sizeof(msg), (const char *) message, length);
|
|
|
|
|
2013-09-15 22:38:38 +02:00
|
|
|
int i;
|
|
|
|
|
2014-03-18 03:18:04 +01:00
|
|
|
for (i = 0; i < MAX_WINDOWS_NUM; ++i) {
|
2013-09-15 22:38:38 +02:00
|
|
|
if (windows[i].onGroupMessage != NULL)
|
2014-10-03 23:53:50 +02:00
|
|
|
windows[i].onGroupMessage(&windows[i], m, groupnumber, peernumber, msg, length);
|
2013-09-15 22:38:38 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-07-02 23:30:31 +02:00
|
|
|
void on_groupaction(Tox *m, int groupnumber, int peernumber, const uint8_t *action, uint16_t length,
|
2013-12-14 02:57:32 +01:00
|
|
|
void *userdata)
|
|
|
|
{
|
2014-10-03 23:53:50 +02:00
|
|
|
char msg[MAX_STR_SIZE + 1];
|
|
|
|
length = copy_tox_str(msg, sizeof(msg), (const char *) action, length);
|
|
|
|
|
2013-12-14 02:57:32 +01:00
|
|
|
int i;
|
|
|
|
|
2014-03-18 03:18:04 +01:00
|
|
|
for (i = 0; i < MAX_WINDOWS_NUM; ++i) {
|
2013-12-14 02:57:32 +01:00
|
|
|
if (windows[i].onGroupAction != NULL)
|
2014-10-03 23:53:50 +02:00
|
|
|
windows[i].onGroupAction(&windows[i], m, groupnumber, peernumber, msg, length);
|
2013-12-14 02:57:32 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-09-28 04:50:20 +02:00
|
|
|
void on_groupinvite(Tox *m, int32_t friendnumber, const uint8_t *group_pub_key, uint16_t length, void *userdata)
|
2013-09-15 22:38:38 +02:00
|
|
|
{
|
|
|
|
int i;
|
|
|
|
|
2014-03-18 03:18:04 +01:00
|
|
|
for (i = 0; i < MAX_WINDOWS_NUM; ++i) {
|
2013-09-15 22:38:38 +02:00
|
|
|
if (windows[i].onGroupInvite != NULL)
|
2014-09-28 04:50:20 +02:00
|
|
|
windows[i].onGroupInvite(&windows[i], m, friendnumber, (const char *) group_pub_key, length);
|
2013-09-15 22:38:38 +02:00
|
|
|
}
|
|
|
|
}
|
2013-10-10 10:52:05 +02:00
|
|
|
|
2013-11-26 00:49:31 +01:00
|
|
|
void on_group_namelistchange(Tox *m, int groupnumber, int peernumber, uint8_t change, void *userdata)
|
2013-11-24 03:19:59 +01:00
|
|
|
{
|
|
|
|
int i;
|
|
|
|
|
2014-03-18 03:18:04 +01:00
|
|
|
for (i = 0; i < MAX_WINDOWS_NUM; ++i) {
|
2013-11-24 03:19:59 +01:00
|
|
|
if (windows[i].onGroupNamelistChange != NULL)
|
2013-11-26 00:49:31 +01:00
|
|
|
windows[i].onGroupNamelistChange(&windows[i], m, groupnumber, peernumber, change);
|
2013-11-24 03:19:59 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-04-19 23:58:13 +02:00
|
|
|
void on_file_sendrequest(Tox *m, int32_t friendnumber, uint8_t filenumber, uint64_t filesize,
|
2014-07-02 23:30:31 +02:00
|
|
|
const uint8_t *filename, uint16_t filename_length, void *userdata)
|
2013-10-10 10:52:05 +02:00
|
|
|
{
|
|
|
|
int i;
|
|
|
|
|
2014-03-18 03:18:04 +01:00
|
|
|
for (i = 0; i < MAX_WINDOWS_NUM; ++i) {
|
2013-10-10 10:52:05 +02:00
|
|
|
if (windows[i].onFileSendRequest != NULL)
|
|
|
|
windows[i].onFileSendRequest(&windows[i], m, friendnumber, filenumber, filesize,
|
2014-07-07 04:15:35 +02:00
|
|
|
(const char *) filename, filename_length);
|
2013-10-10 10:52:05 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-04-19 23:58:13 +02:00
|
|
|
void on_file_control (Tox *m, int32_t friendnumber, uint8_t receive_send, uint8_t filenumber,
|
2014-07-02 23:30:31 +02:00
|
|
|
uint8_t control_type, const uint8_t *data, uint16_t length, void *userdata)
|
2013-10-10 10:52:05 +02:00
|
|
|
{
|
|
|
|
int i;
|
|
|
|
|
2014-03-18 03:18:04 +01:00
|
|
|
for (i = 0; i < MAX_WINDOWS_NUM; ++i) {
|
2013-10-10 10:52:05 +02:00
|
|
|
if (windows[i].onFileControl != NULL)
|
|
|
|
windows[i].onFileControl(&windows[i], m, friendnumber, receive_send, filenumber,
|
2014-07-07 04:15:35 +02:00
|
|
|
control_type, (const char *) data, length);
|
2013-10-10 10:52:05 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-07-02 23:30:31 +02:00
|
|
|
void on_file_data(Tox *m, int32_t friendnumber, uint8_t filenumber, const uint8_t *data, uint16_t length,
|
2013-10-11 10:42:30 +02:00
|
|
|
void *userdata)
|
2013-10-10 10:52:05 +02:00
|
|
|
{
|
|
|
|
int i;
|
|
|
|
|
2014-03-18 03:18:04 +01:00
|
|
|
for (i = 0; i < MAX_WINDOWS_NUM; ++i) {
|
2013-10-10 10:52:05 +02:00
|
|
|
if (windows[i].onFileData != NULL)
|
2014-07-07 04:15:35 +02:00
|
|
|
windows[i].onFileData(&windows[i], m, friendnumber, filenumber, (const char *) data, length);
|
2013-10-10 10:52:05 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-09-07 08:43:53 +02:00
|
|
|
void on_read_receipt(Tox *m, int32_t friendnumber, uint32_t receipt, void *userdata)
|
|
|
|
{
|
|
|
|
int i;
|
|
|
|
|
|
|
|
for (i = 0; i < MAX_WINDOWS_NUM; ++i) {
|
|
|
|
if (windows[i].onReadReceipt != NULL)
|
|
|
|
windows[i].onReadReceipt(&windows[i], m, friendnumber, receipt);
|
|
|
|
}
|
|
|
|
}
|
2013-08-13 02:21:03 +02:00
|
|
|
/* CALLBACKS END */
|
|
|
|
|
2013-08-23 23:03:44 +02:00
|
|
|
int add_window(Tox *m, ToxWindow w)
|
2013-08-13 02:21:03 +02:00
|
|
|
{
|
2013-08-16 19:11:09 +02:00
|
|
|
if (LINES < 2)
|
|
|
|
return -1;
|
2013-08-21 01:37:05 +02:00
|
|
|
|
2013-08-17 10:00:19 +02:00
|
|
|
int i;
|
2013-08-21 01:37:05 +02:00
|
|
|
|
|
|
|
for (i = 0; i < MAX_WINDOWS_NUM; i++) {
|
2013-11-30 11:35:25 +01:00
|
|
|
if (windows[i].active)
|
2013-08-17 10:00:19 +02:00
|
|
|
continue;
|
2013-08-21 01:37:05 +02:00
|
|
|
|
2013-08-17 10:00:19 +02:00
|
|
|
w.window = newwin(LINES - 2, COLS, 0, 0);
|
2013-08-21 01:37:05 +02:00
|
|
|
|
2013-08-17 10:00:19 +02:00
|
|
|
if (w.window == NULL)
|
|
|
|
return -1;
|
2014-04-19 23:58:13 +02:00
|
|
|
|
2013-09-26 15:51:21 +02:00
|
|
|
#ifdef URXVT_FIX
|
|
|
|
/* Fixes text color problem on some terminals. */
|
|
|
|
wbkgd(w.window, COLOR_PAIR(6));
|
|
|
|
#endif
|
2013-08-17 10:00:19 +02:00
|
|
|
windows[i] = w;
|
2014-03-19 08:14:08 +01:00
|
|
|
|
|
|
|
if (w.onInit)
|
|
|
|
w.onInit(&w, m);
|
2013-08-21 01:37:05 +02:00
|
|
|
|
2014-03-07 01:39:57 +01:00
|
|
|
++num_active_windows;
|
|
|
|
|
2013-08-17 10:00:19 +02:00
|
|
|
return i;
|
|
|
|
}
|
2013-08-21 01:37:05 +02:00
|
|
|
|
2013-08-17 10:00:19 +02:00
|
|
|
return -1;
|
2013-08-13 02:21:03 +02:00
|
|
|
}
|
|
|
|
|
2014-07-09 01:24:44 +02:00
|
|
|
void set_active_window(int index)
|
2013-08-13 02:21:03 +02:00
|
|
|
{
|
2014-07-09 01:24:44 +02:00
|
|
|
if (index < 0 || index >= MAX_WINDOWS_NUM)
|
|
|
|
return;
|
2013-08-31 02:13:29 +02:00
|
|
|
|
2014-07-09 01:24:44 +02:00
|
|
|
active_window = windows + index;
|
2013-08-13 02:21:03 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/* Shows next window when tab or back-tab is pressed */
|
2013-12-07 04:07:37 +01:00
|
|
|
void set_next_window(int ch)
|
2013-08-13 02:21:03 +02:00
|
|
|
{
|
2013-08-21 01:37:05 +02:00
|
|
|
ToxWindow *end = windows + MAX_WINDOWS_NUM - 1;
|
2013-08-17 10:00:19 +02:00
|
|
|
ToxWindow *inf = active_window;
|
2013-08-21 01:37:05 +02:00
|
|
|
|
|
|
|
while (true) {
|
2014-09-23 03:24:45 +02:00
|
|
|
if (ch == user_settings->key_next_tab) {
|
2013-08-17 10:00:19 +02:00
|
|
|
if (++active_window > end)
|
|
|
|
active_window = windows;
|
2013-08-21 01:37:05 +02:00
|
|
|
} else if (--active_window < windows)
|
|
|
|
active_window = end;
|
|
|
|
|
2013-08-17 10:00:19 +02:00
|
|
|
if (active_window->window)
|
|
|
|
return;
|
2013-08-21 01:37:05 +02:00
|
|
|
|
2014-06-18 21:54:05 +02:00
|
|
|
if (active_window == inf) /* infinite loop check */
|
|
|
|
exit_toxic_err("failed in set_next_window", FATALERR_INFLOOP);
|
2013-08-13 02:21:03 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-07-09 01:24:44 +02:00
|
|
|
/* Deletes window w and cleans up */
|
|
|
|
void del_window(ToxWindow *w)
|
2013-08-13 02:21:03 +02:00
|
|
|
{
|
2014-07-09 01:24:44 +02:00
|
|
|
set_active_window(0); /* Go to prompt screen */
|
2013-08-21 01:37:05 +02:00
|
|
|
|
2014-07-09 01:24:44 +02:00
|
|
|
delwin(w->window);
|
|
|
|
memset(w, 0, sizeof(ToxWindow));
|
|
|
|
|
|
|
|
clear();
|
|
|
|
refresh();
|
|
|
|
--num_active_windows;
|
2013-08-13 02:21:03 +02:00
|
|
|
}
|
|
|
|
|
2013-11-30 11:35:25 +01:00
|
|
|
ToxWindow *init_windows(Tox *m)
|
2013-08-13 02:21:03 +02:00
|
|
|
{
|
2013-08-17 16:05:32 +02:00
|
|
|
int n_prompt = add_window(m, new_prompt());
|
2013-08-21 01:37:05 +02:00
|
|
|
|
2014-06-18 21:54:05 +02:00
|
|
|
if (n_prompt == -1 || add_window(m, new_friendlist()) == -1)
|
|
|
|
exit_toxic_err("failed in init_windows", FATALERR_WININIT);
|
2013-08-16 19:11:09 +02:00
|
|
|
|
|
|
|
prompt = &windows[n_prompt];
|
2013-08-17 10:00:19 +02:00
|
|
|
active_window = prompt;
|
2013-08-21 01:37:05 +02:00
|
|
|
|
2013-08-16 19:11:09 +02:00
|
|
|
return prompt;
|
2013-08-13 02:21:03 +02:00
|
|
|
}
|
|
|
|
|
2014-07-01 05:56:47 +02:00
|
|
|
void on_window_resize(void)
|
2014-06-13 07:42:20 +02:00
|
|
|
{
|
2014-06-29 00:40:22 +02:00
|
|
|
endwin();
|
2014-06-13 07:42:20 +02:00
|
|
|
refresh();
|
|
|
|
clear();
|
2014-07-01 05:56:47 +02:00
|
|
|
|
2014-07-02 01:39:25 +02:00
|
|
|
/* equivalent to LINES and COLS */
|
|
|
|
int x2, y2;
|
|
|
|
getmaxyx(stdscr, y2, x2);
|
|
|
|
y2 -= 2;
|
|
|
|
|
2014-07-01 05:56:47 +02:00
|
|
|
int i;
|
|
|
|
|
2014-07-07 04:15:35 +02:00
|
|
|
for (i = 0; i < MAX_WINDOWS_NUM; ++i) {
|
2014-07-01 07:17:31 +02:00
|
|
|
if (!windows[i].active)
|
2014-07-01 05:56:47 +02:00
|
|
|
continue;
|
|
|
|
|
|
|
|
ToxWindow *w = &windows[i];
|
2014-07-01 07:17:31 +02:00
|
|
|
|
2014-07-10 04:11:31 +02:00
|
|
|
if (windows[i].is_friendlist) {
|
|
|
|
delwin(w->window);
|
|
|
|
w->window = newwin(y2, x2, 0, 0);
|
2014-07-02 01:39:25 +02:00
|
|
|
continue;
|
2014-07-10 04:11:31 +02:00
|
|
|
}
|
2014-07-02 01:39:25 +02:00
|
|
|
|
2014-07-05 20:46:16 +02:00
|
|
|
if (w->help->active)
|
|
|
|
wclear(w->help->win);
|
|
|
|
|
2014-07-01 20:55:59 +02:00
|
|
|
if (w->is_groupchat)
|
|
|
|
delwin(w->chatwin->sidebar);
|
|
|
|
else
|
|
|
|
delwin(w->stb->topline);
|
|
|
|
|
|
|
|
delwin(w->chatwin->linewin);
|
|
|
|
delwin(w->chatwin->history);
|
2014-07-10 04:11:31 +02:00
|
|
|
delwin(w->window);
|
2014-07-01 20:55:59 +02:00
|
|
|
|
2014-07-10 04:11:31 +02:00
|
|
|
w->window = newwin(y2, x2, 0, 0);
|
2014-07-01 20:55:59 +02:00
|
|
|
w->chatwin->linewin = subwin(w->window, CHATBOX_HEIGHT, x2, y2 - CHATBOX_HEIGHT, 0);
|
2014-07-01 05:56:47 +02:00
|
|
|
|
|
|
|
if (w->is_groupchat) {
|
2014-07-01 20:55:59 +02:00
|
|
|
w->chatwin->history = subwin(w->window, y2 - CHATBOX_HEIGHT + 1, x2 - SIDEBAR_WIDTH - 1, 0, 0);
|
|
|
|
w->chatwin->sidebar = subwin(w->window, y2 - CHATBOX_HEIGHT + 1, SIDEBAR_WIDTH, 0, x2 - SIDEBAR_WIDTH);
|
2014-07-01 05:56:47 +02:00
|
|
|
} else {
|
2014-07-01 20:55:59 +02:00
|
|
|
w->chatwin->history = subwin(w->window, y2 - CHATBOX_HEIGHT + 1, x2, 0, 0);
|
2014-07-01 05:56:47 +02:00
|
|
|
w->stb->topline = subwin(w->window, 2, x2, 0, 0);
|
|
|
|
}
|
|
|
|
|
2014-09-23 03:24:45 +02:00
|
|
|
#ifdef AUDIO
|
2014-07-01 20:55:59 +02:00
|
|
|
if (w->chatwin->infobox.active) {
|
|
|
|
delwin(w->chatwin->infobox.win);
|
|
|
|
w->chatwin->infobox.win = newwin(INFOBOX_HEIGHT, INFOBOX_WIDTH + 1, 1, x2 - INFOBOX_WIDTH);
|
2014-07-01 17:17:52 +02:00
|
|
|
}
|
2014-09-23 03:24:45 +02:00
|
|
|
#endif /* AUDIO */
|
2014-07-01 17:17:52 +02:00
|
|
|
|
2014-07-01 20:55:59 +02:00
|
|
|
scrollok(w->chatwin->history, 0);
|
2014-07-01 05:56:47 +02:00
|
|
|
}
|
2014-06-13 07:42:20 +02:00
|
|
|
}
|
|
|
|
|
2014-08-08 01:53:47 +02:00
|
|
|
static void draw_window_tab(ToxWindow *toxwin)
|
2013-11-29 01:45:28 +01:00
|
|
|
{
|
2014-08-08 01:53:47 +02:00
|
|
|
if (toxwin->alert != WINDOW_ALERT_NONE) attron(COLOR_PAIR(toxwin->alert));
|
2013-11-29 01:45:28 +01:00
|
|
|
clrtoeol();
|
2014-08-08 01:53:47 +02:00
|
|
|
printw(" [%s]", toxwin->name);
|
|
|
|
if (toxwin->alert != WINDOW_ALERT_NONE) attroff(COLOR_PAIR(toxwin->alert));
|
2013-11-29 01:45:28 +01:00
|
|
|
}
|
2013-11-26 23:39:11 +01:00
|
|
|
|
2013-11-24 03:19:59 +01:00
|
|
|
static void draw_bar(void)
|
2013-08-13 02:21:03 +02:00
|
|
|
{
|
2013-09-05 06:47:33 +02:00
|
|
|
attron(COLOR_PAIR(BLUE));
|
2013-08-16 19:11:09 +02:00
|
|
|
mvhline(LINES - 2, 0, '_', COLS);
|
2013-09-05 06:47:33 +02:00
|
|
|
attroff(COLOR_PAIR(BLUE));
|
2013-08-16 19:11:09 +02:00
|
|
|
|
|
|
|
move(LINES - 1, 0);
|
|
|
|
|
2013-09-05 06:47:33 +02:00
|
|
|
attron(COLOR_PAIR(BLUE) | A_BOLD);
|
2013-08-31 08:22:07 +02:00
|
|
|
printw(" TOXIC " TOXICVER " |");
|
2013-09-05 06:47:33 +02:00
|
|
|
attroff(COLOR_PAIR(BLUE) | A_BOLD);
|
2013-08-13 02:21:03 +02:00
|
|
|
|
2013-08-16 19:11:09 +02:00
|
|
|
int i;
|
2013-08-13 02:21:03 +02:00
|
|
|
|
2013-08-28 11:46:09 +02:00
|
|
|
for (i = 0; i < MAX_WINDOWS_NUM; ++i) {
|
2014-06-12 00:47:18 +02:00
|
|
|
if (!windows[i].active)
|
|
|
|
continue;
|
|
|
|
|
|
|
|
if (windows + i == active_window)
|
|
|
|
|
2013-09-26 15:51:21 +02:00
|
|
|
#ifdef URXVT_FIX
|
2014-06-12 00:47:18 +02:00
|
|
|
attron(A_BOLD | COLOR_PAIR(GREEN));
|
|
|
|
else
|
2013-09-26 15:51:21 +02:00
|
|
|
#endif
|
2013-08-13 02:21:03 +02:00
|
|
|
|
2014-06-12 00:47:18 +02:00
|
|
|
attron(A_BOLD);
|
|
|
|
|
2014-08-08 01:53:47 +02:00
|
|
|
draw_window_tab(&windows[i]);
|
2014-06-12 00:47:18 +02:00
|
|
|
|
|
|
|
if (windows + i == active_window)
|
2013-08-13 02:21:03 +02:00
|
|
|
|
2013-09-26 15:51:21 +02:00
|
|
|
#ifdef URXVT_FIX
|
2014-06-12 00:47:18 +02:00
|
|
|
attroff(A_BOLD | COLOR_PAIR(GREEN));
|
|
|
|
else
|
2013-09-26 15:51:21 +02:00
|
|
|
#endif
|
2014-06-12 00:47:18 +02:00
|
|
|
|
|
|
|
attroff(A_BOLD);
|
2013-08-13 02:21:03 +02:00
|
|
|
}
|
2013-08-16 19:11:09 +02:00
|
|
|
|
|
|
|
refresh();
|
2013-08-13 02:21:03 +02:00
|
|
|
}
|
|
|
|
|
2013-08-23 23:03:44 +02:00
|
|
|
void draw_active_window(Tox *m)
|
2013-08-13 02:21:03 +02:00
|
|
|
{
|
2013-08-17 10:00:19 +02:00
|
|
|
ToxWindow *a = active_window;
|
2014-07-21 01:12:13 +02:00
|
|
|
a->alert = WINDOW_ALERT_NONE;
|
2013-12-04 07:08:26 +01:00
|
|
|
|
2013-08-21 23:19:35 +02:00
|
|
|
wint_t ch = 0;
|
|
|
|
|
2013-12-04 07:08:26 +01:00
|
|
|
draw_bar();
|
|
|
|
|
2013-09-27 22:14:43 +02:00
|
|
|
touchwin(a->window);
|
2014-03-09 07:02:54 +01:00
|
|
|
a->onDraw(a, m);
|
2013-08-16 19:11:09 +02:00
|
|
|
|
|
|
|
/* Handle input */
|
2014-03-30 22:40:13 +02:00
|
|
|
bool ltr;
|
2013-08-22 22:57:34 +02:00
|
|
|
#ifdef HAVE_WIDECHAR
|
2014-03-30 22:40:13 +02:00
|
|
|
int status = wget_wch(stdscr, &ch);
|
2014-03-30 22:42:27 +02:00
|
|
|
|
|
|
|
if (status == ERR)
|
|
|
|
return;
|
|
|
|
|
2014-03-30 22:40:13 +02:00
|
|
|
if (status == OK)
|
2014-03-30 22:42:27 +02:00
|
|
|
ltr = iswprint(ch);
|
|
|
|
else /* if (status == KEY_CODE_YES) */
|
2014-03-30 22:40:13 +02:00
|
|
|
ltr = false;
|
2014-04-19 23:58:13 +02:00
|
|
|
|
2013-08-22 22:57:34 +02:00
|
|
|
#else
|
2014-03-30 22:40:13 +02:00
|
|
|
ch = getch();
|
|
|
|
|
|
|
|
if (ch == ERR)
|
2014-03-17 01:18:31 +01:00
|
|
|
return;
|
2013-08-16 19:11:09 +02:00
|
|
|
|
2014-03-30 22:40:13 +02:00
|
|
|
/* TODO verify if this works */
|
|
|
|
ltr = isprint(ch);
|
2014-06-29 00:40:22 +02:00
|
|
|
#endif /* HAVE_WIDECHAR */
|
2014-03-30 22:40:13 +02:00
|
|
|
|
2014-09-23 03:24:45 +02:00
|
|
|
if (!ltr && (ch == user_settings->key_next_tab || ch == user_settings->key_prev_tab)) {
|
2013-12-07 04:07:37 +01:00
|
|
|
set_next_window((int) ch);
|
2014-03-17 01:18:31 +01:00
|
|
|
} else {
|
2014-03-13 11:06:53 +01:00
|
|
|
pthread_mutex_lock(&Winthread.lock);
|
2014-03-30 22:40:13 +02:00
|
|
|
a->onKey(a, m, ch, ltr);
|
2014-03-13 11:06:53 +01:00
|
|
|
pthread_mutex_unlock(&Winthread.lock);
|
|
|
|
}
|
2013-08-13 02:21:03 +02:00
|
|
|
}
|
2013-11-30 11:35:25 +01:00
|
|
|
|
2014-06-01 09:38:20 +02:00
|
|
|
/* refresh inactive windows to prevent scrolling bugs.
|
|
|
|
call at least once per second */
|
|
|
|
void refresh_inactive_windows(void)
|
|
|
|
{
|
|
|
|
int i;
|
|
|
|
|
|
|
|
for (i = 0; i < MAX_WINDOWS_NUM; ++i) {
|
|
|
|
ToxWindow *a = &windows[i];
|
|
|
|
|
2014-06-29 00:40:22 +02:00
|
|
|
if (a->active && a != active_window && !a->is_friendlist)
|
2014-06-01 18:54:45 +02:00
|
|
|
line_info_print(a);
|
2014-06-01 09:38:20 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-08-01 03:59:53 +02:00
|
|
|
/* returns a pointer to the ToxWindow in the ith index. Returns NULL if no ToxWindow exists */
|
|
|
|
ToxWindow *get_window_ptr(int i)
|
|
|
|
{
|
|
|
|
ToxWindow *toxwin = NULL;
|
|
|
|
|
2014-08-17 05:23:03 +02:00
|
|
|
if (i >= 0 && i <= MAX_WINDOWS_NUM && windows[i].active)
|
2014-08-01 03:59:53 +02:00
|
|
|
toxwin = &windows[i];
|
|
|
|
|
|
|
|
return toxwin;
|
|
|
|
}
|
|
|
|
|
2014-10-01 22:24:36 +02:00
|
|
|
void force_refresh(WINDOW *w)
|
|
|
|
{
|
|
|
|
wclear(w);
|
|
|
|
endwin();
|
|
|
|
refresh();
|
|
|
|
}
|
|
|
|
|
2014-03-07 01:39:57 +01:00
|
|
|
int get_num_active_windows(void)
|
2013-11-30 11:35:25 +01:00
|
|
|
{
|
2014-03-07 01:39:57 +01:00
|
|
|
return num_active_windows;
|
2013-11-30 22:09:45 +01:00
|
|
|
}
|
2014-02-26 11:23:11 +01:00
|
|
|
|
|
|
|
/* destroys all chat and groupchat windows (should only be called on shutdown) */
|
2014-08-05 23:38:33 +02:00
|
|
|
void kill_all_windows(Tox *m)
|
2014-02-26 11:23:11 +01:00
|
|
|
{
|
|
|
|
int i;
|
|
|
|
|
|
|
|
for (i = 0; i < MAX_WINDOWS_NUM; ++i) {
|
|
|
|
if (windows[i].is_chat)
|
2014-08-05 23:38:33 +02:00
|
|
|
kill_chat_window(&windows[i], m);
|
2014-02-26 11:23:11 +01:00
|
|
|
else if (windows[i].is_groupchat)
|
|
|
|
kill_groupchat_window(&windows[i]);
|
|
|
|
}
|
2014-08-08 01:24:56 +02:00
|
|
|
|
|
|
|
kill_prompt_window(prompt);
|
|
|
|
kill_friendlist();
|
2014-02-26 11:23:11 +01:00
|
|
|
}
|