/****************************************************************************** * This file is part of TinTin++ * * * * Copyright 2004-2019 Igor van den Hoven * * * * TinTin++ 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. * * * * 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 TinTin++. If not, see https://www.gnu.org/licenses. * ******************************************************************************/ /****************************************************************************** * (T)he K(I)cki(N) (T)ickin D(I)kumud Clie(N)t * * * * coded by Igor van den Hoven 2007 * ******************************************************************************/ #include "tintin.h" DO_COMMAND(do_event) { char arg1[BUFFER_SIZE], arg2[BUFFER_SIZE]; int cnt; arg = sub_arg_in_braces(ses, arg, arg1, GET_ONE, SUB_VAR|SUB_FUN); arg = get_arg_in_braces(ses, arg, arg2, GET_ALL); if (*arg1 == 0) { tintin_header(ses, " EVENTS "); for (cnt = 0 ; *event_table[cnt].name != 0 ; cnt++) { tintin_printf2(ses, "%s [%-27s] %s", search_node_list(ses->list[LIST_EVENT], event_table[cnt].name) ? "+" : " ", event_table[cnt].name, event_table[cnt].desc); } tintin_header(ses, ""); } else if (*arg2 == 0) { if (show_node_with_wild(ses, arg1, ses->list[LIST_EVENT]) == FALSE) { show_message(ses, LIST_ALIAS, "#EVENT: NO MATCH(ES) FOUND FOR {%s}.", arg1); } } else { for (cnt = 0 ; *event_table[cnt].name != 0 ; cnt++) { if (!strncmp(event_table[cnt].name, arg1, strlen(event_table[cnt].name))) { show_message(ses, LIST_EVENT, "#EVENT {%s} HAS BEEN SET TO {%s}.", arg1, arg2); update_node_list(ses->list[LIST_EVENT], arg1, arg2, "", ""); return ses; } } show_error(ses, LIST_EVENT, "#EVENT {%s} IS NOT AN EXISTING EVENT.", arg1); } return ses; } DO_COMMAND(do_unevent) { delete_node_with_wild(ses, LIST_EVENT, arg); return ses; } int check_all_events(struct session *ses, int flags, int args, int vars, char *fmt, ...) { struct session *ses_ptr; struct listnode *node; char name[BUFFER_SIZE], buf[BUFFER_SIZE]; va_list list; int cnt; if (gtd->ignore_level) { return 0; } if (args) { va_start(list, fmt); vsprintf(name, fmt, list); va_end(list); } else { strcpy(name, fmt); } push_call("check_all_events(%p,%d,%d,%d,%s, ...)",ses,flags,args,vars,name); for (ses_ptr = ses ? ses : gts ; ses_ptr ; ses_ptr = ses_ptr->next) { if (!HAS_BIT(ses_ptr->list[LIST_EVENT]->flags, LIST_FLAG_IGNORE)) { show_info(ses_ptr, LIST_EVENT, "#INFO EVENT {%s}", name); node = search_node_list(ses_ptr->list[LIST_EVENT], name); if (node) { if (vars) { va_start(list, fmt); for (cnt = 0 ; cnt < args ; cnt++) { va_arg(list, char *); } for (cnt = 0 ; cnt < vars ; cnt++) { RESTRING(gtd->vars[cnt], va_arg(list, char *)); } va_end(list); } substitute(ses_ptr, node->arg2, buf, flags); if (HAS_BIT(ses_ptr->list[LIST_EVENT]->flags, LIST_FLAG_DEBUG)) { show_debug(ses_ptr, LIST_ACTION, "#DEBUG EVENT {%s} (%s}", node->arg1, node->arg2); } script_driver(ses_ptr, LIST_EVENT, buf); if (ses) { pop_call(); return 1; } } } if (ses) { pop_call(); return 0; } } pop_call(); return 0; } void mouse_handler(struct session *ses, int flags, int row, int col, char type) { char arg1[BUFFER_SIZE], arg2[BUFFER_SIZE], line[BUFFER_SIZE], word[BUFFER_SIZE]; static char last[100]; static long long click[3]; if (HAS_BIT(flags, MOUSE_FLAG_MOTION)) { strcpy(arg1, "MOVED"); } else { switch (type) { case 'M': if (HAS_BIT(flags, MOUSE_FLAG_WHEEL)) { strcpy(arg1, "SCROLLED"); } else { strcpy(arg1, "PRESSED"); } break; case 'm': strcpy(arg1, "RELEASED"); break; default: strcpy(arg1, "UNKNOWN"); break; } } arg2[0] = 0; if (HAS_BIT(flags, MOUSE_FLAG_CTRL)) { strcat(arg2, "CTRL "); } if (HAS_BIT(flags, MOUSE_FLAG_ALT)) { strcat(arg2, "ALT "); } if (HAS_BIT(flags, MOUSE_FLAG_SHIFT)) { strcat(arg2, "SHIFT "); } if (HAS_BIT(flags, MOUSE_FLAG_EXTRA)) { strcat(arg2, "EXTRA "); } if (HAS_BIT(flags, MOUSE_FLAG_UNKNOWN)) { strcat(arg2, "256 "); } if (HAS_BIT(flags, MOUSE_FLAG_WHEEL)) { strcat(arg2, "MOUSE WHEEL "); } else { strcat(arg2, "MOUSE BUTTON "); } if (row-1 < 0) { tintin_printf2(ses, "weird error (row,col) (%d,%d)", row, col); return; } else if (row - 1 > gtd->screen->rows) { tintin_printf2(ses, "weird error (row,col) (%d,%d)", row, col); return; } else { strcpy(line, "under development"); strcpy(word, "under development"); // get_line_screen(line, row - 1); // get_word_screen(word, row - 1, col - 1); } if (HAS_BIT(flags, MOUSE_FLAG_WHEEL)) { if (HAS_BIT(flags, MOUSE_FLAG_BUTTON_A) && HAS_BIT(flags, MOUSE_FLAG_BUTTON_B)) { strcat(arg2, "FOUR"); } else if (HAS_BIT(flags, MOUSE_FLAG_BUTTON_B)) { strcat(arg2, "THREE"); } else if (HAS_BIT(flags, MOUSE_FLAG_BUTTON_A)) { strcat(arg2, "DOWN"); } else { strcat(arg2, "UP"); } } else { if (HAS_BIT(flags, MOUSE_FLAG_BUTTON_A) && HAS_BIT(flags, MOUSE_FLAG_BUTTON_B)) { strcat(arg2, "FOUR"); } else if (HAS_BIT(flags, MOUSE_FLAG_BUTTON_B)) { strcat(arg2, "THREE"); } else if (HAS_BIT(flags, MOUSE_FLAG_BUTTON_A)) { strcat(arg2, "TWO"); } else { strcat(arg2, "ONE"); } } check_all_buttons(ses, row, col, arg1, arg2, word, line); check_all_events(ses, SUB_ARG, 2, 6, "%s %s", arg1, arg2, ntos(row), ntos(col), ntos(-1 - (gtd->screen->rows - row)), ntos(-1 - (gtd->screen->cols - col)), word, line); check_all_events(ses, SUB_ARG, 3, 6, "%s %s %d", arg1, arg2, row, ntos(row), ntos(col), ntos(-1 - (gtd->screen->rows - row)), ntos(-1 - (gtd->screen->cols - col)), word, line); check_all_events(ses, SUB_ARG, 3, 6, "%s %s %d", arg1, arg2, -1 - (gtd->screen->rows - row), ntos(row), ntos(col), ntos(-1 - (gtd->screen->rows - row)), ntos(-1 - (gtd->screen->cols - col)), word, line); map_mouse_handler(ses, arg1, arg2, col, row); if (!strcmp(arg1, "PRESSED")) { sprintf(arg1, "PRESSED %s %d %d", arg2, col, row); if (!strcmp(arg1, last)) { click[2] = click[1]; click[1] = click[0]; click[0] = utime(); if (click[0] - click[1] < 500000) { if (click[0] - click[2] < 500000) { check_all_buttons(ses, row, col, "TRIPLE-CLICKED", arg2, word, line); check_all_events(ses, SUB_ARG, 1, 6, "TRIPLE-CLICKED %s", arg2, ntos(row), ntos(col), ntos(-1 - (gtd->screen->rows - row)), ntos(-1 - (gtd->screen->cols - col)), word, line); check_all_events(ses, SUB_ARG, 2, 6, "TRIPLE-CLICKED %s %d", arg2, row, ntos(row), ntos(col), ntos(-1 - (gtd->screen->rows - row)), ntos(-1 - (gtd->screen->cols - col)), word, line); check_all_events(ses, SUB_ARG, 2, 6, "TRIPLE-CLICKED %s %d", arg2, -1 - (gtd->screen->rows - row), ntos(row), ntos(col), ntos(-1 - (gtd->screen->rows - row)), ntos(-1 - (gtd->screen->cols - col)), word, line); map_mouse_handler(ses, "TRIPPLE-CLICKED", arg2, col, row); strcpy(last, ""); } else { check_all_buttons(ses, row, col, "DOUBLE-CLICKED", arg2, word, line); check_all_events(ses, SUB_ARG, 1, 6, "DOUBLE-CLICKED %s", arg2, ntos(row), ntos(col), ntos(-1 - (gtd->screen->rows - row)), ntos(-1 - (gtd->screen->cols - col)), word, line); check_all_events(ses, SUB_ARG, 2, 6, "DOUBLE-CLICKED %s %d", arg2, row, ntos(row), ntos(col), ntos(-1 - (gtd->screen->rows - row)), ntos(-1 - (gtd->screen->cols - col)), word, line); check_all_events(ses, SUB_ARG, 2, 6, "DOUBLE-CLICKED %s %d", arg2, -1 - (gtd->screen->rows - row), ntos(row), ntos(col), ntos(-1 - (gtd->screen->rows - row)), ntos(-1 - (gtd->screen->cols - col)), word, line); map_mouse_handler(ses, "DOUBLE-CLICKED", arg2, col, row); } } } else { click[2] = 0; click[1] = 0; click[0] = utime(); sprintf(last, "PRESSED %s %d %d", arg2, col, row); } } else if (!strcmp(arg1, "RELEASED")) { if (utime() - click[0] >= 500000) { check_all_buttons(ses, row, col, "LONG-CLICKED", arg2, word, line); check_all_events(ses, SUB_ARG, 1, 6, "LONG-CLICKED %s", arg2, ntos(row), ntos(col), ntos(-1 - (gtd->screen->rows - row)), ntos(-1 - (gtd->screen->cols - col)), word, line); check_all_events(ses, SUB_ARG, 2, 6, "LONG-CLICKED %s %d", arg2, row, ntos(row), ntos(col), ntos(-1 - (gtd->screen->rows - row)), ntos(-1 - (gtd->screen->cols - col)), word, line); check_all_events(ses, SUB_ARG, 2, 6, "LONG-CLICKED %s %d", arg2, -1 - (gtd->screen->rows - row), ntos(row), ntos(col), ntos(-1 - (gtd->screen->rows - row)), ntos(-1 - (gtd->screen->cols - col)), word, line); map_mouse_handler(ses, "LONG-CLICKED", arg2, col, row); } else if (click[0] - click[1] >= 500000) { check_all_buttons(ses, row, col, "SHORT-CLICKED", arg2, word, line); check_all_events(ses, SUB_ARG, 1, 6, "SHORT-CLICKED %s", arg2, ntos(row), ntos(col), ntos(-1 - (gtd->screen->rows - row)), ntos(-1 - (gtd->screen->cols - col)), word, line); check_all_events(ses, SUB_ARG, 2, 6, "SHORT-CLICKED %s %d", arg2, row, ntos(row), ntos(col), ntos(-1 - (gtd->screen->rows - row)), ntos(-1 - (gtd->screen->cols - col)), word, line); check_all_events(ses, SUB_ARG, 2, 6, "SHORT-CLICKED %s %d", arg2, -1 - (gtd->screen->rows - row), ntos(row), ntos(col), ntos(-1 - (gtd->screen->rows - row)), ntos(-1 - (gtd->screen->cols - col)), word, line); map_mouse_handler(ses, "SHORT-CLICKED", arg2, col, row); } } return; }