summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJonathan Callen <jcallen@gentoo.org>2010-02-28 18:11:03 +0000
committerJonathan Callen <jcallen@gentoo.org>2010-02-28 18:11:03 +0000
commit8cc4d80347044bc55576a2906b0e6780a3323fe7 (patch)
tree19aaf9b88e42018ed8a496ad9a6ac88154f33607 /app-admin/eselect-ecj
parentStable for HPPA (bug #306865). (diff)
downloadhistorical-8cc4d80347044bc55576a2906b0e6780a3323fe7.tar.gz
historical-8cc4d80347044bc55576a2906b0e6780a3323fe7.tar.bz2
historical-8cc4d80347044bc55576a2906b0e6780a3323fe7.zip
Version bump to add prefix support, keywords
Package-Manager: portage--svn/cvs/Linux i686
Diffstat (limited to 'app-admin/eselect-ecj')
-rw-r--r--app-admin/eselect-ecj/ChangeLog10
-rw-r--r--app-admin/eselect-ecj/Manifest14
-rw-r--r--app-admin/eselect-ecj/eselect-ecj-0.4.ebuild26
-rw-r--r--app-admin/eselect-ecj/files/ecj-0.4.eselect187
4 files changed, 234 insertions, 3 deletions
diff --git a/app-admin/eselect-ecj/ChangeLog b/app-admin/eselect-ecj/ChangeLog
index f2458f2c3942..981935e24c88 100644
--- a/app-admin/eselect-ecj/ChangeLog
+++ b/app-admin/eselect-ecj/ChangeLog
@@ -1,6 +1,12 @@
# ChangeLog for app-admin/eselect-ecj
-# Copyright 1999-2009 Gentoo Foundation; Distributed under the GPL v2
-# $Header: /var/cvsroot/gentoo-x86/app-admin/eselect-ecj/ChangeLog,v 1.5 2009/11/10 20:13:57 caster Exp $
+# Copyright 1999-2010 Gentoo Foundation; Distributed under the GPL v2
+# $Header: /var/cvsroot/gentoo-x86/app-admin/eselect-ecj/ChangeLog,v 1.6 2010/02/28 18:11:02 abcd Exp $
+
+*eselect-ecj-0.4 (28 Feb 2010)
+
+ 28 Feb 2010; Jonathan Callen <abcd@gentoo.org> +eselect-ecj-0.4.ebuild,
+ +files/ecj-0.4.eselect:
+ Version bump to add prefix support, keywords
10 Nov 2009; Vlastimil Babka <caster@gentoo.org> eselect-ecj-0.3.ebuild:
Remove ecj-3.2 and add ecj-3.5 in the dependency alternatives.
diff --git a/app-admin/eselect-ecj/Manifest b/app-admin/eselect-ecj/Manifest
index 7adee9d8f6c4..2c0e1f1e9bbc 100644
--- a/app-admin/eselect-ecj/Manifest
+++ b/app-admin/eselect-ecj/Manifest
@@ -1,4 +1,16 @@
+-----BEGIN PGP SIGNED MESSAGE-----
+Hash: SHA1
+
+AUX ecj-0.4.eselect 3961 RMD160 69f893bda58874b6f4145a6e15792fe4634452eb SHA1 ed959b1468bcae5a045c7e3f20b9eeb424f66c8d SHA256 c1d3f5f0ffc48891e5cdec3363dc6a00fa542e2fc8e330d3d6599c22f93efaf7
AUX ecj.eselect 3960 RMD160 9547fe4fd121414ff0a199a9aa196c5bff6d4f7f SHA1 1ab678117ec9df5cd0841f887e973b6e7e3d8895 SHA256 8124d5a2989584ad923c5914f4e52a846fc76670a7990a4ca3f763aeafaf726b
EBUILD eselect-ecj-0.3.ebuild 650 RMD160 45ca2a4ddb56ba22a0c4e287bea083be9a1d2f81 SHA1 addec9b2257de06d1940abf2311ff32f1dc6b2e7 SHA256 80881cf36a78647991a17f7571c4f8b2d921a15798780569539ded8ade64f745
-MISC ChangeLog 902 RMD160 12ed287d6ea82f5bebe7f9da046deec05726bb05 SHA1 873689a1408a2ca58f881dacdf69f6cef7918bc5 SHA256 bb0e4ea386115f26bd0a35e64bbf5e897e6508b1a9bd3f38cdbbb871d0d2fb7c
+EBUILD eselect-ecj-0.4.ebuild 734 RMD160 3f2f06bc490cd058e75e9a2da86725e835aa43a0 SHA1 5baba7f6c70be43d59d368919b24bdc2da9a6226 SHA256 6c0de20d303f13cf5faff0fca685646c8e0783a58f6e824952abe9df24b0f2a0
+MISC ChangeLog 1080 RMD160 fdd22dc05859a7f4343ee22e50d1e2e8ddbb80c8 SHA1 301018abd0c3075ef04544ced58330035e42fd7e SHA256 a131fa708a74eb5e3638bec67d824a083e292c039051463e44d45e19ebb2db52
MISC metadata.xml 158 RMD160 493079b5fb71d66863beea1b023901c90ba81be5 SHA1 77cd509a8b3c377b9a24480b48a5d5481b7874f1 SHA256 ea882ceccfd160b16cf7e79de423bdcc12b3fa000f124491a6df36f5783894fb
+-----BEGIN PGP SIGNATURE-----
+Version: GnuPG v2.0.14 (GNU/Linux)
+
+iEYEARECAAYFAkuKsb8ACgkQOypDUo0oQOpchQCfX2FCy5+5OHbsmwmNxK54i5jr
+a5cAn2bqDzxMeKUlnO5aAD7i9gzdRI5i
+=6TgG
+-----END PGP SIGNATURE-----
diff --git a/app-admin/eselect-ecj/eselect-ecj-0.4.ebuild b/app-admin/eselect-ecj/eselect-ecj-0.4.ebuild
new file mode 100644
index 000000000000..2b575aa43e05
--- /dev/null
+++ b/app-admin/eselect-ecj/eselect-ecj-0.4.ebuild
@@ -0,0 +1,26 @@
+# Copyright 1999-2010 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Header: /var/cvsroot/gentoo-x86/app-admin/eselect-ecj/eselect-ecj-0.4.ebuild,v 1.1 2010/02/28 18:11:02 abcd Exp $
+
+EAPI=1
+
+DESCRIPTION="Manages ECJ symlinks"
+HOMEPAGE="http://www.gentoo.org/"
+SRC_URI=""
+LICENSE="GPL-2"
+SLOT="0"
+KEYWORDS="~amd64 ~ia64 ~ppc ~ppc64 ~x86 ~x86-fbsd ~x86-freebsd ~amd64-linux ~x86-linux ~sparc-solaris ~x86-solaris"
+IUSE=""
+
+RDEPEND=">=app-admin/eselect-1.2"
+PDEPEND="
+|| (
+ dev-java/eclipse-ecj:3.5
+ dev-java/eclipse-ecj:3.4
+ >=dev-java/eclipse-ecj-3.3.0-r2:3.3
+)"
+
+src_install() {
+ insinto /usr/share/eselect/modules
+ newins "${FILESDIR}/ecj-${PV}.eselect" ecj.eselect || die "newins failed"
+}
diff --git a/app-admin/eselect-ecj/files/ecj-0.4.eselect b/app-admin/eselect-ecj/files/ecj-0.4.eselect
new file mode 100644
index 000000000000..196c111ffcb5
--- /dev/null
+++ b/app-admin/eselect-ecj/files/ecj-0.4.eselect
@@ -0,0 +1,187 @@
+# Copyright 1999-2010 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Id: ecj-0.4.eselect,v 1.1 2010/02/28 18:11:03 abcd Exp $
+
+DESCRIPTION="Manage ECJ targets"
+MAINTAINER="chewi@aura-online.co.uk"
+VERSION="0.4"
+
+ECJ="${EROOT}/usr/bin/ecj"
+
+# find a list of ecj symlink targets, best first.
+find_targets() {
+ for f in $(ls -r "${ECJ}"-[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}" = ecj-[0-9]* ]] && [[ -f "${EROOT}/usr/bin/${target}" ]] ; then
+ echo ${target}
+ else
+ die -q "Target \"${1}\" doesn't appear to be valid!"
+ fi
+}
+
+# try to remove the ecj symlink.
+remove_symlink() {
+ rm "${ECJ}" &>/dev/null
+}
+
+# determine the current target.
+get_target() {
+ local canonicalised=$(canonicalise "${ECJ}")
+ echo $(basename "${canonicalised}")
+}
+
+# set the ecj symlink.
+set_symlink() {
+ local target=$(find_target "${1}")
+ remove_symlink
+ ln -s "${EROOT}/usr/bin/${target}" "${ECJ}" || \
+ die "Couldn't set ${target} symlink."
+}
+
+### show action ###
+
+describe_show() {
+ echo "Show current ECJ target"
+}
+
+do_show() {
+ if [[ ${#} -gt 0 ]]; then
+ die -q "No parameters allowed."
+ fi
+
+ if [[ -L "${ECJ}" ]] ; then
+ get_target
+ return 0
+ elif [[ -e "${ECJ}" ]] ; then
+ echo "(not a symlink)" >&2
+ return 1
+ else
+ echo "(unset)" >&2
+ return 1
+ fi
+}
+
+### list action ###
+
+describe_list() {
+ echo "List available ECJ 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 "${ECJ}")
+ basename=$(basename "${canonicalised}")
+
+ if [[ "${targets[${i}]}" = "${basename}" ]] ; then
+ targets[${i}]="${targets[${i}]} $(highlight '*')"
+ fi
+ done
+
+ write_list_start "Available ECJ targets:"
+ write_numbered_list "${targets[@]}"
+ else
+ write_kv_list_entry "(none found)" ""
+ fi
+}
+
+### set action ###
+
+describe_set() {
+ echo "Set a new ECJ 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 "${ECJ}" ]] ; then
+ if ! remove_symlink ; then
+ die -q "Can't remove existing ecj provider."
+ elif ! set_symlink "${1}" ; then
+ die -q "Can't set new ecj provider."
+ fi
+ elif [[ -e "${ECJ}" ]] ; then
+ write_warning_msg "Can't set a new ecj provider. There's a file in the way at ${ECJ}. 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 ECJ 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 "${ECJ}")
+
+ if [[ ! -L "${ECJ}" ]] || [[ ! -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 :