From: Leo Famulari <leo@famulari.name>
To: Lukas Gradl <lgradl@openmailbox.org>
Cc: guix-devel@gnu.org
Subject: Re: [PATCH] Add procmail
Date: Mon, 29 Feb 2016 14:50:19 -0500 [thread overview]
Message-ID: <20160229195019.GA21923@jasmine> (raw)
In-Reply-To: <87io1aqzrd.wl-lgradl@openmailbox.org>
On Sat, Feb 27, 2016 at 03:16:38AM -0600, Lukas Gradl wrote:
>
> Hello Guix!
>
> Attached is a patch to add the mail delivery agent Procmail.
>
> I am new to Guix and Scheme, so I would very much welcome any comments
> you might have.
> Thanks in advance!
>
> Best,
> Lukas
>
> From 862c540938cd16ed20ce8107ff9729e5f24dae09 Mon Sep 17 00:00:00 2001
> From: Lukas Gradl <lgradl@openmailbox.org>
> Date: Sat, 27 Feb 2016 02:43:57 -0600
> Subject: [PATCH] gnu: Add procmail.
>
> * gnu/packages/patches/procmail-ambiguous-getline-debian.patch: New file
> * gnu-system.am: Add patch
> * gnu/packages/mail.scm (procmail): New variable
A few more minor comments. When adding a patch to gnu-system.am, we
specify that we are adding the patch to (dist_patch_DATA). Also, we give
the name of the new variable. There's a good example in commit
c4a7904c2.
Thanks for this worthy addition! Can you send an updated patch
incorporating the changes requested by me and Andy?
> ---
> gnu-system.am | 1 +
> gnu/packages/mail.scm | 50 +++++++++++++++++++++
> .../procmail-ambiguous-getline-debian.patch | 52 ++++++++++++++++++++++
> 3 files changed, 103 insertions(+)
> create mode 100644 gnu/packages/patches/procmail-ambiguous-getline-debian.patch
>
> diff --git a/gnu-system.am b/gnu-system.am
> index 7727bad..c484031 100644
> --- a/gnu-system.am
> +++ b/gnu-system.am
> @@ -658,6 +658,7 @@ dist_patch_DATA = \
> gnu/packages/patches/plotutils-libpng-jmpbuf.patch \
> gnu/packages/patches/polkit-drop-test.patch \
> gnu/packages/patches/portaudio-audacity-compat.patch \
> + gnu/packages/patches/procmail-ambiguous-getline-debian.patch \
> gnu/packages/patches/pt-scotch-build-parallelism.patch \
> gnu/packages/patches/pulseaudio-fix-mult-test.patch \
> gnu/packages/patches/pulseaudio-longer-test-timeout.patch \
> diff --git a/gnu/packages/mail.scm b/gnu/packages/mail.scm
> index 5a9f420..31b23a1 100644
> --- a/gnu/packages/mail.scm
> +++ b/gnu/packages/mail.scm
> @@ -1085,4 +1085,54 @@ deliver it in various ways.")
> ;; with that information.
> (non-copyleft "https://github.com/nicm/fdm/blob/master/command.c"))))
>
> +
> +(define-public procmail
> + (package
> + (name "procmail")
> + (version "3.22")
> + (source
> + (origin
> + (method url-fetch)
> + (uri (string-append
> + "ftp://ftp.fu-berlin.de/pub/unix/mail/procmail/procmail-"
> + version
> + ".tar.gz"))
> + (sha256
> + (base32
> + "05z1c803n5cppkcq99vkyd5myff904lf9sdgynfqngfk9nrpaz08"))
> + ;; the following patch fixes an ambiguous definition of
> + ;; getline() in formail.c. The patch is provided by Debian as
> + ;; patch 24
> + (patches
> + (list
> + (search-patch "procmail-ambiguous-getline-debian.patch")))))
> + (arguments
> + `(#:phases (alist-replace
> + 'configure
> + (lambda _
> + (substitute* "Makefile"
> + (("/bin/sh")
> + (which "sh")))
> + (substitute* "Makefile"
> + (("/usr")
> + (assoc-ref %outputs "out")))
> + (substitute* "Makefile"
> + (("/bin/rm")
> + (which "rm"))))
> + %standard-phases)
> + #:tests? #f)) ; no tests
> + (build-system gnu-build-system)
> + (inputs `(("glibc" ,glibc)
> + ("exim" ,exim)))
> + (home-page "http://www.procmail.org/")
> + (synopsis "Versatile mail delivery agent (MDA)")
> + (description "Procmail is a mail delivery agent (MDA) featuring support
> +for a variety of mailbox formats such as mbox, mh and maildir. Incoming mail
> +can be sorted into separate files/directories and arbitrary commands can be
> +executed on mail arrival. Procmail is considered stable, but is no longer
> +maintained.")
> + (license gpl2+))) ; procmail allows to choose the
> + ; nonfree Artistic License 1.0
> + ; as alternative to the GPL2+.
> + ; This option is not listed here.
> ;;; mail.scm ends here
> diff --git a/gnu/packages/patches/procmail-ambiguous-getline-debian.patch b/gnu/packages/patches/procmail-ambiguous-getline-debian.patch
> new file mode 100644
> index 0000000..63bf258
> --- /dev/null
> +++ b/gnu/packages/patches/procmail-ambiguous-getline-debian.patch
> @@ -0,0 +1,52 @@
> +--- a/src/fields.c
> ++++ b/src/fields.c
> +@@ -110,16 +110,16 @@
> + /* try and append one valid field to rdheader from stdin */
> + int readhead P((void))
> + { int idlen;
> +- getline();
> ++ procmail_getline();
> + if((idlen=breakfield(buf,buffilled))<=0) /* not the start of a valid field */
> + return 0;
> + if(idlen==STRLEN(FROM)&&eqFrom_(buf)) /* it's a From_ line */
> + { if(rdheader)
> + return 0; /* the From_ line was a fake! */
> +- for(;buflast=='>';getline()); /* gather continued >From_ lines */
> ++ for(;buflast=='>';procmail_getline()); /* gather continued >From_ lines */
> + }
> + else
> +- for(;;getline()) /* get the rest of the continued field */
> ++ for(;;procmail_getline()) /* get the rest of the continued field */
> + { switch(buflast) /* will this line be continued? */
> + { case ' ':case '\t': /* yep, it sure is */
> + continue;
> +--- a/src/formail.c
> ++++ b/src/formail.c
> +@@ -819,7 +819,7 @@
> + { if(split) /* gobble up the next start separator */
> + { buffilled=0;
> + #ifdef sMAILBOX_SEPARATOR
> +- getline();buffilled=0; /* but only if it's defined */
> ++ procmail_getline();buffilled=0; /* but only if it's defined */
> + #endif
> + if(buflast!=EOF) /* if any */
> + goto splitit;
> +--- a/src/formisc.c
> ++++ b/src/formisc.c
> +@@ -115,7 +115,7 @@
> + buf[buffilled++]=c;
> + }
> +
> +-int getline P((void)) /* read a newline-terminated line */
> ++int procmail_getline P((void)) /* read a newline-terminated line */
> + { if(buflast==EOF) /* at the end of our Latin already? */
> + { loadchar('\n'); /* fake empty line */
> + return EOF; /* spread the word */
> +--- a/src/formisc.h
> ++++ b/src/formisc.h
> +@@ -17,4 +17,4 @@
> + char*
> + skipwords P((char*start));
> + int
> +- getline P((void));
> ++ procmail_getline P((void));
> --
> 2.6.3
>
next prev parent reply other threads:[~2016-02-29 19:50 UTC|newest]
Thread overview: 7+ messages / expand[flat|nested] mbox.gz Atom feed top
2016-02-27 9:16 [PATCH] Add procmail Lukas Gradl
2016-02-29 13:54 ` Andy Wingo
2016-03-01 4:35 ` Lukas Gradl
2016-02-29 19:50 ` Leo Famulari [this message]
2016-03-01 4:41 ` Lukas Gradl
2016-03-03 1:46 ` Leo Famulari
2016-03-03 2:59 ` Lukas Gradl
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
List information: https://guix.gnu.org/
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20160229195019.GA21923@jasmine \
--to=leo@famulari.name \
--cc=guix-devel@gnu.org \
--cc=lgradl@openmailbox.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
Code repositories for project(s) associated with this public inbox
https://git.savannah.gnu.org/cgit/guix.git
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).