2011-02-24 04:14:30 +01:00
|
|
|
/* X-Chat
|
|
|
|
* Copyright (C) 1998 Peter Zelezny.
|
|
|
|
*
|
|
|
|
* This program 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 2 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 this program; if not, write to the Free Software
|
|
|
|
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <string.h>
|
|
|
|
#ifdef HAVE_STRINGS_H
|
|
|
|
#include <strings.h>
|
|
|
|
#endif
|
2011-02-28 18:59:32 +01:00
|
|
|
#ifdef WIN32
|
2012-11-04 04:22:22 +01:00
|
|
|
#include <io.h>
|
2011-02-28 18:59:32 +01:00
|
|
|
#define STDIN_FILENO 0
|
|
|
|
#define STDOUT_FILENO 1
|
|
|
|
#else
|
|
|
|
#include <unistd.h>
|
2011-02-24 04:14:30 +01:00
|
|
|
#include <sys/time.h>
|
2011-02-28 18:59:32 +01:00
|
|
|
#endif
|
2011-02-24 04:14:30 +01:00
|
|
|
#include <sys/types.h>
|
|
|
|
#include <ctype.h>
|
2011-02-28 18:59:32 +01:00
|
|
|
#include <glib.h>
|
2012-10-24 21:33:02 +02:00
|
|
|
#include "../common/hexchat.h"
|
|
|
|
#include "../common/hexchatc.h"
|
2011-02-28 18:59:32 +01:00
|
|
|
#include "../common/cfgfiles.h"
|
2011-02-24 04:14:30 +01:00
|
|
|
#include "../common/outbound.h"
|
|
|
|
#include "../common/util.h"
|
|
|
|
#include "../common/fe.h"
|
|
|
|
#include "fe-text.h"
|
|
|
|
|
|
|
|
|
|
|
|
static int done = FALSE; /* finished ? */
|
|
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
send_command (char *cmd)
|
|
|
|
{
|
2011-02-28 18:59:32 +01:00
|
|
|
handle_multiline (current_tab, cmd, TRUE, FALSE);
|
2011-02-24 04:14:30 +01:00
|
|
|
}
|
|
|
|
|
2011-02-28 18:59:32 +01:00
|
|
|
static gboolean
|
|
|
|
handle_line (GIOChannel *channel, GIOCondition cond, gpointer data)
|
2011-02-24 04:14:30 +01:00
|
|
|
{
|
|
|
|
|
2011-02-28 18:59:32 +01:00
|
|
|
gchar *str_return;
|
|
|
|
gsize length, terminator_pos;
|
|
|
|
GError *error = NULL;
|
|
|
|
GIOStatus result;
|
2011-02-24 04:14:30 +01:00
|
|
|
|
2011-02-28 18:59:32 +01:00
|
|
|
result = g_io_channel_read_line(channel, &str_return, &length, &terminator_pos, &error);
|
|
|
|
if (result == G_IO_STATUS_ERROR) {
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
send_command(str_return);
|
|
|
|
g_free(str_return);
|
|
|
|
return TRUE;
|
2011-02-24 04:14:30 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
static int done_intro = 0;
|
|
|
|
|
|
|
|
void
|
|
|
|
fe_new_window (struct session *sess, int focus)
|
|
|
|
{
|
|
|
|
char buf[512];
|
|
|
|
|
|
|
|
sess->gui = malloc (4);
|
2011-02-28 18:59:32 +01:00
|
|
|
current_sess = sess;
|
2011-02-24 04:14:30 +01:00
|
|
|
|
|
|
|
if (!sess->server->front_session)
|
|
|
|
sess->server->front_session = sess;
|
|
|
|
if (!sess->server->server_session)
|
|
|
|
sess->server->server_session = sess;
|
2011-02-28 18:59:32 +01:00
|
|
|
if (!current_tab || focus)
|
2011-02-24 04:14:30 +01:00
|
|
|
current_tab = sess;
|
|
|
|
|
|
|
|
if (done_intro)
|
|
|
|
return;
|
|
|
|
done_intro = 1;
|
|
|
|
|
|
|
|
snprintf (buf, sizeof (buf),
|
|
|
|
"\n"
|
2012-10-13 13:05:01 +02:00
|
|
|
" \017HexChat-Text \00310"PACKAGE_VERSION"\n"
|
2011-02-24 04:14:30 +01:00
|
|
|
" \017Running on \00310%s \017glib \00310%d.%d.%d\n"
|
|
|
|
" \017This binary compiled \00310"__DATE__"\017\n",
|
2012-10-28 00:05:40 +02:00
|
|
|
get_sys_str (1),
|
2011-02-24 04:14:30 +01:00
|
|
|
glib_major_version, glib_minor_version, glib_micro_version);
|
|
|
|
fe_print_text (sess, buf, 0);
|
|
|
|
|
|
|
|
fe_print_text (sess, "\n\nCompiled in Features\0032:\017 "
|
|
|
|
#ifdef USE_PLUGIN
|
|
|
|
"Plugin "
|
|
|
|
#endif
|
|
|
|
#ifdef ENABLE_NLS
|
|
|
|
"NLS "
|
|
|
|
#endif
|
|
|
|
#ifdef USE_OPENSSL
|
|
|
|
"OpenSSL "
|
|
|
|
#endif
|
|
|
|
#ifdef USE_IPV6
|
|
|
|
"IPv6"
|
|
|
|
#endif
|
|
|
|
"\n\n", 0);
|
|
|
|
fflush (stdout);
|
|
|
|
fflush (stdin);
|
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
get_stamp_str (time_t tim, char *dest, int size)
|
|
|
|
{
|
2012-10-22 15:55:43 +02:00
|
|
|
return strftime (dest, size, prefs.hex_stamp_text_format, localtime (&tim));
|
2011-02-24 04:14:30 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
2011-02-28 18:59:32 +01:00
|
|
|
timecat (char *buf, time_t stamp)
|
2011-02-24 04:14:30 +01:00
|
|
|
{
|
|
|
|
char stampbuf[64];
|
|
|
|
|
2011-02-28 18:59:32 +01:00
|
|
|
/* set the stamp to the current time if not provided */
|
|
|
|
if (!stamp)
|
|
|
|
stamp = time (0);
|
|
|
|
|
|
|
|
get_stamp_str (stamp, stampbuf, sizeof (stampbuf));
|
2011-02-24 04:14:30 +01:00
|
|
|
strcat (buf, stampbuf);
|
|
|
|
return strlen (stampbuf);
|
|
|
|
}
|
|
|
|
|
2011-02-28 18:59:32 +01:00
|
|
|
/* Windows doesn't handle ANSI codes in cmd.exe, need to not display them */
|
|
|
|
#ifndef WIN32
|
2011-02-24 04:14:30 +01:00
|
|
|
/* 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 */
|
|
|
|
static const short colconv[] = { 0, 7, 4, 2, 1, 3, 5, 11, 13, 12, 6, 16, 14, 15, 10, 7 };
|
|
|
|
|
|
|
|
void
|
|
|
|
fe_print_text (struct session *sess, char *text, time_t stamp)
|
|
|
|
{
|
|
|
|
int dotime = FALSE;
|
|
|
|
char num[8];
|
|
|
|
int reverse = 0, under = 0, bold = 0,
|
|
|
|
comma, k, i = 0, j = 0, len = strlen (text);
|
|
|
|
unsigned char *newtext = malloc (len + 1024);
|
|
|
|
|
2012-10-22 15:55:43 +02:00
|
|
|
if (prefs.hex_stamp_text)
|
2011-02-24 04:14:30 +01:00
|
|
|
{
|
|
|
|
newtext[0] = 0;
|
2011-02-28 18:59:32 +01:00
|
|
|
j += timecat (newtext, stamp);
|
2011-02-24 04:14:30 +01:00
|
|
|
}
|
|
|
|
while (i < len)
|
|
|
|
{
|
|
|
|
if (dotime && text[i] != 0)
|
|
|
|
{
|
|
|
|
dotime = FALSE;
|
|
|
|
newtext[j] = 0;
|
2011-02-28 18:59:32 +01:00
|
|
|
j += timecat (newtext, stamp);
|
2011-02-24 04:14:30 +01:00
|
|
|
}
|
|
|
|
switch (text[i])
|
|
|
|
{
|
|
|
|
case 3:
|
|
|
|
i++;
|
|
|
|
if (!isdigit (text[i]))
|
|
|
|
{
|
|
|
|
newtext[j] = 27;
|
|
|
|
j++;
|
|
|
|
newtext[j] = '[';
|
|
|
|
j++;
|
|
|
|
newtext[j] = 'm';
|
|
|
|
j++;
|
2011-02-28 18:59:32 +01:00
|
|
|
goto endloop;
|
2011-02-24 04:14:30 +01:00
|
|
|
}
|
|
|
|
k = 0;
|
|
|
|
comma = FALSE;
|
|
|
|
while (i < len)
|
|
|
|
{
|
|
|
|
if (text[i] >= '0' && text[i] <= '9' && k < 2)
|
|
|
|
{
|
|
|
|
num[k] = text[i];
|
|
|
|
k++;
|
|
|
|
} else
|
|
|
|
{
|
|
|
|
int col, mirc;
|
|
|
|
num[k] = 0;
|
|
|
|
newtext[j] = 27;
|
|
|
|
j++;
|
|
|
|
newtext[j] = '[';
|
|
|
|
j++;
|
|
|
|
if (k == 0)
|
|
|
|
{
|
|
|
|
newtext[j] = 'm';
|
|
|
|
j++;
|
|
|
|
} else
|
|
|
|
{
|
|
|
|
if (comma)
|
|
|
|
col = 40;
|
|
|
|
else
|
|
|
|
col = 30;
|
|
|
|
mirc = atoi (num);
|
|
|
|
mirc = colconv[mirc];
|
|
|
|
if (mirc > 9)
|
|
|
|
{
|
|
|
|
mirc += 50;
|
|
|
|
sprintf ((char *) &newtext[j], "%dm", mirc + col);
|
|
|
|
} else
|
|
|
|
{
|
|
|
|
sprintf ((char *) &newtext[j], "%dm", mirc + col);
|
|
|
|
}
|
|
|
|
j = strlen (newtext);
|
|
|
|
}
|
|
|
|
switch (text[i])
|
|
|
|
{
|
|
|
|
case ',':
|
|
|
|
comma = TRUE;
|
|
|
|
break;
|
|
|
|
default:
|
2011-02-28 18:59:32 +01:00
|
|
|
goto endloop;
|
2011-02-24 04:14:30 +01:00
|
|
|
}
|
|
|
|
k = 0;
|
|
|
|
}
|
|
|
|
i++;
|
|
|
|
}
|
|
|
|
break;
|
2011-02-28 18:59:32 +01:00
|
|
|
/* don't actually want hidden text */
|
|
|
|
case '\010': /* hidden */
|
|
|
|
break;
|
2011-02-24 04:14:30 +01:00
|
|
|
case '\026': /* REVERSE */
|
|
|
|
if (reverse)
|
|
|
|
{
|
|
|
|
reverse = FALSE;
|
|
|
|
strcpy (&newtext[j], "\033[27m");
|
|
|
|
} else
|
|
|
|
{
|
|
|
|
reverse = TRUE;
|
|
|
|
strcpy (&newtext[j], "\033[7m");
|
|
|
|
}
|
|
|
|
j = strlen (newtext);
|
|
|
|
break;
|
|
|
|
case '\037': /* underline */
|
|
|
|
if (under)
|
|
|
|
{
|
|
|
|
under = FALSE;
|
|
|
|
strcpy (&newtext[j], "\033[24m");
|
|
|
|
} else
|
|
|
|
{
|
|
|
|
under = TRUE;
|
|
|
|
strcpy (&newtext[j], "\033[4m");
|
|
|
|
}
|
|
|
|
j = strlen (newtext);
|
|
|
|
break;
|
|
|
|
case '\002': /* bold */
|
|
|
|
if (bold)
|
|
|
|
{
|
|
|
|
bold = FALSE;
|
|
|
|
strcpy (&newtext[j], "\033[22m");
|
|
|
|
} else
|
|
|
|
{
|
|
|
|
bold = TRUE;
|
|
|
|
strcpy (&newtext[j], "\033[1m");
|
|
|
|
}
|
|
|
|
j = strlen (newtext);
|
|
|
|
break;
|
|
|
|
case '\007':
|
2012-10-22 14:18:20 +02:00
|
|
|
if (!prefs.hex_input_filter_beep)
|
2011-02-24 04:14:30 +01:00
|
|
|
{
|
|
|
|
newtext[j] = text[i];
|
|
|
|
j++;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case '\017': /* reset all */
|
|
|
|
strcpy (&newtext[j], "\033[m");
|
|
|
|
j += 3;
|
|
|
|
reverse = FALSE;
|
|
|
|
bold = FALSE;
|
|
|
|
under = FALSE;
|
|
|
|
break;
|
|
|
|
case '\t':
|
|
|
|
newtext[j] = ' ';
|
|
|
|
j++;
|
|
|
|
break;
|
|
|
|
case '\n':
|
|
|
|
newtext[j] = '\r';
|
|
|
|
j++;
|
2012-10-22 15:55:43 +02:00
|
|
|
if (prefs.hex_stamp_text)
|
2011-02-24 04:14:30 +01:00
|
|
|
dotime = TRUE;
|
|
|
|
default:
|
|
|
|
newtext[j] = text[i];
|
|
|
|
j++;
|
|
|
|
}
|
|
|
|
i++;
|
2011-02-28 18:59:32 +01:00
|
|
|
endloop:
|
|
|
|
;
|
2011-02-24 04:14:30 +01:00
|
|
|
}
|
2011-02-28 18:59:32 +01:00
|
|
|
|
|
|
|
/* make sure last character is a new line */
|
|
|
|
if (text[i-1] != '\n')
|
|
|
|
newtext[j++] = '\n';
|
|
|
|
|
2011-02-24 04:14:30 +01:00
|
|
|
newtext[j] = 0;
|
|
|
|
write (STDOUT_FILENO, newtext, j);
|
|
|
|
free (newtext);
|
|
|
|
}
|
2011-02-28 18:59:32 +01:00
|
|
|
#else
|
|
|
|
/* The win32 version for cmd.exe */
|
2011-02-24 04:14:30 +01:00
|
|
|
void
|
2011-02-28 18:59:32 +01:00
|
|
|
fe_print_text (struct session *sess, char *text, time_t stamp)
|
2011-02-24 04:14:30 +01:00
|
|
|
{
|
2011-02-28 18:59:32 +01:00
|
|
|
int dotime = FALSE;
|
|
|
|
int comma, k, i = 0, j = 0, len = strlen (text);
|
|
|
|
|
|
|
|
unsigned char *newtext = malloc (len + 1024);
|
2011-02-24 04:14:30 +01:00
|
|
|
|
2012-10-22 15:55:43 +02:00
|
|
|
if (prefs.hex_stamp_text)
|
2011-02-24 04:14:30 +01:00
|
|
|
{
|
2011-02-28 18:59:32 +01:00
|
|
|
newtext[0] = 0;
|
|
|
|
j += timecat (newtext, stamp);
|
|
|
|
}
|
|
|
|
while (i < len)
|
|
|
|
{
|
|
|
|
if (dotime && text[i] != 0)
|
2011-02-24 04:14:30 +01:00
|
|
|
{
|
2011-02-28 18:59:32 +01:00
|
|
|
dotime = FALSE;
|
|
|
|
newtext[j] = 0;
|
|
|
|
j += timecat (newtext, stamp);
|
2011-02-24 04:14:30 +01:00
|
|
|
}
|
2011-02-28 18:59:32 +01:00
|
|
|
switch (text[i])
|
|
|
|
{
|
|
|
|
case 3:
|
|
|
|
i++;
|
|
|
|
if (!isdigit (text[i]))
|
|
|
|
{
|
|
|
|
goto endloop;
|
|
|
|
}
|
|
|
|
k = 0;
|
|
|
|
comma = FALSE;
|
|
|
|
while (i < len)
|
|
|
|
{
|
|
|
|
if (text[i] >= '0' && text[i] <= '9' && k < 2)
|
|
|
|
{
|
|
|
|
k++;
|
|
|
|
} else
|
|
|
|
{
|
|
|
|
switch (text[i])
|
|
|
|
{
|
|
|
|
case ',':
|
|
|
|
comma = TRUE;
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
goto endloop;
|
|
|
|
}
|
|
|
|
k = 0;
|
|
|
|
|
|
|
|
}
|
|
|
|
i++;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
/* don't actually want hidden text */
|
|
|
|
case '\010': /* hidden */
|
|
|
|
case '\026': /* REVERSE */
|
|
|
|
case '\037': /* underline */
|
|
|
|
case '\002': /* bold */
|
|
|
|
case '\017': /* reset all */
|
|
|
|
break;
|
|
|
|
case '\007':
|
2012-10-22 14:18:20 +02:00
|
|
|
if (!prefs.hex_input_filter_beep)
|
2011-02-28 18:59:32 +01:00
|
|
|
{
|
|
|
|
newtext[j] = text[i];
|
|
|
|
j++;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case '\t':
|
|
|
|
newtext[j] = ' ';
|
|
|
|
j++;
|
|
|
|
break;
|
|
|
|
case '\n':
|
|
|
|
newtext[j] = '\r';
|
|
|
|
j++;
|
2012-10-22 15:55:43 +02:00
|
|
|
if (prefs.hex_stamp_text)
|
2011-02-28 18:59:32 +01:00
|
|
|
dotime = TRUE;
|
|
|
|
default:
|
|
|
|
newtext[j] = text[i];
|
|
|
|
j++;
|
|
|
|
}
|
|
|
|
i++;
|
|
|
|
endloop:
|
|
|
|
;
|
2011-02-24 04:14:30 +01:00
|
|
|
}
|
2011-02-28 18:59:32 +01:00
|
|
|
|
|
|
|
/* make sure last character is a new line */
|
|
|
|
if (text[i-1] != '\n')
|
|
|
|
newtext[j++] = '\n';
|
|
|
|
|
|
|
|
newtext[j] = 0;
|
|
|
|
write (STDOUT_FILENO, newtext, j);
|
|
|
|
free (newtext);
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
void
|
|
|
|
fe_timeout_remove (int tag)
|
|
|
|
{
|
|
|
|
g_source_remove (tag);
|
2011-02-24 04:14:30 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
fe_timeout_add (int interval, void *callback, void *userdata)
|
|
|
|
{
|
2011-02-28 18:59:32 +01:00
|
|
|
return g_timeout_add (interval, (GSourceFunc) callback, userdata);
|
2011-02-24 04:14:30 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
fe_input_remove (int tag)
|
|
|
|
{
|
2011-02-28 18:59:32 +01:00
|
|
|
g_source_remove (tag);
|
2011-02-24 04:14:30 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
fe_input_add (int sok, int flags, void *func, void *data)
|
|
|
|
{
|
2011-02-28 18:59:32 +01:00
|
|
|
int tag, type = 0;
|
|
|
|
GIOChannel *channel;
|
2011-02-24 04:14:30 +01:00
|
|
|
|
2011-02-28 18:59:32 +01:00
|
|
|
channel = g_io_channel_unix_new (sok);
|
2011-02-24 04:14:30 +01:00
|
|
|
|
2011-02-28 18:59:32 +01:00
|
|
|
if (flags & FIA_READ)
|
|
|
|
type |= G_IO_IN | G_IO_HUP | G_IO_ERR;
|
|
|
|
if (flags & FIA_WRITE)
|
|
|
|
type |= G_IO_OUT | G_IO_ERR;
|
|
|
|
if (flags & FIA_EX)
|
|
|
|
type |= G_IO_PRI;
|
2011-02-24 04:14:30 +01:00
|
|
|
|
2011-02-28 18:59:32 +01:00
|
|
|
tag = g_io_add_watch (channel, type, (GIOFunc) func, data);
|
|
|
|
g_io_channel_unref (channel);
|
|
|
|
|
|
|
|
return tag;
|
2011-02-24 04:14:30 +01:00
|
|
|
}
|
|
|
|
|
2011-02-28 18:59:32 +01:00
|
|
|
/* === command-line parameter parsing : requires glib 2.6 === */
|
|
|
|
|
|
|
|
static char *arg_cfgdir = NULL;
|
|
|
|
static gint arg_show_autoload = 0;
|
|
|
|
static gint arg_show_config = 0;
|
|
|
|
static gint arg_show_version = 0;
|
|
|
|
|
|
|
|
static const GOptionEntry gopt_entries[] =
|
|
|
|
{
|
|
|
|
{"no-auto", 'a', 0, G_OPTION_ARG_NONE, &arg_dont_autoconnect, N_("Don't auto connect to servers"), NULL},
|
|
|
|
{"cfgdir", 'd', 0, G_OPTION_ARG_STRING, &arg_cfgdir, N_("Use a different config directory"), "PATH"},
|
|
|
|
{"no-plugins", 'n', 0, G_OPTION_ARG_NONE, &arg_skip_plugins, N_("Don't auto load any plugins"), NULL},
|
2012-11-04 21:40:59 +01:00
|
|
|
{"plugindir", 'p', 0, G_OPTION_ARG_NONE, &arg_show_autoload, N_("Show plugin/script auto-load directory"), NULL},
|
2011-02-28 18:59:32 +01:00
|
|
|
{"configdir", 'u', 0, G_OPTION_ARG_NONE, &arg_show_config, N_("Show user config directory"), NULL},
|
|
|
|
{"url", 0, 0, G_OPTION_ARG_STRING, &arg_url, N_("Open an irc://server:port/channel URL"), "URL"},
|
|
|
|
{"version", 'v', 0, G_OPTION_ARG_NONE, &arg_show_version, N_("Show version information"), NULL},
|
|
|
|
{NULL}
|
|
|
|
};
|
|
|
|
|
2011-02-24 04:14:30 +01:00
|
|
|
int
|
|
|
|
fe_args (int argc, char *argv[])
|
|
|
|
{
|
2011-02-28 18:59:32 +01:00
|
|
|
GError *error = NULL;
|
|
|
|
GOptionContext *context;
|
|
|
|
|
|
|
|
#ifdef ENABLE_NLS
|
|
|
|
bindtextdomain (GETTEXT_PACKAGE, LOCALEDIR);
|
|
|
|
bind_textdomain_codeset (GETTEXT_PACKAGE, "UTF-8");
|
|
|
|
textdomain (GETTEXT_PACKAGE);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
context = g_option_context_new (NULL);
|
|
|
|
g_option_context_add_main_entries (context, gopt_entries, GETTEXT_PACKAGE);
|
|
|
|
g_option_context_parse (context, &argc, &argv, &error);
|
|
|
|
|
|
|
|
if (error)
|
|
|
|
{
|
|
|
|
if (error->message)
|
|
|
|
printf ("%s\n", error->message);
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
g_option_context_free (context);
|
|
|
|
|
|
|
|
if (arg_show_version)
|
|
|
|
{
|
|
|
|
printf (PACKAGE_TARNAME" "PACKAGE_VERSION"\n");
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (arg_show_autoload)
|
2011-02-24 04:14:30 +01:00
|
|
|
{
|
2011-02-28 18:59:32 +01:00
|
|
|
#ifdef WIN32
|
|
|
|
/* see the chdir() below */
|
|
|
|
char *sl, *exe = strdup (argv[0]);
|
|
|
|
sl = strrchr (exe, '\\');
|
|
|
|
if (sl)
|
2011-02-24 04:14:30 +01:00
|
|
|
{
|
2011-02-28 18:59:32 +01:00
|
|
|
*sl = 0;
|
|
|
|
printf ("%s\\plugins\n", exe);
|
2011-02-24 04:14:30 +01:00
|
|
|
}
|
2011-02-28 18:59:32 +01:00
|
|
|
#else
|
2012-07-13 18:04:00 +02:00
|
|
|
printf ("%s\n", HEXCHATLIBDIR"/plugins");
|
2011-02-28 18:59:32 +01:00
|
|
|
#endif
|
|
|
|
return 0;
|
2011-02-24 04:14:30 +01:00
|
|
|
}
|
2011-02-28 18:59:32 +01:00
|
|
|
|
|
|
|
if (arg_show_config)
|
|
|
|
{
|
2012-11-03 18:24:25 +01:00
|
|
|
printf ("%s\n", get_xdir ());
|
2011-02-28 18:59:32 +01:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (arg_cfgdir) /* we want filesystem encoding */
|
|
|
|
{
|
2012-11-03 18:24:25 +01:00
|
|
|
if (xdir)
|
|
|
|
g_free (xdir);
|
|
|
|
xdir = strdup (arg_cfgdir);
|
|
|
|
if (xdir[strlen (xdir) - 1] == '/')
|
|
|
|
xdir[strlen (xdir) - 1] = 0;
|
2011-02-28 18:59:32 +01:00
|
|
|
g_free (arg_cfgdir);
|
|
|
|
}
|
|
|
|
|
2011-02-24 04:14:30 +01:00
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
fe_init (void)
|
|
|
|
{
|
2011-02-28 18:59:32 +01:00
|
|
|
/* the following should be default generated, not enfoced in binary */
|
2012-10-22 13:49:28 +02:00
|
|
|
prefs.hex_gui_tab_server = 0;
|
|
|
|
prefs.hex_gui_autoopen_dialog = 0;
|
2011-02-28 18:59:32 +01:00
|
|
|
/* except for these, there is no lag meter, there is no server list */
|
2012-10-22 13:49:28 +02:00
|
|
|
prefs.hex_gui_lagometer = 0;
|
|
|
|
prefs.hex_gui_slist_skip = 1;
|
2011-02-24 04:14:30 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
fe_main (void)
|
|
|
|
{
|
2011-02-28 18:59:32 +01:00
|
|
|
GIOChannel *keyboard_input;
|
2011-02-24 04:14:30 +01:00
|
|
|
|
2011-02-28 18:59:32 +01:00
|
|
|
main_loop = g_main_loop_new(NULL, FALSE);
|
2011-02-24 04:14:30 +01:00
|
|
|
|
2011-02-28 18:59:32 +01:00
|
|
|
/* Keyboard Entry Setup */
|
|
|
|
#ifdef G_OS_WIN32
|
|
|
|
keyboard_input = g_io_channel_win32_new_fd(STDIN_FILENO);
|
|
|
|
#else
|
|
|
|
keyboard_input = g_io_channel_unix_new(STDIN_FILENO);
|
2011-02-24 04:14:30 +01:00
|
|
|
#endif
|
|
|
|
|
2011-02-28 18:59:32 +01:00
|
|
|
g_io_add_watch(keyboard_input, G_IO_IN, handle_line, NULL);
|
2011-02-24 04:14:30 +01:00
|
|
|
|
2011-02-28 18:59:32 +01:00
|
|
|
g_main_loop_run(main_loop);
|
2011-02-24 04:14:30 +01:00
|
|
|
|
2011-02-28 18:59:32 +01:00
|
|
|
return;
|
2011-02-24 04:14:30 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
fe_exit (void)
|
|
|
|
{
|
|
|
|
done = TRUE;
|
2011-02-28 18:59:32 +01:00
|
|
|
g_main_loop_quit(main_loop);
|
2011-02-24 04:14:30 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
fe_new_server (struct server *serv)
|
|
|
|
{
|
|
|
|
serv->gui = malloc (4);
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
fe_message (char *msg, int flags)
|
|
|
|
{
|
|
|
|
puts (msg);
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
fe_close_window (struct session *sess)
|
|
|
|
{
|
|
|
|
session_free (sess);
|
|
|
|
done = TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
fe_beep (void)
|
|
|
|
{
|
|
|
|
putchar (7);
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
fe_add_rawlog (struct server *serv, char *text, int len, int outbound)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
void
|
|
|
|
fe_set_topic (struct session *sess, char *topic, char *stripped_topic)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
void
|
|
|
|
fe_cleanup (void)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
void
|
|
|
|
fe_set_hilight (struct session *sess)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
void
|
|
|
|
fe_set_tab_color (struct session *sess, int col)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
void
|
|
|
|
fe_update_mode_buttons (struct session *sess, char mode, char sign)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
void
|
|
|
|
fe_update_channel_key (struct session *sess)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
void
|
|
|
|
fe_update_channel_limit (struct session *sess)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
int
|
|
|
|
fe_is_chanwindow (struct server *serv)
|
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
fe_add_chan_list (struct server *serv, char *chan, char *users, char *topic)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
void
|
|
|
|
fe_chan_list_end (struct server *serv)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
int
|
|
|
|
fe_is_banwindow (struct session *sess)
|
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
void
|
|
|
|
fe_add_ban_list (struct session *sess, char *mask, char *who, char *when, int is_exemption)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
void
|
|
|
|
fe_ban_list_end (struct session *sess, int is_exemption)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
void
|
|
|
|
fe_notify_update (char *name)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
void
|
|
|
|
fe_notify_ask (char *name, char *networks)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
void
|
|
|
|
fe_text_clear (struct session *sess, int lines)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
void
|
|
|
|
fe_progressbar_start (struct session *sess)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
void
|
|
|
|
fe_progressbar_end (struct server *serv)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
void
|
|
|
|
fe_userlist_insert (struct session *sess, struct User *newuser, int row, int sel)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
int
|
|
|
|
fe_userlist_remove (struct session *sess, struct User *user)
|
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
void
|
|
|
|
fe_userlist_rehash (struct session *sess, struct User *user)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
void
|
|
|
|
fe_userlist_move (struct session *sess, struct User *user, int new_row)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
void
|
|
|
|
fe_userlist_numbers (struct session *sess)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
void
|
|
|
|
fe_userlist_clear (struct session *sess)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
void
|
|
|
|
fe_userlist_set_selected (struct session *sess)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
void
|
|
|
|
fe_dcc_add (struct DCC *dcc)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
void
|
|
|
|
fe_dcc_update (struct DCC *dcc)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
void
|
|
|
|
fe_dcc_remove (struct DCC *dcc)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
void
|
|
|
|
fe_clear_channel (struct session *sess)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
void
|
|
|
|
fe_session_callback (struct session *sess)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
void
|
|
|
|
fe_server_callback (struct server *serv)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
void
|
|
|
|
fe_url_add (const char *text)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
void
|
|
|
|
fe_pluginlist_update (void)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
void
|
|
|
|
fe_buttons_update (struct session *sess)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
void
|
|
|
|
fe_dlgbuttons_update (struct session *sess)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
void
|
|
|
|
fe_dcc_send_filereq (struct session *sess, char *nick, int maxcps, int passive)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
void
|
|
|
|
fe_set_channel (struct session *sess)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
void
|
|
|
|
fe_set_title (struct session *sess)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
void
|
|
|
|
fe_set_nonchannel (struct session *sess, int state)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
void
|
|
|
|
fe_set_nick (struct server *serv, char *newnick)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
void
|
|
|
|
fe_change_nick (struct server *serv, char *nick, char *newnick)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
void
|
|
|
|
fe_ignore_update (int level)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
int
|
|
|
|
fe_dcc_open_recv_win (int passive)
|
|
|
|
{
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
int
|
|
|
|
fe_dcc_open_send_win (int passive)
|
|
|
|
{
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
int
|
|
|
|
fe_dcc_open_chat_win (int passive)
|
|
|
|
{
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
void
|
|
|
|
fe_userlist_hide (session * sess)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
void
|
2012-10-24 20:41:13 +02:00
|
|
|
fe_lastlog (session *sess, session *lastlog_sess, char *sstr, gtk_xtext_search_flags flags)
|
2011-02-24 04:14:30 +01:00
|
|
|
{
|
|
|
|
}
|
|
|
|
void
|
|
|
|
fe_set_lag (server * serv, int lag)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
void
|
|
|
|
fe_set_throttle (server * serv)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
void
|
|
|
|
fe_set_away (server *serv)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
void
|
|
|
|
fe_serverlist_open (session *sess)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
void
|
|
|
|
fe_get_str (char *prompt, char *def, void *callback, void *ud)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
void
|
|
|
|
fe_get_int (char *prompt, int def, void *callback, void *ud)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
void
|
|
|
|
fe_idle_add (void *func, void *data)
|
|
|
|
{
|
2011-02-28 18:59:32 +01:00
|
|
|
g_idle_add (func, data);
|
2011-02-24 04:14:30 +01:00
|
|
|
}
|
|
|
|
void
|
|
|
|
fe_ctrl_gui (session *sess, fe_gui_action action, int arg)
|
|
|
|
{
|
2011-02-28 18:59:32 +01:00
|
|
|
/* only one action type handled for now, but could add more */
|
|
|
|
switch (action)
|
|
|
|
{
|
2012-10-13 13:05:01 +02:00
|
|
|
/* gui focus is really the only case hexchat-text needs to wory about */
|
2011-02-28 18:59:32 +01:00
|
|
|
case FE_GUI_FOCUS:
|
|
|
|
current_sess = sess;
|
|
|
|
current_tab = sess;
|
|
|
|
sess->server->front_session = sess;
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
2011-02-24 04:14:30 +01:00
|
|
|
}
|
|
|
|
int
|
|
|
|
fe_gui_info (session *sess, int info_type)
|
|
|
|
{
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
void *
|
|
|
|
fe_gui_info_ptr (session *sess, int info_type)
|
|
|
|
{
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
void fe_confirm (const char *message, void (*yesproc)(void *), void (*noproc)(void *), void *ud)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
char *fe_get_inputbox_contents (struct session *sess)
|
|
|
|
{
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
void fe_set_inputbox_contents (struct session *sess, char *text)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
int fe_get_inputbox_cursor (struct session *sess)
|
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
void fe_set_inputbox_cursor (struct session *sess, int delta, int pos)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
void fe_open_url (const char *url)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
void fe_menu_del (menu_entry *me)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
char *fe_menu_add (menu_entry *me)
|
|
|
|
{
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
void fe_menu_update (menu_entry *me)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
void fe_uselect (struct session *sess, char *word[], int do_clear, int scroll_to)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
void
|
|
|
|
fe_server_event (server *serv, int type, int arg)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
void
|
|
|
|
fe_flash_window (struct session *sess)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
void fe_get_file (const char *title, char *initial,
|
|
|
|
void (*callback) (void *userdata, char *file), void *userdata,
|
|
|
|
int flags)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
void fe_tray_set_flash (const char *filename1, const char *filename2, int timeout){}
|
|
|
|
void fe_tray_set_file (const char *filename){}
|
|
|
|
void fe_tray_set_icon (feicon icon){}
|
|
|
|
void fe_tray_set_tooltip (const char *text){}
|
|
|
|
void fe_tray_set_balloon (const char *title, const char *text){}
|
|
|
|
void fe_userlist_update (session *sess, struct User *user){}
|