Mercurial > pidgin.yaz
annotate finch/gntft.c @ 22048:6704629dc478
Remove the completed/cancelled xfers when 'Clear finished transfers' is selected. (Did anyone notice our 'purple_xfer_is_canceled' is typoed?)
author | Sadrul Habib Chowdhury <imadil@gmail.com> |
---|---|
date | Wed, 09 Jan 2008 08:42:33 +0000 |
parents | c38d72677c8a |
children | 3f7e58ae1305 |
rev | line source |
---|---|
15818 | 1 /** |
2 * @file gntft.c GNT File Transfer UI | |
16194
0f0832c13fcb
Rename the Doxygen group from gntui to finch and define the finch group
Richard Laager <rlaager@wiktel.com>
parents:
15964
diff
changeset
|
3 * @ingroup finch |
20074
6bf32c9e15a7
remove gpl boilerplate from doxygen docs
Sean Egan <seanegan@gmail.com>
parents:
19680
diff
changeset
|
4 */ |
6bf32c9e15a7
remove gpl boilerplate from doxygen docs
Sean Egan <seanegan@gmail.com>
parents:
19680
diff
changeset
|
5 |
6bf32c9e15a7
remove gpl boilerplate from doxygen docs
Sean Egan <seanegan@gmail.com>
parents:
19680
diff
changeset
|
6 /* finch |
15818 | 7 * |
15871
66dff3dfdea6
Re-sed the copyright notices so they don't all talk about Purple.
Richard Laager <rlaager@wiktel.com>
parents:
15823
diff
changeset
|
8 * Finch is the legal property of its developers, whose names are too numerous |
15818 | 9 * to list here. Please refer to the COPYRIGHT file distributed with this |
10 * source distribution. | |
11 * | |
12 * This program is free software; you can redistribute it and/or modify | |
13 * it under the terms of the GNU General Public License as published by | |
14 * the Free Software Foundation; either version 2 of the License, or | |
15 * (at your option) any later version. | |
16 * | |
17 * This program is distributed in the hope that it will be useful, | |
18 * but WITHOUT ANY WARRANTY; without even the implied warranty of | |
19 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
20 * GNU General Public License for more details. | |
21 * | |
22 * You should have received a copy of the GNU General Public License | |
23 * along with this program; if not, write to the Free Software | |
19680
44b4e8bd759b
The FSF changed its address a while ago; our files were out of date.
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
19374
diff
changeset
|
24 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02111-1301 USA |
15818 | 25 */ |
26 #include <gnt.h> | |
27 #include <gntbox.h> | |
28 #include <gntbutton.h> | |
29 #include <gntcheckbox.h> | |
30 #include <gntlabel.h> | |
31 #include <gnttree.h> | |
32 #include "internal.h" | |
33 | |
34 #include "debug.h" | |
35 #include "notify.h" | |
36 #include "ft.h" | |
37 #include "prpl.h" | |
38 #include "util.h" | |
39 | |
40 #include "gntft.h" | |
41 #include "prefs.h" | |
42 | |
15823 | 43 #define FINCHXFER(xfer) \ |
44 (PurpleGntXferUiData *)(xfer)->ui_data | |
15818 | 45 |
46 typedef struct | |
47 { | |
48 gboolean keep_open; | |
49 gboolean auto_clear; | |
50 gint num_transfers; | |
51 | |
52 GntWidget *window; | |
53 GntWidget *tree; | |
54 | |
55 GntWidget *remove_button; | |
56 GntWidget *stop_button; | |
57 GntWidget *close_button; | |
15823 | 58 } PurpleGntXferDialog; |
15818 | 59 |
15823 | 60 static PurpleGntXferDialog *xfer_dialog = NULL; |
15818 | 61 |
62 typedef struct | |
63 { | |
64 time_t last_updated_time; | |
65 gboolean in_list; | |
66 | |
67 char *name; | |
68 | |
15823 | 69 } PurpleGntXferUiData; |
15818 | 70 |
71 enum | |
72 { | |
73 COLUMN_PROGRESS = 0, | |
74 COLUMN_FILENAME, | |
75 COLUMN_SIZE, | |
76 COLUMN_SPEED, | |
77 COLUMN_REMAINING, | |
78 COLUMN_STATUS, | |
79 NUM_COLUMNS | |
80 }; | |
81 | |
82 | |
83 /************************************************************************** | |
84 * Utility Functions | |
85 **************************************************************************/ | |
86 | |
87 static void | |
22007
c38d72677c8a
Probe for -Wstrict-prototypes to get some more warnings. I then cleaned up
Richard Laager <rlaager@wiktel.com>
parents:
20074
diff
changeset
|
88 update_title_progress(void) |
15818 | 89 { |
18118
ab6d2763b8d8
Re-fix the DBus list handling code by killing const GList* / const GSList*
Richard Laager <rlaager@wiktel.com>
parents:
16677
diff
changeset
|
90 GList *list; |
15818 | 91 int num_active_xfers = 0; |
92 guint64 total_bytes_xferred = 0; | |
93 guint64 total_file_size = 0; | |
94 | |
95 if (xfer_dialog == NULL || xfer_dialog->window == NULL) | |
96 return; | |
97 | |
98 /* Find all active transfers */ | |
99 for (list = gnt_tree_get_rows(GNT_TREE(xfer_dialog->tree)); list; list = list->next) { | |
15823 | 100 PurpleXfer *xfer = (PurpleXfer *)list->data; |
15818 | 101 |
15823 | 102 if (purple_xfer_get_status(xfer) == PURPLE_XFER_STATUS_STARTED) { |
15818 | 103 num_active_xfers++; |
15823 | 104 total_bytes_xferred += purple_xfer_get_bytes_sent(xfer); |
105 total_file_size += purple_xfer_get_size(xfer); | |
15818 | 106 } |
107 } | |
108 | |
109 /* Update the title */ | |
110 if (num_active_xfers > 0) { | |
111 gchar *title; | |
112 int total_pct = 0; | |
113 | |
114 if (total_file_size > 0) { | |
115 total_pct = 100 * total_bytes_xferred / total_file_size; | |
116 } | |
117 | |
118 title = g_strdup_printf(_("File Transfers - %d%% of %d files"), | |
119 total_pct, num_active_xfers); | |
120 gnt_screen_rename_widget((xfer_dialog->window), title); | |
121 g_free(title); | |
122 } else { | |
123 gnt_screen_rename_widget((xfer_dialog->window), _("File Transfers")); | |
124 } | |
125 } | |
126 | |
127 | |
128 /************************************************************************** | |
129 * Callbacks | |
130 **************************************************************************/ | |
131 static void | |
132 toggle_keep_open_cb(GntWidget *w) | |
133 { | |
134 xfer_dialog->keep_open = !xfer_dialog->keep_open; | |
16427
4999bbc52881
Works for me! Renames prefs: /core to /purple, /gaim/gtk to /pidgin, /gaim/gnt to /finch
Sean Egan <seanegan@gmail.com>
parents:
16194
diff
changeset
|
135 purple_prefs_set_bool("/finch/filetransfer/keep_open", |
15818 | 136 xfer_dialog->keep_open); |
137 } | |
138 | |
139 static void | |
140 toggle_clear_finished_cb(GntWidget *w) | |
141 { | |
142 xfer_dialog->auto_clear = !xfer_dialog->auto_clear; | |
16427
4999bbc52881
Works for me! Renames prefs: /core to /purple, /gaim/gtk to /pidgin, /gaim/gnt to /finch
Sean Egan <seanegan@gmail.com>
parents:
16194
diff
changeset
|
143 purple_prefs_set_bool("/finch/filetransfer/clear_finished", |
15818 | 144 xfer_dialog->auto_clear); |
22048
6704629dc478
Remove the completed/cancelled xfers when 'Clear finished transfers' is selected. (Did anyone notice our 'purple_xfer_is_canceled' is typoed?)
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
22007
diff
changeset
|
145 if (xfer_dialog->auto_clear) { |
6704629dc478
Remove the completed/cancelled xfers when 'Clear finished transfers' is selected. (Did anyone notice our 'purple_xfer_is_canceled' is typoed?)
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
22007
diff
changeset
|
146 GList *iter = purple_xfers_get_all(); |
6704629dc478
Remove the completed/cancelled xfers when 'Clear finished transfers' is selected. (Did anyone notice our 'purple_xfer_is_canceled' is typoed?)
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
22007
diff
changeset
|
147 while (iter) { |
6704629dc478
Remove the completed/cancelled xfers when 'Clear finished transfers' is selected. (Did anyone notice our 'purple_xfer_is_canceled' is typoed?)
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
22007
diff
changeset
|
148 PurpleXfer *xfer = iter->data; |
6704629dc478
Remove the completed/cancelled xfers when 'Clear finished transfers' is selected. (Did anyone notice our 'purple_xfer_is_canceled' is typoed?)
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
22007
diff
changeset
|
149 iter = iter->next; |
6704629dc478
Remove the completed/cancelled xfers when 'Clear finished transfers' is selected. (Did anyone notice our 'purple_xfer_is_canceled' is typoed?)
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
22007
diff
changeset
|
150 if (purple_xfer_is_completed(xfer) || purple_xfer_is_canceled(xfer)) |
6704629dc478
Remove the completed/cancelled xfers when 'Clear finished transfers' is selected. (Did anyone notice our 'purple_xfer_is_canceled' is typoed?)
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
22007
diff
changeset
|
151 finch_xfer_dialog_remove_xfer(xfer); |
6704629dc478
Remove the completed/cancelled xfers when 'Clear finished transfers' is selected. (Did anyone notice our 'purple_xfer_is_canceled' is typoed?)
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
22007
diff
changeset
|
152 } |
6704629dc478
Remove the completed/cancelled xfers when 'Clear finished transfers' is selected. (Did anyone notice our 'purple_xfer_is_canceled' is typoed?)
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
22007
diff
changeset
|
153 } |
15818 | 154 } |
155 | |
156 static void | |
157 remove_button_cb(GntButton *button) | |
158 { | |
15823 | 159 PurpleXfer *selected_xfer = gnt_tree_get_selection_data(GNT_TREE(xfer_dialog->tree)); |
22048
6704629dc478
Remove the completed/cancelled xfers when 'Clear finished transfers' is selected. (Did anyone notice our 'purple_xfer_is_canceled' is typoed?)
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
22007
diff
changeset
|
160 if (selected_xfer && (purple_xfer_is_completed(selected_xfer) || |
6704629dc478
Remove the completed/cancelled xfers when 'Clear finished transfers' is selected. (Did anyone notice our 'purple_xfer_is_canceled' is typoed?)
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
22007
diff
changeset
|
161 purple_xfer_is_canceled(selected_xfer))) { |
15818 | 162 finch_xfer_dialog_remove_xfer(selected_xfer); |
163 } | |
164 } | |
165 | |
166 static void | |
167 stop_button_cb(GntButton *button) | |
168 { | |
15823 | 169 PurpleXfer *selected_xfer = gnt_tree_get_selection_data(GNT_TREE(xfer_dialog->tree)); |
15942
ee397e53d9ce
allow cancellation of transfers waiting to be accepted
Richard Nelson <wabz@pidgin.im>
parents:
15871
diff
changeset
|
170 if (selected_xfer && selected_xfer->status != PURPLE_XFER_STATUS_CANCEL_LOCAL && |
ee397e53d9ce
allow cancellation of transfers waiting to be accepted
Richard Nelson <wabz@pidgin.im>
parents:
15871
diff
changeset
|
171 selected_xfer->status != PURPLE_XFER_STATUS_CANCEL_REMOTE && |
ee397e53d9ce
allow cancellation of transfers waiting to be accepted
Richard Nelson <wabz@pidgin.im>
parents:
15871
diff
changeset
|
172 selected_xfer->status != PURPLE_XFER_STATUS_DONE) |
15823 | 173 purple_xfer_cancel_local(selected_xfer); |
15818 | 174 } |
175 | |
176 /************************************************************************** | |
177 * Dialog Building Functions | |
178 **************************************************************************/ | |
179 | |
180 | |
181 void | |
182 finch_xfer_dialog_new(void) | |
183 { | |
18118
ab6d2763b8d8
Re-fix the DBus list handling code by killing const GList* / const GSList*
Richard Laager <rlaager@wiktel.com>
parents:
16677
diff
changeset
|
184 GList *iter; |
15818 | 185 GntWidget *window; |
186 GntWidget *bbox; | |
187 GntWidget *button; | |
188 GntWidget *checkbox; | |
189 GntWidget *tree; | |
18404
9a0f99ea664d
Resize tree-columns nicely when the tree is resized. We can tell it to
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
18345
diff
changeset
|
190 int widths[] = {8, 12, 8, 8, 8, 8, -1}; |
15818 | 191 |
192 if (!xfer_dialog) | |
15823 | 193 xfer_dialog = g_new0(PurpleGntXferDialog, 1); |
15818 | 194 |
195 xfer_dialog->keep_open = | |
16427
4999bbc52881
Works for me! Renames prefs: /core to /purple, /gaim/gtk to /pidgin, /gaim/gnt to /finch
Sean Egan <seanegan@gmail.com>
parents:
16194
diff
changeset
|
196 purple_prefs_get_bool("/finch/filetransfer/keep_open"); |
15818 | 197 xfer_dialog->auto_clear = |
16427
4999bbc52881
Works for me! Renames prefs: /core to /purple, /gaim/gtk to /pidgin, /gaim/gnt to /finch
Sean Egan <seanegan@gmail.com>
parents:
16194
diff
changeset
|
198 purple_prefs_get_bool("/finch/filetransfer/clear_finished"); |
15818 | 199 |
200 /* Create the window. */ | |
201 xfer_dialog->window = window = gnt_vbox_new(FALSE); | |
202 g_signal_connect(G_OBJECT(window), "destroy", G_CALLBACK(finch_xfer_dialog_destroy), NULL); | |
203 gnt_box_set_toplevel(GNT_BOX(window), TRUE); | |
204 gnt_box_set_title(GNT_BOX(window), _("File Transfers")); | |
19374
d65ce3df5be2
Make some of the dialogs look and behave more like each other.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
18404
diff
changeset
|
205 gnt_box_set_fill(GNT_BOX(window), TRUE); |
d65ce3df5be2
Make some of the dialogs look and behave more like each other.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
18404
diff
changeset
|
206 gnt_box_set_alignment(GNT_BOX(window), GNT_ALIGN_MID); |
15818 | 207 |
208 xfer_dialog->tree = tree = gnt_tree_new_with_columns(NUM_COLUMNS); | |
209 gnt_tree_set_column_titles(GNT_TREE(tree), _("Progress"), _("Filename"), _("Size"), _("Speed"), _("Remaining"), _("Status")); | |
18404
9a0f99ea664d
Resize tree-columns nicely when the tree is resized. We can tell it to
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
18345
diff
changeset
|
210 gnt_tree_set_column_width_ratio(GNT_TREE(tree), widths); |
9a0f99ea664d
Resize tree-columns nicely when the tree is resized. We can tell it to
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
18345
diff
changeset
|
211 gnt_tree_set_column_resizable(GNT_TREE(tree), COLUMN_PROGRESS, FALSE); |
9a0f99ea664d
Resize tree-columns nicely when the tree is resized. We can tell it to
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
18345
diff
changeset
|
212 gnt_tree_set_column_resizable(GNT_TREE(tree), COLUMN_SIZE, FALSE); |
9a0f99ea664d
Resize tree-columns nicely when the tree is resized. We can tell it to
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
18345
diff
changeset
|
213 gnt_tree_set_column_resizable(GNT_TREE(tree), COLUMN_SPEED, FALSE); |
9a0f99ea664d
Resize tree-columns nicely when the tree is resized. We can tell it to
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
18345
diff
changeset
|
214 gnt_tree_set_column_resizable(GNT_TREE(tree), COLUMN_REMAINING, FALSE); |
9a0f99ea664d
Resize tree-columns nicely when the tree is resized. We can tell it to
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
18345
diff
changeset
|
215 gnt_widget_set_size(tree, 70, -1); |
15818 | 216 gnt_tree_set_show_title(GNT_TREE(tree), TRUE); |
217 gnt_box_add_widget(GNT_BOX(window), tree); | |
15942
ee397e53d9ce
allow cancellation of transfers waiting to be accepted
Richard Nelson <wabz@pidgin.im>
parents:
15871
diff
changeset
|
218 |
15818 | 219 checkbox = gnt_check_box_new( _("Close this window when all transfers finish")); |
220 gnt_check_box_set_checked(GNT_CHECK_BOX(checkbox), | |
221 !xfer_dialog->keep_open); | |
222 g_signal_connect(G_OBJECT(checkbox), "toggled", | |
223 G_CALLBACK(toggle_keep_open_cb), NULL); | |
224 gnt_box_add_widget(GNT_BOX(window), checkbox); | |
225 | |
226 checkbox = gnt_check_box_new(_("Clear finished transfers")); | |
227 gnt_check_box_set_checked(GNT_CHECK_BOX(checkbox), | |
228 xfer_dialog->auto_clear); | |
229 g_signal_connect(G_OBJECT(checkbox), "toggled", | |
230 G_CALLBACK(toggle_clear_finished_cb), NULL); | |
231 gnt_box_add_widget(GNT_BOX(window), checkbox); | |
232 | |
19374
d65ce3df5be2
Make some of the dialogs look and behave more like each other.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
18404
diff
changeset
|
233 bbox = gnt_hbox_new(FALSE); |
15818 | 234 |
235 xfer_dialog->remove_button = button = gnt_button_new(_("Remove")); | |
236 g_signal_connect(G_OBJECT(button), "activate", | |
237 G_CALLBACK(remove_button_cb), NULL); | |
238 gnt_box_add_widget(GNT_BOX(bbox), button); | |
239 | |
240 xfer_dialog->stop_button = button = gnt_button_new(_("Stop")); | |
241 g_signal_connect(G_OBJECT(button), "activate", | |
242 G_CALLBACK(stop_button_cb), NULL); | |
243 gnt_box_add_widget(GNT_BOX(bbox), button); | |
244 | |
245 xfer_dialog->close_button = button = gnt_button_new(_("Close")); | |
246 g_signal_connect(G_OBJECT(button), "activate", | |
247 G_CALLBACK(finch_xfer_dialog_destroy), NULL); | |
248 gnt_box_add_widget(GNT_BOX(bbox), button); | |
249 | |
250 gnt_box_add_widget(GNT_BOX(window), bbox); | |
251 | |
15823 | 252 for (iter = purple_xfers_get_all(); iter; iter = iter->next) { |
253 PurpleXfer *xfer = (PurpleXfer *)iter->data; | |
254 PurpleGntXferUiData *data = FINCHXFER(xfer); | |
15818 | 255 if (data->in_list) { |
256 finch_xfer_dialog_add_xfer(xfer); | |
257 finch_xfer_dialog_update_xfer(xfer); | |
258 gnt_tree_set_selected(GNT_TREE(tree), xfer); | |
259 } | |
260 } | |
261 gnt_widget_show(xfer_dialog->window); | |
262 } | |
263 | |
264 void | |
265 finch_xfer_dialog_destroy() | |
266 { | |
267 gnt_widget_destroy(xfer_dialog->window); | |
268 g_free(xfer_dialog); | |
269 xfer_dialog = NULL; | |
270 } | |
271 | |
272 void | |
273 finch_xfer_dialog_show() | |
274 { | |
275 if (xfer_dialog == NULL) | |
276 finch_xfer_dialog_new(); | |
18345
2d4df5ef0090
If the action-windows are already there, then bring them to front when
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
18129
diff
changeset
|
277 else |
2d4df5ef0090
If the action-windows are already there, then bring them to front when
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
18129
diff
changeset
|
278 gnt_window_present(xfer_dialog->window); |
15818 | 279 } |
280 | |
281 void | |
15823 | 282 finch_xfer_dialog_add_xfer(PurpleXfer *xfer) |
15818 | 283 { |
15823 | 284 PurpleGntXferUiData *data; |
285 PurpleXferType type; | |
15818 | 286 char *size_str, *remaining_str; |
287 char *lfilename, *utf8; | |
288 | |
289 g_return_if_fail(xfer_dialog != NULL); | |
290 g_return_if_fail(xfer != NULL); | |
291 | |
15823 | 292 purple_xfer_ref(xfer); |
15818 | 293 |
15823 | 294 data = FINCHXFER(xfer); |
15818 | 295 data->in_list = TRUE; |
296 | |
297 finch_xfer_dialog_show(); | |
298 | |
299 data->last_updated_time = 0; | |
300 | |
15823 | 301 type = purple_xfer_get_type(xfer); |
15818 | 302 |
15823 | 303 size_str = purple_str_size_to_units(purple_xfer_get_size(xfer)); |
304 remaining_str = purple_str_size_to_units(purple_xfer_get_bytes_remaining(xfer)); | |
15818 | 305 |
15823 | 306 lfilename = g_path_get_basename(purple_xfer_get_local_filename(xfer)); |
15818 | 307 utf8 = g_filename_to_utf8(lfilename, -1, NULL, NULL, NULL); |
308 g_free(lfilename); | |
309 lfilename = utf8; | |
310 gnt_tree_add_row_last(GNT_TREE(xfer_dialog->tree), xfer, | |
311 gnt_tree_create_row(GNT_TREE(xfer_dialog->tree), | |
15823 | 312 "0.0", (type == PURPLE_XFER_RECEIVE) ? purple_xfer_get_filename(xfer) : lfilename, |
15818 | 313 size_str, "0.0", "",_("Waiting for transfer to begin")), NULL); |
314 g_free(lfilename); | |
315 | |
316 g_free(size_str); | |
317 g_free(remaining_str); | |
318 | |
319 xfer_dialog->num_transfers++; | |
320 | |
321 update_title_progress(); | |
322 } | |
323 | |
324 void | |
15823 | 325 finch_xfer_dialog_remove_xfer(PurpleXfer *xfer) |
15818 | 326 { |
15823 | 327 PurpleGntXferUiData *data; |
15818 | 328 |
329 g_return_if_fail(xfer_dialog != NULL); | |
330 g_return_if_fail(xfer != NULL); | |
331 | |
15823 | 332 data = FINCHXFER(xfer); |
15818 | 333 |
334 if (data == NULL) | |
335 return; | |
336 | |
337 if (!data->in_list) | |
338 return; | |
339 | |
340 data->in_list = FALSE; | |
341 | |
342 gnt_tree_remove(GNT_TREE(xfer_dialog->tree), xfer); | |
343 | |
344 xfer_dialog->num_transfers--; | |
345 | |
346 if (xfer_dialog->num_transfers == 0 && !xfer_dialog->keep_open) | |
347 finch_xfer_dialog_destroy(); | |
348 else | |
349 update_title_progress(); | |
15823 | 350 purple_xfer_unref(xfer); |
15818 | 351 } |
352 | |
353 void | |
15823 | 354 finch_xfer_dialog_cancel_xfer(PurpleXfer *xfer) |
15818 | 355 { |
15823 | 356 PurpleGntXferUiData *data; |
15818 | 357 const gchar *status; |
358 | |
359 g_return_if_fail(xfer_dialog != NULL); | |
360 g_return_if_fail(xfer != NULL); | |
361 | |
15823 | 362 data = FINCHXFER(xfer); |
15818 | 363 |
364 if (data == NULL) | |
365 return; | |
366 | |
367 if (!data->in_list) | |
368 return; | |
369 | |
15823 | 370 if ((purple_xfer_get_status(xfer) == PURPLE_XFER_STATUS_CANCEL_LOCAL) && (xfer_dialog->auto_clear)) { |
15818 | 371 finch_xfer_dialog_remove_xfer(xfer); |
372 return; | |
373 } | |
374 | |
15823 | 375 data = FINCHXFER(xfer); |
15818 | 376 |
377 update_title_progress(); | |
378 | |
15823 | 379 if (purple_xfer_is_canceled(xfer)) |
15818 | 380 status = _("Canceled"); |
381 else | |
382 status = _("Failed"); | |
383 | |
384 gnt_tree_change_text(GNT_TREE(xfer_dialog->tree), xfer, COLUMN_STATUS, status); | |
385 } | |
386 | |
387 void | |
15823 | 388 finch_xfer_dialog_update_xfer(PurpleXfer *xfer) |
15818 | 389 { |
15823 | 390 PurpleGntXferUiData *data; |
15818 | 391 char *size_str, *remaining_str; |
392 time_t current_time; | |
393 char prog_str[5]; | |
394 double kb_sent, kb_rem; | |
395 double kbps = 0.0; | |
396 time_t elapsed, now; | |
397 char *kbsec; | |
398 | |
399 if (xfer->end_time != 0) | |
400 now = xfer->end_time; | |
401 else | |
402 now = time(NULL); | |
403 | |
15823 | 404 kb_sent = purple_xfer_get_bytes_sent(xfer) / 1024.0; |
405 kb_rem = purple_xfer_get_bytes_remaining(xfer) / 1024.0; | |
15818 | 406 elapsed = (xfer->start_time > 0 ? now - xfer->start_time : 0); |
407 kbps = (elapsed > 0 ? (kb_sent / elapsed) : 0); | |
408 | |
409 g_return_if_fail(xfer_dialog != NULL); | |
410 g_return_if_fail(xfer != NULL); | |
411 | |
15823 | 412 if ((data = FINCHXFER(xfer)) == NULL) |
15818 | 413 return; |
414 | |
415 if (data->in_list == FALSE) | |
416 return; | |
417 | |
418 current_time = time(NULL); | |
419 if (((current_time - data->last_updated_time) == 0) && | |
15823 | 420 (!purple_xfer_is_completed(xfer))) { |
15818 | 421 /* Don't update the window more than once per second */ |
422 return; | |
423 } | |
424 data->last_updated_time = current_time; | |
425 | |
15823 | 426 size_str = purple_str_size_to_units(purple_xfer_get_size(xfer)); |
427 remaining_str = purple_str_size_to_units(purple_xfer_get_bytes_remaining(xfer)); | |
18129
16f3919b78f5
Use the IEC binary units to match our math.
Richard Laager <rlaager@wiktel.com>
parents:
18118
diff
changeset
|
428 kbsec = g_strdup_printf(_("%.2f KiB/s"), kbps); |
15818 | 429 |
430 gnt_tree_change_text(GNT_TREE(xfer_dialog->tree), xfer, COLUMN_PROGRESS, | |
15823 | 431 g_ascii_dtostr(prog_str, sizeof(prog_str), purple_xfer_get_progress(xfer) * 100.)); |
15818 | 432 gnt_tree_change_text(GNT_TREE(xfer_dialog->tree), xfer, COLUMN_SIZE, size_str); |
433 gnt_tree_change_text(GNT_TREE(xfer_dialog->tree), xfer, COLUMN_REMAINING, remaining_str); | |
434 gnt_tree_change_text(GNT_TREE(xfer_dialog->tree), xfer, COLUMN_SPEED, kbsec); | |
435 g_free(size_str); | |
436 g_free(remaining_str); | |
15964 | 437 g_free(kbsec); |
15823 | 438 if (purple_xfer_is_completed(xfer)) { |
19374
d65ce3df5be2
Make some of the dialogs look and behave more like each other.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
18404
diff
changeset
|
439 char *msg = g_strdup_printf(_("The file was saved as %s."), purple_xfer_get_local_filename(xfer)); |
15818 | 440 gnt_tree_change_text(GNT_TREE(xfer_dialog->tree), xfer, COLUMN_STATUS, _("Finished")); |
15942
ee397e53d9ce
allow cancellation of transfers waiting to be accepted
Richard Nelson <wabz@pidgin.im>
parents:
15871
diff
changeset
|
441 gnt_tree_change_text(GNT_TREE(xfer_dialog->tree), xfer, COLUMN_REMAINING, _("Finished")); |
19374
d65ce3df5be2
Make some of the dialogs look and behave more like each other.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
18404
diff
changeset
|
442 purple_xfer_conversation_write(xfer, msg, FALSE); |
d65ce3df5be2
Make some of the dialogs look and behave more like each other.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
18404
diff
changeset
|
443 g_free(msg); |
15818 | 444 } else { |
445 gnt_tree_change_text(GNT_TREE(xfer_dialog->tree), xfer, COLUMN_STATUS, _("Transferring")); | |
446 } | |
447 | |
448 update_title_progress(); | |
449 | |
15823 | 450 if (purple_xfer_is_completed(xfer) && xfer_dialog->auto_clear) |
15818 | 451 finch_xfer_dialog_remove_xfer(xfer); |
452 } | |
453 | |
454 /************************************************************************** | |
455 * File Transfer UI Ops | |
456 **************************************************************************/ | |
457 static void | |
15823 | 458 finch_xfer_new_xfer(PurpleXfer *xfer) |
15818 | 459 { |
15823 | 460 PurpleGntXferUiData *data; |
15818 | 461 |
462 /* This is where we're setting xfer->ui_data for the first time. */ | |
15823 | 463 data = g_new0(PurpleGntXferUiData, 1); |
15818 | 464 xfer->ui_data = data; |
465 } | |
466 | |
467 static void | |
15823 | 468 finch_xfer_destroy(PurpleXfer *xfer) |
15818 | 469 { |
15823 | 470 PurpleGntXferUiData *data; |
15818 | 471 |
15823 | 472 data = FINCHXFER(xfer); |
15818 | 473 if (data) { |
474 g_free(data->name); | |
475 g_free(data); | |
476 xfer->ui_data = NULL; | |
477 } | |
478 } | |
479 | |
480 static void | |
15823 | 481 finch_xfer_add_xfer(PurpleXfer *xfer) |
15818 | 482 { |
483 if (!xfer_dialog) | |
484 finch_xfer_dialog_new(); | |
485 | |
486 finch_xfer_dialog_add_xfer(xfer); | |
487 gnt_tree_set_selected(GNT_TREE(xfer_dialog->tree), xfer); | |
488 } | |
489 | |
490 static void | |
15823 | 491 finch_xfer_update_progress(PurpleXfer *xfer, double percent) |
15818 | 492 { |
493 if (xfer_dialog) | |
494 finch_xfer_dialog_update_xfer(xfer); | |
495 } | |
496 | |
497 static void | |
15823 | 498 finch_xfer_cancel_local(PurpleXfer *xfer) |
15818 | 499 { |
500 if (xfer_dialog) | |
501 finch_xfer_dialog_cancel_xfer(xfer); | |
502 } | |
503 | |
504 static void | |
15823 | 505 finch_xfer_cancel_remote(PurpleXfer *xfer) |
15818 | 506 { |
507 if (xfer_dialog) | |
508 finch_xfer_dialog_cancel_xfer(xfer); | |
509 } | |
510 | |
15823 | 511 static PurpleXferUiOps ops = |
15818 | 512 { |
513 finch_xfer_new_xfer, | |
514 finch_xfer_destroy, | |
515 finch_xfer_add_xfer, | |
516 finch_xfer_update_progress, | |
517 finch_xfer_cancel_local, | |
16677
30829e806dae
And finch is up to date
Gary Kramlich <grim@reaperworld.com>
parents:
16427
diff
changeset
|
518 finch_xfer_cancel_remote, |
30829e806dae
And finch is up to date
Gary Kramlich <grim@reaperworld.com>
parents:
16427
diff
changeset
|
519 |
30829e806dae
And finch is up to date
Gary Kramlich <grim@reaperworld.com>
parents:
16427
diff
changeset
|
520 /* padding */ |
30829e806dae
And finch is up to date
Gary Kramlich <grim@reaperworld.com>
parents:
16427
diff
changeset
|
521 NULL, |
30829e806dae
And finch is up to date
Gary Kramlich <grim@reaperworld.com>
parents:
16427
diff
changeset
|
522 NULL, |
30829e806dae
And finch is up to date
Gary Kramlich <grim@reaperworld.com>
parents:
16427
diff
changeset
|
523 NULL, |
30829e806dae
And finch is up to date
Gary Kramlich <grim@reaperworld.com>
parents:
16427
diff
changeset
|
524 NULL |
15818 | 525 }; |
526 | |
527 /************************************************************************** | |
528 * GNT File Transfer API | |
529 **************************************************************************/ | |
530 void | |
531 finch_xfers_init(void) | |
532 { | |
16427
4999bbc52881
Works for me! Renames prefs: /core to /purple, /gaim/gtk to /pidgin, /gaim/gnt to /finch
Sean Egan <seanegan@gmail.com>
parents:
16194
diff
changeset
|
533 purple_prefs_add_none("/finch/filetransfer"); |
4999bbc52881
Works for me! Renames prefs: /core to /purple, /gaim/gtk to /pidgin, /gaim/gnt to /finch
Sean Egan <seanegan@gmail.com>
parents:
16194
diff
changeset
|
534 purple_prefs_add_bool("/finch/filetransfer/clear_finished", TRUE); |
4999bbc52881
Works for me! Renames prefs: /core to /purple, /gaim/gtk to /pidgin, /gaim/gnt to /finch
Sean Egan <seanegan@gmail.com>
parents:
16194
diff
changeset
|
535 purple_prefs_add_bool("/finch/filetransfer/keep_open", FALSE); |
15818 | 536 } |
537 | |
538 void | |
539 finch_xfers_uninit(void) | |
540 { | |
541 if (xfer_dialog != NULL) | |
542 finch_xfer_dialog_destroy(); | |
543 } | |
544 | |
15823 | 545 PurpleXferUiOps * |
15818 | 546 finch_xfers_get_ui_ops(void) |
547 { | |
548 return &ops; | |
549 } |