aboutsummaryrefslogtreecommitdiff
path: root/libsylph/utils.c
diff options
context:
space:
mode:
authorhiro <hiro@ee746299-78ed-0310-b773-934348b2243d>2005-12-05 09:21:32 +0000
committerhiro <hiro@ee746299-78ed-0310-b773-934348b2243d>2005-12-05 09:21:32 +0000
commit4a468c2c09e69f053cb3948ec41716e2aa68bd07 (patch)
tree03f877ea561b4b49d7d288d979576dfba6d3edaa /libsylph/utils.c
parent4e8222b4ad7c46fc6e3d84d0d2c0de438b312737 (diff)
imap_cmd_append(): send message contents all at once.
git-svn-id: svn://sylpheed.sraoss.jp/sylpheed/trunk@800 ee746299-78ed-0310-b773-934348b2243d
Diffstat (limited to 'libsylph/utils.c')
-rw-r--r--libsylph/utils.c71
1 files changed, 71 insertions, 0 deletions
diff --git a/libsylph/utils.c b/libsylph/utils.c
index 8f531967..cfa223a7 100644
--- a/libsylph/utils.c
+++ b/libsylph/utils.c
@@ -2665,6 +2665,77 @@ gint canonicalize_file_replace(const gchar *file)
return 0;
}
+FILE *canonicalize_file_stream(FILE *src_fp, gint *length)
+{
+ FILE *dest_fp;
+ gchar buf[BUFFSIZE];
+ gint len;
+ gint length_ = 0;
+ gboolean err = FALSE;
+ gboolean last_linebreak = FALSE;
+
+ if ((dest_fp = my_tmpfile()) == NULL)
+ return NULL;
+
+ while (fgets(buf, sizeof(buf), src_fp) != NULL) {
+ gint r = 0;
+
+ len = strlen(buf);
+ if (len == 0) break;
+ last_linebreak = FALSE;
+
+ if (buf[len - 1] != '\n') {
+ last_linebreak = TRUE;
+ r = fputs(buf, dest_fp);
+ length_ += len;
+ } else if (len > 1 && buf[len - 1] == '\n' && buf[len - 2] == '\r') {
+ r = fputs(buf, dest_fp);
+ length_ += len;
+ } else {
+ if (len > 1) {
+ r = fwrite(buf, len - 1, 1, dest_fp);
+ if (r != 1)
+ r = EOF;
+ else
+ length_ += len - 1;
+ }
+ if (r != EOF) {
+ r = fputs("\r\n", dest_fp);
+ length_ += 2;
+ }
+ }
+
+ if (r == EOF) {
+ g_warning("writing to temporary file failed.\n");
+ fclose(dest_fp);
+ return NULL;
+ }
+ }
+
+ if (last_linebreak == TRUE) {
+ if (fputs("\r\n", dest_fp) == EOF)
+ err = TRUE;
+ else
+ length_ += 2;
+ }
+
+ if (ferror(src_fp)) {
+ FILE_OP_ERROR("canonicalize_file_stream", "fgets");
+ err = TRUE;
+ }
+
+ if (err) {
+ fclose(dest_fp);
+ return NULL;
+ }
+
+ if (length)
+ *length = length_;
+
+ rewind(dest_fp);
+ return dest_fp;
+}
+
gint uncanonicalize_file(const gchar *src, const gchar *dest)
{
FILE *src_fp, *dest_fp;