unofficial mirror of guix-patches@gnu.org 
 help / color / mirror / code / Atom feed
* [bug#59281] [PATCH] gnu: Add python-dm-tree.
@ 2022-11-15  8:38 Nicolas Graves via Guix-patches via
  2022-11-15 20:03 ` Nicolas Graves via Guix-patches via
  0 siblings, 1 reply; 3+ messages in thread
From: Nicolas Graves via Guix-patches via @ 2022-11-15  8:38 UTC (permalink / raw)
  To: 59281; +Cc: ngraves

* gnu/packages/python-xyz.scm (python-dm-tree): New variable.
---
 gnu/packages/python-xyz.scm | 65 +++++++++++++++++++++++++++++++++++++
 1 file changed, 65 insertions(+)

diff --git a/gnu/packages/python-xyz.scm b/gnu/packages/python-xyz.scm
index 7e10682e69..7e66a69273 100644
--- a/gnu/packages/python-xyz.scm
+++ b/gnu/packages/python-xyz.scm
@@ -131,6 +131,7 @@
 ;;; Copyright © 2022 Mathieu Laparie <mlaparie@disr.it>
 ;;; Copyright © 2022 Garek Dyszel <garekdyszel@disroot.org>
 ;;; Copyright © 2022 Baptiste Strazzulla <bstrazzull@hotmail.fr>
+;;; Copyright © 2022 Nicolas Graves <ngraves@ngraves.fr>
 ;;;
 ;;; This file is part of GNU Guix.
 ;;;
@@ -159,6 +160,7 @@ (define-module (gnu packages python-xyz)
   #:use-module (gnu packages check)
   #:use-module (gnu packages cmake)
   #:use-module (gnu packages compression)
+  #:use-module (gnu packages cpp)
   #:use-module (gnu packages crypto)
   #:use-module (gnu packages databases)
   #:use-module (gnu packages dbm)
@@ -4631,6 +4633,69 @@ (define-public autokey
 flexibility and power of the Python language.")
     (license license:gpl3+)))
 
+(define-public python-dm-tree
+  (package
+    (name "python-dm-tree")
+    (version "0.1.7")
+    (source
+     (origin
+       (method url-fetch)
+       (uri (pypi-uri "dm-tree" version))
+       (sha256
+        (base32 "0apxfxgmqh22qpk92zmmf3acqkavhwxz78lnwz026a5rlnncizih"))))
+    (build-system python-build-system)
+    (native-inputs (list python-wheel
+                         python-absl-py
+                         python-attrs
+                         python-numpy
+                         python-wrapt))
+    (inputs (list pybind11 abseil-cpp))
+    (arguments
+     (list
+      #:tests? #f
+      #:phases
+      #~(modify-phases %standard-phases
+          (add-before 'build 'build-shared-lib
+            (lambda _
+              ;; Delete default cmake build.
+              (substitute* "setup.py"
+                (("ext_modules.*") "")
+                (("cmdclass.*") ""))
+              ;; Actual build phase.
+              (mkdir-p "build/temp.linux-x86_64-3.9/tree/")
+              (invoke
+               "gcc" "-pthread" "-Wno-unused-result" "-Wsign-compare"
+               "-DNDEBUG" "-g" "-fwrapv" "-O3" "-Wall"
+               "-fno-semantic-interposition" "-fPIC"
+               "-I" #$(file-append
+                       pybind11 "/lib/python3.9/site-packages/pybind11/include")
+               "-I" #$(file-append python "/include/python3.9")
+               "-I" #$(file-append abseil-cpp "/include")
+               "-c" "tree/tree.cc"
+               "-o" "build/temp.linux-x86_64-3.9/tree/tree.o"
+               "-fvisibility=hidden" "-g0")
+              (mkdir-p "build/lib/tree")
+              (invoke
+               "g++" "-pthread" "-shared"
+               (string-append "-Wl," "-rpath=" #$python "/lib")
+               "-fno-semantic-interposition"
+               "build/temp.linux-x86_64-3.9/tree/tree.o"
+               "-L" #$(file-append python "/lib")
+               "-L" #$(file-append abseil-cpp "/lib")
+               "-l" "absl_int128"
+               "-l" "absl_raw_hash_set"
+               "-l" "absl_raw_logging_internal"
+               "-l" "absl_strings"
+               "-l" "absl_throw_delegate"
+               "-o" "build/lib/tree/_tree.so"))))))
+    (home-page "https://github.com/deepmind/tree")
+    (synopsis "Work with nested data structures in python.")
+    (description "Tree is a python library for working with nested
+data structures. In a way, @code{tree} generalizes the builtin map
+function which only supports flat sequences, and allows to apply a
+function to each leaf preserving the overall structure.")
+    (license license:asl2.0)))
+
 (define-public python-docutils
   (package
     (name "python-docutils")
-- 
2.38.1





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

* [bug#59281] [PATCH] gnu: Add python-dm-tree.
  2022-11-15  8:38 [bug#59281] [PATCH] gnu: Add python-dm-tree Nicolas Graves via Guix-patches via
@ 2022-11-15 20:03 ` Nicolas Graves via Guix-patches via
  2022-11-28 22:29   ` bug#59281: " Ludovic Courtès
  0 siblings, 1 reply; 3+ messages in thread
From: Nicolas Graves via Guix-patches via @ 2022-11-15 20:03 UTC (permalink / raw)
  To: 59281; +Cc: ngraves

* gnu/packages/python-xyz.scm (python-dm-tree): New variable.
---
 gnu/packages/python-xyz.scm | 68 +++++++++++++++++++++++++++++++++++++
 1 file changed, 68 insertions(+)

diff --git a/gnu/packages/python-xyz.scm b/gnu/packages/python-xyz.scm
index 1758450c2f..fafacc4d94 100644
--- a/gnu/packages/python-xyz.scm
+++ b/gnu/packages/python-xyz.scm
@@ -131,6 +131,7 @@
 ;;; Copyright © 2022 Mathieu Laparie <mlaparie@disr.it>
 ;;; Copyright © 2022 Garek Dyszel <garekdyszel@disroot.org>
 ;;; Copyright © 2022 Baptiste Strazzulla <bstrazzull@hotmail.fr>
+;;; Copyright © 2022 Nicolas Graves <ngraves@ngraves.fr>
 ;;;
 ;;; This file is part of GNU Guix.
 ;;;
@@ -159,6 +160,7 @@ (define-module (gnu packages python-xyz)
   #:use-module (gnu packages check)
   #:use-module (gnu packages cmake)
   #:use-module (gnu packages compression)
+  #:use-module (gnu packages cpp)
   #:use-module (gnu packages crypto)
   #:use-module (gnu packages databases)
   #:use-module (gnu packages dbm)
@@ -4618,6 +4620,72 @@ (define-public autokey
 flexibility and power of the Python language.")
     (license license:gpl3+)))
 
+(define-public python-dm-tree
+  (package
+    (name "python-dm-tree")
+    (version "0.1.7")
+    (source
+     (origin
+       (method url-fetch)
+       (uri (pypi-uri "dm-tree" version))
+       (sha256
+        (base32 "0apxfxgmqh22qpk92zmmf3acqkavhwxz78lnwz026a5rlnncizih"))))
+    (build-system python-build-system)
+    (inputs (list pybind11 abseil-cpp python))
+    (propagated-inputs (list python-wheel
+                         python-absl-py
+                         python-attrs
+                         python-numpy
+                         python-wrapt))
+    (arguments
+     (list
+      #:tests? #f
+      #:phases
+      #~(modify-phases %standard-phases
+          (add-before 'build 'build-shared-lib
+            (lambda _
+              (let* ((pybind11   #$(this-package-input "pybind11"))
+                     (python     #$(this-package-input "python"))
+                     (abseil-cpp #$(this-package-input "abseil-cpp")))
+                ;; Delete default cmake build.
+                (substitute* "setup.py"
+                  (("ext_modules.*") "")
+                  (("cmdclass.*") ""))
+                ;; Actual build phase.
+                (mkdir-p "build/temp/tree/")
+                (invoke
+                 "gcc" "-pthread" "-Wno-unused-result" "-Wsign-compare"
+                 "-DNDEBUG" "-g" "-fwrapv" "-O3" "-Wall"
+                 "-fno-semantic-interposition" "-fPIC"
+                 "-I" (string-append
+                       pybind11 "/lib/python3.9/site-packages/pybind11/include")
+                 "-I" (string-append python "/include/python3.9")
+                 "-I" (string-append abseil-cpp "/include")
+                 "-c" "tree/tree.cc"
+                 "-o" "build/temp/tree/tree.o"
+                 "-fvisibility=hidden" "-g0")
+                (mkdir-p "build/lib/tree")
+                (invoke
+                 "g++" "-pthread" "-shared"
+                 (string-append "-Wl," "-rpath=" python "/lib")
+                 "-fno-semantic-interposition"
+                 "build/temp/tree/tree.o"
+                 "-L" (string-append python "/lib")
+                 "-L" (string-append abseil-cpp "/lib")
+                 "-l" "absl_int128"
+                 "-l" "absl_raw_hash_set"
+                 "-l" "absl_raw_logging_internal"
+                 "-l" "absl_strings"
+                 "-l" "absl_throw_delegate"
+                 "-o" "build/lib/tree/_tree.so")))))))
+    (home-page "https://github.com/deepmind/tree")
+    (synopsis "Work with nested data structures in python.")
+    (description "Tree is a python library for working with nested
+data structures. In a way, @code{tree} generalizes the builtin map
+function which only supports flat sequences, and allows to apply a
+function to each leaf preserving the overall structure.")
+    (license license:asl2.0)))
+
 (define-public python-docutils
   (package
     (name "python-docutils")
-- 
2.38.1





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

* bug#59281: [PATCH] gnu: Add python-dm-tree.
  2022-11-15 20:03 ` Nicolas Graves via Guix-patches via
@ 2022-11-28 22:29   ` Ludovic Courtès
  0 siblings, 0 replies; 3+ messages in thread
From: Ludovic Courtès @ 2022-11-28 22:29 UTC (permalink / raw)
  To: Nicolas Graves; +Cc: 59281-done

Hi,

Nicolas Graves <ngraves@ngraves.fr> skribis:

> * gnu/packages/python-xyz.scm (python-dm-tree): New variable.

Applied with cosmetic changes, primarily to remove the hardcoded “3.9”
Python version number.

Thanks,
Ludo’.




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

end of thread, other threads:[~2022-11-28 22:31 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2022-11-15  8:38 [bug#59281] [PATCH] gnu: Add python-dm-tree Nicolas Graves via Guix-patches via
2022-11-15 20:03 ` Nicolas Graves via Guix-patches via
2022-11-28 22:29   ` bug#59281: " Ludovic Courtès

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