commit:     b868bd51cf6da8474556387d674aa0f4a3246e3d
Author:     Aric Belsito <lluixhi <AT> gmail <DOT> com>
AuthorDate: Sat Mar 18 00:39:44 2017 +0000
Commit:     Aric Belsito <lluixhi <AT> gmail <DOT> com>
CommitDate: Sat Mar 18 00:39:44 2017 +0000
URL:        https://gitweb.gentoo.org/proj/musl.git/commit/?id=b868bd51

sys-apps/portage: add 2.3.5

Drop previous versions -- 2.3.3, is stable and can be compiled with
native-extensions.

 sys-apps/portage/Manifest                          |  15 +-
 ...-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 ---------
 ...ert-URI-changes-related-to-docbook-schema.patch |  39 ---
 sys-apps/portage/files/2.3.5-loff_t.patch          |  11 +
 .../files/portage-2.2.26-fix-check_locale.patch    |  29 --
 sys-apps/portage/metadata.xml                      |  14 +-
 sys-apps/portage/portage-2.2.28-r99.ebuild         | 368 --------------------
 sys-apps/portage/portage-2.2.28-r999.ebuild        | 370 ---------------------
 .../{portage-2.3.1.ebuild => portage-2.3.5.ebuild} | 136 ++------
 11 files changed, 52 insertions(+), 1180 deletions(-)

diff --git a/sys-apps/portage/Manifest b/sys-apps/portage/Manifest
index fc77bb8..6df2c8a 100644
--- a/sys-apps/portage/Manifest
+++ b/sys-apps/portage/Manifest
@@ -1,12 +1,5 @@
-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 2.3.1-doc-Revert-URI-changes-related-to-docbook-schema.patch 1394 SHA256 
a076b70b775aef23e89127d2fc64065f2d7a895b3b56a723122f641375b7c3d3 SHA512 
fb3488ec9c5a849bdc9ae2cfaed3732c939072cd847534fdeaaff28560b62ad5b184f15bfb6943b921f417ec7de8e1fd3845322a0ba4d3e55f625a12cf903dcd
 WHIRLPOOL 
ddf6cd307f063404f53e9e819b01965b053df7554790d1332a5d131c11e5e6eec466412c17c4d8b3dd124ab81797641001ec3bbcfadd7ff06f5e59b2f40dc7d2
+AUX 2.3.5-loff_t.patch 476 SHA256 
147dbc5d8265da02019294748de91039d184a6a6b46b7d1414be52bfa75f37c0 SHA512 
d64dcc80e4747251c58b2f01eabb020894550ba69d8c3e7d8513ecb6a0f6d7e3ff4d4670532d0fa8ff9d887e3935ba3cb85c60d0bffb2ec016491165cbb31bb1
 WHIRLPOOL 
cd3b2c16afef5d32b3bc5ec170efab5249f35e0da394c7c5b3d591e8ca69d791a8f7e6f3227d87ec31427e10b4de043ae19c59565549fd91cfd0412e063849a6
 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.28.tar.bz2 969138 SHA256 
da8148a1a9275c87f535679e41b1bb3a1380ba0f903b80510017517e4c5229d0 SHA512 
d21bf7e7dcc0a779a13df6a959e5d4291492fce2a5525b67e9a4705888021f9c08b8d78cd32b2eb930ac5428c40383e4e46da5a7b1ed5c9c9c42314c0f1c6a0b
 WHIRLPOOL 
1b9584b0243b46c70d0778aad57df2d3ea99e19f243280e542c29e6fed0634b72de6b203a3c296c2977d1a6e5e5250b910574176c692d2c7c27c0938528bb43d
-DIST portage-2.3.1.tar.bz2 918411 SHA256 
a3c5ee98791c579687ad5ec6a7882a6b6a486a54c14d1bc73ccc9a79b4a507e9 SHA512 
75a713cfa077ac271ad7fad0a48bbc923beedd2ec47000602576297fabae2de47ee69e7e6d52e02c87f9ba5d9e5b27c10fa9be7b308f72c6dcc8e7f6c321f2c6
 WHIRLPOOL 
4ee7942d73e8e5b977d0260b568d31d0b49387787f7ffa2e77d4ec49e00b3e67c54506840be463cb5a6da070683013192f46bb47df1df1a328457de1796d05c0
-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
-EBUILD portage-2.3.1.ebuild 11403 SHA256 
5cefcb0b231eac7020baee448f135fa8b3c62b2479761ace88691fcaa97b170b SHA512 
98ad8c0d53ddcc95c4e0c8d15798b02cc28239cc79cfc66af74c95088dde9a85f797b71891df6c5da4c829029c84ebc98e75c0013c3fb1bc5e01b6eb8b743aa7
 WHIRLPOOL 
92c6550e267d64ce3de84e6f060094150ff3218012fe6428276970767ad7eaf6ef422545e40ad0a1b8e5a99c8d9f3ae2c3b74868ec2224b189abb1bd3b1b1fad
-MISC metadata.xml 814 SHA256 
e33780a3f1af692a5539738aa243581beb5d6398daf23ac28a252b8481742db1 SHA512 
d68c833a70bae0e497f5c0217f6f64161c7cbe3fd01253e8f5657512e5eb62438dec5cc587ca9667c0cd4f791f25cdcb3f7017743f6f66cfdc41fec835b4f3a7
 WHIRLPOOL 
b2c926e03f312e1cdcaedf1f6c5f9b0c25887e93f44fb8aef56212f72369e1916efa863e34cd568d0f50cddcaf8fb9bf33d745d7fc785c62476162465f3298b7
+DIST portage-2.3.5.tar.bz2 933047 SHA256 
9b3282eee8f7f5728a4a71864d6b34315d71d43c52b2b650cf0d8f412c871941 SHA512 
c403578caf40d97e8081c203d433b515cb2fdb14cb8b7d2652ed664bd079e65db32b54ce12ff495af6dd5fb468c5a1ef58d335e202ede5355d115049e21a6a35
 WHIRLPOOL 
25dbb6547d6488cebc1baf093a600e2034e17558306fd55f5502346330a78012e32d3c49dcf0445664c69d4e3e6b2580762417324ccd0bf3aa08575245165a24
+EBUILD portage-2.3.5.ebuild 8727 SHA256 
d0b643f1b6438fd330553c34d3f1f89821616239d11dad4cd213b5ce1762a766 SHA512 
d59f134737dd05d00c7e770c49cdb5a9f1d917bf2979a17825cc6e0b8498c67bbb9417f030a49153b22349aaa498007ef5edfc9be0ec0a11deb89ee407847891
 WHIRLPOOL 
2edb81341f1a95ae6c7aa3f8c0bc8500d02a4a4fbad39f1d785132129bedfeabf385516107e7f4495e388bb784a02e03912f8ced25d83b0079017c481d17279d
+MISC metadata.xml 1147 SHA256 
c4832ae64ab0915c65eadca15e4540680d109c21d572464f69e218d14fe6bd8b SHA512 
733193cbfc96da31252b5e4109d0b76f797e339c41eda2c1230cc1d5b0e75912177570ed0140218a7a7b85d9b8bc53e8e6931e88810269c499be87af40e6b86c
 WHIRLPOOL 
bf901ca7474f9b8358c458edad904f9c0c853187c6dc8ea0bc0c327bded60940c6f8b20f0231d78d86aa7dc5235b23d70c69f7153cca9e375fa271c7c93707b9

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
deleted file mode 100644
index 258c221..0000000
--- 
a/sys-apps/portage/files/0001-pym-portage-util-locale.py-fix-decoding-for-python2-.patch
+++ /dev/null
@@ -1,40 +0,0 @@
-From f13322877e2778f145308160ccee5d2e27b34235 Mon Sep 17 00:00:00 2001
-From: "Anthony G. Basile" <[email protected]>
-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 <[email protected]>
----
- 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
deleted file mode 100644
index d880e44..0000000
--- 
a/sys-apps/portage/files/0002-setup.py-add-stub-for-building-custom-modules-in-C-C.patch
+++ /dev/null
@@ -1,59 +0,0 @@
-From 0ce1fa04fc6ce32c54efa0e48cd61f577aa585b2 Mon Sep 17 00:00:00 2001
-From: "Anthony G. Basile" <[email protected]>
-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 <[email protected]>
----
- 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
deleted file mode 100644
index 8b89030..0000000
--- 
a/sys-apps/portage/files/0003-pym-portage-util-locale.py-add-a-C-module-to-help-ch.patch
+++ /dev/null
@@ -1,151 +0,0 @@
-From aeb46be70eefc2bdcd851b1a7eba2fcc7b4fa575 Mon Sep 17 00:00:00 2001
-From: "Anthony G. Basile" <[email protected]>
-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 <[email protected]>
----
- 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/files/2.3.1-doc-Revert-URI-changes-related-to-docbook-schema.patch
 
b/sys-apps/portage/files/2.3.1-doc-Revert-URI-changes-related-to-docbook-schema.patch
deleted file mode 100644
index ee191ff..0000000
--- 
a/sys-apps/portage/files/2.3.1-doc-Revert-URI-changes-related-to-docbook-schema.patch
+++ /dev/null
@@ -1,39 +0,0 @@
-From 35863a80b915939aac3ce6bf017d942cac879df8 Mon Sep 17 00:00:00 2001
-From: Mike Gilbert <[email protected]>
-Date: Wed, 20 Jul 2016 12:30:05 -0400
-Subject: [PATCH] doc: Revert URI changes related to docbook schema
-
-This partially reverts b5365341dad167e314023df95d2c5e0f955962f0.
-
-X-Gentoo-Bug: 589210
-X-Gentoo-Bug-URL: https://bugs.gentoo.org/589210
----
- doc/custom.xsl      | 2 +-
- doc/portage.docbook | 2 +-
- 2 files changed, 2 insertions(+), 2 deletions(-)
-
-diff --git a/doc/custom.xsl b/doc/custom.xsl
-index 11a2b9e..a7763ec 100644
---- a/doc/custom.xsl
-+++ b/doc/custom.xsl
-@@ -1,4 +1,4 @@
--<xsl:stylesheet xmlns:xsl="https://www.w3.org/1999/XSL/Transform"; 
version="1.0">
-+<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"; 
version="1.0">
- <xsl:param name="toc.section.depth" select="20"/>
- <xsl:param name="chunk.section.depth" select="2"/>
- <xsl:param name="generate.section.toc.level" select="2"/>
-diff --git a/doc/portage.docbook b/doc/portage.docbook
-index f7d539a..811544f 100644
---- a/doc/portage.docbook
-+++ b/doc/portage.docbook
-@@ -1,6 +1,6 @@
- <?xml version="1.0" encoding="UTF-8"?>
- <!DOCTYPE book PUBLIC "-//OASIS//DTD DocBook V4.4//EN"
--      "https://www.oasis-open.org/docbook/xml/4.4/docbookx.dtd"; [
-+      "http://www.oasis-open.org/docbook/xml/4.4/docbookx.dtd"; [
- 
-       <!ENTITY date SYSTEM "fragment/date">
-       <!ENTITY version SYSTEM "fragment/version">
--- 
-2.10.0
-

diff --git a/sys-apps/portage/files/2.3.5-loff_t.patch 
b/sys-apps/portage/files/2.3.5-loff_t.patch
new file mode 100644
index 0000000..448c312
--- /dev/null
+++ b/sys-apps/portage/files/2.3.5-loff_t.patch
@@ -0,0 +1,11 @@
+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 @@
+ 
+ #include <Python.h>
+ #include <errno.h>
++#include <fcntl.h>
+ #include <stdlib.h>
+ #include <ctype.h>
+ #include <sys/sendfile.h>

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
deleted file mode 100644
index 7d137d6..0000000
--- a/sys-apps/portage/files/portage-2.2.26-fix-check_locale.patch
+++ /dev/null
@@ -1,29 +0,0 @@
-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
index e032ea5..c662419 100644
--- a/sys-apps/portage/metadata.xml
+++ b/sys-apps/portage/metadata.xml
@@ -11,7 +11,17 @@
   </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="xattr">Preserve extended attributes (filesystem-stored 
metadata) when installing files. Usually only required for hardened 
systems.</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.2.28-r99.ebuild 
b/sys-apps/portage/portage-2.2.28-r99.ebuild
deleted file mode 100644
index d6fd851..0000000
--- a/sys-apps/portage/portage-2.2.28-r99.ebuild
+++ /dev/null
@@ -1,368 +0,0 @@
-# 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 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}"/${PN}-2.2.26-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 ""
-}

diff --git a/sys-apps/portage/portage-2.2.28-r999.ebuild 
b/sys-apps/portage/portage-2.2.28-r999.ebuild
deleted file mode 100644
index c03d330..0000000
--- a/sys-apps/portage/portage-2.2.28-r999.ebuild
+++ /dev/null
@@ -1,370 +0,0 @@
-# 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 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}"/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..."
-               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 ""
-}

diff --git a/sys-apps/portage/portage-2.3.1.ebuild 
b/sys-apps/portage/portage-2.3.5.ebuild
similarity index 66%
rename from sys-apps/portage/portage-2.3.1.ebuild
rename to sys-apps/portage/portage-2.3.5.ebuild
index 5b32485..8880bb8 100644
--- a/sys-apps/portage/portage-2.3.1.ebuild
+++ b/sys-apps/portage/portage-2.3.5.ebuild
@@ -1,15 +1,14 @@
-# Copyright 1999-2016 Gentoo Foundation
+# Copyright 1999-2017 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
+       python3_3 python3_4 python3_5 python3_6
        python2_7
 )
-PYTHON_REQ_USE='bzip2(+)'
+PYTHON_REQ_USE='bzip2(+),threads(+)'
 
 inherit distutils-r1 multilib
 
@@ -17,9 +16,9 @@ DESCRIPTION="Portage is the package management and 
distribution system for Gento
 HOMEPAGE="https://wiki.gentoo.org/wiki/Project:Portage";
 
 LICENSE="GPL-2"
-KEYWORDS="amd64 arm ~mips ppc x86"
+KEYWORDS="~alpha ~amd64 ~arm ~arm64 ~hppa ~ia64 ~m68k ~mips ~ppc ~ppc64 ~s390 
~sh ~sparc ~x86 ~amd64-fbsd ~sparc-fbsd ~x86-fbsd"
 SLOT="0"
-IUSE="build doc epydoc +ipc linguas_ru selinux xattr"
+IUSE="build doc epydoc +ipc linguas_ru +native-extensions selinux xattr"
 
 DEPEND="!build? ( $(python_gen_impl_dep 'ssl(+)') )
        >=app-arch/tar-1.27
@@ -44,6 +43,7 @@ RDEPEND="
        )
        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}] )
@@ -65,6 +65,8 @@ 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
@@ -78,10 +80,6 @@ TARBALL_PV=${PV}
 SRC_URI="mirror://gentoo/${PN}-${TARBALL_PV}.tar.bz2
        $(prefix_src_archives ${PN}-${TARBALL_PV}.tar.bz2)"
 
-PATCHES=(
-       
"${FILESDIR}/2.3.1-doc-Revert-URI-changes-related-to-docbook-schema.patch"
-)
-
 pkg_setup() {
        use epydoc && DISTUTILS_ALL_SUBPHASE_IMPLS=( python2.7 )
 }
@@ -89,6 +87,11 @@ pkg_setup() {
 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:" \
@@ -128,7 +131,10 @@ python_prepare_all() {
                        -i cnf/make.globals || die "sed failed"
 
                einfo "Adjusting repos.conf ..."
-               sed -e "s|^\(location = \)\(/usr/portage\)|\\1${EPREFIX}\\2|" \
+               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 ..."
@@ -220,21 +226,11 @@ pkg_preinst() {
                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)
+       if has_version ">=${CATEGORY}/${PN}-2.3.1" && \
+               has_version "<${CATEGORY}/${PN}-2.3.3"; then
+               SYNC_DEPTH_UPGRADE=true
        else
-               USERPRIV_UPGRADE=false
-               USERSYNC_UPGRADE=false
-               REPOS_CONF_UPGRADE=false
+               SYNC_DEPTH_UPGRADE=false
        fi
 }
 
@@ -269,93 +265,11 @@ new_config_protect() {
 }
 
 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
+       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
-
-       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 NO LONGER contains the repoman code 
base."
        einfo "Repoman has its own ebuild and release package."

Reply via email to