unofficial mirror of guix-devel@gnu.org 
 help / color / mirror / code / Atom feed
* [PATCH 1/9] gnu: Add ttfautohint.
@ 2016-04-06  4:32 ericbavier
  2016-04-06  4:32 ` [PATCH 2/9] gnu: Add woff-tools ericbavier
                   ` (9 more replies)
  0 siblings, 10 replies; 34+ messages in thread
From: ericbavier @ 2016-04-06  4:32 UTC (permalink / raw)
  To: guix-devel; +Cc: Eric Bavier

From: Eric Bavier <bavier@member.fsf.org>

* gnu/packages/fontutils.scm (ttfautohint): New variable.
* gnu/packages/patches/ttfautohint-source-date-epoch.patch: New patch.
* gnu-system.am (dist_patch_DATA): Add it.
---
 gnu-system.am                                      |  1 +
 gnu/packages/fontutils.scm                         | 36 ++++++++++-
 .../patches/ttfautohint-source-date-epoch.patch    | 70 ++++++++++++++++++++++
 3 files changed, 106 insertions(+), 1 deletion(-)
 create mode 100644 gnu/packages/patches/ttfautohint-source-date-epoch.patch

diff --git a/gnu-system.am b/gnu-system.am
index c8048b7..764e564 100644
--- a/gnu-system.am
+++ b/gnu-system.am
@@ -747,6 +747,7 @@ dist_patch_DATA =						\
   gnu/packages/patches/tidy-CVE-2015-5522+5523.patch		\
   gnu/packages/patches/tinyxml-use-stl.patch			\
   gnu/packages/patches/tk-find-library.patch			\
+  gnu/packages/patches/ttfautohint-source-date-epoch.patch	\
   gnu/packages/patches/tophat-build-with-later-seqan.patch	\
   gnu/packages/patches/torsocks-dns-test.patch			\
   gnu/packages/patches/tvtime-gcc41.patch			\
diff --git a/gnu/packages/fontutils.scm b/gnu/packages/fontutils.scm
index ff10a4a..a0701d5 100644
--- a/gnu/packages/fontutils.scm
+++ b/gnu/packages/fontutils.scm
@@ -1,6 +1,6 @@
 ;;; GNU Guix --- Functional package management for GNU
 ;;; Copyright © 2013, 2014, 2015 Andreas Enge <andreas@enge.fr>
-;;; Copyright © 2014 Eric Bavier <bavier@member.fsf.org>
+;;; Copyright © 2014, 2016 Eric Bavier <bavier@member.fsf.org>
 ;;; Copyright © 2016 Mark H Weaver <mhw@netris.org>
 ;;; Copyright © 2016 Efraim Flashner <efraim@flashner.co.il>
 ;;;
@@ -29,6 +29,8 @@
   #:use-module (gnu packages gettext)
   #:use-module (gnu packages python)
   #:use-module (gnu packages image)
+  #:use-module (gnu packages bison)
+  #:use-module (gnu packages flex)
   #:use-module (gnu packages glib)
   #:use-module (gnu packages xorg)
   #:use-module (gnu packages gtk)
@@ -70,6 +72,38 @@ anti-aliased glyph bitmap generation with 256 gray levels.")
    (license license:freetype)           ; some files have other licenses
    (home-page "http://www.freetype.org/")))
 
+(define-public ttfautohint
+  (package
+    (name "ttfautohint")
+    (version "1.5")
+    (source
+     (origin
+       (method url-fetch)
+       (uri (string-append "mirror://savannah/freetype/ttfautohint-"
+                           version ".tar.gz"))
+       (sha256
+        (base32
+         ;; /gnu/store/5kzmy7061aimljpga9qfz49227283sfr-ttfautohint-1.5.tar.gz
+         "1lgghck46p33z3hg8dnl76jryig4fh6d8rhzms837zp7x4hyfkv4"))
+       (patches (map search-patch '("ttfautohint-source-date-epoch.patch")))))
+    (build-system gnu-build-system)
+    (native-inputs
+     `(("flex" ,flex)
+       ("bison" ,bison)
+       ("pkg-config" ,pkg-config)))
+    (inputs
+     `(("freetype" ,freetype)
+       ("harfbuzz" ,harfbuzz)))
+    (arguments
+     `(#:configure-flags '("--with-qt=no"))) ;no gui
+    (synopsis "Automated font hinting")
+    (description
+     "ttfautohint provides a 99% automated hinting process and a platform for
+finely hand-hinting the last 1%.  It is ideal for web fonts and supports many
+scripts.")
+    (license license:gpl2+)             ;or FreeType license
+    (home-page "http://www.freetype.org/ttfautohint/")))
+
 (define-public fontconfig
   (package
    (name "fontconfig")
diff --git a/gnu/packages/patches/ttfautohint-source-date-epoch.patch b/gnu/packages/patches/ttfautohint-source-date-epoch.patch
new file mode 100644
index 0000000..e42fdbf
--- /dev/null
+++ b/gnu/packages/patches/ttfautohint-source-date-epoch.patch
@@ -0,0 +1,70 @@
+Honour an external definition of SOURCE_DATE_EPOCH when updating the embedded
+modification date in TTF/TTC files.
+
+--- a/lib/tatime.c
++++ b/lib/tatime.c
+@@ -15,6 +15,8 @@
+ 
+ #include <time.h>
+ #include <stdint.h>
++#include <errno.h>
++#include <limits.h>
+ 
+ #include "ta.h"
+ 
+@@ -27,12 +29,51 @@ TA_get_current_time(FT_ULong* high,
+ {
+   /* there have been 24107 days between January 1st, 1904 (the epoch of */
+   /* OpenType), and January 1st, 1970 (the epoch of the `time' function) */
+-  TA_ULongLong seconds_to_1970 = 24107 * 24 * 60 * 60;
+-  TA_ULongLong seconds_to_today = seconds_to_1970 + (TA_ULongLong)time(NULL);
++  const TA_ULongLong seconds_to_1970 = 24107 * 24 * 60 * 60;
++  TA_ULongLong seconds_to_build;
+ 
++  time_t now;
++  char *source_date_epoch, *endptr;
++  TA_ULongLong epoch;
++  source_date_epoch = getenv("SOURCE_DATE_EPOCH");
++  if (source_date_epoch) {
++    errno = 0;
++    epoch = strtoull(source_date_epoch, &endptr, 10);
++    if ((errno == ERANGE && (epoch == ULLONG_MAX || epoch == 0))
++	|| (errno != 0 && epoch == 0)) {
++      fprintf(stderr,
++	      "Environment variable $SOURCE_DATE_EPOCH: strtoull: %s\n",
++	      strerror(errno));
++      exit(EXIT_FAILURE);
++    }
++    if (endptr == source_date_epoch) {
++      fprintf(stderr,
++	      "Environment variable $SOURCE_DATE_EPOCH: No digits were found: %s\n",
++	      endptr);
++      exit(EXIT_FAILURE);
++    }
++    if (*endptr != '\0') {
++      fprintf(stderr,
++	      "Environment variable $SOURCE_DATE_EPOCH: Trailing garbage: %s\n",
++	      endptr);
++      exit(EXIT_FAILURE);
++    }
++    if (epoch > ULONG_MAX) {
++      fprintf(stderr,
++	      "Environment variable $SOURCE_DATE_EPOCH: value must be smaller "
++	      "than or equal to: %lu but was found to be: %llu \n",
++	      ULONG_MAX, epoch);
++      exit(EXIT_FAILURE);
++    }
++    now = epoch;
++  } else {
++    now = time(NULL);
++  }
+ 
+-  *high = (FT_ULong)(seconds_to_today >> 32);
+-  *low = (FT_ULong)seconds_to_today;
++  seconds_to_build = seconds_to_1970 + (TA_ULongLong)now;
++
++  *high = (FT_ULong)(seconds_to_build >> 32);
++  *low = (FT_ULong)seconds_to_build;
+ }
+ 
+ /* end of tatime.c */
-- 
2.7.3

^ permalink raw reply related	[flat|nested] 34+ messages in thread

* [PATCH 2/9] gnu: Add woff-tools.
  2016-04-06  4:32 [PATCH 1/9] gnu: Add ttfautohint ericbavier
@ 2016-04-06  4:32 ` ericbavier
  2016-04-07  6:18   ` Efraim Flashner
  2016-04-06  4:32 ` [PATCH 3/9] gnu: Add ttf2eot ericbavier
                   ` (8 subsequent siblings)
  9 siblings, 1 reply; 34+ messages in thread
From: ericbavier @ 2016-04-06  4:32 UTC (permalink / raw)
  To: guix-devel; +Cc: Eric Bavier

From: Eric Bavier <bavier@member.fsf.org>

* gnu/packages/fontutils.scm (woff-tools): New variable.
---
 gnu/packages/fontutils.scm | 41 +++++++++++++++++++++++++++++++++++++++++
 1 file changed, 41 insertions(+)

diff --git a/gnu/packages/fontutils.scm b/gnu/packages/fontutils.scm
index a0701d5..614aac5 100644
--- a/gnu/packages/fontutils.scm
+++ b/gnu/packages/fontutils.scm
@@ -104,6 +104,47 @@ scripts.")
     (license license:gpl2+)             ;or FreeType license
     (home-page "http://www.freetype.org/ttfautohint/")))
 
+(define-public woff-tools
+  (package
+    (name "woff-tools")
+    (version "2009.10.04")
+    (source
+     (origin
+       (method url-fetch)
+       ;; Upstream source is unversioned, so use Debian's versioned tarball
+       (uri (string-append "mirror://debian/pool/main/w/woff-tools/"
+                           "woff-tools_" version ".orig.tar.gz"))
+       (file-name (string-append name "-" version ".tar.gz"))
+       (sha256
+        (base32
+         "1i97gkqa6jfzlslsngqf556kx60knlgf7yc9pzsq2pizc6f0d4zl"))))
+    (build-system gnu-build-system)
+    (inputs
+     `(("zlib" ,zlib)))
+    (arguments
+     `(#:make-flags '("CC=gcc")
+       #:tests? #f                      ;no tests
+       #:phases
+       (modify-phases %standard-phases
+         (delete 'configure)            ;no configuration
+         (replace 'install
+           (lambda* (#:key outputs #:allow-other-keys)
+             (let* ((out (assoc-ref outputs "out"))
+                    (bin (string-append out "/bin")))
+               (install-file "sfnt2woff" bin)
+               (install-file "woff2sfnt" bin)))))))
+    (synopsis "Convert between OpenType and WOFF formats")
+    (description
+     "This package provides two tools:
+@table @code
+@item sfnt2woff
+Converts OpenType fonts to WOFF fonts
+@item woff2sfnt
+Converts WOFF fonts to OpenType fonts
+@end table")
+    (license (list license:mpl1.1 license:gpl2+ license:lgpl2.1+))
+    (home-page "https://people.mozilla.com/~jkew/woff/")))
+
 (define-public fontconfig
   (package
    (name "fontconfig")
-- 
2.7.3

^ permalink raw reply related	[flat|nested] 34+ messages in thread

* [PATCH 3/9] gnu: Add ttf2eot.
  2016-04-06  4:32 [PATCH 1/9] gnu: Add ttfautohint ericbavier
  2016-04-06  4:32 ` [PATCH 2/9] gnu: Add woff-tools ericbavier
@ 2016-04-06  4:32 ` ericbavier
  2016-04-07  6:24   ` Efraim Flashner
  2016-04-06  4:32 ` [PATCH 4/9] gnu: Add brotli ericbavier
                   ` (7 subsequent siblings)
  9 siblings, 1 reply; 34+ messages in thread
From: ericbavier @ 2016-04-06  4:32 UTC (permalink / raw)
  To: guix-devel; +Cc: Eric Bavier

From: Eric Bavier <bavier@member.fsf.org>

* gnu/packages/fontutils.scm (ttf2eot): New variable.
* gnu/packages/patches/ttf2eot-cstddef.patch: New patch.
* gnu-system.am (dist_patch_DATA): Add it.
---
 gnu-system.am                              |  1 +
 gnu/packages/fontutils.scm                 | 34 ++++++++++++++++++++++++++++++
 gnu/packages/patches/ttf2eot-cstddef.patch | 12 +++++++++++
 3 files changed, 47 insertions(+)
 create mode 100644 gnu/packages/patches/ttf2eot-cstddef.patch

diff --git a/gnu-system.am b/gnu-system.am
index 764e564..d3d08da 100644
--- a/gnu-system.am
+++ b/gnu-system.am
@@ -747,6 +747,7 @@ dist_patch_DATA =						\
   gnu/packages/patches/tidy-CVE-2015-5522+5523.patch		\
   gnu/packages/patches/tinyxml-use-stl.patch			\
   gnu/packages/patches/tk-find-library.patch			\
+  gnu/packages/patches/ttf2eot-cstddef.patch			\
   gnu/packages/patches/ttfautohint-source-date-epoch.patch	\
   gnu/packages/patches/tophat-build-with-later-seqan.patch	\
   gnu/packages/patches/torsocks-dns-test.patch			\
diff --git a/gnu/packages/fontutils.scm b/gnu/packages/fontutils.scm
index 614aac5..1e2424b 100644
--- a/gnu/packages/fontutils.scm
+++ b/gnu/packages/fontutils.scm
@@ -145,6 +145,40 @@ Converts WOFF fonts to OpenType fonts
     (license (list license:mpl1.1 license:gpl2+ license:lgpl2.1+))
     (home-page "https://people.mozilla.com/~jkew/woff/")))
 
+(define-public ttf2eot
+  (package
+    (name "ttf2eot")
+    (version "0.0.2")
+    (source
+     (origin
+       (method url-fetch)
+       (uri (string-append "https://storage.googleapis.com/"
+                           "google-code-archive-downloads/v2/"
+                           "code.google.com/ttf2eot/"
+                           "ttf2eot-" version "-2.tar.gz"))
+       (sha256
+        (base32
+         "1f4dzzmhn0208dvbm3ia5ar6ls9apwc6ampy5blmfxkigi6z0g02"))
+       (patches (map search-patch '("ttf2eot-cstddef.patch")))))
+    (build-system gnu-build-system)
+    (arguments
+     `(#:tests? #f                      ;no tests
+       #:phases
+       (modify-phases %standard-phases
+         (delete 'configure)            ;no configuration
+         (replace 'install
+           (lambda* (#:key outputs #:allow-other-keys)
+             (let* ((out (assoc-ref outputs "out"))
+                    (bin (string-append out "/bin")))
+               (install-file "ttf2eot" bin)))))))
+    (synopsis "Convert from TrueType to Embeddable Open Type")
+    (description
+     "This package contains a commandline wrapper around OpenTypeUtilities.cpp
+from Chromium, used to make EOT (Embeddable Open Type) files from
+TTF (TrueType/OpenType Font) files.")
+    (license license:bsd-2)
+    (home-page "https://code.google.com/archive/p/ttf2eot/")))
+
 (define-public fontconfig
   (package
    (name "fontconfig")
diff --git a/gnu/packages/patches/ttf2eot-cstddef.patch b/gnu/packages/patches/ttf2eot-cstddef.patch
new file mode 100644
index 0000000..af76898
--- /dev/null
+++ b/gnu/packages/patches/ttf2eot-cstddef.patch
@@ -0,0 +1,12 @@
+From resolution of https://code.google.com/p/ttf2eot/issues/detail?id=26
+
+--- ttf2eot-0.0.2-2/OpenTypeUtilities.cpp	2009-04-30 04:18:46.000000000 -0500
++++ ttf2eot-0.0.2-2/OpenTypeUtilities.cpp	2016-03-31 01:06:39.109996011 -0500
+@@ -25,6 +25,7 @@
+  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 
+  */
+ 
++#include <cstddef>
+ #include <string.h>
+ #include <vector>
+ 
-- 
2.7.3

^ permalink raw reply related	[flat|nested] 34+ messages in thread

* [PATCH 4/9] gnu: Add brotli.
  2016-04-06  4:32 [PATCH 1/9] gnu: Add ttfautohint ericbavier
  2016-04-06  4:32 ` [PATCH 2/9] gnu: Add woff-tools ericbavier
  2016-04-06  4:32 ` [PATCH 3/9] gnu: Add ttf2eot ericbavier
@ 2016-04-06  4:32 ` ericbavier
  2016-04-13 21:44   ` Ludovic Courtès
  2016-04-06  4:32 ` [PATCH 5/9] gnu: Add woff2 ericbavier
                   ` (6 subsequent siblings)
  9 siblings, 1 reply; 34+ messages in thread
From: ericbavier @ 2016-04-06  4:32 UTC (permalink / raw)
  To: guix-devel; +Cc: Eric Bavier

From: Eric Bavier <bavier@member.fsf.org>

* gnu/packages/compression.scm (brotli): New variable.
---
 gnu/packages/compression.scm | 41 ++++++++++++++++++++++++++++++++++++++++-
 1 file changed, 40 insertions(+), 1 deletion(-)

diff --git a/gnu/packages/compression.scm b/gnu/packages/compression.scm
index 938d4b8..5c9c00c 100644
--- a/gnu/packages/compression.scm
+++ b/gnu/packages/compression.scm
@@ -3,7 +3,7 @@
 ;;; Copyright © 2013 Andreas Enge <andreas@enge.fr>
 ;;; Copyright © 2014, 2015 Mark H Weaver <mhw@netris.org>
 ;;; Copyright © 2015 Taylan Ulrich Bayırlı/Kammer <taylanbayirli@gmail.com>
-;;; Copyright © 2015 Eric Bavier <bavier@member.fsf.org>
+;;; Copyright © 2015, 2016 Eric Bavier <bavier@member.fsf.org>
 ;;; Copyright © 2015 Ricardo Wurmus <rekado@elephly.net>
 ;;; Copyright © 2015 Leo Famulari <leo@famulari.name>
 ;;; Copyright © 2015 Jeff Mickey <j@codemac.net>
@@ -33,6 +33,7 @@
   #:use-module (guix git-download)
   #:use-module (guix build-system gnu)
   #:use-module (guix build-system perl)
+  #:use-module (gnu packages autotools)
   #:use-module (gnu packages backup)
   #:use-module (gnu packages base)
   #:use-module (gnu packages perl)
@@ -688,3 +689,41 @@ a collection of smaller blocks which makes random access to the original data
 possible and can compress in parallel.  This is especially useful for large
 tarballs.")
     (license license:bsd-2)))
+
+(define-public brotli
+  (let ((commit "e992cce7a174d6e2b3486616499d26bb0bad6448"))
+    (package
+      (name "brotli")
+      (version "0.1")
+      (source (origin
+                (method git-fetch)
+                (uri (git-reference
+                      (url "https://github.com/bagder/libbrotli.git")
+                      (commit commit)
+                      (recursive? #t)))
+                (file-name (string-append name "-" version ".tar.xz"))
+                (sha256
+                 (base32
+                  "1qxxsasvwbbbh6dl3138y9h3fg0q2v7xdk5jjc690bdg7g1wrj6n"))
+                (modules '((guix build utils)))
+                (snippet
+                 ;; This is a recursive submodule that is unnecessary for this
+                 ;; package, so delete it.
+                 '(delete-file-recursively "brotli/terryfy"))))
+      (build-system gnu-build-system)
+      (native-inputs
+       `(("autoconf" ,autoconf)
+         ("automake" ,automake)
+         ("libtool" ,libtool)))
+      (arguments
+       `(#:phases (modify-phases %standard-phases
+                    (add-after 'unpack 'autogen
+                      (lambda _
+                        (mkdir "m4")
+                        (system* "autoreconf" "-vfi"))))))
+      (home-page "https://github.com/bagder/libbrotli/")
+      (synopsis "Brotli encoder/decoder libraries")
+      (description
+       "This package provides Brotli encoder and decoder libraries: libbrotlienc
+and libbrotlidec, respectively.")
+      (license license:expat))))
-- 
2.7.3

^ permalink raw reply related	[flat|nested] 34+ messages in thread

* [PATCH 5/9] gnu: Add woff2.
  2016-04-06  4:32 [PATCH 1/9] gnu: Add ttfautohint ericbavier
                   ` (2 preceding siblings ...)
  2016-04-06  4:32 ` [PATCH 4/9] gnu: Add brotli ericbavier
@ 2016-04-06  4:32 ` ericbavier
  2016-04-06  4:32 ` [PATCH 6/9] gnu: fontforge: Make SVG builds reproducible ericbavier
                   ` (5 subsequent siblings)
  9 siblings, 0 replies; 34+ messages in thread
From: ericbavier @ 2016-04-06  4:32 UTC (permalink / raw)
  To: guix-devel; +Cc: Eric Bavier

From: Eric Bavier <bavier@member.fsf.org>

* gnu/packages/fontutils.scm (woff2): New variable.
* gnu/packages/patches/woff2-libbrotli.patch: New patch.
* gnu-system.am (dist_patch_DATA): Add it.
---
 gnu-system.am                              |  1 +
 gnu/packages/fontutils.scm                 | 39 ++++++++++++++
 gnu/packages/patches/woff2-libbrotli.patch | 84 ++++++++++++++++++++++++++++++
 3 files changed, 124 insertions(+)
 create mode 100644 gnu/packages/patches/woff2-libbrotli.patch

diff --git a/gnu-system.am b/gnu-system.am
index d3d08da..977a898 100644
--- a/gnu-system.am
+++ b/gnu-system.am
@@ -785,6 +785,7 @@ dist_patch_DATA =						\
   gnu/packages/patches/wicd-urwid-1.3.patch			\
   gnu/packages/patches/wicd-wpa2-ttls.patch			\
   gnu/packages/patches/wmctrl-64-fix.patch			\
+  gnu/packages/patches/woff2-libbrotli.patch			\
   gnu/packages/patches/wpa-supplicant-CVE-2015-5310.patch	\
   gnu/packages/patches/wpa-supplicant-CVE-2015-5314.patch	\
   gnu/packages/patches/wpa-supplicant-CVE-2015-5315.patch	\
diff --git a/gnu/packages/fontutils.scm b/gnu/packages/fontutils.scm
index 1e2424b..75edd55 100644
--- a/gnu/packages/fontutils.scm
+++ b/gnu/packages/fontutils.scm
@@ -39,6 +39,7 @@
   #:use-module (guix packages)
   #:use-module (guix download)
   #:use-module (guix svn-download)
+  #:use-module (guix git-download)
   #:use-module (guix build-system cmake)
   #:use-module (guix build-system gnu))
 
@@ -179,6 +180,44 @@ TTF (TrueType/OpenType Font) files.")
     (license license:bsd-2)
     (home-page "https://code.google.com/archive/p/ttf2eot/")))
 
+(define-public woff2
+  (let ((commit "4e698b8c6c5e070d53c340db9ddf160e21070ede"))
+    (package
+      (name "woff2")
+      (version (string-append "20160306." (string-take commit 7)))
+      (source (origin
+                (method git-fetch)
+                (uri (git-reference
+                      (url "https://github.com/google/woff2.git")
+                      (commit commit)))
+                (file-name (string-append name "-" version ".tar.xz"))
+                (sha256
+                 (base32
+                  "0wka0yhf0cjmd4rv2jckxpyv6lb5ckj4nj0k1ajq5hrjy7f30lcp"))
+                (patches (map search-patch '("woff2-libbrotli.patch")))))
+      (build-system gnu-build-system)
+      (native-inputs
+       `(("pkg-config" ,pkg-config)))
+      (inputs
+       `(("brotli" ,brotli)))
+      (arguments
+       `(#:tests? #f                    ;no tests
+         #:phases (modify-phases %standard-phases
+                    (delete 'configure)
+                    (replace 'install
+                      (lambda* (#:key outputs #:allow-other-keys)
+                        (let* ((out (assoc-ref outputs "out"))
+                               (bin (string-append out "/bin")))
+                          (install-file "woff2_compress" bin)
+                          (install-file "woff2_decompress" bin)
+                          #t))))))
+      (synopsis "Compress TrueType fonts to WOFF2")
+      (description
+       "This package provides utilities for compressing/decompressing TrueType
+fonts to/from the WOFF2 format.")
+      (license license:asl2.0)
+      (home-page "https://github.com/google/woff2"))))
+
 (define-public fontconfig
   (package
    (name "fontconfig")
diff --git a/gnu/packages/patches/woff2-libbrotli.patch b/gnu/packages/patches/woff2-libbrotli.patch
new file mode 100644
index 0000000..47539c8
--- /dev/null
+++ b/gnu/packages/patches/woff2-libbrotli.patch
@@ -0,0 +1,84 @@
+From: Eric Bavier <bavier@member.fsf.org>
+Date: Sat, 2 Apr 2016 01:31:03 -0500
+Subject: [PATCH] Build against external libbrotli.
+
+---
+ Makefile         | 20 ++++----------------
+ src/woff2_dec.cc |  2 +-
+ src/woff2_enc.cc |  2 +-
+ 3 files changed, 6 insertions(+), 18 deletions(-)
+
+diff --git a/Makefile b/Makefile
+index 92b8d54..618a751 100644
+--- a/Makefile
++++ b/Makefile
+@@ -1,6 +1,6 @@
+ OS := $(shell uname)
+ 
+-CPPFLAGS = -I./brotli/dec/ -I./brotli/enc/ -I./src
++CPPFLAGS := -I./src $(shell pkg-config --cflags libbrotlienc libbrotlidec)
+ 
+ CC ?= gcc
+ CXX ?= g++
+@@ -22,29 +22,17 @@ OUROBJ = font.o glyph.o normalize.o table_tags.o transform.o \
+          woff2_dec.o woff2_enc.o woff2_common.o woff2_out.o \
+          variable_length.o
+ 
+-BROTLI = brotli
+-ENCOBJ = $(BROTLI)/enc/*.o
+-DECOBJ = $(BROTLI)/dec/*.o
++BROTLI_LIBS := $(shell pkg-config --libs libbrotlienc libbrotlidec)
+ 
+ OBJS = $(patsubst %, $(SRCDIR)/%, $(OUROBJ))
+ EXECUTABLES=woff2_compress woff2_decompress
+ 
+ EXE_OBJS=$(patsubst %, $(SRCDIR)/%.o, $(EXECUTABLES))
+ 
+-ifeq (,$(wildcard $(BROTLI)/*))
+-  $(error Brotli dependency not found : you must initialize the Git submodule)
+-endif
+-
+ all : $(OBJS) $(EXECUTABLES)
+ 
+-$(EXECUTABLES) : $(EXE_OBJS) deps
+-	$(CXX) $(LFLAGS) $(OBJS) $(ENCOBJ) $(DECOBJ) $(SRCDIR)/$@.o -o $@
+-
+-deps :
+-	$(MAKE) -C $(BROTLI)/dec
+-	$(MAKE) -C $(BROTLI)/enc
++$(EXECUTABLES) : $(EXE_OBJS)
++	$(CXX) $(LDFLAGS) $(OBJS) $(SRCDIR)/$@.o -o $@ $(BROTLI_LIBS) $(LIBS)
+ 
+ clean :
+ 	rm -f $(OBJS) $(EXE_OBJS) $(EXECUTABLES)
+-	$(MAKE) -C $(BROTLI)/dec clean
+-	$(MAKE) -C $(BROTLI)/enc clean
+diff --git a/src/woff2_dec.cc b/src/woff2_dec.cc
+index 837eede..98c01ce 100644
+--- a/src/woff2_dec.cc
++++ b/src/woff2_dec.cc
+@@ -27,7 +27,7 @@
+ #include <memory>
+ #include <utility>
+ 
+-#include "./decode.h"
++#include "brotli/dec/decode.h"
+ #include "./buffer.h"
+ #include "./port.h"
+ #include "./round.h"
+diff --git a/src/woff2_enc.cc b/src/woff2_enc.cc
+index 920c614..00d74da 100644
+--- a/src/woff2_enc.cc
++++ b/src/woff2_enc.cc
+@@ -23,7 +23,7 @@
+ #include <string>
+ #include <vector>
+ 
+-#include "./encode.h"
++#include "brotli/enc/encode.h"
+ #include "./buffer.h"
+ #include "./font.h"
+ #include "./normalize.h"
+-- 
+2.7.3
+
-- 
2.7.3

^ permalink raw reply related	[flat|nested] 34+ messages in thread

* [PATCH 6/9] gnu: fontforge: Make SVG builds reproducible.
  2016-04-06  4:32 [PATCH 1/9] gnu: Add ttfautohint ericbavier
                   ` (3 preceding siblings ...)
  2016-04-06  4:32 ` [PATCH 5/9] gnu: Add woff2 ericbavier
@ 2016-04-06  4:32 ` ericbavier
  2016-04-06 17:36   ` Leo Famulari
  2016-04-06  4:32 ` [PATCH 7/9] gnu: Add font-fantasque-sans ericbavier
                   ` (4 subsequent siblings)
  9 siblings, 1 reply; 34+ messages in thread
From: ericbavier @ 2016-04-06  4:32 UTC (permalink / raw)
  To: guix-devel; +Cc: Eric Bavier

From: Eric Bavier <bavier@member.fsf.org>

* gnu/packages/fontutils.scm (fontforge)[source]: Add snippet to clear
  timestamp in svg.c.
---
 gnu/packages/fontutils.scm | 7 ++++++-
 1 file changed, 6 insertions(+), 1 deletion(-)

diff --git a/gnu/packages/fontutils.scm b/gnu/packages/fontutils.scm
index 75edd55..5ca9835 100644
--- a/gnu/packages/fontutils.scm
+++ b/gnu/packages/fontutils.scm
@@ -512,7 +512,12 @@ definitions.")
                ;; Make TTF builds bit-reproducible by clearing the timestamp
                ;; that goes in TTF files.
                (substitute* "fontforge/tottf.c"
-                 (("cvt_unix_to_1904\\(now") "cvt_unix_to_1904(0"))))))
+                 (("cvt_unix_to_1904\\(now") "cvt_unix_to_1904(0"))
+
+               ;; Make SVG builds bit-reproducible by clearing the timestamp
+               ;; that goes in SVG files.
+               (substitute* "fontforge/svg.c"
+                 (("ctime\\(&now\\)") "ctime(0)"))))))
    (build-system gnu-build-system)
    (native-inputs
     `(("pkg-config" ,pkg-config)))
-- 
2.7.3

^ permalink raw reply related	[flat|nested] 34+ messages in thread

* [PATCH 7/9] gnu: Add font-fantasque-sans.
  2016-04-06  4:32 [PATCH 1/9] gnu: Add ttfautohint ericbavier
                   ` (4 preceding siblings ...)
  2016-04-06  4:32 ` [PATCH 6/9] gnu: fontforge: Make SVG builds reproducible ericbavier
@ 2016-04-06  4:32 ` ericbavier
  2016-04-06  4:33 ` [PATCH 8/9] gnu: fontforge: Use modify-phases ericbavier
                   ` (3 subsequent siblings)
  9 siblings, 0 replies; 34+ messages in thread
From: ericbavier @ 2016-04-06  4:32 UTC (permalink / raw)
  To: guix-devel; +Cc: Eric Bavier

From: Eric Bavier <bavier@member.fsf.org>

* gnu/packages/fonts.scm (font-fantasque-sans): New variable.
---
 gnu/packages/fonts.scm | 47 +++++++++++++++++++++++++++++++++++++++++++++++
 1 file changed, 47 insertions(+)

diff --git a/gnu/packages/fonts.scm b/gnu/packages/fonts.scm
index 3d75591..2ed11d4 100644
--- a/gnu/packages/fonts.scm
+++ b/gnu/packages/fonts.scm
@@ -8,6 +8,7 @@
 ;;; Copyright © 2015 Ricardo Wurmus <rekado@elephly.net>
 ;;; Copyright © 2016 Nils Gillmann <niasterisk@grrlz.net>
 ;;; Copyright © 2016 Jookia <166291@gmail.com>
+;;; Copyright © 2016 Eric Bavier <bavier@member.fsf.org>
 ;;;
 ;;; This file is part of GNU Guix.
 ;;;
@@ -759,3 +760,49 @@ It contains the following fonts and styles:
 @item UnGungseo: cursive, brush-stroke.
 @end enumerate\n")
     (license license:gpl2+)))
+
+(define-public font-fantasque-sans
+  (package
+    (name "font-fantasque-sans")
+    (version "1.7.0")
+    (source
+     (origin
+       (method url-fetch)
+       (uri (string-append "https://github.com/belluzj/fantasque-sans/"
+                           "archive/v" version ".tar.gz"))
+       (file-name (string-append name "-" version ".tar.gz"))
+       (sha256
+        (base32
+         "1nr5sy34ih3hlf1fkcrp398k4vpcsvl0yfy6kv50jirrjfy66d1h"))))
+    (build-system gnu-build-system)
+    (native-inputs
+     `(("ttfautohint" ,ttfautohint)
+       ("woff-tools" ,woff-tools)
+       ("fontforge" ,fontforge)
+       ("woff2" ,woff2)
+       ("ttf2eot" ,ttf2eot)))
+    (arguments
+     `(#:tests? #f                 ;test target intended for visual inspection
+       #:phases (modify-phases %standard-phases
+                  (delete 'configure)   ;no configuration
+                  (replace 'install
+                    ;; 'make install' wants to install to ~/.fonts, install to
+                    ;; output instead.
+                    (lambda* (#:key outputs #:allow-other-keys)
+                      (let* ((out (assoc-ref outputs "out"))
+                             (font-dir (string-append out "/share/fonts"))
+                             (truetype-dir (string-append font-dir "/truetype"))
+                             (opentype-dir (string-append font-dir "/opentype"))
+                             (webfonts-dir (string-append font-dir "/webfonts")))
+                        (copy-recursively "OTF" opentype-dir)
+                        (for-each (lambda (f) (install-file f truetype-dir))
+                                  (find-files "." "\\.ttf$"))
+                        (copy-recursively "Webfonts" webfonts-dir)
+                        #t))))))
+    (synopsis "Font family with a monospaced variant for programmers")
+    (description
+     "Fantasque Sans Mono is a programming font designed with functionality in
+mind.  The font includes a bold version and a good italic version with new
+glyph designs, not just an added slant.")
+    (home-page "https://fontlibrary.org/en/font/fantasque-sans-mono")
+    (license license:silofl1.1)))
-- 
2.7.3

^ permalink raw reply related	[flat|nested] 34+ messages in thread

* [PATCH 8/9] gnu: fontforge: Use modify-phases.
  2016-04-06  4:32 [PATCH 1/9] gnu: Add ttfautohint ericbavier
                   ` (5 preceding siblings ...)
  2016-04-06  4:32 ` [PATCH 7/9] gnu: Add font-fantasque-sans ericbavier
@ 2016-04-06  4:33 ` ericbavier
  2016-04-06  4:33 ` [PATCH 9/9] gnu: fontforge: Install 'showttf' tool ericbavier
                   ` (2 subsequent siblings)
  9 siblings, 0 replies; 34+ messages in thread
From: ericbavier @ 2016-04-06  4:33 UTC (permalink / raw)
  To: guix-devel; +Cc: Eric Bavier

From: Eric Bavier <bavier@member.fsf.org>

* gnu/packages/fontutils.scm (fontforge)[arguments]: Use modify-phases.
---
 gnu/packages/fontutils.scm | 64 ++++++++++++++++++++++------------------------
 1 file changed, 31 insertions(+), 33 deletions(-)

diff --git a/gnu/packages/fontutils.scm b/gnu/packages/fontutils.scm
index 5ca9835..5b3247b 100644
--- a/gnu/packages/fontutils.scm
+++ b/gnu/packages/fontutils.scm
@@ -546,39 +546,37 @@ definitions.")
    (arguments
     '(#:tests? #f
       #:phases
-      (alist-cons-before
-       'configure 'patch-configure
-       (lambda* (#:key inputs #:allow-other-keys)
-         (let ((libxml2 (assoc-ref inputs "libxml2"))
-               (cairo   (assoc-ref inputs "cairo"))
-               (pango   (assoc-ref inputs "pango")))
-           (substitute* "configure"
-             ;; configure looks for a directory to be present to determine
-             ;; whether libxml2 is available, rather than checking for the
-             ;; library or headers.  Point it to the correct directory.
-             (("/usr/include/libxml2")
-              (string-append libxml2 "/include/libxml2"))
-             ;; Similary, the search directories for cairo and pango are
-             ;; hard-coded.
-             (("gww_prefix in.*") (string-append "gww_prefix in "
-                                                 cairo " " pango "\n")))))
-       (alist-cons-after
-        'install 'set-library-path
-        (lambda* (#:key inputs outputs #:allow-other-keys)
-          (let ((out (assoc-ref outputs "out"))
-                (potrace (string-append (assoc-ref inputs "potrace") "/bin")))
-            (wrap-program (string-append out "/bin/fontforge")
-                          ;; Fontforge dynamically opens libraries.
-                          `("LD_LIBRARY_PATH" ":" prefix
-                            ,(map (lambda (input)
-                                    (string-append (assoc-ref inputs input)
-                                                   "/lib"))
-                                  '("libtiff" "libjpeg" "libpng" "giflib"
-                                    "libxml2" "zlib" "libspiro" "freetype"
-                                    "pango" "cairo" "fontconfig")))
-                          ;; Checks for potrace program at runtime
-                          `("PATH" ":" prefix (,potrace)))))
-        %standard-phases))))
+      (modify-phases %standard-phases
+        (add-before 'configure 'patch-configure
+          (lambda* (#:key inputs #:allow-other-keys)
+            (let ((libxml2 (assoc-ref inputs "libxml2"))
+                  (cairo   (assoc-ref inputs "cairo"))
+                  (pango   (assoc-ref inputs "pango")))
+              (substitute* "configure"
+                ;; configure looks for a directory to be present to determine
+                ;; whether libxml2 is available, rather than checking for the
+                ;; library or headers.  Point it to the correct directory.
+                (("/usr/include/libxml2")
+                 (string-append libxml2 "/include/libxml2"))
+                ;; Similary, the search directories for cairo and pango are
+                ;; hard-coded.
+                (("gww_prefix in.*") (string-append "gww_prefix in "
+                                                   cairo " " pango "\n"))))))
+        (add-after 'install 'set-library-path
+          (lambda* (#:key inputs outputs #:allow-other-keys)
+            (let ((out (assoc-ref outputs "out"))
+                  (potrace (string-append (assoc-ref inputs "potrace") "/bin")))
+              (wrap-program (string-append out "/bin/fontforge")
+                ;; Fontforge dynamically opens libraries.
+                `("LD_LIBRARY_PATH" ":" prefix
+                  ,(map (lambda (input)
+                          (string-append (assoc-ref inputs input)
+                                         "/lib"))
+                        '("libtiff" "libjpeg" "libpng" "giflib"
+                          "libxml2" "zlib" "libspiro" "freetype"
+                          "pango" "cairo" "fontconfig")))
+                ;; Checks for potrace program at runtime
+                `("PATH" ":" prefix (,potrace)))))))))
    (synopsis "Outline font editor")
    (description
     "FontForge allows you to create and modify postscript, truetype and
-- 
2.7.3

^ permalink raw reply related	[flat|nested] 34+ messages in thread

* [PATCH 9/9] gnu: fontforge: Install 'showttf' tool.
  2016-04-06  4:32 [PATCH 1/9] gnu: Add ttfautohint ericbavier
                   ` (6 preceding siblings ...)
  2016-04-06  4:33 ` [PATCH 8/9] gnu: fontforge: Use modify-phases ericbavier
@ 2016-04-06  4:33 ` ericbavier
  2016-04-06 12:13 ` [PATCH 1/9] gnu: Add ttfautohint Alex Kost
  2016-04-13 21:36 ` Ludovic Courtès
  9 siblings, 0 replies; 34+ messages in thread
From: ericbavier @ 2016-04-06  4:33 UTC (permalink / raw)
  To: guix-devel; +Cc: Eric Bavier

From: Eric Bavier <bavier@member.fsf.org>

* gnu/packages/fontutils.scm (fontforge)[arguments]: Add 'build-contrib'
  phase.
---
 gnu/packages/fontutils.scm | 8 ++++++++
 1 file changed, 8 insertions(+)

diff --git a/gnu/packages/fontutils.scm b/gnu/packages/fontutils.scm
index 5b3247b..f120aef 100644
--- a/gnu/packages/fontutils.scm
+++ b/gnu/packages/fontutils.scm
@@ -562,6 +562,14 @@ definitions.")
                 ;; hard-coded.
                 (("gww_prefix in.*") (string-append "gww_prefix in "
                                                    cairo " " pango "\n"))))))
+        (add-after 'build 'build-contrib
+          (lambda* (#:key outputs #:allow-other-keys)
+            (let* ((out (assoc-ref outputs "out"))
+                   (bin (string-append out "/bin")))
+              (and (zero? (system* "make" "-Ccontrib/fonttools"
+                                   "CC=gcc" "showttf"))
+                   (begin (install-file "contrib/fonttools/showttf" bin)
+                          #t)))))
         (add-after 'install 'set-library-path
           (lambda* (#:key inputs outputs #:allow-other-keys)
             (let ((out (assoc-ref outputs "out"))
-- 
2.7.3

^ permalink raw reply related	[flat|nested] 34+ messages in thread

* Re: [PATCH 1/9] gnu: Add ttfautohint.
  2016-04-06  4:32 [PATCH 1/9] gnu: Add ttfautohint ericbavier
                   ` (7 preceding siblings ...)
  2016-04-06  4:33 ` [PATCH 9/9] gnu: fontforge: Install 'showttf' tool ericbavier
@ 2016-04-06 12:13 ` Alex Kost
  2016-04-06 14:57   ` Eric Bavier
  2016-04-13 21:36 ` Ludovic Courtès
  9 siblings, 1 reply; 34+ messages in thread
From: Alex Kost @ 2016-04-06 12:13 UTC (permalink / raw)
  To: ericbavier; +Cc: guix-devel, Eric Bavier

ericbavier@openmailbox.org (2016-04-06 07:32 +0300) wrote:

> From: Eric Bavier <bavier@member.fsf.org>
>
> * gnu/packages/fontutils.scm (ttfautohint): New variable.
> * gnu/packages/patches/ttfautohint-source-date-epoch.patch: New patch.
> * gnu-system.am (dist_patch_DATA): Add it.
> ---
>  gnu-system.am                                      |  1 +
>  gnu/packages/fontutils.scm                         | 36 ++++++++++-
>  .../patches/ttfautohint-source-date-epoch.patch    | 70 ++++++++++++++++++++++
>  3 files changed, 106 insertions(+), 1 deletion(-)
>  create mode 100644 gnu/packages/patches/ttfautohint-source-date-epoch.patch
[...]
> +(define-public ttfautohint
> +  (package
> +    (name "ttfautohint")
> +    (version "1.5")
> +    (source
> +     (origin
> +       (method url-fetch)
> +       (uri (string-append "mirror://savannah/freetype/ttfautohint-"
> +                           version ".tar.gz"))
> +       (sha256
> +        (base32
> +         ;; /gnu/store/5kzmy7061aimljpga9qfz49227283sfr-ttfautohint-1.5.tar.gz
        ^^^^^^^^^^
Leftover line?

> +         "1lgghck46p33z3hg8dnl76jryig4fh6d8rhzms837zp7x4hyfkv4"))
> +       (patches (map search-patch '("ttfautohint-source-date-epoch.patch")))))

Since it's just a single patch, I don't see a reason to use 'map' here.

> +    (build-system gnu-build-system)
> +    (native-inputs
> +     `(("flex" ,flex)
> +       ("bison" ,bison)
> +       ("pkg-config" ,pkg-config)))
> +    (inputs
> +     `(("freetype" ,freetype)
> +       ("harfbuzz" ,harfbuzz)))
> +    (arguments
> +     `(#:configure-flags '("--with-qt=no"))) ;no gui
> +    (synopsis "Automated font hinting")
> +    (description
> +     "ttfautohint provides a 99% automated hinting process and a platform for
> +finely hand-hinting the last 1%.  It is ideal for web fonts and supports many
> +scripts.")
> +    (license license:gpl2+)             ;or FreeType license

Or FreeType?  Sorry, what does it mean?  If some files are under GPL2+
and some under FreeType, then why don't you use a list of licenses?

-- 
Alex

^ permalink raw reply	[flat|nested] 34+ messages in thread

* Re: [PATCH 1/9] gnu: Add ttfautohint.
  2016-04-06 12:13 ` [PATCH 1/9] gnu: Add ttfautohint Alex Kost
@ 2016-04-06 14:57   ` Eric Bavier
  2016-04-07  9:52     ` Specifying package patches in a more convenient form Alex Kost
  2016-04-13 21:40     ` [PATCH 1/9] gnu: Add ttfautohint Ludovic Courtès
  0 siblings, 2 replies; 34+ messages in thread
From: Eric Bavier @ 2016-04-06 14:57 UTC (permalink / raw)
  To: Alex Kost; +Cc: guix-devel

On Wed, 06 Apr 2016 15:13:47 +0300
Alex Kost <alezost@gmail.com> wrote:

> ericbavier@openmailbox.org (2016-04-06 07:32 +0300) wrote:
> 
> > From: Eric Bavier <bavier@member.fsf.org>
> >
> > * gnu/packages/fontutils.scm (ttfautohint): New variable.
> > * gnu/packages/patches/ttfautohint-source-date-epoch.patch: New patch.
> > * gnu-system.am (dist_patch_DATA): Add it.
> > ---
> >  gnu-system.am                                      |  1 +
> >  gnu/packages/fontutils.scm                         | 36 ++++++++++-
> >  .../patches/ttfautohint-source-date-epoch.patch    | 70 ++++++++++++++++++++++
> >  3 files changed, 106 insertions(+), 1 deletion(-)
> >  create mode 100644 gnu/packages/patches/ttfautohint-source-date-epoch.patch
> [...]
> > +(define-public ttfautohint
> > +  (package
> > +    (name "ttfautohint")
> > +    (version "1.5")
> > +    (source
> > +     (origin
> > +       (method url-fetch)
> > +       (uri (string-append "mirror://savannah/freetype/ttfautohint-"
> > +                           version ".tar.gz"))
> > +       (sha256
> > +        (base32
> > +         ;; /gnu/store/5kzmy7061aimljpga9qfz49227283sfr-ttfautohint-1.5.tar.gz
>         ^^^^^^^^^^
> Leftover line?

Yes, thanks for catching it.

> > +         "1lgghck46p33z3hg8dnl76jryig4fh6d8rhzms837zp7x4hyfkv4"))
> > +       (patches (map search-patch '("ttfautohint-source-date-epoch.patch")))))
> 
> Since it's just a single patch, I don't see a reason to use 'map' here.

Just that it's less to change if more patches are added later.  The
same has been used in other packages.

> 
> > +    (build-system gnu-build-system)
> > +    (native-inputs
> > +     `(("flex" ,flex)
> > +       ("bison" ,bison)
> > +       ("pkg-config" ,pkg-config)))
> > +    (inputs
> > +     `(("freetype" ,freetype)
> > +       ("harfbuzz" ,harfbuzz)))
> > +    (arguments
> > +     `(#:configure-flags '("--with-qt=no"))) ;no gui
> > +    (synopsis "Automated font hinting")
> > +    (description
> > +     "ttfautohint provides a 99% automated hinting process and a platform for
> > +finely hand-hinting the last 1%.  It is ideal for web fonts and supports many
> > +scripts.")
> > +    (license license:gpl2+)             ;or FreeType license
> 
> Or FreeType?  Sorry, what does it mean?  If some files are under GPL2+
> and some under FreeType, then why don't you use a list of licenses?
> 

The license text says to pick one, and I wanted to indicate that in
some way in the absense of more descriptive license operators.

`~Eric

^ permalink raw reply	[flat|nested] 34+ messages in thread

* Re: [PATCH 6/9] gnu: fontforge: Make SVG builds reproducible.
  2016-04-06  4:32 ` [PATCH 6/9] gnu: fontforge: Make SVG builds reproducible ericbavier
@ 2016-04-06 17:36   ` Leo Famulari
  2016-04-06 17:44     ` Eric Bavier
  0 siblings, 1 reply; 34+ messages in thread
From: Leo Famulari @ 2016-04-06 17:36 UTC (permalink / raw)
  To: ericbavier; +Cc: guix-devel, Eric Bavier

On Tue, Apr 05, 2016 at 11:32:58PM -0500, ericbavier@openmailbox.org wrote:
> From: Eric Bavier <bavier@member.fsf.org>
> 
> * gnu/packages/fontutils.scm (fontforge)[source]: Add snippet to clear
>   timestamp in svg.c.
> ---
>  gnu/packages/fontutils.scm | 7 ++++++-
>  1 file changed, 6 insertions(+), 1 deletion(-)
> 
> diff --git a/gnu/packages/fontutils.scm b/gnu/packages/fontutils.scm
> index 75edd55..5ca9835 100644
> --- a/gnu/packages/fontutils.scm
> +++ b/gnu/packages/fontutils.scm
> @@ -512,7 +512,12 @@ definitions.")
>                 ;; Make TTF builds bit-reproducible by clearing the timestamp
>                 ;; that goes in TTF files.
>                 (substitute* "fontforge/tottf.c"
> -                 (("cvt_unix_to_1904\\(now") "cvt_unix_to_1904(0"))))))
> +                 (("cvt_unix_to_1904\\(now") "cvt_unix_to_1904(0"))
> +
> +               ;; Make SVG builds bit-reproducible by clearing the timestamp
> +               ;; that goes in SVG files.
> +               (substitute* "fontforge/svg.c"
> +                 (("ctime\\(&now\\)") "ctime(0)"))))))

Could you use the value of the environment variable SOURCE_DATE_EPOCH
instead of 0?

>     (build-system gnu-build-system)
>     (native-inputs
>      `(("pkg-config" ,pkg-config)))
> -- 
> 2.7.3
> 
> 

^ permalink raw reply	[flat|nested] 34+ messages in thread

* Re: [PATCH 6/9] gnu: fontforge: Make SVG builds reproducible.
  2016-04-06 17:36   ` Leo Famulari
@ 2016-04-06 17:44     ` Eric Bavier
  2016-04-06 17:56       ` Leo Famulari
  0 siblings, 1 reply; 34+ messages in thread
From: Eric Bavier @ 2016-04-06 17:44 UTC (permalink / raw)
  To: Leo Famulari; +Cc: guix-devel

On 2016-04-06 12:36, Leo Famulari wrote:
> On Tue, Apr 05, 2016 at 11:32:58PM -0500, ericbavier@openmailbox.org 
> wrote:
>> From: Eric Bavier <bavier@member.fsf.org>
>> 
>> * gnu/packages/fontutils.scm (fontforge)[source]: Add snippet to clear
>>   timestamp in svg.c.
>> ---
>>  gnu/packages/fontutils.scm | 7 ++++++-
>>  1 file changed, 6 insertions(+), 1 deletion(-)
>> 
>> diff --git a/gnu/packages/fontutils.scm b/gnu/packages/fontutils.scm
>> index 75edd55..5ca9835 100644
>> --- a/gnu/packages/fontutils.scm
>> +++ b/gnu/packages/fontutils.scm
>> @@ -512,7 +512,12 @@ definitions.")
>>                 ;; Make TTF builds bit-reproducible by clearing the 
>> timestamp
>>                 ;; that goes in TTF files.
>>                 (substitute* "fontforge/tottf.c"
>> -                 (("cvt_unix_to_1904\\(now") 
>> "cvt_unix_to_1904(0"))))))
>> +                 (("cvt_unix_to_1904\\(now") "cvt_unix_to_1904(0"))
>> +
>> +               ;; Make SVG builds bit-reproducible by clearing the 
>> timestamp
>> +               ;; that goes in SVG files.
>> +               (substitute* "fontforge/svg.c"
>> +                 (("ctime\\(&now\\)") "ctime(0)"))))))
> 
> Could you use the value of the environment variable SOURCE_DATE_EPOCH
> instead of 0?

Probably.  But I'd save that for a later update, since it would be a 
much bigger change (that we could hopefully move upstream).

`~Eric

^ permalink raw reply	[flat|nested] 34+ messages in thread

* Re: [PATCH 6/9] gnu: fontforge: Make SVG builds reproducible.
  2016-04-06 17:44     ` Eric Bavier
@ 2016-04-06 17:56       ` Leo Famulari
  0 siblings, 0 replies; 34+ messages in thread
From: Leo Famulari @ 2016-04-06 17:56 UTC (permalink / raw)
  To: Eric Bavier; +Cc: guix-devel

On Wed, Apr 06, 2016 at 12:44:31PM -0500, Eric Bavier wrote:
> On 2016-04-06 12:36, Leo Famulari wrote:
> >On Tue, Apr 05, 2016 at 11:32:58PM -0500, ericbavier@openmailbox.org
> >wrote:
> >>From: Eric Bavier <bavier@member.fsf.org>
> >>
> >>* gnu/packages/fontutils.scm (fontforge)[source]: Add snippet to clear
> >>  timestamp in svg.c.
> >>---
> >> gnu/packages/fontutils.scm | 7 ++++++-
> >> 1 file changed, 6 insertions(+), 1 deletion(-)
> >>
> >>diff --git a/gnu/packages/fontutils.scm b/gnu/packages/fontutils.scm
> >>index 75edd55..5ca9835 100644
> >>--- a/gnu/packages/fontutils.scm
> >>+++ b/gnu/packages/fontutils.scm
> >>@@ -512,7 +512,12 @@ definitions.")
> >>                ;; Make TTF builds bit-reproducible by clearing the
> >>timestamp
> >>                ;; that goes in TTF files.
> >>                (substitute* "fontforge/tottf.c"
> >>-                 (("cvt_unix_to_1904\\(now") "cvt_unix_to_1904(0"))))))
> >>+                 (("cvt_unix_to_1904\\(now") "cvt_unix_to_1904(0"))
> >>+
> >>+               ;; Make SVG builds bit-reproducible by clearing the
> >>timestamp
> >>+               ;; that goes in SVG files.
> >>+               (substitute* "fontforge/svg.c"
> >>+                 (("ctime\\(&now\\)") "ctime(0)"))))))
> >
> >Could you use the value of the environment variable SOURCE_DATE_EPOCH
> >instead of 0?
> 
> Probably.  But I'd save that for a later update, since it would be a much
> bigger change (that we could hopefully move upstream).

You could put the logic in the package definition and string-append the
value into svg.c.

If not, can you set the ctime to '1'? That is what we are using as the
value of SOURCE_DATE_EPOCH on Guix:

http://git.savannah.gnu.org/cgit/guix.git/tree/guix/build/gnu-build-system.scm#n46

^ permalink raw reply	[flat|nested] 34+ messages in thread

* Re: [PATCH 2/9] gnu: Add woff-tools.
  2016-04-06  4:32 ` [PATCH 2/9] gnu: Add woff-tools ericbavier
@ 2016-04-07  6:18   ` Efraim Flashner
  2016-04-07 14:25     ` Eric Bavier
  2016-04-13 21:37     ` Ludovic Courtès
  0 siblings, 2 replies; 34+ messages in thread
From: Efraim Flashner @ 2016-04-07  6:18 UTC (permalink / raw)
  To: ericbavier; +Cc: guix-devel, Eric Bavier

[-- Attachment #1: Type: text/plain, Size: 2817 bytes --]

On Tue, Apr 05, 2016 at 11:32:54PM -0500, ericbavier@openmailbox.org wrote:
> From: Eric Bavier <bavier@member.fsf.org>
> 
> * gnu/packages/fontutils.scm (woff-tools): New variable.
> ---
>  gnu/packages/fontutils.scm | 41 +++++++++++++++++++++++++++++++++++++++++
>  1 file changed, 41 insertions(+)
> 
> diff --git a/gnu/packages/fontutils.scm b/gnu/packages/fontutils.scm
> index a0701d5..614aac5 100644
> --- a/gnu/packages/fontutils.scm
> +++ b/gnu/packages/fontutils.scm
> @@ -104,6 +104,47 @@ scripts.")
>      (license license:gpl2+)             ;or FreeType license
>      (home-page "http://www.freetype.org/ttfautohint/")))
>  
> +(define-public woff-tools
> +  (package
> +    (name "woff-tools")
> +    (version "2009.10.04")
> +    (source
> +     (origin
> +       (method url-fetch)
> +       ;; Upstream source is unversioned, so use Debian's versioned tarball
> +       (uri (string-append "mirror://debian/pool/main/w/woff-tools/"
> +                           "woff-tools_" version ".orig.tar.gz"))

2009 is a long time ago, but woff-tools are still in Debian Sid so we
don't have to worry about needing to go to archive.debian.org/... for
the sources any time soon. By the way, is there a more recent version?

> +       (file-name (string-append name "-" version ".tar.gz"))
> +       (sha256
> +        (base32
> +         "1i97gkqa6jfzlslsngqf556kx60knlgf7yc9pzsq2pizc6f0d4zl"))))
> +    (build-system gnu-build-system)
> +    (inputs
> +     `(("zlib" ,zlib)))
> +    (arguments
> +     `(#:make-flags '("CC=gcc")
> +       #:tests? #f                      ;no tests
> +       #:phases
> +       (modify-phases %standard-phases
> +         (delete 'configure)            ;no configuration
> +         (replace 'install
> +           (lambda* (#:key outputs #:allow-other-keys)
> +             (let* ((out (assoc-ref outputs "out"))
> +                    (bin (string-append out "/bin")))
> +               (install-file "sfnt2woff" bin)
> +               (install-file "woff2sfnt" bin)))))))
> +    (synopsis "Convert between OpenType and WOFF formats")
> +    (description
> +     "This package provides two tools:
> +@table @code
> +@item sfnt2woff
> +Converts OpenType fonts to WOFF fonts
> +@item woff2sfnt
> +Converts WOFF fonts to OpenType fonts
> +@end table")
> +    (license (list license:mpl1.1 license:gpl2+ license:lgpl2.1+))
> +    (home-page "https://people.mozilla.com/~jkew/woff/")))
> +
>  (define-public fontconfig
>    (package
>     (name "fontconfig")
> -- 
> 2.7.3
> 

Looks good to me

-- 
Efraim Flashner   <efraim@flashner.co.il>   אפרים פלשנר
GPG key = A28B F40C 3E55 1372 662D  14F7 41AA E7DC CA3D 8351
Confidentiality cannot be guaranteed on emails sent or received unencrypted

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 819 bytes --]

^ permalink raw reply	[flat|nested] 34+ messages in thread

* Re: [PATCH 3/9] gnu: Add ttf2eot.
  2016-04-06  4:32 ` [PATCH 3/9] gnu: Add ttf2eot ericbavier
@ 2016-04-07  6:24   ` Efraim Flashner
  2016-04-07 14:30     ` Eric Bavier
  2016-04-08  3:49     ` Eric Bavier
  0 siblings, 2 replies; 34+ messages in thread
From: Efraim Flashner @ 2016-04-07  6:24 UTC (permalink / raw)
  To: ericbavier; +Cc: guix-devel, Eric Bavier

[-- Attachment #1: Type: text/plain, Size: 4252 bytes --]

On Tue, Apr 05, 2016 at 11:32:55PM -0500, ericbavier@openmailbox.org wrote:
> From: Eric Bavier <bavier@member.fsf.org>
> 
> * gnu/packages/fontutils.scm (ttf2eot): New variable.
> * gnu/packages/patches/ttf2eot-cstddef.patch: New patch.
> * gnu-system.am (dist_patch_DATA): Add it.
> ---
>  gnu-system.am                              |  1 +
>  gnu/packages/fontutils.scm                 | 34 ++++++++++++++++++++++++++++++
>  gnu/packages/patches/ttf2eot-cstddef.patch | 12 +++++++++++
>  3 files changed, 47 insertions(+)
>  create mode 100644 gnu/packages/patches/ttf2eot-cstddef.patch
> 
> diff --git a/gnu-system.am b/gnu-system.am
> index 764e564..d3d08da 100644
> --- a/gnu-system.am
> +++ b/gnu-system.am
> @@ -747,6 +747,7 @@ dist_patch_DATA =						\
>    gnu/packages/patches/tidy-CVE-2015-5522+5523.patch		\
>    gnu/packages/patches/tinyxml-use-stl.patch			\
>    gnu/packages/patches/tk-find-library.patch			\
> +  gnu/packages/patches/ttf2eot-cstddef.patch			\
>    gnu/packages/patches/ttfautohint-source-date-epoch.patch	\
>    gnu/packages/patches/tophat-build-with-later-seqan.patch	\
>    gnu/packages/patches/torsocks-dns-test.patch			\
> diff --git a/gnu/packages/fontutils.scm b/gnu/packages/fontutils.scm
> index 614aac5..1e2424b 100644
> --- a/gnu/packages/fontutils.scm
> +++ b/gnu/packages/fontutils.scm
> @@ -145,6 +145,40 @@ Converts WOFF fonts to OpenType fonts
>      (license (list license:mpl1.1 license:gpl2+ license:lgpl2.1+))
>      (home-page "https://people.mozilla.com/~jkew/woff/")))
>  
> +(define-public ttf2eot
> +  (package
> +    (name "ttf2eot")
> +    (version "0.0.2")

What about version 0.0.2-2?

> +    (source
> +     (origin
> +       (method url-fetch)
> +       (uri (string-append "https://storage.googleapis.com/"
> +                           "google-code-archive-downloads/v2/"
> +                           "code.google.com/ttf2eot/"
> +                           "ttf2eot-" version "-2.tar.gz"))

I checked and it doesn't look like this project was exported to github

> +       (sha256
> +        (base32
> +         "1f4dzzmhn0208dvbm3ia5ar6ls9apwc6ampy5blmfxkigi6z0g02"))
> +       (patches (map search-patch '("ttf2eot-cstddef.patch")))))
> +    (build-system gnu-build-system)
> +    (arguments
> +     `(#:tests? #f                      ;no tests
> +       #:phases
> +       (modify-phases %standard-phases
> +         (delete 'configure)            ;no configuration
> +         (replace 'install
> +           (lambda* (#:key outputs #:allow-other-keys)
> +             (let* ((out (assoc-ref outputs "out"))
> +                    (bin (string-append out "/bin")))
> +               (install-file "ttf2eot" bin)))))))
> +    (synopsis "Convert from TrueType to Embeddable Open Type")
> +    (description
> +     "This package contains a commandline wrapper around OpenTypeUtilities.cpp
> +from Chromium, used to make EOT (Embeddable Open Type) files from
> +TTF (TrueType/OpenType Font) files.")
> +    (license license:bsd-2)

Issue 30[0] says that the readme says its bsd/lgpl licensed.

> +    (home-page "https://code.google.com/archive/p/ttf2eot/")))
> +
>  (define-public fontconfig
>    (package
>     (name "fontconfig")
> diff --git a/gnu/packages/patches/ttf2eot-cstddef.patch b/gnu/packages/patches/ttf2eot-cstddef.patch
> new file mode 100644
> index 0000000..af76898
> --- /dev/null
> +++ b/gnu/packages/patches/ttf2eot-cstddef.patch
> @@ -0,0 +1,12 @@
> +From resolution of https://code.google.com/p/ttf2eot/issues/detail?id=26
> +
> +--- ttf2eot-0.0.2-2/OpenTypeUtilities.cpp	2009-04-30 04:18:46.000000000 -0500
> ++++ ttf2eot-0.0.2-2/OpenTypeUtilities.cpp	2016-03-31 01:06:39.109996011 -0500
> +@@ -25,6 +25,7 @@
> +  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 
> +  */
> + 
> ++#include <cstddef>
> + #include <string.h>
> + #include <vector>
> + 
> -- 
> 2.7.3
> 

[0] https://code.google.com/archive/p/ttf2eot/issues/30

-- 
Efraim Flashner   <efraim@flashner.co.il>   אפרים פלשנר
GPG key = A28B F40C 3E55 1372 662D  14F7 41AA E7DC CA3D 8351
Confidentiality cannot be guaranteed on emails sent or received unencrypted

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 819 bytes --]

^ permalink raw reply	[flat|nested] 34+ messages in thread

* Specifying package patches in a more convenient form
  2016-04-06 14:57   ` Eric Bavier
@ 2016-04-07  9:52     ` Alex Kost
  2016-04-07 10:08       ` Andy Wingo
  2016-04-07 21:54       ` Ludovic Courtès
  2016-04-13 21:40     ` [PATCH 1/9] gnu: Add ttfautohint Ludovic Courtès
  1 sibling, 2 replies; 34+ messages in thread
From: Alex Kost @ 2016-04-07  9:52 UTC (permalink / raw)
  To: Eric Bavier; +Cc: guix-devel

Eric Bavier (2016-04-06 17:57 +0300) wrote:

> On Wed, 06 Apr 2016 15:13:47 +0300
> Alex Kost <alezost@gmail.com> wrote:
[...]
>> > +         "1lgghck46p33z3hg8dnl76jryig4fh6d8rhzms837zp7x4hyfkv4"))
>> > +       (patches (map search-patch '("ttfautohint-source-date-epoch.patch")))))
>>
>> Since it's just a single patch, I don't see a reason to use 'map' here.
>
> Just that it's less to change if more patches are added later.  The
> same has been used in other packages.

I strongly disagree with this policy.  More patches may never be added,
but mapping through a list of a single element looks redundant for me.

Talking about how we specify package patches currently, I think it would
be better to do it in a more clean and general way.  What about adding
the following macro to (gnu packages)?

  (define-syntax-rule (search-patches file-name ...)
    "Return a list of patches for each FILE-NAME."
    (list (search-patch file-name) ...))

So instead of things like this:

  (list (search-patch "foo.patch")
        (search-patch "bar.patch"))

or this:

  (map search-patch '("foo.patch"
                      "bar.patch"))

we'll have:

  (search-patches "foo.patch"
                  "bar.patch")

If it is acceptable, I can make patches to add this macro and to change
package recipes to use it.

P.S.  Actually, I don't like 'search-patches' name.  Better ideas?

-- 
Alex

^ permalink raw reply	[flat|nested] 34+ messages in thread

* Re: Specifying package patches in a more convenient form
  2016-04-07  9:52     ` Specifying package patches in a more convenient form Alex Kost
@ 2016-04-07 10:08       ` Andy Wingo
  2016-04-07 14:41         ` Eric Bavier
  2016-04-08  8:05         ` Alex Kost
  2016-04-07 21:54       ` Ludovic Courtès
  1 sibling, 2 replies; 34+ messages in thread
From: Andy Wingo @ 2016-04-07 10:08 UTC (permalink / raw)
  To: Alex Kost; +Cc: guix-devel

On Thu 07 Apr 2016 11:52, Alex Kost <alezost@gmail.com> writes:

> Eric Bavier (2016-04-06 17:57 +0300) wrote:
>
>> On Wed, 06 Apr 2016 15:13:47 +0300
>> Alex Kost <alezost@gmail.com> wrote:
> [...]
>>> > +         "1lgghck46p33z3hg8dnl76jryig4fh6d8rhzms837zp7x4hyfkv4"))
>>> > +       (patches (map search-patch '("ttfautohint-source-date-epoch.patch")))))
>>>
>>> Since it's just a single patch, I don't see a reason to use 'map' here.
>>
>> Just that it's less to change if more patches are added later.  The
>> same has been used in other packages.
>
> I strongly disagree with this policy.  More patches may never be added,
> but mapping through a list of a single element looks redundant for me.

What if the "patches" field just applied `search-path' to each of the
items in the list if the path is not absolute?  Use
`absolute-file-name?' to check if this is needed or not.

Andy

^ permalink raw reply	[flat|nested] 34+ messages in thread

* Re: [PATCH 2/9] gnu: Add woff-tools.
  2016-04-07  6:18   ` Efraim Flashner
@ 2016-04-07 14:25     ` Eric Bavier
  2016-04-13 21:37     ` Ludovic Courtès
  1 sibling, 0 replies; 34+ messages in thread
From: Eric Bavier @ 2016-04-07 14:25 UTC (permalink / raw)
  To: Efraim Flashner; +Cc: guix-devel

On 2016-04-07 01:18, Efraim Flashner wrote:
> On Tue, Apr 05, 2016 at 11:32:54PM -0500, ericbavier@openmailbox.org 
> wrote:
>> From: Eric Bavier <bavier@member.fsf.org>
>> 
>> * gnu/packages/fontutils.scm (woff-tools): New variable.
>> ---
>>  gnu/packages/fontutils.scm | 41 
>> +++++++++++++++++++++++++++++++++++++++++
>>  1 file changed, 41 insertions(+)
>> 
>> diff --git a/gnu/packages/fontutils.scm b/gnu/packages/fontutils.scm
>> index a0701d5..614aac5 100644
>> --- a/gnu/packages/fontutils.scm
>> +++ b/gnu/packages/fontutils.scm
>> @@ -104,6 +104,47 @@ scripts.")
>>      (license license:gpl2+)             ;or FreeType license
>>      (home-page "http://www.freetype.org/ttfautohint/")))
>> 
>> +(define-public woff-tools
>> +  (package
>> +    (name "woff-tools")
>> +    (version "2009.10.04")
>> +    (source
>> +     (origin
>> +       (method url-fetch)
>> +       ;; Upstream source is unversioned, so use Debian's versioned 
>> tarball
>> +       (uri (string-append "mirror://debian/pool/main/w/woff-tools/"
>> +                           "woff-tools_" version ".orig.tar.gz"))
> 
> 2009 is a long time ago, but woff-tools are still in Debian Sid so we
> don't have to worry about needing to go to archive.debian.org/... for
> the sources any time soon. By the way, is there a more recent version?

Not that I can find.

Thanks for the review,
`~Eric

^ permalink raw reply	[flat|nested] 34+ messages in thread

* Re: [PATCH 3/9] gnu: Add ttf2eot.
  2016-04-07  6:24   ` Efraim Flashner
@ 2016-04-07 14:30     ` Eric Bavier
  2016-04-08  3:49     ` Eric Bavier
  1 sibling, 0 replies; 34+ messages in thread
From: Eric Bavier @ 2016-04-07 14:30 UTC (permalink / raw)
  To: Efraim Flashner; +Cc: guix-devel

On 2016-04-07 01:24, Efraim Flashner wrote:
> On Tue, Apr 05, 2016 at 11:32:55PM -0500, ericbavier@openmailbox.org 
> wrote:
>> From: Eric Bavier <bavier@member.fsf.org>
>> 
>> * gnu/packages/fontutils.scm (ttf2eot): New variable.
>> * gnu/packages/patches/ttf2eot-cstddef.patch: New patch.
>> * gnu-system.am (dist_patch_DATA): Add it.
>> ---
>>  gnu-system.am                              |  1 +
>>  gnu/packages/fontutils.scm                 | 34 
>> ++++++++++++++++++++++++++++++
>>  gnu/packages/patches/ttf2eot-cstddef.patch | 12 +++++++++++
>>  3 files changed, 47 insertions(+)
>>  create mode 100644 gnu/packages/patches/ttf2eot-cstddef.patch
>> 
>> diff --git a/gnu-system.am b/gnu-system.am
>> index 764e564..d3d08da 100644
>> --- a/gnu-system.am
>> +++ b/gnu-system.am
>> @@ -747,6 +747,7 @@ dist_patch_DATA =						\
>>    gnu/packages/patches/tidy-CVE-2015-5522+5523.patch		\
>>    gnu/packages/patches/tinyxml-use-stl.patch			\
>>    gnu/packages/patches/tk-find-library.patch			\
>> +  gnu/packages/patches/ttf2eot-cstddef.patch			\
>>    gnu/packages/patches/ttfautohint-source-date-epoch.patch	\
>>    gnu/packages/patches/tophat-build-with-later-seqan.patch	\
>>    gnu/packages/patches/torsocks-dns-test.patch			\
>> diff --git a/gnu/packages/fontutils.scm b/gnu/packages/fontutils.scm
>> index 614aac5..1e2424b 100644
>> --- a/gnu/packages/fontutils.scm
>> +++ b/gnu/packages/fontutils.scm
>> @@ -145,6 +145,40 @@ Converts WOFF fonts to OpenType fonts
>>      (license (list license:mpl1.1 license:gpl2+ license:lgpl2.1+))
>>      (home-page "https://people.mozilla.com/~jkew/woff/")))
>> 
>> +(define-public ttf2eot
>> +  (package
>> +    (name "ttf2eot")
>> +    (version "0.0.2")
> 
> What about version 0.0.2-2?

Yes, that might be better.

> 
>> +    (source
>> +     (origin
>> +       (method url-fetch)
>> +       (uri (string-append "https://storage.googleapis.com/"
>> +                           "google-code-archive-downloads/v2/"
>> +                           "code.google.com/ttf2eot/"
>> +                           "ttf2eot-" version "-2.tar.gz"))
> 
> I checked and it doesn't look like this project was exported to github
> 
>> +       (sha256
>> +        (base32
>> +         "1f4dzzmhn0208dvbm3ia5ar6ls9apwc6ampy5blmfxkigi6z0g02"))
>> +       (patches (map search-patch '("ttf2eot-cstddef.patch")))))
>> +    (build-system gnu-build-system)
>> +    (arguments
>> +     `(#:tests? #f                      ;no tests
>> +       #:phases
>> +       (modify-phases %standard-phases
>> +         (delete 'configure)            ;no configuration
>> +         (replace 'install
>> +           (lambda* (#:key outputs #:allow-other-keys)
>> +             (let* ((out (assoc-ref outputs "out"))
>> +                    (bin (string-append out "/bin")))
>> +               (install-file "ttf2eot" bin)))))))
>> +    (synopsis "Convert from TrueType to Embeddable Open Type")
>> +    (description
>> +     "This package contains a commandline wrapper around 
>> OpenTypeUtilities.cpp
>> +from Chromium, used to make EOT (Embeddable Open Type) files from
>> +TTF (TrueType/OpenType Font) files.")
>> +    (license license:bsd-2)
> 
> Issue 30[0] says that the readme says its bsd/lgpl licensed.

I'll look into it.

Thanks,
`~Eric

^ permalink raw reply	[flat|nested] 34+ messages in thread

* Re: Specifying package patches in a more convenient form
  2016-04-07 10:08       ` Andy Wingo
@ 2016-04-07 14:41         ` Eric Bavier
  2016-04-08  8:05         ` Alex Kost
  1 sibling, 0 replies; 34+ messages in thread
From: Eric Bavier @ 2016-04-07 14:41 UTC (permalink / raw)
  To: Andy Wingo; +Cc: guix-devel, Alex Kost

On 2016-04-07 05:08, Andy Wingo wrote:
> On Thu 07 Apr 2016 11:52, Alex Kost <alezost@gmail.com> writes:
> 
>> Eric Bavier (2016-04-06 17:57 +0300) wrote:
>> 
>>> On Wed, 06 Apr 2016 15:13:47 +0300
>>> Alex Kost <alezost@gmail.com> wrote:
>> [...]
>>>> > +         "1lgghck46p33z3hg8dnl76jryig4fh6d8rhzms837zp7x4hyfkv4"))
>>>> > +       (patches (map search-patch '("ttfautohint-source-date-epoch.patch")))))
>>>> 
>>>> Since it's just a single patch, I don't see a reason to use 'map' 
>>>> here.
>>> 
>>> Just that it's less to change if more patches are added later.  The
>>> same has been used in other packages.
>> 
>> I strongly disagree with this policy.  More patches may never be 
>> added,
>> but mapping through a list of a single element looks redundant for me.

Sure.  I'm persuaded.

> 
> What if the "patches" field just applied `search-path' to each of the
> items in the list if the path is not absolute?  Use
> `absolute-file-name?' to check if this is needed or not.

This sounds like a promising idea to me.

-- 
`~Eric

^ permalink raw reply	[flat|nested] 34+ messages in thread

* Re: Specifying package patches in a more convenient form
  2016-04-07  9:52     ` Specifying package patches in a more convenient form Alex Kost
  2016-04-07 10:08       ` Andy Wingo
@ 2016-04-07 21:54       ` Ludovic Courtès
  2016-04-09  8:22         ` Alex Kost
  2016-04-09 11:42         ` Andreas Enge
  1 sibling, 2 replies; 34+ messages in thread
From: Ludovic Courtès @ 2016-04-07 21:54 UTC (permalink / raw)
  To: Alex Kost; +Cc: guix-devel

Alex Kost <alezost@gmail.com> skribis:

> Eric Bavier (2016-04-06 17:57 +0300) wrote:
>
>> On Wed, 06 Apr 2016 15:13:47 +0300
>> Alex Kost <alezost@gmail.com> wrote:
> [...]
>>> > +         "1lgghck46p33z3hg8dnl76jryig4fh6d8rhzms837zp7x4hyfkv4"))
>>> > +       (patches (map search-patch '("ttfautohint-source-date-epoch.patch")))))
>>>
>>> Since it's just a single patch, I don't see a reason to use 'map' here.
>>
>> Just that it's less to change if more patches are added later.  The
>> same has been used in other packages.
>
> I strongly disagree with this policy.

I think “strongly” and “policy” are a bit… too strong.  ;-)

> More patches may never be added, but mapping through a list of a
> single element looks redundant for me.
>
> Talking about how we specify package patches currently, I think it would
> be better to do it in a more clean and general way.  What about adding
> the following macro to (gnu packages)?
>
>   (define-syntax-rule (search-patches file-name ...)
>     "Return a list of patches for each FILE-NAME."
>     (list (search-patch file-name) ...))
>
> So instead of things like this:
>
>   (list (search-patch "foo.patch")
>         (search-patch "bar.patch"))
>
> or this:
>
>   (map search-patch '("foo.patch"
>                       "bar.patch"))
>
> we'll have:
>
>   (search-patches "foo.patch"
>                   "bar.patch")

I like it!

> P.S.  Actually, I don't like 'search-patches' name.  Better ideas?

No!  I like it.

Andy Wingo <wingo@igalia.com> skribis:

> What if the "patches" field just applied `search-path' to each of the
> items in the list if the path is not absolute?  Use
> `absolute-file-name?' to check if this is needed or not.

FWIW I have a preference for keeping things explicit.

Thanks!

Ludo’.

^ permalink raw reply	[flat|nested] 34+ messages in thread

* Re: [PATCH 3/9] gnu: Add ttf2eot.
  2016-04-07  6:24   ` Efraim Flashner
  2016-04-07 14:30     ` Eric Bavier
@ 2016-04-08  3:49     ` Eric Bavier
  2016-04-13 21:39       ` Ludovic Courtès
  1 sibling, 1 reply; 34+ messages in thread
From: Eric Bavier @ 2016-04-08  3:49 UTC (permalink / raw)
  To: Efraim Flashner; +Cc: guix-devel, Eric Bavier

On Thu, 7 Apr 2016 09:24:35 +0300
Efraim Flashner <efraim@flashner.co.il> wrote:

> On Tue, Apr 05, 2016 at 11:32:55PM -0500, ericbavier@openmailbox.org wrote:
> > From: Eric Bavier <bavier@member.fsf.org>
> > 
> > * gnu/packages/fontutils.scm (ttf2eot): New variable.
> > * gnu/packages/patches/ttf2eot-cstddef.patch: New patch.
> > * gnu-system.am (dist_patch_DATA): Add it.
[...]
> > +    (license license:bsd-2)  
> 
> Issue 30[0] says that the readme says its bsd/lgpl licensed.
[...]
> 
> [0] https://code.google.com/archive/p/ttf2eot/issues/30

I recall now: I listed bsd-2 as the license, because, while the README
says "License: Derived from WebKit, so BSD/LGPL 2/LGPL 2.1",
the single derived source file includes only BSD in its license
header, and the wrapper source contains no license header at all.  Does
this seem alright?

`~Eric

^ permalink raw reply	[flat|nested] 34+ messages in thread

* Re: Specifying package patches in a more convenient form
  2016-04-07 10:08       ` Andy Wingo
  2016-04-07 14:41         ` Eric Bavier
@ 2016-04-08  8:05         ` Alex Kost
  2016-04-09 14:43           ` Ludovic Courtès
  1 sibling, 1 reply; 34+ messages in thread
From: Alex Kost @ 2016-04-08  8:05 UTC (permalink / raw)
  To: Andy Wingo; +Cc: guix-devel

Andy Wingo (2016-04-07 13:08 +0300) wrote:

> On Thu 07 Apr 2016 11:52, Alex Kost <alezost@gmail.com> writes:
>
>> Eric Bavier (2016-04-06 17:57 +0300) wrote:
>>
>>> On Wed, 06 Apr 2016 15:13:47 +0300
>>> Alex Kost <alezost@gmail.com> wrote:
>> [...]
>>>> > +         "1lgghck46p33z3hg8dnl76jryig4fh6d8rhzms837zp7x4hyfkv4"))
>>>> > +       (patches (map search-patch '("ttfautohint-source-date-epoch.patch")))))
>>>>
>>>> Since it's just a single patch, I don't see a reason to use 'map' here.
>>>
>>> Just that it's less to change if more patches are added later.  The
>>> same has been used in other packages.
>>
>> I strongly disagree with this policy.  More patches may never be added,
>> but mapping through a list of a single element looks redundant for me.
>
> What if the "patches" field just applied `search-path' to each of the
> items in the list if the path is not absolute?  Use
> `absolute-file-name?' to check if this is needed or not.

I think it is a good choice that 'patches' field takes a list of file
names.  For example, currently a user can do:

  (patches (find-my-patches "package-name"))

With what you suggest, it would not be possible.

-- 
Alex

^ permalink raw reply	[flat|nested] 34+ messages in thread

* Re: Specifying package patches in a more convenient form
  2016-04-07 21:54       ` Ludovic Courtès
@ 2016-04-09  8:22         ` Alex Kost
  2016-04-09 11:42         ` Andreas Enge
  1 sibling, 0 replies; 34+ messages in thread
From: Alex Kost @ 2016-04-09  8:22 UTC (permalink / raw)
  To: Ludovic Courtès; +Cc: guix-devel

Ludovic Courtès (2016-04-08 00:54 +0300) wrote:

> Alex Kost <alezost@gmail.com> skribis:
[...]
>> Talking about how we specify package patches currently, I think it would
>> be better to do it in a more clean and general way.  What about adding
>> the following macro to (gnu packages)?
>>
>>   (define-syntax-rule (search-patches file-name ...)
>>     "Return a list of patches for each FILE-NAME."
>>     (list (search-patch file-name) ...))
>>
>> So instead of things like this:
>>
>>   (list (search-patch "foo.patch")
>>         (search-patch "bar.patch"))
>>
>> or this:
>>
>>   (map search-patch '("foo.patch"
>>                       "bar.patch"))
>>
>> we'll have:
>>
>>   (search-patches "foo.patch"
>>                   "bar.patch")
>
> I like it!

OK, I've sent the patches for this change.

> Andy Wingo <wingo@igalia.com> skribis:
>
>> What if the "patches" field just applied `search-path' to each of the
>> items in the list if the path is not absolute?  Use
>> `absolute-file-name?' to check if this is needed or not.
>
> FWIW I have a preference for keeping things explicit.

Another argument is 'glibc-locales' packages which has:

  (patches (cons (search-patch "glibc-locales.patch")
                 (origin-patches (package-source glibc))))

-- 
Alex

^ permalink raw reply	[flat|nested] 34+ messages in thread

* Re: Specifying package patches in a more convenient form
  2016-04-07 21:54       ` Ludovic Courtès
  2016-04-09  8:22         ` Alex Kost
@ 2016-04-09 11:42         ` Andreas Enge
  2016-04-09 16:40           ` Alex Kost
  1 sibling, 1 reply; 34+ messages in thread
From: Andreas Enge @ 2016-04-09 11:42 UTC (permalink / raw)
  To: Ludovic Courtès; +Cc: guix-devel, Alex Kost

On Thu, Apr 07, 2016 at 11:54:49PM +0200, Ludovic Courtès wrote:
> Alex Kost <alezost@gmail.com> skribis:
> > P.S.  Actually, I don't like 'search-patches' name.  Better ideas?
> No!  I like it.

How about "find-patches"? This would be analogous to "find-files".

Andreas

^ permalink raw reply	[flat|nested] 34+ messages in thread

* Re: Specifying package patches in a more convenient form
  2016-04-08  8:05         ` Alex Kost
@ 2016-04-09 14:43           ` Ludovic Courtès
  0 siblings, 0 replies; 34+ messages in thread
From: Ludovic Courtès @ 2016-04-09 14:43 UTC (permalink / raw)
  To: Alex Kost; +Cc: guix-devel

Alex Kost <alezost@gmail.com> skribis:

> Andy Wingo (2016-04-07 13:08 +0300) wrote:
>
>> On Thu 07 Apr 2016 11:52, Alex Kost <alezost@gmail.com> writes:
>>
>>> Eric Bavier (2016-04-06 17:57 +0300) wrote:
>>>
>>>> On Wed, 06 Apr 2016 15:13:47 +0300
>>>> Alex Kost <alezost@gmail.com> wrote:
>>> [...]
>>>>> > +         "1lgghck46p33z3hg8dnl76jryig4fh6d8rhzms837zp7x4hyfkv4"))
>>>>> > +       (patches (map search-patch '("ttfautohint-source-date-epoch.patch")))))
>>>>>
>>>>> Since it's just a single patch, I don't see a reason to use 'map' here.
>>>>
>>>> Just that it's less to change if more patches are added later.  The
>>>> same has been used in other packages.
>>>
>>> I strongly disagree with this policy.  More patches may never be added,
>>> but mapping through a list of a single element looks redundant for me.
>>
>> What if the "patches" field just applied `search-path' to each of the
>> items in the list if the path is not absolute?  Use
>> `absolute-file-name?' to check if this is needed or not.
>
> I think it is a good choice that 'patches' field takes a list of file
> names.  For example, currently a user can do:
>
>   (patches (find-my-patches "package-name"))
>
> With what you suggest, it would not be possible.

It would still be possible, provided ‘find-my-patches’ returns absolute
file names.  But yeah, there would always be this extra pass of
guesswork under the hood.

Ludo’.

^ permalink raw reply	[flat|nested] 34+ messages in thread

* Re: Specifying package patches in a more convenient form
  2016-04-09 11:42         ` Andreas Enge
@ 2016-04-09 16:40           ` Alex Kost
  0 siblings, 0 replies; 34+ messages in thread
From: Alex Kost @ 2016-04-09 16:40 UTC (permalink / raw)
  To: Andreas Enge; +Cc: guix-devel

Andreas Enge (2016-04-09 14:42 +0300) wrote:

> On Thu, Apr 07, 2016 at 11:54:49PM +0200, Ludovic Courtès wrote:
>> Alex Kost <alezost@gmail.com> skribis:
>> > P.S.  Actually, I don't like 'search-patches' name.  Better ideas?
>> No!  I like it.
>
> How about "find-patches"? This would be analogous to "find-files".

Since it is build on 'search-patch' procedure, 'search-patches' name
looks like a more natural choice to me, but I don't have a preference.
I agree on any name (I just like none of them :-)).

-- 
Alex

^ permalink raw reply	[flat|nested] 34+ messages in thread

* Re: [PATCH 1/9] gnu: Add ttfautohint.
  2016-04-06  4:32 [PATCH 1/9] gnu: Add ttfautohint ericbavier
                   ` (8 preceding siblings ...)
  2016-04-06 12:13 ` [PATCH 1/9] gnu: Add ttfautohint Alex Kost
@ 2016-04-13 21:36 ` Ludovic Courtès
  2016-04-14 14:43   ` Eric Bavier
  9 siblings, 1 reply; 34+ messages in thread
From: Ludovic Courtès @ 2016-04-13 21:36 UTC (permalink / raw)
  To: ericbavier; +Cc: guix-devel, Eric Bavier

ericbavier@openmailbox.org skribis:

> From: Eric Bavier <bavier@member.fsf.org>
>
> * gnu/packages/fontutils.scm (ttfautohint): New variable.
> * gnu/packages/patches/ttfautohint-source-date-epoch.patch: New patch.
> * gnu-system.am (dist_patch_DATA): Add it.

LGTM!

Did you submit the SOURCE_DATE_EPOCH patch upstream?  Good work!

Thanks,
Ludo’.

^ permalink raw reply	[flat|nested] 34+ messages in thread

* Re: [PATCH 2/9] gnu: Add woff-tools.
  2016-04-07  6:18   ` Efraim Flashner
  2016-04-07 14:25     ` Eric Bavier
@ 2016-04-13 21:37     ` Ludovic Courtès
  1 sibling, 0 replies; 34+ messages in thread
From: Ludovic Courtès @ 2016-04-13 21:37 UTC (permalink / raw)
  To: Efraim Flashner; +Cc: guix-devel, Eric Bavier

Efraim Flashner <efraim@flashner.co.il> skribis:

> On Tue, Apr 05, 2016 at 11:32:54PM -0500, ericbavier@openmailbox.org wrote:
>> From: Eric Bavier <bavier@member.fsf.org>
>> 
>> * gnu/packages/fontutils.scm (woff-tools): New variable.

[...]

> Looks good to me

+1

Ludo’.

^ permalink raw reply	[flat|nested] 34+ messages in thread

* Re: [PATCH 3/9] gnu: Add ttf2eot.
  2016-04-08  3:49     ` Eric Bavier
@ 2016-04-13 21:39       ` Ludovic Courtès
  0 siblings, 0 replies; 34+ messages in thread
From: Ludovic Courtès @ 2016-04-13 21:39 UTC (permalink / raw)
  To: Eric Bavier; +Cc: guix-devel, Eric Bavier

Eric Bavier <ericbavier@openmailbox.org> skribis:

> On Thu, 7 Apr 2016 09:24:35 +0300
> Efraim Flashner <efraim@flashner.co.il> wrote:
>
>> On Tue, Apr 05, 2016 at 11:32:55PM -0500, ericbavier@openmailbox.org wrote:
>> > From: Eric Bavier <bavier@member.fsf.org>
>> > 
>> > * gnu/packages/fontutils.scm (ttf2eot): New variable.
>> > * gnu/packages/patches/ttf2eot-cstddef.patch: New patch.
>> > * gnu-system.am (dist_patch_DATA): Add it.
> [...]
>> > +    (license license:bsd-2)  
>> 
>> Issue 30[0] says that the readme says its bsd/lgpl licensed.
> [...]
>> 
>> [0] https://code.google.com/archive/p/ttf2eot/issues/30
>
> I recall now: I listed bsd-2 as the license, because, while the README
> says "License: Derived from WebKit, so BSD/LGPL 2/LGPL 2.1",
> the single derived source file includes only BSD in its license
> header, and the wrapper source contains no license header at all.  Does
> this seem alright?

I think so.  Just briefly mention this as a comment for future
reference.

Thanks,
Ludo’.

^ permalink raw reply	[flat|nested] 34+ messages in thread

* Re: [PATCH 1/9] gnu: Add ttfautohint.
  2016-04-06 14:57   ` Eric Bavier
  2016-04-07  9:52     ` Specifying package patches in a more convenient form Alex Kost
@ 2016-04-13 21:40     ` Ludovic Courtès
  1 sibling, 0 replies; 34+ messages in thread
From: Ludovic Courtès @ 2016-04-13 21:40 UTC (permalink / raw)
  To: Eric Bavier; +Cc: guix-devel, Alex Kost

Eric Bavier <ericbavier@openmailbox.org> skribis:

> On Wed, 06 Apr 2016 15:13:47 +0300
> Alex Kost <alezost@gmail.com> wrote:
>
>> ericbavier@openmailbox.org (2016-04-06 07:32 +0300) wrote:

[...]

>> > +    (license license:gpl2+)             ;or FreeType license
>>
>> Or FreeType?  Sorry, what does it mean?  If some files are under GPL2+
>> and some under FreeType, then why don't you use a list of licenses?
>>
>
> The license text says to pick one, and I wanted to indicate that in
> some way in the absense of more descriptive license operators.

You can use ‘list’ and indicate in a comment above that it’s up to the
recipient to choose one of these two licenses.

Ludo’.

^ permalink raw reply	[flat|nested] 34+ messages in thread

* Re: [PATCH 4/9] gnu: Add brotli.
  2016-04-06  4:32 ` [PATCH 4/9] gnu: Add brotli ericbavier
@ 2016-04-13 21:44   ` Ludovic Courtès
  0 siblings, 0 replies; 34+ messages in thread
From: Ludovic Courtès @ 2016-04-13 21:44 UTC (permalink / raw)
  To: ericbavier; +Cc: guix-devel, Eric Bavier

ericbavier@openmailbox.org skribis:

> From: Eric Bavier <bavier@member.fsf.org>
>
> * gnu/packages/compression.scm (brotli): New variable.

[...]

> +  (let ((commit "e992cce7a174d6e2b3486616499d26bb0bad6448"))
> +    (package
> +      (name "brotli")
> +      (version "0.1")

Please use a version string as noted in the guidelines (info "(guix)
Version Numbers").


[...]

> +       `(#:phases (modify-phases %standard-phases
> +                    (add-after 'unpack 'autogen
> +                      (lambda _
> +                        (mkdir "m4")
> +                        (system* "autoreconf" "-vfi"))))))

(zero? (system* …))

> +      (synopsis "Brotli encoder/decoder libraries")

Maybe “Implementation of the Brotli compression algorithm” or something
like this to hint at the application domain?

> +      (description
> +       "This package provides Brotli encoder and decoder libraries: libbrotlienc
> +and libbrotlidec, respectively.")

Could you expound the description a little bit?  :-)

Thanks,
Ludo’.

^ permalink raw reply	[flat|nested] 34+ messages in thread

* Re: [PATCH 1/9] gnu: Add ttfautohint.
  2016-04-13 21:36 ` Ludovic Courtès
@ 2016-04-14 14:43   ` Eric Bavier
  0 siblings, 0 replies; 34+ messages in thread
From: Eric Bavier @ 2016-04-14 14:43 UTC (permalink / raw)
  To: ludo; +Cc: guix-devel

On 2016-04-13 16:36, ludo@gnu.org wrote:
> ericbavier@openmailbox.org skribis:
> 
>> From: Eric Bavier <bavier@member.fsf.org>
>> 
>> * gnu/packages/fontutils.scm (ttfautohint): New variable.
>> * gnu/packages/patches/ttfautohint-source-date-epoch.patch: New patch.
>> * gnu-system.am (dist_patch_DATA): Add it.
> 
> LGTM!

Great.  Thanks for reviewing.

> 
> Did you submit the SOURCE_DATE_EPOCH patch upstream?  Good work!
> 

I just sent the patch to Werner Lemberg.

`~Eric

-- 
`~Eric

^ permalink raw reply	[flat|nested] 34+ messages in thread

end of thread, other threads:[~2016-04-14 14:44 UTC | newest]

Thread overview: 34+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2016-04-06  4:32 [PATCH 1/9] gnu: Add ttfautohint ericbavier
2016-04-06  4:32 ` [PATCH 2/9] gnu: Add woff-tools ericbavier
2016-04-07  6:18   ` Efraim Flashner
2016-04-07 14:25     ` Eric Bavier
2016-04-13 21:37     ` Ludovic Courtès
2016-04-06  4:32 ` [PATCH 3/9] gnu: Add ttf2eot ericbavier
2016-04-07  6:24   ` Efraim Flashner
2016-04-07 14:30     ` Eric Bavier
2016-04-08  3:49     ` Eric Bavier
2016-04-13 21:39       ` Ludovic Courtès
2016-04-06  4:32 ` [PATCH 4/9] gnu: Add brotli ericbavier
2016-04-13 21:44   ` Ludovic Courtès
2016-04-06  4:32 ` [PATCH 5/9] gnu: Add woff2 ericbavier
2016-04-06  4:32 ` [PATCH 6/9] gnu: fontforge: Make SVG builds reproducible ericbavier
2016-04-06 17:36   ` Leo Famulari
2016-04-06 17:44     ` Eric Bavier
2016-04-06 17:56       ` Leo Famulari
2016-04-06  4:32 ` [PATCH 7/9] gnu: Add font-fantasque-sans ericbavier
2016-04-06  4:33 ` [PATCH 8/9] gnu: fontforge: Use modify-phases ericbavier
2016-04-06  4:33 ` [PATCH 9/9] gnu: fontforge: Install 'showttf' tool ericbavier
2016-04-06 12:13 ` [PATCH 1/9] gnu: Add ttfautohint Alex Kost
2016-04-06 14:57   ` Eric Bavier
2016-04-07  9:52     ` Specifying package patches in a more convenient form Alex Kost
2016-04-07 10:08       ` Andy Wingo
2016-04-07 14:41         ` Eric Bavier
2016-04-08  8:05         ` Alex Kost
2016-04-09 14:43           ` Ludovic Courtès
2016-04-07 21:54       ` Ludovic Courtès
2016-04-09  8:22         ` Alex Kost
2016-04-09 11:42         ` Andreas Enge
2016-04-09 16:40           ` Alex Kost
2016-04-13 21:40     ` [PATCH 1/9] gnu: Add ttfautohint Ludovic Courtès
2016-04-13 21:36 ` Ludovic Courtès
2016-04-14 14:43   ` Eric Bavier

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).