public inbox for gentoo-commits@lists.gentoo.org
 help / color / mirror / Atom feed
* [gentoo-commits] proj/musl:master commit in: sys-apps/portage/, sys-apps/portage/files/
@ 2016-01-21  1:44 Anthony G. Basile
  0 siblings, 0 replies; 4+ messages in thread
From: Anthony G. Basile @ 2016-01-21  1:44 UTC (permalink / raw
  To: gentoo-commits

commit:     a866c0d82835fc956b26f75437ac8175610afad7
Author:     Anthony G. Basile <blueness <AT> gentoo <DOT> org>
AuthorDate: Thu Jan 21 01:50:16 2016 +0000
Commit:     Anthony G. Basile <blueness <AT> gentoo <DOT> org>
CommitDate: Thu Jan 21 01:50:16 2016 +0000
URL:        https://gitweb.gentoo.org/proj/musl.git/commit/?id=a866c0d8

sys-apps/portage: fix check_locale on musl, bug #571444

Package-Manager: portage-2.2.26
RepoMan-Options: --force

 sys-apps/portage/Manifest                          |   5 +
 sys-apps/portage/files/README.RESCUE               |   2 +
 .../files/portage-2.2.26-fix-check_locale.patch    |  29 ++
 sys-apps/portage/metadata.xml                      |  20 ++
 sys-apps/portage/portage-2.2.26-r99.ebuild         | 368 +++++++++++++++++++++
 5 files changed, 424 insertions(+)

diff --git a/sys-apps/portage/Manifest b/sys-apps/portage/Manifest
new file mode 100644
index 0000000..14976fe
--- /dev/null
+++ b/sys-apps/portage/Manifest
@@ -0,0 +1,5 @@
+AUX README.RESCUE 137 SHA256 69bea0c755eab59b6b4d90838b8551744f0b0c8eeac170b1cd13a71ee83f9ac4 SHA512 dba0f0d6d4cd140e636cc70dfb7bdb298e2f2fb040bc07b0874cac994bdbabd26bfd9361d85a0f8b9a92a185281e4901606b9e4f563afdc8867341bbe6af1cb0 WHIRLPOOL 713fcc790442999d56e13efaf536fec9954dadeda680b3642d0358311332096ddedf8b55697bd1ca620d84f0dc7d025ff7931e086c74c1f5032be72dca2ff8f5
+AUX portage-2.2.26-fix-check_locale.patch 810 SHA256 d055958fe52fbfb4d628b11c3a52226f0ce07895d951efbf285d55b0bac455a1 SHA512 33b4d497788de9146abe9a99e4c788c94e8e5e4e615ae7bf18ed415407d4bf0398fb972d938a78f3fff1edfee425f2d672e9868e58efb15cfcccab65cfb5152b WHIRLPOOL 3477eb51320b13de03038e5cf1987f00cce03d65467148ffc23728540de09fde94128cc25986fc40688206059d2ca84734ba4a7379583f68511a2c5f0f0aff23
+DIST portage-2.2.26.tar.bz2 977277 SHA256 7f57aa704c58ea47f031f177203dc7b335e01e7ec1e809437ea9e46e3f9263e5 SHA512 fd1a5e5d028d52ba82bbeb7f87bf331d0c1d8c7f5a3bd450c668dd742e99185b6d2b21944f5d7788fe941c99736744b08157ca30145f0964ea60a7c2c435d601 WHIRLPOOL 0469f4c5609146c57eae4baeb8488b95c04f336a5511460ee44d15746339fd43a7c2d61b58528845d77a6a0b21e46c2afad19a9f05e94ac8dc6180032d71f298
+EBUILD portage-2.2.26-r99.ebuild 11703 SHA256 32a5b9852ff9620a1b1191baa2b54e0fb6b6abc8bad8944f0a9d6757e249a058 SHA512 b83b69af04617c925c4be8cd9d0a18c7d62c3b9d5b127d4451245bc8f6bcf24c6e3d16228c5e198f3969fc7049178d0f9a9c0cf669c09a4e2c61d4d2d5fc2e14 WHIRLPOOL f598ce0601676f3f0e7b84045e909b1158a33b3da58f3b4e7d3d19febb79f0794aab1ed6804b956b695d48d62462b65c9c18b8602ecd1380d522dfb234d357e7
+MISC metadata.xml 1002 SHA256 fc87597788bb707c98546201df63e6c4ecbbd22f74b0258d447336b80bd06dcc SHA512 db96daddb29c78919b6dccd88549d5f3b567ba834314663a2ac6c571a2e143ba3dd409e81f378d4b0f40c49d8eb42038b521579a88493a0054e94226d233ebe1 WHIRLPOOL 9d872e9fe5e3384d7270f0dd7b648c23e5858d620e9d530ee895570b145c351c265d0852f32a22c73f625ae2cd7de1641ebdca5ea2c293c5c37e5976f62eaa1b

diff --git a/sys-apps/portage/files/README.RESCUE b/sys-apps/portage/files/README.RESCUE
new file mode 100644
index 0000000..70c494e
--- /dev/null
+++ b/sys-apps/portage/files/README.RESCUE
@@ -0,0 +1,2 @@
+Please see http://www.gentoo.org/proj/en/portage/doc/manually-fixing-portage.xml
+for a recovery guide for a broken portage installation.

diff --git a/sys-apps/portage/files/portage-2.2.26-fix-check_locale.patch b/sys-apps/portage/files/portage-2.2.26-fix-check_locale.patch
new file mode 100644
index 0000000..7d137d6
--- /dev/null
+++ b/sys-apps/portage/files/portage-2.2.26-fix-check_locale.patch
@@ -0,0 +1,29 @@
+diff -Naur portage-2.2.26.orig/pym/portage/util/locale.py portage-2.2.26/pym/portage/util/locale.py
+--- portage-2.2.26.orig/pym/portage/util/locale.py	2015-11-24 16:38:22.000000000 -0500
++++ portage-2.2.26/pym/portage/util/locale.py	2016-01-20 20:08:08.731746146 -0500
+@@ -13,10 +13,10 @@
+ import os
+ import textwrap
+ import traceback
++from ctypes import CDLL
+ 
+ import portage
+ from portage.util import writemsg_level
+-from portage.util._ctypes import find_library, LoadLibrary
+ 
+ 
+ locale_categories = (
+@@ -35,12 +35,7 @@
+ 	The inner locale check function.
+ 	"""
+ 
+-	libc_fn = find_library("c")
+-	if libc_fn is None:
+-		return None
+-	libc = LoadLibrary(libc_fn)
+-	if libc is None:
+-		return None
++	libc = CDLL("libc.so.6")
+ 
+ 	lc = list(range(ord('a'), ord('z')+1))
+ 	uc = list(range(ord('A'), ord('Z')+1))

diff --git a/sys-apps/portage/metadata.xml b/sys-apps/portage/metadata.xml
new file mode 100644
index 0000000..68283d8
--- /dev/null
+++ b/sys-apps/portage/metadata.xml
@@ -0,0 +1,20 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!DOCTYPE pkgmetadata SYSTEM "http://www.gentoo.org/dtd/metadata.dtd">
+<pkgmetadata>
+  <upstream>
+    <bugs-to>mailto:dev-portage@gentoo.org</bugs-to>
+    <changelog>https://gitweb.gentoo.org/proj/portage.git/plain/RELEASE-NOTES</changelog>
+    <doc>https://wiki.gentoo.org/wiki/Handbook:AMD64/Working/Portage</doc>
+  </upstream>
+  <maintainer>
+    <email>dev-portage@gentoo.org</email>
+  </maintainer>
+  <use>
+    <flag name="epydoc">Build html API documentation with epydoc.</flag>
+    <flag name="ipc">Use inter-process communication between portage and running ebuilds.</flag>
+    <flag name="pypy2_0">Use pypy-c2.0 as Python interpreter.</flag>
+    <flag name="python2">Use python2 as Python interpreter.</flag>
+    <flag name="python3">Use python3 as Python interpreter.</flag>
+    <flag name="xattr">Preserve extended attributes (filesystem-stored metadata) when installing files. Usually only required for hardened systems.</flag>
+  </use>
+</pkgmetadata>

diff --git a/sys-apps/portage/portage-2.2.26-r99.ebuild b/sys-apps/portage/portage-2.2.26-r99.ebuild
new file mode 100644
index 0000000..3aa681a
--- /dev/null
+++ b/sys-apps/portage/portage-2.2.26-r99.ebuild
@@ -0,0 +1,368 @@
+# Copyright 1999-2016 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Id$
+
+EAPI=5
+
+PYTHON_COMPAT=(
+	pypy
+	python3_3 python3_4 python3_5
+	python2_7
+)
+PYTHON_REQ_USE='bzip2(+)'
+
+inherit distutils-r1 eutils multilib
+
+DESCRIPTION="Portage is the package management and distribution system for Gentoo"
+HOMEPAGE="https://wiki.gentoo.org/wiki/Project:Portage"
+
+LICENSE="GPL-2"
+KEYWORDS="amd64 arm ~mips ppc x86"
+SLOT="0"
+IUSE="build doc epydoc +ipc linguas_ru selinux xattr"
+
+DEPEND="!build? ( $(python_gen_impl_dep 'ssl(+)') )
+	>=app-arch/tar-1.27
+	dev-lang/python-exec:2
+	>=sys-apps/sed-4.0.5 sys-devel/patch
+	doc? ( app-text/xmlto ~app-text/docbook-xml-dtd-4.4 )
+	epydoc? ( >=dev-python/epydoc-2.0[$(python_gen_usedep 'python2*')] )"
+# Require sandbox-2.2 for bug #288863.
+# For xattr, we can spawn getfattr and setfattr from sys-apps/attr, but that's
+# quite slow, so it's not considered in the dependencies as an alternative to
+# to python-3.3 / pyxattr. Also, xattr support is only tested with Linux, so
+# for now, don't pull in xattr deps for other kernels.
+# For whirlpool hash, require python[ssl] (bug #425046).
+# For compgen, require bash[readline] (bug #445576).
+RDEPEND="
+	>=app-arch/tar-1.27
+	dev-lang/python-exec:2
+	!build? (
+		>=sys-apps/sed-4.0.5
+		app-shells/bash:0[readline]
+		>=app-admin/eselect-1.2
+	)
+	elibc_FreeBSD? ( sys-freebsd/freebsd-bin )
+	elibc_glibc? ( >=sys-apps/sandbox-2.2 )
+	elibc_uclibc? ( >=sys-apps/sandbox-2.2 )
+	>=app-misc/pax-utils-0.1.17
+	selinux? ( >=sys-libs/libselinux-2.0.94[python,${PYTHON_USEDEP}] )
+	xattr? ( kernel_linux? (
+		>=sys-apps/install-xattr-0.3
+		$(python_gen_cond_dep 'dev-python/pyxattr[${PYTHON_USEDEP}]' \
+			python2_7 pypy)
+	) )
+	!<app-admin/logrotate-3.8.0"
+PDEPEND="
+	!build? (
+		>=net-misc/rsync-2.6.4
+		userland_GNU? ( >=sys-apps/coreutils-6.4 )
+	)"
+# coreutils-6.4 rdep is for date format in emerge-webrsync #164532
+# NOTE: FEATURES=installsources requires debugedit and rsync
+
+REQUIRED_USE="epydoc? ( $(python_gen_useflags 'python2*') )"
+
+SRC_ARCHIVES="https://dev.gentoo.org/~dolsen/releases/portage"
+
+prefix_src_archives() {
+	local x y
+	for x in ${@}; do
+		for y in ${SRC_ARCHIVES}; do
+			echo ${y}/${x}
+		done
+	done
+}
+
+TARBALL_PV=${PV}
+SRC_URI="mirror://gentoo/${PN}-${TARBALL_PV}.tar.bz2
+	$(prefix_src_archives ${PN}-${TARBALL_PV}.tar.bz2)"
+
+pkg_setup() {
+	use epydoc && DISTUTILS_ALL_SUBPHASE_IMPLS=( python2.7 )
+}
+
+python_prepare_all() {
+	distutils-r1_python_prepare_all
+
+	epatch "${FILESDIR}"/${P}-fix-check_locale.patch
+
+	if ! use ipc ; then
+		einfo "Disabling ipc..."
+		sed -e "s:_enable_ipc_daemon = True:_enable_ipc_daemon = False:" \
+			-i pym/_emerge/AbstractEbuildProcess.py || \
+			die "failed to patch AbstractEbuildProcess.py"
+	fi
+
+	if use xattr && use kernel_linux ; then
+		einfo "Adding FEATURES=xattr to make.globals ..."
+		echo -e '\nFEATURES="${FEATURES} xattr"' >> cnf/make.globals \
+			|| die "failed to append to make.globals"
+	fi
+
+	if [[ -n ${EPREFIX} ]] ; then
+		einfo "Setting portage.const.EPREFIX ..."
+		sed -e "s|^\(SANDBOX_BINARY[[:space:]]*=[[:space:]]*\"\)\(/usr/bin/sandbox\"\)|\\1${EPREFIX}\\2|" \
+			-e "s|^\(FAKEROOT_BINARY[[:space:]]*=[[:space:]]*\"\)\(/usr/bin/fakeroot\"\)|\\1${EPREFIX}\\2|" \
+			-e "s|^\(BASH_BINARY[[:space:]]*=[[:space:]]*\"\)\(/bin/bash\"\)|\\1${EPREFIX}\\2|" \
+			-e "s|^\(MOVE_BINARY[[:space:]]*=[[:space:]]*\"\)\(/bin/mv\"\)|\\1${EPREFIX}\\2|" \
+			-e "s|^\(PRELINK_BINARY[[:space:]]*=[[:space:]]*\"\)\(/usr/sbin/prelink\"\)|\\1${EPREFIX}\\2|" \
+			-e "s|^\(EPREFIX[[:space:]]*=[[:space:]]*\"\).*|\\1${EPREFIX}\"|" \
+			-i pym/portage/const.py || \
+			die "Failed to patch portage.const.EPREFIX"
+
+		einfo "Prefixing shebangs ..."
+		while read -r -d $'\0' ; do
+			local shebang=$(head -n1 "$REPLY")
+			if [[ ${shebang} == "#!"* && ! ${shebang} == "#!${EPREFIX}/"* ]] ; then
+				sed -i -e "1s:.*:#!${EPREFIX}${shebang:2}:" "$REPLY" || \
+					die "sed failed"
+			fi
+		done < <(find . -type f -print0)
+
+		einfo "Adjusting make.globals ..."
+		sed -e "s|\(/usr/portage\)|${EPREFIX}\\1|" \
+			-e "s|^\(PORTAGE_TMPDIR=\"\)\(/var/tmp\"\)|\\1${EPREFIX}\\2|" \
+			-i cnf/make.globals || die "sed failed"
+
+		einfo "Adjusting repos.conf ..."
+		sed -e "s|^\(main-repo = \).*|\\1gentoo_prefix|" \
+			-e "s|^\\[gentoo\\]|[gentoo_prefix]|" \
+			-e "s|^\(location = \)\(/usr/portage\)|\\1${EPREFIX}\\2|" \
+			-e "s|^\(sync-uri = \).*|\\1rsync://prefix.gentooexperimental.org/gentoo-portage-prefix|" \
+			-i cnf/repos.conf || die "sed failed"
+
+		einfo "Adding FEATURES=force-prefix to make.globals ..."
+		echo -e '\nFEATURES="${FEATURES} force-prefix"' >> cnf/make.globals \
+			|| die "failed to append to make.globals"
+	fi
+
+	cd "${S}/cnf" || die
+	if [ -f "make.conf.example.${ARCH}".diff ]; then
+		patch make.conf.example "make.conf.example.${ARCH}".diff || \
+			die "Failed to patch make.conf.example"
+	else
+		eerror ""
+		eerror "Portage does not have an arch-specific configuration for this arch."
+		eerror "Please notify the arch maintainer about this issue. Using generic."
+		eerror ""
+	fi
+}
+
+python_compile_all() {
+	local targets=()
+	use doc && targets+=( docbook )
+	use epydoc && targets+=( epydoc )
+
+	if [[ ${targets[@]} ]]; then
+		esetup.py "${targets[@]}"
+	fi
+}
+
+python_test() {
+	esetup.py test
+}
+
+python_install() {
+	# Install sbin scripts to bindir for python-exec linking
+	# they will be relocated in pkg_preinst()
+	distutils-r1_python_install \
+		--system-prefix="${EPREFIX}/usr" \
+		--bindir="$(python_get_scriptdir)" \
+		--docdir="${EPREFIX}/usr/share/doc/${PF}" \
+		--htmldir="${EPREFIX}/usr/share/doc/${PF}/html" \
+		--portage-bindir="${EPREFIX}/usr/lib/portage/${EPYTHON}" \
+		--sbindir="$(python_get_scriptdir)" \
+		--sysconfdir="${EPREFIX}/etc" \
+		"${@}"
+}
+
+python_install_all() {
+	distutils-r1_python_install_all
+
+	local targets=()
+	use doc && targets+=( install_docbook )
+	use epydoc && targets+=( install_epydoc )
+
+	# install docs
+	if [[ ${targets[@]} ]]; then
+		esetup.py "${targets[@]}"
+	fi
+
+	# Due to distutils/python-exec limitations
+	# these must be installed to /usr/bin.
+	local sbin_relocations='archive-conf dispatch-conf emaint env-update etc-update fixpackages regenworld'
+	einfo "Moving admin scripts to the correct directory"
+	dodir /usr/sbin
+	for target in ${sbin_relocations}; do
+		einfo "Moving /usr/bin/${target} to /usr/sbin/${target}"
+		mv "${ED}usr/bin/${target}" "${ED}usr/sbin/${target}" || die "sbin scripts move failed!"
+	done
+}
+
+pkg_preinst() {
+	# comment out sanity test until it is fixed to work
+	# with the new PORTAGE_PYM_PATH
+	#if [[ $ROOT == / ]] ; then
+		## Run some minimal tests as a sanity check.
+		#local test_runner=$(find "${ED}" -name runTests)
+		#if [[ -n $test_runner && -x $test_runner ]] ; then
+			#einfo "Running preinst sanity tests..."
+			#"$test_runner" || die "preinst sanity tests failed"
+		#fi
+	#fi
+
+	# elog dir must exist to avoid logrotate error for bug #415911.
+	# This code runs in preinst in order to bypass the mapping of
+	# portage:portage to root:root which happens after src_install.
+	keepdir /var/log/portage/elog
+	# This is allowed to fail if the user/group are invalid for prefix users.
+	if chown portage:portage "${ED}"var/log/portage{,/elog} 2>/dev/null ; then
+		chmod g+s,ug+rwx "${ED}"var/log/portage{,/elog}
+	fi
+
+	if has_version "<${CATEGORY}/${PN}-2.1.13" || \
+		{
+			has_version ">=${CATEGORY}/${PN}-2.2_rc0" && \
+			has_version "<${CATEGORY}/${PN}-2.2.0_alpha189"
+		} ; then
+		USERPRIV_UPGRADE=true
+		USERSYNC_UPGRADE=true
+		REPOS_CONF_UPGRADE=true
+		REPOS_CONF_SYNC=
+		type -P portageq >/dev/null 2>&1 && \
+			REPOS_CONF_SYNC=$("$(type -P portageq)" envvar SYNC)
+	else
+		USERPRIV_UPGRADE=false
+		USERSYNC_UPGRADE=false
+		REPOS_CONF_UPGRADE=false
+	fi
+}
+
+get_ownership() {
+	case ${USERLAND} in
+		BSD)
+			stat -f '%Su:%Sg' "${1}"
+			;;
+		*)
+			stat -c '%U:%G' "${1}"
+			;;
+	esac
+}
+
+new_config_protect() {
+	# Generate a ._cfg file even if the target file
+	# does not exist, ensuring that the user will
+	# notice the config change.
+	local basename=${1##*/}
+	local dirname=${1%/*}
+	local i=0
+	while true ; do
+		local filename=$(
+			echo -n "${dirname}/._cfg"
+			printf "%04d" ${i}
+			echo -n "_${basename}"
+		)
+		[[ -e ${filename} ]] || break
+		(( i++ ))
+	done
+	echo "${filename}"
+}
+
+pkg_postinst() {
+
+	if ${REPOS_CONF_UPGRADE} ; then
+		einfo "Generating repos.conf"
+		local repo_name=
+		[[ -f ${PORTDIR}/profiles/repo_name ]] && \
+			repo_name=$(< "${PORTDIR}/profiles/repo_name")
+		if [[ -z ${REPOS_CONF_SYNC} ]] ; then
+			REPOS_CONF_SYNC=$(grep "^sync-uri =" "${EROOT:-${ROOT}}usr/share/portage/config/repos.conf")
+			REPOS_CONF_SYNC=${REPOS_CONF_SYNC##* }
+		fi
+		local sync_type=
+		[[ ${REPOS_CONF_SYNC} == git://* ]] && sync_type=git
+
+		if [[ ${REPOS_CONF_SYNC} == cvs://* ]]; then
+			sync_type=cvs
+			REPOS_CONF_SYNC=${REPOS_CONF_SYNC#cvs://}
+		fi
+
+		cat <<-EOF > "${T}/repos.conf"
+		[DEFAULT]
+		main-repo = ${repo_name:-gentoo}
+
+		[${repo_name:-gentoo}]
+		location = ${PORTDIR:-${EPREFIX}/usr/portage}
+		sync-type = ${sync_type:-rsync}
+		sync-uri = ${REPOS_CONF_SYNC}
+		EOF
+
+		[[ ${sync_type} == cvs ]] && echo "sync-cvs-repo = $(<"${PORTDIR}/CVS/Repository")" >> "${T}/repos.conf"
+
+		local dest=${EROOT:-${ROOT}}etc/portage/repos.conf
+		if [[ ! -f ${dest} ]] && mkdir -p "${dest}" 2>/dev/null ; then
+			dest=${EROOT:-${ROOT}}etc/portage/repos.conf/${repo_name:-gentoo}.conf
+		fi
+		# Don't install the config update if the desired repos.conf directory
+		# and config file exist, since users may accept it blindly and break
+		# their config (bug #478726).
+		[[ -e ${EROOT:-${ROOT}}etc/portage/repos.conf/${repo_name:-gentoo}.conf ]] || \
+			mv "${T}/repos.conf" "$(new_config_protect "${dest}")"
+
+		if [[ ${PORTDIR} == ${EPREFIX}/usr/portage ]] ; then
+			einfo "Generating make.conf PORTDIR setting for backward compatibility"
+			for dest in "${EROOT:-${ROOT}}etc/make.conf" "${EROOT:-${ROOT}}etc/portage/make.conf" ; do
+				[[ -e ${dest} ]] && break
+			done
+			[[ -d ${dest} ]] && dest=${dest}/portdir.conf
+			rm -rf "${T}/make.conf"
+			[[ -f ${dest} ]] && cat "${dest}" > "${T}/make.conf"
+			cat <<-EOF >> "${T}/make.conf"
+
+			# Set PORTDIR for backward compatibility with various tools:
+			#   gentoo-bashcomp - bug #478444
+			#   euse - bug #474574
+			#   euses and ufed - bug #478318
+			PORTDIR="${EPREFIX}/usr/portage"
+			EOF
+			mkdir -p "${dest%/*}"
+			mv "${T}/make.conf" "$(new_config_protect "${dest}")"
+		fi
+	fi
+
+	local distdir=${PORTAGE_ACTUAL_DISTDIR-${DISTDIR}}
+
+	if ${USERSYNC_UPGRADE} && \
+		[[ -d ${PORTDIR} && -w ${PORTDIR} ]] ; then
+		local ownership=$(get_ownership "${PORTDIR}")
+		if [[ -n ${ownership} ]] ; then
+			einfo "Adjusting PORTDIR permissions for usersync"
+			find "${PORTDIR}" -path "${distdir%/}" -prune -o \
+				! \( -user "${ownership%:*}" -a -group "${ownership#*:}" \) \
+				-exec chown "${ownership}" {} +
+		fi
+	fi
+
+	# Do this last, since it could take a long time if there
+	# are lots of live sources, and the user may be tempted
+	# to kill emerge while it is running.
+	if ${USERPRIV_UPGRADE} && \
+		[[ -d ${distdir} && -w ${distdir} ]] ; then
+		local ownership=$(get_ownership "${distdir}")
+		if [[ ${ownership#*:} == portage ]] ; then
+			einfo "Adjusting DISTDIR permissions for userpriv"
+			find "${distdir}" -mindepth 1 -maxdepth 1 -type d -uid 0 \
+				-exec chown -R portage:portage {} +
+		fi
+	fi
+
+	einfo ""
+	einfo "This release of portage contains the new repoman code base"
+	einfo "This code base is still being developed.  So its API's are"
+	einfo "not to be considered stable and are subject to change."
+	einfo "The code released has been tested and considered ready for use."
+	einfo "This however does not guarantee it to be completely bug free."
+	einfo "Please report any bugs you may encounter."
+	einfo ""
+}


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

* [gentoo-commits] proj/musl:master commit in: sys-apps/portage/, sys-apps/portage/files/
@ 2016-06-20 19:34 Anthony G. Basile
  0 siblings, 0 replies; 4+ messages in thread
From: Anthony G. Basile @ 2016-06-20 19:34 UTC (permalink / raw
  To: gentoo-commits

commit:     0674131adf745882b40cb02ba39747382541c4ab
Author:     Anthony G. Basile <blueness <AT> gentoo <DOT> org>
AuthorDate: Mon Jun 20 19:37:02 2016 +0000
Commit:     Anthony G. Basile <blueness <AT> gentoo <DOT> org>
CommitDate: Mon Jun 20 19:37:02 2016 +0000
URL:        https://gitweb.gentoo.org/proj/musl.git/commit/?id=0674131a

sys-apps/portage: backport C module fix

Package-Manager: portage-2.2.28

 sys-apps/portage/Manifest                          |   6 +-
 ...-util-locale.py-fix-decoding-for-python2-.patch |  40 ++++++
 ...d-stub-for-building-custom-modules-in-C-C.patch |  59 ++++++++
 ...-util-locale.py-add-a-C-module-to-help-ch.patch | 151 +++++++++++++++++++++
 ....2.26-r99.ebuild => portage-2.2.28-r999.ebuild} |   8 +-
 5 files changed, 259 insertions(+), 5 deletions(-)

diff --git a/sys-apps/portage/Manifest b/sys-apps/portage/Manifest
index aa4ce2d..51130a3 100644
--- a/sys-apps/portage/Manifest
+++ b/sys-apps/portage/Manifest
@@ -1,7 +1,9 @@
+AUX 0001-pym-portage-util-locale.py-fix-decoding-for-python2-.patch 1374 SHA256 1c40030d4ef7c2a56ea81f00281a56432bb7918d294abcda7b9eab7eb05fd1c9 SHA512 f434323783fa4db0bc096f35da93a33311f00fd8b315f95cc5f3d78365ea0d70376609c27f1d64319bd49f83db6d0cc7d88d035c758f1f0de62f1ef9243c0a30 WHIRLPOOL cdecf4a184fea71c0ee93aa5598cc513e676203d8a226da8c90524471d79f2c22b474c2a2edba0ae3495257792dfc7bd3e78c9a9aed3e9e85bb4906161451891
+AUX 0002-setup.py-add-stub-for-building-custom-modules-in-C-C.patch 1867 SHA256 285fd48357a1996a92860a03059656729d5faa05e4d150865abaaf79f93d5acd SHA512 e073c849650822ea01c804605a4c5743957f9c8c45076dcd9a983951f6607716c1891c0a564268af3c1c0680361d0c4605ed30e50c4f0a23909a1f155925622a WHIRLPOOL f0e6bdaa992d2d374a65e96c9a148b6460a42bb1d939f1b60bbb11368553c750318befae3157e236302580f8b682887ebdc08ec40e62e8f1d81cda925cd48e97
+AUX 0003-pym-portage-util-locale.py-add-a-C-module-to-help-ch.patch 4075 SHA256 42e7c7c9eff8ee423f9e23a7f3d9aa2d629b2755cd053c21d53796bfb9f3655f SHA512 090b8905db5af236644e57b3050e80dab0d58ef63abd2c94746a63204de155379ab63ca9536e53e30be6d6e7bf529047675e17ce266c0256f5f1f828222e4a32 WHIRLPOOL 0b9baa422b64072eb95454b8e833fa040a4ea47d609f42ac7da744f58d3ef20d96e06ce4c488b26593c311a0d9451cc684849d04093328abf34d174c90023a7d
 AUX README.RESCUE 137 SHA256 69bea0c755eab59b6b4d90838b8551744f0b0c8eeac170b1cd13a71ee83f9ac4 SHA512 dba0f0d6d4cd140e636cc70dfb7bdb298e2f2fb040bc07b0874cac994bdbabd26bfd9361d85a0f8b9a92a185281e4901606b9e4f563afdc8867341bbe6af1cb0 WHIRLPOOL 713fcc790442999d56e13efaf536fec9954dadeda680b3642d0358311332096ddedf8b55697bd1ca620d84f0dc7d025ff7931e086c74c1f5032be72dca2ff8f5
 AUX portage-2.2.26-fix-check_locale.patch 810 SHA256 d055958fe52fbfb4d628b11c3a52226f0ce07895d951efbf285d55b0bac455a1 SHA512 33b4d497788de9146abe9a99e4c788c94e8e5e4e615ae7bf18ed415407d4bf0398fb972d938a78f3fff1edfee425f2d672e9868e58efb15cfcccab65cfb5152b WHIRLPOOL 3477eb51320b13de03038e5cf1987f00cce03d65467148ffc23728540de09fde94128cc25986fc40688206059d2ca84734ba4a7379583f68511a2c5f0f0aff23
-DIST portage-2.2.26.tar.bz2 977277 SHA256 7f57aa704c58ea47f031f177203dc7b335e01e7ec1e809437ea9e46e3f9263e5 SHA512 fd1a5e5d028d52ba82bbeb7f87bf331d0c1d8c7f5a3bd450c668dd742e99185b6d2b21944f5d7788fe941c99736744b08157ca30145f0964ea60a7c2c435d601 WHIRLPOOL 0469f4c5609146c57eae4baeb8488b95c04f336a5511460ee44d15746339fd43a7c2d61b58528845d77a6a0b21e46c2afad19a9f05e94ac8dc6180032d71f298
 DIST portage-2.2.28.tar.bz2 969138 SHA256 da8148a1a9275c87f535679e41b1bb3a1380ba0f903b80510017517e4c5229d0 SHA512 d21bf7e7dcc0a779a13df6a959e5d4291492fce2a5525b67e9a4705888021f9c08b8d78cd32b2eb930ac5428c40383e4e46da5a7b1ed5c9c9c42314c0f1c6a0b WHIRLPOOL 1b9584b0243b46c70d0778aad57df2d3ea99e19f243280e542c29e6fed0634b72de6b203a3c296c2977d1a6e5e5250b910574176c692d2c7c27c0938528bb43d
-EBUILD portage-2.2.26-r99.ebuild 11703 SHA256 32a5b9852ff9620a1b1191baa2b54e0fb6b6abc8bad8944f0a9d6757e249a058 SHA512 b83b69af04617c925c4be8cd9d0a18c7d62c3b9d5b127d4451245bc8f6bcf24c6e3d16228c5e198f3969fc7049178d0f9a9c0cf669c09a4e2c61d4d2d5fc2e14 WHIRLPOOL f598ce0601676f3f0e7b84045e909b1158a33b3da58f3b4e7d3d19febb79f0794aab1ed6804b956b695d48d62462b65c9c18b8602ecd1380d522dfb234d357e7
 EBUILD portage-2.2.28-r99.ebuild 11704 SHA256 b814d8beda3bd2364b13153ef5663d40497684ace1cdc2209bd03a61a5fe8fb7 SHA512 78442e2d479acb0b59cade22060c5bef2740cf3c5ae451b25ca629f547824f4bb04a768e5400623d1508f72318bbc0abcf31b8286886241de6cbe640f0f95eb1 WHIRLPOOL 7f220a0e33e825b123f364dff0d43d57f1823bb01e454f66fea71825ec206d4fb8ce42478e033e98fb6c6ae1f598af57008b64effe6274a53e5655e39834095f
+EBUILD portage-2.2.28-r999.ebuild 11908 SHA256 65003a03410bcfcc49b56746293dcdf8bbcabb6c85e6f4229fe2caf97a27dbe9 SHA512 4e33ae8ee35ecf9bf609e8b603de050903e4b4a1c79fc6eb65cff524b731dd044314ce72a663296cd511451e333351de1ac6374569d85852fd5ab6800bddaa7c WHIRLPOOL 842c97b6cfd98ca4f3b0de666b5bc3ce465cab48cd94cf66b7fe593be4344b8737da780cb8da7c2434880ee0e5df8594061c34914451fd6425cb84cf153cf0c4
 MISC metadata.xml 814 SHA256 e33780a3f1af692a5539738aa243581beb5d6398daf23ac28a252b8481742db1 SHA512 d68c833a70bae0e497f5c0217f6f64161c7cbe3fd01253e8f5657512e5eb62438dec5cc587ca9667c0cd4f791f25cdcb3f7017743f6f66cfdc41fec835b4f3a7 WHIRLPOOL b2c926e03f312e1cdcaedf1f6c5f9b0c25887e93f44fb8aef56212f72369e1916efa863e34cd568d0f50cddcaf8fb9bf33d745d7fc785c62476162465f3298b7

diff --git a/sys-apps/portage/files/0001-pym-portage-util-locale.py-fix-decoding-for-python2-.patch b/sys-apps/portage/files/0001-pym-portage-util-locale.py-fix-decoding-for-python2-.patch
new file mode 100644
index 0000000..258c221
--- /dev/null
+++ b/sys-apps/portage/files/0001-pym-portage-util-locale.py-fix-decoding-for-python2-.patch
@@ -0,0 +1,40 @@
+From f13322877e2778f145308160ccee5d2e27b34235 Mon Sep 17 00:00:00 2001
+From: "Anthony G. Basile" <blueness@gentoo.org>
+Date: Wed, 25 May 2016 08:48:32 -0400
+Subject: [PATCH 1/3] pym/portage/util/locale.py: fix decoding for python2 plus
+ some locales
+
+When using python2 with some locales, like turkish, chr() is passed values not in
+range(128) which cannot be decoded as ASCII, thus throwing a UnicodeDecodeError
+exception.  We use _unicode_decode() from portage.util to address this.
+
+Signed-off-by: Anthony G. Basile <blueness@gentoo.org>
+---
+ pym/portage/util/locale.py | 4 ++--
+ 1 file changed, 2 insertions(+), 2 deletions(-)
+
+diff --git a/pym/portage/util/locale.py b/pym/portage/util/locale.py
+index 2a15ea1..093eb86 100644
+--- a/pym/portage/util/locale.py
++++ b/pym/portage/util/locale.py
+@@ -15,7 +15,7 @@ import textwrap
+ import traceback
+ 
+ import portage
+-from portage.util import writemsg_level
++from portage.util import _unicode_decode, writemsg_level
+ from portage.util._ctypes import find_library, LoadLibrary
+ 
+ 
+@@ -62,7 +62,7 @@ def _check_locale(silent):
+ 			"as LC_CTYPE in make.conf.")
+ 		msg = [l for l in textwrap.wrap(msg, 70)]
+ 		msg.append("")
+-		chars = lambda l: ''.join(chr(x) for x in l)
++		chars = lambda l: ''.join(_unicode_decode(chr(x)) for x in l)
+ 		if uc != ruc:
+ 			msg.extend([
+ 				"  %s -> %s" % (chars(lc), chars(ruc)),
+-- 
+2.7.3
+

diff --git a/sys-apps/portage/files/0002-setup.py-add-stub-for-building-custom-modules-in-C-C.patch b/sys-apps/portage/files/0002-setup.py-add-stub-for-building-custom-modules-in-C-C.patch
new file mode 100644
index 0000000..d880e44
--- /dev/null
+++ b/sys-apps/portage/files/0002-setup.py-add-stub-for-building-custom-modules-in-C-C.patch
@@ -0,0 +1,59 @@
+From 0ce1fa04fc6ce32c54efa0e48cd61f577aa585b2 Mon Sep 17 00:00:00 2001
+From: "Anthony G. Basile" <blueness@gentoo.org>
+Date: Thu, 19 May 2016 06:52:43 -0400
+Subject: [PATCH 2/3] setup.py: add stub for building custom modules in C/C++
+
+Currently portage doesn't include any custom modules written in C/C++.
+This commit introduces stub code for building such modules in setup.py.
+
+Signed-off-by: Anthony G. Basile <blueness@gentoo.org>
+---
+ setup.py | 11 ++++++++++-
+ 1 file changed, 10 insertions(+), 1 deletion(-)
+
+diff --git a/setup.py b/setup.py
+index 75c4bcb..25429bc 100755
+--- a/setup.py
++++ b/setup.py
+@@ -4,7 +4,7 @@
+ 
+ from __future__ import print_function
+ 
+-from distutils.core import setup, Command
++from distutils.core import setup, Command, Extension
+ from distutils.command.build import build
+ from distutils.command.build_scripts import build_scripts
+ from distutils.command.clean import clean
+@@ -30,6 +30,9 @@ import sys
+ # TODO:
+ # - smarter rebuilds of docs w/ 'install_docbook' and 'install_epydoc'.
+ 
++# Dictionary of scripts.  The structure is
++#   key   = location in filesystem to install the scripts
++#   value = list of scripts, path relative to top source directory
+ x_scripts = {
+ 	'bin': [
+ 		'bin/ebuild', 'bin/egencache', 'bin/emerge', 'bin/emerge-webrsync',
+@@ -41,6 +44,10 @@ x_scripts = {
+ 	],
+ }
+ 
++# Dictionary custom modules written in C/C++ here.  The structure is
++#   key   = module name
++#   value = list of C/C++ source code, path relative to top source directory
++x_c_helpers = {}
+ 
+ class x_build(build):
+ 	""" Build command with extra build_man call. """
+@@ -636,6 +643,8 @@ setup(
+ 		['$sysconfdir/portage/repo.postsync.d', ['cnf/repo.postsync.d/example']],
+ 	],
+ 
++	ext_modules = [Extension(name=n, sources=m) for n, m in x_c_helpers.items()],
++
+ 	cmdclass = {
+ 		'build': x_build,
+ 		'build_man': build_man,
+-- 
+2.7.3
+

diff --git a/sys-apps/portage/files/0003-pym-portage-util-locale.py-add-a-C-module-to-help-ch.patch b/sys-apps/portage/files/0003-pym-portage-util-locale.py-add-a-C-module-to-help-ch.patch
new file mode 100644
index 0000000..8b89030
--- /dev/null
+++ b/sys-apps/portage/files/0003-pym-portage-util-locale.py-add-a-C-module-to-help-ch.patch
@@ -0,0 +1,151 @@
+From aeb46be70eefc2bdcd851b1a7eba2fcc7b4fa575 Mon Sep 17 00:00:00 2001
+From: "Anthony G. Basile" <blueness@gentoo.org>
+Date: Fri, 27 May 2016 09:47:34 -0400
+Subject: [PATCH 3/3] pym/portage/util/locale.py: add a C module to help check
+ locale
+
+The current method to check for a sane system locale is to use python's
+ctypes.util.find_library() to construct a full library path to the
+system libc.so and pass that path to ctypes.CDLL() so we can call
+toupper() and tolower() directly.  However, this gets bogged down in
+implementation details and fails with musl.
+
+We work around this design flaw in ctypes with a small python module
+written in C which provides thin wrappers to toupper() and tolower(),
+and only fall back on the current ctypes-based check when this module
+is not available.
+
+This has been tested on glibc, uClibc and musl systems.
+
+X-Gentoo-bug: 571444
+X-Gentoo-bug-url: https://bugs.gentoo.org/show_bug.cgi?id=571444
+
+Signed-off-by: Anthony G. Basile <blueness@gentoo.org>
+---
+ pym/portage/util/locale.py | 16 ++++++-----
+ setup.py                   |  6 +++-
+ src/portage_util_libc.c    | 68 ++++++++++++++++++++++++++++++++++++++++++++++
+ 3 files changed, 82 insertions(+), 8 deletions(-)
+ create mode 100644 src/portage_util_libc.c
+
+diff --git a/pym/portage/util/locale.py b/pym/portage/util/locale.py
+index 093eb86..5b09945 100644
+--- a/pym/portage/util/locale.py
++++ b/pym/portage/util/locale.py
+@@ -34,13 +34,15 @@ def _check_locale(silent):
+ 	"""
+ 	The inner locale check function.
+ 	"""
+-
+-	libc_fn = find_library("c")
+-	if libc_fn is None:
+-		return None
+-	libc = LoadLibrary(libc_fn)
+-	if libc is None:
+-		return None
++	try:
++		from portage.util import libc
++	except ImportError:
++		libc_fn = find_library("c")
++		if libc_fn is None:
++			return None
++		libc = LoadLibrary(libc_fn)
++		if libc is None:
++			return None
+ 
+ 	lc = list(range(ord('a'), ord('z')+1))
+ 	uc = list(range(ord('A'), ord('Z')+1))
+diff --git a/setup.py b/setup.py
+index 25429bc..5ca8156 100755
+--- a/setup.py
++++ b/setup.py
+@@ -47,7 +47,11 @@ x_scripts = {
+ # Dictionary custom modules written in C/C++ here.  The structure is
+ #   key   = module name
+ #   value = list of C/C++ source code, path relative to top source directory
+-x_c_helpers = {}
++x_c_helpers = {
++	'portage.util.libc' : [
++		'src/portage_util_libc.c',
++	],
++}
+ 
+ class x_build(build):
+ 	""" Build command with extra build_man call. """
+diff --git a/src/portage_util_libc.c b/src/portage_util_libc.c
+new file mode 100644
+index 0000000..977b954
+--- /dev/null
++++ b/src/portage_util_libc.c
+@@ -0,0 +1,68 @@
++/* Copyright 2005-2016 Gentoo Foundation
++ * Distributed under the terms of the GNU General Public License v2
++ */
++
++#include <Python.h>
++#include <stdlib.h>
++#include <ctype.h>
++
++static PyObject * _libc_tolower(PyObject *, PyObject *);
++static PyObject * _libc_toupper(PyObject *, PyObject *);
++
++static PyMethodDef LibcMethods[] = {
++	{"tolower", _libc_tolower, METH_VARARGS, "Convert to lower case using system locale."},
++	{"toupper", _libc_toupper, METH_VARARGS, "Convert to upper case using system locale."},
++	{NULL, NULL, 0, NULL}
++};
++
++#if PY_MAJOR_VERSION >= 3
++static struct PyModuleDef moduledef = {
++	PyModuleDef_HEAD_INIT,
++	"libc",								/* m_name */
++	"Module for converting case using the system locale",		/* m_doc */
++	-1,								/* m_size */
++	LibcMethods,							/* m_methods */
++	NULL,								/* m_reload */
++	NULL,								/* m_traverse */
++	NULL,								/* m_clear */
++	NULL,								/* m_free */
++};
++
++PyMODINIT_FUNC
++PyInit_libc(void)
++{
++	PyObject *m;
++	m = PyModule_Create(&moduledef);
++	return m;
++}
++#else
++PyMODINIT_FUNC
++initlibc(void)
++{
++	Py_InitModule("libc", LibcMethods);
++}
++#endif
++
++
++static PyObject *
++_libc_tolower(PyObject *self, PyObject *args)
++{
++	int c;
++
++	if (!PyArg_ParseTuple(args, "i", &c))
++		return NULL;
++
++	return Py_BuildValue("i", tolower(c));
++}
++
++
++static PyObject *
++_libc_toupper(PyObject *self, PyObject *args)
++{
++	int c;
++
++	if (!PyArg_ParseTuple(args, "i", &c))
++		return NULL;
++
++	return Py_BuildValue("i", toupper(c));
++}
+-- 
+2.7.3
+

diff --git a/sys-apps/portage/portage-2.2.26-r99.ebuild b/sys-apps/portage/portage-2.2.28-r999.ebuild
similarity index 97%
rename from sys-apps/portage/portage-2.2.26-r99.ebuild
rename to sys-apps/portage/portage-2.2.28-r999.ebuild
index 3aa681a..c03d330 100644
--- a/sys-apps/portage/portage-2.2.26-r99.ebuild
+++ b/sys-apps/portage/portage-2.2.28-r999.ebuild
@@ -11,13 +11,13 @@ PYTHON_COMPAT=(
 )
 PYTHON_REQ_USE='bzip2(+)'
 
-inherit distutils-r1 eutils multilib
+inherit distutils-r1 multilib
 
 DESCRIPTION="Portage is the package management and distribution system for Gentoo"
 HOMEPAGE="https://wiki.gentoo.org/wiki/Project:Portage"
 
 LICENSE="GPL-2"
-KEYWORDS="amd64 arm ~mips ppc x86"
+KEYWORDS="~amd64 ~arm ~mips ~ppc ~x86"
 SLOT="0"
 IUSE="build doc epydoc +ipc linguas_ru selinux xattr"
 
@@ -85,7 +85,9 @@ pkg_setup() {
 python_prepare_all() {
 	distutils-r1_python_prepare_all
 
-	epatch "${FILESDIR}"/${P}-fix-check_locale.patch
+	epatch "${FILESDIR}"/0001-pym-portage-util-locale.py-fix-decoding-for-python2-.patch
+	epatch "${FILESDIR}"/0002-setup.py-add-stub-for-building-custom-modules-in-C-C.patch
+	epatch "${FILESDIR}"/0003-pym-portage-util-locale.py-add-a-C-module-to-help-ch.patch
 
 	if ! use ipc ; then
 		einfo "Disabling ipc..."


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

* [gentoo-commits] proj/musl:master commit in: sys-apps/portage/, sys-apps/portage/files/
@ 2017-05-09 16:56 Anthony G. Basile
  0 siblings, 0 replies; 4+ messages in thread
From: Anthony G. Basile @ 2017-05-09 16:56 UTC (permalink / raw
  To: gentoo-commits

commit:     fe65acb50b89ceb40ef5e8087738c43386a71aa6
Author:     Anthony G. Basile <blueness <AT> gentoo <DOT> org>
AuthorDate: Tue May  9 16:55:24 2017 +0000
Commit:     Anthony G. Basile <blueness <AT> gentoo <DOT> org>
CommitDate: Tue May  9 16:56:02 2017 +0000
URL:        https://gitweb.gentoo.org/proj/musl.git/commit/?id=fe65acb5

sys-apps/portage: import upstream patch

Package-Manager: Portage-2.3.3, Repoman-2.3.1

 sys-apps/portage/Manifest                 |  2 +-
 sys-apps/portage/files/2.3.5-loff_t.patch | 79 +++++++++++++++++++++++++++----
 2 files changed, 70 insertions(+), 11 deletions(-)

diff --git a/sys-apps/portage/Manifest b/sys-apps/portage/Manifest
index 285f379..e43af65 100644
--- a/sys-apps/portage/Manifest
+++ b/sys-apps/portage/Manifest
@@ -1,4 +1,4 @@
-AUX 2.3.5-loff_t.patch 476 SHA256 147dbc5d8265da02019294748de91039d184a6a6b46b7d1414be52bfa75f37c0 SHA512 d64dcc80e4747251c58b2f01eabb020894550ba69d8c3e7d8513ecb6a0f6d7e3ff4d4670532d0fa8ff9d887e3935ba3cb85c60d0bffb2ec016491165cbb31bb1 WHIRLPOOL cd3b2c16afef5d32b3bc5ec170efab5249f35e0da394c7c5b3d591e8ca69d791a8f7e6f3227d87ec31427e10b4de043ae19c59565549fd91cfd0412e063849a6
+AUX 2.3.5-loff_t.patch 2569 SHA256 709f0374f9f88cc89f379356ae8bffc6560e240f2157ccab367d0ebc2e523438 SHA512 e944be00cd7bca618202a5f3084624eb110a02edc5d5cac44603c7a9c16132305b13e916578bfd06f6792c978cc78c60282823fc162df7120032c9239880e21f WHIRLPOOL dd638c53a1ecf36b7501bed36eccb8099f581d6a5b4c061015e40dd34cbd4bb58af3c14c18bfcab76a762813b365d5e80e8d298d230a0d29fe7a741449158cb2
 AUX README.RESCUE 137 SHA256 69bea0c755eab59b6b4d90838b8551744f0b0c8eeac170b1cd13a71ee83f9ac4 SHA512 dba0f0d6d4cd140e636cc70dfb7bdb298e2f2fb040bc07b0874cac994bdbabd26bfd9361d85a0f8b9a92a185281e4901606b9e4f563afdc8867341bbe6af1cb0 WHIRLPOOL 713fcc790442999d56e13efaf536fec9954dadeda680b3642d0358311332096ddedf8b55697bd1ca620d84f0dc7d025ff7931e086c74c1f5032be72dca2ff8f5
 DIST portage-2.3.5.tar.bz2 933047 SHA256 9b3282eee8f7f5728a4a71864d6b34315d71d43c52b2b650cf0d8f412c871941 SHA512 c403578caf40d97e8081c203d433b515cb2fdb14cb8b7d2652ed664bd079e65db32b54ce12ff495af6dd5fb468c5a1ef58d335e202ede5355d115049e21a6a35 WHIRLPOOL 25dbb6547d6488cebc1baf093a600e2034e17558306fd55f5502346330a78012e32d3c49dcf0445664c69d4e3e6b2580762417324ccd0bf3aa08575245165a24
 EBUILD portage-2.3.5.ebuild 8633 SHA256 2e353b0fbb3e9e06a84af2f236e85b4e9fe4e204ca22bcb93ff74c367db487f8 SHA512 0fa9d646f5e0e80990b31e9c39fe4b994efdec13530b610da22046eaa6023224dc6f7bec27865d478eb440389632e99a60a8d4f3f9c8eea9d114b2ee1b04f704 WHIRLPOOL 302ad07d96b58b5730ef868079137e184de1428b650182dfb45847a9712023aaa6fa844b77b5cec0c1a8b796c55ffef9e4634a8be57cd1578427427d6b7cc6de

diff --git a/sys-apps/portage/files/2.3.5-loff_t.patch b/sys-apps/portage/files/2.3.5-loff_t.patch
index 448c312..95a3b86 100644
--- a/sys-apps/portage/files/2.3.5-loff_t.patch
+++ b/sys-apps/portage/files/2.3.5-loff_t.patch
@@ -1,11 +1,70 @@
-diff -Naur portage-2.3.5.orig/src/portage_util_file_copy_reflink_linux.c portage-2.3.5/src/portage_util_file_copy_reflink_linux.c
---- portage-2.3.5.orig/src/portage_util_file_copy_reflink_linux.c	2017-03-17 17:34:29.300177738 -0700
-+++ portage-2.3.5/src/portage_util_file_copy_reflink_linux.c	2017-03-17 17:35:26.802723400 -0700
-@@ -4,6 +4,7 @@
+From 1a7aeb58c4e687e4d4012054b56373f27941a067 Mon Sep 17 00:00:00 2001
+From: Zac Medico <zmedico@gentoo.org>
+Date: Sun, 7 May 2017 16:32:19 -0700
+Subject: [PATCH] file_copy: replace loff_t with off_t for portability (bug
+ 617778)
+
+The loff_t type is a GNU extension, so use the portable off_t
+type instead. Also, enable Large File Support macros in setup.py,
+for 64-bit offsets.
+
+Reported-by: Patrick Steinhardt <ps@pks.im>
+X-Gentoo-bug: 617778
+X-Gentoo-bug-url: https://bugs.gentoo.org/show_bug.cgi?id=617778
+Acked-by: Anthony G. Basile <blueness@gentoo.org>
+Acked-by: Brian Dolbec <dolsen@gentoo.org>
+---
+ setup.py                                   | 5 ++++-
+ src/portage_util_file_copy_reflink_linux.c | 6 +++---
+ 2 files changed, 7 insertions(+), 4 deletions(-)
+
+diff --git a/setup.py b/setup.py
+index e993177..1ba6f87 100755
+--- a/setup.py
++++ b/setup.py
+@@ -676,7 +676,10 @@ setup(
+ 		['$sysconfdir/portage/repo.postsync.d', ['cnf/repo.postsync.d/example']],
+ 	],
  
- #include <Python.h>
- #include <errno.h>
-+#include <fcntl.h>
- #include <stdlib.h>
- #include <ctype.h>
- #include <sys/sendfile.h>
+-	ext_modules = [Extension(name=n, sources=m) for n, m in x_c_helpers.items()],
++	ext_modules = [Extension(name=n, sources=m,
++		extra_compile_args=['-D_FILE_OFFSET_BITS=64',
++		'-D_LARGEFILE_SOURCE', '-D_LARGEFILE64_SOURCE'])
++		for n, m in x_c_helpers.items()],
+ 
+ 	cmdclass = {
+ 		'build': x_build,
+diff --git a/src/portage_util_file_copy_reflink_linux.c b/src/portage_util_file_copy_reflink_linux.c
+index b031d96..2fb17a0 100644
+--- a/src/portage_util_file_copy_reflink_linux.c
++++ b/src/portage_util_file_copy_reflink_linux.c
+@@ -66,7 +66,7 @@ initreflink_linux(void)
+  * (errno is set appropriately).
+  */
+ static ssize_t
+-cfr_wrapper(int fd_out, int fd_in, loff_t *off_out, size_t len)
++cfr_wrapper(int fd_out, int fd_in, off_t *off_out, size_t len)
+ {
+ #ifdef __NR_copy_file_range
+     return syscall(__NR_copy_file_range, fd_in, NULL, fd_out,
+@@ -96,7 +96,7 @@ cfr_wrapper(int fd_out, int fd_in, loff_t *off_out, size_t len)
+  * reaches EOF.
+  */
+ static off_t
+-do_lseek_data(int fd_out, int fd_in, loff_t *off_out) {
++do_lseek_data(int fd_out, int fd_in, off_t *off_out) {
+ #ifdef SEEK_DATA
+     /* Use lseek SEEK_DATA/SEEK_HOLE for sparse file support,
+      * as suggested in the copy_file_range man page.
+@@ -189,7 +189,7 @@ _reflink_linux_file_copy(PyObject *self, PyObject *args)
+     ssize_t buf_bytes, buf_offset, copyfunc_ret;
+     struct stat stat_in, stat_out;
+     char* buf;
+-    ssize_t (*copyfunc)(int, int, loff_t *, size_t);
++    ssize_t (*copyfunc)(int, int, off_t *, size_t);
+ 
+     if (!PyArg_ParseTuple(args, "ii", &fd_in, &fd_out))
+         return NULL;
+-- 
+2.10.2
+


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

* [gentoo-commits] proj/musl:master commit in: sys-apps/portage/, sys-apps/portage/files/
@ 2017-09-03 20:54 Anthony G. Basile
  0 siblings, 0 replies; 4+ messages in thread
From: Anthony G. Basile @ 2017-09-03 20:54 UTC (permalink / raw
  To: gentoo-commits

commit:     a0e1a91d1b191aca42bee226457008e25660ed89
Author:     stefson <herrtimson <AT> yahoo <DOT> de>
AuthorDate: Sun Sep  3 11:35:16 2017 +0000
Commit:     Anthony G. Basile <blueness <AT> gentoo <DOT> org>
CommitDate: Sun Sep  3 20:54:09 2017 +0000
URL:        https://gitweb.gentoo.org/proj/musl.git/commit/?id=a0e1a91d

sys-apps/portage: bug #617778 is fixed and stablized for all musl arches in portage-2.3.6

Signed-off-by: Anthony G. Basile <blueness <AT> gentoo.org>

 sys-apps/portage/Manifest                 |   5 -
 sys-apps/portage/files/2.3.5-loff_t.patch |  70 --------
 sys-apps/portage/files/README.RESCUE      |   2 -
 sys-apps/portage/metadata.xml             |  27 ---
 sys-apps/portage/portage-2.3.5.ebuild     | 279 ------------------------------
 5 files changed, 383 deletions(-)

diff --git a/sys-apps/portage/Manifest b/sys-apps/portage/Manifest
deleted file mode 100644
index e43af65..0000000
--- a/sys-apps/portage/Manifest
+++ /dev/null
@@ -1,5 +0,0 @@
-AUX 2.3.5-loff_t.patch 2569 SHA256 709f0374f9f88cc89f379356ae8bffc6560e240f2157ccab367d0ebc2e523438 SHA512 e944be00cd7bca618202a5f3084624eb110a02edc5d5cac44603c7a9c16132305b13e916578bfd06f6792c978cc78c60282823fc162df7120032c9239880e21f WHIRLPOOL dd638c53a1ecf36b7501bed36eccb8099f581d6a5b4c061015e40dd34cbd4bb58af3c14c18bfcab76a762813b365d5e80e8d298d230a0d29fe7a741449158cb2
-AUX README.RESCUE 137 SHA256 69bea0c755eab59b6b4d90838b8551744f0b0c8eeac170b1cd13a71ee83f9ac4 SHA512 dba0f0d6d4cd140e636cc70dfb7bdb298e2f2fb040bc07b0874cac994bdbabd26bfd9361d85a0f8b9a92a185281e4901606b9e4f563afdc8867341bbe6af1cb0 WHIRLPOOL 713fcc790442999d56e13efaf536fec9954dadeda680b3642d0358311332096ddedf8b55697bd1ca620d84f0dc7d025ff7931e086c74c1f5032be72dca2ff8f5
-DIST portage-2.3.5.tar.bz2 933047 SHA256 9b3282eee8f7f5728a4a71864d6b34315d71d43c52b2b650cf0d8f412c871941 SHA512 c403578caf40d97e8081c203d433b515cb2fdb14cb8b7d2652ed664bd079e65db32b54ce12ff495af6dd5fb468c5a1ef58d335e202ede5355d115049e21a6a35 WHIRLPOOL 25dbb6547d6488cebc1baf093a600e2034e17558306fd55f5502346330a78012e32d3c49dcf0445664c69d4e3e6b2580762417324ccd0bf3aa08575245165a24
-EBUILD portage-2.3.5.ebuild 8633 SHA256 2e353b0fbb3e9e06a84af2f236e85b4e9fe4e204ca22bcb93ff74c367db487f8 SHA512 0fa9d646f5e0e80990b31e9c39fe4b994efdec13530b610da22046eaa6023224dc6f7bec27865d478eb440389632e99a60a8d4f3f9c8eea9d114b2ee1b04f704 WHIRLPOOL 302ad07d96b58b5730ef868079137e184de1428b650182dfb45847a9712023aaa6fa844b77b5cec0c1a8b796c55ffef9e4634a8be57cd1578427427d6b7cc6de
-MISC metadata.xml 1147 SHA256 c4832ae64ab0915c65eadca15e4540680d109c21d572464f69e218d14fe6bd8b SHA512 733193cbfc96da31252b5e4109d0b76f797e339c41eda2c1230cc1d5b0e75912177570ed0140218a7a7b85d9b8bc53e8e6931e88810269c499be87af40e6b86c WHIRLPOOL bf901ca7474f9b8358c458edad904f9c0c853187c6dc8ea0bc0c327bded60940c6f8b20f0231d78d86aa7dc5235b23d70c69f7153cca9e375fa271c7c93707b9

diff --git a/sys-apps/portage/files/2.3.5-loff_t.patch b/sys-apps/portage/files/2.3.5-loff_t.patch
deleted file mode 100644
index 95a3b86..0000000
--- a/sys-apps/portage/files/2.3.5-loff_t.patch
+++ /dev/null
@@ -1,70 +0,0 @@
-From 1a7aeb58c4e687e4d4012054b56373f27941a067 Mon Sep 17 00:00:00 2001
-From: Zac Medico <zmedico@gentoo.org>
-Date: Sun, 7 May 2017 16:32:19 -0700
-Subject: [PATCH] file_copy: replace loff_t with off_t for portability (bug
- 617778)
-
-The loff_t type is a GNU extension, so use the portable off_t
-type instead. Also, enable Large File Support macros in setup.py,
-for 64-bit offsets.
-
-Reported-by: Patrick Steinhardt <ps@pks.im>
-X-Gentoo-bug: 617778
-X-Gentoo-bug-url: https://bugs.gentoo.org/show_bug.cgi?id=617778
-Acked-by: Anthony G. Basile <blueness@gentoo.org>
-Acked-by: Brian Dolbec <dolsen@gentoo.org>
----
- setup.py                                   | 5 ++++-
- src/portage_util_file_copy_reflink_linux.c | 6 +++---
- 2 files changed, 7 insertions(+), 4 deletions(-)
-
-diff --git a/setup.py b/setup.py
-index e993177..1ba6f87 100755
---- a/setup.py
-+++ b/setup.py
-@@ -676,7 +676,10 @@ setup(
- 		['$sysconfdir/portage/repo.postsync.d', ['cnf/repo.postsync.d/example']],
- 	],
- 
--	ext_modules = [Extension(name=n, sources=m) for n, m in x_c_helpers.items()],
-+	ext_modules = [Extension(name=n, sources=m,
-+		extra_compile_args=['-D_FILE_OFFSET_BITS=64',
-+		'-D_LARGEFILE_SOURCE', '-D_LARGEFILE64_SOURCE'])
-+		for n, m in x_c_helpers.items()],
- 
- 	cmdclass = {
- 		'build': x_build,
-diff --git a/src/portage_util_file_copy_reflink_linux.c b/src/portage_util_file_copy_reflink_linux.c
-index b031d96..2fb17a0 100644
---- a/src/portage_util_file_copy_reflink_linux.c
-+++ b/src/portage_util_file_copy_reflink_linux.c
-@@ -66,7 +66,7 @@ initreflink_linux(void)
-  * (errno is set appropriately).
-  */
- static ssize_t
--cfr_wrapper(int fd_out, int fd_in, loff_t *off_out, size_t len)
-+cfr_wrapper(int fd_out, int fd_in, off_t *off_out, size_t len)
- {
- #ifdef __NR_copy_file_range
-     return syscall(__NR_copy_file_range, fd_in, NULL, fd_out,
-@@ -96,7 +96,7 @@ cfr_wrapper(int fd_out, int fd_in, loff_t *off_out, size_t len)
-  * reaches EOF.
-  */
- static off_t
--do_lseek_data(int fd_out, int fd_in, loff_t *off_out) {
-+do_lseek_data(int fd_out, int fd_in, off_t *off_out) {
- #ifdef SEEK_DATA
-     /* Use lseek SEEK_DATA/SEEK_HOLE for sparse file support,
-      * as suggested in the copy_file_range man page.
-@@ -189,7 +189,7 @@ _reflink_linux_file_copy(PyObject *self, PyObject *args)
-     ssize_t buf_bytes, buf_offset, copyfunc_ret;
-     struct stat stat_in, stat_out;
-     char* buf;
--    ssize_t (*copyfunc)(int, int, loff_t *, size_t);
-+    ssize_t (*copyfunc)(int, int, off_t *, size_t);
- 
-     if (!PyArg_ParseTuple(args, "ii", &fd_in, &fd_out))
-         return NULL;
--- 
-2.10.2
-

diff --git a/sys-apps/portage/files/README.RESCUE b/sys-apps/portage/files/README.RESCUE
deleted file mode 100644
index 70c494e..0000000
--- a/sys-apps/portage/files/README.RESCUE
+++ /dev/null
@@ -1,2 +0,0 @@
-Please see http://www.gentoo.org/proj/en/portage/doc/manually-fixing-portage.xml
-for a recovery guide for a broken portage installation.

diff --git a/sys-apps/portage/metadata.xml b/sys-apps/portage/metadata.xml
deleted file mode 100644
index c662419..0000000
--- a/sys-apps/portage/metadata.xml
+++ /dev/null
@@ -1,27 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<!DOCTYPE pkgmetadata SYSTEM "http://www.gentoo.org/dtd/metadata.dtd">
-<pkgmetadata>
-  <upstream>
-    <bugs-to>mailto:dev-portage@gentoo.org</bugs-to>
-    <changelog>https://gitweb.gentoo.org/proj/portage.git/plain/RELEASE-NOTES</changelog>
-    <doc>https://wiki.gentoo.org/wiki/Handbook:AMD64/Working/Portage</doc>
-  </upstream>
-  <maintainer type="project">
-    <email>dev-portage@gentoo.org</email>
-  </maintainer>
-  <use>
-    <flag name="epydoc">Build html API documentation with epydoc.</flag>
-    <flag name="ipc">Use inter-process communication between portage and
-        running ebuilds.
-    </flag>
-    <flag name="native-extensions">
-        Compiles native "C" extensions (speedups, instead of using python
-        backup code).  Currently includes libc-locales.
-        This should only be temporarily disabled for some bootstrapping
-        operations.  Cross-compilation is not supported.
-    </flag>
-    <flag name="xattr">Preserve extended attributes (filesystem-stored metadata)
-        when installing files. Usually only required for hardened systems.
-    </flag>
-  </use>
-</pkgmetadata>

diff --git a/sys-apps/portage/portage-2.3.5.ebuild b/sys-apps/portage/portage-2.3.5.ebuild
deleted file mode 100644
index a912c81..0000000
--- a/sys-apps/portage/portage-2.3.5.ebuild
+++ /dev/null
@@ -1,279 +0,0 @@
-# Copyright 1999-2017 Gentoo Foundation
-# Distributed under the terms of the GNU General Public License v2
-
-EAPI=5
-
-PYTHON_COMPAT=(
-	pypy
-	python3_3 python3_4 python3_5 python3_6
-	python2_7
-)
-PYTHON_REQ_USE='bzip2(+),threads(+)'
-
-inherit distutils-r1 multilib
-
-DESCRIPTION="Portage is the package management and distribution system for Gentoo"
-HOMEPAGE="https://wiki.gentoo.org/wiki/Project:Portage"
-
-LICENSE="GPL-2"
-KEYWORDS="amd64 arm ~mips ppc x86"
-SLOT="0"
-IUSE="build doc epydoc +ipc linguas_ru +native-extensions selinux xattr"
-
-DEPEND="!build? ( $(python_gen_impl_dep 'ssl(+)') )
-	>=app-arch/tar-1.27
-	dev-lang/python-exec:2
-	>=sys-apps/sed-4.0.5 sys-devel/patch
-	doc? ( app-text/xmlto ~app-text/docbook-xml-dtd-4.4 )
-	epydoc? ( >=dev-python/epydoc-2.0[$(python_gen_usedep 'python2*')] )"
-# Require sandbox-2.2 for bug #288863.
-# For xattr, we can spawn getfattr and setfattr from sys-apps/attr, but that's
-# quite slow, so it's not considered in the dependencies as an alternative to
-# to python-3.3 / pyxattr. Also, xattr support is only tested with Linux, so
-# for now, don't pull in xattr deps for other kernels.
-# For whirlpool hash, require python[ssl] (bug #425046).
-# For compgen, require bash[readline] (bug #445576).
-RDEPEND="
-	>=app-arch/tar-1.27
-	dev-lang/python-exec:2
-	!build? (
-		>=sys-apps/sed-4.0.5
-		app-shells/bash:0[readline]
-		>=app-admin/eselect-1.2
-	)
-	elibc_FreeBSD? ( sys-freebsd/freebsd-bin )
-	elibc_glibc? ( >=sys-apps/sandbox-2.2 )
-	elibc_musl? ( >=sys-apps/sandbox-2.2 )
-	elibc_uclibc? ( >=sys-apps/sandbox-2.2 )
-	>=app-misc/pax-utils-0.1.17
-	selinux? ( >=sys-libs/libselinux-2.0.94[python,${PYTHON_USEDEP}] )
-	xattr? ( kernel_linux? (
-		>=sys-apps/install-xattr-0.3
-		$(python_gen_cond_dep 'dev-python/pyxattr[${PYTHON_USEDEP}]' \
-			python2_7 pypy)
-	) )
-	!<app-admin/logrotate-3.8.0"
-PDEPEND="
-	!build? (
-		>=net-misc/rsync-2.6.4
-		userland_GNU? ( >=sys-apps/coreutils-6.4 )
-	)"
-# coreutils-6.4 rdep is for date format in emerge-webrsync #164532
-# NOTE: FEATURES=installsources requires debugedit and rsync
-
-REQUIRED_USE="epydoc? ( $(python_gen_useflags 'python2*') )"
-
-SRC_ARCHIVES="https://dev.gentoo.org/~dolsen/releases/portage"
-
-PATCHES=( "${FILESDIR}"/${PV}-loff_t.patch )
-
-prefix_src_archives() {
-	local x y
-	for x in ${@}; do
-		for y in ${SRC_ARCHIVES}; do
-			echo ${y}/${x}
-		done
-	done
-}
-
-TARBALL_PV=${PV}
-SRC_URI="mirror://gentoo/${PN}-${TARBALL_PV}.tar.bz2
-	$(prefix_src_archives ${PN}-${TARBALL_PV}.tar.bz2)"
-
-pkg_setup() {
-	use epydoc && DISTUTILS_ALL_SUBPHASE_IMPLS=( python2.7 )
-}
-
-python_prepare_all() {
-	distutils-r1_python_prepare_all
-
-	if use native-extensions; then
-		printf "[build_ext]\nportage-ext-modules=true\n" >> \
-			setup.cfg || die
-	fi
-
-	if ! use ipc ; then
-		einfo "Disabling ipc..."
-		sed -e "s:_enable_ipc_daemon = True:_enable_ipc_daemon = False:" \
-			-i pym/_emerge/AbstractEbuildProcess.py || \
-			die "failed to patch AbstractEbuildProcess.py"
-	fi
-
-	if use xattr && use kernel_linux ; then
-		einfo "Adding FEATURES=xattr to make.globals ..."
-		echo -e '\nFEATURES="${FEATURES} xattr"' >> cnf/make.globals \
-			|| die "failed to append to make.globals"
-	fi
-
-	if [[ -n ${EPREFIX} ]] ; then
-		einfo "Setting portage.const.EPREFIX ..."
-		sed -e "s|^\(SANDBOX_BINARY[[:space:]]*=[[:space:]]*\"\)\(/usr/bin/sandbox\"\)|\\1${EPREFIX}\\2|" \
-			-e "s|^\(FAKEROOT_BINARY[[:space:]]*=[[:space:]]*\"\)\(/usr/bin/fakeroot\"\)|\\1${EPREFIX}\\2|" \
-			-e "s|^\(BASH_BINARY[[:space:]]*=[[:space:]]*\"\)\(/bin/bash\"\)|\\1${EPREFIX}\\2|" \
-			-e "s|^\(MOVE_BINARY[[:space:]]*=[[:space:]]*\"\)\(/bin/mv\"\)|\\1${EPREFIX}\\2|" \
-			-e "s|^\(PRELINK_BINARY[[:space:]]*=[[:space:]]*\"\)\(/usr/sbin/prelink\"\)|\\1${EPREFIX}\\2|" \
-			-e "s|^\(EPREFIX[[:space:]]*=[[:space:]]*\"\).*|\\1${EPREFIX}\"|" \
-			-i pym/portage/const.py || \
-			die "Failed to patch portage.const.EPREFIX"
-
-		einfo "Prefixing shebangs ..."
-		while read -r -d $'\0' ; do
-			local shebang=$(head -n1 "$REPLY")
-			if [[ ${shebang} == "#!"* && ! ${shebang} == "#!${EPREFIX}/"* ]] ; then
-				sed -i -e "1s:.*:#!${EPREFIX}${shebang:2}:" "$REPLY" || \
-					die "sed failed"
-			fi
-		done < <(find . -type f -print0)
-
-		einfo "Adjusting make.globals ..."
-		sed -e "s|\(/usr/portage\)|${EPREFIX}\\1|" \
-			-e "s|^\(PORTAGE_TMPDIR=\"\)\(/var/tmp\"\)|\\1${EPREFIX}\\2|" \
-			-i cnf/make.globals || die "sed failed"
-
-		einfo "Adjusting repos.conf ..."
-		sed -e "s|^\(main-repo = \).*|\\1gentoo_prefix|" \
-			-e "s|^\\[gentoo\\]|[gentoo_prefix]|" \
-			-e "s|^\(location = \)\(/usr/portage\)|\\1${EPREFIX}\\2|" \
-			-e "s|^\(sync-uri = \).*|\\1rsync://rsync.prefix.bitzolder.nl/gentoo-portage-prefix|" \
-			-i cnf/repos.conf || die "sed failed"
-
-		einfo "Adding FEATURES=force-prefix to make.globals ..."
-		echo -e '\nFEATURES="${FEATURES} force-prefix"' >> cnf/make.globals \
-			|| die "failed to append to make.globals"
-	fi
-
-	cd "${S}/cnf" || die
-	if [ -f "make.conf.example.${ARCH}".diff ]; then
-		patch make.conf.example "make.conf.example.${ARCH}".diff || \
-			die "Failed to patch make.conf.example"
-	else
-		eerror ""
-		eerror "Portage does not have an arch-specific configuration for this arch."
-		eerror "Please notify the arch maintainer about this issue. Using generic."
-		eerror ""
-	fi
-}
-
-python_compile_all() {
-	local targets=()
-	use doc && targets+=( docbook )
-	use epydoc && targets+=( epydoc )
-
-	if [[ ${targets[@]} ]]; then
-		esetup.py "${targets[@]}"
-	fi
-}
-
-python_test() {
-	esetup.py test
-}
-
-python_install() {
-	# Install sbin scripts to bindir for python-exec linking
-	# they will be relocated in pkg_preinst()
-	distutils-r1_python_install \
-		--system-prefix="${EPREFIX}/usr" \
-		--bindir="$(python_get_scriptdir)" \
-		--docdir="${EPREFIX}/usr/share/doc/${PF}" \
-		--htmldir="${EPREFIX}/usr/share/doc/${PF}/html" \
-		--portage-bindir="${EPREFIX}/usr/lib/portage/${EPYTHON}" \
-		--sbindir="$(python_get_scriptdir)" \
-		--sysconfdir="${EPREFIX}/etc" \
-		"${@}"
-}
-
-python_install_all() {
-	distutils-r1_python_install_all
-
-	local targets=()
-	use doc && targets+=( install_docbook )
-	use epydoc && targets+=( install_epydoc )
-
-	# install docs
-	if [[ ${targets[@]} ]]; then
-		esetup.py "${targets[@]}"
-	fi
-
-	# Due to distutils/python-exec limitations
-	# these must be installed to /usr/bin.
-	local sbin_relocations='archive-conf dispatch-conf emaint env-update etc-update fixpackages regenworld'
-	einfo "Moving admin scripts to the correct directory"
-	dodir /usr/sbin
-	for target in ${sbin_relocations}; do
-		einfo "Moving /usr/bin/${target} to /usr/sbin/${target}"
-		mv "${ED}usr/bin/${target}" "${ED}usr/sbin/${target}" || die "sbin scripts move failed!"
-	done
-}
-
-pkg_preinst() {
-	# comment out sanity test until it is fixed to work
-	# with the new PORTAGE_PYM_PATH
-	#if [[ $ROOT == / ]] ; then
-		## Run some minimal tests as a sanity check.
-		#local test_runner=$(find "${ED}" -name runTests)
-		#if [[ -n $test_runner && -x $test_runner ]] ; then
-			#einfo "Running preinst sanity tests..."
-			#"$test_runner" || die "preinst sanity tests failed"
-		#fi
-	#fi
-
-	# elog dir must exist to avoid logrotate error for bug #415911.
-	# This code runs in preinst in order to bypass the mapping of
-	# portage:portage to root:root which happens after src_install.
-	keepdir /var/log/portage/elog
-	# This is allowed to fail if the user/group are invalid for prefix users.
-	if chown portage:portage "${ED}"var/log/portage{,/elog} 2>/dev/null ; then
-		chmod g+s,ug+rwx "${ED}"var/log/portage{,/elog}
-	fi
-
-	if has_version ">=${CATEGORY}/${PN}-2.3.1" && \
-		has_version "<${CATEGORY}/${PN}-2.3.3"; then
-		SYNC_DEPTH_UPGRADE=true
-	else
-		SYNC_DEPTH_UPGRADE=false
-	fi
-}
-
-get_ownership() {
-	case ${USERLAND} in
-		BSD)
-			stat -f '%Su:%Sg' "${1}"
-			;;
-		*)
-			stat -c '%U:%G' "${1}"
-			;;
-	esac
-}
-
-new_config_protect() {
-	# Generate a ._cfg file even if the target file
-	# does not exist, ensuring that the user will
-	# notice the config change.
-	local basename=${1##*/}
-	local dirname=${1%/*}
-	local i=0
-	while true ; do
-		local filename=$(
-			echo -n "${dirname}/._cfg"
-			printf "%04d" ${i}
-			echo -n "_${basename}"
-		)
-		[[ -e ${filename} ]] || break
-		(( i++ ))
-	done
-	echo "${filename}"
-}
-
-pkg_postinst() {
-	if ${SYNC_DEPTH_UPGRADE}; then
-		ewarn "Please note that this release no longer respects sync-depth for"
-		ewarn "git repositories.  There have been too many problems and"
-		ewarn "performance issues.  See bugs 552814, 559008"
-	fi
-	einfo ""
-	einfo "This release of portage NO LONGER contains the repoman code base."
-	einfo "Repoman has its own ebuild and release package."
-	einfo "For repoman functionality please emerge app-portage/repoman"
-	einfo "Please report any bugs you may encounter."
-	einfo ""
-}


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

end of thread, other threads:[~2017-09-03 20:54 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2017-09-03 20:54 [gentoo-commits] proj/musl:master commit in: sys-apps/portage/, sys-apps/portage/files/ Anthony G. Basile
  -- strict thread matches above, loose matches on Subject: below --
2017-05-09 16:56 Anthony G. Basile
2016-06-20 19:34 Anthony G. Basile
2016-01-21  1:44 Anthony G. Basile

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