diff options
author | Alexis Ballier <aballier@gentoo.org> | 2008-04-07 21:29:18 +0000 |
---|---|---|
committer | Alexis Ballier <aballier@gentoo.org> | 2008-04-07 21:29:18 +0000 |
commit | 73ef13595861bb7489b739fcd8e099b2c24dd76d (patch) | |
tree | b14946b2441706a756c5a2befc6747a0ece81d9e /app-admin/eselect-unison | |
parent | Stable on alpha, bug #216765 (diff) | |
download | gentoo-2-73ef13595861bb7489b739fcd8e099b2c24dd76d.tar.gz gentoo-2-73ef13595861bb7489b739fcd8e099b2c24dd76d.tar.bz2 gentoo-2-73ef13595861bb7489b739fcd8e099b2c24dd76d.zip |
Initial import. eselect module for SLOTted net-misc/unison by Martin von Gagern <Martin.vGagern@gmx.net>, bug #207746
(Portage version: 2.1.5_rc2)
Diffstat (limited to 'app-admin/eselect-unison')
-rw-r--r-- | app-admin/eselect-unison/ChangeLog | 11 | ||||
-rw-r--r-- | app-admin/eselect-unison/Manifest | 4 | ||||
-rw-r--r-- | app-admin/eselect-unison/eselect-unison-0.1.ebuild | 25 | ||||
-rw-r--r-- | app-admin/eselect-unison/files/unison.eselect-0.1 | 152 | ||||
-rw-r--r-- | app-admin/eselect-unison/metadata.xml | 5 |
5 files changed, 197 insertions, 0 deletions
diff --git a/app-admin/eselect-unison/ChangeLog b/app-admin/eselect-unison/ChangeLog new file mode 100644 index 000000000000..3b323f49fb77 --- /dev/null +++ b/app-admin/eselect-unison/ChangeLog @@ -0,0 +1,11 @@ +# ChangeLog for app-admin/eselect-unison +# Copyright 1999-2008 Gentoo Foundation; Distributed under the GPL v2 +# $Header: /var/cvsroot/gentoo-x86/app-admin/eselect-unison/ChangeLog,v 1.1 2008/04/07 21:29:17 aballier Exp $ + +*eselect-unison-0.1 (07 Apr 2008) + + 07 Apr 2008; Alexis Ballier <aballier@gentoo.org> + +files/unison.eselect-0.1, +metadata.xml, +eselect-unison-0.1.ebuild: + Initial import. eselect module for SLOTted net-misc/unison by Martin von + Gagern <Martin.vGagern@gmx.net>, bug #207746 + diff --git a/app-admin/eselect-unison/Manifest b/app-admin/eselect-unison/Manifest new file mode 100644 index 000000000000..fb781fcc2463 --- /dev/null +++ b/app-admin/eselect-unison/Manifest @@ -0,0 +1,4 @@ +AUX unison.eselect-0.1 3640 RMD160 20dd8320844e5902b36d71dc6c8c3474851962b0 SHA1 4d4c1ba6a55d92aedd52c76b04cb39b39cdf2c3e SHA256 3a2c14e7235afd54d0b9263e61112986ad91c377f32258909235fd633a90e34b +EBUILD eselect-unison-0.1.ebuild 559 RMD160 1c899bf77ad5ac98d44eff96be3ba34e7857497d SHA1 6f5d12455d327c3cfd4b0a3e21a284c964273349 SHA256 e34399ee51b33f14eeb7f596704ffa9b190bcf55ccbb6f5715c564cc329187fc +MISC ChangeLog 407 RMD160 1b580f15f665e705389f573fc0933822586e1f14 SHA1 f04e2017525b3686ce6e1fab0ead84d437a27d8e SHA256 8ea545fcc972a9dbdd7a17d3f32994fca08d2d98401c6f7772c2dda518403f01 +MISC metadata.xml 155 RMD160 dfaa057e679b01302a807c75a32a910098b26809 SHA1 94024f83dcacbb53e92be090dd0f994ec93dc90d SHA256 118048376ebb76f57628b0819f3de4856e73959c2578c88715d37ea2d1e0af81 diff --git a/app-admin/eselect-unison/eselect-unison-0.1.ebuild b/app-admin/eselect-unison/eselect-unison-0.1.ebuild new file mode 100644 index 000000000000..839565d5b447 --- /dev/null +++ b/app-admin/eselect-unison/eselect-unison-0.1.ebuild @@ -0,0 +1,25 @@ +# Copyright 1999-2008 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 +# $Header: /var/cvsroot/gentoo-x86/app-admin/eselect-unison/eselect-unison-0.1.ebuild,v 1.1 2008/04/07 21:29:17 aballier Exp $ + +inherit eutils + +DESCRIPTION="unison module for eselect" +HOMEPAGE="http://www.gentoo.org/proj/en/eselect/" +SRC_URI="" + +LICENSE="GPL-2" +SLOT="0" +KEYWORDS="~amd64" + +IUSE="" +DEPEND="" +RDEPEND=">=app-admin/eselect-1.0.5" + +src_install() { + local MODULEDIR="/usr/share/eselect/modules" + local MODULE="unison" + dodir ${MODULEDIR} + insinto ${MODULEDIR} + newins "${FILESDIR}/${MODULE}.eselect-${PVR}" ${MODULE}.eselect || die "failed to install" +} diff --git a/app-admin/eselect-unison/files/unison.eselect-0.1 b/app-admin/eselect-unison/files/unison.eselect-0.1 new file mode 100644 index 000000000000..26d68521a597 --- /dev/null +++ b/app-admin/eselect-unison/files/unison.eselect-0.1 @@ -0,0 +1,152 @@ +# Copyright 1999-2007 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 +# $Id: unison.eselect-0.1,v 1.1 2008/04/07 21:29:18 aballier Exp $ + +DESCRIPTION="Manage /usr/bin/unison versions" +MAINTAINER="ml@gentoo.org" +SVN_DATE='$Date: 2008/04/07 21:29:18 $' +VERSION=$(svn_date_to_version "${SVN_DATE}" ) + +# find a list of unison symlink targets, best first +find_targets() { + local f + for f in "${ROOT}"/usr/bin/unison-[0-9]*; do + if [[ -f ${f} ]] ; then + echo "${f##*/unison-}" + fi + done | tac +} + +# find version number of currently symlinked version +identify_target() { + local f + f="$(canonicalise "${ROOT}"/usr/bin/unison)" + echo "${f##*/unison-}" +} + +# try to remove the unison symlink +remove_symlinks() { + rm -f "${ROOT}"/usr/bin/unison &>/dev/null +} + +# set the unison symlink +set_symlinks() { + local target="${1}" targets + if is_number "${target}" && [[ ${target} -ge 1 ]] ; then + targets=( $(find_targets ) ) + target=${targets[$(( ${target} - 1 ))]} + fi + if [[ -f "${ROOT}/usr/bin/unison-${target}" ]] ; then + remove_symlinks + ln -s "unison-${target}" "${ROOT}/usr/bin/unison" || \ + die "Could not set ${target} /usr/bin/unison symlink" + else + die -q "Target \"${target}\" doesn't appear to be valid!" + fi +} + +### show action ### + +describe_show() { + echo "Show the current unison version" +} + +do_show() { + [[ -z "${@}" ]] || die -q "Too many parameters" + + write_list_start "Current unison verson:" + if [[ -L "${ROOT}/usr/bin/unison" ]] ; then + write_kv_list_entry "$(identify_target)" "" + elif [[ -e "${ROOT}/usr/bin/unison" ]] ; then + write_kv_list_entry "(not a symlink)" "" + else + write_kv_list_entry "(unset)" "" + fi +} + +### list action ### + +describe_list() { + echo "List available unison versions" +} + +do_list() { + [[ -z "${@}" ]] || die -q "Too many parameters" + + local i targets current + targets=( $(find_targets ) ) + current=$(identify_target) + if [[ -n ${targets[@]} ]] ; then + for (( i = 0 ; i < ${#targets[@]} ; i = i + 1 )) ; do + [[ ${targets[${i}]} == ${current} ]] && \ + targets[${i}]="${targets[${i}]} $(highlight '*' )" + done + write_list_start "Available unison versions:" + write_numbered_list "${targets[@]}" + else + write_kv_list_entry "(none found)" "" + fi +} + +### set action ### + +describe_set() { + echo "Set a new unison version" +} + +describe_set_options() { + echo "target : Target version number or index from 'list' action" +} + +describe_set_parameters() { + echo "<target>" +} + +do_set() { + if [[ -z "${1}" ]] ; then + die -q "You didn't give me a version number" + + elif [[ -n "${2}" ]] ; then + die -q "Too many parameters" + + elif [[ -L "${ROOT}/usr/bin/unison" ]] ; then + if ! remove_symlinks ; then + die -q "Can't remove existing version symlink" + elif ! set_symlinks "${1}" ; then + die -q "Can't set new version" + fi + + elif [[ -e "${ROOT}/usr/bin/unison" ]] ; then + die -q "${ROOT}/usr/bin/unison seems to be from an old ebuild, please remove manually" + + else + set_symlinks "${1}" || die -q "Can't set new version" + fi +} + +### update action ### + +describe_update() { + echo "Automatically update the unison version number" +} + +describe_update_options() { + echo "--if-unset : Do not override currently selected version" +} + +do_update() { + [[ -z "${1}" ]] || ( [[ -z "${2}" ]] && [[ "${1}" == "--if-unset" ]] ) || \ + die -q "Usage error" + + if [[ -L "${ROOT}/usr/bin/unison" ]] ; then + [[ ${1} == "--if-unset" ]] && return + remove_symlinks || die -q "Can't remove existing symlink" + fi + if [[ -e "${ROOT}/usr/bin/unison" ]] ; then + die -q "${ROOT}/usr/bin/unison seems to be from an old ebuild, please remove manually" + elif ! [[ -z $(find_targets ) ]] ; then + set_symlinks 1 || die -q "Can't set a new version" + fi +} + +# vim: set ft=eselect : diff --git a/app-admin/eselect-unison/metadata.xml b/app-admin/eselect-unison/metadata.xml new file mode 100644 index 000000000000..2193d772e351 --- /dev/null +++ b/app-admin/eselect-unison/metadata.xml @@ -0,0 +1,5 @@ +<?xml version="1.0" encoding="UTF-8"?> +<!DOCTYPE pkgmetadata SYSTEM "http://www.gentoo.org/dtd/metadata.dtd"> +<pkgmetadata> +<herd>ml</herd> +</pkgmetadata> |