annotate mcabber/src/main.c @ 177:a51ce78a0e2a

[/trunk] Changeset 189 by mikael * Add a "load_logs" variable to enable logs reading. (Actual reading is not implemented yet...)
author mikael
date Thu, 05 May 2005 08:53:49 +0000
parents ea5e101fd29e
children 7604e3cdbb86
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
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;
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
90 char *username, *password, *resource;
88
3c51989b0982 [/trunk] Changeset 102 by mikael
mikael
parents: 87
diff changeset
91 char *servername, *portstring;
35
a8ceaa3005fd [/trunk] Changeset 51 by mikael
mikael
parents: 30
diff changeset
92 char *jid;
177
a51ce78a0e2a [/trunk] Changeset 189 by mikael
mikael
parents: 170
diff changeset
93 char *optstring, *optstring2;
a51ce78a0e2a [/trunk] Changeset 189 by mikael
mikael
parents: 170
diff changeset
94 int optval, optval2;
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;
70
5b1249ce812d [/trunk] Changeset 84 by mikael
mikael
parents: 53
diff changeset
98 int ssl;
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
99 int ret = 0;
151
b69c0b7a23e3 [/trunk] Changeset 163 by mikael
mikael
parents: 149
diff changeset
100 unsigned int refresh = 0;
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
101
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
102 credits();
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
103
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
104 /* SET THIS >0 TO ENABLE LOG */
138
250f872c722f [/trunk] Changeset 150 by mikael
mikael
parents: 135
diff changeset
105 ut_InitDebug(0, NULL);
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
106
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
107 ut_WriteLog("Setting signals handlers...\n");
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
108 signal(SIGTERM, sig_handler);
163
a8f7dc0a56cb [/trunk] Changeset 175 by mikael
mikael
parents: 160
diff changeset
109 signal(SIGCHLD, sig_handler);
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
110
77
32f54ad6d729 [/trunk] Changeset 91 by mikael
mikael
parents: 70
diff changeset
111 /* Parse command line options */
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
112 while (1) {
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
113 int c = getopt(argc, argv, "hf:");
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
114 if (c == -1) {
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
115 break;
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
116 } else
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
117 switch (c) {
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
118 case 'h':
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
119 printf("Usage: %s [-f mcabberrc_file]\n\n", argv[0]);
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
120 printf("Thanks to AjMacias for cabber!\n\n");
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
121 return 0;
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
122 case 'f':
169
0ed6099b5a54 [/trunk] Changeset 181 by mikael
mikael
parents: 165
diff changeset
123 configFile = g_strdup(optarg);
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
124 break;
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
125 }
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
126 }
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
127
169
0ed6099b5a54 [/trunk] Changeset 181 by mikael
mikael
parents: 165
diff changeset
128 if (configFile)
0ed6099b5a54 [/trunk] Changeset 181 by mikael
mikael
parents: 165
diff changeset
129 ut_WriteLog("Setting config file: %s\n", configFile);
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
130
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
131 /* Parsing config file... */
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
132 ut_WriteLog("Parsing config file...\n");
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
133 cfg_file(configFile);
169
0ed6099b5a54 [/trunk] Changeset 181 by mikael
mikael
parents: 165
diff changeset
134 if (configFile) g_free(configFile);
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
135
138
250f872c722f [/trunk] Changeset 150 by mikael
mikael
parents: 135
diff changeset
136 optstring = cfg_read("debug");
250f872c722f [/trunk] Changeset 150 by mikael
mikael
parents: 135
diff changeset
137 if (optstring)
250f872c722f [/trunk] Changeset 150 by mikael
mikael
parents: 135
diff changeset
138 ut_InitDebug(1, optstring);
250f872c722f [/trunk] Changeset 150 by mikael
mikael
parents: 135
diff changeset
139
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
140 servername = cfg_read("server");
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
141 username = cfg_read("username");
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
142 password = cfg_read("password");
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
143 resource = cfg_read("resource");
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
144
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
145 if (!servername) {
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
146 printf("Server name has not been specified in the config file!\n");
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
147 return -1;
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
148 }
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
149 if (!username) {
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
150 printf("User name has not been specified in the config file!\n");
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
151 return -1;
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
152 }
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
153 if (!password) {
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
154 char *p;
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
155 size_t passsize = 64;
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
156 printf("Please enter password: ");
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
157 my_getpass(&password, &passsize);
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
158 printf("\n");
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
159 for (p = password; *p; p++);
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
160 for ( ; p > password ; p--)
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
161 if (*p == '\n' || *p == '\r') *p = 0;
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
162 }
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
163
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
164 /* Initialize N-Curses */
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
165 ut_WriteLog("Initializing N-Curses...\n");
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
166 scr_InitCurses();
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
167
29
86837ff0554c [/trunk] Changeset 45 by mikael
mikael
parents: 28
diff changeset
168 ut_WriteLog("Drawing main window...\n");
151
b69c0b7a23e3 [/trunk] Changeset 163 by mikael
mikael
parents: 149
diff changeset
169 scr_DrawMainWindow(TRUE);
29
86837ff0554c [/trunk] Changeset 45 by mikael
mikael
parents: 28
diff changeset
170
177
a51ce78a0e2a [/trunk] Changeset 189 by mikael
mikael
parents: 170
diff changeset
171 optstring = cfg_read("logging");
a51ce78a0e2a [/trunk] Changeset 189 by mikael
mikael
parents: 170
diff changeset
172 optstring2 = cfg_read("load_logs");
a51ce78a0e2a [/trunk] Changeset 189 by mikael
mikael
parents: 170
diff changeset
173 optval = (optstring && (atoi(optstring) > 0));
a51ce78a0e2a [/trunk] Changeset 189 by mikael
mikael
parents: 170
diff changeset
174 optval2 = (optstring2 && (atoi(optstring2) > 0));
a51ce78a0e2a [/trunk] Changeset 189 by mikael
mikael
parents: 170
diff changeset
175 if (optval || optval2)
a51ce78a0e2a [/trunk] Changeset 189 by mikael
mikael
parents: 170
diff changeset
176 hlog_enable(optval, cfg_read("logging_dir"), optval2);
113
8ac67e951eab [/trunk] Changeset 127 by mikael
mikael
parents: 112
diff changeset
177
160
44c6410b4845 [/trunk] Changeset 172 by mikael
mikael
parents: 156
diff changeset
178 if ((optstring = cfg_read("events_command")) != NULL)
44c6410b4845 [/trunk] Changeset 172 by mikael
mikael
parents: 156
diff changeset
179 hk_ext_cmd_init(optstring);
44c6410b4845 [/trunk] Changeset 172 by mikael
mikael
parents: 156
diff changeset
180
70
5b1249ce812d [/trunk] Changeset 84 by mikael
mikael
parents: 53
diff changeset
181 ssl = 0;
88
3c51989b0982 [/trunk] Changeset 102 by mikael
mikael
parents: 87
diff changeset
182 optstring = cfg_read("ssl");
3c51989b0982 [/trunk] Changeset 102 by mikael
mikael
parents: 87
diff changeset
183 if (optstring && (atoi(optstring) > 0))
70
5b1249ce812d [/trunk] Changeset 84 by mikael
mikael
parents: 53
diff changeset
184 ssl = 1;
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
185 portstring = cfg_read("port");
70
5b1249ce812d [/trunk] Changeset 84 by mikael
mikael
parents: 53
diff changeset
186 port = (portstring != NULL) ? (unsigned int) atoi(portstring) : 0;
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
187
35
a8ceaa3005fd [/trunk] Changeset 51 by mikael
mikael
parents: 30
diff changeset
188 /* Connect to server */
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
189 ut_WriteLog("Connecting to server: %s:%d\n", servername, port);
29
86837ff0554c [/trunk] Changeset 45 by mikael
mikael
parents: 28
diff changeset
190 scr_LogPrint("Connecting to server: %s:%d", servername, port);
35
a8ceaa3005fd [/trunk] Changeset 51 by mikael
mikael
parents: 30
diff changeset
191
a8ceaa3005fd [/trunk] Changeset 51 by mikael
mikael
parents: 30
diff changeset
192 jid = compose_jid(username, servername, resource);
70
5b1249ce812d [/trunk] Changeset 84 by mikael
mikael
parents: 53
diff changeset
193 jc = jb_connect(jid, port, ssl, password);
169
0ed6099b5a54 [/trunk] Changeset 181 by mikael
mikael
parents: 165
diff changeset
194 g_free(jid);
29
86837ff0554c [/trunk] Changeset 45 by mikael
mikael
parents: 28
diff changeset
195 if (!jc) {
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
196 ut_WriteLog("\terror!!!\n");
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
197 fprintf(stderr, "Error connecting to (%s)\n", servername);
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
198 scr_TerminateCurses();
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
199 return -2;
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
200 }
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
201
112
edb5591e2e64 [/trunk] Changeset 126 by mikael
mikael
parents: 102
diff changeset
202 ping = 40;
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
203 if (cfg_read("pinginterval"))
27
77e6bd2ccde6 [/trunk] Changeset 43 by mikael
mikael
parents: 26
diff changeset
204 ping = (unsigned int) atoi(cfg_read("pinginterval"));
112
edb5591e2e64 [/trunk] Changeset 126 by mikael
mikael
parents: 102
diff changeset
205 jb_set_keepalive_delay(ping);
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
206 ut_WriteLog("Ping interval stablished: %d secs\n", ping);
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
207
88
3c51989b0982 [/trunk] Changeset 102 by mikael
mikael
parents: 87
diff changeset
208 optstring = cfg_read("hide_offline_buddies");
3c51989b0982 [/trunk] Changeset 102 by mikael
mikael
parents: 87
diff changeset
209 if (optstring && (atoi(optstring) > 0))
120
cfd3df636d5f [/trunk] Changeset 133 by mikael
mikael
parents: 113
diff changeset
210 buddylist_set_hide_offline_buddies(TRUE);
87
f600615c490d [/trunk] Changeset 101 by mikael
mikael
parents: 81
diff changeset
211
96
8b2703ccc4be [/trunk] Changeset 110 by mikael
mikael
parents: 88
diff changeset
212 /* Initialize commands system */
8b2703ccc4be [/trunk] Changeset 110 by mikael
mikael
parents: 88
diff changeset
213 cmd_init();
8b2703ccc4be [/trunk] Changeset 110 by mikael
mikael
parents: 88
diff changeset
214
112
edb5591e2e64 [/trunk] Changeset 126 by mikael
mikael
parents: 102
diff changeset
215 ut_WriteLog("Entering into main loop...\n\n");
edb5591e2e64 [/trunk] Changeset 126 by mikael
mikael
parents: 102
diff changeset
216 ut_WriteLog("Ready to send/receive messages...\n");
edb5591e2e64 [/trunk] Changeset 126 by mikael
mikael
parents: 102
diff changeset
217
edb5591e2e64 [/trunk] Changeset 126 by mikael
mikael
parents: 102
diff changeset
218 jb_reset_keepalive();
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
219 while (ret != 255) {
35
a8ceaa3005fd [/trunk] Changeset 51 by mikael
mikael
parents: 30
diff changeset
220 key = scr_Getch();
151
b69c0b7a23e3 [/trunk] Changeset 163 by mikael
mikael
parents: 149
diff changeset
221
b69c0b7a23e3 [/trunk] Changeset 163 by mikael
mikael
parents: 149
diff changeset
222 // The refresh is really an ugly hack, but we need to call doupdate()
b69c0b7a23e3 [/trunk] Changeset 163 by mikael
mikael
parents: 149
diff changeset
223 // from time to time to catch the RESIZE events, because getch keep
b69c0b7a23e3 [/trunk] Changeset 163 by mikael
mikael
parents: 149
diff changeset
224 // returning ERR until a real key is pressed :-(
156
439b750d99fa [/trunk] Changeset 168 by mikael
mikael
parents: 152
diff changeset
225 if (key != ERR) {
29
86837ff0554c [/trunk] Changeset 45 by mikael
mikael
parents: 28
diff changeset
226 ret = process_key(key);
156
439b750d99fa [/trunk] Changeset 168 by mikael
mikael
parents: 152
diff changeset
227 refresh = 0;
439b750d99fa [/trunk] Changeset 168 by mikael
mikael
parents: 152
diff changeset
228 } else if (refresh++ > 1) {
151
b69c0b7a23e3 [/trunk] Changeset 163 by mikael
mikael
parents: 149
diff changeset
229 doupdate();
152
05f606cfb9e4 [/trunk] Changeset 164 by mikael
mikael
parents: 151
diff changeset
230 refresh = 0;
05f606cfb9e4 [/trunk] Changeset 164 by mikael
mikael
parents: 151
diff changeset
231 }
151
b69c0b7a23e3 [/trunk] Changeset 163 by mikael
mikael
parents: 149
diff changeset
232
152
05f606cfb9e4 [/trunk] Changeset 164 by mikael
mikael
parents: 151
diff changeset
233 if (key != KEY_RESIZE)
05f606cfb9e4 [/trunk] Changeset 164 by mikael
mikael
parents: 151
diff changeset
234 jb_main();
36
8f1a5e79ca40 [/trunk] Changeset 52 by mikael
mikael
parents: 35
diff changeset
235 if (update_roster)
81
0bd578421ce9 [/trunk] Changeset 95 by mikael
mikael
parents: 77
diff changeset
236 scr_DrawRoster();
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
237 }
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
238
35
a8ceaa3005fd [/trunk] Changeset 51 by mikael
mikael
parents: 30
diff changeset
239 jb_disconnect();
81
0bd578421ce9 [/trunk] Changeset 95 by mikael
mikael
parents: 77
diff changeset
240 //bud_TerminateBuddies();
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
241 scr_TerminateCurses();
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
242
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
243 printf("\n\nHave a nice day!\nBye!\n");
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
244
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
245 return 0;
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
246 }