public inbox for gentoo-commits@lists.gentoo.org
 help / color / mirror / Atom feed
* [gentoo-commits] repo/gentoo:master commit in: app-eselect/eselect-zig/, app-eselect/eselect-zig/files/
@ 2023-03-09 13:04 Joonas Niilola
  0 siblings, 0 replies; 2+ messages in thread
From: Joonas Niilola @ 2023-03-09 13:04 UTC (permalink / raw
  To: gentoo-commits

commit:     44449238d9f6f5665b352013369612931217074f
Author:     Eric Joldasov <bratishkaerik <AT> getgoogleoff <DOT> me>
AuthorDate: Thu Mar  9 12:51:14 2023 +0000
Commit:     Joonas Niilola <juippis <AT> gentoo <DOT> org>
CommitDate: Thu Mar  9 13:03:40 2023 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=44449238

app-eselect/eselect-zig: fix remove_symlink -> remove_symlinks

Signed-off-by: Eric Joldasov <bratishkaerik <AT> getgoogleoff.me>
Closes: https://github.com/gentoo/gentoo/pull/30016
Signed-off-by: Joonas Niilola <juippis <AT> gentoo.org>

 .../eselect-zig/{eselect-zig-1.ebuild => eselect-zig-1-r1.ebuild}       | 0
 app-eselect/eselect-zig/files/{zig.eselect-1 => zig.eselect-1-r1}       | 2 +-
 2 files changed, 1 insertion(+), 1 deletion(-)

diff --git a/app-eselect/eselect-zig/eselect-zig-1.ebuild b/app-eselect/eselect-zig/eselect-zig-1-r1.ebuild
similarity index 100%
rename from app-eselect/eselect-zig/eselect-zig-1.ebuild
rename to app-eselect/eselect-zig/eselect-zig-1-r1.ebuild

diff --git a/app-eselect/eselect-zig/files/zig.eselect-1 b/app-eselect/eselect-zig/files/zig.eselect-1-r1
similarity index 99%
rename from app-eselect/eselect-zig/files/zig.eselect-1
rename to app-eselect/eselect-zig/files/zig.eselect-1-r1
index 938a0d665226..0918e68316eb 100644
--- a/app-eselect/eselect-zig/files/zig.eselect-1
+++ b/app-eselect/eselect-zig/files/zig.eselect-1-r1
@@ -113,7 +113,7 @@ do_update() {
         if [[ $1 == ifunset && -e ${EROOT}/usr/bin/zig ]]; then
             return
         fi
-        remove_symlink
+        remove_symlinks
     elif [[ -e ${EROOT}/usr/bin/zig ]]; then
         die -q "${EROOT}/usr/bin/zig exists but is not a symlink"
     fi


^ permalink raw reply related	[flat|nested] 2+ messages in thread

* [gentoo-commits] repo/gentoo:master commit in: app-eselect/eselect-zig/, app-eselect/eselect-zig/files/
@ 2025-05-31 21:29 Sam James
  0 siblings, 0 replies; 2+ messages in thread
From: Sam James @ 2025-05-31 21:29 UTC (permalink / raw
  To: gentoo-commits

commit:     4a1cb61bd516359bb6b6ddb88bb96dd9fcb8260f
Author:     Eric Joldasov <bratishkaerik <AT> landless-city <DOT> net>
AuthorDate: Sun May 25 13:54:28 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat May 31 21:09:06 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=4a1cb61b

app-eselect/eselect-zig: add 2

Added more target checks similar to those from zig-utils.eclass,
to avoid incorrect targets added to list (like zig-ebuilder).

Also consistent formatting everywhere and keyworded for s390
(needed for dev-lang/zig-bin 0.14.1).

Signed-off-by: Eric Joldasov <bratishkaerik <AT> landless-city.net>
Part-of: https://github.com/gentoo/gentoo/pull/42374
Signed-off-by: Sam James <sam <AT> gentoo.org>

 app-eselect/eselect-zig/eselect-zig-2.ebuild |  19 ++++
 app-eselect/eselect-zig/files/zig.eselect-2  | 133 +++++++++++++++++++++++++++
 2 files changed, 152 insertions(+)

diff --git a/app-eselect/eselect-zig/eselect-zig-2.ebuild b/app-eselect/eselect-zig/eselect-zig-2.ebuild
new file mode 100644
index 000000000000..aaaaeb795471
--- /dev/null
+++ b/app-eselect/eselect-zig/eselect-zig-2.ebuild
@@ -0,0 +1,19 @@
+# Copyright 2023-2025 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=8
+
+DESCRIPTION="Manages Zig versions"
+HOMEPAGE="https://wiki.gentoo.org/wiki/No_homepage"
+S="${WORKDIR}"
+
+LICENSE="GPL-2"
+SLOT="0"
+KEYWORDS="~amd64 ~arm ~arm64 ~loong ~ppc ~ppc64 ~riscv ~s390 ~x86"
+
+RDEPEND="app-admin/eselect"
+
+src_install() {
+	insinto /usr/share/eselect/modules/
+	newins "${FILESDIR}"/zig.eselect-${PVR} zig.eselect
+}

diff --git a/app-eselect/eselect-zig/files/zig.eselect-2 b/app-eselect/eselect-zig/files/zig.eselect-2
new file mode 100644
index 000000000000..987c1a465e11
--- /dev/null
+++ b/app-eselect/eselect-zig/files/zig.eselect-2
@@ -0,0 +1,133 @@
+# -*-eselect-*-  vim: ft=eselect
+# Copyright 2022-2025 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+DESCRIPTION="Manage Zig versions"
+MAINTAINER="bratishkaerik@landless-city.net"
+VERSION="2"
+
+show_selected_target() {
+	readlink "${EROOT}/usr/bin/zig"
+}
+
+find_targets() {
+	local f name
+	for f in "${EROOT}"/usr/bin/zig-*; do
+		name="$(basename "${f}")"
+
+		[[ "${name}" =~ ^zig(-bin)?-[[:digit:]] ]] || continue
+		[[ -x "${f}" ]] || continue
+		echo "${name}"
+	done
+}
+
+remove_symlinks() {
+	rm "${EROOT}/usr/bin/zig"
+}
+
+set_symlinks() {
+	local target="${1}"
+	if is_number "${target}"; then
+		local targets=( $(find_targets) )
+		target="${targets[target - 1]}"
+	fi
+
+	[[ -z "${target}" || ! -x "${EROOT}/usr/bin/${target}" ]] &&
+		die -q "Target \"${1}\" doesn't appear to be valid!"
+
+	ln -s "${target}" "${EROOT}/usr/bin/zig"
+}
+
+### show action ###
+
+describe_show() {
+	echo "Show current Zig version"
+}
+
+do_show() {
+	write_list_start "Current Zig version:"
+	if [[ -L "${EROOT}/usr/bin/zig" ]]; then
+		write_kv_list_entry "$(show_selected_target)" ""
+	else
+		write_kv_list_entry "(unset)" ""
+	fi
+}
+
+### list action ###
+
+describe_list() {
+	echo "List available Zig versions"
+}
+
+do_list() {
+	local targets=( $(find_targets) )
+	local selected_target
+	selected_target=$(show_selected_target)
+
+	write_list_start "Available Zig versions:"
+	for ((i = 0; i < ${#targets[@]}; i++)); do
+		[[ "${targets[i]}" == "${selected_target}" ]] && targets[i]="$(highlight_marker "${targets[i]}")"
+	done
+	write_numbered_list -m "(none found)" "${targets[@]}"
+}
+
+### set action ###
+
+describe_set() {
+	echo "Set active Zig version"
+}
+
+describe_set_parameters() {
+	echo "<target>"
+}
+
+describe_set_options() {
+	echo "target:      Target name or number (from 'list' action)"
+}
+
+do_set() {
+	[[ -z "${1}" ]] && die -q "You need to specify a target"
+	[[ ${#} -gt 1 ]] && die -q "Too many parameters"
+	test_usr_bin_writeable
+
+	if [[ -L "${EROOT}/usr/bin/zig" ]]; then
+		remove_symlinks || die -q "Couldn't remove symlink"
+	fi
+	set_symlinks "${1}" || die -q "Couldn't set a new symlink"
+}
+
+### update action ###
+
+describe_update() {
+	echo "Automatically update the zig symlink"
+}
+
+describe_update_options() {
+	echo "ifunset: Do not override currently set version"
+}
+
+do_update() {
+	[[ -z "${1}" || "${1}" == ifunset ]] || die -q "Usage error"
+	[[ ${#} -gt 1 ]] && die -q "Too many parameters"
+	test_usr_bin_writeable
+
+	if [[ -L "${EROOT}/usr/bin/zig" ]]; then
+		if [[ "${1}" == ifunset && -e "${EROOT}/usr/bin/zig" ]]; then
+			return
+		fi
+		remove_symlinks
+	elif [[ -e "${EROOT}/usr/bin/zig" ]]; then
+		die -q "\"${EROOT}/usr/bin/zig\" exists but is not a symlink"
+	fi
+
+	local targets=( $(find_targets) )
+	if [[ ${#targets[@]} -gt 0 ]]; then
+		set_symlinks "${targets[${#targets[@]} - 1]}"
+	fi
+}
+
+### helper functions ###
+
+test_usr_bin_writeable() {
+	[[ -w "${EROOT}/usr/bin" ]] || die -q "\"${EROOT}/usr/bin\" not writeable by current user. Are you root?"
+}


^ permalink raw reply related	[flat|nested] 2+ messages in thread

end of thread, other threads:[~2025-05-31 21:29 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2025-05-31 21:29 [gentoo-commits] repo/gentoo:master commit in: app-eselect/eselect-zig/, app-eselect/eselect-zig/files/ Sam James
  -- strict thread matches above, loose matches on Subject: below --
2023-03-09 13:04 Joonas Niilola

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox