summaryrefslogtreecommitdiffstats
Commit message (Collapse)AuthorAgeFilesLines
...
* Fix breakage in the depclean/prune unsatisfied deps handling.Zac Medico2008-07-211-7/+8
| | | | svn path=/main/trunk/; revision=11154
* Fix typo.Zac Medico2008-07-211-1/+1
| | | | svn path=/main/trunk/; revision=11153
* For --depclean and --prune, eliminate duplicate graph creation code by re-usingZac Medico2008-07-213-187/+207
| | | | | | | | the depgraph class to do it. The depgraph class was used in the past for this purpose but back then it didn't handle USE flags correctly for installed packages. Now it works fine. svn path=/main/trunk/; revision=11152
* Redirect the 'Recording <pkg> in "world" favorites file...' message throughZac Medico2008-07-211-2/+2
| | | | | | _status_msg(). svn path=/main/trunk/; revision=11151
* Fix broken references to the old elog_modules namespace.Zac Medico2008-07-201-2/+2
| | | | svn path=/main/trunk/; revision=11150
* Redirect some more unmerge() output through writemsg_level() so that it canZac Medico2008-07-201-4/+6
| | | | | | filtered out when in background mode. svn path=/main/trunk/; revision=11147
* Fix Scheduler emergelog() interaction to properly disable emergelog()Zac Medico2008-07-201-6/+7
| | | | | | xterm titles whenever the status display is enabled. svn path=/main/trunk/; revision=11146
* * Clean up _schedule_tasks_imp() a bit.Zac Medico2008-07-201-9/+9
| | | | | | * Make _task() access _background directly instead of as a parameter. svn path=/main/trunk/; revision=11145
* Make PollScheduler._poll() add poll events to the stack instead of returningZac Medico2008-07-201-6/+7
| | | | | | | them. This makes it more useful as a hook, allowing Scheduler._poll() to safely call _schedule(). svn path=/main/trunk/; revision=11144
* Merge tasks currently run synchronously which makes it necessary to disableZac Medico2008-07-191-1/+8
| | | | | | | auto_schedule on the merge queue in order to avoid excess recursion which prevents tasks from being marked complete as soon as they should be. svn path=/main/trunk/; revision=11143
* Fix Scheduler._schedule_tasks_imp() so that it never indicates that thereZac Medico2008-07-191-2/+5
| | | | | | | are remaining tasks in cases when it's supposed to bail out due to a package failure. svn path=/main/trunk/; revision=11142
* Calling _schedule() from Scheduler._poll() is unsafe since the _schedule()Zac Medico2008-07-191-1/+1
| | | | | | | call itself can consume poll events. Therefore, until a safe way exists, don't do it. svn path=/main/trunk/; revision=11141
* Use the memoized _choose_pkg() result to return earlier fromZac Medico2008-07-191-1/+2
| | | | | | _schedule_tasks() when possible. svn path=/main/trunk/; revision=11140
* When Scheduler._choose_pkg() is unable to find a package, memoize the resultZac Medico2008-07-191-2/+23
| | | | | | until at least one of the existing jobs completes. svn path=/main/trunk/; revision=11139
* Bug #231464 - Replace erroneous "return" statement in elog_process() withZac Medico2008-07-191-1/+1
| | | | | | a continue statement. Thanks to TGL for this patch. svn path=/main/trunk/; revision=11138
* Instead of calling _background_mode(), use the cached result.Zac Medico2008-07-191-4/+4
| | | | svn path=/main/trunk/; revision=11137
* Fix JobStatusDisplay._init_term() to supply default codes in cases whenZac Medico2008-07-191-6/+10
| | | | | | curses.tigetstr() returns None. svn path=/main/trunk/; revision=11136
* * Call self._schedule() from inside Scheduler._poll(). This ensures thatZac Medico2008-07-191-10/+20
| | | | | | | | | | | | | | | | | new jobs can scheduled as soon a the load average is low enough, and one of the running jobs doesn't have to complete for _schedule() to get called. * Cache the result of _background_mode() so it doesn't have to be called inside _schedule(), since this method is called a lot more often now. * Move background related state adjustments into _background_mode(). * Call _status_display.display() unconditionally inside _schedule_tasks(), since we want to update the display to show current load average even if no new jobs are added. svn path=/main/trunk/; revision=11135
* Fix typos.Zac Medico2008-07-191-2/+2
| | | | svn path=/main/trunk/; revision=11134
* Add a Scheduler._background_mode() method to control background mode, andZac Medico2008-07-191-6/+9
| | | | | | trigger it if either --quiet is enabled or --jobs > 1. svn path=/main/trunk/; revision=11133
* Display "Verifying ebuild manifests" and "Starting parallel fetch" viaZac Medico2008-07-191-2/+2
| | | | | | the status display instead of directly to stdout. svn path=/main/trunk/; revision=11132
* Add a hook in Scheduler._poll() that updates the display once every 2 secondsZac Medico2008-07-191-4/+24
| | | | | | if stdout is a tty, so that the load average numbers are always current. svn path=/main/trunk/; revision=11131
* Make all poll() calls pass through PollScheduler._poll().Zac Medico2008-07-191-5/+11
| | | | svn path=/main/trunk/; revision=11130
* When JobStatusDisplay.displayMessage() is called while the status is currentlyZac Medico2008-07-191-0/+6
| | | | | | displayed, call display() after showing the given message. svn path=/main/trunk/; revision=11129
* Add support to JobStatusDisplay() to update the current line on the terminal,Zac Medico2008-07-191-5/+91
| | | | | | | | | | | which in the future can be used to erase the line and update it with new information such as the latest load average measurement. This uses curses to obtain the simple control codes that are needed, and has fallback codes in case the curses module is unavailable or raises an error. When stdout is not a tty then the line erasing behavior is automatically disabled and display updates are simply show on a new line. svn path=/main/trunk/; revision=11128
* Add a MergeListItem.statusMessage(msg) callback for displaying messages likeZac Medico2008-07-191-21/+25
| | | | | | | | | "Building this" or "Installing that". This delegates the resposibility of generating \r and \n control characters, to guarantee that lines are created or erased when necessary and appropriate. TODO: Make JobStatusDisplay display the output. svn path=/main/trunk/; revision=11127
* Bug #199788 - Make repoman parse GLEP 56 USE flag descriptions fromZac Medico2008-07-182-0/+48
| | | | | | | metadata.xml (in addition to use.local.desc). Thanks to Doug Goldstein <cardoe@g.o> for this patch. svn path=/main/trunk/; revision=11126
* Fix typo.Zac Medico2008-07-181-1/+1
| | | | svn path=/main/trunk/; revision=11124
* Suppress counter initialization warning messages inZac Medico2008-07-181-4/+7
| | | | | | | | vardbapi.get_counter_tick_core() in cases when the vdb is empty. This avoids pointless error messages when merging packages into a new root, like when building stage 1. svn path=/main/trunk/; revision=11123
* Add background output redirection and async ebuild phase support forZac Medico2008-07-182-41/+70
| | | | | | PackageUninstall (automatic uninstalls that solve blockers). svn path=/main/trunk/; revision=11122
* Change package status messages to give more accurate information about whatZac Medico2008-07-181-18/+34
| | | | | | | | | | | is happening at a given time: * Change "Emerging" messages to "Building" for ebuilds and "Extracting" for binary packages. * Change "Merging" messages to "Installing" and "Uninstalling". svn path=/main/trunk/; revision=11121
* In dblink._dblink_display_merge(), when in background mode and no log isZac Medico2008-07-181-2/+3
| | | | | | | | | available, suppress output when level < logging.WARNING. This hides ">>> Regenerating /etc/ld.so.cache..." messages that appear after postrm when PORT_LOGDIR is unset (the log file if it exists is removed after postrm so there's no place to log the message). svn path=/main/trunk/; revision=11120
* Use dblink._eerror() to eliminate duplicate code.Zac Medico2008-07-181-14/+2
| | | | svn path=/main/trunk/; revision=11119
* If an problem is detected in dblink._security_check(), log it via elog soZac Medico2008-07-181-10/+21
| | | | | | that it's properly displayed in the foreground even when in background mode. svn path=/main/trunk/; revision=11118
* Redirect dblink elog messages from stdout to the log file when in backgroundZac Medico2008-07-173-13/+48
| | | | | | | | mode. This is implemented by adding a new "out" parameter to the portage.elog.e* functions, which can be used to send output to an arbitary file instead of stdout. svn path=/main/trunk/; revision=11117
* When dblink is looping over files for merge/unmerge, temporarily yield to theZac Medico2008-07-172-11/+76
| | | | | | | | | | scheduler each time a fixed number of files are processed (currently 20). This gives the scheduler an opportunity to service pending poll events. This is implemented with a new PollScheduler._schedule_yield() method which calls poll() exactly once, without blocking, and any services any resulting poll events. svn path=/main/trunk/; revision=11116
* Also, reset "merges" in JobStatusDisplay.reset().Zac Medico2008-07-171-0/+1
| | | | svn path=/main/trunk/; revision=11115
* Initialize JobStatusDisplay.merges since it's not initialized with the boundZac Medico2008-07-171-0/+1
| | | | | | properties anymore. svn path=/main/trunk/; revision=11114
* Also, don't count "merges" as changes in the status display.Zac Medico2008-07-171-1/+1
| | | | svn path=/main/trunk/; revision=11113
* Since it's not very interesting, disable the "merges" part of status display.Zac Medico2008-07-171-1/+2
| | | | svn path=/main/trunk/; revision=11112
* Fix identation (tabnanny complains about this) branches/prefix r11110Zac Medico2008-07-171-1/+1
| | | | svn path=/main/trunk/; revision=11111
* Reformat the status display. Here's an example:Zac Medico2008-07-171-27/+52
| | | | | | | | >>> Jobs: 0 of 2 complete, 2 running Load average: 2.9, 2.4, 2.0 >>> Jobs: 0 of 2 complete, 1 running, 2 merges Load average: 2.8, 2.4, 2.0 >>> Jobs: 2 of 2 complete Load average: 2.6, 2.3, 2.0 svn path=/main/trunk/; revision=11107
* Don't show "Merging" and "merged." messages when in background mode.Zac Medico2008-07-171-2/+4
| | | | svn path=/main/trunk/; revision=11105
* Make Binpkg send "Extracting" messages to the log file when in backgroundZac Medico2008-07-171-3/+16
| | | | | | mode, instead of stdout. svn path=/main/trunk/; revision=11104
* Update the status display in _build_exit(), after decrementing the job count.Zac Medico2008-07-171-0/+1
| | | | svn path=/main/trunk/; revision=11103
* Make BinpkgVerifier redirect output to the fetch log when in background mode.Zac Medico2008-07-171-20/+41
| | | | svn path=/main/trunk/; revision=11102
* Don't show a blank newline before ">>> Emerging" when in background mode.Zac Medico2008-07-171-1/+4
| | | | svn path=/main/trunk/; revision=11101
* Handle the case in dblink.unmerge() when the log file is a temp file and soZac Medico2008-07-171-1/+6
| | | | | | it doesn't exist after postrm cleaning. svn path=/main/trunk/; revision=11100
* Tweak interaction between Scheduler and status display so that it doesn'tZac Medico2008-07-171-5/+6
| | | | | | display more often than necessary and avoids showing inconsistent counts. svn path=/main/trunk/; revision=11099
* * Add a new portage.util.writemsg_level() function which uses a "level"Zac Medico2008-07-174-35/+59
| | | | | | | | | | | | | | | | parameter to control whether the message is sent to stdout or stderr. When level >= logging.WARNING then the message is sent to stderr, otherwise it is sent to stdout. The noiselevel is passed directly to writemsg(). * Use writemsg_level() for handling merge messages from dblink and add appropriate noiselevel values to each call. * Add a writemsg_level parameter to portage.env_update() so that dblink can pass in dblink._display_merge() as a means to redirect output back to the scheduler for appropriate handling when running in the background. svn path=/main/trunk/; revision=11098