aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--gnu/packages/plotutils.scm120
1 files changed, 69 insertions, 51 deletions
diff --git a/gnu/packages/plotutils.scm b/gnu/packages/plotutils.scm
index ecee057913..3ac07cde54 100644
--- a/gnu/packages/plotutils.scm
+++ b/gnu/packages/plotutils.scm
@@ -1,7 +1,7 @@
;;; GNU Guix --- Functional package management for GNU
;;; Copyright © 2013, 2014, 2015, 2016, 2017, 2018, 2019, 2020, 2021 Ludovic Courtès <ludo@gnu.org>
;;; Copyright © 2015 Eric Bavier <bavier@member.fsf.org>
-;;; Copyright © 2016, 2017, 2019, 2020, 2021 Nicolas Goaziou <mail@nicolasgoaziou.fr>
+;;; Copyright © 2016–2022 Nicolas Goaziou <mail@nicolasgoaziou.fr>
;;; Copyright © 2018 Tobias Geerinckx-Rice <me@tobias.gr>
;;; Copyright © 2020 Maxim Cournoyer <maxim.cournoyer@gmail.com>
;;;
@@ -31,6 +31,7 @@
#:use-module (gnu packages algebra)
#:use-module (gnu packages autotools)
#:use-module (gnu packages bdw-gc)
+ #:use-module (gnu packages boost)
#:use-module (gnu packages emacs)
#:use-module (gnu packages xorg)
#:use-module (gnu packages image)
@@ -39,6 +40,7 @@
#:use-module (gnu packages gl)
#:use-module (gnu packages gtk)
#:use-module (gnu packages maths)
+ #:use-module (gnu packages onc-rpc)
#:use-module (gnu packages perl)
#:use-module (gnu packages pkg-config)
#:use-module (gnu packages python)
@@ -47,6 +49,7 @@
#:use-module (gnu packages qt)
#:use-module (gnu packages texinfo)
#:use-module (gnu packages tex)
+ #:use-module (gnu packages web)
#:use-module (gnu packages compression)
#:use-module (gnu packages))
@@ -265,41 +268,47 @@ colors, styles, options and details.")
(define-public asymptote
(package
(name "asymptote")
- (version "2.70")
+ (version "2.74")
(source
(origin
(method url-fetch)
(uri (string-append "mirror://sourceforge/asymptote/"
version "/asymptote-" version ".src.tgz"))
(sha256
- (base32 "0gqcm0m916kjzyfswlplhyyvmqhg9hsishmbg4pyjcwchlx93k7m"))))
+ (base32 "1fmkxgxaxgngbc079sdrba00rdkq7v076pl43zd03br9j1d8m3nl"))))
(build-system gnu-build-system)
;; Note: The 'asy' binary retains a reference to docdir for use with its
;; "help" command in interactive mode, so adding a "doc" output is not
;; currently useful.
(native-inputs
- `(("emacs" ,emacs-minimal)
- ("gs" ,ghostscript) ;For tests
- ("perl" ,perl)
- ("texinfo" ,texinfo) ;For generating documentation
- ;; For the manual and the tests.
- ("texlive" ,(texlive-updmap.cfg
- (list texlive-amsfonts
- texlive-dvips-l3backend
- texlive-epsf
- texlive-etoolbox
- texlive-fonts-ec
- texlive-generic-infwarerr
- texlive-generic-kvdefinekeys
- texlive-grfext
- texlive-latex-base
- texlive-latex-geometry
- texlive-latex-graphics
- texlive-latex-kvoptions
- texlive-latex-pdftexcmds
- texlive-oberdiek ;for ifluatex
- texlive-latex-parskip
- texlive-tex-texinfo)))))
+ (list autoconf
+ automake
+ boost
+ emacs-minimal
+ ghostscript ;for tests
+ perl
+ rapidjson
+ texinfo ;for generating documentation
+ (texlive-updmap.cfg
+ (list texlive-amsfonts
+ texlive-dvips-l3backend
+ texlive-epsf
+ texlive-etoolbox
+ texlive-fonts-ec
+ texlive-generic-infwarerr
+ texlive-generic-kvdefinekeys
+ texlive-grfext
+ texlive-hyperref
+ texlive-latex-base
+ texlive-latex-geometry
+ texlive-latex-graphics
+ texlive-latex-kvoptions
+ texlive-latex-media9
+ texlive-latex-ocgx2
+ texlive-latex-pdftexcmds
+ texlive-oberdiek ;for ifluatex
+ texlive-latex-parskip
+ texlive-tex-texinfo))))
(inputs
(list fftw
freeglut
@@ -307,6 +316,7 @@ colors, styles, options and details.")
glm
gsl
libgc
+ libtirpc
python
python-cson
python-numpy
@@ -314,29 +324,42 @@ colors, styles, options and details.")
readline
zlib))
(arguments
- `(#:modules ((guix build emacs-utils)
+ (list
+ #:modules '((guix build emacs-utils)
(guix build gnu-build-system)
(guix build utils)
(srfi srfi-26))
- #:imported-modules (,@%gnu-build-system-modules
+ #:imported-modules `(,@%gnu-build-system-modules
(guix build emacs-utils))
- #:configure-flags
- (list (string-append "--enable-gc=" (assoc-ref %build-inputs "libgc"))
- (string-append "--with-latex="
- (assoc-ref %outputs "out")
- "/share/texmf/tex/latex")
- (string-append "--with-context="
- (assoc-ref %outputs "out")
- "/share/texmf/tex/context/third"))
- #:phases
- (modify-phases %standard-phases
- (add-after 'unpack 'fix-build
- ;; XXX: Build process complains about missing "config.h"
- ;; and "primitives.h" files.
+ #:configure-flags
+ #~(list (string-append "--enable-gc=" #$(this-package-input "libgc"))
+ (string-append "--with-latex=" #$output "/share/texmf/tex/latex")
+ (string-append "--with-context="
+ #$output
+ "/share/texmf/tex/context/third"))
+ #:phases
+ `(modify-phases %standard-phases
+ (add-after 'unpack 'locate-tirpc
+ (lambda* (#:key inputs #:allow-other-keys)
+ (substitute* (list "configure.ac")
+ (("/usr/include/tirpc")
+ (search-input-directory inputs "include/tirpc")))))
+ (add-after 'unpack 'fix-includes
(lambda _
(substitute* (find-files "." "\\.in$")
(("#include <primitives.h>") "#include \"primitives.h\""))
- (invoke "touch" "prc/config.h")))
+ (substitute* (find-files "prc" "\\.h$")
+ (("#include \"config.h\"") "#include \"../config.h\""))
+ (substitute* "prc/oPRCFile.h"
+ (("#include \"xstream.h\"") "#include \"../xstream.h\""))
+ (substitute* "v3dfile.h"
+ (("#include <prc/oPRCFile.h>") "#include \"prc/oPRCFile.h\""))
+ (substitute* "LspCpp/LibLsp/lsp/ParentProcessWatcher.cpp"
+ (("#include <boost/process.hpp>" all)
+ (string-append "#include <algorithm>\n" all)))))
+ (replace 'bootstrap
+ (lambda _
+ (invoke "autoreconf" "-vfi")))
(add-after 'unpack 'move-info-location
;; Build process installs info file in the unusual
;; "%out/share/info/asymptote/" location. Move it to
@@ -345,21 +368,18 @@ colors, styles, options and details.")
(substitute* "doc/png/Makefile.in"
(("(\\$\\(infodir\\))/asymptote" _ infodir) infodir))
(substitute* "doc/asymptote.texi"
- (("asymptote/asymptote") "asymptote"))
- #t))
+ (("asymptote/asymptote") "asymptote"))))
(add-before 'build 'patch-pdf-viewer
(lambda _
;; Default to a free pdf viewer.
(substitute* "settings.cc"
(("defaultPDFViewer=\"acroread\"")
- "defaultPDFViewer=\"gv\""))
- #t))
+ "defaultPDFViewer=\"gv\""))))
(add-before 'check 'set-HOME
;; Some tests require write access to $HOME, otherwise leading to
;; "failed to create directory /homeless-shelter/.asy" error.
(lambda _
- (setenv "HOME" "/tmp")
- #t))
+ (setenv "HOME" "/tmp")))
(add-after 'install 'install-Emacs-data
(lambda* (#:key outputs #:allow-other-keys)
;; Install related Emacs libraries into an appropriate location.
@@ -367,16 +387,14 @@ colors, styles, options and details.")
(lisp-dir (string-append out "/share/emacs/site-lisp")))
(for-each (cut install-file <> lisp-dir)
(find-files "." "\\.el$"))
- (emacs-generate-autoloads ,name lisp-dir))
- #t))
+ (emacs-generate-autoloads ,name lisp-dir))))
(add-after 'install-Emacs-data 'wrap-python-script
(lambda* (#:key inputs outputs #:allow-other-keys)
;; Make sure 'xasy' runs with the correct PYTHONPATH.
(let* ((out (assoc-ref outputs "out"))
(path (getenv "GUIX_PYTHONPATH")))
(wrap-program (string-append out "/share/asymptote/GUI/xasy.py")
- `("GUIX_PYTHONPATH" ":" prefix (,path))))
- #t)))))
+ `("GUIX_PYTHONPATH" ":" prefix (,path)))))))))
(home-page "http://asymptote.sourceforge.net")
(synopsis "Script-based vector graphics language")
(description