From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from mp1 ([2001:41d0:8:6d80::]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits)) by ms0.migadu.com with LMTPS id cOrrDoMFmWGFpgAAgWs5BA (envelope-from ) for ; Sat, 20 Nov 2021 15:26:11 +0100 Received: from aspmx1.migadu.com ([2001:41d0:8:6d80::]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits)) by mp1 with LMTPS id QAqDCoMFmWHjTQAAbx9fmQ (envelope-from ) for ; Sat, 20 Nov 2021 14:26:11 +0000 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 84BC61C8D5 for ; Sat, 20 Nov 2021 15:26:09 +0100 (CET) Received: from localhost ([::1]:56840 helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1moRJg-0006ji-LD for larch@yhetil.org; Sat, 20 Nov 2021 09:26:08 -0500 Received: from eggs.gnu.org ([209.51.188.92]:55198) by lists.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.90_1) (envelope-from ) id 1moRJa-0006jG-Q6 for guix-patches@gnu.org; Sat, 20 Nov 2021 09:26:02 -0500 Received: from debbugs.gnu.org ([209.51.188.43]:58701) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1moRJa-00079p-IA for guix-patches@gnu.org; Sat, 20 Nov 2021 09:26:02 -0500 Received: from Debian-debbugs by debbugs.gnu.org with local (Exim 4.84_2) (envelope-from ) id 1moRJa-0007C7-2w for guix-patches@gnu.org; Sat, 20 Nov 2021 09:26:02 -0500 X-Loop: help-debbugs@gnu.org Subject: [bug#51512] [PATCH v 2]: gnu: Add bash-bcu. Resent-From: Tobias Geerinckx-Rice Original-Sender: "Debbugs-submit" Resent-CC: guix-patches@gnu.org Resent-Date: Sat, 20 Nov 2021 14:26:02 +0000 Resent-Message-ID: Resent-Sender: help-debbugs@gnu.org X-GNU-PR-Message: followup 51512 X-GNU-PR-Package: guix-patches X-GNU-PR-Keywords: patch To: david larsson Cc: 51512@debbugs.gnu.org X-Debbugs-Original-Cc: 51512@debbugs.gnu.org, guix-patches@gnu.org Received: via spool by 51512-submit@debbugs.gnu.org id=B51512.163741833327609 (code B ref 51512); Sat, 20 Nov 2021 14:26:02 +0000 Received: (at 51512) by debbugs.gnu.org; 20 Nov 2021 14:25:33 +0000 Received: from localhost ([127.0.0.1]:42014 helo=debbugs.gnu.org) by debbugs.gnu.org with esmtp (Exim 4.84_2) (envelope-from ) id 1moRJ3-0007B5-1Q for submit@debbugs.gnu.org; Sat, 20 Nov 2021 09:25:33 -0500 Received: from tobias.gr ([80.241.217.52]:44600) by debbugs.gnu.org with esmtp (Exim 4.84_2) (envelope-from ) id 1moRJ1-0007Au-9p for 51512@debbugs.gnu.org; Sat, 20 Nov 2021 09:25:28 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; s=2018; bh=q7SZqdmhq5m3o nAhgpZwRe0H7zeAlVCQ9V0xPQ0eyvo=; h=in-reply-to:date:subject:cc:to: from:references; d=tobias.gr; b=AxVPK282YAut54Z1IbyJVzdYIiJ3MMpm7yhPv4 MPx9dFSN7jVBp+AwKow2cWMxWN8r26gxCvmp9RURcdOJG2sfBGjb8fNrsffeM6ldyDdL14 FF7o/FmdrFaW344kW847+PlcscCgQsMq52bj5RXiGWikqp38a8e9SQ0OS3rbymqiYD7bly P+grlxIIfRHBXLU2uktHtG1iC9L5PS0s8WsYMxK12QjuMzEDnVDgm7yHsDJsB+9uE1HsTa uT0Tb47SdMM6XdWrC40oeI1H5DP2+3wwMzi3Vzs0NY4KAk62aJnGB2/R9cguKuUpBT9g+8 TU0Q5pmV+BJPrxJhaso7yrPQ== Received: by submission.tobias.gr (OpenSMTPD) with ESMTPSA id b7cb816f (TLSv1.3:AEAD-AES256-GCM-SHA384:256:NO); Sat, 20 Nov 2021 14:25:23 +0000 (UTC) References: <3add15b77522d6e9ebd715a19d966666@selfhosted.xyz> <87r1bsqdy8.fsf@nckx> <93d8232c104dc63f46f6b975073b56ca@selfhosted.xyz> Date: Sat, 20 Nov 2021 15:11:30 +0100 In-reply-to: <93d8232c104dc63f46f6b975073b56ca@selfhosted.xyz> BIMI-Selector: v=BIMI1; s=default; Message-ID: <87y25inbsu.fsf@nckx> MIME-Version: 1.0 Content-Type: multipart/signed; boundary="==-=-="; micalg=pgp-sha512; protocol="application/pgp-signature" X-BeenThere: debbugs-submit@debbugs.gnu.org X-Mailman-Version: 2.1.18 Precedence: list X-BeenThere: guix-patches@gnu.org List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: guix-patches-bounces+larch=yhetil.org@gnu.org Sender: "Guix-patches" Reply-to: Tobias Geerinckx-Rice X-ACL-Warn: , Tobias Geerinckx-Rice via Guix-patches From: Tobias Geerinckx-Rice via Guix-patches via X-Migadu-Flow: FLOW_IN X-Migadu-Country: US ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=yhetil.org; s=key1; t=1637418370; h=from:from:sender:sender:reply-to:reply-to:subject:subject:date:date: message-id:message-id:to:to:cc:cc:mime-version:mime-version: content-type:content-type:resent-cc:resent-from:resent-sender: resent-message-id:in-reply-to:in-reply-to:references:references: list-id:list-help:list-unsubscribe:list-subscribe:list-post: dkim-signature; bh=q7SZqdmhq5m3onAhgpZwRe0H7zeAlVCQ9V0xPQ0eyvo=; b=jOyALPMr4twxVPqOaJw6yJXeA/2wxkCDblDXbVLIrln1Ie6aJaL7kUv4+RvecNYFKJy7x4 I2FNssqAjOfycFLg1CQhztTOn4IRTgMI1zQ/TLEI7S9KsvDQwDs7eTp3nw07/+tB1WLUCF VBTkEyR7RORyLI4tZUTalfuvssi66rRgvagiY3bx0rUtrNRNQ39nnE41AC0nG8xWqt76Vc cWAJCqVdliOCaZjwsv6zSXnver1q3UVBxaKtL4OYt49FadiJCy3oQ/k7sZx1bBBxLDj77+ AN1pgkIt5pkJZ/dsVfzSOSIwyRiciI861VdvIQVaABUvVR5AthLgvuxItaYHGA== ARC-Seal: i=1; s=key1; d=yhetil.org; t=1637418370; a=rsa-sha256; cv=none; b=AOar8rtmn9QyUGsRwwjUYHelyGI2eQSKvWYKO2JBEhOiyPlkaSgTLbRnAvCDMfmimTSzMy jXxuXnTSd0tUu3A2naX69IM/h5usCa6Cop1bXBSqHqel01JphVm5P7GdKUJ15ojK1H2nAc rb7LTOkUs7FkAOPu7xpPJ3gsNWiHXIUCk6ZQ9E0qPQvH5utyEMl22hkF8EDGKCWzV6j8Bs BNDN0Rhrx64lINaK7DcubJSutFZd+e/FG8V/xO1+S51s6nhpq9MHhlfDm11asVffMZg1ug FN/yhdeERs6Zn9og5t16og+R1e2NSzKnrw/AwvpDU9k4z4dFrsNJQrzOtHyC1w== ARC-Authentication-Results: i=1; aspmx1.migadu.com; dkim=fail ("headers rsa verify failed") header.d=tobias.gr header.s=2018 header.b=AxVPK282; dmarc=pass (policy=none) header.from=gnu.org; spf=pass (aspmx1.migadu.com: domain of "guix-patches-bounces+larch=yhetil.org@gnu.org" designates 209.51.188.17 as permitted sender) smtp.mailfrom="guix-patches-bounces+larch=yhetil.org@gnu.org" X-Migadu-Spam-Score: -4.97 Authentication-Results: aspmx1.migadu.com; dkim=fail ("headers rsa verify failed") header.d=tobias.gr header.s=2018 header.b=AxVPK282; dmarc=pass (policy=none) header.from=gnu.org; spf=pass (aspmx1.migadu.com: domain of "guix-patches-bounces+larch=yhetil.org@gnu.org" designates 209.51.188.17 as permitted sender) smtp.mailfrom="guix-patches-bounces+larch=yhetil.org@gnu.org" X-Migadu-Queue-Id: 84BC61C8D5 X-Spam-Score: -4.97 X-Migadu-Scanner: scn0.migadu.com X-TUID: BO5idH/KE1yy --==-=-= Content-Type: multipart/mixed; boundary="=-=-=" --=-=-= Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: quoted-printable David, david larsson =E5=86=99=E9=81=93=EF=BC=9A > Not sure if u intended to attach ur modified version of the=20 > patch when > you replied or not. Absolutely. Oops! Here it is, belatedly, and possibly=20 pointlessly. > Basically just to make minimal disruption of the the current > environment when you source bcu.sh. Almost certainly a non-issue=20 > 99.9% > of cases, i.e. I think that just prepending /run/setuid-programs=20 > to > PATH would be fine as well. The current package does much =E2=80=98worse=E2=80=99 comparatively: > + ":" (assoc-ref %build-inputs "bindutils") "/bin" > + ":" (assoc-ref %build-inputs "coreutils") "/bin" > + ":" (assoc-ref %build-inputs "ctypes.sh") "/bin" > + ":" (assoc-ref %build-inputs "curl") "/bin" > [=E2=80=A6many more=E2=80=A6] However, you make an excellent point, and this packages's intended=20 usage means that it will clobber the caller's environment, not=20 just its own. If I were to use this package (and I might=E2=80=94it's neat) I would=20 almost certainly end up using it in a setting where changing PATH=20 at all would cause unexpected and frustrating =E2=80=98bugs=E2=80=99. Hmm=E2=80=A6 Kind regards, T G-R --=-=-= Content-Type: text/x-patch Content-Disposition: inline; filename=wip-bcu.patch Content-Transfer-Encoding: quoted-printable From=202ee51b0224c6f3bf9720d217346f53e3cb94e68a Mon Sep 17 00:00:00 2001 From: Tobias Geerinckx-Rice Date: Mon, 8 Nov 2021 21:09:17 +0100 Subject: [PATCH 06/10] wip bcu =2D-- gnu/packages/bash.scm | 196 ++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 196 insertions(+) diff --git a/gnu/packages/bash.scm b/gnu/packages/bash.scm index ed2931fd97..114ea1dcac 100644 =2D-- a/gnu/packages/bash.scm +++ b/gnu/packages/bash.scm @@ -25,17 +25,34 @@ (define-module (gnu packages bash) #:use-module ((guix licenses) #:prefix license:) #:use-module (gnu packages) + #:use-module (gnu packages admin) #:use-module (gnu packages base) #:use-module (gnu packages bootstrap) #:use-module (gnu packages compression) + #:use-module (gnu packages curl) + #:use-module (gnu packages dns) + #:use-module (gnu packages ed) #:use-module (gnu packages elf) + #:use-module (gnu packages freedesktop) + #:use-module (gnu packages gawk) + #:use-module (gnu packages gtk) #:use-module (gnu packages ncurses) + #:use-module (gnu packages networking) #:use-module (gnu packages readline) #:use-module (gnu packages bison) #:use-module (gnu packages linux) #:use-module (gnu packages libffi) + #:use-module (gnu packages pcre) + #:use-module (gnu packages perl) + #:use-module (gnu packages php) #:use-module (gnu packages pkg-config) + #:use-module (gnu packages python) + #:use-module (gnu packages python-xyz) #:use-module (gnu packages guile) + #:use-module (gnu packages guile-xyz) + #:use-module (gnu packages tcl) + #:use-module (gnu packages web) + #:use-module (gnu packages xml) #:use-module (guix packages) #:use-module (guix download) #:use-module (guix git-download) @@ -448,3 +465,182 @@ (define-public bash-ctypes function interface (FFI) directly in your shell. In other words, it allows you to call routines in shared libraries from within Bash.") (license license:expat))) + +(define-public bash-coding-utils + (let () + (package + (name "bash-coding-utils") + (version "0.2.0") + (source + (origin + (method git-fetch) + (uri (git-reference + (commit "40d6527a9effb4e18778c37bebaa9f3a58de12d6") + (url "https://gitlab.com/methuselah-0/bash-coding-utils.sh.= git") + ;; Include submodules/. TODO: These seem to be worth packa= ging? + (recursive? #t))) + (sha256 + (base32 "007g6wfybjr0ms32qikb545r11lgm3p98cd7dbzpfyh0grgn9vj1"))= )) + (inputs `(("bash" ,bash) + ("bindutils" ,isc-bind "utils") + ("coreutils" ,coreutils) + ("ctypes.sh" ,bash-ctypes) + ("curl" ,curl) + ("diffutils" ,diffutils) + ("ed" ,ed) + ("expect" ,expect) + ("find" ,findutils) + ("gawk" ,gawk) + ("grep" ,grep) + ("guile" ,guile-3.0) + ("guile-bash" ,guile-bash) + ("guile-daemon" ,guile-daemon) + ("inetutils" ,inetutils) + ("jq" ,jq) + ("libxml2-xpath0" ,libxml2-xpath0) + ("netcat" ,netcat) + ("nmap" ,nmap) + ("pcre/bin" ,pcre "bin") + ("perl" ,perl) + ("php" ,php) + ("prips" ,prips) + ("python" ,python) + ("python-elementpath" ,python-elementpath) + ("python-lxml" ,python-lxml) + ("python-netaddr" ,python-netaddr) + ("python-yq" ,python-yq) + ("sed" ,sed) + ("socat" ,socat) + ("util-linux" ,util-linux) + ("which" ,which) + ("xdg-utils" ,xdg-utils) + ("yad" ,yad))) + (build-system trivial-build-system) + (arguments + `(#:modules ((guix build utils)) + #:builder + (begin + (use-modules (guix build utils)) + (let* ((bash (assoc-ref %build-inputs "bash")) + ;; Some Guile libraries such as GNU Bash will need + ;; to be added to GUILE_LOAD_PATH. + (guile-bash (assoc-ref %build-inputs "guile-bash")) + (g-bash-lib (string-append guile-bash + "/share/guile/site/" + ,(version-major+minor (package-ver= sion guile-3.0)))) + ;; Some Python libraries needs added to PYTHONPATH. + (python-version ,(version-major+minor (package-version p= ython))) + (p-elementpath-lib (string-append + (assoc-ref %build-inputs "python-ele= mentpath") + "/lib/python" python-version "/site-= packages")) + (p-lxml-lib (string-append + (assoc-ref %build-inputs "python-lxml") + "/lib/python" python-version "/site-package= s")) + (p-netaddr-lib (string-append + (assoc-ref %build-inputs "python-netaddr= ") + "/lib/python" python-version "/site-pack= ages")) + (p-lib (string-append + (assoc-ref %build-inputs "python") + "/lib/python" python-version "/site-packages")) + (pylibsline (string-append + p-elementpath-lib ":" p-lxml-lib + ":" p-netaddr-lib ":" p-lib)) + (out (assoc-ref %outputs "out")) + (bin (string-append out "/bin")) + ;; Everything but bcu.sh itself is only accessed + ;; internally by bcu so we put it in libexec. + (libexec (string-append out "/libexec/bcu"))) + (mkdir-p libexec) + (copy-recursively (assoc-ref %build-inputs "source") libexec) + ;; Create a bcu.sh wrapping script manually that ensures + ;; we prepend necessary PATHs. + (mkdir-p bin) + (let* ((bcu.sh (string-append bin "/bcu.sh")) + (path (string-append + "/run/setuid-programs" + ":" bash "/bin" + ":" (assoc-ref %build-inputs "bindutils") "= /bin" + ":" (assoc-ref %build-inputs "coreutils") "= /bin" + ":" (assoc-ref %build-inputs "ctypes.sh") "= /bin" + ":" (assoc-ref %build-inputs "curl") "/bin" + ":" (assoc-ref %build-inputs "diffutils") "= /bin" + ":" (assoc-ref %build-inputs "ed") "/bin" + ":" (assoc-ref %build-inputs "expect") "/bi= n" + ":" (assoc-ref %build-inputs "find") "/bin" + ":" (assoc-ref %build-inputs "gawk") "/bin" + ":" (assoc-ref %build-inputs "grep") "/bin" + ":" (assoc-ref %build-inputs "guile") "/bin" + ":" (assoc-ref %build-inputs "inetutils") "= /bin" + ":" (assoc-ref %build-inputs "jq") "/bin" + ":" (assoc-ref %build-inputs "libxml2-xpath= 0") "/bin" + ":" (assoc-ref %build-inputs "netcat") "/bi= n" + ":" (assoc-ref %build-inputs "nmap") "/bin" + ":" (assoc-ref %build-inputs "pcre/bin") "/= bin" + ":" (assoc-ref %build-inputs "perl") "/bin" + ":" (assoc-ref %build-inputs "php") "/bin" + ":" (assoc-ref %build-inputs "prips") "/bin" + ":" (assoc-ref %build-inputs "python") "/bi= n" + ":" (assoc-ref %build-inputs "python-yq") "= /bin" + ":" (assoc-ref %build-inputs "sed") "/bin" + ":" (assoc-ref %build-inputs "socat") "/bin" + ":" (assoc-ref %build-inputs "util-linux") = "/bin" + ":" (assoc-ref %build-inputs "which") "/bin" + ":" (assoc-ref %build-inputs "xdg-utils") "= /bin" + ":" (assoc-ref %build-inputs "yad") "/bin")= )) + (with-output-to-file bcu.sh + (lambda _ + (display (string-append "#!" bash "/bin/bash\n")) + (display "[[ \"$_BCU_SH_LOADED\" =3D=3D YES ]] || { \n") + (display (string-append "export PATH=3D\"" path + "${PATH:+:}${PATH}\"\n")) + (display (string-append "export PYTHONPATH=3D\"" pylibs= line + "${PYTHONPATH:+:}${PYTHONPATH}\= "\n")) + (display + (string-append "export GUILE_LOAD_PATH=3D\"" g-bash-lib + "${GUILE_LOAD_PATH:+:}${GUILE_LOAD_PATH= }\"\n")) + ;; XDG_DATA_DIRS needs set for yad to load icons proper= ly. + (display (string-append + "[[ -e /run/current-system/profile/share ]] &= & " + "export XDG_DATA_DIRS=3D" + "/run/current-system/profile/share" + "${XDG_DATA_DIRS:+:}${XDG_DATA_DIRS}\n")) + (display (string-append "source " libexec "/bcu.sh\n")) + (display "}\n"))) + (chmod bcu.sh #o555) + (setenv "PATH" (string-append path ":" (getenv "PATH")))) + (substitute* (find-files out ".*\\.sh") + (("~/\\.guix-profile/lib/bash/libguile-bash\\.so") + (string-append guile-bash "/lib/bash/libguile-bash.so")) + (("\"\\$GUIX_PROFILE\"/lib/bash/libguile-bash\\.so") + (string-append guile-bash "/lib/bash/libguile-bash.so"))) + (for-each (lambda (file) + (patch-shebang file)) + (find-files out ".*\\.(sh|scm|awk|php|py)$") ) + ;; Set up PATH for tests. + (setenv "PATH" (string-append bin ":" (getenv "PATH"))) + ;; Some tests need a HOME directory. + (setenv "HOME" "/tmp") + ;; Disable network tests, and all tests for setopts which + ;; don't work inside the Guix build environment. + (with-output-to-file (string-append libexec "/disabled_tests.= txt") + (lambda _ + (format #t "~{~a~%~}" + (list "ip_of_test_1" + "setopts_test_1" + "setopts_test_2" + "setopts_test_3" + "setopts_test_4" + "setopts_test_5" + "setopts_test_6")))) + (invoke (string-append libexec "/bcu-test.sh")))))) + (home-page "https://gitlab.com/methuselah-0/bash-coding-utils.sh") + (synopsis "Functions and tools for software prototyping in Bash") + (description + "This package contains Bash functions and wrappers that can be usef= ul +when writing quick implementations of new programs. It helps you work with +JSON, XML, and parallelization, and installs some commonly used helper pro= grams +used in Bash scripting. Just run @command{. bcu.sh}, type @command{bcu__}= , hit +@key{TAB} to see available functions and give any of them the @code{--help} +flag to see how to use it, or run @command{bcu__docs} for the full HTML +documentation.") + (license license:gpl3)))) =2D-=20 2.34.0 --=-=-=-- --==-=-= Content-Type: application/pgp-signature; name="signature.asc" -----BEGIN PGP SIGNATURE----- iIMEARYKACsWIQT12iAyS4c9C3o4dnINsP+IT1VteQUCYZkFgQ0cbWVAdG9iaWFz LmdyAAoJEA2w/4hPVW15t5kA/1hUt6eWgsPInj1c+tgtc8Y1NLVCh1KL3T9iX5ME s87jAQDSxy1Bv8+ki2J21Oea1bgjVUfKnmLw0/dxsoXPgRoNBw== =7rK0 -----END PGP SIGNATURE----- --==-=-=--