unofficial mirror of guix-patches@gnu.org 
 help / color / mirror / code / Atom feed
From: Ekaitz Zarraga <ekaitz@elenq.tech>
To: "iyzsong@member.fsf.org" <iyzsong@member.fsf.org>
Cc: "41294\\@debbugs.gnu.org" <41294@debbugs.gnu.org>
Subject: [bug#41294] [PATCH] gnu: Add libfreenect.
Date: Tue, 19 May 2020 13:52:15 +0000	[thread overview]
Message-ID: <9ZfB8rv2oVS3f1P4KqZV9twP9VRoO9GNuPvbzT_BjLAzXCs6kumdqaIPD_TMejSv5B0D34dg6tpbmKPmIQxuLW64pU35VX5LGNn5tM9Ka04=@elenq.tech> (raw)
In-Reply-To: <dwdu0IFP-FBpKY7y534ks2EfI-mzljVFIhzsFddw0aV0LiBC-4QVKl_rkYuoqO1vzW9-MlAE_IbnvdgGtlieqn1nyJNFuwPnlL3asTzvgts=@elenq.tech>

‐‐‐‐‐‐‐ Original Message ‐‐‐‐‐‐‐
On Tuesday, May 19, 2020 3:42 PM, Ekaitz Zarraga <ekaitz@elenq.tech> wrote:

> Hi,
>
> > > There's some kind of weird magic I'm not getting.
> >
> > Hello, I don't know the whole detail too, but to build a package, guix likely:
> >
> > -   Load and eval the package module, to get the package object. The
> >     'arguments' field is a list.
> >
> > -   Convert this package object to a derivation, and write it in store as
> >     a file (/gnu/store/*.drv). Where 'arguments' being part of the
> >     builder, serialize as string to the file, it dosen't do complex things
> >     for procedure bindings, only write their string descriptions... So
> >     when the builder file is loaded, you get `Unknown object` errors.
> >     Here, to avoid duplicating the code, you can:
> >
> >
> > 1.  Unquote list value into `arguments`. (eg: 'asdf-substitutions' in lisp.scm)
>
> This doesn't work for me. I don't know why.
>
> Just moved the lambda to a (define* deactivate-sources ...) and then when I try to put the name like
>
> (arguments `( #tests? .... ,deactivate-sources ...)
>
> Shoots an Unknown object error. I add a diff below to let you see the whole picture of what I did and doesn't work.
>
> > 2.  Use `(package-arguments libfreenect-examples)` with
> >     `substitute-keyword-arguments` to reuse arguments, but modify
> >     `configure-flags` etc. (eg: qtx11extras)
> >     The build system can use 'imported-modules' to make a set of guile
> >     modules (which can contains useful procedures, etc.) available to the
> >     builder, but thas's overkill to be used here...
> >
>
> I'll check that option too.
>
> Thank you for your help!
>
> diff --git a/gnu/local.mk b/gnu/local.mk
> index ab2bac9bc5..b9c09cc5e3 100644
> --- a/gnu/local.mk
> +++ b/gnu/local.mk
> @@ -394,6 +394,7 @@ GNU_SYSTEM_MODULES = \
> %D%/packages/nvi.scm \
> %D%/packages/ocaml.scm \
> %D%/packages/ocr.scm \
>
> -   %D%/packages/openkinect.scm \
>     %D%/packages/onc-rpc.scm \
>     %D%/packages/opencl.scm \
>     %D%/packages/openbox.scm \
>     diff --git a/gnu/packages/openkinect.scm b/gnu/packages/openkinect.scm
>     new file mode 100644
>     index 0000000000..5a17acef0e
>     --- /dev/null
>     +++ b/gnu/packages/openkinect.scm
>     @@ -0,0 +1,127 @@
>     +(define-module (gnu packages openkinect)
>
> -   #:use-module (guix packages)
> -   #:use-module (guix git-download)
> -   #:use-module (guix build-system cmake)
> -   #:use-module ((guix licenses) #:prefix license:)
> -   #:use-module (gnu packages pkg-config)
> -   #:use-module (gnu packages libusb)
> -   #:use-module (gnu packages python)
> -   #:use-module (gnu packages python-xyz)
> -   #:use-module (gnu packages gl)
> -   #:use-module (gnu packages pkg-config)
> -   #:use-module (gnu packages image-processing))
> -
>
> +(define-public libfreenect
>
> -   (let ((version "0.6.1"))
> -   (package
> -        (name "libfreenect")
>
>
> -        (version version)
>
>
> -        (source (origin
>
>
> -                  (method git-fetch)
>
>
> -                  (uri (git-reference
>
>
> -                        (url "https://github.com/OpenKinect/libfreenect")
>
>
> -                        (commit (string-append "v" version))))
>
>
> -                  (sha256
>
>
> -                   (base32 "0was1va167rqshmpn382h36yyprpfi9cwillb6ylppmnfdrfrhrr"))))
>
>
> -        (build-system cmake-build-system)
>
>
> -        (arguments
>
>
> -         '(#:tests? #f ; Project has not tests
>
>
> -           #:configure-flags
>
>
> -           '("-DBUILD_FAKENECT=ON"
>
>
> -             "-DBUILD_CPP=ON"
>
>
> -             "-DBUILD_EXAMPLES=OFF" ; Available in libfreenect-examples
>
>
> -             "-DBUILD_CV=OFF"       ; Available in libfreenect-cv
>
>
> -             "-DBUILD_PYTHON=OFF"   ; Available in libfreenect-python
>
>
> -             "-DBUILD_C_SYNC=ON")
>
>
> -           #:phases
>
>
> -           (modify-phases %standard-phases
>
>
> -             (add-after 'install 'install-udev-rules
>
>
> -               (lambda* (#:key outputs #:allow-other-keys)
>
>
> -                 (let* ((out (assoc-ref outputs "out"))
>
>
> -                        (rules-out (string-append out "/lib/udev/rules.d")))
>
>
> -                   (install-file "../source/platform/linux/udev/51-kinect.rules"
>
>
> -                                 (string-append rules-out "51-kinect.rules"))
>
>
> -                   #t))))))
>
>
> -        (native-inputs
>
>
> -         `(("pkg-config" ,pkg-config)))
>
>
> -        (inputs
>
>
> -         `(("libusb" ,libusb)))
>
>
> -        (synopsis "Drivers and libraries for the Xbox Kinect device")
>
>
> -        (description "libfreenect is a userspace driver for the Microsoft Kinect.
>
>
>
> +It supports: RGB and Depth Images, Motors, Accelerometer, LED and Audio.")
>
> -        (home-page "https://openkinect.org/")
>
>
> -        (license license:gpl2+))))
>
>
> -
>
> +(define (disable-sources)
>
> -   (lambda* (#:key outputs #:allow-other-keys)
> -             (substitute* "CMakeLists.txt"
>
>
> -                          ((".*libusb.*") "")
>
>
> -                          (("add_subdirectory \\\\(src\\\\)") "")
>
>
> -                          ((".*libfreenectConfig.cmake.*") ""))))
>
>
> -
>
> +(define-public libfreenect-examples
>
> -   (package
> -   (inherit libfreenect)
> -   (name "libfreenect-examples")
> -   (inputs
> -       `(("libfreenect" ,libfreenect)
>
>
> -         ("glut" ,freeglut)))
>
>
> -   (arguments
> -       `(#:tests? #f ; Project has not tests
>
>
> -         #:configure-flags '("-DBUILD_EXAMPLES=ON"
>
>
> -                             "-DBUILD_FAKENECT=OFF"
>
>
> -                             "-DBUILD_CPP=OFF"
>
>
> -                             "-DBUILD_C_SYNC=OFF"
>
>
> -                             "-DBUILD_CV=OFF")
>
>
> -         #:phases
>
>
> -         (modify-phases %standard-phases
>
>
> -           ;; Sources are already compiled in libfreenect input
>
>
> -           (add-after 'unpack 'disable-sources ,disable-sources)))) ;; UNKNOW OBJECT!
>
>
> -   (synopsis "Examples for libfreenect, the Xbox Kinect device library")))
> -
>
> +(define-public libfreenect-cv
>
> -   (package
> -   (inherit libfreenect)
> -   (name "libfreenect-cv")
> -   (inputs
> -       `(("libfreenect" ,libfreenect)
>
>
> -         ("opencv" ,opencv)))
>
>
> -   (arguments
> -       `(#:tests? #f ; Project has not tests
>
>
> -         #:configure-flags '("-DBUILD_EXAMPLES=OFF"
>
>
> -                             "-DBUILD_FAKENECT=OFF"
>
>
> -                             "-DBUILD_CPP=OFF"
>
>
> -                             "-DBUILD_C_SYNC=OFF"
>
>
> -                             "-DBUILD_CV=ON")
>
>
> -         #:phases
>
>
> -         (modify-phases %standard-phases
>
>
> -           ;; Sources are already compiled in libfreenect input
>
>
> -           (add-after 'unpack 'disable-sources ,disable-sources))))
>
>
> -   (synopsis "OpenCV wrapper for libfreenect, the Xbox Kinect device
>     +library")))
>
> -
>
> +(define-public libfreenect-python
>
> -   (package
> -   (inherit libfreenect)
> -   (name "libfreenect-python")
> -   (native-inputs
> -       `(("python-cython" ,python-cython)))
>
>
> -   (inputs
> -       `(("libfreenect" ,libfreenect)))
>
>
> -   (propagated-inputs
> -       `(("python" ,python)
>
>
> -         ("python-numpy" ,python-numpy)))
>
>
> -   (arguments
> -       `(#:tests? #f ; Project has not tests
>
>
> -         #:configure-flags '("-DBUILD_EXAMPLES=OFF"
>
>
> -                             "-DBUILD_FAKENECT=OFF"
>
>
> -                             "-DBUILD_CPP=OFF"
>
>
> -                             "-DBUILD_C_SYNC=OFF"
>
>
> -                             "-DBUILD_CV=OFF"
>
>
> -                             "-DBUILD_PYTHON3=ON")
>
>
> -         #:phases
>
>
> -         (modify-phases %standard-phases
>
>
> -           ;; Sources are already compiled in libfreenect input
>
>
> -           (add-after 'unpack 'disable-sources ,disable-sources))))
>
>
> -   (synopsis "Python wrapper for libfreenect, the Xbox Kinect device
>     +library")))
>

oh,

the code is wrong, there parenthesis on the define are making it a function but anyway:
- Tested using ,(disable-sources) FAIL
- Tested removing the parenthesis and leaving (define disable-sources (lambda*...))

There must be something I'm missing.




  reply	other threads:[~2020-05-19 13:53 UTC|newest]

Thread overview: 17+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2020-05-15 21:47 [bug#41294] [PATCH] gnu: Add libfreenect Ekaitz Zarraga
2020-05-15 23:09 ` [bug#41294] [PATCH] gnu: libfreenect: Correct native-inputs vs inputs Ekaitz Zarraga
2020-05-16  3:48 ` [bug#41294] [PATCH] gnu: Add libfreenect 宋文武
2020-05-16 10:18   ` Ekaitz Zarraga
2020-05-16 13:06     ` Ekaitz Zarraga
2020-05-16 13:28       ` Ekaitz Zarraga
2020-05-17  2:15       ` 宋文武
2020-05-17  9:37         ` Ekaitz Zarraga
2020-05-17 12:15           ` Ekaitz Zarraga
2020-05-19 13:26             ` 宋文武
2020-05-19 13:42               ` Ekaitz Zarraga
2020-05-19 13:52                 ` Ekaitz Zarraga [this message]
2020-05-20 13:33                   ` 宋文武
2020-05-20 16:37                     ` Ekaitz Zarraga
2020-05-21 11:38                       ` bug#41294: " 宋文武
2020-05-21 11:40                         ` [bug#41294] " Ekaitz Zarraga
2020-05-17  1:56     ` 宋文武

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

  List information: https://guix.gnu.org/

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to='9ZfB8rv2oVS3f1P4KqZV9twP9VRoO9GNuPvbzT_BjLAzXCs6kumdqaIPD_TMejSv5B0D34dg6tpbmKPmIQxuLW64pU35VX5LGNn5tM9Ka04=@elenq.tech' \
    --to=ekaitz@elenq.tech \
    --cc=41294@debbugs.gnu.org \
    --cc=iyzsong@member.fsf.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
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).