portage.git
15 years agoBail out earlier if the file name argument doesn't end with '.ebuild'. Thanks
Zac Medico [Sat, 27 Dec 2008 18:27:52 +0000 (18:27 -0000)]
Bail out earlier if the file name argument doesn't end with '.ebuild'. Thanks
to Diego 'Flameeyes' Pettenò for reporting. (trunk r12350)

svn path=/main/branches/2.1.6/; revision=12355

15 years agoFix loop logic some more for bug #252572. (trunk r12349)
Zac Medico [Sat, 27 Dec 2008 18:27:19 +0000 (18:27 -0000)]
Fix loop logic some more for bug #252572. (trunk r12349)

svn path=/main/branches/2.1.6/; revision=12354

15 years ago (trunk r12345)
Zac Medico [Sat, 27 Dec 2008 18:26:49 +0000 (18:26 -0000)]
 (trunk r12345)

svn path=/main/branches/2.1.6/; revision=12353

16 years agoFix typo. (trunk r12341) v2.1.6.3
Zac Medico [Thu, 25 Dec 2008 05:36:36 +0000 (05:36 -0000)]
Fix typo. (trunk r12341)

svn path=/main/branches/2.1.6/; revision=12342

16 years agoRefactor EbuildMetadataPhase._output_handler() and _set_returncode().
Zac Medico [Thu, 25 Dec 2008 05:30:18 +0000 (05:30 -0000)]
Refactor EbuildMetadataPhase._output_handler() and _set_returncode().
(trunk r12339)

svn path=/main/branches/2.1.6/; revision=12340

16 years agoUse long() instead of float() when parsing Package.mtime from the metadata.
Zac Medico [Thu, 25 Dec 2008 05:05:53 +0000 (05:05 -0000)]
Use long() instead of float() when parsing Package.mtime from the metadata.
(trunk r12332)

svn path=/main/branches/2.1.6/; revision=12338

16 years agoMake vardbapi._aux_get() return _mtime_ as a long (never as a float).
Zac Medico [Thu, 25 Dec 2008 05:05:25 +0000 (05:05 -0000)]
Make vardbapi._aux_get() return _mtime_ as a long (never as a float).
(trunk r12331)

svn path=/main/branches/2.1.6/; revision=12337

16 years agoInside portdbapi._metadata_callback(), preserve _eclasses_ when the EAPI is
Zac Medico [Thu, 25 Dec 2008 05:05:14 +0000 (05:05 -0000)]
Inside portdbapi._metadata_callback(), preserve _eclasses_ when the EAPI is
unsupported since the eclass timestamps might be needed in order to decide
that the cache entry should be regenerated. Also, make sure that all metadata
returned from portdbapi.aux_get() is returned as empty strings when the
EAPI is unsupported. (trunk r12330)

svn path=/main/branches/2.1.6/; revision=12336

16 years agoHandle potential KeyErrors that may be raised from get_eclass_data(), and
Zac Medico [Thu, 25 Dec 2008 05:04:53 +0000 (05:04 -0000)]
Handle potential KeyErrors that may be raised from get_eclass_data(), and
remove unnecessary print statements inside get_eclass_data(). (trunk r12329)

svn path=/main/branches/2.1.6/; revision=12335

16 years agoDon't add any more that one "-" symbol to the front of an unsupported EAPI.
Zac Medico [Thu, 25 Dec 2008 05:04:37 +0000 (05:04 -0000)]
Don't add any more that one "-" symbol to the front of an unsupported EAPI.
(trunk r12328)

svn path=/main/branches/2.1.6/; revision=12334

16 years agoInside mirror_cache(), handle unsupported EAPI like portdbapi does.
Zac Medico [Thu, 25 Dec 2008 05:04:15 +0000 (05:04 -0000)]
Inside mirror_cache(), handle unsupported EAPI like portdbapi does.
(trunk r12327)

svn path=/main/branches/2.1.6/; revision=12333

16 years agoAdd support for synchronizing ebuild and eclass timestamps with the metadata
Zac Medico [Thu, 25 Dec 2008 01:28:34 +0000 (01:28 -0000)]
Add support for synchronizing ebuild and eclass timestamps with the metadata
cache timestamps which emerge --sync operates on a git repository. This is
necessary since git doesn't preserve timestamps. It is assumed that the
timestamps should be synchronized if the relevant ebuilds and eclasses are
unmodified relative to the HEAD commit (as reported by git-ls-files). This
feature was requested by Daniel Robbins, so that it's possible for the funtoo
git repository to distribute pre-generated metadata. (trunk r12303)

svn path=/main/branches/2.1.6/; revision=12326

16 years agoMake BinpkgFetcher use longs instead of floats when synchronizing timestamps,
Zac Medico [Thu, 25 Dec 2008 01:28:20 +0000 (01:28 -0000)]
Make BinpkgFetcher use longs instead of floats when synchronizing timestamps,
since it's better not to rely on float comparison here. (trunk r12302)

svn path=/main/branches/2.1.6/; revision=12325

16 years agoBug #252374 - Warn if FEATURES=fakeroot is enabled, but the fakeroot binary
Zac Medico [Thu, 25 Dec 2008 01:27:55 +0000 (01:27 -0000)]
Bug #252374 - Warn if FEATURES=fakeroot is enabled, but the fakeroot binary
is not installed. (trunk r12301)

svn path=/main/branches/2.1.6/; revision=12324

16 years agoBug #251976 - Add a QA_PRESTRIPPED variable for ebuilds to disable warnings about
Zac Medico [Thu, 25 Dec 2008 01:27:20 +0000 (01:27 -0000)]
Bug #251976 - Add a QA_PRESTRIPPED variable for ebuilds to disable warnings about
pre-stripped files. (trunk r12295:12300)

svn path=/main/branches/2.1.6/; revision=12323

16 years agoBug #252304 - Restore the -V/--version option. (trunk r12293)
Zac Medico [Thu, 25 Dec 2008 01:24:26 +0000 (01:24 -0000)]
Bug #252304 - Restore the -V/--version option. (trunk r12293)

svn path=/main/branches/2.1.6/; revision=12322

16 years agoAdd SIGUSR1 signal handlers that call pdb.set_trace(). Thanks to Brian Harring for
Zac Medico [Thu, 25 Dec 2008 01:23:32 +0000 (01:23 -0000)]
Add SIGUSR1 signal handlers that call pdb.set_trace(). Thanks to Brian Harring for
the suggestion. (trunk r12292)

svn path=/main/branches/2.1.6/; revision=12321

16 years agoMake more code conditional on POLLIN events, where appropriate. (trunk r12291)
Zac Medico [Thu, 25 Dec 2008 01:23:13 +0000 (01:23 -0000)]
Make more code conditional on POLLIN events, where appropriate. (trunk r12291)

svn path=/main/branches/2.1.6/; revision=12320

16 years agoMove initial signal handlers to the launcher script. (trunk r12290)
Zac Medico [Thu, 25 Dec 2008 01:22:57 +0000 (01:22 -0000)]
Move initial signal handlers to the launcher script. (trunk r12290)

svn path=/main/branches/2.1.6/; revision=12319

16 years agoRename the PollTask class to AbstractPollTask. (trunk r12289)
Zac Medico [Thu, 25 Dec 2008 01:22:38 +0000 (01:22 -0000)]
Rename the PollTask class to AbstractPollTask. (trunk r12289)

svn path=/main/branches/2.1.6/; revision=12318

16 years agoAdd handling for POLLERR, POLLNVAL, and POLLHUP. Hopefully this solves hung poll...
Zac Medico [Thu, 25 Dec 2008 01:22:12 +0000 (01:22 -0000)]
Add handling for POLLERR, POLLNVAL, and POLLHUP. Hopefully this solves hung poll calls
with defunct ebuild.sh processes, reported on solaris systems by Fabian Groffen
<grobian@g.o>. (trunk r12287)

svn path=/main/branches/2.1.6/; revision=12317

16 years agoRegister for poll events before forking, in order to avoid potential race conditions
Zac Medico [Thu, 25 Dec 2008 01:21:17 +0000 (01:21 -0000)]
Register for poll events before forking, in order to avoid potential race conditions
in SpawnProcess._start() and EbuildMetadataPhase._start(). Hopefully this solves
hung poll calls with defunct ebuild.sh processes, reported on solaris systems by
Fabian Groffen <grobian@g.o>. (trunk r12285)

svn path=/main/branches/2.1.6/; revision=12316

16 years agoFix PATH comparison in binarytree.inject() some more. (trunk r12295)
Zac Medico [Thu, 25 Dec 2008 01:20:52 +0000 (01:20 -0000)]
Fix PATH comparison in binarytree.inject() some more. (trunk r12295)

svn path=/main/branches/2.1.6/; revision=12315

16 years agoFix broken PATH comparisons when eliminating duplicate entries inside
Zac Medico [Thu, 25 Dec 2008 01:20:42 +0000 (01:20 -0000)]
Fix broken PATH comparisons when eliminating duplicate entries inside
binarytree.inject(). (trunk r12294)

svn path=/main/branches/2.1.6/; revision=12314

16 years agoWhen removing entries with duplicate paths inside binarytree.inject(), handle
Zac Medico [Thu, 25 Dec 2008 01:20:27 +0000 (01:20 -0000)]
When removing entries with duplicate paths inside binarytree.inject(), handle
path collisions in $PKGDIR/All when CPV is not identical. (trunk r12282)

svn path=/main/branches/2.1.6/; revision=12313

16 years agoFix typo. (trunk r12281)
Zac Medico [Thu, 25 Dec 2008 01:13:37 +0000 (01:13 -0000)]
Fix typo. (trunk r12281)

svn path=/main/branches/2.1.6/; revision=12312

16 years agoBug #252243 - Fix binarytree.prevent_collision() so that it won't create a circular
Zac Medico [Thu, 25 Dec 2008 01:13:15 +0000 (01:13 -0000)]
Bug #252243 - Fix binarytree.prevent_collision() so that it won't create a circular
symlink if there happens to be a symlink in $PKGDIR/All for some reason.
(trunk r12280)

svn path=/main/branches/2.1.6/; revision=12311

16 years agoSimplify the code from bug #218854. Also, ensure that the set of visible packages
Zac Medico [Thu, 25 Dec 2008 01:12:48 +0000 (01:12 -0000)]
Simplify the code from bug #218854. Also, ensure that the set of visible packages
thats used by depgraph._iter_atoms_for_pkg() is consistent with the packages that
have been selected by depgraph._select_pkg_highest_available(). This should correct
potential inconstencies introduced by the package selection changes from bug #252167.
(trunk r12279)

svn path=/main/branches/2.1.6/; revision=12310

16 years agoBug #252167 - If the ebuild no longer exists or it's keywords have been dropped,
Zac Medico [Thu, 25 Dec 2008 01:12:33 +0000 (01:12 -0000)]
Bug #252167 - If the ebuild no longer exists or it's keywords have been dropped,
reject built instances (installed or binary). If --usepkgonly is enabled, assume
that the ebuild status should be ignored. (trunk r12278)

svn path=/main/branches/2.1.6/; revision=12309

16 years agoRemove code from unused config.load_infodir() method and issue a deprecation
Zac Medico [Thu, 25 Dec 2008 01:12:14 +0000 (01:12 -0000)]
Remove code from unused config.load_infodir() method and issue a deprecation
warning if it's called. (trunk r12275)

svn path=/main/branches/2.1.6/; revision=12308

16 years agoAdd support for the new DEFINED_PHASES metadata key which is automatically generated
Zac Medico [Thu, 25 Dec 2008 01:11:56 +0000 (01:11 -0000)]
Add support for the new DEFINED_PHASES metadata key which is automatically generated
from the set of phase functions that are defined by the ebuild and any eclasses it
may have inherited. (trunk r12272:12274)

svn path=/main/branches/2.1.6/; revision=12307

16 years agoFix --clean <atom> so that it considers all packages within a given slot when
Zac Medico [Thu, 25 Dec 2008 01:09:39 +0000 (01:09 -0000)]
Fix --clean <atom> so that it considers all packages within a given slot when
it's deciding which packages to keep, rather than just considering the ones
matched by the given atom. Any packages not matching the given atom are protected
from being unmerged. Thanks to Mart Raudsepp <leio@g.o> for reporting.
(trunk r12272)

svn path=/main/branches/2.1.6/; revision=12306

16 years agoUpdate --depclean 'unsatisfied deps' message to recommend the same emerge update
Zac Medico [Thu, 25 Dec 2008 01:09:24 +0000 (01:09 -0000)]
Update --depclean 'unsatisfied deps' message to recommend the same emerge update
command that's recommended earlier. Thanks to Jeremy Olexa <darkside@g.o> for
reporting. (trunk r12271)

svn path=/main/branches/2.1.6/; revision=12305

16 years agoRemove the TaskScheduler.run() method since the constructor replaces it with
Zac Medico [Thu, 25 Dec 2008 01:08:19 +0000 (01:08 -0000)]
Remove the TaskScheduler.run() method since the constructor replaces it with
the QueueScheduler.run() method. (trunk r12270)

svn path=/main/branches/2.1.6/; revision=12304

16 years agoAdjust the EbuildNestedDie pattern so that it only matches when ( is surrounded v2.1.6.2
Zac Medico [Sat, 20 Dec 2008 20:24:18 +0000 (20:24 -0000)]
Adjust the EbuildNestedDie pattern so that it only matches when ( is surrounded
by whitespace. This filters out false positives triggered by sed expressions in
net-analyzer/amap-5.2-r1 and media-libs/libsndfile-1.0.17-r1. Thanks to Diego
Pettenò <flameeyes@g.o> for reporting. (trunk r12265)

svn path=/main/branches/2.1.6/; revision=12267

16 years agoSimplify the InheritAutotools pattern by using \b to match word boundaries.
Zac Medico [Sat, 20 Dec 2008 20:24:11 +0000 (20:24 -0000)]
Simplify the InheritAutotools pattern by using \b to match word boundaries.
(trunk r12264)

svn path=/main/branches/2.1.6/; revision=12266

16 years agoBug #251591 - Adjust the InheritAutotools pattern to treat more things similar to
Zac Medico [Sat, 20 Dec 2008 19:46:33 +0000 (19:46 -0000)]
Bug #251591 - Adjust the InheritAutotools pattern to treat more things similar to
whitespace. Now it recognizes escaped newlines, || operators, and && operators.
(trunk r12260)

svn path=/main/branches/2.1.6/; revision=12263

16 years agoBug #251616 - Inside _check_build_log(), remove unnecessary .* patterns from regular
Zac Medico [Sat, 20 Dec 2008 19:46:18 +0000 (19:46 -0000)]
Bug #251616 - Inside _check_build_log(), remove unnecessary .* patterns from regular
expressions. These patterns trigger extreme performance issues when matched against
extremely large lines such as those produced by dev-util/bzr test suite when it
uses \r to rewrite the same line thousands of times. (trunk r12259)

svn path=/main/branches/2.1.6/; revision=12262

16 years agoFix DependencyArg.__str__() to ensure that str type is always returned.
Zac Medico [Sat, 20 Dec 2008 19:45:55 +0000 (19:45 -0000)]
Fix DependencyArg.__str__() to ensure that str type is always returned.
(trunk r12258)

svn path=/main/branches/2.1.6/; revision=12261

16 years agoDetect problems with arguments and return non-zero when appropriate. v2.1.6.1
Zac Medico [Fri, 12 Dec 2008 22:49:35 +0000 (22:49 -0000)]
Detect problems with arguments and return non-zero when appropriate.
(trunk r12248)

svn path=/main/branches/2.1.6/; revision=12249

16 years agoRemove note about the repo_name warning since it's disabled in this branch
Zac Medico [Fri, 12 Dec 2008 22:20:08 +0000 (22:20 -0000)]
Remove note about the repo_name warning since it's disabled in this branch
(bug #248603).

svn path=/main/branches/2.1.6/; revision=12247

16 years agoAdd a new FEATURES=test-fail-continue value which causes ebuild execution
Zac Medico [Fri, 12 Dec 2008 21:51:45 +0000 (21:51 -0000)]
Add a new FEATURES=test-fail-continue value which causes ebuild execution
to continue after the test phase has failed. Thanks to Diego Pettenò
<flameeyes@g.o> for the suggestion. (trunk r12214)

svn path=/main/branches/2.1.6/; revision=12245

16 years agoFix --pretend logic in Binpkg some more. (trunk r12213)
Zac Medico [Fri, 12 Dec 2008 21:51:21 +0000 (21:51 -0000)]
Fix --pretend logic in Binpkg some more. (trunk r12213)

svn path=/main/branches/2.1.6/; revision=12244

16 years agoFix --getbinpkg to behave as expected with --pretend and --fetchonly.
Zac Medico [Fri, 12 Dec 2008 21:50:43 +0000 (21:50 -0000)]
Fix --getbinpkg to behave as expected with --pretend and --fetchonly.
(trunk r12212)

svn path=/main/branches/2.1.6/; revision=12243

16 years agoFix breakage in stale metadata logic inside binarytree._poplulate().
Zac Medico [Fri, 12 Dec 2008 21:50:25 +0000 (21:50 -0000)]
Fix breakage in stale metadata logic inside binarytree._poplulate().
(trunk r12211)

svn path=/main/branches/2.1.6/; revision=12242

16 years agoFix incorrect usage of trap (only remove on signal at a time). (trunk r12210)
Zac Medico [Fri, 12 Dec 2008 21:50:00 +0000 (21:50 -0000)]
Fix incorrect usage of trap (only remove on signal at a time). (trunk r12210)

svn path=/main/branches/2.1.6/; revision=12241

16 years agoWhen using the old binhost protocol, comparison with the remote
Zac Medico [Fri, 12 Dec 2008 21:49:20 +0000 (21:49 -0000)]
When using the old binhost protocol, comparison with the remote
package isn't supported, so the local package is always preferred
even if --getbinpkgonly is enabled. Simplify bintree.isremote()
so it works the same way regardless of which protocol is used. (trunk r12209)

svn path=/main/branches/2.1.6/; revision=12240

16 years agoFix old-style binhost code binarytree.digestCheck() will use local digests when
Zac Medico [Fri, 12 Dec 2008 21:48:56 +0000 (21:48 -0000)]
Fix old-style binhost code binarytree.digestCheck() will use local digests when
a local package overrides a remote one. (trunk r12208)

svn path=/main/branches/2.1.6/; revision=12239

16 years agoFix --getbinpkgonly behavior so that binaries from the remote server are
Zac Medico [Fri, 12 Dec 2008 21:45:18 +0000 (21:45 -0000)]
Fix --getbinpkgonly behavior so that binaries from the remote server are
preferred over local packages if they are not identical. Thanks to Lance
Albertson <ramereth@g.o> for reporting. (trunk r12207)

svn path=/main/branches/2.1.6/; revision=12238

16 years agoDon't warn about missing repo_name for $PORTDIR when it happens to be empty.
Zac Medico [Fri, 12 Dec 2008 21:41:57 +0000 (21:41 -0000)]
Don't warn about missing repo_name for $PORTDIR when it happens to be empty.
(trunk r12206)

svn path=/main/branches/2.1.6/; revision=12237

16 years agoAdd --sync support for `git pull`, and also add a failsafe to prevent rsync
Zac Medico [Fri, 12 Dec 2008 21:41:29 +0000 (21:41 -0000)]
Add --sync support for `git pull`, and also add a failsafe to prevent rsync
from being called if $PORTDIR appears to be under revision control. Thanks
to Daniel Robbins for the initial patch. (trunk r12205)

svn path=/main/branches/2.1.6/; revision=12236

16 years agoFix exit code to return non-zero when an error occurs. Thanks to Christoph
Zac Medico [Fri, 12 Dec 2008 21:40:50 +0000 (21:40 -0000)]
Fix exit code to return non-zero when an error occurs. Thanks to Christoph
Mende <angelos@g.o> for reporting. (trunk r12202)

svn path=/main/branches/2.1.6/; revision=12235

16 years agoMake BinpkgFetcher synchronize the local timestamp of the downloaded file
Zac Medico [Fri, 12 Dec 2008 21:40:20 +0000 (21:40 -0000)]
Make BinpkgFetcher synchronize the local timestamp of the downloaded file
with the remote file, if the fetcher hasn't done it automatically.
(trunk r12201)

svn path=/main/branches/2.1.6/; revision=12234

16 years agoRemove ManifestEntry.__cmp__() since it's not needed and py3k won't use it.
Zac Medico [Fri, 12 Dec 2008 21:39:52 +0000 (21:39 -0000)]
Remove ManifestEntry.__cmp__() since it's not needed and py3k won't use it.
(trunk r12200)

svn path=/main/branches/2.1.6/; revision=12233

16 years agoFor py3k compat, remove Atom.__cmp__() and use str.__lt__() instead.
Zac Medico [Fri, 12 Dec 2008 21:39:35 +0000 (21:39 -0000)]
For py3k compat, remove Atom.__cmp__() and use str.__lt__() instead.
(trunk r12199)

svn path=/main/branches/2.1.6/; revision=12232

16 years agoMake Binpkg clean the build dir immediately after locking it. This ensures
Zac Medico [Fri, 12 Dec 2008 21:39:19 +0000 (21:39 -0000)]
Make Binpkg clean the build dir immediately after locking it. This ensures
that a new PORTAGE_LOG_FILE is created. (trunk r12198)

svn path=/main/branches/2.1.6/; revision=12231

16 years agoMake BinpkgVerifier rename files that fail verification, similar to how
Zac Medico [Fri, 12 Dec 2008 21:39:01 +0000 (21:39 -0000)]
Make BinpkgVerifier rename files that fail verification, similar to how
distfiles are automatically renamed. (trunk r12197)

svn path=/main/branches/2.1.6/; revision=12230

16 years agoMake the Binpkg class handle fetch logging similar to how EbuildBuild does,
Zac Medico [Fri, 12 Dec 2008 21:37:31 +0000 (21:37 -0000)]
Make the Binpkg class handle fetch logging similar to how EbuildBuild does,
directing output to PORTAGE_LOG_FILE instead of emerge-fetch.log which is
only used for prefetchers now. (trunk r12196)

svn path=/main/branches/2.1.6/; revision=12229

16 years agoVerify binary packages even when not in "strict" mode (normal distfiles are
Zac Medico [Fri, 12 Dec 2008 21:36:58 +0000 (21:36 -0000)]
Verify binary packages even when not in "strict" mode (normal distfiles are
also verified in this case). (trunk r12195)

svn path=/main/branches/2.1.6/; revision=12228

16 years agoCreate a BinpkgPrefetcher composite task to handle fetch, verification,
Zac Medico [Fri, 12 Dec 2008 21:36:34 +0000 (21:36 -0000)]
Create a BinpkgPrefetcher composite task to handle fetch, verification,
and injection. (trunk r12194)

svn path=/main/branches/2.1.6/; revision=12227

16 years agoWhen the Binpkg class has fetched a package in --fetchonly mode, wait until
Zac Medico [Fri, 12 Dec 2008 21:36:15 +0000 (21:36 -0000)]
When the Binpkg class has fetched a package in --fetchonly mode, wait until
after the package is verified and injected before returning. (trunk r12193)

svn path=/main/branches/2.1.6/; revision=12226

16 years agourlparse.urljoin() only works correctly with recognized protocols and
Zac Medico [Fri, 12 Dec 2008 21:30:00 +0000 (21:30 -0000)]
urlparse.urljoin() only works correctly with recognized protocols and
requires the base url to have a trailing slash, so join PORTAGE_BINHOST
manually. Thanks to Lance Albertson <ramereth@g.o> for reporting. (trunk r12192)

svn path=/main/branches/2.1.6/; revision=12225

16 years agoWhen processing output from the "depend" phase, use the number of lines as
Zac Medico [Fri, 12 Dec 2008 21:29:26 +0000 (21:29 -0000)]
When processing output from the "depend" phase, use the number of lines as
a sanity check so that bash's returncode doesn't have to be trusted.
(trunk r12191)

svn path=/main/branches/2.1.6/; revision=12224

16 years agoWhen attempting to close fd 9 at the end of the depend phase, use exec so that
Zac Medico [Fri, 12 Dec 2008 21:29:09 +0000 (21:29 -0000)]
When attempting to close fd 9 at the end of the depend phase, use exec so that
it really works. (trunk r12190)

svn path=/main/branches/2.1.6/; revision=12223

16 years agoBug #250148 - Prevent ebuild.sh subprocess from inheriting file descriptor
Zac Medico [Fri, 12 Dec 2008 21:28:54 +0000 (21:28 -0000)]
Bug #250148 - Prevent ebuild.sh subprocess from inheriting file descriptor
9, since otherwise if a daemon process such as udevd gets spawned then it
can inherit the file descriptor and hang emerge. (trunk r12189)

svn path=/main/branches/2.1.6/; revision=12222

16 years agoBug #250166 - To avoid accidental regeneration of digests with the incorrect
Zac Medico [Fri, 12 Dec 2008 21:28:11 +0000 (21:28 -0000)]
Bug #250166 - To avoid accidental regeneration of digests with the incorrect
files (such as partially downloaded files), trigger the fetch code if the file
exists and it's size doesn't match the current manifest entry. If there really
is a legitimate reason for the digest to change, `ebuild --force digest` can
be used to avoid triggering this code (or else the old digests can be manually
removed from the Manifest). (trunk r12185:12188)

svn path=/main/branches/2.1.6/; revision=12221

16 years agoWhen in --debug mode, make the depgraph call self.digraph.debug_print() to
Zac Medico [Fri, 12 Dec 2008 21:25:36 +0000 (21:25 -0000)]
When in --debug mode, make the depgraph call self.digraph.debug_print() to
display the final digraph state. This should help when troubleshooting
problems with blockers that don't resolve automatically, by making it easier
to see what pulled in unwanted packages. (trunk r12185)

svn path=/main/branches/2.1.6/; revision=12220

16 years agoFor py3k compat, avoid using list.sort(cmp). (trunk r12184)
Zac Medico [Fri, 12 Dec 2008 21:24:53 +0000 (21:24 -0000)]
For py3k compat, avoid using list.sort(cmp). (trunk r12184)

svn path=/main/branches/2.1.6/; revision=12219

16 years agoFor py3k compat, remove Package.__cmp__() and related cmp() function call.
Zac Medico [Fri, 12 Dec 2008 21:23:54 +0000 (21:23 -0000)]
For py3k compat, remove Package.__cmp__() and related cmp() function call.
(trunk r12183)

svn path=/main/branches/2.1.6/; revision=12218

16 years agoFix deprecated_profile_check() to account for PORTAGE_CONFIGROOT. Thanks to
Zac Medico [Fri, 12 Dec 2008 21:23:16 +0000 (21:23 -0000)]
Fix deprecated_profile_check() to account for PORTAGE_CONFIGROOT. Thanks to
Jeremy Olexa <darkside@g.o> for the initial patch. (trunk r12181)

svn path=/main/branches/2.1.6/; revision=12217

16 years agoAvoid TypeError in BlockerCache.__iter__() that's triggered with
Zac Medico [Fri, 12 Dec 2008 21:20:59 +0000 (21:20 -0000)]
Avoid TypeError in BlockerCache.__iter__() that's triggered with
FEATURES=python-trace. Thanks to Fabian Groffen <grobian@g.o> for reporting.
(trunk r12180)

svn path=/main/branches/2.1.6/; revision=12216

16 years agoBug #250212 - Add a new 'upstream.workaround' qa category, and use it for
Zac Medico [Fri, 12 Dec 2008 21:20:17 +0000 (21:20 -0000)]
Bug #250212 - Add a new 'upstream.workaround' qa category, and use it for
the EMakeParallelDisabled check. Thanks to Mike Auty <ikelos@g.o> for this
patch. (trunk r12179)

svn path=/main/branches/2.1.6/; revision=12215

16 years agoRemove the part about 'link level dependency awareness' which is not supported
Zac Medico [Thu, 11 Dec 2008 19:05:25 +0000 (19:05 -0000)]
Remove the part about 'link level dependency awareness' which is not supported
in this branch. Thanks to Arun Raghavan <ford_prefect@g.g> for reporting.

svn path=/main/branches/2.1.6/; revision=12203

16 years agoBug #249586 - Use writemsg() to send output to stderr instead of stdout. v2.1.6
Zac Medico [Sun, 7 Dec 2008 20:17:27 +0000 (20:17 -0000)]
Bug #249586 - Use writemsg() to send output to stderr instead of stdout.
(trunk r12176)

svn path=/main/branches/2.1.6/; revision=12177

16 years agoIf pkg_nofetch needs to be spawned inside fetch() and it happens that
Zac Medico [Sun, 7 Dec 2008 00:20:43 +0000 (00:20 -0000)]
If pkg_nofetch needs to be spawned inside fetch() and it happens that
PORTAGE_BUILDDIR doesn't exist, like when called by digestgen(), use
mkdtemp to create a private temporary directory so that pkg_nofetch
can be spawned (directory needed to satisfy safe $PWD requirement of
bug #239560). This is more user friendly since before the pkg_nofetch
phase would simply be skipped in this case. Thanks to Petteri Räty
<betelgeuse@g.o> for reporting. (trunk r12174)

svn path=/main/branches/2.1.6/; revision=12175

16 years agoAllow 'system' and 'world' arguments simultaneously since it doesn't hurt.
Zac Medico [Sat, 6 Dec 2008 22:34:13 +0000 (22:34 -0000)]
Allow 'system' and 'world' arguments simultaneously since it doesn't hurt.

svn path=/main/branches/2.1.6/; revision=12173

16 years agoAdd docs for PORTAGE_GPG_DIR and PORTAGE_GPG_KEY that are used by repoman for
Zac Medico [Sat, 6 Dec 2008 08:11:00 +0000 (08:11 -0000)]
Add docs for PORTAGE_GPG_DIR and PORTAGE_GPG_KEY that are used by repoman for
FEATURES=sign support. Thanks to Petteri Räty <betelgeuse@g.o> for reporting.
(trunk r12168)

svn path=/main/branches/2.1.6/; revision=12169

16 years agoValidate $ROOT inside the --resume merge list in order to avoid a pottential
Zac Medico [Sat, 6 Dec 2008 05:36:06 +0000 (05:36 -0000)]
Validate $ROOT inside the --resume merge list in order to avoid a pottential
KeyError due to a stale merge list that was for a different $ROOT setting.
Thanks to Ned Ludd <solar@g.o> for reporting. (trunk r12166)

svn path=/main/branches/2.1.6/; revision=12167

16 years agoMake fixpackages use a new "#" symbol for /var/db updates (previously '*' v2.1.6_rc3
Zac Medico [Fri, 5 Dec 2008 00:09:54 +0000 (00:09 -0000)]
Make fixpackages use a new "#" symbol for /var/db updates (previously '*'
which means 'binary update' was used). (trunk r12159)

svn path=/main/branches/2.1.6/; revision=12160

16 years agoMake fixpackages less noisy by only generting '*' characters for packages
Zac Medico [Thu, 4 Dec 2008 23:57:32 +0000 (23:57 -0000)]
Make fixpackages less noisy by only generting '*' characters for packages
that are modified by updates. (trunk r12155)

svn path=/main/branches/2.1.6/; revision=12158

16 years agoEnable FEATURES=fixpackages by default since the performance is pretty
Zac Medico [Thu, 4 Dec 2008 21:13:09 +0000 (21:13 -0000)]
Enable FEATURES=fixpackages by default since the performance is pretty
reasonable now. Thanks to Jeremy Olexa <darkside@g.o> for the suggestion.
(trunk r12153 and r12155)

svn path=/main/branches/2.1.6/; revision=12156

16 years agoMake sure depgraph._slot_conflict_explanation() doesn't display the same
Zac Medico [Thu, 4 Dec 2008 06:57:49 +0000 (06:57 -0000)]
Make sure depgraph._slot_conflict_explanation() doesn't display the same
atom more than once. (trunk r12150)

svn path=/main/branches/2.1.6/; revision=12151

16 years agoBug #249185 - For common cases in which USE deps trigger SLOT conflicts, give
Zac Medico [Thu, 4 Dec 2008 05:42:41 +0000 (05:42 -0000)]
Bug #249185 - For common cases in which USE deps trigger SLOT conflicts, give
a short explanation and suggest a course of action to solve the problem.
(trunk r12148)

svn path=/main/branches/2.1.6/; revision=12149

16 years agoBreak references between the depgraph and the dropped tasks inside
Zac Medico [Wed, 3 Dec 2008 20:47:05 +0000 (20:47 -0000)]
Break references between the depgraph and the dropped tasks inside
Scheduler._calc_resume_list(), since the tasks are now saved for
display at the end. (trunk r12146)

svn path=/main/branches/2.1.6/; revision=12147

16 years agoWhen --keep-going drops packages due to unsatisfied dependencies, include
Zac Medico [Wed, 3 Dec 2008 20:41:50 +0000 (20:41 -0000)]
When --keep-going drops packages due to unsatisfied dependencies, include
them in the list of packgaes that "failed to build or install" that's
displayed at the end. Thanks to Jeremy Olexa <darkside@g.o> for the
suggestion. (trunk r12144)

svn path=/main/branches/2.1.6/; revision=12145

16 years agoIt's not safe to use the git commit -a option since there might
Zac Medico [Wed, 3 Dec 2008 08:23:34 +0000 (08:23 -0000)]
It's not safe to use the git commit -a option since there might
be some modified files elsewhere in the working tree that the
user doesn't want to commit. Therefore, call git update-index
in order to ensure that the index is updated with the latest
versions of all new and modified files in the relevant portion
of the working tree. (trunk r12142)

svn path=/main/branches/2.1.6/; revision=12143

16 years agoWhen calling `git ls-files -m` to list modified files, use --with-tree=HEAD
Zac Medico [Wed, 3 Dec 2008 05:44:07 +0000 (05:44 -0000)]
When calling `git ls-files -m` to list modified files, use --with-tree=HEAD
so that differences from the most recent commit are given instead of
differences from the index which is used for commit staging purposes.
This is required since otherwise files that have been added via `git add`
(such as echangelog does with the ChangeLog) won't show up in the list
of modified files due to being unmodified relative to the index. Thanks
to Christian Ruppert (idl0r) for reporting. (trunk r12140)

svn path=/main/branches/2.1.6/; revision=12141

16 years agoFix depgraph._dep_check_composite_db._visible() to reject installed packages
Zac Medico [Tue, 2 Dec 2008 23:39:59 +0000 (23:39 -0000)]
Fix depgraph._dep_check_composite_db._visible() to reject installed packages
that are masked. This is necessary for correct choices in || deps when we
want to ensure that installed masked packages are not preferred over other
available choices that are not masked. Thanks to Jan Kundrát <jkt@g.o> for
reporting this issue and testing the patch. (trunk r12138)

svn path=/main/branches/2.1.6/; revision=12139

16 years agoSkip sourcing of profile.bashrc during the depend phase. (trunk r12136)
Zac Medico [Tue, 2 Dec 2008 22:39:22 +0000 (22:39 -0000)]
Skip sourcing of profile.bashrc during the depend phase. (trunk r12136)

svn path=/main/branches/2.1.6/; revision=12137

16 years agoSource bashrc files as late as possible, giving them the opportunity to
Zac Medico [Tue, 2 Dec 2008 22:20:34 +0000 (22:20 -0000)]
Source bashrc files as late as possible, giving them the opportunity to
override as much as possible. Thanks to Ned Ludd <solar@g.o> for the
suggestion. (trunk r12134)

svn path=/main/branches/2.1.6/; revision=12135

16 years agoFix inconsistencies between the "clean" and "cleanrm" phases. (trunk r12126)
Zac Medico [Mon, 1 Dec 2008 19:06:29 +0000 (19:06 -0000)]
Fix inconsistencies between the "clean" and "cleanrm" phases. (trunk r12126)

svn path=/main/branches/2.1.6/; revision=12129

16 years agoBug #249185 - For more useful output in cases when one or more USE deps
Zac Medico [Mon, 1 Dec 2008 19:04:53 +0000 (19:04 -0000)]
Bug #249185 - For more useful output in cases when one or more USE deps
trigger "SLOT conflicts", show the specific atoms that triggered the
conflict. TODO: Distiguish between various possible causes and tailor
messages to suit them. (trunk r12125)

svn path=/main/branches/2.1.6/; revision=12128

16 years agoChange depgraph._slot_collision_info() from a set to a dict that contains
Zac Medico [Mon, 1 Dec 2008 19:02:33 +0000 (19:02 -0000)]
Change depgraph._slot_collision_info() from a set to a dict that contains
sets of packages pulled into a given slot. This will make the data easier
to analyze when implementing a fix for bug #249185. (trunk r12124)

svn path=/main/branches/2.1.6/; revision=12127

16 years agoAdd a sanity check inside depgraph._add_pkg() to ensure that the dependencies
Zac Medico [Sat, 29 Nov 2008 20:24:31 +0000 (20:24 -0000)]
Add a sanity check inside depgraph._add_pkg() to ensure that the dependencies
of the same package are never processed more than once. (trunk r12122)

svn path=/main/branches/2.1.6/; revision=12123

16 years agoAdd 'automatically resolved' blockers to the --pretend docs. (trunk r12120)
Zac Medico [Sat, 29 Nov 2008 06:39:43 +0000 (06:39 -0000)]
Add 'automatically resolved' blockers to the --pretend docs. (trunk r12120)

svn path=/main/branches/2.1.6/; revision=12121

16 years agoUse stat st_dev attributes instead of the older approach. (trunk r12117) v2.1.6_rc2
Zac Medico [Thu, 27 Nov 2008 02:36:41 +0000 (02:36 -0000)]
Use stat st_dev attributes instead of the older approach. (trunk r12117)

svn path=/main/branches/2.1.6/; revision=12118

16 years agoDon't call prepare_build_dirs() inside doebuild() when called for parallel
Zac Medico [Thu, 27 Nov 2008 02:09:11 +0000 (02:09 -0000)]
Don't call prepare_build_dirs() inside doebuild() when called for parallel
fetching. (trunk r12115)

svn path=/main/branches/2.1.6/; revision=12116

16 years agoFor bug #235642, include the stat mode, uid, and gid bits in the hardlink key.
Zac Medico [Wed, 26 Nov 2008 23:56:08 +0000 (23:56 -0000)]
For bug #235642, include the stat mode, uid, and gid bits in the hardlink key.
(trunk r12113)

svn path=/main/branches/2.1.6/; revision=12114

16 years agoIn movefile(), ignore the hardlink_candidates parameter when it's an empty list.
Zac Medico [Wed, 26 Nov 2008 23:07:44 +0000 (23:07 -0000)]
In movefile(), ignore the hardlink_candidates parameter when it's an empty list.
(trunk r12111)

svn path=/main/branches/2.1.6/; revision=12112

16 years agoBug #235642 - Create hardlinks when merging identical files. This works by using a
Zac Medico [Wed, 26 Nov 2008 22:40:41 +0000 (22:40 -0000)]
Bug #235642 - Create hardlinks when merging identical files. This works by using a
tuple of (md5, st_size) as a key to a list of hardlink candidates. Multiple candidates
are used in case some happen to be merged to separate devices. (trunk r12109)

svn path=/main/branches/2.1.6/; revision=12110