#include "stock_pixmap.h"
#include "gtk/gtkvscrollbutton.h"
#include "gtk/logwindow.h"
-
+#include "timing.h"
typedef enum
{
guint time,
MimeView *mimeview);
+static gboolean mimeview_scrolled (GtkWidget *widget,
+ GdkEventScroll *event,
+ MimeView *mimeview);
static void mimeview_display_as_text (MimeView *mimeview);
static void mimeview_save_as (MimeView *mimeview);
static void mimeview_save_all (MimeView *mimeview);
-static void mimeview_launch (MimeView *mimeview);
+static void mimeview_launch (MimeView *mimeview,
+ MimeInfo *partinfo);
static void mimeview_open_with (MimeView *mimeview);
static void mimeview_open_part_with (MimeView *mimeview,
- MimeInfo *partinfo);
+ MimeInfo *partinfo,
+ gboolean automatic);
static void mimeview_view_file (const gchar *filename,
MimeInfo *partinfo,
- const gchar *cmdline,
+ const gchar *cmd,
MimeView *mimeview);
static gboolean icon_clicked_cb (GtkWidget *button,
GdkEventButton *event,
static void icon_scroll_size_allocate_cb(GtkWidget *widget,
GtkAllocation *layout_size,
MimeView *mimeview);
+static MimeInfo *mimeview_get_part_to_use(MimeView *mimeview);
+static void mimeview_launch_cb(MimeView *mimeview)
+{
+ mimeview_launch(mimeview, mimeview_get_part_to_use(mimeview));
+}
static GtkItemFactoryEntry mimeview_popup_entries[] =
{
- {N_("/_Open"), NULL, mimeview_launch, 0, NULL},
+ {N_("/_Open"), NULL, mimeview_launch_cb, 0, NULL},
{N_("/Open _with..."), NULL, mimeview_open_with, 0, NULL},
{N_("/_Display as text"), NULL, mimeview_display_as_text, 0, NULL},
{N_("/_Save as..."), NULL, mimeview_save_as, 0, NULL},
scrollbutton = gtk_vscrollbutton_new(gtk_layout_get_vadjustment(GTK_LAYOUT(icon_scroll)));
gtk_widget_show(scrollbutton);
+ g_signal_connect(G_OBJECT(icon_scroll), "scroll_event",
+ G_CALLBACK(mimeview_scrolled), mimeview);
+
mime_toggle = gtk_toggle_button_new();
gtk_widget_show(mime_toggle);
arrow = gtk_arrow_new(GTK_ARROW_LEFT, GTK_SHADOW_NONE);
mimeview->oldsize = 60;
mimeview->mime_toggle = mime_toggle;
mimeview->siginfoview = siginfoview;
-
+ mimeview->scrollbutton = scrollbutton;
mimeview->target_list = gtk_target_list_new(mimeview_mime_types, 1);
mimeviews = g_slist_prepend(mimeviews, mimeview);
const gchar *fname;
if (!partinfo) return;
+ if (partinfo == mimeview->opened)
+ return;
fname = mimeview->file;
if (!fname) return;
static void mimeview_change_view_type(MimeView *mimeview, MimeViewType type)
{
TextView *textview = mimeview->textview;
+ GtkWidget *focused = NULL;
+
+ if (mainwindow_get_mainwindow())
+ focused = gtkut_get_focused_child(mainwindow_get_mainwindow()->window);
if ((mimeview->type != MIMEVIEW_VIEWER) &&
(mimeview->type == type)) return;
default:
return;
}
-
+ if (focused)
+ gtk_widget_grab_focus(focused);
mimeview->type = type;
}
return FALSE;
}
+static gboolean mimeview_scrolled(GtkWidget *widget, GdkEventScroll *event,
+ MimeView *mimeview)
+{
+ GtkVScrollbutton *scrollbutton = (GtkVScrollbutton *)mimeview->scrollbutton;
+ if (event->direction == GDK_SCROLL_UP) {
+ scrollbutton->scroll_type = GTK_SCROLL_STEP_BACKWARD;
+ } else {
+ scrollbutton->scroll_type = GTK_SCROLL_STEP_FORWARD;
+ }
+ gtk_vscrollbutton_scroll(scrollbutton);
+ return TRUE;
+}
+
/* from gdkevents.c */
#define DOUBLE_CLICK_TIME 250
if (event->button == 2 ||
(event->button == 1 && (event->time - lasttime) < DOUBLE_CLICK_TIME && lastinfo == partinfo)) {
/* call external program for image, audio or html */
- mimeview_launch(mimeview);
+ mimeview_launch(mimeview, partinfo);
return TRUE;
} else if (event->button == 3) {
if (partinfo && (partinfo->type == MIMETYPE_MESSAGE ||
switch (event->keyval) {
case GDK_space:
- if (textview_scroll_page(mimeview->textview, FALSE))
+ if (mimeview_scroll_page(mimeview, FALSE))
return TRUE;
node = GTK_CTREE_NODE_NEXT(mimeview->opened);
}
break;
case GDK_BackSpace:
- textview_scroll_page(mimeview->textview, TRUE);
+ mimeview_scroll_page(mimeview, TRUE);
return TRUE;
case GDK_Return:
- textview_scroll_one_line(mimeview->textview,
+ mimeview_scroll_one_line(mimeview,
(event->state & GDK_MOD1_MASK) != 0);
return TRUE;
case GDK_n:
case GDK_l:
BREAK_ON_MODIFIER_KEY();
KEY_PRESS_EVENT_STOP();
- mimeview_launch(mimeview);
+ mimeview_launch(mimeview, NULL);
return TRUE;
case GDK_o:
BREAK_ON_MODIFIER_KEY();
partinfo = mimeview->spec_part;
mimeview->spec_part = NULL;
} else {
- partinfo = mimeview_get_selected_part(mimeview);
+ partinfo = (MimeInfo *) g_object_get_data
+ (G_OBJECT(mimeview->popupmenu),
+ "pop_partinfo");
+ g_object_set_data(G_OBJECT(mimeview->popupmenu),
+ "pop_partinfo", NULL);
if (!partinfo) {
- partinfo = (MimeInfo *) g_object_get_data
- (G_OBJECT(mimeview->popupmenu),
- "pop_partinfo");
- g_object_set_data(G_OBJECT(mimeview->popupmenu),
- "pop_partinfo", NULL);
+ partinfo = mimeview_get_selected_part(mimeview);
}
}
if (!mimeview->opened) return;
partinfo = mimeview_get_part_to_use(mimeview);
-
+ mimeview_select_mimepart_icon(mimeview, partinfo);
g_return_if_fail(partinfo != NULL);
mimeview_show_message_part(mimeview, partinfo);
}
-static void mimeview_launch(MimeView *mimeview)
+static void mimeview_launch(MimeView *mimeview, MimeInfo *partinfo)
{
- MimeInfo *partinfo;
gchar *filename;
if (!mimeview->opened) return;
if (!mimeview->file) return;
- partinfo = mimeview_get_part_to_use(mimeview);
+ if (!partinfo)
+ partinfo = mimeview_get_part_to_use(mimeview);
g_return_if_fail(partinfo != NULL);
partinfo = mimeview_get_part_to_use(mimeview);
- mimeview_open_part_with(mimeview, partinfo);
+ mimeview_open_part_with(mimeview, partinfo, FALSE);
}
-static void mimeview_open_part_with(MimeView *mimeview, MimeInfo *partinfo)
+static void mimeview_open_part_with(MimeView *mimeview, MimeInfo *partinfo, gboolean automatic)
{
gchar *filename;
gchar *cmd;
content_type = procmime_get_content_type_str(partinfo->type,
partinfo->subtype);
}
- mime_command = mailcap_get_command_for_type(content_type);
-
+
+ if ((partinfo->type == MIMETYPE_TEXT && !strcmp(partinfo->subtype, "html"))
+ && prefs_common.uri_cmd && prefs_common.uri_cmd[0]) {
+ mime_command = g_strdup(prefs_common.uri_cmd);
+ g_free(content_type);
+ content_type = NULL;
+ } else if (partinfo->type != MIMETYPE_TEXT || !prefs_common.ext_editor_cmd
+ || !prefs_common.ext_editor_cmd[0]) {
+ mime_command = mailcap_get_command_for_type(content_type, filename);
+ } else {
+ mime_command = g_strdup(prefs_common.ext_editor_cmd);
+ g_free(content_type);
+ content_type = NULL;
+ }
if (mime_command == NULL) {
/* try with extension this time */
g_free(content_type);
content_type = procmime_get_mime_type(filename);
- mime_command = mailcap_get_command_for_type(content_type);
+ mime_command = mailcap_get_command_for_type(content_type, filename);
}
- g_free(content_type);
- cmd = input_dialog_combo
- (_("Open with"),
- _("Enter the command line to open file:\n"
- "('%s' will be replaced with file name)"),
- mime_command ? mime_command : prefs_common.mime_open_cmd,
- prefs_common.mime_open_cmd_history,
- TRUE);
- g_free(mime_command);
+ if (mime_command == NULL)
+ automatic = FALSE;
+
+ if (!automatic) {
+ gboolean remember = FALSE;
+ if (content_type != NULL)
+ cmd = input_dialog_combo_remember
+ (_("Open with"),
+ _("Enter the command line to open file:\n"
+ "('%s' will be replaced with file name)"),
+ mime_command ? mime_command : prefs_common.mime_open_cmd,
+ prefs_common.mime_open_cmd_history,
+ TRUE, &remember);
+ else
+ cmd = input_dialog_combo
+ (_("Open with"),
+ _("Enter the command line to open file:\n"
+ "('%s' will be replaced with file name)"),
+ mime_command ? mime_command : prefs_common.mime_open_cmd,
+ prefs_common.mime_open_cmd_history,
+ TRUE);
+ if (cmd && remember) {
+ mailcap_update_default(content_type, cmd);
+ }
+ g_free(mime_command);
+ } else {
+ cmd = mime_command;
+ }
if (cmd) {
mimeview_view_file(filename, partinfo, cmd, mimeview);
g_free(prefs_common.mime_open_cmd);
prefs_common.mime_open_cmd_history =
add_history(prefs_common.mime_open_cmd_history, cmd);
}
-
+ g_free(content_type);
g_free(filename);
}
static void mimeview_view_file(const gchar *filename, MimeInfo *partinfo,
- const gchar *cmdline, MimeView *mimeview)
-{
- static gchar *default_image_cmdline = DEFAULT_IMAGE_VIEWER_CMD;
- static gchar *default_audio_cmdline = DEFAULT_AUDIO_PLAYER_CMD;
- static gchar *default_html_cmdline = DEFAULT_BROWSER_CMD;
- static gchar *mime_cmdline = DEFAULT_MIME_CMD;
- gchar buf[1024];
- gchar m_buf[1024];
- const gchar *cmd;
- const gchar *def_cmd;
- const gchar *p;
-
- if (cmdline) {
- cmd = cmdline;
- def_cmd = NULL;
- } else if (MIMETYPE_APPLICATION == partinfo->type &&
- !g_ascii_strcasecmp(partinfo->subtype, "octet-stream")) {
- mimeview_open_part_with(mimeview, partinfo);
- return;
- } else if (MIMETYPE_IMAGE == partinfo->type) {
- cmd = prefs_common.mime_image_viewer;
- def_cmd = default_image_cmdline;
- } else if (MIMETYPE_AUDIO == partinfo->type) {
- cmd = prefs_common.mime_audio_player;
- def_cmd = default_audio_cmdline;
- } else if (MIMETYPE_TEXT == partinfo->type && !strcmp(partinfo->subtype, "html")) {
- cmd = prefs_common.uri_cmd;
- def_cmd = default_html_cmdline;
- } else {
- gchar *content_type;
-
- content_type = procmime_get_content_type_str(partinfo->type, partinfo->subtype);
- g_snprintf(m_buf, sizeof(m_buf), mime_cmdline,
- content_type, "%s");
- g_free(content_type);
- cmd = m_buf;
- def_cmd = NULL;
- }
-
- if (cmd && (p = strchr(cmd, '%')) && *(p + 1) == 's' &&
- !strchr(p + 2, '%'))
- g_snprintf(buf, sizeof(buf), cmd, filename);
+ const gchar *cmd, MimeView *mimeview)
+{
+ gchar *p;
+ gchar buf[BUFFSIZE];
+ if (cmd == NULL)
+ mimeview_open_part_with(mimeview, partinfo, TRUE);
else {
- if (cmd)
+ if ((p = strchr(cmd, '%')) && *(p + 1) == 's' &&
+ !strchr(p + 2, '%'))
+ g_snprintf(buf, sizeof(buf), cmd, filename);
+ else {
g_warning("MIME viewer command line is invalid: '%s'", cmd);
- if (def_cmd)
- g_snprintf(buf, sizeof(buf), def_cmd, filename);
- else {
- mimeview_open_part_with(mimeview, partinfo);
- return;
- }
+ mimeview_open_part_with(mimeview, partinfo, FALSE);
+ }
+ if (execute_command_line(buf, TRUE) != 0)
+ mimeview_open_part_with(mimeview, partinfo, FALSE);
}
-
- if (execute_command_line(buf, TRUE) != 0)
- mimeview_open_part_with(mimeview, partinfo);
}
void mimeview_register_viewer_factory(MimeViewerFactory *factory)
num = GPOINTER_TO_INT(g_object_get_data(G_OBJECT(button), "icon_number"));
partinfo = g_object_get_data(G_OBJECT(button), "partinfo");
- icon_selected(mimeview, num, partinfo);
- gtk_widget_grab_focus(button);
- if (!gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(button))) {
- toggle_icon(GTK_TOGGLE_BUTTON(button), mimeview);
- if (event->button == 2 || event->button == 3)
- gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(button),
- TRUE);
+ if (event->button == 1) {
+ icon_selected(mimeview, num, partinfo);
+ gtk_widget_grab_focus(button);
+ if (!gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(button))) {
+ toggle_icon(GTK_TOGGLE_BUTTON(button), mimeview);
+ }
}
-
part_button_pressed(mimeview, event, partinfo);
return FALSE;
gtk_ctree_select(GTK_CTREE(mimeview->ctree), node);
}
+void mimeview_select_mimepart_icon(MimeView *mimeview, MimeInfo *partinfo)
+{
+ icon_list_toggle_by_mime_info(mimeview, partinfo);
+ icon_selected(mimeview, -1, partinfo);
+}
+
#undef KEY_PRESS_EVENT_STOP
#define KEY_PRESS_EVENT_STOP() \
g_signal_stop_emission_by_name(G_OBJECT(button), \
if (gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(button))) {
/* stop the button being untoggled */
KEY_PRESS_EVENT_STOP();
- if (textview_scroll_page(textview, FALSE))
+ if (mimeview_scroll_page(mimeview, FALSE))
return TRUE;
if (icon_list_select_by_number(mimeview, num + 1))
break;
case GDK_BackSpace:
- textview_scroll_page(textview, TRUE);
+ mimeview_scroll_page(mimeview, TRUE);
return TRUE;
case GDK_Return:
if (gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(button))) {
KEY_PRESS_EVENT_STOP();
- textview_scroll_one_line(textview,
+ mimeview_scroll_one_line(mimeview,
(event->state & GDK_MOD1_MASK) != 0);
return TRUE;
} else {
case GDK_l:
BREAK_ON_MODIFIER_KEY();
KEY_PRESS_EVENT_STOP();
- mimeview_launch(mimeview);
+ mimeview_launch(mimeview, NULL);
return TRUE;
case GDK_o:
BREAK_ON_MODIFIER_KEY();
gtk_layout_set_size(GTK_LAYOUT(mimeview->icon_scroll),
GTK_LAYOUT(mimeview->icon_scroll)->width,
MAX(vbox_size->height, layout_size->height));
- adj->step_increment = 5;
+ adj->step_increment = 10;
}
static void icon_list_create(MimeView *mimeview, MimeInfo *mimeinfo)
if (!mainwin)
return;
- else if (!strcmp(cmd, "sc://view_log"))
+ g_object_set_data(G_OBJECT(mimeview->popupmenu),
+ "pop_partinfo", NULL);
+
+ if (!strcmp(cmd, "sc://view_log"))
log_window_show(mainwin->logwin);
else if (!strcmp(cmd, "sc://save_as"))
mimeview_save_as(mimeview);
else if (!strcmp(cmd, "sc://open_with"))
mimeview_open_with(mimeview);
else if (!strcmp(cmd, "sc://open"))
- mimeview_launch(mimeview);
+ mimeview_launch(mimeview, NULL);
else if (!strcmp(cmd, "sc://select_attachment") && data != NULL) {
icon_list_toggle_by_mime_info(mimeview, (MimeInfo *)data);
icon_selected(mimeview, -1, (MimeInfo *)data);
} else if (!strcmp(cmd, "sc://open_attachment") && data != NULL) {
- icon_list_toggle_by_mime_info(mimeview, (MimeInfo *)data);
- icon_selected(mimeview, -1, (MimeInfo *)data);
- mimeview_launch(mimeview);
+ mimeview_launch(mimeview, (MimeInfo *)data);
} else if (!strcmp(cmd, "sc://menu_attachment") && data != NULL) {
mimeview->spec_part = (MimeInfo *)data;
part_button_pressed(mimeview, event, (MimeInfo *)data);
}
}
+gboolean mimeview_scroll_page(MimeView *mimeview, gboolean up)
+{
+ if (mimeview->type == MIMEVIEW_TEXT)
+ return textview_scroll_page(mimeview->textview, up);
+ else if (mimeview->mimeviewer) {
+ MimeViewer *mimeviewer = mimeview->mimeviewer;
+ if (mimeviewer->scroll_page)
+ return mimeviewer->scroll_page(mimeviewer, up);
+ }
+ return TRUE;
+}
+
+void mimeview_scroll_one_line(MimeView *mimeview, gboolean up)
+{
+ if (mimeview->type == MIMEVIEW_TEXT)
+ textview_scroll_one_line(mimeview->textview, up);
+ else if (mimeview->mimeviewer) {
+ MimeViewer *mimeviewer = mimeview->mimeviewer;
+ if (mimeviewer->scroll_one_line)
+ mimeviewer->scroll_one_line(mimeviewer, up);
+ }
+}