* [bug#68305] [PATCH] gnu: Add guile-srfi-197.
@ 2024-01-07 15:09 Tomas Volf
2024-01-12 16:10 ` Mathieu Othacehe
2024-01-12 16:46 ` [bug#68305] [PATCH v2] " Tomas Volf
0 siblings, 2 replies; 6+ messages in thread
From: Tomas Volf @ 2024-01-07 15:09 UTC (permalink / raw)
To: 68305; +Cc: Tomas Volf
* gnu/packages/guile-xyz.scm (guile-srfi-197): New variable.
Change-Id: Ifcdc264e6a03e88e7614d79792fbe6ca9c8e519c
---
gnu/packages/guile-xyz.scm | 56 ++++++++++++++++++++++++++++++++++++++
1 file changed, 56 insertions(+)
diff --git a/gnu/packages/guile-xyz.scm b/gnu/packages/guile-xyz.scm
index 75e3754046..ff3104a407 100644
--- a/gnu/packages/guile-xyz.scm
+++ b/gnu/packages/guile-xyz.scm
@@ -3840,6 +3840,62 @@ (define-public guile-srfi-189
or errors (Left).")
(license license:expat))))
+(define-public guile-srfi-197
+ (let ((commit "d31b8be86460bf837cccf2737a1b9b9c01788573")
+ (revision "0"))
+ (package
+ (name "guile-srfi-197")
+ (version (git-version "0" revision commit))
+ (source
+ (origin
+ (method git-fetch)
+ (uri (git-reference
+ (url "https://github.com/scheme-requests-for-implementation/srfi-197")
+ (commit commit)))
+ (sha256
+ (base32
+ "1c1jjzqgavjwfzs352wssdbjga5ymv4g3lkl0zxhjw7pfrr5xx1m"))
+ (file-name (git-file-name name version))))
+ (build-system guile-build-system)
+ (arguments
+ (list
+ #:source-directory "src"
+ #:phases
+ #~(modify-phases %standard-phases
+ (add-after 'unpack 'create-module
+ (λ _
+ (use-modules (ice-9 textual-ports))
+ (mkdir-p "src/srfi")
+ (call-with-output-file "src/srfi/srfi-197.scm"
+ (λ (port)
+ (write '(define-module (srfi srfi-197)
+ #:use-module (scheme base)
+ #:export (chain
+ chain-and
+ chain-when
+ chain-lambda
+ nest
+ nest-reverse))
+ port)
+ (call-with-input-file "srfi-197-syntax-case.scm"
+ (λ (in-port)
+ (display (get-string-all in-port) port)))))))
+ (add-after 'install 'check-installed
+ (λ _
+ (define-values (scm go) (target-guile-scm+go #$output))
+ (invoke "guile" "-L" scm "-C" go
+ "--use-srfi=197" "./test.scm"))))))
+ (native-inputs
+ (list guile-3.0))
+ (home-page "https://srfi.schemers.org/srfi-197/")
+ (synopsis "Pipeline operators for Guile")
+ (description
+ "This library provides a reference implementation for SRFI-197. This
+SRFI defines a family of chain and nest pipeline operators, which can rewrite
+nested expressions like (a b (c d (e f g))) as a sequence of operations:
+(chain g (e f _) (c d _) (a b _)).")
+ (license license:expat))))
+
(define-public guile-srfi-232
(package
(name "guile-srfi-232")
base-commit: b212e6934643e085f168a5364cb593f61aa616ba
--
2.41.0
^ permalink raw reply related [flat|nested] 6+ messages in thread
* [bug#68305] [PATCH] gnu: Add guile-srfi-197.
2024-01-07 15:09 [bug#68305] [PATCH] gnu: Add guile-srfi-197 Tomas Volf
@ 2024-01-12 16:10 ` Mathieu Othacehe
2024-01-12 16:47 ` Tomas Volf
2024-01-12 16:46 ` [bug#68305] [PATCH v2] " Tomas Volf
1 sibling, 1 reply; 6+ messages in thread
From: Mathieu Othacehe @ 2024-01-12 16:10 UTC (permalink / raw)
To: Tomas Volf; +Cc: 68305
Hello,
> +(define-public guile-srfi-197
> + (let ((commit "d31b8be86460bf837cccf2737a1b9b9c01788573")
> + (revision "0"))
You should explain why you are not using a release with a comment. The
"final" tag for instance.
> + #~(modify-phases %standard-phases
> + (add-after 'unpack 'create-module
> + (λ _
Please use 'lambda'.
> +SRFI defines a family of chain and nest pipeline operators, which can rewrite
> +nested expressions like (a b (c d (e f g))) as a sequence of operations:
@code{(a b (c d (e f g)))}
> +(chain g (e f _) (c d _) (a b _)).")
@code{(chain g (e f _) (c d _) (a b _)).")}
Can you please send a v2?
Thanks,
Mathieu
^ permalink raw reply [flat|nested] 6+ messages in thread
* [bug#68305] [PATCH v2] gnu: Add guile-srfi-197.
2024-01-07 15:09 [bug#68305] [PATCH] gnu: Add guile-srfi-197 Tomas Volf
2024-01-12 16:10 ` Mathieu Othacehe
@ 2024-01-12 16:46 ` Tomas Volf
2024-01-13 9:40 ` bug#68305: " Mathieu Othacehe
1 sibling, 1 reply; 6+ messages in thread
From: Tomas Volf @ 2024-01-12 16:46 UTC (permalink / raw)
To: 68305; +Cc: Tomas Volf
* gnu/packages/guile-xyz.scm (guile-srfi-197): New variable.
Change-Id: Ifcdc264e6a03e88e7614d79792fbe6ca9c8e519c
---
* Use lambda instead of λ.
* Add comment regarding the commit used.
* Use @code{} in the description.
gnu/packages/guile-xyz.scm | 59 ++++++++++++++++++++++++++++++++++++++
1 file changed, 59 insertions(+)
diff --git a/gnu/packages/guile-xyz.scm b/gnu/packages/guile-xyz.scm
index 75e3754046..841127e8c9 100644
--- a/gnu/packages/guile-xyz.scm
+++ b/gnu/packages/guile-xyz.scm
@@ -3840,6 +3840,65 @@ (define-public guile-srfi-189
or errors (Left).")
(license license:expat))))
+(define-public guile-srfi-197
+ (let (
+ ;; There is minor fix to the documention after the final tag, so use
+ ;; the newest commit instead.
+ (commit "d31b8be86460bf837cccf2737a1b9b9c01788573")
+ (revision "0"))
+ (package
+ (name "guile-srfi-197")
+ (version (git-version "0" revision commit))
+ (source
+ (origin
+ (method git-fetch)
+ (uri (git-reference
+ (url "https://github.com/scheme-requests-for-implementation/srfi-197")
+ (commit commit)))
+ (sha256
+ (base32
+ "1c1jjzqgavjwfzs352wssdbjga5ymv4g3lkl0zxhjw7pfrr5xx1m"))
+ (file-name (git-file-name name version))))
+ (build-system guile-build-system)
+ (arguments
+ (list
+ #:source-directory "src"
+ #:phases
+ #~(modify-phases %standard-phases
+ (add-after 'unpack 'create-module
+ (lambda _
+ (use-modules (ice-9 textual-ports))
+ (mkdir-p "src/srfi")
+ (call-with-output-file "src/srfi/srfi-197.scm"
+ (lambda (port)
+ (write '(define-module (srfi srfi-197)
+ #:use-module (scheme base)
+ #:export (chain
+ chain-and
+ chain-when
+ chain-lambda
+ nest
+ nest-reverse))
+ port)
+ (call-with-input-file "srfi-197-syntax-case.scm"
+ (lambda (in-port)
+ (display (get-string-all in-port) port)))))))
+ (add-after 'install 'check-installed
+ (lambda _
+ (define-values (scm go) (target-guile-scm+go #$output))
+ (invoke "guile" "-L" scm "-C" go
+ "--use-srfi=197" "./test.scm"))))))
+ (native-inputs
+ (list guile-3.0))
+ (home-page "https://srfi.schemers.org/srfi-197/")
+ (synopsis "Pipeline operators for Guile")
+ (description
+ "This library provides a reference implementation for SRFI-197. This
+SRFI defines a family of chain and nest pipeline operators, which can rewrite
+nested expressions like @code{(a b (c d (e f g)))} as a sequence of
+operations: @code{(chain g (e f _) (c d _) (a b _))}.")
+ (license license:expat))))
+
(define-public guile-srfi-232
(package
(name "guile-srfi-232")
base-commit: b212e6934643e085f168a5364cb593f61aa616ba
--
2.41.0
^ permalink raw reply related [flat|nested] 6+ messages in thread
* [bug#68305] [PATCH] gnu: Add guile-srfi-197.
2024-01-12 16:10 ` Mathieu Othacehe
@ 2024-01-12 16:47 ` Tomas Volf
2024-01-13 9:22 ` Mathieu Othacehe
0 siblings, 1 reply; 6+ messages in thread
From: Tomas Volf @ 2024-01-12 16:47 UTC (permalink / raw)
To: Mathieu Othacehe; +Cc: 68305
[-- Attachment #1: Type: text/plain, Size: 1216 bytes --]
On 2024-01-12 17:10:50 +0100, Mathieu Othacehe wrote:
>
> Hello,
>
> > +(define-public guile-srfi-197
> > + (let ((commit "d31b8be86460bf837cccf2737a1b9b9c01788573")
> > + (revision "0"))
>
> You should explain why you are not using a release with a comment. The
> "final" tag for instance.
Comment added.
>
> > + #~(modify-phases %standard-phases
> > + (add-after 'unpack 'create-module
> > + (λ _
>
> Please use 'lambda'.
I replaced all occurrences. Is there something regarding this in the manual? I
see no mention of it and guix style leaves it as it is. There are few (~5) uses
in the repository already, so I assumed it is permitted.
>
> > +SRFI defines a family of chain and nest pipeline operators, which can rewrite
> > +nested expressions like (a b (c d (e f g))) as a sequence of operations:
>
> @code{(a b (c d (e f g)))}
>
> > +(chain g (e f _) (c d _) (a b _)).")
>
> @code{(chain g (e f _) (c d _) (a b _)).")}
>
> Can you please send a v2?
Done and done.
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] 6+ messages in thread
* [bug#68305] [PATCH] gnu: Add guile-srfi-197.
2024-01-12 16:47 ` Tomas Volf
@ 2024-01-13 9:22 ` Mathieu Othacehe
0 siblings, 0 replies; 6+ messages in thread
From: Mathieu Othacehe @ 2024-01-13 9:22 UTC (permalink / raw)
To: Tomas Volf; +Cc: 68305
Hey,
> I replaced all occurrences. Is there something regarding this in the manual? I
> see no mention of it and guix style leaves it as it is. There are few (~5) uses
> in the repository already, so I assumed it is permitted.
I don't think it is advised not to use that anywhere but the reason to
me is the consistency of the code base. It would be nice to remove the 5
existing use that you are reporting :)
> Done and done.
Perfect, thanks,
Mathieu
^ permalink raw reply [flat|nested] 6+ messages in thread
* bug#68305: [PATCH v2] gnu: Add guile-srfi-197.
2024-01-12 16:46 ` [bug#68305] [PATCH v2] " Tomas Volf
@ 2024-01-13 9:40 ` Mathieu Othacehe
0 siblings, 0 replies; 6+ messages in thread
From: Mathieu Othacehe @ 2024-01-13 9:40 UTC (permalink / raw)
To: Tomas Volf; +Cc: 68305-done
> * gnu/packages/guile-xyz.scm (guile-srfi-197): New variable.
Applied, thanks!
Mathieu
^ permalink raw reply [flat|nested] 6+ messages in thread
end of thread, other threads:[~2024-01-13 9:42 UTC | newest]
Thread overview: 6+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2024-01-07 15:09 [bug#68305] [PATCH] gnu: Add guile-srfi-197 Tomas Volf
2024-01-12 16:10 ` Mathieu Othacehe
2024-01-12 16:47 ` Tomas Volf
2024-01-13 9:22 ` Mathieu Othacehe
2024-01-12 16:46 ` [bug#68305] [PATCH v2] " Tomas Volf
2024-01-13 9:40 ` bug#68305: " Mathieu Othacehe
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).