diff options
author | 2009-05-12 19:08:17 +0000 | |
---|---|---|
committer | 2009-05-12 19:08:17 +0000 | |
commit | 5792f761cb2dd3479c74f1c76f7c628dc987d0e5 (patch) | |
tree | e81b36b740a19de799b2854bb87d646afdc84852 /app-admin | |
parent | Add mono support. forcing as this mono will be unmasked once this is committed. (diff) | |
download | historical-5792f761cb2dd3479c74f1c76f7c628dc987d0e5.tar.gz historical-5792f761cb2dd3479c74f1c76f7c628dc987d0e5.tar.bz2 historical-5792f761cb2dd3479c74f1c76f7c628dc987d0e5.zip |
New package eselect-maven. moved from java-exp overlay.
Package-Manager: portage-2.1.6.13/cvs/Linux x86_64
Diffstat (limited to 'app-admin')
-rw-r--r-- | app-admin/eselect-maven/ChangeLog | 14 | ||||
-rw-r--r-- | app-admin/eselect-maven/Manifest | 4 | ||||
-rw-r--r-- | app-admin/eselect-maven/eselect-maven-0.1.ebuild | 26 | ||||
-rw-r--r-- | app-admin/eselect-maven/files/maven.eselect | 187 | ||||
-rw-r--r-- | app-admin/eselect-maven/metadata.xml | 5 |
5 files changed, 236 insertions, 0 deletions
diff --git a/app-admin/eselect-maven/ChangeLog b/app-admin/eselect-maven/ChangeLog new file mode 100644 index 000000000000..25a5d2b0e540 --- /dev/null +++ b/app-admin/eselect-maven/ChangeLog @@ -0,0 +1,14 @@ +# ChangeLog for app-admin/eselect-maven +# Copyright 1999-2009 Gentoo Foundation; Distributed under the GPL v2 +# $Header: /var/cvsroot/gentoo-x86/app-admin/eselect-maven/ChangeLog,v 1.1 2009/05/12 19:08:16 ali_bush Exp $ + + 12 May 2009; Alistair Bush <ali_bush@gentoo.org> + +eselect-maven-0.1.ebuild, +files/maven.eselect, +metadata.xml: + Move eselect-maven from java-experimental overlay. + +*eselect-maven-0.1 (08 May 2009) + + 08 May 2009; Jesse Farinacci <jieryn@gmail.com> +eselect-maven-0.1.ebuild, + +files/maven.eselect, +metadata.xml: + initial import, related to bug #264027 + diff --git a/app-admin/eselect-maven/Manifest b/app-admin/eselect-maven/Manifest new file mode 100644 index 000000000000..2c9fda9096f3 --- /dev/null +++ b/app-admin/eselect-maven/Manifest @@ -0,0 +1,4 @@ +AUX maven.eselect 3973 RMD160 5ce8a91cf1df5eddd5444d0a8b17e4e6b02efc2e SHA1 48b49b1a490dee9784d26cb1559550c9a7cbe0fd SHA256 936763f3e8c3eb051414185cd0d54dd86059f2d176eb1078a8856d4bca6b0944 +EBUILD eselect-maven-0.1.ebuild 626 RMD160 ea480adc44109c0f917e5f72753bb913f79c43db SHA1 22413953cc2dc6501a4559891fe88c39c227a733 SHA256 8f19b77e66c7d484faf67089fb053a5943c4aebd1ab19f850a87973b91e9fba4 +MISC ChangeLog 584 RMD160 6f4c3f431d30d3209d20ab4304bdf43e6971c4ac SHA1 d5705aa80cbed749944369ad69f7177fc0774cba SHA256 5d29fea2ee62f3737987f4dce5759145796fb009e593a1a1675ce3508fa373cf +MISC metadata.xml 158 RMD160 493079b5fb71d66863beea1b023901c90ba81be5 SHA1 77cd509a8b3c377b9a24480b48a5d5481b7874f1 SHA256 ea882ceccfd160b16cf7e79de423bdcc12b3fa000f124491a6df36f5783894fb diff --git a/app-admin/eselect-maven/eselect-maven-0.1.ebuild b/app-admin/eselect-maven/eselect-maven-0.1.ebuild new file mode 100644 index 000000000000..1827d147805a --- /dev/null +++ b/app-admin/eselect-maven/eselect-maven-0.1.ebuild @@ -0,0 +1,26 @@ +# Copyright 1999-2009 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 +# $Header: /var/cvsroot/gentoo-x86/app-admin/eselect-maven/eselect-maven-0.1.ebuild,v 1.1 2009/05/12 19:08:16 ali_bush Exp $ + +EAPI=1 + +DESCRIPTION="Manages Maven symlinks" +HOMEPAGE="http://www.gentoo.org/" +SRC_URI="" +LICENSE="GPL-2" +SLOT="0" +KEYWORDS="~amd64 ~x86" +IUSE="" + +RDEPEND=">=app-admin/eselect-1.0.10 + !<dev-java/maven-bin-2.0.9-r1" +PDEPEND=" +|| ( + dev-java/maven-bin:2.0 + dev-java/maven-bin:2.1 +)" + +src_install() { + insinto /usr/share/eselect/modules + doins "${FILESDIR}/maven.eselect" || die "doins failed" +} diff --git a/app-admin/eselect-maven/files/maven.eselect b/app-admin/eselect-maven/files/maven.eselect new file mode 100644 index 000000000000..15f84f3a0279 --- /dev/null +++ b/app-admin/eselect-maven/files/maven.eselect @@ -0,0 +1,187 @@ +# Copyright 1999-2008 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 +# $Id: maven.eselect,v 1.1 2009/05/12 19:08:17 ali_bush Exp $ + +DESCRIPTION="Manage Maven targets" +MAINTAINER="jieryn@gmail.com" +VERSION="0.1" + +MVN="${ROOT}/usr/bin/mvn" + +# find a list of mvn symlink targets, best first. +find_targets() { + for f in $(ls -r "${MVN}"-[0-9]* 2> /dev/null) ; do + if [[ -f "${f}" ]] ; then + echo $(basename "${f}") + fi + done +} + +# get a named or numbered target. +find_target() { + local target=${1} + + if is_number "${target}" && [[ ${target} -ge 1 ]] ; then + targets=( $(find_targets ) ) + [[ -z "${targets}" ]] && die -q "No targets found!" + target=${targets[$(( ${target} - 1 ))]} + fi + + if [[ "${target}" = mvn-[0-9]* ]] && [[ -f "${ROOT}/usr/bin/${target}" ]] ; then + echo ${target} + else + die -q "Target \"${1}\" doesn't appear to be valid!" + fi +} + +# try to remove the mvn symlink. +remove_symlink() { + rm "${MVN}" &>/dev/null +} + +# determine the current target. +get_target() { + local canonicalised=$(canonicalise "${MVN}") + echo $(basename "${canonicalised}") +} + +# set the Maven symlink. +set_symlink() { + local target=$(find_target "${1}") + remove_symlink + ln -s "${ROOT}/usr/bin/${target}" "${MVN}" || \ + die "Couldn't set ${target} symlink." +} + +### show action ### + +describe_show() { + echo "Show current Maven target" +} + +do_show() { + if [[ ${#} -gt 0 ]]; then + die -q "No parameters allowed." + fi + + if [[ -L "${MVN}" ]] ; then + get_target + return 0 + elif [[ -e "${MVN}" ]] ; then + echo "(not a symlink)" >&2 + return 1 + else + echo "(unset)" >&2 + return 1 + fi +} + +### list action ### + +describe_list() { + echo "List available Maven targets" +} + +do_list() { + if [[ ${#} -gt 0 ]]; then + die -q "Usage error: no parameters allowed." + fi + + local i targets + targets=( $(find_targets) ) + + if [[ -n ${targets[@]} ]] ; then + local canonicalised basename + + for (( i = 0 ; i < ${#targets[@]} ; i = i + 1 )) ; do + canonicalised=$(canonicalise "${MVN}") + basename=$(basename "${canonicalised}") + + if [[ "${targets[${i}]}" = "${basename}" ]] ; then + targets[${i}]="${targets[${i}]} $(highlight '*')" + fi + done + + write_list_start "Available Maven targets:" + write_numbered_list "${targets[@]}" + else + write_kv_list_entry "(none found)" "" + fi +} + +### set action ### + +describe_set() { + echo "Set a new Maven target" +} + +describe_set_options() { + echo "target : Target name or number (from 'list' action)" +} + +describe_set_parameters() { + echo "<target>" +} + +do_set() { + if [[ $# -gt 1 ]]; then + die -q "Too many parameters. Expected only one." + fi + + local target=${1} + + if [[ -z "${target}" ]] ; then + die -q "You didn't give me a target name or number." + elif [[ -L "${MVN}" ]] ; then + if ! remove_symlink ; then + die -q "Can't remove existing Maven provider." + elif ! set_symlink "${1}" ; then + die -q "Can't set new Maven provider." + fi + elif [[ -e "${MVN}" ]] ; then + write_warning_msg "Can't set a new Maven provider. There's a file in the way at ${MVN}. You can try removing it manually, and then re-running this command." + else + set_symlink "${target}" || die -q "Wasn't able to set a new provider." + fi +} + +### update action ### + +describe_update() { + echo "Set the Maven target to the latest if the current target is invalid or if the given target is the latest" +} + +describe_update_options() { + echo "target (optional) : Target name (from 'list' action)" +} + +describe_update_parameters() { + echo "<target>" +} + +do_update() { + if [[ $# -gt 1 ]] ; then + die -q "Too many parameters. Expected only one." + fi + + # For pkg_postrm + if [[ ! $(find_targets) ]]; then + remove_symlink + return + fi + + local canonicalised=$(canonicalise "${MVN}") + + if [[ ! -L "${MVN}" ]] || [[ ! -f "${canonicalised}" ]] ; then + do_set 1 + elif [[ -n "${1}" ]] ; then + # Check whether target name is valid. + find_target "${1}" > /dev/null + + if [[ "${1}" == "$(find_target 1)" ]] ; then + do_set 1 + fi + fi +} + +# vim: set ft=eselect : diff --git a/app-admin/eselect-maven/metadata.xml b/app-admin/eselect-maven/metadata.xml new file mode 100644 index 000000000000..7303cef96964 --- /dev/null +++ b/app-admin/eselect-maven/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>java</herd> +</pkgmetadata> |