comparison plugins/lagmeter.c @ 193:6af9b88e4f90

[gaim-migrate @ 203] Added a plugin to mimic the Lag-O-Meter. Configurable, loadable whenever, does the right thing (tm), etc. Maybe one of these days the Lag-O-Meter will be removed from being statically in gaim. Maybe. committer: Tailor Script <tailor@pidgin.im>
author Eric Warmenhoven <eric@warmenhoven.org>
date Fri, 28 Apr 2000 22:42:20 +0000
parents
children 5f19ec4a91f7
comparison
equal deleted inserted replaced
192:e9ca9146ebf1 193:6af9b88e4f90
1 /* KNOWN BUGS:
2 * if you are also using notify.so, it will open a new window to yourself.
3 * it will not, however, write anything in that window. this is a problem
4 * with notify.c. maybe one day i'll modify notify.c so that these two
5 * plugins are more compatible. we'll see.
6 *
7 * This lagometer has a tendency to not at all show the same lag that the
8 * built-in lagometer shows. My guess as to why this is (because they use the
9 * exact same code) is because it sends the string more often. That's why I
10 * included the configuration option to set the delay between updates.
11 *
12 * You can load this plugin even when you're not signed on, even though it
13 * modifies the buddy list. This is because it checks to see that the buddy
14 * list is actually there. In every case that I've been able to think of so
15 * far, it does the right thing (tm).
16 */
17
18 #define GAIM_PLUGINS
19 #include "gaim.h"
20
21 #include <time.h>
22 #include <sys/types.h>
23 #include <sys/time.h>
24 #include <unistd.h>
25 #include <math.h>
26
27 #define MY_LAG_STRING "ZYXCHECKLAGXYZ"
28
29 void *handle;
30 GtkWidget *lagbox;
31 GtkWidget *my_lagometer;
32 struct timeval my_lag_tv;
33 int check_timeout;
34 guint delay = 10;
35 static GtkWidget *confdlg;
36
37 void update_lag(int us) {
38 double pct;
39
40 if (lagbox == NULL) {
41 /* guess we better build it then :P */
42 GtkWidget *label = gtk_label_new("Lag-O-Meter: ");
43 GList *tmp = gtk_container_children(GTK_CONTAINER(blist));
44 GtkWidget *vbox2 = (GtkWidget *)tmp->data;
45 lagbox = gtk_hbox_new(FALSE, 0);
46 my_lagometer = gtk_progress_bar_new();
47
48 gtk_box_pack_start(GTK_BOX(lagbox), label, FALSE, FALSE, 5);
49 gtk_box_pack_start(GTK_BOX(lagbox), my_lagometer, TRUE, TRUE, 5);
50 gtk_widget_set_usize(my_lagometer, 5, 5);
51
52 gtk_widget_show(label);
53 gtk_widget_show(my_lagometer);
54
55 gtk_box_pack_start(GTK_BOX(vbox2), lagbox, FALSE, TRUE, 0);
56 gtk_box_reorder_child(GTK_BOX(vbox2), lagbox, 1);
57 gtk_widget_show(lagbox);
58 }
59
60 pct = us/100000;
61 if (pct > 0)
62 pct = 25 * log(pct);
63 if (pct < 0)
64 pct = 0;
65 if (pct > 100)
66 pct = 100;
67 pct /= 100;
68
69 gtk_progress_bar_update(GTK_PROGRESS_BAR(my_lagometer), pct);
70 }
71
72 void check_lag(char **who, char **message, void *m) {
73 char *name = g_strdup(normalize(*who));
74 if (!strcasecmp(current_user->username, name) &&
75 !strcmp(*message, MY_LAG_STRING)) {
76 struct timeval tv;
77 int ms;
78
79 gettimeofday(&tv, NULL);
80
81 ms = 1000000 * (tv.tv_sec - my_lag_tv.tv_sec);
82
83 ms += tv.tv_usec - my_lag_tv.tv_usec;
84
85 update_lag(ms);
86 *message = NULL;
87 }
88 g_free(name);
89 }
90
91 void send_lag() {
92 gettimeofday(&my_lag_tv, NULL);
93 serv_send_im(current_user->username, MY_LAG_STRING, 1);
94 }
95
96 void gaim_plugin_remove() {
97 gtk_timeout_remove(check_timeout);
98 if (confdlg)
99 gtk_widget_destroy(confdlg);
100 confdlg = NULL;
101 gtk_widget_destroy(lagbox);
102 }
103
104 void avail_now(void *m) {
105 update_lag(0);
106 gaim_signal_connect(handle, event_im_recv, check_lag, NULL);
107 gaim_signal_connect(handle, event_signoff, gaim_plugin_remove, NULL);
108 check_timeout = gtk_timeout_add(1000 * delay, (GtkFunction)send_lag, NULL);
109 }
110
111 void gaim_plugin_init(void *h) {
112 handle = h;
113
114 if (!blist)
115 gaim_signal_connect(handle, event_signon, avail_now, NULL);
116 else
117 avail_now(NULL);
118 }
119
120 void adjust_timeout(GtkWidget *button, GtkWidget *spinner) {
121 delay = CLAMP(gtk_spin_button_get_value_as_int(
122 GTK_SPIN_BUTTON(spinner)), 0, 3600);
123 sprintf(debug_buff, "new updates: %d\n", delay);
124 debug_print(debug_buff);
125 gtk_timeout_remove(check_timeout);
126 check_timeout = gtk_timeout_add(1000 * delay, (GtkFunction)send_lag, NULL);
127 gtk_widget_destroy(confdlg);
128 confdlg = NULL;
129 }
130
131 void gaim_plugin_config() {
132 GtkWidget *label;
133 GtkAdjustment *adj;
134 GtkWidget *spinner;
135 GtkWidget *button;
136 GtkWidget *box;
137
138 if (confdlg) {
139 gtk_widget_show(confdlg);
140 return;
141 }
142
143 confdlg = gtk_window_new(GTK_WINDOW_DIALOG);
144 gtk_window_set_title(GTK_WINDOW(confdlg), "Gaim Lag Delay");
145
146 box = gtk_hbox_new(FALSE, 0);
147 gtk_container_set_border_width(GTK_CONTAINER(box), 5);
148 gtk_container_add(GTK_CONTAINER(confdlg), box);
149 gtk_widget_show(box);
150
151 label = gtk_label_new("Delay between updates: ");
152 gtk_misc_set_alignment(GTK_MISC(label), 0, 0.5);
153 gtk_box_pack_start(GTK_BOX(box), label, FALSE, TRUE, 0);
154 gtk_widget_show(label);
155
156 adj = (GtkAdjustment *)gtk_adjustment_new(delay, 0, 3600, 1, 0, 0);
157 spinner = gtk_spin_button_new(GTK_ADJUSTMENT(adj), 0, 0);
158 gtk_box_pack_start(GTK_BOX(box), spinner, TRUE, TRUE, 0);
159 gtk_widget_show(spinner);
160
161 button = gtk_button_new_with_label("OK");
162 gtk_signal_connect(GTK_OBJECT(button), "clicked",
163 (GtkSignalFunc)adjust_timeout, spinner);
164 gtk_box_pack_start(GTK_BOX(box), button, FALSE, TRUE, 0);
165 gtk_widget_show(button);
166
167 gtk_widget_show(confdlg);
168 }
169
170 char *name() {
171 return "Lag-O-Meter, Pluggified";
172 }
173
174 char *description() {
175 return "Your old familiar Lag-O-Meter, in a brand new form.";
176 }