X-Git-Url: https://vcs.fsf.org/?a=blobdiff_plain;f=src%2Fsrc%2Fspool_in.c;h=915798784297ac9f2593708705b4ce4e75657073;hb=6d5c916cc5720591335fea53242dd6b97ea56fe3;hp=6341387a206f45f6a91181548e26e1da3d0b2cb2;hpb=a2da3176aa39ec9aa5ae495e5a6d533477f871aa;p=exim.git diff --git a/src/src/spool_in.c b/src/src/spool_in.c index 6341387a2..915798784 100644 --- a/src/src/spool_in.c +++ b/src/src/spool_in.c @@ -37,7 +37,6 @@ spool_open_datafile(uschar *id) int i; struct stat statbuf; flock_t lock_data; -uschar spoolname[256]; int fd; /* If split_spool_directory is set, first look for the file in the appropriate @@ -49,23 +48,27 @@ splitting state. */ for (i = 0; i < 2; i++) { + uschar * fname; int save_errno; - message_subdir[0] = split_spool_directory == (i == 0) ? id[5] : 0; - snprintf(CS spoolname, sizeof(spoolname), "%s/input/%s/%s/%s-D", - spool_directory, queue_name, message_subdir, id); - DEBUG(D_deliver) debug_printf("Trying spool file %s\n", spoolname); - if ((fd = Uopen(spoolname, O_RDWR | O_APPEND, 0)) >= 0) + message_subdir[0] = split_spool_directory == i == 0 ? id[5] : 0; + fname = spool_fname(US"input", message_subdir, id, US"-D"); + DEBUG(D_deliver) debug_printf("Trying spool file %s\n", fname); + + if ((fd = Uopen(fname, O_RDWR | O_APPEND, 0)) >= 0) break; save_errno = errno; if (errno == ENOENT) { if (i == 0) continue; if (!queue_running) - log_write(0, LOG_MAIN, "Spool file %s-D not found", id); + log_write(0, LOG_MAIN, "Spool%s%s file %s-D not found", + *queue_name ? US" Q=" : US"", + *queue_name ? queue_name : US"", + id); } - else log_write(0, LOG_MAIN, "Spool error for %s: %s", spoolname, - strerror(errno)); + else + log_write(0, LOG_MAIN, "Spool error for %s: %s", fname, strerror(errno)); errno = save_errno; return -1; } @@ -322,10 +325,11 @@ for (n = 0; n < 2; n++) { if (!subdir_set) message_subdir[0] = split_spool_directory == (n == 0) ? name[5] : 0; - sprintf(CS big_buffer, "%s/input/%s/%s/%s", - spool_directory, queue_name, message_subdir, name); - if ((f = Ufopen(big_buffer, "rb"))) break; - if (n != 0 || subdir_set || errno != ENOENT) return spool_read_notopen; + + if ((f = Ufopen(spool_fname(US"input", message_subdir, name, US""), "rb"))) + break; + if (n != 0 || subdir_set || errno != ENOENT) + return spool_read_notopen; } errno = 0;