mcabber/src/main.c
author mikael@matrix
Sun, 03 Jul 2005 20:54:45 +0100
changeset 272 7f2e61392b2e
parent 217 200ea7c89d9a
child 279 f5dd437c057b
permissions -rw-r--r--
Add resource priority option
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
149
9f74832eb4f8 [/trunk] Changeset 161 by mikael
mikael
parents: 138
diff changeset
     1
#define _GNU_SOURCE
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
     2
#include <stdio.h>
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
     3
#include <stdlib.h>
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
     4
#include <unistd.h>
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
     5
#include <string.h>
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
     6
#include <signal.h>
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
     7
#include <termios.h>
28
0cd8025eebee [/trunk] Changeset 44 by mikael
mikael
parents: 27
diff changeset
     8
#include <getopt.h>
163
a8f7dc0a56cb [/trunk] Changeset 175 by mikael
mikael
parents: 160
diff changeset
     9
#include <sys/types.h>
a8f7dc0a56cb [/trunk] Changeset 175 by mikael
mikael
parents: 160
diff changeset
    10
#include <sys/wait.h>
169
0ed6099b5a54 [/trunk] Changeset 181 by mikael
mikael
parents: 165
diff changeset
    11
#include <glib.h>
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
    12
81
0bd578421ce9 [/trunk] Changeset 95 by mikael
mikael
parents: 77
diff changeset
    13
#include "jabglue.h"
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
    14
#include "screen.h"
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
    15
#include "parsecfg.h"
102
2b4cc6bc5bf2 [/trunk] Changeset 116 by mikael
mikael
parents: 96
diff changeset
    16
#include "roster.h"
96
8b2703ccc4be [/trunk] Changeset 110 by mikael
mikael
parents: 88
diff changeset
    17
#include "commands.h"
113
8ac67e951eab [/trunk] Changeset 127 by mikael
mikael
parents: 112
diff changeset
    18
#include "histolog.h"
163
a8f7dc0a56cb [/trunk] Changeset 175 by mikael
mikael
parents: 160
diff changeset
    19
#include "hooks.h"
81
0bd578421ce9 [/trunk] Changeset 95 by mikael
mikael
parents: 77
diff changeset
    20
#include "utils.h"
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
    21
#include "harddefines.h"
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
    22
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
    23
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
    24
void sig_handler(int signum)
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
    25
{
163
a8f7dc0a56cb [/trunk] Changeset 175 by mikael
mikael
parents: 160
diff changeset
    26
  if (signum == SIGCHLD) {
a8f7dc0a56cb [/trunk] Changeset 175 by mikael
mikael
parents: 160
diff changeset
    27
    int status;
a8f7dc0a56cb [/trunk] Changeset 175 by mikael
mikael
parents: 160
diff changeset
    28
    pid_t pid;
a8f7dc0a56cb [/trunk] Changeset 175 by mikael
mikael
parents: 160
diff changeset
    29
    do {
a8f7dc0a56cb [/trunk] Changeset 175 by mikael
mikael
parents: 160
diff changeset
    30
      pid = waitpid (WAIT_ANY, &status, WNOHANG);
a8f7dc0a56cb [/trunk] Changeset 175 by mikael
mikael
parents: 160
diff changeset
    31
    } while (pid > 0);
165
b4921dbf8709 [/trunk] Changeset 177 by mikael
mikael
parents: 163
diff changeset
    32
    //if (pid < 0)
b4921dbf8709 [/trunk] Changeset 177 by mikael
mikael
parents: 163
diff changeset
    33
    //  ut_WriteLog("Error in waitpid: errno=%d\n", errno);
163
a8f7dc0a56cb [/trunk] Changeset 175 by mikael
mikael
parents: 160
diff changeset
    34
    signal(SIGCHLD, sig_handler);
a8f7dc0a56cb [/trunk] Changeset 175 by mikael
mikael
parents: 160
diff changeset
    35
  } else if (signum == SIGTERM) {
81
0bd578421ce9 [/trunk] Changeset 95 by mikael
mikael
parents: 77
diff changeset
    36
    // bud_TerminateBuddies();
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
    37
    scr_TerminateCurses();
35
a8ceaa3005fd [/trunk] Changeset 51 by mikael
mikael
parents: 30
diff changeset
    38
    jb_disconnect();
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
    39
    printf("Killed by SIGTERM\nBye!\n");
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
    40
    exit(EXIT_SUCCESS);
165
b4921dbf8709 [/trunk] Changeset 177 by mikael
mikael
parents: 163
diff changeset
    41
  } else {
b4921dbf8709 [/trunk] Changeset 177 by mikael
mikael
parents: 163
diff changeset
    42
    ut_WriteLog("Caught signal: %d\n", signum);
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
    43
  }
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
    44
}
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
    45
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
    46
ssize_t my_getpass (char **passstr, size_t *n)
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
    47
{
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
    48
  struct termios orig, new;
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
    49
  int nread;
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
    50
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
    51
  /* Turn echoing off and fail if we can't. */
28
0cd8025eebee [/trunk] Changeset 44 by mikael
mikael
parents: 27
diff changeset
    52
  if (tcgetattr(fileno(stdin), &orig) != 0)
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
    53
      return -1;
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
    54
  new = orig;
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
    55
  new.c_lflag &= ~ECHO;
28
0cd8025eebee [/trunk] Changeset 44 by mikael
mikael
parents: 27
diff changeset
    56
  if (tcsetattr(fileno(stdin), TCSAFLUSH, &new) != 0)
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
    57
      return -1;
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
    58
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
    59
  /* Read the password. */
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
    60
  nread = getline(passstr, n, stdin);
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
    61
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
    62
  /* Restore terminal. */
28
0cd8025eebee [/trunk] Changeset 44 by mikael
mikael
parents: 27
diff changeset
    63
  (void) tcsetattr(fileno(stdin), TCSAFLUSH, &orig);
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
    64
27
77e6bd2ccde6 [/trunk] Changeset 43 by mikael
mikael
parents: 26
diff changeset
    65
  return (ssize_t)nread;
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
    66
}
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
    67
35
a8ceaa3005fd [/trunk] Changeset 51 by mikael
mikael
parents: 30
diff changeset
    68
char *compose_jid(const char *username, const char *servername,
a8ceaa3005fd [/trunk] Changeset 51 by mikael
mikael
parents: 30
diff changeset
    69
        const char *resource)
a8ceaa3005fd [/trunk] Changeset 51 by mikael
mikael
parents: 30
diff changeset
    70
{
170
ea5e101fd29e [/trunk] Changeset 182 by mikael
mikael
parents: 169
diff changeset
    71
  char *jid = g_new(char, 
ea5e101fd29e [/trunk] Changeset 182 by mikael
mikael
parents: 169
diff changeset
    72
          strlen(username)+strlen(servername)+strlen(resource)+3);
35
a8ceaa3005fd [/trunk] Changeset 51 by mikael
mikael
parents: 30
diff changeset
    73
  strcpy(jid, username);
a8ceaa3005fd [/trunk] Changeset 51 by mikael
mikael
parents: 30
diff changeset
    74
  strcat(jid, "@");
a8ceaa3005fd [/trunk] Changeset 51 by mikael
mikael
parents: 30
diff changeset
    75
  strcat(jid, servername);
a8ceaa3005fd [/trunk] Changeset 51 by mikael
mikael
parents: 30
diff changeset
    76
  strcat(jid, "/");
a8ceaa3005fd [/trunk] Changeset 51 by mikael
mikael
parents: 30
diff changeset
    77
  strcat(jid, resource);
a8ceaa3005fd [/trunk] Changeset 51 by mikael
mikael
parents: 30
diff changeset
    78
  return jid;
a8ceaa3005fd [/trunk] Changeset 51 by mikael
mikael
parents: 30
diff changeset
    79
}
a8ceaa3005fd [/trunk] Changeset 51 by mikael
mikael
parents: 30
diff changeset
    80
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
    81
void credits(void)
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
    82
{
53
5690d6c2e48c [/trunk] Changeset 69 by mikael
mikael
parents: 36
diff changeset
    83
  printf(MCABBER_VERSION "\n");
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
    84
  printf(EMAIL "\n");
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
    85
}
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
    86
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
    87
int main(int argc, char **argv)
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
    88
{
169
0ed6099b5a54 [/trunk] Changeset 181 by mikael
mikael
parents: 165
diff changeset
    89
  char *configFile = NULL;
188
7604e3cdbb86 [/trunk] Changeset 200 by mikael
mikael
parents: 177
diff changeset
    90
  char *username, *password, *resource, *servername;
35
a8ceaa3005fd [/trunk] Changeset 51 by mikael
mikael
parents: 30
diff changeset
    91
  char *jid;
188
7604e3cdbb86 [/trunk] Changeset 200 by mikael
mikael
parents: 177
diff changeset
    92
  char *optstring;
177
a51ce78a0e2a [/trunk] Changeset 189 by mikael
mikael
parents: 170
diff changeset
    93
  int optval, optval2;
188
7604e3cdbb86 [/trunk] Changeset 200 by mikael
mikael
parents: 177
diff changeset
    94
  int ssl;
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
    95
  int key;
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
    96
  unsigned int port;
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
    97
  unsigned int ping;
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
    98
  int ret = 0;
151
b69c0b7a23e3 [/trunk] Changeset 163 by mikael
mikael
parents: 149
diff changeset
    99
  unsigned int refresh = 0;
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   100
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   101
  credits();
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   102
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   103
  /* SET THIS >0 TO ENABLE LOG */
138
250f872c722f [/trunk] Changeset 150 by mikael
mikael
parents: 135
diff changeset
   104
  ut_InitDebug(0, NULL);
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   105
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   106
  ut_WriteLog("Setting signals handlers...\n");
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   107
  signal(SIGTERM, sig_handler);
163
a8f7dc0a56cb [/trunk] Changeset 175 by mikael
mikael
parents: 160
diff changeset
   108
  signal(SIGCHLD, sig_handler);
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   109
77
32f54ad6d729 [/trunk] Changeset 91 by mikael
mikael
parents: 70
diff changeset
   110
  /* Parse command line options */
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   111
  while (1) {
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   112
    int c = getopt(argc, argv, "hf:");
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   113
    if (c == -1) {
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   114
      break;
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   115
    } else
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   116
      switch (c) {
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   117
      case 'h':
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   118
	printf("Usage: %s [-f mcabberrc_file]\n\n", argv[0]);
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   119
        printf("Thanks to AjMacias for cabber!\n\n");
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   120
	return 0;
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   121
      case 'f':
169
0ed6099b5a54 [/trunk] Changeset 181 by mikael
mikael
parents: 165
diff changeset
   122
	configFile = g_strdup(optarg);
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   123
	break;
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   124
      }
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   125
  }
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   126
169
0ed6099b5a54 [/trunk] Changeset 181 by mikael
mikael
parents: 165
diff changeset
   127
  if (configFile)
0ed6099b5a54 [/trunk] Changeset 181 by mikael
mikael
parents: 165
diff changeset
   128
    ut_WriteLog("Setting config file: %s\n", configFile);
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   129
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   130
  /* Parsing config file... */
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   131
  ut_WriteLog("Parsing config file...\n");
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   132
  cfg_file(configFile);
169
0ed6099b5a54 [/trunk] Changeset 181 by mikael
mikael
parents: 165
diff changeset
   133
  if (configFile) g_free(configFile);
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   134
138
250f872c722f [/trunk] Changeset 150 by mikael
mikael
parents: 135
diff changeset
   135
  optstring = cfg_read("debug");
217
200ea7c89d9a [/trunk] Changeset 229 by mikael
mikael
parents: 188
diff changeset
   136
  if (optstring) ut_InitDebug(1, optstring);
138
250f872c722f [/trunk] Changeset 150 by mikael
mikael
parents: 135
diff changeset
   137
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   138
  servername = cfg_read("server");
188
7604e3cdbb86 [/trunk] Changeset 200 by mikael
mikael
parents: 177
diff changeset
   139
  username   = cfg_read("username");
7604e3cdbb86 [/trunk] Changeset 200 by mikael
mikael
parents: 177
diff changeset
   140
  password   = cfg_read("password");
7604e3cdbb86 [/trunk] Changeset 200 by mikael
mikael
parents: 177
diff changeset
   141
  resource   = cfg_read("resource");
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   142
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   143
  if (!servername) {
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   144
      printf("Server name has not been specified in the config file!\n");
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   145
      return -1;
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   146
  }
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   147
  if (!username) {
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   148
      printf("User name has not been specified in the config file!\n");
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   149
      return -1;
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   150
  }
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   151
  if (!password) {
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   152
      char *p;
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   153
      size_t passsize = 64;
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   154
      printf("Please enter password: ");
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   155
      my_getpass(&password, &passsize);
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   156
      printf("\n");
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   157
      for (p = password; *p; p++);
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   158
      for ( ; p > password ; p--)
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   159
          if (*p == '\n' || *p == '\r') *p = 0;
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   160
  }
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   161
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   162
  /* Initialize N-Curses */
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   163
  ut_WriteLog("Initializing N-Curses...\n");
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   164
  scr_InitCurses();
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   165
29
86837ff0554c [/trunk] Changeset 45 by mikael
mikael
parents: 28
diff changeset
   166
  ut_WriteLog("Drawing main window...\n");
151
b69c0b7a23e3 [/trunk] Changeset 163 by mikael
mikael
parents: 149
diff changeset
   167
  scr_DrawMainWindow(TRUE);
29
86837ff0554c [/trunk] Changeset 45 by mikael
mikael
parents: 28
diff changeset
   168
188
7604e3cdbb86 [/trunk] Changeset 200 by mikael
mikael
parents: 177
diff changeset
   169
  optval   = (cfg_read_int("logging") > 0);
7604e3cdbb86 [/trunk] Changeset 200 by mikael
mikael
parents: 177
diff changeset
   170
  optval2  = (cfg_read_int("load_logs") > 0);
177
a51ce78a0e2a [/trunk] Changeset 189 by mikael
mikael
parents: 170
diff changeset
   171
  if (optval || optval2)
a51ce78a0e2a [/trunk] Changeset 189 by mikael
mikael
parents: 170
diff changeset
   172
    hlog_enable(optval, cfg_read("logging_dir"), optval2);
113
8ac67e951eab [/trunk] Changeset 127 by mikael
mikael
parents: 112
diff changeset
   173
160
44c6410b4845 [/trunk] Changeset 172 by mikael
mikael
parents: 156
diff changeset
   174
  if ((optstring = cfg_read("events_command")) != NULL)
44c6410b4845 [/trunk] Changeset 172 by mikael
mikael
parents: 156
diff changeset
   175
    hk_ext_cmd_init(optstring);
44c6410b4845 [/trunk] Changeset 172 by mikael
mikael
parents: 156
diff changeset
   176
188
7604e3cdbb86 [/trunk] Changeset 200 by mikael
mikael
parents: 177
diff changeset
   177
  ssl  = (cfg_read_int("ssl") > 0);
7604e3cdbb86 [/trunk] Changeset 200 by mikael
mikael
parents: 177
diff changeset
   178
  port = (unsigned int) cfg_read_int("port");
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   179
272
7f2e61392b2e Add resource priority option
mikael@matrix
parents: 217
diff changeset
   180
  jb_set_priority(cfg_read_int("priority"));
7f2e61392b2e Add resource priority option
mikael@matrix
parents: 217
diff changeset
   181
35
a8ceaa3005fd [/trunk] Changeset 51 by mikael
mikael
parents: 30
diff changeset
   182
  /* Connect to server */
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   183
  ut_WriteLog("Connecting to server: %s:%d\n", servername, port);
29
86837ff0554c [/trunk] Changeset 45 by mikael
mikael
parents: 28
diff changeset
   184
  scr_LogPrint("Connecting to server: %s:%d", servername, port);
35
a8ceaa3005fd [/trunk] Changeset 51 by mikael
mikael
parents: 30
diff changeset
   185
a8ceaa3005fd [/trunk] Changeset 51 by mikael
mikael
parents: 30
diff changeset
   186
  jid = compose_jid(username, servername, resource);
70
5b1249ce812d [/trunk] Changeset 84 by mikael
mikael
parents: 53
diff changeset
   187
  jc = jb_connect(jid, port, ssl, password);
169
0ed6099b5a54 [/trunk] Changeset 181 by mikael
mikael
parents: 165
diff changeset
   188
  g_free(jid);
29
86837ff0554c [/trunk] Changeset 45 by mikael
mikael
parents: 28
diff changeset
   189
  if (!jc) {
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   190
    ut_WriteLog("\terror!!!\n");
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   191
    fprintf(stderr, "Error connecting to (%s)\n", servername);
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   192
    scr_TerminateCurses();
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   193
    return -2;
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   194
  }
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   195
112
edb5591e2e64 [/trunk] Changeset 126 by mikael
mikael
parents: 102
diff changeset
   196
  ping = 40;
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   197
  if (cfg_read("pinginterval"))
27
77e6bd2ccde6 [/trunk] Changeset 43 by mikael
mikael
parents: 26
diff changeset
   198
    ping = (unsigned int) atoi(cfg_read("pinginterval"));
112
edb5591e2e64 [/trunk] Changeset 126 by mikael
mikael
parents: 102
diff changeset
   199
  jb_set_keepalive_delay(ping);
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   200
  ut_WriteLog("Ping interval stablished: %d secs\n", ping);
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   201
188
7604e3cdbb86 [/trunk] Changeset 200 by mikael
mikael
parents: 177
diff changeset
   202
  if (cfg_read_int("hide_offline_buddies") > 0)
120
cfd3df636d5f [/trunk] Changeset 133 by mikael
mikael
parents: 113
diff changeset
   203
    buddylist_set_hide_offline_buddies(TRUE);
87
f600615c490d [/trunk] Changeset 101 by mikael
mikael
parents: 81
diff changeset
   204
96
8b2703ccc4be [/trunk] Changeset 110 by mikael
mikael
parents: 88
diff changeset
   205
  /* Initialize commands system */
8b2703ccc4be [/trunk] Changeset 110 by mikael
mikael
parents: 88
diff changeset
   206
  cmd_init();
8b2703ccc4be [/trunk] Changeset 110 by mikael
mikael
parents: 88
diff changeset
   207
112
edb5591e2e64 [/trunk] Changeset 126 by mikael
mikael
parents: 102
diff changeset
   208
  ut_WriteLog("Entering into main loop...\n\n");
edb5591e2e64 [/trunk] Changeset 126 by mikael
mikael
parents: 102
diff changeset
   209
  ut_WriteLog("Ready to send/receive messages...\n");
edb5591e2e64 [/trunk] Changeset 126 by mikael
mikael
parents: 102
diff changeset
   210
edb5591e2e64 [/trunk] Changeset 126 by mikael
mikael
parents: 102
diff changeset
   211
  jb_reset_keepalive();
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   212
  while (ret != 255) {
35
a8ceaa3005fd [/trunk] Changeset 51 by mikael
mikael
parents: 30
diff changeset
   213
    key = scr_Getch();
151
b69c0b7a23e3 [/trunk] Changeset 163 by mikael
mikael
parents: 149
diff changeset
   214
b69c0b7a23e3 [/trunk] Changeset 163 by mikael
mikael
parents: 149
diff changeset
   215
    // The refresh is really an ugly hack, but we need to call doupdate()
b69c0b7a23e3 [/trunk] Changeset 163 by mikael
mikael
parents: 149
diff changeset
   216
    // from time to time to catch the RESIZE events, because getch keep
b69c0b7a23e3 [/trunk] Changeset 163 by mikael
mikael
parents: 149
diff changeset
   217
    // returning ERR until a real key is pressed :-(
156
439b750d99fa [/trunk] Changeset 168 by mikael
mikael
parents: 152
diff changeset
   218
    if (key != ERR) {
29
86837ff0554c [/trunk] Changeset 45 by mikael
mikael
parents: 28
diff changeset
   219
      ret = process_key(key);
156
439b750d99fa [/trunk] Changeset 168 by mikael
mikael
parents: 152
diff changeset
   220
      refresh = 0;
439b750d99fa [/trunk] Changeset 168 by mikael
mikael
parents: 152
diff changeset
   221
    } else if (refresh++ > 1) {
151
b69c0b7a23e3 [/trunk] Changeset 163 by mikael
mikael
parents: 149
diff changeset
   222
      doupdate();
152
05f606cfb9e4 [/trunk] Changeset 164 by mikael
mikael
parents: 151
diff changeset
   223
      refresh = 0;
05f606cfb9e4 [/trunk] Changeset 164 by mikael
mikael
parents: 151
diff changeset
   224
    }
151
b69c0b7a23e3 [/trunk] Changeset 163 by mikael
mikael
parents: 149
diff changeset
   225
152
05f606cfb9e4 [/trunk] Changeset 164 by mikael
mikael
parents: 151
diff changeset
   226
    if (key != KEY_RESIZE)
05f606cfb9e4 [/trunk] Changeset 164 by mikael
mikael
parents: 151
diff changeset
   227
      jb_main();
36
8f1a5e79ca40 [/trunk] Changeset 52 by mikael
mikael
parents: 35
diff changeset
   228
    if (update_roster)
81
0bd578421ce9 [/trunk] Changeset 95 by mikael
mikael
parents: 77
diff changeset
   229
      scr_DrawRoster();
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   230
  }
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   231
35
a8ceaa3005fd [/trunk] Changeset 51 by mikael
mikael
parents: 30
diff changeset
   232
  jb_disconnect();
81
0bd578421ce9 [/trunk] Changeset 95 by mikael
mikael
parents: 77
diff changeset
   233
  //bud_TerminateBuddies();
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   234
  scr_TerminateCurses();
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   235
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   236
  printf("\n\nHave a nice day!\nBye!\n");
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   237
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   238
  return 0;
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
   239
}