annotate mcabber/src/main.c @ 169:0ed6099b5a54

[/trunk] Changeset 181 by mikael * Default logging directory is now "$HOME/.mcabber/histo/" * Default configuration file is now "$HOME/.mcabber/mcabberrc" (~/.mcabberrc should still work) * Switch parsecfg.c to glib
author mikael
date Wed, 04 May 2005 19:33:03 +0000
parents b4921dbf8709
children ea5e101fd29e
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 {
169
0ed6099b5a54 [/trunk] Changeset 181 by mikael
mikael
parents: 165
diff changeset
71 char *jid = g_new(strlen(username)+strlen(servername)+strlen(resource)+3);
35
a8ceaa3005fd [/trunk] Changeset 51 by mikael
mikael
parents: 30
diff changeset
72 strcpy(jid, username);
a8ceaa3005fd [/trunk] Changeset 51 by mikael
mikael
parents: 30
diff changeset
73 strcat(jid, "@");
a8ceaa3005fd [/trunk] Changeset 51 by mikael
mikael
parents: 30
diff changeset
74 strcat(jid, servername);
a8ceaa3005fd [/trunk] Changeset 51 by mikael
mikael
parents: 30
diff changeset
75 strcat(jid, "/");
a8ceaa3005fd [/trunk] Changeset 51 by mikael
mikael
parents: 30
diff changeset
76 strcat(jid, resource);
a8ceaa3005fd [/trunk] Changeset 51 by mikael
mikael
parents: 30
diff changeset
77 return jid;
a8ceaa3005fd [/trunk] Changeset 51 by mikael
mikael
parents: 30
diff changeset
78 }
a8ceaa3005fd [/trunk] Changeset 51 by mikael
mikael
parents: 30
diff changeset
79
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
80 void credits(void)
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
81 {
53
5690d6c2e48c [/trunk] Changeset 69 by mikael
mikael
parents: 36
diff changeset
82 printf(MCABBER_VERSION "\n");
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
83 printf(EMAIL "\n");
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
84 }
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
85
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
86 int main(int argc, char **argv)
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
87 {
169
0ed6099b5a54 [/trunk] Changeset 181 by mikael
mikael
parents: 165
diff changeset
88 char *configFile = NULL;
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
89 char *username, *password, *resource;
88
3c51989b0982 [/trunk] Changeset 102 by mikael
mikael
parents: 87
diff changeset
90 char *servername, *portstring;
35
a8ceaa3005fd [/trunk] Changeset 51 by mikael
mikael
parents: 30
diff changeset
91 char *jid;
88
3c51989b0982 [/trunk] Changeset 102 by mikael
mikael
parents: 87
diff changeset
92 char *optstring;
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
93 int key;
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
94 unsigned int port;
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
95 unsigned int ping;
70
5b1249ce812d [/trunk] Changeset 84 by mikael
mikael
parents: 53
diff changeset
96 int ssl;
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
97 int ret = 0;
151
b69c0b7a23e3 [/trunk] Changeset 163 by mikael
mikael
parents: 149
diff changeset
98 unsigned int refresh = 0;
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
99
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
100 credits();
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
101
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
102 /* SET THIS >0 TO ENABLE LOG */
138
250f872c722f [/trunk] Changeset 150 by mikael
mikael
parents: 135
diff changeset
103 ut_InitDebug(0, NULL);
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
104
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
105 ut_WriteLog("Setting signals handlers...\n");
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
106 signal(SIGTERM, sig_handler);
163
a8f7dc0a56cb [/trunk] Changeset 175 by mikael
mikael
parents: 160
diff changeset
107 signal(SIGCHLD, sig_handler);
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
108
77
32f54ad6d729 [/trunk] Changeset 91 by mikael
mikael
parents: 70
diff changeset
109 /* Parse command line options */
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
110 while (1) {
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
111 int c = getopt(argc, argv, "hf:");
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
112 if (c == -1) {
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
113 break;
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
114 } else
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
115 switch (c) {
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
116 case 'h':
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
117 printf("Usage: %s [-f mcabberrc_file]\n\n", argv[0]);
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
118 printf("Thanks to AjMacias for cabber!\n\n");
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
119 return 0;
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
120 case 'f':
169
0ed6099b5a54 [/trunk] Changeset 181 by mikael
mikael
parents: 165
diff changeset
121 configFile = g_strdup(optarg);
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
122 break;
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
123 }
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
124 }
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
125
169
0ed6099b5a54 [/trunk] Changeset 181 by mikael
mikael
parents: 165
diff changeset
126 if (configFile)
0ed6099b5a54 [/trunk] Changeset 181 by mikael
mikael
parents: 165
diff changeset
127 ut_WriteLog("Setting config file: %s\n", configFile);
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
128
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
129 /* Parsing config file... */
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
130 ut_WriteLog("Parsing config file...\n");
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
131 cfg_file(configFile);
169
0ed6099b5a54 [/trunk] Changeset 181 by mikael
mikael
parents: 165
diff changeset
132 if (configFile) g_free(configFile);
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
133
138
250f872c722f [/trunk] Changeset 150 by mikael
mikael
parents: 135
diff changeset
134 optstring = cfg_read("debug");
250f872c722f [/trunk] Changeset 150 by mikael
mikael
parents: 135
diff changeset
135 if (optstring)
250f872c722f [/trunk] Changeset 150 by mikael
mikael
parents: 135
diff changeset
136 ut_InitDebug(1, optstring);
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");
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
139 username = cfg_read("username");
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
140 password = cfg_read("password");
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
141 resource = cfg_read("resource");
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
113
8ac67e951eab [/trunk] Changeset 127 by mikael
mikael
parents: 112
diff changeset
169 optstring = cfg_read("logging");
8ac67e951eab [/trunk] Changeset 127 by mikael
mikael
parents: 112
diff changeset
170 if (optstring && (atoi(optstring) > 0))
8ac67e951eab [/trunk] Changeset 127 by mikael
mikael
parents: 112
diff changeset
171 hlog_enable(TRUE, cfg_read("logging_dir"));
8ac67e951eab [/trunk] Changeset 127 by mikael
mikael
parents: 112
diff changeset
172
160
44c6410b4845 [/trunk] Changeset 172 by mikael
mikael
parents: 156
diff changeset
173 if ((optstring = cfg_read("events_command")) != NULL)
44c6410b4845 [/trunk] Changeset 172 by mikael
mikael
parents: 156
diff changeset
174 hk_ext_cmd_init(optstring);
44c6410b4845 [/trunk] Changeset 172 by mikael
mikael
parents: 156
diff changeset
175
70
5b1249ce812d [/trunk] Changeset 84 by mikael
mikael
parents: 53
diff changeset
176 ssl = 0;
88
3c51989b0982 [/trunk] Changeset 102 by mikael
mikael
parents: 87
diff changeset
177 optstring = cfg_read("ssl");
3c51989b0982 [/trunk] Changeset 102 by mikael
mikael
parents: 87
diff changeset
178 if (optstring && (atoi(optstring) > 0))
70
5b1249ce812d [/trunk] Changeset 84 by mikael
mikael
parents: 53
diff changeset
179 ssl = 1;
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
180 portstring = cfg_read("port");
70
5b1249ce812d [/trunk] Changeset 84 by mikael
mikael
parents: 53
diff changeset
181 port = (portstring != NULL) ? (unsigned int) atoi(portstring) : 0;
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
182
35
a8ceaa3005fd [/trunk] Changeset 51 by mikael
mikael
parents: 30
diff changeset
183 /* Connect to server */
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
184 ut_WriteLog("Connecting to server: %s:%d\n", servername, port);
29
86837ff0554c [/trunk] Changeset 45 by mikael
mikael
parents: 28
diff changeset
185 scr_LogPrint("Connecting to server: %s:%d", servername, port);
35
a8ceaa3005fd [/trunk] Changeset 51 by mikael
mikael
parents: 30
diff changeset
186
a8ceaa3005fd [/trunk] Changeset 51 by mikael
mikael
parents: 30
diff changeset
187 jid = compose_jid(username, servername, resource);
70
5b1249ce812d [/trunk] Changeset 84 by mikael
mikael
parents: 53
diff changeset
188 jc = jb_connect(jid, port, ssl, password);
169
0ed6099b5a54 [/trunk] Changeset 181 by mikael
mikael
parents: 165
diff changeset
189 g_free(jid);
29
86837ff0554c [/trunk] Changeset 45 by mikael
mikael
parents: 28
diff changeset
190 if (!jc) {
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
191 ut_WriteLog("\terror!!!\n");
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
192 fprintf(stderr, "Error connecting to (%s)\n", servername);
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
193 scr_TerminateCurses();
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
194 return -2;
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
195 }
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
196
112
edb5591e2e64 [/trunk] Changeset 126 by mikael
mikael
parents: 102
diff changeset
197 ping = 40;
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
198 if (cfg_read("pinginterval"))
27
77e6bd2ccde6 [/trunk] Changeset 43 by mikael
mikael
parents: 26
diff changeset
199 ping = (unsigned int) atoi(cfg_read("pinginterval"));
112
edb5591e2e64 [/trunk] Changeset 126 by mikael
mikael
parents: 102
diff changeset
200 jb_set_keepalive_delay(ping);
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
201 ut_WriteLog("Ping interval stablished: %d secs\n", ping);
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
202
88
3c51989b0982 [/trunk] Changeset 102 by mikael
mikael
parents: 87
diff changeset
203 optstring = cfg_read("hide_offline_buddies");
3c51989b0982 [/trunk] Changeset 102 by mikael
mikael
parents: 87
diff changeset
204 if (optstring && (atoi(optstring) > 0))
120
cfd3df636d5f [/trunk] Changeset 133 by mikael
mikael
parents: 113
diff changeset
205 buddylist_set_hide_offline_buddies(TRUE);
87
f600615c490d [/trunk] Changeset 101 by mikael
mikael
parents: 81
diff changeset
206
96
8b2703ccc4be [/trunk] Changeset 110 by mikael
mikael
parents: 88
diff changeset
207 /* Initialize commands system */
8b2703ccc4be [/trunk] Changeset 110 by mikael
mikael
parents: 88
diff changeset
208 cmd_init();
8b2703ccc4be [/trunk] Changeset 110 by mikael
mikael
parents: 88
diff changeset
209
112
edb5591e2e64 [/trunk] Changeset 126 by mikael
mikael
parents: 102
diff changeset
210 ut_WriteLog("Entering into main loop...\n\n");
edb5591e2e64 [/trunk] Changeset 126 by mikael
mikael
parents: 102
diff changeset
211 ut_WriteLog("Ready to send/receive messages...\n");
edb5591e2e64 [/trunk] Changeset 126 by mikael
mikael
parents: 102
diff changeset
212
edb5591e2e64 [/trunk] Changeset 126 by mikael
mikael
parents: 102
diff changeset
213 jb_reset_keepalive();
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
214 while (ret != 255) {
35
a8ceaa3005fd [/trunk] Changeset 51 by mikael
mikael
parents: 30
diff changeset
215 key = scr_Getch();
151
b69c0b7a23e3 [/trunk] Changeset 163 by mikael
mikael
parents: 149
diff changeset
216
b69c0b7a23e3 [/trunk] Changeset 163 by mikael
mikael
parents: 149
diff changeset
217 // The refresh is really an ugly hack, but we need to call doupdate()
b69c0b7a23e3 [/trunk] Changeset 163 by mikael
mikael
parents: 149
diff changeset
218 // from time to time to catch the RESIZE events, because getch keep
b69c0b7a23e3 [/trunk] Changeset 163 by mikael
mikael
parents: 149
diff changeset
219 // returning ERR until a real key is pressed :-(
156
439b750d99fa [/trunk] Changeset 168 by mikael
mikael
parents: 152
diff changeset
220 if (key != ERR) {
29
86837ff0554c [/trunk] Changeset 45 by mikael
mikael
parents: 28
diff changeset
221 ret = process_key(key);
156
439b750d99fa [/trunk] Changeset 168 by mikael
mikael
parents: 152
diff changeset
222 refresh = 0;
439b750d99fa [/trunk] Changeset 168 by mikael
mikael
parents: 152
diff changeset
223 } else if (refresh++ > 1) {
151
b69c0b7a23e3 [/trunk] Changeset 163 by mikael
mikael
parents: 149
diff changeset
224 doupdate();
152
05f606cfb9e4 [/trunk] Changeset 164 by mikael
mikael
parents: 151
diff changeset
225 refresh = 0;
05f606cfb9e4 [/trunk] Changeset 164 by mikael
mikael
parents: 151
diff changeset
226 }
151
b69c0b7a23e3 [/trunk] Changeset 163 by mikael
mikael
parents: 149
diff changeset
227
152
05f606cfb9e4 [/trunk] Changeset 164 by mikael
mikael
parents: 151
diff changeset
228 if (key != KEY_RESIZE)
05f606cfb9e4 [/trunk] Changeset 164 by mikael
mikael
parents: 151
diff changeset
229 jb_main();
36
8f1a5e79ca40 [/trunk] Changeset 52 by mikael
mikael
parents: 35
diff changeset
230 if (update_roster)
81
0bd578421ce9 [/trunk] Changeset 95 by mikael
mikael
parents: 77
diff changeset
231 scr_DrawRoster();
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
232 }
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
233
35
a8ceaa3005fd [/trunk] Changeset 51 by mikael
mikael
parents: 30
diff changeset
234 jb_disconnect();
81
0bd578421ce9 [/trunk] Changeset 95 by mikael
mikael
parents: 77
diff changeset
235 //bud_TerminateBuddies();
24
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
236 scr_TerminateCurses();
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
237
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
238 printf("\n\nHave a nice day!\nBye!\n");
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
239
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
240 return 0;
e88b15cbf2de [/trunk] Changeset 40 by mikael
mikael
parents:
diff changeset
241 }