summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'gnome-base/nautilus/files/nautilus-2.8-x-printers.patch')
-rw-r--r--gnome-base/nautilus/files/nautilus-2.8-x-printers.patch1129
1 files changed, 1129 insertions, 0 deletions
diff --git a/gnome-base/nautilus/files/nautilus-2.8-x-printers.patch b/gnome-base/nautilus/files/nautilus-2.8-x-printers.patch
new file mode 100644
index 000000000000..3280a523f9ee
--- /dev/null
+++ b/gnome-base/nautilus/files/nautilus-2.8-x-printers.patch
@@ -0,0 +1,1129 @@
+diff -Nru -x '*~' -x '*.o' -x '*.orig' -x '*.rej' nautilus-2.2.4.orig/components/Makefile.am nautilus-2.2.4/components/Makefile.am
+--- nautilus-2.2.4.orig/components/Makefile.am 2002-11-20 07:19:52.000000000 -0500
++++ nautilus-2.2.4/components/Makefile.am 2003-05-27 01:31:42.000000000 -0400
+@@ -5,6 +5,7 @@
+ hardware \
+ history \
+ notes \
++ printers \
+ text \
+ throbber \
+ tree \
+diff -Nru -x '*~' -x '*.o' -x '*.orig' -x '*.rej' nautilus-2.2.4.orig/components/printers/Makefile.am nautilus-2.2.4/components/printers/Makefile.am
+--- nautilus-2.2.4.orig/components/printers/Makefile.am 1969-12-31 19:00:00.000000000 -0500
++++ nautilus-2.2.4/components/printers/Makefile.am 2003-05-26 22:17:59.000000000 -0400
+@@ -0,0 +1,37 @@
++NULL =
++
++INCLUDES=\
++ -DG_LOG_DOMAIN=\"Nautilus-Printers\" \
++ -I$(top_srcdir) \
++ -DDATADIR=\""$(datadir)"\" \
++ -DGNOMELOCALEDIR=\""$(prefix)/${DATADIRNAME}/locale"\" \
++ $(PRINTER_CFLAGS) \
++ $(NULL) \
++ -DGTK_ENABLE_BROKEN
++
++bonobodir = $(libdir)/bonobo
++bonobo_LTLIBRARIES = libnautilus-printers-view.la
++
++libnautilus_printers_view_la_SOURCES = nautilus-printers.c
++
++libnautilus_printers_view_la_LIBADD = \
++ $(top_builddir)/libnautilus/libnautilus.la \
++ $(top_builddir)/libnautilus-private/libnautilus-private.la \
++ $(PRINTER_LIBS) \
++ $(NULL)
++
++libnautilus_printers_view_la_LDFLAGS = -module -avoid-version
++
++server_in_files = Nautilus_View_printers.server.in.in
++
++serverdir = $(libdir)/bonobo/servers
++server_DATA = $(server_in_files:.server.in.in=.server)
++$(server_in_files:.server.in.in=.server.in): $(server_in_files)
++ sed -e "s|\@BONOBODIR\@|$(bonobodir)|" $< > $@
++@INTLTOOL_SERVER_RULE@
++
++uidir=$(datadir)/gnome-2.0/ui
++ui_DATA = nautilus-printers-view-ui.xml
++
++EXTRA_DIST= $(server_in_files) $(ui_DATA)
++CLEANFILES = $(server_DATA) $(server_DATA).in
+diff -Nru -x '*~' -x '*.o' -x '*.orig' -x '*.rej' nautilus-2.2.4.orig/components/printers/nautilus-printers.c nautilus-2.2.4/components/printers/nautilus-printers.c
+--- nautilus-2.2.4.orig/components/printers/nautilus-printers.c 1969-12-31 19:00:00.000000000 -0500
++++ nautilus-2.2.4/components/printers/nautilus-printers.c 2003-05-27 01:31:06.000000000 -0400
+@@ -0,0 +1,923 @@
++/* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 8 -*- */
++
++/*
++ * Nautilus
++ *
++ * Copyright (C) 2002 Ximian Inc.
++ *
++ * This library 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 library 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 library; if not, write to the Free Software
++ * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
++ *
++ * Author: Dave Camp <dave@ximian.com>
++ *
++ */
++
++#define VIEW_IID "OAFIID:Nautilus_Printers_View"
++
++#include <config.h>
++
++#include <string.h>
++#include <bonobo/bonobo-window.h>
++#include <eel/eel-glib-extensions.h>
++#include <eel/eel-gtk-extensions.h>
++#include <gtk/gtklabel.h>
++#include <gtk/gtklayout.h>
++#include <gtk/gtkmessagedialog.h>
++#include <gtk/gtkscrolledwindow.h>
++#include <libgnome/gnome-i18n.h>
++#include <libgnome/gnome-macros.h>
++#include <libgnomecups/gnome-cups-init.h>
++#include <libgnomecups/gnome-cups-printer.h>
++#include <libgnomecups/gnome-cups-request.h>
++#include <libgnomecups/gnome-cups-ui-init.h>
++#include <libnautilus/nautilus-view.h>
++#include <libnautilus/nautilus-view-standard-main.h>
++#include <libnautilus-private/nautilus-bonobo-extensions.h>
++#include <libnautilus-private/nautilus-icon-container.h>
++#include <libnautilus-private/nautilus-icon-factory.h>
++#include <libnautilus-private/nautilus-global-preferences.h>
++
++#define NEW_PRINTER_ICON ((NautilusIconData*)1)
++
++#define COMMAND_NEW_PRINTER "/commands/New Printer"
++#define COMMAND_OPEN "/commands/Open"
++#define COMMAND_DELETE "/commands/Delete"
++#define COMMAND_PAUSE "/commands/Pause"
++#define COMMAND_RESUME "/commands/Resume"
++#define COMMAND_MAKE_DEFAULT "/commands/Make Default"
++#define COMMAND_PROPERTIES "/commands/Properties"
++
++typedef struct {
++ NautilusIconContainer container;
++
++ GList *printers;
++ guint new_printer_notify;
++ NautilusView *view;
++ BonoboUIComponent *ui;
++} NautilusPrinterContainer;
++
++typedef struct {
++ NautilusIconContainerClass container;
++} NautilusPrinterContainerClass;
++
++static GType nautilus_printer_container_get_type (void);
++
++static void remove_printer (NautilusPrinterContainer *container,
++ GnomeCupsPrinter *printer);
++
++GNOME_CLASS_BOILERPLATE (NautilusPrinterContainer, nautilus_printer_container,
++ NautilusIconContainer,
++ nautilus_icon_container_get_type ());
++
++static void
++update_menus (NautilusPrinterContainer *container)
++{
++ GList *selection;
++ GList *l;
++ GnomeCupsPrinter *printer;
++ int num_selected;
++ gboolean new_printer_selected;
++ gboolean all_paused;
++ gboolean all_running;
++ gboolean is_default;
++
++ selection = nautilus_icon_container_get_selection (NAUTILUS_ICON_CONTAINER (container));
++
++ num_selected = g_list_length (selection);
++
++ new_printer_selected = FALSE;
++ all_paused = TRUE;
++ all_running = TRUE;
++ is_default = FALSE;
++
++ for (l = selection; l != NULL; l = l->next) {
++ if (l->data == NEW_PRINTER_ICON) {
++ new_printer_selected = TRUE;
++ } else {
++ printer = GNOME_CUPS_PRINTER (l->data);
++ if (gnome_cups_printer_get_state (printer) == IPP_PRINTER_STOPPED) {
++ all_running = FALSE;
++ } else {
++ all_paused = FALSE;
++ }
++
++ is_default = gnome_cups_printer_get_is_default (printer);
++ }
++ }
++
++ g_list_free (selection);
++
++ nautilus_bonobo_set_sensitive (container->ui,
++ COMMAND_PAUSE,
++ !new_printer_selected && !all_paused);
++ nautilus_bonobo_set_sensitive (container->ui,
++ COMMAND_RESUME,
++ !new_printer_selected && !all_running);
++ nautilus_bonobo_set_sensitive (container->ui,
++ COMMAND_MAKE_DEFAULT,
++ (!new_printer_selected && num_selected == 1) && !is_default);
++ nautilus_bonobo_set_sensitive (container->ui,
++ COMMAND_PROPERTIES,
++ !new_printer_selected);
++ nautilus_bonobo_set_sensitive (container->ui,
++ COMMAND_DELETE,
++ !new_printer_selected);
++}
++
++static void
++get_icon_text (NautilusIconContainer *container,
++ NautilusIconData *data,
++ char **editable_text,
++ char **additional_text)
++{
++ GnomeCupsPrinter *printer;
++
++ if (data == NEW_PRINTER_ICON) {
++ *editable_text = g_strdup (_("New Printer"));
++ *additional_text = NULL;
++ } else {
++ printer = GNOME_CUPS_PRINTER (data);
++
++ *editable_text = g_strdup (gnome_cups_printer_get_name (printer));
++ *additional_text = g_strdup_printf (_("%s\n%d Jobs"),
++ gnome_cups_printer_get_state_name (printer),
++ gnome_cups_printer_get_job_count (printer));
++ }
++}
++
++static char *
++get_icon_images (NautilusIconContainer *container,
++ NautilusIconData *data,
++ GList **emblem_icons,
++ char **embedded_text)
++{
++ char *icon_name;
++
++ *embedded_text = NULL;
++
++ if (data == NEW_PRINTER_ICON) {
++ icon_name = g_strdup ("gnome-dev-printer-new");
++ } else {
++ gnome_cups_printer_get_icon (GNOME_CUPS_PRINTER (data),
++ &icon_name,
++ emblem_icons);
++ }
++
++ return icon_name;
++}
++
++static int
++compare_icons (NautilusIconContainer *container,
++ NautilusIconData *data_a,
++ NautilusIconData *data_b)
++{
++ if (data_a == data_b) {
++ return 0;
++ } else if (data_a == NEW_PRINTER_ICON && data_b != NEW_PRINTER_ICON) {
++ return -1;
++ } else if (data_b == NEW_PRINTER_ICON && data_a != NEW_PRINTER_ICON) {
++ return 1;
++ } else {
++ return strcmp (gnome_cups_printer_get_name (GNOME_CUPS_PRINTER (data_a)),
++ gnome_cups_printer_get_name (GNOME_CUPS_PRINTER (data_b)));
++ }
++}
++
++static int
++compare_icons_by_name (NautilusIconContainer *container,
++ NautilusIconData *data_a,
++ NautilusIconData *data_b)
++{
++ if (data_a == data_b) {
++ return 0;
++ } else if (data_a == NEW_PRINTER_ICON && data_b != NEW_PRINTER_ICON) {
++ return -1;
++ } else if (data_b == NEW_PRINTER_ICON && data_a != NEW_PRINTER_ICON) {
++ return 1;
++ } else {
++ return strcmp (gnome_cups_printer_get_name (GNOME_CUPS_PRINTER (data_a)),
++ gnome_cups_printer_get_name (GNOME_CUPS_PRINTER (data_b)));
++ }
++}
++
++static gboolean
++can_accept_item (NautilusIconContainer *container,
++ NautilusIconData *target,
++ const char *item_uri)
++{
++ return FALSE;
++}
++
++static gboolean
++get_stored_icon_position (NautilusIconContainer *container,
++ NautilusIconData *data,
++ NautilusIconPosition *position)
++{
++ return FALSE;
++}
++
++static char *
++get_icon_uri (NautilusIconContainer *container,
++ NautilusIconData *data)
++{
++ return NULL;
++}
++
++static char *
++get_icon_drop_target_uri (NautilusIconContainer *container,
++ NautilusIconData *data)
++{
++ return g_strdup ("printers:");
++}
++
++static char *
++get_container_uri (NautilusIconContainer *container)
++{
++ return g_strdup ("printers:");
++}
++
++static void
++printer_gone_cb (GnomeCupsPrinter *printer,
++ gpointer user_data)
++{
++ NautilusPrinterContainer *container;
++
++ container = user_data;
++
++ remove_printer (container, printer);
++}
++
++static void
++printer_changed_cb (GnomeCupsPrinter *printer,
++ gpointer user_data)
++{
++ NautilusIconContainer *container;
++
++ container = NAUTILUS_ICON_CONTAINER (user_data);
++
++ update_menus ((NautilusPrinterContainer*)container);
++ nautilus_icon_container_request_update (container, (NautilusIconData*)printer);
++}
++
++static void
++disconnect_printer (NautilusPrinterContainer *container,
++ GnomeCupsPrinter *printer)
++{
++ g_signal_handlers_disconnect_by_func (printer,
++ G_CALLBACK (printer_changed_cb),
++ printer);
++ g_signal_handlers_disconnect_by_func (printer,
++ G_CALLBACK (printer_gone_cb),
++ printer);
++ g_object_unref (printer);
++}
++
++static void
++remove_printer (NautilusPrinterContainer *container,
++ GnomeCupsPrinter *printer)
++{
++ nautilus_icon_container_remove (NAUTILUS_ICON_CONTAINER (container),
++ (NautilusIconData*)printer);
++ container->printers = g_list_remove (container->printers, printer);
++ disconnect_printer (container, printer);
++}
++
++static void
++watch_printer (NautilusPrinterContainer *container,
++ const char *name)
++{
++ GnomeCupsPrinter *printer;
++
++ printer = gnome_cups_printer_get (name);
++ if (!printer) {
++ return;
++ }
++
++ container->printers = g_list_append (container->printers, printer);
++
++ nautilus_icon_container_add (NAUTILUS_ICON_CONTAINER (container),
++ (NautilusIconData*)printer);
++
++ g_signal_connect_object (printer, "is_default_changed",
++ G_CALLBACK (printer_changed_cb),
++ container, 0);
++ g_signal_connect_object (printer, "attributes_changed",
++ G_CALLBACK (printer_changed_cb),
++ container, 0);
++ g_signal_connect_object (printer, "gone",
++ G_CALLBACK (printer_gone_cb),
++ container, 0);
++}
++
++static BonoboWindow *
++get_bonobo_window (GtkWidget *widget)
++{
++ GtkWidget *window;
++
++ /* Note: This works only because we are in the same process
++ * as the Nautilus shell. Bonobo components in their own
++ * processes can't do this.
++ */
++ window = gtk_widget_get_ancestor (widget, BONOBO_TYPE_WINDOW);
++ g_assert (window != NULL);
++
++ return BONOBO_WINDOW (window);
++}
++
++static GtkMenu *
++create_popup_menu (NautilusIconContainer *container, const char *popup_path)
++{
++ GtkMenu *menu;
++
++ menu = GTK_MENU (gtk_menu_new ());
++ update_menus ((NautilusPrinterContainer*)container);
++
++ bonobo_window_add_popup (get_bonobo_window (GTK_WIDGET (container)),
++ menu, popup_path);
++
++ return menu;
++}
++
++static void
++context_click_selection (NautilusIconContainer *container,
++ GdkEventButton *event)
++{
++ eel_pop_up_context_menu (create_popup_menu (container,
++ "/popups/selection"),
++ EEL_DEFAULT_POPUP_MENU_DISPLACEMENT,
++ EEL_DEFAULT_POPUP_MENU_DISPLACEMENT,
++ event);
++}
++
++static void
++selection_changed (NautilusIconContainer *container)
++{
++ update_menus ((NautilusPrinterContainer *)container);
++}
++
++static void
++handle_error (NautilusPrinterContainer *container,
++ const char *prefix,
++ GError *error)
++{
++ GtkWidget *dialog;
++ char *msg;
++
++ if (prefix) {
++ msg = g_strdup_printf (_("%s: %s"),
++ prefix,
++ error ? error->message : _("Unknown Error"));
++ } else {
++ msg = g_strdup (error ? error->message : _("Unknown Error"));
++ }
++
++ dialog = gtk_message_dialog_new (GTK_WINDOW (gtk_widget_get_toplevel (GTK_WIDGET (container))),
++ GTK_DIALOG_DESTROY_WITH_PARENT | GTK_DIALOG_MODAL,
++ GTK_MESSAGE_ERROR,
++ GTK_BUTTONS_OK,
++ "%s",
++ msg);
++ g_free (msg);
++ gtk_dialog_run (GTK_DIALOG (dialog));
++ gtk_widget_destroy (dialog);
++}
++
++static void
++new_printer (NautilusPrinterContainer *container)
++{
++ char *argv[] = { "gnome-cups-add", NULL };
++ GError *error;
++
++ error = NULL;
++
++ g_spawn_async (NULL, argv, NULL,
++ G_SPAWN_SEARCH_PATH, NULL, NULL, NULL, &error);
++
++ if (error) {
++ handle_error (container, NULL, error);
++ g_error_free (error);
++ }
++}
++
++static void
++open_printers (NautilusPrinterContainer *container,
++ GList *printer_names,
++ const char *command)
++{
++ char **argv;
++ int argc;
++ GList *l;
++ int i;
++ GError *error;
++
++ argc = g_list_length (printer_names) + 4;
++ argv = g_new0 (char *, argc);
++
++ i = 0;
++
++ argv[i++] = "gnome-cups-manager";
++ argv[i++] = (char*)command;
++
++ for (l = printer_names; l != NULL; l = l->next, i++) {
++ argv[i] = l->data;
++ }
++ argv[i] = NULL;
++
++ error = NULL;
++ g_spawn_async (NULL, argv, NULL,
++ G_SPAWN_SEARCH_PATH, NULL, NULL, NULL, &error);
++
++ if (error) {
++ handle_error (container, NULL, error);
++ g_error_free (error);
++ }
++
++ g_free (argv);
++}
++
++static void
++activate_selection (NautilusPrinterContainer *container,
++ GList *selection)
++{
++ GList *l;
++ GnomeCupsPrinter *printer;
++ GList *printer_names;
++
++ printer_names = NULL;
++
++
++ for (l = selection; l != NULL; l = l->next) {
++ if (l->data == NEW_PRINTER_ICON) {
++ new_printer (container);
++ } else {
++ printer = GNOME_CUPS_PRINTER (l->data);
++ printer_names = g_list_prepend (printer_names,
++ g_strdup (gnome_cups_printer_get_name (printer)));
++ }
++ }
++
++ if (printer_names) {
++ open_printers (container, printer_names, "-v");
++ }
++
++ eel_g_list_free_deep (printer_names);
++}
++
++static void
++activate (NautilusIconContainer *container,
++ /* FIXME */NautilusIconData *data)
++{
++ /* FIXME: nautilus-icon-container's header is busted, and lists this
++ * argument as a NautilusIconData rather than a GList * */
++ GList *items = (GList*)data;
++
++ activate_selection ((NautilusPrinterContainer*)container, items);
++}
++
++static void
++show_selection_properties (NautilusPrinterContainer *container,
++ GList *selection)
++{
++ GList *l;
++ GnomeCupsPrinter *printer;
++ GList *printer_names;
++
++ printer_names = NULL;
++
++ for (l = selection; l != NULL; l = l->next) {
++ if (l->data == NEW_PRINTER_ICON) {
++ g_warning ("properties selected on New Printer");
++ } else {
++ printer = GNOME_CUPS_PRINTER (l->data);
++ printer_names = g_list_prepend (printer_names,
++ g_strdup (gnome_cups_printer_get_name (printer)));
++ }
++ }
++
++ if (printer_names) {
++ open_printers (container, printer_names, "-p");
++ }
++
++ eel_g_list_free_deep (printer_names);
++}
++
++static void
++nautilus_printer_container_unload_printers (NautilusPrinterContainer *container)
++{
++ GList *l;
++ for (l = container->printers; l != NULL; l = l->next) {
++ nautilus_icon_container_remove (NAUTILUS_ICON_CONTAINER (container),
++ (NautilusIconData*)l->data);
++ disconnect_printer (container, GNOME_CUPS_PRINTER (l->data));
++ }
++ g_list_free (container->printers);
++ container->printers = NULL;
++}
++
++static void
++nautilus_printer_container_load_printers (NautilusPrinterContainer *container)
++{
++ GList *printer_names;
++ GList *l;
++
++ nautilus_printer_container_unload_printers (container);
++
++ printer_names = gnome_cups_get_printers ();
++ for (l = printer_names; l != NULL; l = l->next) {
++ watch_printer (container, l->data);
++ }
++ gnome_cups_printer_list_free (printer_names);
++}
++
++static void
++nautilus_printer_container_dispose (GObject *object)
++{
++ NautilusPrinterContainer *container;
++ GList *l;
++
++ container = (NautilusPrinterContainer*)object;
++
++ for (l = container->printers; l != NULL; l = l->next) {
++ disconnect_printer (container, GNOME_CUPS_PRINTER (l->data));
++ }
++ g_list_free (container->printers);
++ container->printers = NULL;
++
++ if (container->new_printer_notify) {
++ gnome_cups_printer_new_printer_notify_remove (container->new_printer_notify);
++ container->new_printer_notify = 0;
++ }
++
++ GNOME_CALL_PARENT (G_OBJECT_CLASS, dispose, (object));
++}
++
++
++static void
++update_click_mode (gpointer user_data)
++{
++ NautilusIconContainer *container;
++ int click_mode;
++
++ container = NAUTILUS_ICON_CONTAINER (user_data);
++
++ click_mode = eel_preferences_get_enum (NAUTILUS_PREFERENCES_CLICK_POLICY);
++
++ nautilus_icon_container_set_single_click_mode (container,
++ click_mode == NAUTILUS_CLICK_POLICY_SINGLE);
++}
++
++static void
++prioritize_thumbnailing (NautilusIconContainer *container,
++ NautilusIconData *data)
++{
++}
++
++static void
++nautilus_printer_container_instance_init (NautilusPrinterContainer *container)
++{
++}
++
++static void
++nautilus_printer_container_class_init (NautilusPrinterContainerClass *klass)
++{
++ NautilusIconContainerClass *container_class;
++ GObjectClass *object_class;
++
++ container_class = NAUTILUS_ICON_CONTAINER_CLASS (klass);
++ object_class = G_OBJECT_CLASS (klass);
++
++ container_class->get_icon_text = get_icon_text;
++ container_class->get_icon_images = get_icon_images;
++ container_class->compare_icons = compare_icons;
++ container_class->compare_icons_by_name = compare_icons_by_name;
++ container_class->can_accept_item = can_accept_item;
++ container_class->get_stored_icon_position = get_stored_icon_position;
++ container_class->get_icon_uri = get_icon_uri;
++ container_class->get_icon_drop_target_uri = get_icon_drop_target_uri;
++ container_class->get_container_uri = get_container_uri;
++
++ container_class->context_click_selection = context_click_selection;
++ container_class->selection_changed = selection_changed;
++
++ container_class->activate = activate;
++ container_class->prioritize_thumbnailing = prioritize_thumbnailing;
++
++ object_class->dispose = nautilus_printer_container_dispose;
++
++}
++
++static void
++printer_added_cb (const char *name, gpointer user_data)
++{
++ NautilusPrinterContainer *container;
++
++ container = (NautilusPrinterContainer*)user_data;
++
++ watch_printer (container, name);
++}
++
++static void
++printers_load_location (NautilusView *view,
++ const char *location,
++ gpointer user_data)
++{
++ NautilusPrinterContainer *container;
++ GtkWidget *dialog;
++
++ container = (NautilusPrinterContainer*)user_data;
++ if (gnome_cups_check_daemon ()) {
++ if (!container->new_printer_notify) {
++ container->new_printer_notify =
++ gnome_cups_printer_new_printer_notify_add (printer_added_cb,
++ user_data);
++ }
++
++ nautilus_printer_container_load_printers (user_data);
++
++ nautilus_view_set_title (view, _("Printers"));
++
++ nautilus_view_report_load_complete (view);
++ } else {
++ dialog = gtk_message_dialog_new (GTK_WINDOW (gtk_widget_get_toplevel (GTK_WIDGET (container))),
++ GTK_DIALOG_DESTROY_WITH_PARENT | GTK_DIALOG_MODAL,
++ GTK_MESSAGE_ERROR,
++ GTK_BUTTONS_OK,
++ _("CUPS does not appear to be running. CUPS must be running for the printers: url to work correctly."));
++ gtk_dialog_run (GTK_DIALOG (dialog));
++ gtk_widget_destroy (dialog);
++
++ nautilus_view_report_load_failed (view);
++ }
++}
++
++static void
++open_cb (BonoboUIComponent *component, gpointer user_data, const char *verb)
++{
++ NautilusPrinterContainer *container;
++ GList *selection;
++
++ container = user_data;
++
++ selection = nautilus_icon_container_get_selection (NAUTILUS_ICON_CONTAINER (container));
++ activate_selection (container, selection);
++ g_list_free (selection);
++}
++
++static void
++properties_cb (BonoboUIComponent *component, gpointer user_data, const char *verb)
++{
++ NautilusPrinterContainer *container;
++ GList *selection;
++
++ container = user_data;
++
++ selection = nautilus_icon_container_get_selection (NAUTILUS_ICON_CONTAINER (container));
++ show_selection_properties (container, selection);
++ g_list_free (selection);
++}
++
++static void
++pause_cb (BonoboUIComponent *component, gpointer user_data, const char *verb)
++{
++ NautilusPrinterContainer *container;
++ GList *selection;
++ GList *l;
++ GnomeCupsPrinter *printer;
++
++ container = user_data;
++
++ selection = nautilus_icon_container_get_selection (NAUTILUS_ICON_CONTAINER (container));
++ for (l = selection; l != NULL; l = l->next) {
++ GError *error = NULL;
++ g_return_if_fail (l->data != NEW_PRINTER_ICON);
++ printer = GNOME_CUPS_PRINTER (l->data);
++ gnome_cups_printer_pause (printer, &error);
++ if (error) {
++ char *msg;
++ msg = g_strdup_printf ("Could not pause '%s'",
++ gnome_cups_printer_get_name (printer));
++ handle_error (container, msg, error);
++ g_free (msg);
++ g_error_free (error);
++ }
++
++ }
++ g_list_free (selection);
++}
++
++static void
++resume_cb (BonoboUIComponent *component, gpointer user_data, const char *verb)
++{
++ NautilusPrinterContainer *container;
++ GList *selection;
++ GList *l;
++ GnomeCupsPrinter *printer;
++
++ container = user_data;
++
++ selection = nautilus_icon_container_get_selection (NAUTILUS_ICON_CONTAINER (container));
++ for (l = selection; l != NULL; l = l->next) {
++ GError *error = NULL;
++ g_return_if_fail (l->data != NEW_PRINTER_ICON);
++ printer = GNOME_CUPS_PRINTER (l->data);
++ gnome_cups_printer_resume (printer, &error);
++ if (error) {
++ char *msg;
++ msg = g_strdup_printf ("Could not resume '%s'",
++ gnome_cups_printer_get_name (printer));
++ handle_error (container, msg, error);
++ g_free (msg);
++ g_error_free (error);
++ }
++
++ }
++ g_list_free (selection);
++}
++
++static void
++make_default_cb (BonoboUIComponent *component, gpointer user_data, const char *verb)
++{
++ NautilusPrinterContainer *container;
++ GList *selection;
++ GnomeCupsPrinter *printer;
++ GError *error = NULL;
++
++ container = user_data;
++
++ selection = nautilus_icon_container_get_selection (NAUTILUS_ICON_CONTAINER (container));
++ g_return_if_fail (g_list_length (selection) == 1);
++ g_return_if_fail (selection->data != NEW_PRINTER_ICON);
++
++ printer = GNOME_CUPS_PRINTER (selection->data);
++ gnome_cups_printer_set_default (printer, &error);
++ if (error) {
++ char *msg;
++ msg = g_strdup_printf ("Could not make '%s' the default printer",
++ gnome_cups_printer_get_name (printer));
++ handle_error (container, msg, error);
++ g_free (msg);
++ g_error_free (error);
++ }
++
++ g_list_free (selection);
++}
++
++static void
++delete_cb (BonoboUIComponent *component, gpointer user_data, const char *verb)
++{
++ NautilusPrinterContainer *container;
++ GList *selection;
++ GList *l;
++ GnomeCupsPrinter *printer;
++
++ container = user_data;
++
++ selection = nautilus_icon_container_get_selection (NAUTILUS_ICON_CONTAINER (container));
++ for (l = selection; l != NULL; l = l->next) {
++ GError *error = NULL;
++ g_return_if_fail (l->data != NEW_PRINTER_ICON);
++ printer = GNOME_CUPS_PRINTER (l->data);
++ gnome_cups_printer_delete (printer, &error);
++ if (error) {
++ char *msg;
++ msg = g_strdup_printf ("Could not delete '%s'",
++ gnome_cups_printer_get_name (printer));
++ handle_error (container, msg, error);
++ g_free (msg);
++ g_error_free (error);
++ }
++
++ }
++ g_list_free (selection);
++}
++
++static void
++new_printer_cb (BonoboUIComponent *component, gpointer user_data, const char *verb)
++{
++ NautilusPrinterContainer *container;
++
++ container = user_data;
++
++ new_printer (container);
++}
++
++static BonoboUIVerb verbs[] = {
++ BONOBO_UI_VERB ("Open", open_cb),
++ BONOBO_UI_VERB ("Pause", pause_cb),
++ BONOBO_UI_VERB ("Resume", resume_cb),
++ BONOBO_UI_VERB ("Make Default", make_default_cb),
++ BONOBO_UI_VERB ("Delete", delete_cb),
++ BONOBO_UI_VERB ("Properties", properties_cb),
++ BONOBO_UI_VERB ("New Printer", new_printer_cb),
++ BONOBO_UI_VERB_END,
++};
++
++static void
++control_activate_cb (BonoboObject *control,
++ gboolean state,
++ gpointer callback_data)
++{
++ NautilusView *view;
++ NautilusPrinterContainer *container;
++
++ view = NAUTILUS_VIEW (callback_data);
++ container = g_object_get_data (G_OBJECT (view), "container");
++
++ if (state) {
++ container->ui = nautilus_view_set_up_ui (view, DATADIR,
++ "nautilus-printers-view-ui.xml",
++ "nautilus-printers");
++ bonobo_ui_component_add_verb_list_with_data (container->ui,
++ verbs,
++ container);
++ update_menus (container);
++ }
++ /* Nothing to do on deactivate case, which necer happens
++ * because of the way nautilus content views are handled */
++}
++
++static BonoboObject *
++make_printers_view (void)
++{
++ GtkWidget *scrolled;
++ NautilusView *view;
++ NautilusPrinterContainer *container;
++
++ gnome_cups_ui_init (NULL);
++
++ scrolled = gtk_scrolled_window_new (NULL, NULL);
++ gtk_scrolled_window_set_shadow_type (GTK_SCROLLED_WINDOW (scrolled),
++ GTK_SHADOW_IN);
++ gtk_scrolled_window_set_policy (GTK_SCROLLED_WINDOW (scrolled),
++ GTK_POLICY_AUTOMATIC,
++ GTK_POLICY_AUTOMATIC);
++ container = g_object_new (nautilus_printer_container_get_type (), NULL);
++ gtk_container_add (GTK_CONTAINER (scrolled),
++ GTK_WIDGET (container));
++
++ update_click_mode (container);
++ eel_preferences_add_callback (NAUTILUS_PREFERENCES_CLICK_POLICY,
++ update_click_mode, container);
++
++
++ nautilus_icon_container_set_auto_layout (NAUTILUS_ICON_CONTAINER (container), TRUE);
++ nautilus_icon_container_add (NAUTILUS_ICON_CONTAINER (container),
++ NEW_PRINTER_ICON);
++
++ gtk_widget_show_all (scrolled);
++
++ /* Create CORBA object. */
++ view = nautilus_view_new (scrolled);
++ g_object_set_data (G_OBJECT (view), "container", container);
++
++ g_signal_connect_object (nautilus_view_get_bonobo_control (view),
++ "activate",
++ G_CALLBACK (control_activate_cb), view, 0);
++
++ /* handle events */
++ g_signal_connect (view, "load_location",
++ G_CALLBACK (printers_load_location),
++ container);
++
++ return BONOBO_OBJECT (view);
++}
++
++static CORBA_Object
++printers_shlib_make_object (PortableServer_POA poa,
++ const char *iid,
++ gpointer impl_ptr,
++ CORBA_Environment *ev)
++{
++ BonoboObject *view;
++
++ if (strcmp (iid, VIEW_IID) != 0) {
++ return CORBA_OBJECT_NIL;
++ }
++
++ view = make_printers_view ();
++
++ bonobo_activation_plugin_use (poa, impl_ptr);
++
++ return CORBA_Object_duplicate (BONOBO_OBJREF (view), ev);
++}
++
++static const BonoboActivationPluginObject printers_plugin_list[] = {
++ { VIEW_IID, printers_shlib_make_object },
++ { NULL }
++};
++
++const BonoboActivationPlugin Bonobo_Plugin_info = {
++ printers_plugin_list,
++ "Nautilus Printers View"
++};
+diff -Nru -x '*~' -x '*.o' -x '*.orig' -x '*.rej' nautilus-2.2.4.orig/components/printers/nautilus-printers-view-ui.xml nautilus-2.2.4/components/printers/nautilus-printers-view-ui.xml
+--- nautilus-2.2.4.orig/components/printers/nautilus-printers-view-ui.xml 1969-12-31 19:00:00.000000000 -0500
++++ nautilus-2.2.4/components/printers/nautilus-printers-view-ui.xml 2003-05-26 22:17:59.000000000 -0400
+@@ -0,0 +1,93 @@
++<Root>
++<commands>
++ <cmd name="Delete"
++ _label="_Delete"
++ _tip="Delete each selected printer"/>
++ <cmd name="New Printer"
++ _label="_New Printer"
++ _tip="Create a new printer"/>
++ <cmd name="Open"
++ _label="_Open"
++ _tip="Open the selected item"/>
++ <cmd name="Pause"
++ _label="Pause"
++ _tip="Pause the selected item"/>
++ <cmd name="Resume"
++ _label="Resume"
++ _tip="Resume the selected item"/>
++ <cmd name="Make Default"
++ _label="Make _Default"
++ _tip="Make the selected item the default"/>
++ <cmd name="Properties"
++ _label="_Properties"
++ _tip="View or modify the properties of each selected item"/>
++</commands>
++<menu>
++ <submenu name="File">
++ <placeholder name="New Items Placeholder">
++ <menuitem name="New Printer"
++ accel="*Control*n"
++ pixtype="stock" pixname="gtk-new"
++ verb="New Printer"/>
++ </placeholder>
++ <placeholder name="Open Placeholder">
++ <menuitem name="Open"
++ accel="*Control*o"
++ pixtype="stock" pixname="gtk-open"
++ verb="Open"/>
++ </placeholder>
++ <placeholder name="File Items Placeholder">
++ <menuitem name="Properties"
++ accel="*Control*i"
++ verb="Properties"/>
++ </placeholder>
++ </submenu>
++
++ <submenu name="Edit">
++ <menuitem name="Select All"
++ accel="*Control*a"
++ verb="Select All"/>
++
++ <placeholder name="File Items Placeholder">
++ <placeholder name="Printer Operations Placeholder" delimit="none">
++ <menuitem name="Pause" verb="Pause"/>
++ <menuitem name="Resume" verb="Resume"/>
++ <menuitem name="Make Default" verb="Make Default"/>
++ </placeholder>
++ </placeholder>
++
++ <placeholder name="Dangerous File Items Placeholder">
++ <menuitem name="Delete"
++ verb="Delete"/>
++ </placeholder>
++
++ </submenu>
++</menu>
++<popups>
++ <popup name="background">
++ <placeholder name="Before Zoom Items">
++ <placeholder name="New Items">
++ <menuitem name="New Printer"
++ verb="New Printer"/>
++ </placeholder>
++ </placeholder>
++ </popup>
++
++ <popup name="selection" tearoff="0">
++ <placeholder name="Open Placeholder" delimit="none">
++ <menuitem name="Open" verb="Open"
++ pixtype="stock" pixname="gtk-open"/>
++ </placeholder>
++ <placeholder name="Printer Operations Placeholder" delimit="top">
++ <menuitem name="Pause" verb="Pause"/>
++ <menuitem name="Resume" verb="Resume"/>
++ <menuitem name="Make Default" verb="Make Default"/>
++ </placeholder>
++ <placeholder name="Dangerous File Actions" delimit="top">
++ <menuitem name="Delete" verb="Delete"/>
++ </placeholder>
++ <separator/>
++ <menuitem name="Properties" verb="Properties"/>
++ </popup>
++</popups>
++</Root>
+diff -Nru -x '*~' -x '*.o' -x '*.orig' -x '*.rej' nautilus-2.2.4.orig/components/printers/Nautilus_View_printers.server.in.in nautilus-2.2.4/components/printers/Nautilus_View_printers.server.in.in
+--- nautilus-2.2.4.orig/components/printers/Nautilus_View_printers.server.in.in 1969-12-31 19:00:00.000000000 -0500
++++ nautilus-2.2.4/components/printers/Nautilus_View_printers.server.in.in 2003-05-26 22:17:59.000000000 -0400
+@@ -0,0 +1,20 @@
++<oaf_info>
++
++<oaf_server iid="OAFIID:Nautilus_Printers_View"
++ type="shlib" location="@BONOBODIR@/libnautilus-printers-view.so">
++ <oaf_attribute name="repo_ids" type="stringv">
++ <item value="IDL:Bonobo/Unknown:1.0"/>
++ <item value="IDL:Bonobo/Control:1.0"/>
++ <item value="IDL:Nautilus/View:1.0"/>
++ </oaf_attribute>
++ <oaf_attribute name="description" type="string" _value="Printers view for nautilus"/>
++ <oaf_attribute name="name" type="string" _value="Printers View"/>
++ <oaf_attribute name="bonobo:supported_uri_schemes" type="stringv">
++ <item value="printers"/>
++ </oaf_attribute>
++ <oaf_attribute name="nautilus:view_as_name" type="string" _value="Printers"/>
++ <oaf_attribute name="nautilus:view_as_label" type="string" _value="View as Printers"/>
++ <oaf_attribute name="nautilus:viewer_label" type="string" _value="Printer Viewer"/>
++</oaf_server>
++
++</oaf_info>
+diff -Nru -x '*~' -x '*.o' -x '*.orig' -x '*.rej' nautilus-2.2.4.orig/configure.in nautilus-2.2.4/configure.in
+--- nautilus-2.2.4.orig/configure.in 2003-05-07 13:51:36.000000000 -0400
++++ nautilus-2.2.4/configure.in 2003-05-27 01:31:42.000000000 -0400
+@@ -296,6 +296,17 @@
+ COMPONENT_LIBS="`$PKG_CONFIG --libs $COMPONENT_MODULES`"
+ AC_SUBST(COMPONENT_LIBS)
+
++dnl printer component
++dnl FIXME: Make optional
++
++PRINTER_MODULES="eel-2.0 libbonoboui-2.0 gnome-vfs-module-2.0 gnome-desktop-2.0 libgnomecups-1.0 libgnomecupsui-1.0"
++PKG_CHECK_MODULES(PRINTER, $PRINTER_MODULES)
++PRINTER_CFLAGS="`$PKG_CONFIG --cflags $PRINTER_MODULES`"
++AC_SUBST(PRINTER_CFLAGS)
++PRINTER_LIBS="`$PKG_CONFIG --libs $PRINTER_MODULES`"
++AC_SUBST(PRINTER_LIBS)
++
++
+ dnl emblems component
+ EMBLEM_COMPONENT_MODULES="$COMPONENT_MODULES librsvg-2.0"
+ EMBLEM_COMPONENT_CFLAGS="`$PKG_CONFIG --cflags $EMBLEM_COMPONENT_MODULES`"
+@@ -352,6 +363,7 @@
+ components/hardware/icons/Makefile
+ components/history/Makefile
+ components/notes/Makefile
++components/printers/Makefile
+ components/text/Makefile
+ components/text/services/Makefile
+ components/throbber/Makefile