* [bug#34615] [PATCH] gnu: Add libtommath. @ 2019-02-22 12:20 Efraim Flashner 2019-02-22 12:27 ` Efraim Flashner 2019-02-22 18:57 ` [bug#34615] " Tobias Geerinckx-Rice 0 siblings, 2 replies; 9+ messages in thread From: Efraim Flashner @ 2019-02-22 12:20 UTC (permalink / raw) To: 34615 * gnu/packages/algebra.scm (libtommath): New variable. --- gnu/packages/algebra.scm | 47 +++++++++++++++++++++++++++++++++++++++- 1 file changed, 46 insertions(+), 1 deletion(-) diff --git a/gnu/packages/algebra.scm b/gnu/packages/algebra.scm index f9ae22b3f3..98dc414ac5 100644 --- a/gnu/packages/algebra.scm +++ b/gnu/packages/algebra.scm @@ -4,7 +4,7 @@ ;;; Copyright © 2016, 2017, 2018, 2019 Nicolas Goaziou <mail@nicolasgoaziou.fr> ;;; Copyright © 2014, 2018 Mark H Weaver <mhw@netris.org> ;;; Copyright © 2016, 2018, 2019 Ricardo Wurmus <rekado@elephly.net> -;;; Copyright © 2017 Efraim Flashner <efraim@flashner.co.il> +;;; Copyright © 2017, 2019 Efraim Flashner <efraim@flashner.co.il> ;;; Copyright © 2017, 2018 Tobias Geerinckx-Rice <me@tobias.gr> ;;; Copyright © 2017 Marius Bakke <mbakke@fastmail.com> ;;; Copyright © 2017, 2019 Eric Bavier <bavier@member.fsf.org> @@ -1000,3 +1000,48 @@ objects.") ;; means that the gpl2+ licence of GAP itself applies, but to be on the ;; safe side, we drop them for now. (license license:gpl2+))) + +(define-public libtommath + (package + (name "libtommath") + (version "1.1.0") + (source + (origin + (method url-fetch) + (uri (string-append "https://github.com/libtom/libtommath/releases/" + "download/v" version "/ltm-" version ".tar.xz")) + (sha256 + (base32 + "1bbyagqzfdbg37k1n08nsqzdf44z8zsnjjinqbsyj7rxg246qilh")) + (patches (search-patches "libtommath-fix-linkage.patch")))) + (build-system gnu-build-system) + (arguments + '(#:phases + (modify-phases %standard-phases + (delete 'configure) ; no configure + (add-after 'unpack 'prepare-build + (lambda _ + ;; Don't pull in coreutils. + (substitute* "makefile_include.mk" + (("arch") "uname -m")) + (delete-file "makefile") + (symlink "makefile.shared" "makefile") + #t)) + (replace 'check + (lambda* (#:key make-flags #:allow-other-keys) + (apply invoke "make" "test_standalone" make-flags) + (invoke "sh" "test"))) + (add-after 'check 'make-static + (lambda* (#:key make-flags #:allow-other-keys) + (apply invoke "make" "-f" "makefile.unix" "install" make-flags)))) + #:make-flags (list (string-append "PREFIX=" (assoc-ref %outputs "out")) + "CC=gcc"))) + (native-inputs + `(("libtool" ,libtool))) + (home-page "https://www.libtom.net/LibTomMath/") + (synopsis "portable number theoretic multiple-precision integer library") + (description "LibTomMath is a portable number theoretic multiple-precision +integer library written entirely in C. The library is designed to provide a +simple to work with API that provides fairly efficient routines that build out +of the box without configuration.") + (license license:unlicense))) -- 2.20.1 ^ permalink raw reply related [flat|nested] 9+ messages in thread
* [bug#34615] [PATCH] gnu: Add libtommath. 2019-02-22 12:20 [bug#34615] [PATCH] gnu: Add libtommath Efraim Flashner @ 2019-02-22 12:27 ` Efraim Flashner 2019-02-22 22:30 ` Tobias Geerinckx-Rice 2019-02-24 8:52 ` bug#34615: " Efraim Flashner 2019-02-22 18:57 ` [bug#34615] " Tobias Geerinckx-Rice 1 sibling, 2 replies; 9+ messages in thread From: Efraim Flashner @ 2019-02-22 12:27 UTC (permalink / raw) To: 34615 [-- Attachment #1.1: Type: text/plain, Size: 304 bytes --] Looks like I sent the email and forgot to add the patch to the package definition patch. -- 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 #1.2: 0001-gnu-Add-libtommath.patch --] [-- Type: text/plain, Size: 6592 bytes --] From 11dc41593f353e8bf55c9403182690c7adc49556 Mon Sep 17 00:00:00 2001 From: Efraim Flashner <efraim@flashner.co.il> Date: Fri, 22 Feb 2019 14:18:10 +0200 Subject: [PATCH] gnu: Add libtommath. * gnu/packages/algebra.scm (libtommath): New variable. * gnu/packages/patches/libtommath.patch: New file. * gnu/local.mk (dist_patch_DATA): Register it. --- gnu/local.mk | 1 + gnu/packages/algebra.scm | 47 +++++++++++++++- .../patches/libtommath-fix-linkage.patch | 55 +++++++++++++++++++ 3 files changed, 102 insertions(+), 1 deletion(-) create mode 100644 gnu/packages/patches/libtommath-fix-linkage.patch diff --git a/gnu/local.mk b/gnu/local.mk index faebff2e5d..73472fdc50 100644 --- a/gnu/local.mk +++ b/gnu/local.mk @@ -993,6 +993,7 @@ dist_patch_DATA = \ %D%/packages/patches/libssh2-fix-build-failure-with-gcrypt.patch \ %D%/packages/patches/libtar-CVE-2013-4420.patch \ %D%/packages/patches/libtheora-config-guess.patch \ + %D%/packages/patches/libtommath-fix-linkage.patch \ %D%/packages/patches/libtool-skip-tests2.patch \ %D%/packages/patches/libusb-0.1-disable-tests.patch \ %D%/packages/patches/libusb-for-axoloti.patch \ diff --git a/gnu/packages/algebra.scm b/gnu/packages/algebra.scm index f9ae22b3f3..98dc414ac5 100644 --- a/gnu/packages/algebra.scm +++ b/gnu/packages/algebra.scm @@ -4,7 +4,7 @@ ;;; Copyright © 2016, 2017, 2018, 2019 Nicolas Goaziou <mail@nicolasgoaziou.fr> ;;; Copyright © 2014, 2018 Mark H Weaver <mhw@netris.org> ;;; Copyright © 2016, 2018, 2019 Ricardo Wurmus <rekado@elephly.net> -;;; Copyright © 2017 Efraim Flashner <efraim@flashner.co.il> +;;; Copyright © 2017, 2019 Efraim Flashner <efraim@flashner.co.il> ;;; Copyright © 2017, 2018 Tobias Geerinckx-Rice <me@tobias.gr> ;;; Copyright © 2017 Marius Bakke <mbakke@fastmail.com> ;;; Copyright © 2017, 2019 Eric Bavier <bavier@member.fsf.org> @@ -1000,3 +1000,48 @@ objects.") ;; means that the gpl2+ licence of GAP itself applies, but to be on the ;; safe side, we drop them for now. (license license:gpl2+))) + +(define-public libtommath + (package + (name "libtommath") + (version "1.1.0") + (source + (origin + (method url-fetch) + (uri (string-append "https://github.com/libtom/libtommath/releases/" + "download/v" version "/ltm-" version ".tar.xz")) + (sha256 + (base32 + "1bbyagqzfdbg37k1n08nsqzdf44z8zsnjjinqbsyj7rxg246qilh")) + (patches (search-patches "libtommath-fix-linkage.patch")))) + (build-system gnu-build-system) + (arguments + '(#:phases + (modify-phases %standard-phases + (delete 'configure) ; no configure + (add-after 'unpack 'prepare-build + (lambda _ + ;; Don't pull in coreutils. + (substitute* "makefile_include.mk" + (("arch") "uname -m")) + (delete-file "makefile") + (symlink "makefile.shared" "makefile") + #t)) + (replace 'check + (lambda* (#:key make-flags #:allow-other-keys) + (apply invoke "make" "test_standalone" make-flags) + (invoke "sh" "test"))) + (add-after 'check 'make-static + (lambda* (#:key make-flags #:allow-other-keys) + (apply invoke "make" "-f" "makefile.unix" "install" make-flags)))) + #:make-flags (list (string-append "PREFIX=" (assoc-ref %outputs "out")) + "CC=gcc"))) + (native-inputs + `(("libtool" ,libtool))) + (home-page "https://www.libtom.net/LibTomMath/") + (synopsis "portable number theoretic multiple-precision integer library") + (description "LibTomMath is a portable number theoretic multiple-precision +integer library written entirely in C. The library is designed to provide a +simple to work with API that provides fairly efficient routines that build out +of the box without configuration.") + (license license:unlicense))) diff --git a/gnu/packages/patches/libtommath-fix-linkage.patch b/gnu/packages/patches/libtommath-fix-linkage.patch new file mode 100644 index 0000000000..1a9d46eb7c --- /dev/null +++ b/gnu/packages/patches/libtommath-fix-linkage.patch @@ -0,0 +1,55 @@ +https://github.com/libtom/libtommath/commit/93dea3a4162527346cd8856bfda6f17ffe98ab04.patch + +From 93dea3a4162527346cd8856bfda6f17ffe98ab04 Mon Sep 17 00:00:00 2001 +From: Steffen Jaeckel <s@jaeckel.eu> +Date: Thu, 31 Jan 2019 14:12:03 +0100 +Subject: [PATCH] makefile.shared: fix compilation and linkage + +--- + makefile.shared | 15 ++++++++------- + 1 file changed, 8 insertions(+), 7 deletions(-) + +diff --git a/makefile.shared b/makefile.shared +index 3955f830..870b18d1 100644 +--- a/makefile.shared ++++ b/makefile.shared +@@ -18,6 +18,7 @@ ifndef LIBTOOL + endif + endif + LTCOMPILE = $(LIBTOOL) --mode=compile --tag=CC $(CC) ++LTLINK = $(LIBTOOL) --mode=link --tag=CC $(CC) + + LCOV_ARGS=--directory .libs --directory . + +@@ -59,7 +60,7 @@ objs: $(OBJECTS) + LOBJECTS = $(OBJECTS:.o=.lo) + + $(LIBNAME): $(OBJECTS) +- $(LIBTOOL) --mode=link --tag=CC $(CC) $(LDFLAGS) $(LOBJECTS) -o $(LIBNAME) -rpath $(LIBPATH) -version-info $(VERSION_SO) $(LIBTOOLFLAGS) ++ $(LTLINK) $(LDFLAGS) $(LOBJECTS) -o $(LIBNAME) -rpath $(LIBPATH) -version-info $(VERSION_SO) $(LIBTOOLFLAGS) + + install: $(LIBNAME) + install -d $(DESTDIR)$(LIBPATH) +@@ -76,16 +77,16 @@ uninstall: + rm $(DESTDIR)$(LIBPATH)/pkgconfig/libtommath.pc + + test: $(LIBNAME) demo/demo.o +- $(CC) $(CFLAGS) -c demo/demo.c -o demo/demo.o +- $(LIBTOOL) --mode=link $(CC) $(LDFLAGS) -o test demo/demo.o $(LIBNAME) ++ $(LTCOMPILE) $(CFLAGS) -c demo/demo.c -o demo/demo.o ++ $(LTLINK) $(LDFLAGS) -o test demo/demo.o $(LIBNAME) + + test_standalone: $(LIBNAME) demo/demo.o +- $(CC) $(CFLAGS) -c demo/demo.c -o demo/demo.o +- $(LIBTOOL) --mode=link $(CC) $(LDFLAGS) -o test demo/demo.o $(LIBNAME) ++ $(LTCOMPILE) $(CFLAGS) -c demo/demo.c -o demo/demo.o ++ $(LTLINK) $(LDFLAGS) -o test demo/demo.o $(LIBNAME) + + .PHONY: mtest + mtest: +- cd mtest ; $(CC) $(CFLAGS) $(LDFLAGS) mtest.c -o mtest ++ cd mtest ; $(CC) $(CFLAGS) -O0 mtest.c $(LDFLAGS) -o mtest + + timing: $(LIBNAME) demo/timing.c +- $(LIBTOOL) --mode=link $(CC) $(CFLAGS) $(LDFLAGS) -DTIMER demo/timing.c $(LIBNAME) -o timing ++ $(LTLINK) $(CFLAGS) $(LDFLAGS) -DTIMER demo/timing.c $(LIBNAME) -o timing -- 2.20.1 [-- Attachment #2: signature.asc --] [-- Type: application/pgp-signature, Size: 833 bytes --] ^ permalink raw reply related [flat|nested] 9+ messages in thread
* [bug#34615] [PATCH] gnu: Add libtommath. 2019-02-22 12:27 ` Efraim Flashner @ 2019-02-22 22:30 ` Tobias Geerinckx-Rice 2019-02-24 7:45 ` Efraim Flashner 2019-02-24 8:52 ` bug#34615: " Efraim Flashner 1 sibling, 1 reply; 9+ messages in thread From: Tobias Geerinckx-Rice @ 2019-02-22 22:30 UTC (permalink / raw) To: Efraim Flashner; +Cc: 34615 Efraim, I noticed some PDF documentation that isn't currently installed. How about: (add-after 'build 'install-documentation (lambda* (#:key outputs #:allow-other-keys) (let* ((out (assoc-ref outputs "out")) (doc (string-append out "/share/doc/" ,name "-" ,version))) (for-each (lambda (file) (install-file file doc)) (find-files "doc" "\\.pdf$")) #t)))) (This mail was supposed to be longer because it *is* possible to regenerate al least bn.pdf from the .tex sources, but an hour and 6 GiB of texlive grafting later I don't have the energy to remove the non-determininstic date on their front page. Foo.) Kind regards, T G-R ^ permalink raw reply [flat|nested] 9+ messages in thread
* [bug#34615] [PATCH] gnu: Add libtommath. 2019-02-22 22:30 ` Tobias Geerinckx-Rice @ 2019-02-24 7:45 ` Efraim Flashner 0 siblings, 0 replies; 9+ messages in thread From: Efraim Flashner @ 2019-02-24 7:45 UTC (permalink / raw) To: Tobias Geerinckx-Rice; +Cc: 34615 [-- Attachment #1: Type: text/plain, Size: 1256 bytes --] On Fri, Feb 22, 2019 at 11:30:54PM +0100, Tobias Geerinckx-Rice wrote: > Efraim, > > I noticed some PDF documentation that isn't currently installed. How about: > > (add-after 'build 'install-documentation > (lambda* (#:key outputs #:allow-other-keys) > (let* ((out (assoc-ref outputs "out")) > (doc (string-append out "/share/doc/" ,name "-" > ,version))) > (for-each (lambda (file) (install-file file doc)) > (find-files "doc" "\\.pdf$")) > #t)))) > > (This mail was supposed to be longer because it *is* possible to regenerate > al least bn.pdf from the .tex sources, but an hour and 6 GiB of texlive > grafting later I don't have the energy to remove the non-determininstic date > on their front page. Foo.) > I wanted to keep the install size smaller so I hadn't planned on installing the documentation. Considering we don't build the documentation currently, if there are PDFs that are shipped with the source I should probably delete those in a snippet. -- 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: 833 bytes --] ^ permalink raw reply [flat|nested] 9+ messages in thread
* bug#34615: [PATCH] gnu: Add libtommath. 2019-02-22 12:27 ` Efraim Flashner 2019-02-22 22:30 ` Tobias Geerinckx-Rice @ 2019-02-24 8:52 ` Efraim Flashner 1 sibling, 0 replies; 9+ messages in thread From: Efraim Flashner @ 2019-02-24 8:52 UTC (permalink / raw) To: 34615-done [-- Attachment #1: Type: text/plain, Size: 244 bytes --] Pushed with changes suggested -- 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: 833 bytes --] ^ permalink raw reply [flat|nested] 9+ messages in thread
* [bug#34615] [PATCH] gnu: Add libtommath. 2019-02-22 12:20 [bug#34615] [PATCH] gnu: Add libtommath Efraim Flashner 2019-02-22 12:27 ` Efraim Flashner @ 2019-02-22 18:57 ` Tobias Geerinckx-Rice 2019-02-23 9:06 ` swedebugia 2019-02-24 7:50 ` Efraim Flashner 1 sibling, 2 replies; 9+ messages in thread From: Tobias Geerinckx-Rice @ 2019-02-22 18:57 UTC (permalink / raw) To: Efraim Flashner; +Cc: 34615 Efraim, Thanks! Efraim Flashner wrote: > * gnu/packages/algebra.scm (libtommath): New variable. > + (add-after 'unpack 'prepare-build > + (lambda _ > + ;; Don't pull in coreutils. > + (substitute* "makefile_include.mk" > + (("arch") "uname -m")) I'd add an empty line here or separate this into two fases just to be very clear, since… > + (delete-file "makefile") > + (symlink "makefile.shared" "makefile") > + #t)) …I got a bit lost between all these makefiles. Could you explain exactly what's going on? Is this to avoid repeating ‘-f makefile.shared’ elsewhere? > + (add-after 'check 'make-static More accurate: 'install-static-library. While libtommath.a is ‘only’ 332K, that's almost half of the entire output size. Is it worth moving to a separate :static output? > + (synopsis "portable number theoretic multiple-precision > integer library") s/p/P/ multiprecision.scm is a better fit and already has sister package tomsfastmath to keep this one company. > +integer library written entirely in C. The library is designed > to provide a s/The library is/It's/ IMO. > +simple to work with API ‘simple-to-work-with API’, unfortunately. Kind regards, T G-R ^ permalink raw reply [flat|nested] 9+ messages in thread
* [bug#34615] [PATCH] gnu: Add libtommath. 2019-02-22 18:57 ` [bug#34615] " Tobias Geerinckx-Rice @ 2019-02-23 9:06 ` swedebugia 2019-02-24 7:47 ` Efraim Flashner 2019-02-24 7:50 ` Efraim Flashner 1 sibling, 1 reply; 9+ messages in thread From: swedebugia @ 2019-02-23 9:06 UTC (permalink / raw) To: 34615, somebody, efraim Tobias Geerinckx-Rice <somebody@not-sent-or-endorsed-by.tobias.gr> skrev: (22 februari 2019 19:57:25 CET) >Efraim, > >Thanks! > >Efraim Flashner wrote: > >> +integer library written entirely in C. The library is designed >> to provide a > >s/The library is/It's/ IMO. > >> +simple to work with API > >‘simple-to-work-with API’, unfortunately. I suggest:. ..an API that is simple to work with. -- Sent from my k-9 mail for Android. ^ permalink raw reply [flat|nested] 9+ messages in thread
* [bug#34615] [PATCH] gnu: Add libtommath. 2019-02-23 9:06 ` swedebugia @ 2019-02-24 7:47 ` Efraim Flashner 0 siblings, 0 replies; 9+ messages in thread From: Efraim Flashner @ 2019-02-24 7:47 UTC (permalink / raw) To: swedebugia; +Cc: somebody, 34615 [-- Attachment #1: Type: text/plain, Size: 934 bytes --] On Sat, Feb 23, 2019 at 10:06:07AM +0100, swedebugia wrote: > Tobias Geerinckx-Rice <somebody@not-sent-or-endorsed-by.tobias.gr> skrev: (22 februari 2019 19:57:25 CET) > >Efraim, > > > >Thanks! > > > >Efraim Flashner wrote: > > > > >> +integer library written entirely in C. The library is designed > >> to provide a > > > >s/The library is/It's/ IMO. > > > >> +simple to work with API > > > >‘simple-to-work-with API’, unfortunately. > > I suggest:. ..an API that is simple to work with. > This sounds good. I checked Debian's description¹ and it's much longer, although they do manage to skip discussing the API. ¹ https://sources.debian.org/src/libtommath/1.1.0-3/debian/control/ -- 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: 833 bytes --] ^ permalink raw reply [flat|nested] 9+ messages in thread
* [bug#34615] [PATCH] gnu: Add libtommath. 2019-02-22 18:57 ` [bug#34615] " Tobias Geerinckx-Rice 2019-02-23 9:06 ` swedebugia @ 2019-02-24 7:50 ` Efraim Flashner 1 sibling, 0 replies; 9+ messages in thread From: Efraim Flashner @ 2019-02-24 7:50 UTC (permalink / raw) To: Tobias Geerinckx-Rice; +Cc: 34615 [-- Attachment #1: Type: text/plain, Size: 2197 bytes --] On Fri, Feb 22, 2019 at 07:57:25PM +0100, Tobias Geerinckx-Rice wrote: > Efraim, > > Thanks! > > Efraim Flashner wrote: > > * gnu/packages/algebra.scm (libtommath): New variable. > > > + (add-after 'unpack 'prepare-build > > + (lambda _ > > + ;; Don't pull in coreutils. > > + (substitute* "makefile_include.mk" > > + (("arch") "uname -m")) > > I'd add an empty line here or separate this into two fases just to be very > clear, since… > Sounds good. I didn't want to toss in a couple of one-liner phases, so I'll make it clearer. > > + (delete-file "makefile") > > + (symlink "makefile.shared" "makefile") > > + #t)) > > …I got a bit lost between all these makefiles. Could you explain exactly > what's going on? > > Is this to avoid repeating ‘-f makefile.shared’ elsewhere? Yeah, basically. Pkgsrc has a keyword to use makefile.shared and Debian passes '-f makefile.shared' in all its phases, this seemed much eaiser. > > > + (add-after 'check 'make-static > > More accurate: 'install-static-library. Sounds good > > While libtommath.a is ‘only’ 332K, that's almost half of the entire output > size. Is it worth moving to a separate :static output? > As far as size goes I decided against it since it is so small, but by putting libtommath.a in a separate output it does prevent other packages from picking up the wrong one. Sounds good. > > + (synopsis "portable number theoretic multiple-precision integer > > library") > > s/p/P/ > > multiprecision.scm is a better fit and already has sister package > tomsfastmath to keep this one company. I didn't see that one. I'll stick it next to that one. > > > +integer library written entirely in C. The library is designed to > > provide a > > s/The library is/It's/ IMO. > > > +simple to work with API > > ‘simple-to-work-with API’, unfortunately. > > Kind regards, > > T G-R Thanks -- 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: 833 bytes --] ^ permalink raw reply [flat|nested] 9+ messages in thread
end of thread, other threads:[~2019-02-24 8:53 UTC | newest] Thread overview: 9+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2019-02-22 12:20 [bug#34615] [PATCH] gnu: Add libtommath Efraim Flashner 2019-02-22 12:27 ` Efraim Flashner 2019-02-22 22:30 ` Tobias Geerinckx-Rice 2019-02-24 7:45 ` Efraim Flashner 2019-02-24 8:52 ` bug#34615: " Efraim Flashner 2019-02-22 18:57 ` [bug#34615] " Tobias Geerinckx-Rice 2019-02-23 9:06 ` swedebugia 2019-02-24 7:47 ` Efraim Flashner 2019-02-24 7:50 ` Efraim Flashner
Code repositories for project(s) associated with this external index https://git.savannah.gnu.org/cgit/guix.git This is an external index of several public inboxes, see mirroring instructions on how to clone and mirror all data and code used by this external index.