gchar *srcfile;
gchar *destfile;
FILE *fp;
+ gint filemode = 0;
+ PrefsFolderItem *prefs;
g_return_val_if_fail(dest != NULL, -1);
g_return_val_if_fail(msginfo != NULL, -1);
if (dest->last_num < 0) return -1;
}
+ prefs = dest->prefs;
+
destdir = folder_item_get_path(dest);
if ((fp = procmsg_open_mark_file(destdir, TRUE)) == NULL)
g_warning(_("Can't open mark file.\n"));
return -1;
}
+ if (prefs && prefs->enable_folder_chmod && prefs->folder_chmod) {
+ if (chmod(destfile, prefs->folder_chmod) < 0)
+ FILE_OP_ERROR(destfile, "chmod");
+
+ /* for mark file */
+ filemode = prefs->folder_chmod;
+ if (filemode & S_IRGRP) filemode |= S_IWGRP;
+ if (filemode & S_IROTH) filemode |= S_IWOTH;
+ }
+
g_free(srcfile);
g_free(destfile);
dest->last_num++;
MSG_NEW|MSG_UNREAD|MSG_DELETED);
procmsg_write_flags(&newmsginfo, fp);
+
+ if (filemode) {
+#if HAVE_FCHMOD
+ fchmod(fileno(fp), filemode);
+#else
+ markfile = folder_item_get_mark_file(dest);
+ if (markfile) {
+ chmod(markfile, filemode);
+ g_free(markfile);
+ }
+#endif
+ }
+
fclose(fp);
}
FILE *fp;
GSList *cur;
MsgInfo *msginfo;
+ PrefsFolderItem *prefs;
g_return_val_if_fail(dest != NULL, -1);
g_return_val_if_fail(msglist != NULL, -1);
if (dest->last_num < 0) return -1;
}
+ prefs = dest->prefs;
+
destdir = folder_item_get_path(dest);
if ((fp = procmsg_open_mark_file(destdir, TRUE)) == NULL)
g_warning(_("Can't open mark file.\n"));
gchar *srcfile;
gchar *destfile;
FILE *fp;
+ gint filemode = 0;
+ PrefsFolderItem *prefs;
g_return_val_if_fail(dest != NULL, -1);
g_return_val_if_fail(msginfo != NULL, -1);
if (dest->last_num < 0) return -1;
}
+ prefs = dest->prefs;
+
destdir = folder_item_get_path(dest);
if (!is_dir_exist(destdir))
make_dir_hier(destdir);
return -1;
}
+ if (prefs && prefs->enable_folder_chmod && prefs->folder_chmod) {
+ if (chmod(destfile, prefs->folder_chmod) < 0)
+ FILE_OP_ERROR(destfile, "chmod");
+
+ /* for mark file */
+ filemode = prefs->folder_chmod;
+ if (filemode & S_IRGRP) filemode |= S_IWGRP;
+ if (filemode & S_IROTH) filemode |= S_IWOTH;
+ }
+
g_free(srcfile);
g_free(destfile);
dest->last_num++;
MSG_UNSET_PERM_FLAGS(newmsginfo.flags,
MSG_NEW|MSG_UNREAD|MSG_DELETED);
procmsg_write_flags(&newmsginfo, fp);
+
+ if (filemode) {
+#if HAVE_FCHMOD
+ fchmod(fileno(fp), filemode);
+#else
+ markfile = folder_item_get_mark_file(dest);
+ if (markfile) {
+ chmod(markfile, filemode);
+ g_free(markfile);
+ }
+#endif
+ }
+
fclose(fp);
}
GtkWidget *checkbtn_request_return_receipt;
GtkWidget *checkbtn_default_to;
GtkWidget *entry_default_to;
+ GtkWidget *checkbtn_folder_chmod;
+ GtkWidget *entry_folder_chmod;
};
static PrefParam param[] = {
NULL, NULL, NULL},
{"default_to", "", &tmp_prefs.default_to, P_STRING,
NULL, NULL, NULL},
+ {"enable_folder_chmod", "", &tmp_prefs.enable_folder_chmod, P_BOOL,
+ NULL, NULL, NULL},
+ {"folder_chmod", "", &tmp_prefs.folder_chmod, P_INT,
+ NULL, NULL, NULL},
{NULL, NULL, NULL, P_OTHER, NULL, NULL, NULL}
};
void prefs_folder_item_cancel_cb(GtkWidget *widget, struct PrefsFolderItemDialog *dialog);
void prefs_folder_item_ok_cb(GtkWidget *widget, struct PrefsFolderItemDialog *dialog);
void prefs_folder_item_default_to_cb(GtkWidget *widget, struct PrefsFolderItemDialog *dialog);
+void prefs_folder_item_folder_chmod_cb(GtkWidget *widget, struct PrefsFolderItemDialog *dialog);
+gint prefs_folder_item_chmod_mode(gchar *folder_chmod);
void prefs_folder_item_read_config(FolderItem * item)
{
tmp_prefs.request_return_receipt = FALSE;
tmp_prefs.enable_default_to = FALSE;
tmp_prefs.default_to = NULL;
+ tmp_prefs.enable_folder_chmod = FALSE;
+ tmp_prefs.folder_chmod = 0;
* prefs = tmp_prefs;
GtkWidget *checkbtn_request_return_receipt;
GtkWidget *checkbtn_default_to;
GtkWidget *entry_default_to;
+ GtkWidget *checkbtn_folder_chmod;
+ GtkWidget *entry_folder_chmod;
dialog = g_new0(struct PrefsFolderItemDialog, 1);
dialog->item = item;
gtk_editable_set_editable(GTK_EDITABLE(entry_default_to), item->prefs->enable_default_to);
gtk_entry_set_text(GTK_ENTRY(entry_default_to), item->prefs->default_to);
+ /* Folder chmod */
+ hbox = gtk_hbox_new(FALSE, 8);
+ gtk_widget_show(hbox);
+ gtk_box_pack_start(GTK_BOX(vbox), hbox, FALSE, FALSE, 0);
+
+ PACK_CHECK_BUTTON(hbox, checkbtn_folder_chmod,
+ _("Folder chmod: "));
+ gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(checkbtn_folder_chmod), item->prefs->enable_folder_chmod);
+ gtk_signal_connect(GTK_OBJECT(checkbtn_folder_chmod), "toggled",
+ GTK_SIGNAL_FUNC(prefs_folder_item_folder_chmod_cb), dialog);
+
+ entry_folder_chmod = gtk_entry_new();
+ gtk_widget_show(entry_folder_chmod);
+ gtk_box_pack_start(GTK_BOX(hbox), entry_folder_chmod, FALSE, FALSE, 0);
+ gtk_editable_set_editable(GTK_EDITABLE(entry_folder_chmod), item->prefs->enable_folder_chmod);
+ if (item->prefs->folder_chmod) {
+ gint tmp;
+ gint mult;
+ gint count = 0;
+ char buf[64]; /* plenty enough for an integer */
+
+ tmp = item->prefs->folder_chmod;
+ while (tmp && (count < sizeof(buf) - 1)) {
+ mult = tmp / 8;
+ buf[count++] = '0' + (tmp - mult * 8);
+ tmp /= 8;
+ }
+ buf[count] = '\0';
+ gtk_entry_set_text(GTK_ENTRY(entry_folder_chmod), buf);
+ }
+
dialog->window = window;
dialog->checkbtn_request_return_receipt = checkbtn_request_return_receipt;
dialog->checkbtn_default_to = checkbtn_default_to;
dialog->entry_default_to = entry_default_to;
+ dialog->checkbtn_folder_chmod = checkbtn_folder_chmod;
+ dialog->entry_folder_chmod = entry_folder_chmod;
gtk_widget_show(window);
}
g_free(prefs->default_to);
prefs->default_to =
gtk_editable_get_chars(GTK_EDITABLE(dialog->entry_default_to), 0, -1);
+ prefs->enable_folder_chmod =
+ gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(dialog->checkbtn_folder_chmod));
+ prefs->folder_chmod = prefs_folder_item_chmod_mode(
+ gtk_editable_get_chars(GTK_EDITABLE(dialog->entry_folder_chmod),
+ 0, -1));
prefs_folder_item_save_config(dialog->item);
prefs_folder_item_destroy(dialog);
gtk_editable_set_editable(GTK_EDITABLE(dialog->entry_default_to),
gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(dialog->checkbtn_default_to)));
}
+
+void prefs_folder_item_folder_chmod_cb(GtkWidget *widget, struct PrefsFolderItemDialog *dialog) {
+ gtk_editable_set_editable(GTK_EDITABLE(dialog->entry_folder_chmod),
+ gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(dialog->checkbtn_folder_chmod)));
+}
+
+gint prefs_folder_item_chmod_mode(gchar *folder_chmod) {
+ gint newmode = 0;
+ gchar *tmp;
+
+ if (folder_chmod) {
+ newmode = strtol(folder_chmod, &tmp, 8);
+ if (!(*(folder_chmod) && !(*tmp)))
+ newmode = 0;
+ }
+
+ return newmode;
+}
#include <string.h>
#include <ctype.h>
#include <unistd.h>
+#include <sys/stat.h>
#include "intl.h"
#include "main.h"
gchar *buf;
gchar *cachefile, *markfile;
GSList * cur;
+ gint filemode = 0;
+ PrefsFolderItem *prefs;
if (!summaryview->folder_item || !summaryview->folder_item->path)
return -1;
}
if (change_file_mode_rw(fps.cache_fp, cachefile) < 0)
FILE_OP_ERROR(cachefile, "chmod");
+
+ prefs = summaryview->folder_item->prefs;
+ if (prefs && prefs->enable_folder_chmod && prefs->folder_chmod) {
+ /* for cache file */
+ filemode = prefs->folder_chmod;
+ if (filemode & S_IRGRP) filemode |= S_IWGRP;
+ if (filemode & S_IROTH) filemode |= S_IWOTH;
+#if HAVE_FCHMOD
+ fchmod(fileno(fps.cache_fp), filemode);
+#else
+ chmod(cachefile, filemode);
+#endif
+ }
+
g_free(cachefile);
markfile = folder_item_get_mark_file(summaryview->folder_item);
}
if (change_file_mode_rw(fps.mark_fp, markfile) < 0)
FILE_OP_ERROR(markfile, "chmod");
+ if (prefs && prefs->enable_folder_chmod && prefs->folder_chmod) {
+#if HAVE_FCHMOD
+ fchmod(fileno(fps.mark_fp), filemode);
+#else
+ chmod(markfile, filemode);
+#endif
+ }
+
g_free(markfile);
buf = g_strdup_printf(_("Writing summary cache (%s)..."),