From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from mp11.migadu.com ([2001:41d0:8:6d80::]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits)) by ms0.migadu.com with LMTPS id yPZKCnqzT2IWggEAgWs5BA (envelope-from ) for ; Fri, 08 Apr 2022 06:00:58 +0200 Received: from aspmx1.migadu.com ([2001:41d0:8:6d80::]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits)) by mp11.migadu.com with LMTPS id MK6IB3qzT2J89gAA9RJhRA (envelope-from ) for ; Fri, 08 Apr 2022 06:00:58 +0200 Received: from lists.gnu.org (lists.gnu.org [209.51.188.17]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by aspmx1.migadu.com (Postfix) with ESMTPS id 12B9B2A778 for ; Fri, 8 Apr 2022 06:00:56 +0200 (CEST) Received: from localhost ([::1]:39486 helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1ncfnr-00037p-DL for larch@yhetil.org; Fri, 08 Apr 2022 00:00:55 -0400 Received: from eggs.gnu.org ([2001:470:142:3::10]:42848) by lists.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.90_1) (envelope-from ) id 1ncfn9-00037c-Dr for help-guix@gnu.org; Fri, 08 Apr 2022 00:00:11 -0400 Received: from mx1.riseup.net ([198.252.153.129]:44296) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.90_1) (envelope-from ) id 1ncfn6-0001cK-EF for help-guix@gnu.org; Fri, 08 Apr 2022 00:00:10 -0400 Received: from fews2.riseup.net (fews2-pn.riseup.net [10.0.1.84]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (2048 bits) server-digest SHA256 client-signature RSA-PSS (2048 bits) client-digest SHA256) (Client CN "mail.riseup.net", Issuer "R3" (not verified)) by mx1.riseup.net (Postfix) with ESMTPS id 4KZPds53tczDsLK; Thu, 7 Apr 2022 20:59:45 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=riseup.net; s=squak; t=1649390406; bh=8Ccb5asGQK56qnRtRk8+KGSrYCkDhQha3xms7N2I9VA=; h=Date:From:To:Cc:Subject:In-Reply-To:References:From; b=PQx9EFX/Z5OddDBcJvz9GIfLIOrlNmjgXnqzYgkifrK2YCuO11FBZjrfwf3uMwbIb UAejUewYWLxOtD5d4VYU/QL/7whZps2wAaOF+ZsT9+J861rNCFO1LUTE5OlXgbYURF k+52vcGzuzxXTjzGJ/siU8FtXvqqflNEAQ8Z52eE= X-Riseup-User-ID: D001B459BC54C8A868E5CA76F00878219B1EB4E2AE8A237C23D93B0B6817DFCD Received: from [127.0.0.1] (localhost [127.0.0.1]) by fews2.riseup.net (Postfix) with ESMTPSA id 4KZPdr2kVvz1yQc; Thu, 7 Apr 2022 20:59:44 -0700 (PDT) Date: Fri, 8 Apr 2022 05:59:41 +0200 From: raingloom To: =?UTF-8?B?Q8Ohc3Npbw==?= Tavares Subject: Re: Packaging existing software for Guix Message-ID: <20220408055941.36085b26@riseup.net> In-Reply-To: References: <875ynw8zra.fsf@elephly.net> MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: quoted-printable Received-SPF: pass client-ip=198.252.153.129; envelope-from=raingloom@riseup.net; helo=mx1.riseup.net X-Spam_score_int: -27 X-Spam_score: -2.8 X-Spam_bar: -- X-Spam_report: (-2.8 / 5.0 requ) BAYES_00=-1.9, DKIM_SIGNED=0.1, DKIM_VALID=-0.1, DKIM_VALID_AU=-0.1, DKIM_VALID_EF=-0.1, RCVD_IN_DNSWL_LOW=-0.7, RCVD_IN_MSPIKE_H3=0.001, RCVD_IN_MSPIKE_WL=0.001, SPF_HELO_PASS=-0.001, SPF_PASS=-0.001, T_SCC_BODY_TEXT_LINE=-0.01 autolearn=ham autolearn_force=no X-Spam_action: no action X-BeenThere: help-guix@gnu.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: help-guix@gnu.org Errors-To: help-guix-bounces+larch=yhetil.org@gnu.org Sender: "Help-Guix" X-Migadu-Flow: FLOW_IN X-Migadu-To: larch@yhetil.org X-Migadu-Country: US ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=yhetil.org; s=key1; t=1649390457; h=from:from:sender:sender:reply-to:subject:subject:date:date: message-id:message-id:to:to:cc:cc:mime-version:mime-version: content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references:list-id:list-help: list-unsubscribe:list-subscribe:list-post:dkim-signature; bh=UU3UkLR+Zwxk3vhonrLxHKc9ijILmOSSUjli9P7Ko3c=; b=I3XOUsQGy3V54kf5Fa2wrbQFC6+GDvinwM4g+mKqM8VRR4wMY/ILX8sjD1cAcDrrtP8DsB b45g0mVSZfMaQOus2GiXfKLiTrnbI5ifiavo4wXz5+3P5Pw/rn9Ej7sGcrCAVxe9ZptD2r lxmYIffVTDj+FXRRxYOv46f3BS4diMOxnqYqj+zI4i+5WB7y8x4pyLySDp7/FiM31Dt4XQ CyOy/QAtAAEtD0judRKhEenvYPL+rl1V2qrgJwTEUtu0h4GCP8GwrGr0nW3Ka9+mF5ZpxZ Sg0ig828XXvraytJUvQ+yKMXAtB8FkRFaS7WVfiBsk4Tf1aVR2uC10G/Zt8mkQ== ARC-Seal: i=1; s=key1; d=yhetil.org; t=1649390457; a=rsa-sha256; cv=none; b=NxY4SnyNdZyA16S68qZ78ieA1D3tM0PDGQruwZwC7ND/pVmpLB2Qjq+LXsCbAXJz11Xz3F S+RX1EC9NsXb4r3irzeAy6LknIk4OCGWDDZv4S5638gzMMSdYyYw++hhNrb2Mz2I0o2EWG gJnrJ1THGwhU06S3/VU9EGXab0JmhM8mkYtivc7chF46ZDGlsXe/LV5PRNhWeSXI8DxJHy 7216FX7NxeCREH0s0hpEFdWWZ6h9cmkX4vGdzBkWWwgXBkfyybnOHrortHZ4Sc4hcHlJGq caUVdr5koxEkPqqMXH1KmgkLe2dd3YzbnA0epAX014sUFG7QA+AAbTDD7rAhUA== ARC-Authentication-Results: i=1; aspmx1.migadu.com; dkim=fail ("headers rsa verify failed") header.d=riseup.net header.s=squak header.b="PQx9EFX/"; dmarc=fail reason="SPF not aligned (relaxed)" header.from=riseup.net (policy=none); spf=pass (aspmx1.migadu.com: domain of "help-guix-bounces+larch=yhetil.org@gnu.org" designates 209.51.188.17 as permitted sender) smtp.mailfrom="help-guix-bounces+larch=yhetil.org@gnu.org" X-Migadu-Spam-Score: 5.53 Authentication-Results: aspmx1.migadu.com; dkim=fail ("headers rsa verify failed") header.d=riseup.net header.s=squak header.b="PQx9EFX/"; dmarc=fail reason="SPF not aligned (relaxed)" header.from=riseup.net (policy=none); spf=pass (aspmx1.migadu.com: domain of "help-guix-bounces+larch=yhetil.org@gnu.org" designates 209.51.188.17 as permitted sender) smtp.mailfrom="help-guix-bounces+larch=yhetil.org@gnu.org" X-Migadu-Queue-Id: 12B9B2A778 X-Spam-Score: 5.53 X-Migadu-Scanner: scn0.migadu.com X-TUID: RyfvZs85earP For build system, the best is to look at the source. eg.: if you see a `meson.build` file, it's most likely going to need meson-build-system, etc. Read through the list of available build systems in the Guix manual and see which one matches. For hashes, just use the output of guix hash /dev/null. Guix will complain that the hashes don't match, showing the expected hash and the result, just copy the latter into your package. Do *not* copy the hash from another package, because Guix will blindly trust it and if for some reason the source of that package is also in your store, it will use that. You would be building that other package thinking that you were building the one you were actually working on. It's not fun to debug that situation. The "official" way to get the hash is actually to use `guix download` but I'm always too lazy to figure out how to use that with git repos. Maybe now it's easier to use it for them. For tarballs and such I do use it. On Mon, 4 Apr 2022 21:17:50 +0000 C=C3=A1ssio Tavares wrote: > Hi, and thanks for your patient guidance, Ricardo! > So . . . >=20 > My progress >=20 > I'm trying to follow your (and @Vagrant > Cascadian 's) > suggestions, looking into the ` guix.git/gnu/packages/*` files for > examples of package definitions, reading the development versions of > the manual and the cookbook, and also experimenting on my own. With > that I could find out, for the package I'm trying to port, what > build-system to use, how to specify the origin and the commit, and > how to get the hash for that commit. So, some progress, but there are > still things to debug. >=20 > Your challenge >=20 > > 5. Is there a relatively simple way to port packages from other > > distros =20 > > > into Guix? Could this be an automated process? =20 > > > > Not from other distros but from upstream repositories; see =E2=80=9Cguix > > import=E2=80=9D. =20 >=20 >=20 > I'm looking into `guix import`, and made a few experiments with it. > And ... >=20 >=20 > > If you want a fun project you could work on extending =E2=80=9Cguix > > import=E2=80=9D to import from distro archives. =20 >=20 >=20 > Interesting challenge =E2=94=80 I'd like to be able to accept it. *But* (a > *big* *but*) I think I'm hundreds of miles away from being capable of > doing that =E2=94=80 just > look at the picture you're painting: >=20 > Nixpkgs is often not a good template, because more often than not they > > are cutting corners when it comes to bootstrapping or building from > > source.=20 >=20 > Tricky, isn't it? But just for brainstorming, does any other distro > package its applications in a way that is more descriptive of the > build process, so that it could be more easily translated into Scheme > for Guix? >=20 > And, redirecting a bit the problem =E2=94=80 would it be useful to have an > importer for NodeJS packages? (I know that most Node packages are > defined per-project in a package.json file, but there are those that > can be used as a stand-alone App) And that would be simpler or more > complex than an importer for a distro (assuming a carefully chosen, > favorable distro)? Just to be clear, this is just for the sake of > exploring possibilities =E2=94=80 I'm not committing to undertaking this > project. >=20 > Anyway, I was touched by your availability: >=20 > You are welcome to send me issue numbers with your patches and > > I=E2=80=99ll review them more quickly. > > =20 >=20 > Your offer makes me feel very much encouraged to proceed with my > attempts to package things for Guix, and, in doing so, contribute in > a more concrete way to the Free Software movement. But... >=20 > Failed attempts (help needed) >=20 > I want to install and use TiddlyMap > , which extends > TiddlyWiki5 , which is then > its dependency. So to isolate things, I started by writing a package > definition for the latter, which didn't work. At first debugging was > easy, because guix informs that some `use-module` expression is > missing. But then I got stuck. So, maybe you would be willing to take > a look at how far I've got up to now, and give me some guidance? Here > it is: >=20 > (define-module (gnu packages tiddlywiki) > #:use-module (guix packages) > #:use-module (guix git-download) > #:use-module (guix build-system node) > #:use-module (guix licenses) >=20 > #:use-module (gnu packages node)) >=20 >=20 >=20 > (define-public tiddlywiki > (package > (name "tiddlywiki") > (version "5.2.2") > (source > (origin > (method git-fetch) > (uri (git-reference > (url "https://github.com/Jermolene/TiddlyWiki5") > (commit (string-append "v" version)))) > (file-name (git-file-name name version)) > (sha256 > (base32 > "0ji5c3bqhjaign101fjy13bfhq1i804cxaibs61xmnfync6g1pf7")))) > (build-system node-build-system) > (home-page "https://tiddlywiki.com") > (synopsis "A non-linear web-browser based personal notebook app") > (description "TiddlyWiki is a complete interactive wiki in > JavaScript. It can be used as a single HTML file in the browser > or as a powerful Node.js application. It is highly > customisable: the entire user interface is itself implemented > in hackable WikiText.") > (license bsd-3))) >=20 >=20 > # This last line is so that this file returns a package definition >=20 > tiddlywiki >=20 >=20 > Then I tried to install it with: `guix shell --pure -f > /path/to/tiddlywiki.scm`, but it failed. > This is the relevant information (I think) inside the log-file: >=20 > starting phase `set-SOURCE-DATE-EPOCH' > phase `set-SOURCE-DATE-EPOCH' succeeded after 0.0 seconds > starting phase `set-paths' > environment variable `PATH' set to > `/gnu/store/akwqc82xg9l0g873hh7ia81pdwkf2sm6-node-14.18.3/bin:/gnu/store/= g2ajyl8xk9aarxrgjbng2hkj3qm2v0z2-tar-1.34/bin:/gnu/store/iixwcv3k49ks1rf34p= jgfzmzyhhgwng3-gzip-1.10/bin:/gnu/store/s3hl12jxz9ybs7nsy7kq7ybzz7qnzmsg-bz= ip2-1.0.8/bin:/gnu/store/c8isj4jq6knv0icfgr43di6q3nvdzkx7-xz-5.2.5/bin:/gnu= /store/4ic6244i3ca4b4rxc2wnrgllsidyishv-file-5.39/bin:/gnu/store/ahmmvw21p1= 1ik80lg1f953y7fd8bqkjm-diffutils-3.8/bin:/gnu/store/z39hnrwds1dgcbpfgj8dnv2= cngjb2xbl-patch-2.7.6/bin:/gnu/store/39rsx3nl4c31952jybbjb8d6idr5hx7r-findu= tils-4.8.0/bin:/gnu/store/690qz3fg334dpwn3pn6k59n4wc943p2b-gawk-5.1.0/bin:/= gnu/store/wxgv6i8g0p24q5gcyzd0yr07s8kn9680-sed-4.8/bin:/gnu/store/xjwp2hsd9= 256icjjybfrmznppjicywf6-grep-3.6/bin:/gnu/store/d251rfgc9nm2clzffzhgiipdvfv= zkvwi-coreutils-8.32/bin:/gnu/store/55cbpsi18mahg131nmiya6km5b4mscfa-make-4= .3/bin:/gnu/store/4y5m9lb8k3qkb1y9m02sw9w9a6hacd16-bash-minimal-5.1.8/bin:/= gnu/store/s2pg5k98fl2g2szg9dykxyd9zl3xihv9-ld-wrapper-0/bin:/gnu/store/rc78= 1v4k0drhaqn90xfwwpspki5x0bvf-binutils-2.37/bin:/gnu/store/069aq2v993kpc41ya= bp5b6vm4wb9jkhg-gcc-10.3.0/bin:/gnu/store/5h2w4qi9hk1qzzgi1w83220ydslinr4s-= glibc-2.33/bin:/gnu/store/5h2w4qi9hk1qzzgi1w83220ydslinr4s-glibc-2.33/sbin' > environment variable `NODE_PATH' set to > `/gnu/store/akwqc82xg9l0g873hh7ia81pdwkf2sm6-node-14.18.3/lib/node_module= s' > environment variable `BASH_LOADABLES_PATH' unset > environment variable `C_INCLUDE_PATH' set to > `/gnu/store/akwqc82xg9l0g873hh7ia81pdwkf2sm6-node-14.18.3/include:/gnu/st= ore/ri34iqiy08wn7k6czq43g5wl24ghsk97-libuv-1.42.0/include:/gnu/store/s3hl12= jxz9ybs7nsy7kq7ybzz7qnzmsg-bzip2-1.0.8/include:/gnu/store/c8isj4jq6knv0icfg= r43di6q3nvdzkx7-xz-5.2.5/include:/gnu/store/4ic6244i3ca4b4rxc2wnrgllsidyish= v-file-5.39/include:/gnu/store/690qz3fg334dpwn3pn6k59n4wc943p2b-gawk-5.1.0/= include:/gnu/store/55cbpsi18mahg131nmiya6km5b4mscfa-make-4.3/include:/gnu/s= tore/rc781v4k0drhaqn90xfwwpspki5x0bvf-binutils-2.37/include:/gnu/store/069a= q2v993kpc41yabp5b6vm4wb9jkhg-gcc-10.3.0/include:/gnu/store/5h2w4qi9hk1qzzgi= 1w83220ydslinr4s-glibc-2.33/include:/gnu/store/6mjww4iz4xdan74d5bbjfh7il8rn= gfkk-linux-libre-headers-5.10.35/include' > environment variable `CPLUS_INCLUDE_PATH' set to > `/gnu/store/akwqc82xg9l0g873hh7ia81pdwkf2sm6-node-14.18.3/include:/gnu/st= ore/ri34iqiy08wn7k6czq43g5wl24ghsk97-libuv-1.42.0/include:/gnu/store/s3hl12= jxz9ybs7nsy7kq7ybzz7qnzmsg-bzip2-1.0.8/include:/gnu/store/c8isj4jq6knv0icfg= r43di6q3nvdzkx7-xz-5.2.5/include:/gnu/store/4ic6244i3ca4b4rxc2wnrgllsidyish= v-file-5.39/include:/gnu/store/690qz3fg334dpwn3pn6k59n4wc943p2b-gawk-5.1.0/= include:/gnu/store/55cbpsi18mahg131nmiya6km5b4mscfa-make-4.3/include:/gnu/s= tore/rc781v4k0drhaqn90xfwwpspki5x0bvf-binutils-2.37/include:/gnu/store/069a= q2v993kpc41yabp5b6vm4wb9jkhg-gcc-10.3.0/include/c++:/gnu/store/069aq2v993kp= c41yabp5b6vm4wb9jkhg-gcc-10.3.0/include:/gnu/store/5h2w4qi9hk1qzzgi1w83220y= dslinr4s-glibc-2.33/include:/gnu/store/6mjww4iz4xdan74d5bbjfh7il8rngfkk-lin= ux-libre-headers-5.10.35/include' > environment variable `LIBRARY_PATH' set to > `/gnu/store/akwqc82xg9l0g873hh7ia81pdwkf2sm6-node-14.18.3/lib:/gnu/store/= ri34iqiy08wn7k6czq43g5wl24ghsk97-libuv-1.42.0/lib:/gnu/store/s3hl12jxz9ybs7= nsy7kq7ybzz7qnzmsg-bzip2-1.0.8/lib:/gnu/store/c8isj4jq6knv0icfgr43di6q3nvdz= kx7-xz-5.2.5/lib:/gnu/store/4ic6244i3ca4b4rxc2wnrgllsidyishv-file-5.39/lib:= /gnu/store/690qz3fg334dpwn3pn6k59n4wc943p2b-gawk-5.1.0/lib:/gnu/store/rc781= v4k0drhaqn90xfwwpspki5x0bvf-binutils-2.37/lib:/gnu/store/5h2w4qi9hk1qzzgi1w= 83220ydslinr4s-glibc-2.33/lib:/gnu/store/4jdghmc65q7i7ib89zmvq66l0ghf7jc4-g= libc-2.33-static/lib:/gnu/store/fnr1z6xsan0437r0yg48d0y8k32kqxby-glibc-utf8= -locales-2.33/lib' > environment variable `GUIX_LOCPATH' set to > `/gnu/store/fnr1z6xsan0437r0yg48d0y8k32kqxby-glibc-utf8-locales-2.33/lib/= locale' > phase `set-paths' succeeded after 0.0 seconds > starting phase `install-locale' > using 'en_US.utf8' locale for category "LC_ALL" > phase `install-locale' succeeded after 0.0 seconds > starting phase `unpack' > *... (very long list of unpacked files, with the indication of > where to)* > phase `unpack' succeeded after 0.6 seconds > starting phase `set-home' > set HOME to "/tmp/guix-build-tiddlywiki-5.2.2.drv-0/npm-home-0" > phase `set-home' succeeded after 0.0 seconds > starting phase `bootstrap' > no 'configure.ac' or anything like that, doing nothing > phase `bootstrap' succeeded after 0.0 seconds > starting phase `patch-usr-bin-file' > phase `patch-usr-bin-file' succeeded after 0.0 seconds > starting phase `patch-source-shebangs' > *... (list of shebangs patches)* > phase `patch-source-shebangs' succeeded after 0.5 seconds > starting phase `patch-dependencies' > phase `patch-dependencies' succeeded after 0.0 seconds > starting phase `delete-lockfiles' > phase `delete-lockfiles' succeeded after 0.0 seconds > starting phase `configure' > npm ERR! code ENOTCACHED > npm ERR! request to https://registry.npmjs.org/eslint failed: cache > mode is 'only-if-cached' but no cached response available. >=20 > npm ERR! A complete log of this run can be found in: > npm ERR! > /tmp/guix-build-tiddlywiki-5.2.2.drv-0/npm-home-0/.npm/_logs/2022-04-02T1= 7_48_43_558Z-debug.log > error: in phase 'configure': uncaught exception: > %exception #<&invoke-error program: > "/gnu/store/akwqc82xg9l0g873hh7ia81pdwkf2sm6-node-14.18.3/bin/npm" > arguments: ("--offline" "--ignore-scripts" "install") exit-status: 1 > term-signal: #f stop-signal: #f> > phase `configure' failed after 0.6 seconds > command > "/gnu/store/akwqc82xg9l0g873hh7ia81pdwkf2sm6-node-14.18.3/bin/npm" > "--offline" "--ignore-scripts" "install" failed with status 1 >=20 > I have no idea what this means. Can you deduce anything useful from > that? What do I need to know to fix this? >=20 > Thanks again, > C=C3=A1ssio