unofficial mirror of help-guix@gnu.org 
 help / color / mirror / Atom feed
* Changing the prefix for this libpg_query package
@ 2024-02-20 19:46 Marc Coquand
  2024-02-25 14:04 ` Tomas Volf
  2024-02-25 17:51 ` Felix Lechner via
  0 siblings, 2 replies; 4+ messages in thread
From: Marc Coquand @ 2024-02-20 19:46 UTC (permalink / raw)
  To: help-guix; +Cc: Marc Coquand

Hey everyone!

I am new to Guix, guile, make and trying to create a package. 

I have a functioning patch, attached, but it is not writing to the correct 
location. 

Currently, it is writing to out/usr/local/, which makes sense, because I can 
see in the makefile for libpg_query the following on line 311 of its makefile:

prefix = /usr/local
libdir = $(prefix)/lib
includedir = $(prefix)/include 

I know I need to change the prefix to be the guix out directory, but I 
am not sure how I can substitute these lines. As you can see in the patch
I attached, I tried to set it as a build flag. However, this did not work. 

Any helpers on how to resolve this? :) 

Sincerely,
Marc

---
 gnu/packages/libpg_query.scm | 63 ++++++++++++++++++++++++++++++++++++
 1 file changed, 63 insertions(+)
 create mode 100644 gnu/packages/libpg_query.scm

diff --git a/gnu/packages/libpg_query.scm b/gnu/packages/libpg_query.scm
new file mode 100644
index 0000000000..353762554b
--- /dev/null
+++ b/gnu/packages/libpg_query.scm
@@ -0,0 +1,63 @@
+;;; GNU Guix --- Functional package management for GNU
+;;; Copyright © 2024 Marc Coquand <marc@mccd.space>
+;;;
+;;; This file is part of GNU Guix.
+;;;
+;;; GNU Guix is free software; you can redistribute it and/or modify it
+;;; under the terms of the GNU General Public License as published by
+;;; the Free Software Foundation; either version 3 of the License, or (at
+;;; your option) any later version.
+;;;
+;;; GNU Guix is distributed in the hope that it will be useful, but
+;;; WITHOUT ANY WARRANTY; without even the implied warranty of
+;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+;;; GNU General Public License for more details.
+;;;
+;;; You should have received a copy of the GNU General Public License
+;;; along with GNU Guix.  If not, see <http://www.gnu.org/licenses/>.
+
+(define-module (gnu packages libpg_query)
+  #:use-module (gnu packages)
+  #:use-module (gnu packages base)
+  #:use-module (gnu packages commencement)
+  #:use-module (guix packages)
+  #:use-module (guix utils)
+  #:use-module (guix download)
+  #:use-module (guix build-system gnu)
+  #:use-module ((guix licenses) #:prefix license:)
+ )
+
+(define-public libpg-query
+  (package
+    (name "libpg-query")
+    (version "16-5.1.0")
+    (source
+     (origin
+       (method url-fetch)
+       (uri (string-append
+             "https://github.com/pganalyze/libpg_query/archive/refs/tags/"
+             version ".tar.gz"))
+       (sha256
+        (base32 "1xvdcnqxrvb90kcndxmspnm07p8clnq160rbfsy6djd17mbmpwii"))))
+    (build-system gnu-build-system)
+    (arguments
+     `(#:make-flags (list "build" (string-append "prefix=" (assoc-ref %outputs "out")))
+
+       #:phases (modify-phases %standard-phases
+                  (delete 'configure)
+                  (delete 'check)
+                  (add-before 'build 'set-additional-paths
+                    (lambda* (#:key inputs #:allow-other-keys)
+                      (setenv "CC" "gcc")))
+                  (replace 'install
+                    (lambda* (#:key outputs #:allow-other-keys)
+                      (setenv "DESTDIR"
+                              (string-append (assoc-ref %outputs "out") "/"))
+                      (invoke "make" "install"))))))
+    (inputs (list tar which gcc-toolchain))
+    (home-page "https://github.com/pganalyze/libpg_query")
+    (synopsis
+     "C library for accessing the PostgreSQL parser outside of the server environment")
+    (description
+     "C library for accessing the PostgreSQL parser outside of the server.  This library uses the actual PostgreSQL server source to parse SQL queries and return the internal PostgreSQL parse tree.")
+    (license license:bsd-3)))

base-commit: fdbf4192f5eaa7fdb5e6e2e98ada0726c8104824
-- 
2.43.2



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

* Re: Changing the prefix for this libpg_query package
  2024-02-20 19:46 Changing the prefix for this libpg_query package Marc Coquand
@ 2024-02-25 14:04 ` Tomas Volf
  2024-02-25 17:51 ` Felix Lechner via
  1 sibling, 0 replies; 4+ messages in thread
From: Tomas Volf @ 2024-02-25 14:04 UTC (permalink / raw)
  To: Marc Coquand; +Cc: help-guix

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

On 2024-02-20 13:46:24 -0600, Marc Coquand wrote:
> Hey everyone!
>
> I am new to Guix, guile, make and trying to create a package.
>
> I have a functioning patch, attached, but it is not writing to the correct
> location.
>
> Currently, it is writing to out/usr/local/, which makes sense, because I can
> see in the makefile for libpg_query the following on line 311 of its makefile:
>
> prefix = /usr/local
> libdir = $(prefix)/lib
> includedir = $(prefix)/include
>
> I know I need to change the prefix to be the guix out directory, but I
> am not sure how I can substitute these lines. As you can see in the patch
> I attached, I tried to set it as a build flag. However, this did not work.
>
> Any helpers on how to resolve this? :)
>
> Sincerely,
> Marc
>
> ---
>  gnu/packages/libpg_query.scm | 63 ++++++++++++++++++++++++++++++++++++
>  1 file changed, 63 insertions(+)
>  create mode 100644 gnu/packages/libpg_query.scm
>
> diff --git a/gnu/packages/libpg_query.scm b/gnu/packages/libpg_query.scm
> new file mode 100644
> index 0000000000..353762554b
> --- /dev/null
> +++ b/gnu/packages/libpg_query.scm
> @@ -0,0 +1,63 @@
> +;;; GNU Guix --- Functional package management for GNU
> +;;; Copyright © 2024 Marc Coquand <marc@mccd.space>
> +;;;
> +;;; This file is part of GNU Guix.
> +;;;
> +;;; GNU Guix is free software; you can redistribute it and/or modify it
> +;;; under the terms of the GNU General Public License as published by
> +;;; the Free Software Foundation; either version 3 of the License, or (at
> +;;; your option) any later version.
> +;;;
> +;;; GNU Guix is distributed in the hope that it will be useful, but
> +;;; WITHOUT ANY WARRANTY; without even the implied warranty of
> +;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
> +;;; GNU General Public License for more details.
> +;;;
> +;;; You should have received a copy of the GNU General Public License
> +;;; along with GNU Guix.  If not, see <http://www.gnu.org/licenses/>.
> +
> +(define-module (gnu packages libpg_query)
> +  #:use-module (gnu packages)
> +  #:use-module (gnu packages base)
> +  #:use-module (gnu packages commencement)
> +  #:use-module (guix packages)
> +  #:use-module (guix utils)
> +  #:use-module (guix download)
> +  #:use-module (guix build-system gnu)
> +  #:use-module ((guix licenses) #:prefix license:)
> + )
> +
> +(define-public libpg-query
> +  (package
> +    (name "libpg-query")
> +    (version "16-5.1.0")
> +    (source
> +     (origin
> +       (method url-fetch)
> +       (uri (string-append
> +             "https://github.com/pganalyze/libpg_query/archive/refs/tags/"
> +             version ".tar.gz"))
> +       (sha256
> +        (base32 "1xvdcnqxrvb90kcndxmspnm07p8clnq160rbfsy6djd17mbmpwii"))))
> +    (build-system gnu-build-system)
> +    (arguments
> +     `(#:make-flags (list "build" (string-append "prefix=" (assoc-ref %outputs "out")))
> +
> +       #:phases (modify-phases %standard-phases
> +                  (delete 'configure)
> +                  (delete 'check)
> +                  (add-before 'build 'set-additional-paths
> +                    (lambda* (#:key inputs #:allow-other-keys)
> +                      (setenv "CC" "gcc")))
> +                  (replace 'install
> +                    (lambda* (#:key outputs #:allow-other-keys)
> +                      (setenv "DESTDIR"
> +                              (string-append (assoc-ref %outputs "out") "/"))
> +                      (invoke "make" "install"))))))

So, I am just guessing here, but maybe you need to use the prefix=... also in
here?  Since you are directly invoking make install, I would expect the
#:make-flags to not be in effect here.  The 'install phase in gnu-build-system
you are replacing looks like this:

    (define* (install #:key (make-flags '()) #:allow-other-keys)
      (apply invoke "make" "install" make-flags))

> +    (inputs (list tar which gcc-toolchain))
> +    (home-page "https://github.com/pganalyze/libpg_query")
> +    (synopsis
> +     "C library for accessing the PostgreSQL parser outside of the server environment")
> +    (description
> +     "C library for accessing the PostgreSQL parser outside of the server.  This library uses the actual PostgreSQL server source to parse SQL queries and return the internal PostgreSQL parse tree.")
> +    (license license:bsd-3)))
>
> base-commit: fdbf4192f5eaa7fdb5e6e2e98ada0726c8104824
> --
> 2.43.2
>
>

Have a nice day,
Tomas Volf

--
There are only two hard things in Computer Science:
cache invalidation, naming things and off-by-one errors.

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

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

* Re: Changing the prefix for this libpg_query package
  2024-02-20 19:46 Changing the prefix for this libpg_query package Marc Coquand
  2024-02-25 14:04 ` Tomas Volf
@ 2024-02-25 17:51 ` Felix Lechner via
  2024-02-25 20:03   ` Marc Coquand
  1 sibling, 1 reply; 4+ messages in thread
From: Felix Lechner via @ 2024-02-25 17:51 UTC (permalink / raw)
  To: Marc Coquand, help-guix

Hi Marc,

On Tue, Feb 20 2024, Marc Coquand wrote:

> I need to change the prefix to be the guix out directory

To override the variable assigned in the Makefile [1] you are right to
offer it as an argument to 'make'. [2] I'm not sure why that's not
working. I would just replace it in situ:

    #:phases (modify-phases %standard-phases
              (add-after 'unpack 'fix-prefix
               (lambda _
                (substitute* "Makefile"
                 (("/usr/local") $output)))))

Kind regards
Felix

[1] https://github.com/pganalyze/libpg_query/blob/1ec38940e5c6f09a4c1d17a46d839a881c4f2db7/Makefile#L311
[2] https://www.gnu.org/software/make/manual/make.html#Overriding


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

* Re: Changing the prefix for this libpg_query package
  2024-02-25 17:51 ` Felix Lechner via
@ 2024-02-25 20:03   ` Marc Coquand
  0 siblings, 0 replies; 4+ messages in thread
From: Marc Coquand @ 2024-02-25 20:03 UTC (permalink / raw)
  To: Felix Lechner, help-guix

Hey everyone! 

Thanks for your support. This was my first post to support, so it was stuck
in review for a while. I was able to resolve it using the same substitute 
function Felix shared.

So now my patch is up for review:

https://issues.guix.gnu.org/69309

Thanks everyone for your help.

Sincerely,
Marc

On Sun Feb 25, 2024 at 11:51 AM CST, Felix Lechner wrote:
> Hi Marc,
>
> On Tue, Feb 20 2024, Marc Coquand wrote:
>
> > I need to change the prefix to be the guix out directory
>
> To override the variable assigned in the Makefile [1] you are right to
> offer it as an argument to 'make'. [2] I'm not sure why that's not
> working. I would just replace it in situ:
>
>     #:phases (modify-phases %standard-phases
>               (add-after 'unpack 'fix-prefix
>                (lambda _
>                 (substitute* "Makefile"
>                  (("/usr/local") $output)))))
>
> Kind regards
> Felix
>
> [1] https://github.com/pganalyze/libpg_query/blob/1ec38940e5c6f09a4c1d17a46d839a881c4f2db7/Makefile#L311
> [2] https://www.gnu.org/software/make/manual/make.html#Overriding



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

end of thread, other threads:[~2024-02-25 20:04 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2024-02-20 19:46 Changing the prefix for this libpg_query package Marc Coquand
2024-02-25 14:04 ` Tomas Volf
2024-02-25 17:51 ` Felix Lechner via
2024-02-25 20:03   ` Marc Coquand

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