summaryrefslogtreecommitdiff
path: root/capplets/url-properties/url-properties.c
diff options
context:
space:
mode:
Diffstat (limited to 'capplets/url-properties/url-properties.c')
-rw-r--r--capplets/url-properties/url-properties.c292
1 files changed, 0 insertions, 292 deletions
diff --git a/capplets/url-properties/url-properties.c b/capplets/url-properties/url-properties.c
deleted file mode 100644
index f6296d0d5..000000000
--- a/capplets/url-properties/url-properties.c
+++ /dev/null
@@ -1,292 +0,0 @@
-/* url-properties -- a capplet to configure the behaviour of gnome_url_show
- * Copyright (C) 1998 James Henstridge <james@daa.com.au>
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
- */
-
-#ifdef HAVE_CONFIG_H
-# include <config.h>
-#endif
-
-#include <string.h>
-#include <gtk/gtk.h>
-#include "capplet-widget.h"
-#include <gnome.h>
-
-GtkWidget *capplet, *protocol, *combo, *clist;
-
-void url_capplet_revert(void);
-void url_capplet_commit(void);
-void url_capplet_cancel(void);
-
-void build_capplet(void);
-
-int
-main(int argc, char *argv[]) {
- gint init_ret;
-
- bindtextdomain(PACKAGE, GNOMELOCALEDIR);
- textdomain(PACKAGE);
-
- init_ret = gnome_capplet_init("url-properties", VERSION, argc, argv,
- NULL, 0, NULL);
- if (init_ret == 1) {
- /* nothing to init */
- return 0;
- } else if (init_ret == -1) {
- g_error (_("Error initializing the `url-properties' capplet."));
- }
-
- build_capplet();
- url_capplet_revert(); /* this will refill the clist */
-
- gtk_signal_connect(GTK_OBJECT(capplet), "revert",
- GTK_SIGNAL_FUNC(url_capplet_revert), NULL);
- gtk_signal_connect(GTK_OBJECT(capplet), "ok",
- GTK_SIGNAL_FUNC(url_capplet_commit), NULL);
- gtk_signal_connect(GTK_OBJECT(capplet), "cancel",
- GTK_SIGNAL_FUNC(url_capplet_cancel), NULL);
-
- capplet_gtk_main();
- return 0;
-}
-
-void set_handler(GtkEntry *entry);
-void remove_handler(GtkButton *button);
-void select_clist_row(GtkCList *clist, gint row, gint column);
-
-void build_capplet(void) {
- GtkWidget *vbox, *hbox, *item, *button;
- gchar *titles[] = { N_("Protocol"), N_("Command") };
-
- capplet = capplet_widget_new();
- vbox = gtk_vbox_new(FALSE, 5);
- gtk_widget_set_usize (vbox, 400, 250);
- gtk_container_add(GTK_CONTAINER(capplet), vbox);
- gtk_widget_show(vbox);
-
- hbox = gtk_hbox_new(FALSE, 5);
- gtk_box_pack_start(GTK_BOX(vbox), hbox, FALSE, TRUE, 0);
- gtk_widget_show(hbox);
-
- protocol = gtk_entry_new();
- gtk_widget_set_usize(protocol, 80, -1);
- gtk_box_pack_start(GTK_BOX(hbox), protocol, FALSE, TRUE, 0);
- gtk_widget_show(protocol);
-
- item = gtk_label_new(_("handler:"));
- gtk_box_pack_start(GTK_BOX(hbox), item, FALSE, TRUE, 0);
- gtk_widget_show(item);
-
- combo = gtk_combo_new();
- gtk_combo_set_use_arrows(GTK_COMBO(combo), FALSE);
- gtk_combo_set_value_in_list(GTK_COMBO(combo), FALSE, FALSE);
- gtk_combo_disable_activate(GTK_COMBO(combo));
-
- /* set some commonly used handlers */
- item = gtk_list_item_new_with_label(_("Netscape"));
- gtk_combo_set_item_string(GTK_COMBO(combo), GTK_ITEM(item),
- "gnome-moz-remote '%s'");
- gtk_container_add(GTK_CONTAINER(GTK_COMBO(combo)->list), item);
- gtk_widget_show(item);
- item = gtk_list_item_new_with_label(_("Netscape (new window)"));
- gtk_combo_set_item_string(GTK_COMBO(combo), GTK_ITEM(item),
- "gnome-moz-remote --newwin '%s'");
- gtk_container_add(GTK_CONTAINER(GTK_COMBO(combo)->list), item);
- gtk_widget_show(item);
-
- item = gtk_list_item_new_with_label(_("Help browser"));
- gtk_combo_set_item_string(GTK_COMBO(combo), GTK_ITEM(item),
- "gnome-help-browser '#%s'");
- gtk_container_add(GTK_CONTAINER(GTK_COMBO(combo)->list), item);
- gtk_widget_show(item);
- item = gtk_list_item_new_with_label(_("Help browser (new window)"));
- gtk_combo_set_item_string(GTK_COMBO(combo), GTK_ITEM(item),
- "gnome-help-browser '%s'");
- gtk_container_add(GTK_CONTAINER(GTK_COMBO(combo)->list), item);
- gtk_widget_show(item);
-
- gtk_box_pack_start(GTK_BOX(hbox), combo, TRUE, TRUE, 0);
- gtk_widget_show(combo);
-
- gtk_signal_connect(GTK_OBJECT(GTK_COMBO(combo)->entry), "activate",
- GTK_SIGNAL_FUNC(set_handler), NULL);
-
- button = gtk_button_new_with_label(_("Set"));
- gtk_box_pack_start(GTK_BOX(hbox), button, FALSE, TRUE, 0);
- gtk_widget_show(button);
-
- gtk_signal_connect_object(GTK_OBJECT(button), "clicked",
- GTK_SIGNAL_FUNC(set_handler),
- GTK_OBJECT(GTK_COMBO(combo)->entry));
-
- button = gtk_button_new_with_label(_("Remove"));
- gtk_box_pack_start(GTK_BOX(hbox), button, FALSE, TRUE, 0);
- gtk_widget_show(button);
-
- gtk_signal_connect(GTK_OBJECT(button), "clicked",
- GTK_SIGNAL_FUNC(remove_handler), NULL);
-
- item = gtk_scrolled_window_new(NULL, NULL);
- gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(item),
- GTK_POLICY_AUTOMATIC, GTK_POLICY_AUTOMATIC);
- gtk_box_pack_start(GTK_BOX(vbox), item, TRUE, TRUE, 0);
- gtk_widget_show(item);
-
- titles[0] = _(titles[0]);
- titles[1] = _(titles[1]);
- clist = gtk_clist_new_with_titles(2, titles);
- gtk_container_add(GTK_CONTAINER(item), clist);
- gtk_widget_show(clist);
-
- gtk_clist_set_column_width(GTK_CLIST(clist), 0, 50);
- gtk_clist_set_selection_mode(GTK_CLIST(clist), GTK_SELECTION_BROWSE);
- gtk_clist_set_sort_type(GTK_CLIST(clist), GTK_SORT_ASCENDING);
- gtk_clist_set_sort_column(GTK_CLIST(clist), 0);
- gtk_clist_set_auto_sort(GTK_CLIST(clist), TRUE);
-
- gtk_signal_connect(GTK_OBJECT(clist), "select_row",
- GTK_SIGNAL_FUNC(select_clist_row), NULL);
-
- gtk_widget_show(capplet);
-}
-
-void url_capplet_revert(void) {
- void *iter;
- gchar *key, *value;
- gint len;
- gboolean def = FALSE;
-
- /* see if the default is set. If not, put in some sensible defaults.
- * Maybe this should pass a call through to gnome-url */
- g_free(gnome_config_get_string_with_default(
- "/Gnome/URL Handlers/default-show=?", &def));
- if (def) {
- gnome_config_set_string("/Gnome/URL Handlers/default-show",
- "gnome-moz-remote --newwin \"%s\"");
- g_free(gnome_config_get_string_with_default(
- "/Gnome/URL Handlers/info-show=?", &def));
- if (def)
- gnome_config_set_string("/Gnome/URL Handlers/info-show",
- "gnome-help-browser \"%s\"");
- g_free(gnome_config_get_string_with_default(
- "/Gnome/URL Handlers/man-show=?", &def));
- if (def)
- gnome_config_set_string("/Gnome/URL Handlers/man-show",
- "gnome-help-browser \"%s\"");
- g_free(gnome_config_get_string_with_default(
- "/Gnome/URL Handlers/ghelp-show=?", &def));
- if (def)
- gnome_config_set_string("/Gnome/URL Handlers/ghelp-show",
- "gnome-help-browser \"%s\"");
- }
-
- iter = gnome_config_init_iterator("/Gnome/URL Handlers");
- gtk_clist_freeze(GTK_CLIST(clist));
- gtk_clist_clear(GTK_CLIST(clist));
- while ((iter = gnome_config_iterator_next(iter, &key, &value))) {
- len = strlen(key);
- if (len > 5 && !strcmp(&key[len-5], "-show")) {
- gchar *row[2];
- gint id;
- /* it is a *-show key */
- key[len-5] = '\0';
- row[0] = key;
- row[1] = value;
-
- id = gtk_clist_append(GTK_CLIST(clist), row);
- if (!g_strcasecmp(key, "default"))
- gtk_clist_select_row(GTK_CLIST(clist), id, 0);
- }
- g_free(key);
- g_free(value);
- }
- gtk_clist_thaw(GTK_CLIST(clist));
-}
-
-void url_capplet_commit(void) {
- gint num_rows, row;
- gchar *col1, *col2, *key;
-
- /* should we be more specific here?*/
- gnome_config_clean_section("/Gnome/URL Handlers");
- num_rows = GTK_CLIST(clist)->rows;
- for (row = 0; row < num_rows; row++) {
- gtk_clist_get_text(GTK_CLIST(clist), row, 0, &col1);
- gtk_clist_get_text(GTK_CLIST(clist), row, 1, &col2);
- key = g_strconcat("/Gnome/URL Handlers/", col1, "-show", NULL);
- gnome_config_set_string(key, col2);
- g_free(key);
- }
- gnome_config_sync();
- gtk_main_quit();
-}
-
-void url_capplet_cancel(void) {
- gtk_main_quit();
-}
-
-void set_handler(GtkEntry *entry) {
- gint row, num_rows;
- gchar *col1, *prot, *cols[2];
-
- num_rows = GTK_CLIST(clist)->rows;
- prot = gtk_entry_get_text(GTK_ENTRY(protocol));
- for (row = 0; row < num_rows; row++) {
- gtk_clist_get_text(GTK_CLIST(clist), row, 0, &col1);
- if (!g_strcasecmp(prot, col1)) {
- gtk_clist_set_text(GTK_CLIST(clist), row, 1, gtk_entry_get_text(entry));
- capplet_widget_state_changed(CAPPLET_WIDGET(capplet), TRUE);
- return;
- }
- }
- /* prot not in clist */
- cols[0] = prot;
- cols[1] = gtk_entry_get_text(entry);
- gtk_clist_append(GTK_CLIST(clist), cols);
- capplet_widget_state_changed(CAPPLET_WIDGET(capplet), TRUE);
-}
-
-void remove_handler(GtkButton *button) {
- gint row, num_rows;
- gchar *col1, *prot;
-
- num_rows = GTK_CLIST(clist)->rows;
- prot = gtk_entry_get_text(GTK_ENTRY(protocol));
- for (row = 0; row < num_rows; row++) {
- gtk_clist_get_text(GTK_CLIST(clist), row, 0, &col1);
- if (!g_strcasecmp(prot, col1)) {
- gtk_clist_remove(GTK_CLIST(clist), row);
- capplet_widget_state_changed(CAPPLET_WIDGET(capplet), TRUE);
- gtk_entry_set_text(GTK_ENTRY(protocol), "");
- gtk_entry_set_text(GTK_ENTRY(GTK_COMBO(combo)->entry), "");
- if (num_rows > 1)
- gtk_clist_select_row(GTK_CLIST(clist), 0, 0);
- return;
- }
- }
-}
-
-void select_clist_row(GtkCList *clist, gint row, gint column) {
- gchar *col1, *col2;
-
- /* get column values */
- gtk_clist_get_text(GTK_CLIST(clist), row, 0, &col1);
- gtk_clist_get_text(GTK_CLIST(clist), row, 1, &col2);
-
- gtk_entry_set_text(GTK_ENTRY(protocol), col1);
-
- gtk_entry_set_text(GTK_ENTRY(GTK_COMBO(combo)->entry), col2);
-}