Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
BitchX
GitHub Repository: BitchX/BitchX1.3
Path: blob/master/dll/nicklist/nicklist.c
1074 views
1
#include "irc.h"
2
#include "struct.h"
3
#include "dcc.h"
4
#include "ircaux.h"
5
#include "ctcp.h"
6
#include "status.h"
7
#include "lastlog.h"
8
#include "server.h"
9
#include "screen.h"
10
#include "vars.h"
11
#include "misc.h"
12
#include "output.h"
13
#include "module.h"
14
#include "hook.h"
15
#include "hash2.h"
16
#define INIT_MODULE
17
#include "modval.h"
18
19
#include <sys/time.h>
20
21
#define cparse convert_output_format
22
23
#ifdef __EMXPM__
24
HAB hnab = 0;
25
HMQ hnmq = 0;
26
QMSG nqmsg = { 0 };
27
HWND hwndnClient = 0;
28
HDC hndc = 0;
29
HVPS hnvps = 0;
30
HWND hwndNicklist = 0;
31
HWND hwndscroller;
32
33
char spaces[NICKNAME_LEN+1];
34
35
SBCDATA scrollerdata;
36
int spos;
37
#elif defined(GTK)
38
GdkColor Black = { 0, 0x0000, 0x0000, 0x0000 };
39
GdkColor White = { 0, 0xaaaa, 0xaaaa, 0xaaaa };
40
GtkWidget *GtkNickList = NULL,
41
*clist,
42
*scrolledwindow;
43
char *tmptext[1];
44
#endif
45
46
BUILT_IN_DLL(nicklist_add);
47
int update_nicklist (char *, char *, char **);
48
49
void drawnicklist(void)
50
{
51
NickList *n, *list;
52
ChannelList *cptr;
53
char minibuffer[NICKNAME_LEN+1];
54
int nickcount=0, k;
55
56
cptr = lookup_channel(current_window->current_channel, from_server, 0);
57
list = sorted_nicklist(cptr, NICKSORT_NORMAL);
58
#ifdef __EMXPM__
59
if(spos<0)
60
spos=0;
61
#elif defined(GTK)
62
gui_mutex_lock();
63
gtk_clist_clear((GtkCList *)clist);
64
#endif
65
for(n = list; n; n = n->next)
66
{
67
#ifdef __EMXPM__
68
if(nickcount >= spos && nickcount < spos + 20)
69
{
70
#endif
71
minibuffer[0]='\0';
72
if(nick_isvoice(n))
73
strcpy(minibuffer, "+");
74
if(nick_isop(n))
75
strcpy(minibuffer, "@");
76
if(nick_isircop(n))
77
strcat(minibuffer, "*");
78
strcat(minibuffer, n->nick);
79
for(k=strlen(minibuffer);k<NICKNAME_LEN;k++)
80
minibuffer[k]=' ';
81
minibuffer[NICKNAME_LEN]='\0';
82
#ifdef __EMXPM__
83
VioSetCurPos(nickcount-spos, 0, hnvps);
84
VioWrtTTY(minibuffer, strlen(minibuffer), hnvps);
85
}
86
#elif defined(GTK)
87
tmptext[0] = &minibuffer[0];
88
gtk_clist_append((GtkCList *)clist, tmptext);
89
gtk_clist_set_background((GtkCList *)clist, nickcount, &Black);
90
gtk_clist_set_foreground((GtkCList *)clist, nickcount, &White);
91
#endif
92
nickcount++;
93
}
94
#ifdef __EMXPM__
95
if(nickcount<20)
96
{
97
for(k=nickcount;k<20;k++)
98
{
99
VioSetCurPos(k, 0, hnvps);
100
VioWrtTTY(spaces, NICKNAME_LEN, hnvps);
101
}
102
}
103
else if (spos > nickcount-20)
104
{
105
spos=nickcount-20;
106
drawnicklist();
107
}
108
109
WinSendMsg(hwndscroller, SBM_SETSCROLLBAR, (MPARAM)spos, MPFROM2SHORT(0, nickcount - 20));
110
WinSendMsg(hwndscroller, SBM_SETTHUMBSIZE, MPFROM2SHORT(20, nickcount), (MPARAM)NULL);
111
#elif defined(GTK)
112
gui_mutex_unlock();
113
#endif
114
clear_sorted_nicklist(&list);
115
}
116
117
int update_nicklist (char *which, char *str, char **unused)
118
{
119
#ifdef __EMXPM__
120
if (hwndNicklist)
121
#elif defined(GTK)
122
if (GtkNickList)
123
#endif
124
drawnicklist();
125
return 0;
126
}
127
128
#ifdef __EMXPM__
129
MRESULT EXPENTRY NicklistWndProc(hwnd, msg, mp1, mp2)
130
HWND hwnd;
131
USHORT msg;
132
MPARAM mp1;
133
MPARAM mp2;
134
{
135
HPS hps;
136
137
switch(msg) {
138
case WM_TIMER:
139
if(get_dllint_var("nl_always_on_top"))
140
WinSetWindowPos(WinQueryWindow(hwnd, QW_PARENT),
141
HWND_TOP, 0,0,0,0, SWP_ZORDER);
142
break;
143
case WM_CLOSE:
144
VioAssociate((HDC)NULL, hnvps);
145
VioDestroyPS(hnvps);
146
WinDestroyWindow(hwndNicklist);
147
hwndnClient = hwndscroller = hwndNicklist = NULLHANDLE;
148
return (MRESULT)TRUE;
149
break;
150
case WM_VSCROLL:
151
switch(SHORT2FROMMP(mp2))
152
{
153
case SB_LINEUP:
154
spos--;
155
break;
156
case SB_LINEDOWN:
157
spos++;
158
break;
159
case SB_PAGEUP:
160
spos -= 20;
161
break;
162
case SB_PAGEDOWN:
163
spos += 20;
164
break;
165
case SB_SLIDERPOSITION:
166
case SB_SLIDERTRACK:
167
spos=SHORT1FROMMP(mp2);
168
break;
169
}
170
drawnicklist();
171
break;
172
case WM_PAINT:
173
hps = WinBeginPaint(hwnd, NULLHANDLE, NULL);
174
VioShowPS(20, NICKNAME_LEN, 0, hnvps);
175
WinEndPaint(hps);
176
return (0L);
177
case WM_SIZE:
178
return (WinDefAVioWindowProc(hwnd, msg, (ULONG)mp1, (ULONG)mp2));
179
break;
180
}
181
return (WinDefWindowProc(hwnd, msg, mp1, mp2));
182
}
183
184
void nicklist_thread(void)
185
{
186
ChannelList *chan;
187
NickList *n;
188
SWP winpos;
189
int borderw, borderh, titleh, cx, cy;
190
ULONG fstyle = FCF_TITLEBAR | FCF_SHELLPOSITION | FCF_TASKLIST | FCF_DLGBORDER;
191
VIOCURSORINFO bleah;
192
193
hnab = WinInitialize(0);
194
hnmq = WinCreateMsgQueue(hnab, 0);
195
WinRegisterClass(hnab, "NICKLIST", NicklistWndProc, CS_SIZEREDRAW, 0);
196
hwndNicklist = WinCreateStdWindow(HWND_DESKTOP,
197
WS_VISIBLE,
198
&fstyle,
199
"NICKLIST",
200
"Nicks",
201
0L,
202
NULLHANDLE,
203
0L,
204
&hwndnClient);
205
hndc = WinOpenWindowDC(hwndnClient); /* opens device context */
206
VioCreatePS(&hnvps, 20, NICKNAME_LEN + 1, 0, /* creates AVIO PS */
207
1, 0);
208
VioAssociate(hndc, hnvps); /* associates DC and AVIO PS */
209
VioSetDeviceCellSize(current_window->screen->VIO_font_height, current_window->screen->VIO_font_width, hnvps); /* Set the font size */
210
titleh=WinQuerySysValue(HWND_DESKTOP, SV_CYTITLEBAR);
211
borderh=WinQuerySysValue(HWND_DESKTOP, SV_CYDLGFRAME);
212
borderw=WinQuerySysValue(HWND_DESKTOP, SV_CXDLGFRAME);
213
214
cx=NICKNAME_LEN*current_window->screen->VIO_font_width;
215
cy=20*current_window->screen->VIO_font_height;
216
WinSetWindowPos(hwndNicklist, HWND_TOP, 0, 0, cx + (borderw * 2) + 15 /* scroller width */, cy + titleh + (borderh * 2), SWP_SIZE);
217
scrollerdata.posFirst = 0;
218
scrollerdata.posLast = 0;
219
scrollerdata.posThumb = 0;
220
scrollerdata.cVisible = 0;
221
scrollerdata.cTotal = 0;
222
hwndscroller = WinCreateWindow(hwndnClient, WC_SCROLLBAR, (PSZ)NULL, SBS_VERT | SBS_THUMBSIZE | SBS_AUTOSIZE | WS_VISIBLE, cx, 0, 15, cy, hwndnClient, HWND_TOP, 1L, &scrollerdata, NULL);
223
bleah.yStart = 0;
224
bleah.cEnd = 0;
225
bleah.cx = 0;
226
bleah.attr = -1;
227
VioSetCurType(&bleah, hnvps);
228
update_nicklist(NULL, NULL, NULL);
229
WinStartTimer(0, WinWindowFromID(hwndNicklist, FID_CLIENT), 1, 1000);
230
while (WinGetMsg(hnab, &nqmsg, (HWND)NULL, 0, 0))
231
WinDispatchMsg(hnab, &nqmsg);
232
WinDestroyMsgQueue(hnmq);
233
WinTerminate(hnab);
234
_endthread();
235
}
236
#elif defined(GTK)
237
void gtk_nicklist(void)
238
{
239
gui_mutex_lock();
240
GtkNickList = gtk_window_new(GTK_WINDOW_TOPLEVEL);
241
gtk_window_set_title(GTK_WINDOW(GtkNickList), "Nicks");
242
/*gtk_signal_connect(GTK_OBJECT(GtkNickList), "delete_event", GTK_SIGNAL_FUNC (delete), NULL);*/
243
scrolledwindow = gtk_scrolled_window_new (NULL, NULL);
244
gtk_scrolled_window_set_policy (GTK_SCROLLED_WINDOW (scrolledwindow),
245
GTK_POLICY_AUTOMATIC, GTK_POLICY_ALWAYS);
246
gtk_container_add(GTK_CONTAINER(GtkNickList), scrolledwindow);
247
gtk_widget_show(scrolledwindow);
248
249
clist = gtk_clist_new(1);
250
gtk_container_add(GTK_CONTAINER(scrolledwindow), clist);
251
gtk_widget_show(clist);
252
gtk_widget_show(GtkNickList);
253
gui_mutex_unlock();
254
drawnicklist();
255
}
256
#endif
257
258
BUILT_IN_DLL(nicklist_add)
259
{
260
#ifdef __EMXPM__
261
if(hwndNicklist)
262
WinPostMsg(hwndnClient, WM_CLOSE, 0L, 0L);
263
else
264
_beginthread((void *)nicklist_thread, NULL, 0xFFFF, NULL);
265
#elif defined(GTK)
266
if(GtkNickList)
267
{
268
gui_mutex_lock();
269
gtk_widget_destroy(GtkNickList);
270
GtkNickList = NULL;
271
gui_mutex_unlock();
272
}
273
else
274
gtk_nicklist();
275
#endif
276
}
277
278
int Nicklist_Lock(IrcCommandDll **intp, Function_ptr *global_table)
279
{
280
return 1;
281
}
282
283
int Nicklist_Init(IrcCommandDll **intp, Function_ptr *global_table)
284
{
285
#ifdef GTK
286
/* For paranoia's sake make sure the colors are in the color map */
287
GdkColormap *cmap;
288
#endif
289
initialize_module("Nicklist");
290
291
#ifdef __EMXPM__
292
memset(spaces, ' ', NICKNAME_LEN);
293
spaces[NICKNAME_LEN]=0;
294
#endif
295
296
#ifdef GTK
297
/* gui_mutex_lock();*/
298
cmap = gdk_colormap_get_system();
299
gdk_color_alloc(cmap, &White);
300
gdk_color_alloc(cmap, &Black);
301
/* gui_mutex_unlock();*/
302
#endif
303
304
add_module_proc(COMMAND_PROC, "Nicklist", "nl", "Add a nick list to window", 0, 0, nicklist_add, NULL);
305
add_module_proc(VAR_PROC, "Nicklist", "nl_always_on_top", NULL, BOOL_TYPE_VAR, 0, NULL, NULL);
306
add_module_proc(HOOK_PROC, "Nicklist", NULL, "*", KICK_LIST, 1, NULL, update_nicklist);
307
add_module_proc(HOOK_PROC, "Nicklist", NULL, "*", JOIN_LIST, 1, NULL, update_nicklist);
308
add_module_proc(HOOK_PROC, "Nicklist", NULL, "*", MODE_LIST, 1, NULL, update_nicklist);
309
add_module_proc(HOOK_PROC, "Nicklist", NULL, "*", LEAVE_LIST, 1, NULL, update_nicklist);
310
add_module_proc(HOOK_PROC, "Nicklist", NULL, "*", SIGNOFF_LIST, 1, NULL, update_nicklist);
311
add_module_proc(HOOK_PROC, "Nicklist", NULL, "*", NICKNAME_LIST, 1, NULL, update_nicklist);
312
add_module_proc(HOOK_PROC, "Nicklist", NULL, "*", WINDOW_FOCUS_LIST, 1, NULL, update_nicklist);
313
add_module_proc(HOOK_PROC, "Nicklist", NULL, "*", CHANNEL_SYNCH_LIST, 1, NULL, update_nicklist);
314
add_module_proc(HOOK_PROC, "Nicklist", NULL, "*", CHANNEL_SWITCH_LIST, 1, NULL, update_nicklist);
315
316
return 0;
317
}
318
319
320