guix-devel
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [PATCH] Add procmail


From: Leo Famulari
Subject: Re: [PATCH] Add procmail
Date: Mon, 29 Feb 2016 14:50:19 -0500
User-agent: Mutt/1.5.24 (2015-08-30)

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 <address@hidden>
> 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
> 




reply via email to

[Prev in Thread] Current Thread [Next in Thread]