mirror of
				https://github.com/Tha14/toxic.git
				synced 2025-10-26 15:26:47 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			196 lines
		
	
	
		
			4.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			196 lines
		
	
	
		
			4.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * Toxic -- Tox Curses Client
 | |
|  */
 | |
| 
 | |
| #include <stdlib.h>
 | |
| #include <string.h>
 | |
| #include <time.h>
 | |
| #include <limits.h>
 | |
| 
 | |
| #include "toxic_windows.h"
 | |
| 
 | |
| extern ToxWindow *prompt;
 | |
| 
 | |
| // XXX: FIX
 | |
| unsigned char *hex_string_to_bin(char hex_string[])
 | |
| {
 | |
|     size_t len = strlen(hex_string);
 | |
|     unsigned char *val = malloc(len);
 | |
| 
 | |
|     if (val == NULL) {
 | |
|         endwin();
 | |
|         fprintf(stderr, "malloc() failed. Aborting...\n");
 | |
|         exit(EXIT_FAILURE);
 | |
|     }
 | |
| 
 | |
|     char *pos = hex_string;
 | |
|     size_t i;
 | |
| 
 | |
|     for (i = 0; i < len; ++i, pos += 2)
 | |
|         sscanf(pos, "%2hhx", &val[i]);
 | |
| 
 | |
|     return val;
 | |
| }
 | |
| 
 | |
| /* Get the current local time */
 | |
| struct tm *get_time(void)
 | |
| {
 | |
|     struct tm *timeinfo;
 | |
|     time_t now;
 | |
|     time(&now);
 | |
|     timeinfo = localtime(&now);
 | |
|     return timeinfo;
 | |
| }
 | |
| 
 | |
| /* Prints the time to given window */
 | |
| void print_time(WINDOW *window)
 | |
| {
 | |
|     struct tm *timeinfo = get_time();
 | |
| 
 | |
|     wattron(window, COLOR_PAIR(BLUE));
 | |
|     wprintw(window, "[%02d:%02d:%02d] ", timeinfo->tm_hour, timeinfo->tm_min, timeinfo->tm_sec);
 | |
|     wattroff(window,COLOR_PAIR(BLUE));
 | |
| }
 | |
| 
 | |
| /* Returns 1 if the string is empty, 0 otherwise */
 | |
| int string_is_empty(char *string)
 | |
| {
 | |
|     return string[0] == '\0';
 | |
| }
 | |
| 
 | |
| /* convert a multibyte string to a wide character string (must provide buffer) */
 | |
| int mbs_to_wcs_buf(wchar_t *buf, const uint8_t *string, size_t n)
 | |
| {
 | |
|     size_t len = mbstowcs(NULL, string, 0) + 1;
 | |
| 
 | |
|     if (n < len)
 | |
|         return -1;
 | |
| 
 | |
|     if ((len = mbstowcs(buf, string, n)) == (size_t) -1)
 | |
|         return -1;
 | |
| 
 | |
|     return len;
 | |
| }
 | |
| 
 | |
| /* converts wide character string into a multibyte string.
 | |
|    Same thing as wcs_to_mbs() but caller must provide its own buffer */
 | |
| int wcs_to_mbs_buf(uint8_t *buf, const wchar_t *string, size_t n)
 | |
| {
 | |
|     size_t len = wcstombs(NULL, string, 0) + 1;
 | |
| 
 | |
|     if (n < len)
 | |
|         return -1;
 | |
| 
 | |
|     if ((len = wcstombs(buf, string, n)) == (size_t) -1)
 | |
|         return -1;
 | |
| 
 | |
|     return len;
 | |
| }
 | |
| 
 | |
| /* convert wide characters to multibyte string: string returned must be free'd */
 | |
| uint8_t *wcs_to_mbs(wchar_t *string)
 | |
| {
 | |
|     uint8_t *ret = NULL;
 | |
|     size_t len = wcstombs(NULL, string, 0);
 | |
| 
 | |
|     if (len != (size_t) -1) {
 | |
|         ret = malloc(++len);
 | |
| 
 | |
|         if (ret != NULL) {
 | |
|             if (wcstombs(ret, string, len) == (size_t) -1)
 | |
|                 return NULL;
 | |
|         }
 | |
|     } else {
 | |
|         ret = malloc(2);
 | |
| 
 | |
|         if (ret != NULL) {
 | |
|             ret[0] = ' ';
 | |
|             ret[1] = '\0';
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     if (ret == NULL) {
 | |
|         endwin();
 | |
|         fprintf(stderr, "malloc() failed. Aborting...\n");
 | |
|         exit(EXIT_FAILURE);
 | |
|     }
 | |
| 
 | |
|     return ret;
 | |
| }
 | |
| 
 | |
| /* convert a wide char to multibyte string */
 | |
| char *wc_to_char(wchar_t ch)
 | |
| {
 | |
|     static char ret[MB_LEN_MAX + 1];
 | |
|     int len = wctomb(ret, ch);
 | |
| 
 | |
|     if (len == -1) {
 | |
|         ret[0] = ' ';
 | |
|         ret[1] = '\0';
 | |
|     } else {
 | |
|         ret[len] = '\0';
 | |
|     }
 | |
| 
 | |
|     return ret;
 | |
| }
 | |
| 
 | |
| /* Returns true if connection has timed out, false otherwise */
 | |
| bool timed_out(uint64_t timestamp, uint64_t curtime, uint64_t timeout)
 | |
| {
 | |
|     return timestamp + timeout <= curtime;
 | |
| }
 | |
| 
 | |
| /* Colours the window tab according to type. Beeps if is_beep is true */
 | |
| void alert_window(ToxWindow *self, int type, bool is_beep)
 | |
| {
 | |
|     switch (type) {
 | |
|     case WINDOW_ALERT_0:
 | |
|         self->alert0 = true;
 | |
|         break;
 | |
|     case WINDOW_ALERT_1:
 | |
|         self->alert1 = true;
 | |
|         break;
 | |
|     case WINDOW_ALERT_2:
 | |
|         self->alert2 = true;
 | |
|         break;
 | |
|     }
 | |
| 
 | |
|     StatusBar *stb = prompt->stb;
 | |
| 
 | |
|     if (is_beep && stb->status != TOX_USERSTATUS_BUSY)
 | |
|         beep();
 | |
| }
 | |
| 
 | |
| /* case-insensitive string compare function for use with qsort */
 | |
| int qsort_strcasecmp_hlpr(const void *nick1, const void *nick2)
 | |
| {
 | |
|     return strcasecmp((const char *) nick1, (const char *) nick2);
 | |
| }
 | |
| 
 | |
| /* Returns true if nick is valid. A valid toxic nick:
 | |
|       - cannot be empty
 | |
|       - cannot start with a space
 | |
|       - must not contain contiguous spaces */
 | |
| bool valid_nick(uint8_t *nick)
 | |
| {
 | |
|     if (!nick[0] || nick[0] == ' ')
 | |
|         return false;
 | |
| 
 | |
|     int i;
 | |
| 
 | |
|     for (i = 0; nick[i]; ++i) {
 | |
|         if (nick[i] == ' ' && nick[i+1] == ' ')
 | |
|             return false;
 | |
|     }
 | |
| 
 | |
|     return true;
 | |
| }
 | |
| 
 | |
| /* Moves cursor to the end of the line in given window */
 | |
| void mv_curs_end(WINDOW *w, size_t len, int max_y, int max_x)
 | |
| {
 | |
|     int end_y = (len / max_x) + (max_y - CURS_Y_OFFSET);
 | |
|     int end_x = len % max_x;
 | |
|     wmove(w, end_y, end_x);  
 | |
| }
 |