Mercurial > pidgin
annotate plugins/raw.c @ 4141:ccec4fde84f4
[gaim-migrate @ 4359]
The last in Ari's never-ending memory leak fixes.
committer: Tailor Script <tailor@pidgin.im>
author | Christian Hammond <chipx86@chipx86.com> |
---|---|
date | Wed, 25 Dec 2002 05:30:08 +0000 |
parents | cd938f18f3f8 |
children | 07a3d1fae88f |
rev | line source |
---|---|
2495 | 1 #define GAIM_PLUGINS |
2 #include "gaim.h" | |
3 #include "prpl.h" | |
4 #ifdef MAX | |
5 #undef MAX | |
6 #undef MIN | |
7 #endif | |
2824
2c39e70dd07c
[gaim-migrate @ 2837]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2495
diff
changeset
|
8 #include "protocols/jabber/jabber.h" |
2495 | 9 |
10 static GtkWidget *window = NULL; | |
11 static GtkWidget *optmenu = NULL; | |
12 static struct gaim_connection *gc = NULL; | |
13 static GModule *me = NULL; | |
14 | |
15 /* this is an evil hack. | |
16 * gc->proto_data for Jabber connections can be cast to a jconn *. | |
17 * gc->proto_data for MSN, TOC, and IRC connections can be cast to an int *. | |
18 */ | |
19 | |
3551 | 20 struct gaim_plugin_description desc; |
21 struct gaim_plugin_description *gaim_plugin_desc() { | |
22 desc.api_version = PLUGIN_API_VERSION; | |
23 desc.name = g_strdup("Raw Input"); | |
24 desc.version = g_strdup(VERSION); | |
25 desc.description = g_strdup("Lets you send raw input to text-vased protocols (Jabber, MSN, IRC, TOC). Hit 'Enter' in the entry box to send. Watch the debug window."); | |
26 desc.authors = g_strdup("Eric Warmehoven <eric@warmenhoven.org>"); | |
27 desc.url = g_strdup(WEBSITE); | |
28 return &desc; | |
29 } | |
30 | |
31 | |
2495 | 32 char *name() |
33 { | |
34 return "Raw"; | |
35 } | |
36 | |
37 char *description() | |
38 { | |
39 return "Lets you send raw XML to Jabber, or raw commands to MSN, IRC, and TOC." | |
40 " Not very useful except for debugging. Hit 'enter' in the entry to send." | |
41 " Watch the debug window."; | |
42 } | |
43 | |
44 static int goodbye() | |
45 { | |
46 gaim_plugin_unload(me); | |
47 return FALSE; | |
48 } | |
49 | |
50 static void send_it(GtkEntry *entry) | |
51 { | |
52 char *txt; | |
53 if (!gc) return; | |
54 txt = gtk_entry_get_text(entry); | |
55 switch (gc->protocol) { | |
56 case PROTO_TOC: | |
57 { | |
58 int *a = (int *)gc->proto_data; | |
59 unsigned short seqno = htons(a[1]++ & 0xffff); | |
60 unsigned short len = htons(strlen(txt) + 1); | |
61 write(*a, "*\002", 2); | |
62 write(*a, &seqno, 2); | |
63 write(*a, &len, 2); | |
64 write(*a, txt, ntohs(len)); | |
65 debug_printf("TOC C: %s\n", txt); | |
66 } | |
67 break; | |
68 case PROTO_MSN: | |
69 write(*(int *)gc->proto_data, txt, strlen(txt)); | |
70 write(*(int *)gc->proto_data, "\r\n", 2); | |
71 debug_printf("MSN C: %s\n", txt); | |
72 break; | |
73 case PROTO_IRC: | |
74 write(*(int *)gc->proto_data, txt, strlen(txt)); | |
75 write(*(int *)gc->proto_data, "\r\n", 2); | |
76 debug_printf("IRC C: %s\n", txt); | |
77 break; | |
78 case PROTO_JABBER: | |
79 jab_send_raw(*(jconn *)gc->proto_data, txt); | |
80 break; | |
81 } | |
82 gtk_entry_set_text(entry, ""); | |
83 } | |
84 | |
85 static void set_gc(gpointer d, struct gaim_connection *c) | |
86 { | |
87 gc = c; | |
88 } | |
89 | |
90 static void redo_optmenu(struct gaim_connection *arg, gpointer x) | |
91 { | |
92 GtkWidget *menu; | |
93 GSList *g = connections; | |
94 struct gaim_connection *c; | |
95 | |
96 menu = gtk_menu_new(); | |
97 gc = NULL; | |
98 | |
99 while (g) { | |
100 char buf[256]; | |
101 GtkWidget *opt; | |
102 c = (struct gaim_connection *)g->data; | |
103 g = g->next; | |
104 if (x && c == arg) | |
105 continue; | |
106 if (c->protocol != PROTO_TOC && c->protocol != PROTO_MSN && | |
107 c->protocol != PROTO_IRC && c->protocol != PROTO_JABBER) | |
108 continue; | |
109 if (!gc) | |
110 gc = c; | |
111 g_snprintf(buf, sizeof buf, "%s (%s)", c->username, (*c->prpl->name)()); | |
112 opt = gtk_menu_item_new_with_label(buf); | |
113 gtk_signal_connect(GTK_OBJECT(opt), "activate", GTK_SIGNAL_FUNC(set_gc), c); | |
114 gtk_widget_show(opt); | |
115 gtk_menu_append(GTK_MENU(menu), opt); | |
116 } | |
117 | |
118 gtk_option_menu_remove_menu(GTK_OPTION_MENU(optmenu)); | |
119 gtk_option_menu_set_menu(GTK_OPTION_MENU(optmenu), menu); | |
120 gtk_option_menu_set_history(GTK_OPTION_MENU(optmenu), 0); | |
121 } | |
122 | |
123 char *gaim_plugin_init(GModule *h) | |
124 { | |
125 GtkWidget *hbox; | |
126 GtkWidget *entry; | |
127 | |
128 me = h; | |
129 | |
130 gaim_signal_connect(h, event_signon, redo_optmenu, NULL); | |
131 gaim_signal_connect(h, event_signoff, redo_optmenu, me); | |
132 | |
133 window = gtk_window_new(GTK_WINDOW_TOPLEVEL); | |
134 gtk_signal_connect(GTK_OBJECT(window), "delete_event", GTK_SIGNAL_FUNC(goodbye), NULL); | |
135 | |
136 hbox = gtk_hbox_new(FALSE, 0); | |
137 gtk_container_add(GTK_CONTAINER(window), hbox); | |
138 | |
139 optmenu = gtk_option_menu_new(); | |
140 gtk_box_pack_start(GTK_BOX(hbox), optmenu, FALSE, FALSE, 5); | |
141 | |
142 redo_optmenu(NULL, NULL); | |
143 | |
144 entry = gtk_entry_new(); | |
145 gtk_box_pack_start(GTK_BOX(hbox), entry, FALSE, FALSE, 5); | |
146 gtk_signal_connect(GTK_OBJECT(entry), "activate", GTK_SIGNAL_FUNC(send_it), NULL); | |
147 | |
148 gtk_widget_show_all(window); | |
149 | |
150 return NULL; | |
151 } | |
152 | |
153 void gaim_plugin_remove() | |
154 { | |
155 if (window) | |
156 gtk_widget_destroy(window); | |
157 window = NULL; | |
158 me = NULL; | |
159 } |