12 #include "callbacks.h"
13 #include "interface.h"
16 #define KEY_Enter 65293
18 #define KEY_Down 65364
19 #define KEY_Left 65361
20 #define KEY_Right 65363
22 void terminate_console(int sig);
24 extern "C" gint compare_func(const void *data1, const void *data2);
27 on_console_delete_event(GtkWidget *widget, GdkEvent *event, gpointer user_data)
35 on_connect_activate(GtkMenuItem *menuitem, gpointer user_data)
37 if (connect_to_director(user_data)) {
38 start_director_reader(user_data);
44 on_disconnect_activate(GtkMenuItem *menuitem, gpointer user_data)
46 if (disconnect_from_director(user_data)) {
47 stop_director_reader(user_data);
53 on_exit_activate(GtkMenuItem *menuitem, gpointer user_data)
60 on_cut1_activate(GtkMenuItem *menuitem, gpointer user_data)
67 on_copy1_activate(GtkMenuItem *menuitem, gpointer user_data)
74 on_paste1_activate(GtkMenuItem *menuitem, gpointer user_data)
81 on_clear1_activate(GtkMenuItem *menuitem, gpointer user_data)
87 on_preferences1_activate(GtkMenuItem *menuitem, gpointer user_data)
93 on_about_activate(GtkMenuItem *menuitem, gpointer user_data)
95 gtk_widget_show(about1);
101 on_connect_button_clicked(GtkButton *button, gpointer user_data)
103 if (connect_to_director(user_data)) {
104 start_director_reader(user_data);
108 /* Define max length of history and how many to delete when it gets there.
109 * If you make HIST_DEL > HIST_MAX, you shoot yourself in the foot.
111 #define HIST_MAX 2500
114 static GList *hist = NULL;
115 static GList *hc = NULL;
116 static int hist_len = 0;
118 static void add_to_history(gchar *ecmd)
120 int len = strlen(ecmd);
123 hist = g_list_append(hist, bstrdup(ecmd));
126 if (hist_len >= HIST_MAX) {
129 for (i=0; i<HIST_DEL; i++) {
130 hp = g_list_next(hist);
132 hist = g_list_remove(hist, hp->data);
134 hist_len -= HIST_DEL;
140 * Note, apparently there is a bug in GNOME where some of the
141 * key press events are lost -- at least it loses every other
145 on_entry1_key_press_event(GtkWidget *widget, GdkEventKey *event, gpointer user_data)
147 if (event->keyval == KEY_Enter) {
148 char *ecmd = (char *)gtk_entry_get_text((GtkEntry *)entry1);
149 set_text(ecmd, strlen(ecmd));
151 add_to_history(ecmd);
152 write_director(ecmd);
153 gtk_entry_set_text((GtkEntry *)entry1, "");
154 } else if (event->keyval == KEY_Up) {
159 hc = g_list_last(hist);
161 hc = g_list_previous(hc);
167 hc = g_list_first(hist);
169 gtk_entry_set_text((GtkEntry *)entry1, (gchar *)hc->data);
170 } else if (event->keyval == KEY_Down) {
175 hc = g_list_first(hist);
177 hc = g_list_next(hc);
183 hc = g_list_last(hist);
185 gtk_entry_set_text((GtkEntry *)entry1, (gchar *)hc->data);
187 // gtk_entry_set_position((GtkEntry *)entry1, -1);
188 // gtk_window_set_focus((GtkWindow *)app1, entry1);
194 on_app1_show(GtkWidget *widget, gpointer user_data)
201 on_msgs_button_clicked(GtkButton *button, gpointer user_data)
203 write_director("messages");
207 on_msgs_activate(GtkMenuItem *menuitem, gpointer user_data)
209 write_director("messages");
213 on_about_button_clicked(GtkButton *button, gpointer user_data)
215 gtk_widget_hide(about1);
221 on_select_director_OK_clicked(GtkButton *button, gpointer user_data)
224 gtk_widget_hide(dir_dialog);
231 on_select_director_cancel_clicked(GtkButton *button, gpointer user_data)
234 gtk_widget_hide(dir_dialog);
240 * Compare list string items
243 gint compare_func(const void *data1, const void *data2)
245 return strcmp((const char *)data1, (const char *)data2);
248 static GList *find_combo_list(char *name)
250 if (strcmp(name, "job") == 0) {
253 if (strcmp(name, "pool") == 0) {
256 if (strcmp(name, "client") == 0) {
259 if (strcmp(name, "storage") == 0) {
262 if (strcmp(name, "fileset") == 0) {
265 if (strcmp(name, "messages") == 0) {
266 return messages_list;
268 if (strcmp(name, "type") == 0) {
271 if (strcmp(name, "level") == 0) {
278 * Set correct default values in the Run dialog box
280 static void set_run_defaults()
282 GtkWidget *combo, *entry;
288 stop_director_reader(NULL);
290 combo = lookup_widget(run_dialog, "combo_job");
291 job = (char *)gtk_entry_get_text(GTK_ENTRY(GTK_COMBO(combo)->entry));
292 bsnprintf(cmd, sizeof(cmd), ".defaults job=\"%s\"", job);
294 while (bnet_recv(UA_sock) > 0) {
295 def = strchr(UA_sock->msg, '=');
300 if (strcmp(UA_sock->msg, "job") == 0 ||
301 strcmp(UA_sock->msg, "when") == 0) {
304 /* Where is an entry box */
305 if (strcmp(UA_sock->msg, "where") == 0) {
306 entry = lookup_widget(run_dialog, "entry_where");
307 gtk_entry_set_text(GTK_ENTRY(entry), def);
311 /* Now handle combo boxes */
312 list = find_combo_list(UA_sock->msg);
316 item = g_list_find_custom(list, def, compare_func);
317 bsnprintf(cmd, sizeof(cmd), "combo_%s", UA_sock->msg);
318 combo = lookup_widget(run_dialog, cmd);
322 pos = g_list_position(list, item);
323 gtk_list_select_item(GTK_LIST(GTK_COMBO(combo)->list), pos);
325 start_director_reader(NULL);
329 on_entry_job_changed(GtkEditable *editable, gpointer user_data)
336 on_run_button_clicked(GtkButton *button, gpointer user_data)
341 bstrutime(dt, sizeof(dt), time(NULL));
342 entry = lookup_widget(run_dialog, "entry_when");
343 gtk_entry_set_text(GTK_ENTRY(entry), dt);
345 gtk_widget_show(run_dialog);
350 static char *get_combo_text(GtkWidget *dialog, const char *combo_name)
353 combo = lookup_widget(dialog, combo_name);
357 return (char *)gtk_entry_get_text(GTK_ENTRY(GTK_COMBO(combo)->entry));
360 static char *get_entry_text(GtkWidget *dialog, const char *entry_name)
363 entry = lookup_widget(dialog, entry_name);
367 return (char *)gtk_entry_get_text(GTK_ENTRY(entry));
370 static char *get_spin_text(GtkWidget *dialog, const char *spin_name)
373 spin = (GtkSpinButton *)lookup_widget(dialog, spin_name);
377 return (char *)gtk_entry_get_text(GTK_ENTRY(&spin->entry));
384 on_run_ok_clicked(GtkButton *button, gpointer user_data)
386 char *job, *fileset, *level, *client, *pool, *when, *where, *storage;
388 gtk_widget_hide(run_dialog);
391 job = get_combo_text(run_dialog, "combo_job");
392 fileset = get_combo_text(run_dialog, "combo_fileset");
393 client = get_combo_text(run_dialog, "combo_client");
394 pool = get_combo_text(run_dialog, "combo_pool");
395 storage = get_combo_text(run_dialog, "combo_storage");
396 level = get_combo_text(run_dialog, "combo_level");
398 when = get_entry_text(run_dialog, "entry_when");
399 where = get_entry_text(run_dialog, "entry_where");
401 if (!job || !fileset || !client || !pool || !storage ||
402 !level || !when || !where) {
407 bsnprintf(cmd, sizeof(cmd),
408 "run job=\"%s\" fileset=\"%s\" level=%s client=\"%s\" pool=\"%s\" "
409 "when=\"%s\" where=\"%s\" storage=\"%s\"",
410 job, fileset, level, client, pool, when, where, storage);
412 set_text(cmd, strlen(cmd));
413 write_director("yes");
419 on_run_cancel_clicked(GtkButton *button, gpointer user_data)
421 gtk_widget_hide(run_dialog);
427 on_entry1_key_release_event(GtkWidget *widget, GdkEventKey *event, gpointer user_data)
433 on_restore_button_clicked(GtkButton *button, gpointer user_data)
435 gtk_widget_show(restore_dialog);
440 on_view_fileset_clicked(GtkButton *button, gpointer user_data)
446 on_restore_cancel_clicked(GtkButton *button, gpointer user_data)
448 gtk_widget_hide(restore_dialog);
455 on_label_button_clicked(GtkButton *button, gpointer user_data)
457 gtk_widget_show(label_dialog);
462 on_label_ok_clicked(GtkButton *button, gpointer user_data)
464 char *pool, *volume, *storage, *slot;
466 gtk_widget_hide(label_dialog);
469 pool = get_combo_text(label_dialog, "label_combo_pool");
470 storage = get_combo_text(label_dialog, "label_combo_storage");
472 volume = get_entry_text(label_dialog, "label_entry_volume");
474 slot = get_spin_text(label_dialog, "label_slot");
476 if (!pool || !storage || !volume || !(*volume)) {
481 bsnprintf(cmd, sizeof(cmd),
482 "label name=\"%s\" pool=\"%s\" storage=\"%s\" slot=%s",
483 volume, pool, storage, slot);
485 set_text(cmd, strlen(cmd));
490 on_label_cancel_clicked(GtkButton *button, gpointer user_data)
492 gtk_widget_hide(label_dialog);
499 on_select_files_button_clicked(GtkButton *button, gpointer user_data)
501 char *job, *fileset, *client, *pool, *before, *storage;
503 gtk_widget_hide(restore_dialog);
505 job = get_combo_text(restore_dialog, "combo_restore_job");
506 fileset = get_combo_text(restore_dialog, "combo_restore_fileset");
507 client = get_combo_text(restore_dialog, "combo_restore_client");
508 pool = get_combo_text(restore_dialog, "combo_restore_pool");
509 storage = get_combo_text(restore_dialog, "combo_restore_storage");
511 before = get_entry_text(restore_dialog, "restore_before_entry");
513 if (!job || !fileset || !client || !pool || !storage || !before) {
518 bsnprintf(cmd, sizeof(cmd),
519 "restore select current fileset=\"%s\" client=\"%s\" pool=\"%s\" "
520 "storage=\"%s\"", fileset, client, pool, storage);
522 set_text(cmd, strlen(cmd));
523 gtk_widget_show(restore_file_selection);
524 select_restore_files(); /* put up select files dialog */
528 on_restore_select_ok_clicked(GtkButton *button, gpointer user_data)
530 gtk_widget_hide(restore_file_selection);
531 write_director("done");
538 on_restore_select_cancel_clicked(GtkButton *button, gpointer user_data)
540 gtk_widget_hide(restore_file_selection);
541 write_director("quit");
547 on_restore_files_delete_event(GtkWidget *widget, GdkEvent *event, gpointer user_data)
549 gtk_widget_hide(restore_file_selection);
557 on_new1_activate (GtkMenuItem *menuitem,
565 on_open1_activate (GtkMenuItem *menuitem,
573 on_save1_activate (GtkMenuItem *menuitem,
581 on_save_as1_activate (GtkMenuItem *menuitem,
589 on_quit1_activate (GtkMenuItem *menuitem,
597 on_cut2_activate (GtkMenuItem *menuitem,
605 on_copy2_activate (GtkMenuItem *menuitem,
613 on_paste2_activate (GtkMenuItem *menuitem,
621 on_clear2_activate (GtkMenuItem *menuitem,
629 on_properties1_activate (GtkMenuItem *menuitem,
637 on_preferences2_activate (GtkMenuItem *menuitem,
645 on_about2_activate (GtkMenuItem *menuitem,
652 * Set correct default values in the Restore dialog box
654 void set_restore_dialog_defaults()
662 stop_director_reader(NULL);
664 combo = lookup_widget(restore_dialog, "combo_restore_job");
665 job = (char *)gtk_entry_get_text(GTK_ENTRY(GTK_COMBO(combo)->entry));
666 bsnprintf(cmd, sizeof(cmd), ".defaults job=\"%s\"", job);
668 while (bnet_recv(UA_sock) > 0) {
669 def = strchr(UA_sock->msg, '=');
674 if (strcmp(UA_sock->msg, "job") == 0 ||
675 strcmp(UA_sock->msg, "when") == 0 ||
676 strcmp(UA_sock->msg, "where") == 0 ||
677 strcmp(UA_sock->msg, "messages") == 0 ||
678 strcmp(UA_sock->msg, "level") == 0 ||
679 strcmp(UA_sock->msg, "type") == 0) {
683 /* Now handle combo boxes */
684 list = find_combo_list(UA_sock->msg);
688 item = g_list_find_custom(list, def, compare_func);
689 bsnprintf(cmd, sizeof(cmd), "combo_restore_%s", UA_sock->msg);
690 combo = lookup_widget(restore_dialog, cmd);
694 pos = g_list_position(list, item);
695 gtk_list_select_item(GTK_LIST(GTK_COMBO(combo)->list), pos);
697 start_director_reader(NULL);
702 on_restore_job_entry_changed(GtkEditable *editable, gpointer user_data)
704 /* Set defaults that correspond to new job selection */
705 set_restore_dialog_defaults();