* [bug#56204] Add guile-goblins
@ 2022-06-24 21:24 Christine Lemmer-Webber
2022-06-24 21:57 ` Maxime Devos
` (2 more replies)
0 siblings, 3 replies; 9+ messages in thread
From: Christine Lemmer-Webber @ 2022-06-24 21:24 UTC (permalink / raw)
To: 56204
[-- Attachment #1: Type: text/plain, Size: 173 bytes --]
Finally! ;)
It's a pretty small change, just adding a leaf package, but I figured
since it's adding a package I maintain the project of, best to get
review.
- Christine
[-- Attachment #2: 0001-gnu-Add-guile-goblins.patch --]
[-- Type: text/x-patch, Size: 2865 bytes --]
From a09c70dac11dcc133c8e86c3c7e953019942e00c Mon Sep 17 00:00:00 2001
From: Christine Lemmer-Webber <cwebber@dustycloud.org>
Date: Fri, 24 Jun 2022 14:28:56 -0400
Subject: [PATCH] gnu: Add guile-goblins.
* gnu/packages/guile-xyz.scm (guile-goblins): New variable.
---
gnu/packages/guile-xyz.scm | 42 +++++++++++++++++++++++++++++++++++++-
1 file changed, 41 insertions(+), 1 deletion(-)
diff --git a/gnu/packages/guile-xyz.scm b/gnu/packages/guile-xyz.scm
index 2ed6617fd2..853dfa832e 100644
--- a/gnu/packages/guile-xyz.scm
+++ b/gnu/packages/guile-xyz.scm
@@ -1,7 +1,7 @@
;;; GNU Guix --- Functional package management for GNU
;;; Copyright © 2012-2022 Ludovic Courtès <ludo@gnu.org>
;;; Copyright © 2014, 2015, 2018 Mark H Weaver <mhw@netris.org>
-;;; Copyright © 2015, 2017 Christine Lemmer-Webber <cwebber@dustycloud.org>
+;;; Copyright © 2015, 2017, 2022 Christine Lemmer-Webber <cwebber@dustycloud.org>
;;; Copyright © 2016 Alex Sassmannshausen <alex@pompo.co>
;;; Copyright © 2016, 2017, 2018, 2019, 2020, 2021, 2022 Ricardo Wurmus <rekado@elephly.net>
;;; Copyright © 2016 Erik Edrosa <erik.edrosa@gmail.com>
@@ -5103,3 +5103,43 @@ (define-public guile-termios
termios API is used. GNU Guile doesn't have an interface for that built in.
This module implements this interface by use of Guile's dynamic FFI.")
(license license:bsd-2)))
+
+(define-public guile-goblins
+ (package
+ (name "guile-goblins")
+ (version "0.8")
+ (source
+ (origin
+ (method git-fetch)
+ (uri (git-reference
+ (url "https://gitlab.com/spritely/guile-goblins/")
+ (commit (string-append "v" version))))
+ (file-name (string-append name "-" version))
+ (sha256
+ (base32
+ "1mmyykh79jwhrfgnhhw94aw7a8m6qw249kj7k60ynj16mcfm5iyy"))))
+ (build-system gnu-build-system)
+ (arguments
+ `(#:phases
+ (modify-phases %standard-phases
+ (replace 'bootstrap
+ (lambda _
+ (invoke "autoreconf" "-vif"))))
+ #:make-flags
+ ,#~(list "GUILE_AUTO_COMPILE=0")))
+ (native-inputs
+ (list autoconf automake pkg-config texinfo))
+ (inputs
+ `(("guile" ,guile-3.0)))
+ (propagated-inputs
+ (list guile-fibers guile-gcrypt))
+ (home-page "https://spritely.institute/goblins")
+ (synopsis "Distributed programming environment for Guile")
+ (description
+ "@code{guile-goblins} is the Guile version of
+@url{https://spritely.institute/goblins, Spritely Goblins},
+a transactional, distributed programming environment following object
+capability security designs. Goblins is a general toolkit, and also
+the core layer of Spritely's work to support healthy distributed
+networked communities.")
+ (license license:asl2.0)))
--
2.36.1
^ permalink raw reply related [flat|nested] 9+ messages in thread
* [bug#56204] Add guile-goblins
2022-06-24 21:24 [bug#56204] Add guile-goblins Christine Lemmer-Webber
@ 2022-06-24 21:57 ` Maxime Devos
2022-06-25 2:36 ` bug#56204: " Christine Lemmer-Webber
2022-06-25 9:32 ` [bug#56204] " Maxime Devos
2022-06-25 21:49 ` Ludovic Courtès
2 siblings, 1 reply; 9+ messages in thread
From: Maxime Devos @ 2022-06-24 21:57 UTC (permalink / raw)
To: Christine Lemmer-Webber, 56204
[-- Attachment #1: Type: text/plain, Size: 1502 bytes --]
Christine Lemmer-Webber schreef op vr 24-06-2022 om 17:24 [-0400]:
> + (arguments
> + `(#:phases
> + (modify-phases %standard-phases
> + (replace 'bootstrap
> + (lambda _
> + (invoke "autoreconf" "-vif"))))
I don't know if it works in this particular case, but I thought that
normally 'bootstrap' would automatically do that already?
> + #:make-flags
> + ,#~(list "GUILE_AUTO_COMPILE=0")))
Nesting different forms of quasiquotation seems to be disliked (at
least according to a mini poll I did on #guix some time ago),
apparently
(arguments
(list #:phases
#~(modify-phases ...)
#:make-flags
#~(list ...)))
seems to be the way to go?
> + (native-inputs
> + (list autoconf automake pkg-config texinfo))
> + (inputs
> + `(("guile" ,guile-3.0)))
Can be simplified to (inputs (list guile-3.0))?
> + "@code{guile-goblins} is the Guile version of
> + @url{https://spritely.institute/goblins, Spritely Goblins},
> +a transactional, distributed programming environment following object
> +capability security designs. Goblins is a general toolkit, and also
> +the core layer of Spritely's work to support healthy distributed
> +networked communities.")
Maybe mention that it can network with non-Guile goblin peers as well
(e.g. Racket?), assuming that's correct?
Greetings,
Maxime.
[-- Attachment #2: This is a digitally signed message part --]
[-- Type: application/pgp-signature, Size: 260 bytes --]
^ permalink raw reply [flat|nested] 9+ messages in thread
* bug#56204: Add guile-goblins
2022-06-24 21:57 ` Maxime Devos
@ 2022-06-25 2:36 ` Christine Lemmer-Webber
0 siblings, 0 replies; 9+ messages in thread
From: Christine Lemmer-Webber @ 2022-06-25 2:36 UTC (permalink / raw)
To: Maxime Devos; +Cc: 56204-done
Hey Maxime!
Maxime Devos <maximedevos@telenet.be> writes:
> [[PGP Signed Part:Undecided]]
> Christine Lemmer-Webber schreef op vr 24-06-2022 om 17:24 [-0400]:
>> + (arguments
>> + `(#:phases
>> + (modify-phases %standard-phases
>> + (replace 'bootstrap
>> + (lambda _
>> + (invoke "autoreconf" "-vif"))))
>
> I don't know if it works in this particular case, but I thought that
> normally 'bootstrap' would automatically do that already?
Ah yeah, seems to work without it...!
>> + #:make-flags
>> + ,#~(list "GUILE_AUTO_COMPILE=0")))
>
> Nesting different forms of quasiquotation seems to be disliked (at
> least according to a mini poll I did on #guix some time ago),
> apparently
>
> (arguments
> (list #:phases
> #~(modify-phases ...)
> #:make-flags
> #~(list ...)))
>
> seems to be the way to go?
>
>> + (native-inputs
>> + (list autoconf automake pkg-config texinfo))
>> + (inputs
>> + `(("guile" ,guile-3.0)))
>
> Can be simplified to (inputs (list guile-3.0))?
Cool, done. For (inputs ...) anyway... the above native-inputs did
still seem needed, presumably because we *are* running the bootstrap
code in this case.
>> + "@code{guile-goblins} is the Guile version of
>> + @url{https://spritely.institute/goblins, Spritely Goblins},
>> +a transactional, distributed programming environment following object
>> +capability security designs. Goblins is a general toolkit, and also
>> +the core layer of Spritely's work to support healthy distributed
>> +networked communities.")
>
> Maybe mention that it can network with non-Guile goblin peers as well
> (e.g. Racket?), assuming that's correct?
>
> Greetings,
> Maxime.
It's true, but more accurately, it will be true in the next version,
since guile-goblins v0.8 doesn't have finished networking support.
But yes, that's coming, so I put this comment above the description:
;; In guile-goblins 0.9, OCapN support will be added (it already
;; exists in racket-goblins). At that point we should add the
;; following to this description:
;;
;; Goblins allows for cooperation between networked programs
;; in a mutually suspicious network through OCapN, the Object
;; Capability Network. This includes collaboration across
;; runtimes; for instance, programs written in the Guile and Racket
;; versions of Goblins are able to speak to each other.
And we can do that then. As said in the other email, I don't think this
is far away.
Thanks to both Maxime and Ludo' for reviewing! I pushed it upstream.
Happy hacking with guile-goblins... if someone does anything with it,
let me know. The next release will be the first big guile-goblins
release to celebrate, but was eager to get what we have up there. :)
^ permalink raw reply [flat|nested] 9+ messages in thread
* [bug#56204] Add guile-goblins
2022-06-24 21:24 [bug#56204] Add guile-goblins Christine Lemmer-Webber
2022-06-24 21:57 ` Maxime Devos
@ 2022-06-25 9:32 ` Maxime Devos
2022-06-25 21:46 ` Ludovic Courtès
2022-06-25 21:49 ` Ludovic Courtès
2 siblings, 1 reply; 9+ messages in thread
From: Maxime Devos @ 2022-06-25 9:32 UTC (permalink / raw)
To: Christine Lemmer-Webber, 56204
[-- Attachment #1: Type: text/plain, Size: 749 bytes --]
Christine Lemmer-Webber schreef op vr 24-06-2022 om 17:24 [-0400]:
> + (version "0.8")
> + (source
> + (origin
> + (method git-fetch)
> + (uri (git-reference
> + (url "https://gitlab.com/spritely/guile-goblins/")
> + (commit (string-append "v" version))))
> + (file-name (string-append name "-" version))
> + (sha256
> + (base32
> + "1mmyykh79jwhrfgnhhw94aw7a8m6qw249kj7k60ynj16mcfm5iyy"))))
I'm not seeing "--target" in the invocation of "$(GUILE_TOOLS)
compile", so I don't think that currently it will cross-compile
correctly. Could you add a --target=... in the Makefile.am?
Greetings,
Maxime.
[-- Attachment #2: This is a digitally signed message part --]
[-- Type: application/pgp-signature, Size: 260 bytes --]
^ permalink raw reply [flat|nested] 9+ messages in thread
* [bug#56204] Add guile-goblins
2022-06-25 9:32 ` [bug#56204] " Maxime Devos
@ 2022-06-25 21:46 ` Ludovic Courtès
2022-06-26 19:09 ` Christine Lemmer-Webber
0 siblings, 1 reply; 9+ messages in thread
From: Ludovic Courtès @ 2022-06-25 21:46 UTC (permalink / raw)
To: Maxime Devos; +Cc: Christine Lemmer-Webber, 56204
Maxime Devos <maximedevos@telenet.be> skribis:
> Christine Lemmer-Webber schreef op vr 24-06-2022 om 17:24 [-0400]:
>> + (version "0.8")
>> + (source
>> + (origin
>> + (method git-fetch)
>> + (uri (git-reference
>> + (url "https://gitlab.com/spritely/guile-goblins/")
>> + (commit (string-append "v" version))))
>> + (file-name (string-append name "-" version))
>> + (sha256
>> + (base32
>> + "1mmyykh79jwhrfgnhhw94aw7a8m6qw249kj7k60ynj16mcfm5iyy"))))
>
>
> I'm not seeing "--target" in the invocation of "$(GUILE_TOOLS)
> compile", so I don't think that currently it will cross-compile
> correctly. Could you add a --target=... in the Makefile.am?
That can come upstream in the next version of Goblins IMO.
Ludo’.
^ permalink raw reply [flat|nested] 9+ messages in thread
* [bug#56204] Add guile-goblins
2022-06-25 21:46 ` Ludovic Courtès
@ 2022-06-26 19:09 ` Christine Lemmer-Webber
2022-06-26 20:50 ` Maxime Devos
2022-06-27 10:22 ` Ludovic Courtès
0 siblings, 2 replies; 9+ messages in thread
From: Christine Lemmer-Webber @ 2022-06-26 19:09 UTC (permalink / raw)
To: Ludovic Courtès; +Cc: 56204, Maxime Devos
Ludovic Courtès <ludo@gnu.org> writes:
> Maxime Devos <maximedevos@telenet.be> skribis:
>
>> Christine Lemmer-Webber schreef op vr 24-06-2022 om 17:24 [-0400]:
>>> + (version "0.8")
>>> + (source
>>> + (origin
>>> + (method git-fetch)
>>> + (uri (git-reference
>>> + (url "https://gitlab.com/spritely/guile-goblins/")
>>> + (commit (string-append "v" version))))
>>> + (file-name (string-append name "-" version))
>>> + (sha256
>>> + (base32
>>> + "1mmyykh79jwhrfgnhhw94aw7a8m6qw249kj7k60ynj16mcfm5iyy"))))
>>
>>
>> I'm not seeing "--target" in the invocation of "$(GUILE_TOOLS)
>> compile", so I don't think that currently it will cross-compile
>> correctly. Could you add a --target=... in the Makefile.am?
>
> That can come upstream in the next version of Goblins IMO.
>
> Ludo’.
Cool, I added it to commit 6664daa27e9b3eb3220ba83d9c874b730e792f90 in
guile-goblins. However I was just mimicing guile-gcrypt, so I'm not
sure if it's right:
#+BEGIN_SRC diff
diff --git a/Makefile.am b/Makefile.am
index b8d4944..b056337 100644
--- a/Makefile.am
+++ b/Makefile.am
@@ -32,7 +32,7 @@ EXTRA_DIST = $(SOURCES) $(NOCOMP_SOURCES)
GUILE_WARNINGS = -Wunbound-variable -Warity-mismatch -Wformat
SUFFIXES = .scm .go
.scm.go:
- $(AM_V_GEN)$(top_builddir)/pre-inst-env $(GUILE_TOOLS) compile $(GUILE_WARNINGS) -o "$@" "$<"
+ $(AM_V_GEN)$(top_builddir)/pre-inst-env $(GUILE_TOOLS) compile $(GUILE_TARGET) $(GUILE_WARNINGS) -o "$@" "$<"
SOURCES = goblins.scm \
goblins/ocapn/crypto-stubs.scm \
#+END_SRC
Should that be sufficient?
Notably, the Makefile.am here was bootstrapped using guile-hall, so my
suspicion is that this is an update that should be made in guile-hall's
templates also, then everyone can benefit.
The next release of Goblins should be due out very quickly, I think, so
we'll be able to take advantage of it then.
^ permalink raw reply related [flat|nested] 9+ messages in thread
* [bug#56204] Add guile-goblins
2022-06-26 19:09 ` Christine Lemmer-Webber
@ 2022-06-26 20:50 ` Maxime Devos
2022-06-27 10:22 ` Ludovic Courtès
1 sibling, 0 replies; 9+ messages in thread
From: Maxime Devos @ 2022-06-26 20:50 UTC (permalink / raw)
To: Christine Lemmer-Webber, Ludovic Courtès; +Cc: 56204
[-- Attachment #1: Type: text/plain, Size: 984 bytes --]
Christine Lemmer-Webber schreef op zo 26-06-2022 om 15:09 [-0400]:
> #+BEGIN_SRC diff
> diff --git a/Makefile.am b/Makefile.am
> index b8d4944..b056337 100644
> --- a/Makefile.am
> +++ b/Makefile.am
> @@ -32,7 +32,7 @@ EXTRA_DIST = $(SOURCES) $(NOCOMP_SOURCES)
> GUILE_WARNINGS = -Wunbound-variable -Warity-mismatch -Wformat
> SUFFIXES = .scm .go
> .scm.go:
> - $(AM_V_GEN)$(top_builddir)/pre-inst-env $(GUILE_TOOLS) compile $(GUILE_WARNINGS) -o "$@" "$<"
> + $(AM_V_GEN)$(top_builddir)/pre-inst-env $(GUILE_TOOLS) compile $(GUILE_TARGET) $(GUILE_WARNINGS) -o "$@" "$<"
>
> SOURCES = goblins.scm \
> goblins/ocapn/crypto-stubs.scm \
> #+END_SRC
>
> Should that be sufficient?
I think so (untested)?
> Notably, the Makefile.am here was bootstrapped using guile-hall, so
> my suspicion is that this is an update that should be made in
> guile-hall's templates also, then everyone can benefit.
Agreed.
Greetings,
Maxime.
[-- Attachment #2: This is a digitally signed message part --]
[-- Type: application/pgp-signature, Size: 260 bytes --]
^ permalink raw reply [flat|nested] 9+ messages in thread
* [bug#56204] Add guile-goblins
2022-06-26 19:09 ` Christine Lemmer-Webber
2022-06-26 20:50 ` Maxime Devos
@ 2022-06-27 10:22 ` Ludovic Courtès
1 sibling, 0 replies; 9+ messages in thread
From: Ludovic Courtès @ 2022-06-27 10:22 UTC (permalink / raw)
To: Christine Lemmer-Webber; +Cc: 56204, Maxime Devos
Hi,
Christine Lemmer-Webber <cwebber@dustycloud.org> skribis:
> #+BEGIN_SRC diff
> diff --git a/Makefile.am b/Makefile.am
> index b8d4944..b056337 100644
> --- a/Makefile.am
> +++ b/Makefile.am
> @@ -32,7 +32,7 @@ EXTRA_DIST = $(SOURCES) $(NOCOMP_SOURCES)
> GUILE_WARNINGS = -Wunbound-variable -Warity-mismatch -Wformat
> SUFFIXES = .scm .go
> .scm.go:
> - $(AM_V_GEN)$(top_builddir)/pre-inst-env $(GUILE_TOOLS) compile $(GUILE_WARNINGS) -o "$@" "$<"
> + $(AM_V_GEN)$(top_builddir)/pre-inst-env $(GUILE_TOOLS) compile $(GUILE_TARGET) $(GUILE_WARNINGS) -o "$@" "$<"
>
> SOURCES = goblins.scm \
> goblins/ocapn/crypto-stubs.scm \
> #+END_SRC
>
> Should that be sufficient?
Yes, that LGTM, provided GUILE_TARGET is properly computed, like in
Guile-Gcrypt’s ‘configure.ac’.
Thanks,
Ludo’.
^ permalink raw reply [flat|nested] 9+ messages in thread
* [bug#56204] Add guile-goblins
2022-06-24 21:24 [bug#56204] Add guile-goblins Christine Lemmer-Webber
2022-06-24 21:57 ` Maxime Devos
2022-06-25 9:32 ` [bug#56204] " Maxime Devos
@ 2022-06-25 21:49 ` Ludovic Courtès
2 siblings, 0 replies; 9+ messages in thread
From: Ludovic Courtès @ 2022-06-25 21:49 UTC (permalink / raw)
To: Christine Lemmer-Webber; +Cc: 56204
Hello Christine,
Christine Lemmer-Webber <cwebber@dustycloud.org> skribis:
>>From a09c70dac11dcc133c8e86c3c7e953019942e00c Mon Sep 17 00:00:00 2001
> From: Christine Lemmer-Webber <cwebber@dustycloud.org>
> Date: Fri, 24 Jun 2022 14:28:56 -0400
> Subject: [PATCH] gnu: Add guile-goblins.
>
> * gnu/packages/guile-xyz.scm (guile-goblins): New variable.
Woohoo, awesome!
I agree with the minor issues Maxime noted, but otherwise looks great
to me! Go Spritely, go!!
Ludo’.
^ permalink raw reply [flat|nested] 9+ messages in thread
end of thread, other threads:[~2022-06-27 10:58 UTC | newest]
Thread overview: 9+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2022-06-24 21:24 [bug#56204] Add guile-goblins Christine Lemmer-Webber
2022-06-24 21:57 ` Maxime Devos
2022-06-25 2:36 ` bug#56204: " Christine Lemmer-Webber
2022-06-25 9:32 ` [bug#56204] " Maxime Devos
2022-06-25 21:46 ` Ludovic Courtès
2022-06-26 19:09 ` Christine Lemmer-Webber
2022-06-26 20:50 ` Maxime Devos
2022-06-27 10:22 ` Ludovic Courtès
2022-06-25 21:49 ` Ludovic Courtès
Code repositories for project(s) associated with this external index
https://git.savannah.gnu.org/cgit/guix.git
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.