[PATCH] gnu: make-nsis: Fix build

  • Done
  • quality assurance status badge
Details
2 participants
  • Carl Dong
  • Christopher Baines
Owner
unassigned
Submitted by
Carl Dong
Severity
normal
C
C
Carl Dong wrote on 24 Feb 2021 04:00
(address . guix-patches@gnu.org)(name . Carl Dong)(address . contact@carldong.me)
20210224030050.457744-1-contact@carldong.me
* gnu/packages/installers.scm (make-nsis)[arguments]: Use
C{,PLUS}_INCLUDE_PATH instead of CPATH environment variable to fix
build.
---
gnu/packages/installers.scm | 13 +++++++++++--
1 file changed, 11 insertions(+), 2 deletions(-)

Toggle diff (35 lines)
diff --git a/gnu/packages/installers.scm b/gnu/packages/installers.scm
index a8a5c36a18..e8196b27d0 100644
--- a/gnu/packages/installers.scm
+++ b/gnu/packages/installers.scm
@@ -96,9 +96,18 @@
;; CROSS_-prefixed version of env vars
(setenv (string-append "CROSS_" env-name)
(filter-delimited-string env-val mingw-path?))))
- '("CPATH" "LIBRARY_PATH"))
+ '("C_INCLUDE_PATH" "CPLUS_INCLUDE_PATH" "LIBRARY_PATH"))
;; Hack to place mingw-w64 path at the end of search
;; paths. Could probably use a specfile and dirafter
+ (setenv "CROSS_C_INCLUDE_PATH"
+ (string-join
+ `(,@(map (cut string-append (assoc-ref %build-inputs "xgcc")
+ "/lib/gcc/" ,triplet "/"
+ ,(package-version xgcc) <>)
+ '("/include"
+ "/include-fixed"))
+ ,(getenv "CROSS_C_INCLUDE_PATH"))
+ ":"))
(setenv "CROSS_CPLUS_INCLUDE_PATH"
(string-join
`(,@(map (cut string-append (assoc-ref %build-inputs "xgcc") <>)
@@ -108,7 +117,7 @@
,@(map (cut string-append "/lib/gcc/" ,triplet "/" ,(package-version xgcc) <>)
'("/include"
"/include-fixed"))))
- ,(getenv "CROSS_CPATH"))
+ ,(getenv "CROSS_CPLUS_INCLUDE_PATH"))
":"))))
(add-before 'build 'fix-target-detection
(lambda _
--
2.30.1
C
C
Christopher Baines wrote on 24 Feb 2021 09:43
(name . Carl Dong)(address . contact@carldong.me)(address . 46740@debbugs.gnu.org)
87ft1lluu4.fsf@cbaines.net
Carl Dong <contact@carldong.me> writes:

Toggle quote (41 lines)
> * gnu/packages/installers.scm (make-nsis)[arguments]: Use
> C{,PLUS}_INCLUDE_PATH instead of CPATH environment variable to fix
> build.
> ---
> gnu/packages/installers.scm | 13 +++++++++++--
> 1 file changed, 11 insertions(+), 2 deletions(-)
>
> diff --git a/gnu/packages/installers.scm b/gnu/packages/installers.scm
> index a8a5c36a18..e8196b27d0 100644
> --- a/gnu/packages/installers.scm
> +++ b/gnu/packages/installers.scm
> @@ -96,9 +96,18 @@
> ;; CROSS_-prefixed version of env vars
> (setenv (string-append "CROSS_" env-name)
> (filter-delimited-string env-val mingw-path?))))
> - '("CPATH" "LIBRARY_PATH"))
> + '("C_INCLUDE_PATH" "CPLUS_INCLUDE_PATH" "LIBRARY_PATH"))
> ;; Hack to place mingw-w64 path at the end of search
> ;; paths. Could probably use a specfile and dirafter
> + (setenv "CROSS_C_INCLUDE_PATH"
> + (string-join
> + `(,@(map (cut string-append (assoc-ref %build-inputs "xgcc")
> + "/lib/gcc/" ,triplet "/"
> + ,(package-version xgcc) <>)
> + '("/include"
> + "/include-fixed"))
> + ,(getenv "CROSS_C_INCLUDE_PATH"))
> + ":"))
> (setenv "CROSS_CPLUS_INCLUDE_PATH"
> (string-join
> `(,@(map (cut string-append (assoc-ref %build-inputs "xgcc") <>)
> @@ -108,7 +117,7 @@
> ,@(map (cut string-append "/lib/gcc/" ,triplet "/" ,(package-version xgcc) <>)
> '("/include"
> "/include-fixed"))))
> - ,(getenv "CROSS_CPATH"))
> + ,(getenv "CROSS_CPLUS_INCLUDE_PATH"))
> ":"))))
> (add-before 'build 'fix-target-detection
> (lambda _

Hey!

Looks like this does fix things which is great [1], but it also
introduces some lint warnings [2].


So, I'd remove the tabs and tweak the indentation so you're not
introducing any new long lines. But apart from that I think it's fine to
push, you can push right?

Chris
-----BEGIN PGP SIGNATURE-----

iQKlBAEBCgCPFiEEPonu50WOcg2XVOCyXiijOwuE9XcFAmA2EaNfFIAAAAAALgAo
aXNzdWVyLWZwckBub3RhdGlvbnMub3BlbnBncC5maWZ0aGhvcnNlbWFuLm5ldDNF
ODlFRUU3NDU4RTcyMEQ5NzU0RTBCMjVFMjhBMzNCMEI4NEY1NzcRHG1haWxAY2Jh
aW5lcy5uZXQACgkQXiijOwuE9XcHiA//YVKL2y/0ffgF5yf8bQ8NW2HzDlKpysFa
L7dMejmc2mzrnW6eovQIeDmbBsx6EwzKjmaqsQE4QLuT+iOnr4/EFV2/ggnn3mTn
m//W9fcYrJTuxrYSu+HzbAckEZmdiRxpDABKZHrGANnuimwNk1lSnki1VRtS8CDn
aLal1vilyBYT22thYNQDbWUo4IKWQhQ2wqRmEX/iFlWq4d5jH5yYpHsSXIvhviJX
CS12wNd5hHtGlnq5qYvYbfI34jptwFs/evcob5ZUSpbMJbktF5n1hBFMhL+wajpL
ad4E/sj1I4IVULe4SHHhoCA0/JitJCKJtERSkVcKy45cKiAL5E5jYLq5Z/OdYA1P
rFGH3aQe/oAW1J0+yF61pXSdJ05q7AFpEfEEAOoXPpduY+7j6zBWuKh4Veg63NXd
SGe4u5/iSfF5EnWhW9FXUlWBJz3wuBM+P+//jaCYhuHl+DgTxLx9neiu8rO1XT84
5WgzPYNAKq9IfnSGe//5yzuaAu0Dddg4aWYThVhRkVs4SE2B13KsKQX0pyRl6pPl
pqJZb9Rr5wS8NIKkUiLh3VRJYbtbyhd5Hg4PzIDnvkOWBA2wSiLyLF9fLCtn6Dn1
hwW60+qTHAYtC5p3G0jOF0rPCx54LCxJjkn2Jn7XAC+AFTxLfTkxUHGQhnmR0Gqe
GPOz+z7Mz2c=
=SNGX
-----END PGP SIGNATURE-----

C
C
Carl Dong wrote on 24 Feb 2021 21:42
(name . Christopher Baines)(address . mail@cbaines.net)(address . 46740@debbugs.gnu.org)
F200A9A0-56C7-4FB9-BEEC-A082C482E893@carldong.me
Hi Chris!

Been a while since I last submitted a patch, so want to make sure I get this right :-)
Thanks for your help!

Does this look alright?

From 6b4460bdb64db6f7f9f33c80710bc7020b8fd1f0 Mon Sep 17 00:00:00 2001
From: Carl Dong <contact@carldong.me>
Date: Wed, 3 Feb 2021 20:21:31 +0000
Subject: [PATCH] gnu: make-nsis: Fix build

* gnu/packages/installers.scm (make-nsis)[arguments]: Use
C{,PLUS}_INCLUDE_PATH instead of CPATH environment variable to fix
build.
---
gnu/packages/installers.scm | 29 +++++++++++++++++++----------
1 file changed, 19 insertions(+), 10 deletions(-)

Toggle diff (59 lines)
diff --git a/gnu/packages/installers.scm b/gnu/packages/installers.scm
index a8a5c36a18..775b91f0f7 100644
--- a/gnu/packages/installers.scm
+++ b/gnu/packages/installers.scm
@@ -92,13 +92,23 @@
;; for native toolchain
(setenv env-name
(filter-delimited-string env-val (negate mingw-path?)))
- ;; Add the removed paths back into
- ;; CROSS_-prefixed version of env vars
+ ;; Add the removed paths back into CROSS_-prefixed
+ ;; version of env vars
(setenv (string-append "CROSS_" env-name)
(filter-delimited-string env-val mingw-path?))))
- '("CPATH" "LIBRARY_PATH"))
+ '("C_INCLUDE_PATH" "CPLUS_INCLUDE_PATH" "LIBRARY_PATH"))
;; Hack to place mingw-w64 path at the end of search
;; paths. Could probably use a specfile and dirafter
+ (setenv "CROSS_C_INCLUDE_PATH"
+ (string-join
+ `(,@(map (cut string-append
+ (assoc-ref %build-inputs "xgcc")
+ "/lib/gcc/" ,triplet "/"
+ ,(package-version xgcc) <>)
+ '("/include"
+ "/include-fixed"))
+ ,(getenv "CROSS_C_INCLUDE_PATH"))
+ ":"))
(setenv "CROSS_CPLUS_INCLUDE_PATH"
(string-join
`(,@(map (cut string-append (assoc-ref %build-inputs "xgcc") <>)
@@ -108,21 +118,20 @@
,@(map (cut string-append "/lib/gcc/" ,triplet "/" ,(package-version xgcc) <>)
'("/include"
"/include-fixed"))))
- ,(getenv "CROSS_CPATH"))
+ ,(getenv "CROSS_CPLUS_INCLUDE_PATH"))
":"))))
(add-before 'build 'fix-target-detection
(lambda _
- ;; NSIS target detection is screwed up, manually
- ;; change it ourselves
+ ;; NSIS target detection is screwed up, manually change
+ ;; it ourselves
(substitute* "Source/build.cpp" (("m_target_type=TARGET_X86ANSI")
(string-append "m_target_type=" ,nsis-target-type))))))))
(home-page "http://nsis.sourceforge.net/")
(synopsis "A professional open source system to create Windows installers")
(description
- "NSIS (Nullsoft Scriptable Install System) is a professional open
-source system to create Windows installers. It is designed to be as small and
-flexible as possible and is therefore very suitable for internet
-distribution.")
+ "NSIS (Nullsoft Scriptable Install System) is a professional open source
+system to create Windows installers. It is designed to be as small and flexible
+as possible and is therefore very suitable for internet distribution.")
(license (license:non-copyleft "file://COPYING"
"See COPYING in the distribution.")))))

--
2.30.1

Cheers,
Carl Dong
contact@carldong.me
"I fight for the users"

Toggle quote (59 lines)
> On Feb 24, 2021, at 3:43 AM, Christopher Baines <mail@cbaines.net> wrote:
>
>
> Carl Dong <contact@carldong.me> writes:
>
>> * gnu/packages/installers.scm (make-nsis)[arguments]: Use
>> C{,PLUS}_INCLUDE_PATH instead of CPATH environment variable to fix
>> build.
>> ---
>> gnu/packages/installers.scm | 13 +++++++++++--
>> 1 file changed, 11 insertions(+), 2 deletions(-)
>>
>> diff --git a/gnu/packages/installers.scm b/gnu/packages/installers.scm
>> index a8a5c36a18..e8196b27d0 100644
>> --- a/gnu/packages/installers.scm
>> +++ b/gnu/packages/installers.scm
>> @@ -96,9 +96,18 @@
>> ;; CROSS_-prefixed version of env vars
>> (setenv (string-append "CROSS_" env-name)
>> (filter-delimited-string env-val mingw-path?))))
>> - '("CPATH" "LIBRARY_PATH"))
>> + '("C_INCLUDE_PATH" "CPLUS_INCLUDE_PATH" "LIBRARY_PATH"))
>> ;; Hack to place mingw-w64 path at the end of search
>> ;; paths. Could probably use a specfile and dirafter
>> + (setenv "CROSS_C_INCLUDE_PATH"
>> + (string-join
>> + `(,@(map (cut string-append (assoc-ref %build-inputs "xgcc")
>> + "/lib/gcc/" ,triplet "/"
>> + ,(package-version xgcc) <>)
>> + '("/include"
>> + "/include-fixed"))
>> + ,(getenv "CROSS_C_INCLUDE_PATH"))
>> + ":"))
>> (setenv "CROSS_CPLUS_INCLUDE_PATH"
>> (string-join
>> `(,@(map (cut string-append (assoc-ref %build-inputs "xgcc") <>)
>> @@ -108,7 +117,7 @@
>> ,@(map (cut string-append "/lib/gcc/" ,triplet "/" ,(package-version xgcc) <>)
>> '("/include"
>> "/include-fixed"))))
>> - ,(getenv "CROSS_CPATH"))
>> + ,(getenv "CROSS_CPLUS_INCLUDE_PATH"))
>> ":"))))
>> (add-before 'build 'fix-target-detection
>> (lambda _
>
> Hey!
>
> Looks like this does fix things which is great [1], but it also
> introduces some lint warnings [2].
>
> 1: https://data.guix-patches.cbaines.net/compare/package-derivations?base_commit=c418c6b64cbfa7a4eb1bfb7d02a99083103dd40e&target_commit=28d1e194346b3dae2ae4e969c00724d4d1037ff4&locale=en_US.UTF-8
> 2: https://data.guix-patches.cbaines.net/compare?base_commit=c418c6b64cbfa7a4eb1bfb7d02a99083103dd40e&target_commit=28d1e194346b3dae2ae4e969c00724d4d1037ff4
>
> So, I'd remove the tabs and tweak the indentation so you're not
> introducing any new long lines. But apart from that I think it's fine to
> push, you can push right?
>
> Chris
Attachment: signature.asc
C
C
Christopher Baines wrote on 25 Feb 2021 09:59
(name . Carl Dong)(address . contact@carldong.me)(address . 46740@debbugs.gnu.org)
87v9agjzf8.fsf@cbaines.net
Carl Dong <contact@carldong.me> writes:

Toggle quote (5 lines)
> Been a while since I last submitted a patch, so want to make sure I
> get this right :-) Thanks for your help!
>
> Does this look alright?

Yep, that looks fine.

There's a couple of changes that look a bit redundant, the rearranging
of a comment and the description string, but that's not a problem.
-----BEGIN PGP SIGNATURE-----

iQKlBAEBCgCPFiEEPonu50WOcg2XVOCyXiijOwuE9XcFAmA3ZutfFIAAAAAALgAo
aXNzdWVyLWZwckBub3RhdGlvbnMub3BlbnBncC5maWZ0aGhvcnNlbWFuLm5ldDNF
ODlFRUU3NDU4RTcyMEQ5NzU0RTBCMjVFMjhBMzNCMEI4NEY1NzcRHG1haWxAY2Jh
aW5lcy5uZXQACgkQXiijOwuE9XdJQA//cIPuoL3FcFtxCTU+NDwtG1WaiqtErLfg
LnCvsQ1yq+OsXPuQrGEx6XetbzJhse9ZPhfG0iVfM3QUcljNVKxu3Vh+7qbiudBn
QKucb4lh1zz1reGoFsxiesRjgyIdazORl3OeZrJac88MGTIOFSOU9QJned93i2Rf
oZ68XHdyIsOQOJnvcjJ+p7mItwVxvVZrDWMLi486Qf3uEqbKuNntZfmk3hD/RcDt
8eEAH0PH9gSsiYDQoMQ8LbnTfgFpLfJPF9BAr3MmqDX9Ju0PgnUvj+EY47a1x3U1
k5lFHUNvOKNRt1BZF4RpJPQsJOrvVm+X5f7rKa/Se8WGWphyKBF1qosAv1DsspiP
69UOG1ZOcExH74MHkYTSaaMD36cSIj3EK1KOyxp86bbhJUOusMWbJXNeUbAHZrsg
eQ4XLbuDZUOYnSV8y2AY4Mx/f1blPGsy+nxoib2PPOiCySCp2DtDXFMPqRpb9sw1
6SrcyV5xPUDDApBdidvEj55iDdLPLt598Qrc3U3GrxSgtVJJEu+P79iJY7ikcrkf
JB5tl3VT19zaj/2EHryTAVcrYxF9ZVkStoU6uqtYErrbaoOespIgxp9AMNhA1trS
It2xYQqx+2f2+DGF1xBGul+fhpNWVi29ujmQodd8cyh1sAC/x9FuqprW6hXWYX5l
EqqOwXJYfQY=
=k4JI
-----END PGP SIGNATURE-----

C
C
Carl Dong wrote on 26 Feb 2021 18:04
Closing 46740
(address . control@debbugs.gnu.org)
DF9D8632-CE84-44EA-99B1-DCF66693E958@carldong.me
close 46740
?