* [bug#47027] Disarchive package
@ 2021-03-09 19:37 Timothy Sample
2021-03-09 19:39 ` [bug#47027] [PATCH 1/2] gnu: Add guile-quickcheck Timothy Sample
0 siblings, 1 reply; 19+ messages in thread
From: Timothy Sample @ 2021-03-09 19:37 UTC (permalink / raw)
To: 47027
Hi Guix,
These patches add Disarchive and one of its dependencies,
Guile-QuickCheck.
They are pretty straight forward, but I am a little shaky about using
“guile-3.0-latest”, so I would appreciate another pair of eyes. The
reason it’s there is because Disarchive opportunistically uses the SWH
code from Guix if it is available. If I use plain “guile-3.0”, I get
“incompatible bytecode” errors when restoring archives from SWH.
TIA!
-- Tim
^ permalink raw reply [flat|nested] 19+ messages in thread
* [bug#47027] [PATCH 1/2] gnu: Add guile-quickcheck.
2021-03-09 19:37 [bug#47027] Disarchive package Timothy Sample
@ 2021-03-09 19:39 ` Timothy Sample
2021-03-09 19:39 ` [bug#47027] [PATCH 2/2] gnu: Add disarchive Timothy Sample
` (2 more replies)
0 siblings, 3 replies; 19+ messages in thread
From: Timothy Sample @ 2021-03-09 19:39 UTC (permalink / raw)
To: 47027; +Cc: Timothy Sample
* gnu/packages/guile-xyz.scm (guile-quickcheck): New variable.
---
gnu/packages/guile-xyz.scm | 28 +++++++++++++++++++++++++++-
1 file changed, 27 insertions(+), 1 deletion(-)
diff --git a/gnu/packages/guile-xyz.scm b/gnu/packages/guile-xyz.scm
index bd26010918..5f4329be11 100644
--- a/gnu/packages/guile-xyz.scm
+++ b/gnu/packages/guile-xyz.scm
@@ -22,7 +22,7 @@
;;; Copyright © 2018 Eric Bavier <bavier@member.fsf.org>
;;; Copyright © 2019 swedebugia <swedebugia@riseup.net>
;;; Copyright © 2019, 2020 Amar Singh <nly@disroot.org>
-;;; Copyright © 2019 Timothy Sample <samplet@ngyro.com>
+;;; Copyright © 2019, 2021 Timothy Sample <samplet@ngyro.com>
;;; Copyright © 2019, 2020 Martin Becze <mjbecze@riseup.net>
;;; Copyright © 2020 Evan Straw <evan.straw99@gmail.com>
;;; Copyright © 2020 Jack Hill <jackhill@jackhill.us>
@@ -4616,3 +4616,29 @@ binary which is smaller and faster to generate and parse. This package provides
a Guile implementation of CBOR.")
(home-page "https://inqlab.net/git/guile-cbor.git")
(license license:gpl3+)))
+
+(define-public guile-quickcheck
+ (package
+ (name "guile-quickcheck")
+ (version "0.1.0")
+ (source (origin
+ (method url-fetch)
+ (uri (string-append "https://files.ngyro.com/"
+ "guile-quickcheck/guile-quickcheck-"
+ version ".tar.gz"))
+ (sha256
+ (base32
+ "03mwi1l3354x52nar0zwhcm0x29yai9xjln4p4gbchwvx5dsr6fb"))))
+ (build-system gnu-build-system)
+ (native-inputs
+ `(("pkg-config" ,pkg-config)))
+ (inputs
+ `(("guile" ,guile-3.0)))
+ (home-page "https://ngyro.com/software/guile-quickcheck.html")
+ (synopsis "Randomized property-based testing for Guile")
+ (description "This Guile library provides tools for randomized,
+property-based testing. It follows closely the QuickCheck library
+written in Haskell. You can use it to define a property (a predicate
+with specifications for its inputs) and test it by generating many
+random inputs and seeing if it holds.")
+ (license license:gpl3+)))
--
2.30.1
^ permalink raw reply related [flat|nested] 19+ messages in thread
* [bug#47027] [PATCH 2/2] gnu: Add disarchive.
2021-03-09 19:39 ` [bug#47027] [PATCH 1/2] gnu: Add guile-quickcheck Timothy Sample
@ 2021-03-09 19:39 ` Timothy Sample
2021-03-10 10:23 ` Leo Prikler
2021-03-10 10:00 ` [bug#47027] [PATCH 1/2] gnu: Add guile-quickcheck Leo Prikler
2021-03-14 21:12 ` Maxime Devos
2 siblings, 1 reply; 19+ messages in thread
From: Timothy Sample @ 2021-03-09 19:39 UTC (permalink / raw)
To: 47027; +Cc: Timothy Sample
* gnu/packages/archival.scm: New file.
* gnu/local.mk (GNU_SYSTEM_MODULES): Add it.
---
gnu/local.mk | 1 +
gnu/packages/archival.scm | 60 +++++++++++++++++++++++++++++++++++++++
2 files changed, 61 insertions(+)
create mode 100644 gnu/packages/archival.scm
diff --git a/gnu/local.mk b/gnu/local.mk
index 3a516d487f..775080190e 100644
--- a/gnu/local.mk
+++ b/gnu/local.mk
@@ -88,6 +88,7 @@ GNU_SYSTEM_MODULES = \
%D%/packages/apl.scm \
%D%/packages/apr.scm \
%D%/packages/arcan.scm \
+ %D%/packages/archival.scm \
%D%/packages/aspell.scm \
%D%/packages/assembly.scm \
%D%/packages/astronomy.scm \
diff --git a/gnu/packages/archival.scm b/gnu/packages/archival.scm
new file mode 100644
index 0000000000..6bb1370664
--- /dev/null
+++ b/gnu/packages/archival.scm
@@ -0,0 +1,60 @@
+;;; GNU Guix --- Functional package management for GNU
+;;; Copyright © 2021 Timothy Sample <samplet@ngyro.com>
+;;;
+;;; 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 archival)
+ #:use-module (gnu packages compression)
+ #:use-module (gnu packages gnupg)
+ #:use-module (gnu packages guile)
+ #:use-module (gnu packages guile-xyz)
+ #:use-module (gnu packages pkg-config)
+ #:use-module (guix build-system gnu)
+ #:use-module (guix download)
+ #:use-module ((guix licenses) #:prefix license:)
+ #:use-module (guix packages))
+
+(define with-guile-3.0-latest
+ (package-input-rewriting `((,guile-3.0 . ,guile-3.0-latest)) #:deep? #f))
+
+(define-public disarchive
+ (package
+ (name "disarchive")
+ (version "0.1.0")
+ (source (origin
+ (method url-fetch)
+ (uri (string-append "https://files.ngyro.com/disarchive/"
+ "disarchive-" version ".tar.gz"))
+ (sha256
+ (base32
+ "0yvcfv2zlfqwmigd2xpzfkairz4w32b9gi1pbj5id55z21p0k49c"))))
+ (build-system gnu-build-system)
+ (native-inputs
+ `(("pkg-config" ,pkg-config)
+ ("guile-quickcheck" ,(with-guile-3.0-latest guile-quickcheck))))
+ (inputs
+ `(("guile" ,guile-3.0-latest)
+ ("guile-gcrypt" ,(with-guile-3.0-latest guile-gcrypt))
+ ("zlib" ,zlib)))
+ (home-page "https://ngyro.com/software/disarchive.html")
+ (synopsis "Software archive disassembler")
+ (description "Disarchive can disassemble software archives into data
+and metadata. The goal is to create a small amount of metadata that
+can be used to recreate a software archive bit-for-bit from the
+original files. For example, a software archive made using tar and
+Gzip will need to describe the order of files in the tarball and the
+compression parameters used by Gzip.")
+ (license license:gpl3+)))
--
2.30.1
^ permalink raw reply related [flat|nested] 19+ messages in thread
* [bug#47027] [PATCH 1/2] gnu: Add guile-quickcheck.
2021-03-09 19:39 ` [bug#47027] [PATCH 1/2] gnu: Add guile-quickcheck Timothy Sample
2021-03-09 19:39 ` [bug#47027] [PATCH 2/2] gnu: Add disarchive Timothy Sample
@ 2021-03-10 10:00 ` Leo Prikler
2021-03-14 21:12 ` Maxime Devos
2 siblings, 0 replies; 19+ messages in thread
From: Leo Prikler @ 2021-03-10 10:00 UTC (permalink / raw)
To: Timothy Sample, 47027
This package seems fine to add on its own.
W.r.t. the description I'd avoid overusing the word "library". In
particular, I'd like to compare it to ghc-quickcheck, which starts with
"QuickCheck is a library".
Perhaps something among the lines of
"Guile-Quickcheck is a library for random testing of program
properties inspired similar to ghc-quickcheck. You can use it to
express properties, which functions should satisfy, as Scheme code and
then check whether they hold in a large number of randomly generated
cases."
would make more sense?
Regards,
Leo
^ permalink raw reply [flat|nested] 19+ messages in thread
* [bug#47027] [PATCH 2/2] gnu: Add disarchive.
2021-03-09 19:39 ` [bug#47027] [PATCH 2/2] gnu: Add disarchive Timothy Sample
@ 2021-03-10 10:23 ` Leo Prikler
2021-03-11 22:17 ` [bug#47027] Disarchive package Ludovic Courtès
0 siblings, 1 reply; 19+ messages in thread
From: Leo Prikler @ 2021-03-10 10:23 UTC (permalink / raw)
To: Timothy Sample, 47027
I've checked and the package seems to build fine with Guile 3.0.2. I
think the bytecode mismatch happens, because Guix compiles stuff with
3.0.2 by default, but users have 3.0.5 in their system, which is not
bytecode-compatible. (As an exception, Guix itself seems to be
compiled with Guile 3.0.5 for performance reasons).
I think it would be fine to add with Guile 3.0.2, perhaps adding a note
that Guile 3.0.5 will effectively be required to use Guix interop? If
not, could you provide a script, that breaks in a way other than
recompiling the mismatching code?
As far as the location is concerned, I personally do not like adding
too many single-package files. Would it make sense to add this to
compression.scm (like gzip) or backup.scm (like libarchive)?
Regards,
Leo
^ permalink raw reply [flat|nested] 19+ messages in thread
* [bug#47027] Disarchive package
2021-03-10 10:23 ` Leo Prikler
@ 2021-03-11 22:17 ` Ludovic Courtès
2021-03-11 22:43 ` Tobias Geerinckx-Rice via Guix-patches via
2021-03-12 3:06 ` Timothy Sample
0 siblings, 2 replies; 19+ messages in thread
From: Ludovic Courtès @ 2021-03-11 22:17 UTC (permalink / raw)
To: Leo Prikler; +Cc: Timothy Sample, 47027
Hi!
Leo Prikler <leo.prikler@student.tugraz.at> skribis:
> I've checked and the package seems to build fine with Guile 3.0.2. I
> think the bytecode mismatch happens, because Guix compiles stuff with
> 3.0.2 by default, but users have 3.0.5 in their system, which is not
> bytecode-compatible. (As an exception, Guix itself seems to be
> compiled with Guile 3.0.5 for performance reasons).
>
> I think it would be fine to add with Guile 3.0.2, perhaps adding a note
> that Guile 3.0.5 will effectively be required to use Guix interop? If
> not, could you provide a script, that breaks in a way other than
> recompiling the mismatching code?
I tend to agree here: I don’t think ‘guile-3.0-latest’ is needed in this
case. The only case where you need it is if it depends on a library,
such as Guix, that is itself built with ‘guile-3.0-latest’.
> As far as the location is concerned, I personally do not like adding
> too many single-package files. Would it make sense to add this to
> compression.scm (like gzip) or backup.scm (like libarchive)?
Maybe there’ll be other packages eventually in archival.scm, like the
SWH Python code? It’s fine with me, but I don’t have a strong opinion.
Ludo’.
^ permalink raw reply [flat|nested] 19+ messages in thread
* [bug#47027] Disarchive package
2021-03-11 22:17 ` [bug#47027] Disarchive package Ludovic Courtès
@ 2021-03-11 22:43 ` Tobias Geerinckx-Rice via Guix-patches via
2021-03-12 3:06 ` Timothy Sample
1 sibling, 0 replies; 19+ messages in thread
From: Tobias Geerinckx-Rice via Guix-patches via @ 2021-03-11 22:43 UTC (permalink / raw)
To: Ludovic Courtès; +Cc: samplet, leo.prikler, 47027
[-- Attachment #1: Type: text/plain, Size: 183 bytes --]
Ludovic Courtès 写道:
> Maybe there’ll be other packages eventually in archival.scm,
> like the
> SWH Python code?
Yes, that's the intention.
Kind regards,
T G-R
[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 247 bytes --]
^ permalink raw reply [flat|nested] 19+ messages in thread
* [bug#47027] Disarchive package
2021-03-11 22:17 ` [bug#47027] Disarchive package Ludovic Courtès
2021-03-11 22:43 ` Tobias Geerinckx-Rice via Guix-patches via
@ 2021-03-12 3:06 ` Timothy Sample
2021-03-12 10:08 ` Leo Prikler
2021-03-12 16:45 ` Ludovic Courtès
1 sibling, 2 replies; 19+ messages in thread
From: Timothy Sample @ 2021-03-12 3:06 UTC (permalink / raw)
To: Ludovic Courtès; +Cc: Leo Prikler, 47027
Hi,
Thanks Leo for the review! (And to Ludo and Tobias for follow ups.)
Ludovic Courtès <ludo@gnu.org> writes:
> Leo Prikler <leo.prikler@student.tugraz.at> skribis:
>
>> I've checked and the package seems to build fine with Guile 3.0.2. I
>> think the bytecode mismatch happens, because Guix compiles stuff with
>> 3.0.2 by default, but users have 3.0.5 in their system, which is not
>> bytecode-compatible. (As an exception, Guix itself seems to be
>> compiled with Guile 3.0.5 for performance reasons).
>>
>> I think it would be fine to add with Guile 3.0.2, perhaps adding a note
>> that Guile 3.0.5 will effectively be required to use Guix interop? If
>> not, could you provide a script, that breaks in a way other than
>> recompiling the mismatching code?
>
> I tend to agree here: I don’t think ‘guile-3.0-latest’ is needed in this
> case. The only case where you need it is if it depends on a library,
> such as Guix, that is itself built with ‘guile-3.0-latest’.
Well, now I’m second guessing myself. :)
It is just the auto compilation notes and warnings that I’m worried
about. The module closure of “swh.scm” works fine on Guile 3.0.2.
Eventually, the daemon will invoke Disarchive via “builtin:download” and
“perform-download.scm”. I intend to use the Scheme interface there,
which means Disarchive will be runing on Guile 3.0.5. For that, it
would be preferable to have a Guile 3.0.5 version of Disarchive, right?
On the other hand, when using Disarchive to extract metadata (e.g., with
Cuirass), the SWH code is not needed at all.
I will resurrect my patch for calling Disarchive from Guix, and come
back to this when I know exactly what kind of package I need for that to
work smoothly.
>> As far as the location is concerned, I personally do not like adding
>> too many single-package files. Would it make sense to add this to
>> compression.scm (like gzip) or backup.scm (like libarchive)?
>
> Maybe there’ll be other packages eventually in archival.scm, like the
> SWH Python code? It’s fine with me, but I don’t have a strong opinion.
I don’t feel strongly about it either. There’s other software besides
Disarchive and SWH that could be called “archival”, and I think it’s
more accurate than the other options.
-- Tim
^ permalink raw reply [flat|nested] 19+ messages in thread
* [bug#47027] Disarchive package
2021-03-12 3:06 ` Timothy Sample
@ 2021-03-12 10:08 ` Leo Prikler
2021-03-12 16:45 ` Ludovic Courtès
1 sibling, 0 replies; 19+ messages in thread
From: Leo Prikler @ 2021-03-12 10:08 UTC (permalink / raw)
To: Timothy Sample, Ludovic Courtès; +Cc: 47027
Hi,
Am Donnerstag, den 11.03.2021, 22:06 -0500 schrieb Timothy Sample:
> It is just the auto compilation notes and warnings that I’m worried
> about. The module closure of “swh.scm” works fine on Guile 3.0.2.
>
> Eventually, the daemon will invoke Disarchive via “builtin:download”
> and
> “perform-download.scm”. I intend to use the Scheme interface there,
> which means Disarchive will be runing on Guile 3.0.5. For that, it
> would be preferable to have a Guile 3.0.5 version of Disarchive,
> right?
Guix offers package transformations on a command line/code level.
Having packaged disarchival for Guile 3.0.2, it should be trivial to
provide a variant for Guix, that uses Guile 3.0.5.
Looking at the package description for Guix itself, it does not seem as
though an exception would be needed, though. All of its dependencies
seem to "build and link" fine with Guile 3.0.2 even though Guix uses
3.0.5. Perhaps it's because you're calling into Guix and thus forming
a dependency cycle or perhaps Guix is really good at hiding such
messages from the user otherwise (not that I know of any particularly
large effort to do so).
> > > As far as the location is concerned, I personally do not like
> > > adding
> > > too many single-package files. Would it make sense to add this
> > > to
> > > compression.scm (like gzip) or backup.scm (like libarchive)?
> >
> > Maybe there’ll be other packages eventually in archival.scm, like
> > the
> > SWH Python code? It’s fine with me, but I don’t have a strong
> > opinion.
>
> I don’t feel strongly about it either. There’s other software
> besides
> Disarchive and SWH that could be called “archival”, and I think it’s
> more accurate than the other options.
I think in that case it'd be fine, but OTOH we group libraries by
programming language and prefix them as well. For instance, a python
library, that communicates with SWH would probably go to python-web or
python-xyz and be prefixed with python-. Likewise, if disarchive is
not supposed to be primarily used as a command line tool, I think
putting it into guile-xyz as "guile-disarchive" makes more sense.
WDYT?
Regards,
Leo
^ permalink raw reply [flat|nested] 19+ messages in thread
* [bug#47027] Disarchive package
2021-03-12 3:06 ` Timothy Sample
2021-03-12 10:08 ` Leo Prikler
@ 2021-03-12 16:45 ` Ludovic Courtès
2021-03-21 10:29 ` Ludovic Courtès
1 sibling, 1 reply; 19+ messages in thread
From: Ludovic Courtès @ 2021-03-12 16:45 UTC (permalink / raw)
To: Timothy Sample; +Cc: Leo Prikler, 47027
Hello!
Timothy Sample <samplet@ngyro.com> skribis:
> Ludovic Courtès <ludo@gnu.org> writes:
>
>> Leo Prikler <leo.prikler@student.tugraz.at> skribis:
>>
>>> I've checked and the package seems to build fine with Guile 3.0.2. I
>>> think the bytecode mismatch happens, because Guix compiles stuff with
>>> 3.0.2 by default, but users have 3.0.5 in their system, which is not
>>> bytecode-compatible. (As an exception, Guix itself seems to be
>>> compiled with Guile 3.0.5 for performance reasons).
>>>
>>> I think it would be fine to add with Guile 3.0.2, perhaps adding a note
>>> that Guile 3.0.5 will effectively be required to use Guix interop? If
>>> not, could you provide a script, that breaks in a way other than
>>> recompiling the mismatching code?
>>
>> I tend to agree here: I don’t think ‘guile-3.0-latest’ is needed in this
>> case. The only case where you need it is if it depends on a library,
>> such as Guix, that is itself built with ‘guile-3.0-latest’.
>
> Well, now I’m second guessing myself. :)
>
> It is just the auto compilation notes and warnings that I’m worried
> about. The module closure of “swh.scm” works fine on Guile 3.0.2.
>
> Eventually, the daemon will invoke Disarchive via “builtin:download” and
> “perform-download.scm”. I intend to use the Scheme interface there,
> which means Disarchive will be runing on Guile 3.0.5. For that, it
> would be preferable to have a Guile 3.0.5 version of Disarchive, right?
No, that’s fine. Guile 3.0.5 can run 3.0.2 bytecode without any
warnings; what yields warnings is doing it the other way around.
Anyway, we can always revisit this if problems come up.
> On the other hand, when using Disarchive to extract metadata (e.g., with
> Cuirass), the SWH code is not needed at all.
>
> I will resurrect my patch for calling Disarchive from Guix, and come
> back to this when I know exactly what kind of package I need for that to
> work smoothly.
Yay!
>>> As far as the location is concerned, I personally do not like adding
>>> too many single-package files. Would it make sense to add this to
>>> compression.scm (like gzip) or backup.scm (like libarchive)?
>>
>> Maybe there’ll be other packages eventually in archival.scm, like the
>> SWH Python code? It’s fine with me, but I don’t have a strong opinion.
>
> I don’t feel strongly about it either. There’s other software besides
> Disarchive and SWH that could be called “archival”, and I think it’s
> more accurate than the other options.
Dunno maybe you can do as Leo suggests by putting it in guile-xyz.scm or
some such.
Thanks!
Ludo’.
^ permalink raw reply [flat|nested] 19+ messages in thread
* [bug#47027] [PATCH 1/2] gnu: Add guile-quickcheck.
2021-03-09 19:39 ` [bug#47027] [PATCH 1/2] gnu: Add guile-quickcheck Timothy Sample
2021-03-09 19:39 ` [bug#47027] [PATCH 2/2] gnu: Add disarchive Timothy Sample
2021-03-10 10:00 ` [bug#47027] [PATCH 1/2] gnu: Add guile-quickcheck Leo Prikler
@ 2021-03-14 21:12 ` Maxime Devos
2021-03-17 20:52 ` [bug#47027] Disarchive package Ludovic Courtès
2 siblings, 1 reply; 19+ messages in thread
From: Maxime Devos @ 2021-03-14 21:12 UTC (permalink / raw)
To: Timothy Sample, 47027
[-- Attachment #1: Type: text/plain, Size: 481 bytes --]
On Tue, 2021-03-09 at 14:39 -0500, Timothy Sample wrote:
> [...]
> + (native-inputs
> + `(("pkg-config" ,pkg-config)))
> + (inputs
> + `(("guile" ,guile-3.0)))
Shouldn't the "guile" input be included in the native-inputs
as well (perhaps only native-inputs suffices), for cross-compilation?
Guile's compiled .go are architecture-dependent. (Make sure the
--target= option is passed to "guild compile" in the Makefile.am
if it isn't already.)
Maxime.
[-- Attachment #2: This is a digitally signed message part --]
[-- Type: application/pgp-signature, Size: 260 bytes --]
^ permalink raw reply [flat|nested] 19+ messages in thread
* [bug#47027] Disarchive package
2021-03-14 21:12 ` Maxime Devos
@ 2021-03-17 20:52 ` Ludovic Courtès
0 siblings, 0 replies; 19+ messages in thread
From: Ludovic Courtès @ 2021-03-17 20:52 UTC (permalink / raw)
To: Maxime Devos; +Cc: Timothy Sample, 47027
Hi,
Maxime Devos <maximedevos@telenet.be> skribis:
> On Tue, 2021-03-09 at 14:39 -0500, Timothy Sample wrote:
>> [...]
>> + (native-inputs
>> + `(("pkg-config" ,pkg-config)))
>> + (inputs
>> + `(("guile" ,guile-3.0)))
>
> Shouldn't the "guile" input be included in the native-inputs
> as well (perhaps only native-inputs suffices), for cross-compilation?
Yes it should, good point.
Thank you.
Ludo’, impatient to see Disarchive pushed. :-)
^ permalink raw reply [flat|nested] 19+ messages in thread
* [bug#47027] Disarchive package
2021-03-12 16:45 ` Ludovic Courtès
@ 2021-03-21 10:29 ` Ludovic Courtès
2021-03-21 11:10 ` Leo Prikler
0 siblings, 1 reply; 19+ messages in thread
From: Ludovic Courtès @ 2021-03-21 10:29 UTC (permalink / raw)
To: Timothy Sample; +Cc: Leo Prikler, 47027
Ping! :-)
Ludovic Courtès <ludo@gnu.org> skribis:
> Hello!
>
> Timothy Sample <samplet@ngyro.com> skribis:
>
>> Ludovic Courtès <ludo@gnu.org> writes:
>>
>>> Leo Prikler <leo.prikler@student.tugraz.at> skribis:
>>>
>>>> I've checked and the package seems to build fine with Guile 3.0.2. I
>>>> think the bytecode mismatch happens, because Guix compiles stuff with
>>>> 3.0.2 by default, but users have 3.0.5 in their system, which is not
>>>> bytecode-compatible. (As an exception, Guix itself seems to be
>>>> compiled with Guile 3.0.5 for performance reasons).
>>>>
>>>> I think it would be fine to add with Guile 3.0.2, perhaps adding a note
>>>> that Guile 3.0.5 will effectively be required to use Guix interop? If
>>>> not, could you provide a script, that breaks in a way other than
>>>> recompiling the mismatching code?
>>>
>>> I tend to agree here: I don’t think ‘guile-3.0-latest’ is needed in this
>>> case. The only case where you need it is if it depends on a library,
>>> such as Guix, that is itself built with ‘guile-3.0-latest’.
>>
>> Well, now I’m second guessing myself. :)
>>
>> It is just the auto compilation notes and warnings that I’m worried
>> about. The module closure of “swh.scm” works fine on Guile 3.0.2.
>>
>> Eventually, the daemon will invoke Disarchive via “builtin:download” and
>> “perform-download.scm”. I intend to use the Scheme interface there,
>> which means Disarchive will be runing on Guile 3.0.5. For that, it
>> would be preferable to have a Guile 3.0.5 version of Disarchive, right?
>
> No, that’s fine. Guile 3.0.5 can run 3.0.2 bytecode without any
> warnings; what yields warnings is doing it the other way around.
> Anyway, we can always revisit this if problems come up.
>
>> On the other hand, when using Disarchive to extract metadata (e.g., with
>> Cuirass), the SWH code is not needed at all.
>>
>> I will resurrect my patch for calling Disarchive from Guix, and come
>> back to this when I know exactly what kind of package I need for that to
>> work smoothly.
>
> Yay!
>
>>>> As far as the location is concerned, I personally do not like adding
>>>> too many single-package files. Would it make sense to add this to
>>>> compression.scm (like gzip) or backup.scm (like libarchive)?
>>>
>>> Maybe there’ll be other packages eventually in archival.scm, like the
>>> SWH Python code? It’s fine with me, but I don’t have a strong opinion.
>>
>> I don’t feel strongly about it either. There’s other software besides
>> Disarchive and SWH that could be called “archival”, and I think it’s
>> more accurate than the other options.
>
> Dunno maybe you can do as Leo suggests by putting it in guile-xyz.scm or
> some such.
>
> Thanks!
>
> Ludo’.
^ permalink raw reply [flat|nested] 19+ messages in thread
* [bug#47027] Disarchive package
2021-03-21 10:29 ` Ludovic Courtès
@ 2021-03-21 11:10 ` Leo Prikler
2021-03-21 14:13 ` Timothy Sample
0 siblings, 1 reply; 19+ messages in thread
From: Leo Prikler @ 2021-03-21 11:10 UTC (permalink / raw)
To: Ludovic Courtès, Timothy Sample; +Cc: 47027
Am Sonntag, den 21.03.2021, 11:29 +0100 schrieb Ludovic Courtès:
> Ping! :-)
I've pushed guile-quickcheck as
4cd88522f233dcb9affa3d3b0eada154439487c1, so we now only need to
discuss what to do with (guile-)?disarchive.
> > Hello!
> >
> > Timothy Sample <samplet@ngyro.com> skribis:
> >
> > > Ludovic Courtès <ludo@gnu.org> writes:
> > >
> > > > Leo Prikler <leo.prikler@student.tugraz.at> skribis:
> > > >
> > > > > I've checked and the package seems to build fine with Guile
> > > > > 3.0.2. I
> > > > > think the bytecode mismatch happens, because Guix compiles
> > > > > stuff with
> > > > > 3.0.2 by default, but users have 3.0.5 in their system, which
> > > > > is not
> > > > > bytecode-compatible. (As an exception, Guix itself seems to
> > > > > be
> > > > > compiled with Guile 3.0.5 for performance reasons).
> > > > >
> > > > > I think it would be fine to add with Guile 3.0.2, perhaps
> > > > > adding a note
> > > > > that Guile 3.0.5 will effectively be required to use Guix
> > > > > interop? If
> > > > > not, could you provide a script, that breaks in a way other
> > > > > than
> > > > > recompiling the mismatching code?
> > > >
> > > > I tend to agree here: I don’t think ‘guile-3.0-latest’ is
> > > > needed in this
> > > > case. The only case where you need it is if it depends on a
> > > > library,
> > > > such as Guix, that is itself built with ‘guile-3.0-latest’.
> > >
> > > Well, now I’m second guessing myself. :)
> > >
> > > It is just the auto compilation notes and warnings that I’m
> > > worried
> > > about. The module closure of “swh.scm” works fine on Guile
> > > 3.0.2.
> > >
> > > Eventually, the daemon will invoke Disarchive via
> > > “builtin:download” and
> > > “perform-download.scm”. I intend to use the Scheme interface
> > > there,
> > > which means Disarchive will be runing on Guile 3.0.5. For that,
> > > it
> > > would be preferable to have a Guile 3.0.5 version of Disarchive,
> > > right?
> >
> > No, that’s fine. Guile 3.0.5 can run 3.0.2 bytecode without any
> > warnings; what yields warnings is doing it the other way around.
> > Anyway, we can always revisit this if problems come up.
> >
> > > On the other hand, when using Disarchive to extract metadata
> > > (e.g., with
> > > Cuirass), the SWH code is not needed at all.
> > >
> > > I will resurrect my patch for calling Disarchive from Guix, and
> > > come
> > > back to this when I know exactly what kind of package I need for
> > > that to
> > > work smoothly.
> >
> > Yay!
> >
> > > > > As far as the location is concerned, I personally do not like
> > > > > adding
> > > > > too many single-package files. Would it make sense to add
> > > > > this to
> > > > > compression.scm (like gzip) or backup.scm (like libarchive)?
> > > >
> > > > Maybe there’ll be other packages eventually in archival.scm,
> > > > like the
> > > > SWH Python code? It’s fine with me, but I don’t have a strong
> > > > opinion.
> > >
> > > I don’t feel strongly about it either. There’s other software
> > > besides
> > > Disarchive and SWH that could be called “archival”, and I think
> > > it’s
> > > more accurate than the other options.
> >
> > Dunno maybe you can do as Leo suggests by putting it in guile-
> > xyz.scm or
> > some such.
> >
> > Thanks!
> >
> > Ludo’.
^ permalink raw reply [flat|nested] 19+ messages in thread
* [bug#47027] Disarchive package
2021-03-21 11:10 ` Leo Prikler
@ 2021-03-21 14:13 ` Timothy Sample
2021-03-21 14:59 ` Maxime Devos
2021-03-21 16:59 ` Ludovic Courtès
0 siblings, 2 replies; 19+ messages in thread
From: Timothy Sample @ 2021-03-21 14:13 UTC (permalink / raw)
To: Leo Prikler; +Cc: Ludovic Courtès, 47027
Hi,
Leo Prikler <leo.prikler@student.tugraz.at> writes:
> Am Sonntag, den 21.03.2021, 11:29 +0100 schrieb Ludovic Courtès:
>> Ping! :-)
> I've pushed guile-quickcheck as
> 4cd88522f233dcb9affa3d3b0eada154439487c1, so we now only need to
> discuss what to do with (guile-)?disarchive.
Hey thanks Leo!
I will put Disarchive in “backup.scm” with Guile 3.0.2. In my eyes, it
is a regular command-line program that happens to have a Scheme
interface. (Thanks Ludo – I didn’t know Guile 3.0.5 was fine with 3.0.2
bytecode).
I need to release a new version though, hence the delay. While working
on the download code, I wanted some changes to Disarchive. Now, it lets
Guix figure out how to download the Disarchive specification file and
the directory from SWH. This allows Guix to reuse all of its
specialized HTTP code, simplifies Disarchive, and makes it more suitable
for use outside of Guix (by Nix or SWH or whatever). It all works here
with a database I set up at <https://disarchive.ngyro.com>. Right now,
I am finishing one last UI tweak (stopping Disarchive from printing a
backtrace when the directory does not exist in the SWH archive). Then,
I will release 0.2.0 and push this patch with the new version. Then –
finally – we can talk about using it.
Thanks for your continued patience! :)
-- Tim
^ permalink raw reply [flat|nested] 19+ messages in thread
* [bug#47027] Disarchive package
2021-03-21 14:13 ` Timothy Sample
@ 2021-03-21 14:59 ` Maxime Devos
2021-03-21 16:59 ` Ludovic Courtès
1 sibling, 0 replies; 19+ messages in thread
From: Maxime Devos @ 2021-03-21 14:59 UTC (permalink / raw)
To: Timothy Sample, Leo Prikler; +Cc: Ludovic Courtès, 47027
[-- Attachment #1: Type: text/plain, Size: 312 bytes --]
On Sun, 2021-03-21 at 10:13 -0400, Timothy Sample wrote:
> Hi,
>
> [...] It all works here
> with a database I set up at <https://disarchive.ngyro.com>;.
That web page is saying ‘403 Forbidden --- nginx’.
> Thanks for your continued patience! :)
Thank you for your continued work,
Maxime.
[-- Attachment #2: This is a digitally signed message part --]
[-- Type: application/pgp-signature, Size: 260 bytes --]
^ permalink raw reply [flat|nested] 19+ messages in thread
* [bug#47027] Disarchive package
2021-03-21 14:13 ` Timothy Sample
2021-03-21 14:59 ` Maxime Devos
@ 2021-03-21 16:59 ` Ludovic Courtès
2021-03-23 4:45 ` bug#47027: " Timothy Sample
1 sibling, 1 reply; 19+ messages in thread
From: Ludovic Courtès @ 2021-03-21 16:59 UTC (permalink / raw)
To: Timothy Sample; +Cc: Leo Prikler, 47027
Howdy!
Timothy Sample <samplet@ngyro.com> skribis:
> I will put Disarchive in “backup.scm” with Guile 3.0.2. In my eyes, it
> is a regular command-line program that happens to have a Scheme
> interface. (Thanks Ludo – I didn’t know Guile 3.0.5 was fine with 3.0.2
> bytecode).
Alright!
> I need to release a new version though, hence the delay. While working
> on the download code, I wanted some changes to Disarchive. Now, it lets
> Guix figure out how to download the Disarchive specification file and
> the directory from SWH. This allows Guix to reuse all of its
> specialized HTTP code, simplifies Disarchive, and makes it more suitable
> for use outside of Guix (by Nix or SWH or whatever). It all works here
> with a database I set up at <https://disarchive.ngyro.com>. Right now,
> I am finishing one last UI tweak (stopping Disarchive from printing a
> backtrace when the directory does not exist in the SWH archive). Then,
> I will release 0.2.0 and push this patch with the new version. Then –
> finally – we can talk about using it.
That sounds great—always improving.
> Thanks for your continued patience! :)
Did you mean my continued impatience? :-)
Thanks for the great quality work, as always!
Ludo’.
^ permalink raw reply [flat|nested] 19+ messages in thread
* bug#47027: Disarchive package
2021-03-21 16:59 ` Ludovic Courtès
@ 2021-03-23 4:45 ` Timothy Sample
2021-03-23 11:01 ` [bug#47027] " Ludovic Courtès
0 siblings, 1 reply; 19+ messages in thread
From: Timothy Sample @ 2021-03-23 4:45 UTC (permalink / raw)
To: Ludovic Courtès; +Cc: Leo Prikler, 47027-done
Hey,
Timothy Sample <samplet@ngyro.com> writes:
> Right now, I am finishing one last UI tweak (stopping Disarchive from
> printing a backtrace when the directory does not exist in the SWH
> archive). Then, I will release 0.2.0 and push this patch with the
> new version.
Done and pushed!
> Then – finally – we can talk about using it.
See <https://issues.guix.gnu.org/47336>.
-- Tim
^ permalink raw reply [flat|nested] 19+ messages in thread
* [bug#47027] Disarchive package
2021-03-23 4:45 ` bug#47027: " Timothy Sample
@ 2021-03-23 11:01 ` Ludovic Courtès
0 siblings, 0 replies; 19+ messages in thread
From: Ludovic Courtès @ 2021-03-23 11:01 UTC (permalink / raw)
To: Timothy Sample; +Cc: Leo Prikler, 47027-done
Hi Timothy,
Timothy Sample <samplet@ngyro.com> skribis:
> Timothy Sample <samplet@ngyro.com> writes:
>
>> Right now, I am finishing one last UI tweak (stopping Disarchive from
>> printing a backtrace when the directory does not exist in the SWH
>> archive). Then, I will release 0.2.0 and push this patch with the
>> new version.
>
> Done and pushed!
>
>> Then – finally – we can talk about using it.
>
> See <https://issues.guix.gnu.org/47336>.
Woohoo, congrats on the new release and thank you for all this!
Ludo’.
^ permalink raw reply [flat|nested] 19+ messages in thread
end of thread, other threads:[~2021-03-23 11:03 UTC | newest]
Thread overview: 19+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2021-03-09 19:37 [bug#47027] Disarchive package Timothy Sample
2021-03-09 19:39 ` [bug#47027] [PATCH 1/2] gnu: Add guile-quickcheck Timothy Sample
2021-03-09 19:39 ` [bug#47027] [PATCH 2/2] gnu: Add disarchive Timothy Sample
2021-03-10 10:23 ` Leo Prikler
2021-03-11 22:17 ` [bug#47027] Disarchive package Ludovic Courtès
2021-03-11 22:43 ` Tobias Geerinckx-Rice via Guix-patches via
2021-03-12 3:06 ` Timothy Sample
2021-03-12 10:08 ` Leo Prikler
2021-03-12 16:45 ` Ludovic Courtès
2021-03-21 10:29 ` Ludovic Courtès
2021-03-21 11:10 ` Leo Prikler
2021-03-21 14:13 ` Timothy Sample
2021-03-21 14:59 ` Maxime Devos
2021-03-21 16:59 ` Ludovic Courtès
2021-03-23 4:45 ` bug#47027: " Timothy Sample
2021-03-23 11:01 ` [bug#47027] " Ludovic Courtès
2021-03-10 10:00 ` [bug#47027] [PATCH 1/2] gnu: Add guile-quickcheck Leo Prikler
2021-03-14 21:12 ` Maxime Devos
2021-03-17 20:52 ` [bug#47027] Disarchive package Ludovic Courtès
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).