#!/usr/bin/python -tt # This program is free software; you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by # the Free Software Foundation; either version 2 of the License, or # (at your option) any later version. # # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU Library General Public License for more details. # # You should have received a copy of the GNU General Public License # along with this program; if not, write to the Free Software # Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. """Classes for handling various callbacks.""" # imports import logging from urlgrabber.progress import BaseMeter,format_time,format_number # ProcessTransaction States PT_DOWNLOAD = 10 # Start Download PT_DOWNLOAD_PKGS = 11 # Packages to download PT_GPGCHECK = 20 # Start Checkin Package Signatures PT_TEST_TRANS = 30 # Start Test Transaction PT_TRANSACTION = 40 # Start Transaction PT_MESSAGES = { PT_DOWNLOAD : "Downloading Packages", PT_GPGCHECK : "Check Package Signatures", PT_TEST_TRANS : "Running Test Transaction", PT_TRANSACTION : "Running Transaction"} class ProcessTransBaseCallback: """A class to handle callbacks from :func:`YumBase.processTransaction`. """ def __init__(self): self.logger = logging.getLogger('yum.verbose.ProcessTrasactionBaseCallback') def event(self,state,data=None): """Handle an event by logging it. :param state: a number indicating the type of callback :param data: data associated with the callback """ if state in PT_MESSAGES.keys(): self.logger.info(PT_MESSAGES[state]) class ProcessTransNoOutputCallback: """A class to handle callbacks from :func:`YumBase.processTransaction`, without logging them. """ def __init__(self): pass def event(self,state,data=None): """Handle an event. :param state: a number indicating the type of callback :param data: data associated with the callback """ pass class DownloadBaseCallback( BaseMeter ): """This is a base class that can be extended to implement a custom download progress handler to be used with :func:`YumBase.repos.setProgressBar`. Example:: from yum.callbacks import DownloadBaseCallback class MyDownloadCallback( DownloadBaseCallback ): def updateProgress(self,name,frac,fread,ftime): ''' Update the progressbar @param name: filename @param frac: Progress fracment (0 -> 1) @param fread: formated string containing BytesRead @param ftime : formated string containing remaining or elapsed time ''' pct = int( frac*100 ) print " %s : %s " % (name,pct) if __name__ == '__main__': my = YumBase() my.doConfigSetup() dnlcb = MyDownloadCallback() my.repos.setProgressBar( dnlcb ) for pkg in my.pkgSack: print pkg.name """ def __init__(self): BaseMeter.__init__( self ) self.totSize = "" # Total size to download in a formatted string (Kb, MB etc) def update( self, amount_read, now=None ): """Update the status bar. :param amount_read: the amount of data, in bytes, that has been read :param now: the current time in seconds since the epoch. If *now* is not given, the output of :func:`time.time()` will be used. """ BaseMeter.update( self, amount_read, now ) def _do_start( self, now=None ): name = self._getName() self.updateProgress(name,0.0,"","") if not self.size is None: self.totSize = format_number( self.size ) def _do_update( self, amount_read, now=None ): fread = format_number( amount_read ) name = self._getName() if self.size is None: # Elapsed time etime = self.re.elapsed_time() fetime = format_time( etime ) frac = 0.0 self.updateProgress(name,frac,fread,fetime) else: # Remaining time rtime = self.re.remaining_time() frtime = format_time( rtime ) frac = self.re.fraction_read() self.updateProgress(name,frac,fread,frtime) def _do_end( self, amount_read, now=None ): total_time = format_time( self.re.elapsed_time() ) total_size = format_number( amount_read ) name = self._getName() self.updateProgress(name,1.0,total_size,total_time) def _getName(self): ''' Get the name of the package being downloaded ''' if self.text and type( self.text ) == type( "" ): name = self.text else: name = self.basename return name def updateProgress(self,name,frac,fread,ftime): """Update the progressbar. This method should be overridden by subclasses to implement the handler. :param name: the name of the filed being downloaded :param frac: number between 0 and 1 representing the fraction fraction of the file that has been downloaded :param fread: formatted string containing the number of bytes read :param ftime: formatted string containing remaining or elapsed time """ pass
Name | Type | Size | Permission | Actions |
---|---|---|---|---|
Errors.py | File | 4.26 KB | 0755 |
|
Errors.pyc | File | 9.08 KB | 0644 |
|
__init__.py | File | 304.1 KB | 0755 |
|
__init__.pyc | File | 199.78 KB | 0644 |
|
callbacks.py | File | 5.64 KB | 0755 |
|
callbacks.pyc | File | 6.23 KB | 0644 |
|
comps.py | File | 31.59 KB | 0755 |
|
comps.pyc | File | 26.87 KB | 0644 |
|
config.py | File | 49.89 KB | 0755 |
|
config.pyc | File | 48.02 KB | 0644 |
|
constants.py | File | 4.52 KB | 0755 |
|
constants.pyc | File | 3.42 KB | 0644 |
|
depsolve.py | File | 74.05 KB | 0755 |
|
depsolve.pyc | File | 46.91 KB | 0644 |
|
drpm.py | File | 12.85 KB | 0755 |
|
drpm.pyc | File | 10.83 KB | 0644 |
|
failover.py | File | 5 KB | 0755 |
|
failover.pyc | File | 5.24 KB | 0644 |
|
fssnapshots.py | File | 10.16 KB | 0755 |
|
fssnapshots.pyc | File | 9.75 KB | 0644 |
|
history.py | File | 61.13 KB | 0755 |
|
history.pyc | File | 53.31 KB | 0644 |
|
i18n.py | File | 20.44 KB | 0755 |
|
i18n.pyc | File | 16.05 KB | 0644 |
|
igroups.py | File | 9.31 KB | 0755 |
|
igroups.pyc | File | 10.22 KB | 0644 |
|
logginglevels.py | File | 7.9 KB | 0755 |
|
logginglevels.pyc | File | 6.51 KB | 0644 |
|
mdparser.py | File | 6.26 KB | 0755 |
|
mdparser.pyc | File | 7.58 KB | 0644 |
|
metalink.py | File | 9.19 KB | 0755 |
|
metalink.pyc | File | 8.84 KB | 0644 |
|
misc.py | File | 39.57 KB | 0755 |
|
misc.pyc | File | 39.58 KB | 0644 |
|
packageSack.py | File | 40.79 KB | 0755 |
|
packageSack.pyc | File | 41.88 KB | 0644 |
|
packages.py | File | 84.1 KB | 0755 |
|
packages.pyc | File | 84.51 KB | 0644 |
|
parser.py | File | 7.97 KB | 0755 |
|
parser.pyc | File | 6.5 KB | 0644 |
|
pgpmsg.py | File | 53.5 KB | 0755 |
|
pgpmsg.pyc | File | 38.27 KB | 0644 |
|
pkgtag_db.py | File | 4.86 KB | 0755 |
|
pkgtag_db.pyc | File | 5.06 KB | 0644 |
|
plugins.py | File | 28.1 KB | 0755 |
|
plugins.pyc | File | 29.1 KB | 0644 |
|
repoMDObject.py | File | 11.23 KB | 0755 |
|
repoMDObject.pyc | File | 9.17 KB | 0644 |
|
repos.py | File | 16.53 KB | 0755 |
|
repos.pyc | File | 17.38 KB | 0644 |
|
rpmsack.py | File | 70.25 KB | 0755 |
|
rpmsack.pyc | File | 58.36 KB | 0644 |
|
rpmtrans.py | File | 24.84 KB | 0755 |
|
rpmtrans.pyc | File | 22.54 KB | 0644 |
|
sqlitesack.py | File | 69.76 KB | 0755 |
|
sqlitesack.pyc | File | 53.75 KB | 0644 |
|
sqlutils.py | File | 6.27 KB | 0755 |
|
sqlutils.pyc | File | 5.6 KB | 0644 |
|
transactioninfo.py | File | 33.78 KB | 0755 |
|
transactioninfo.pyc | File | 30.29 KB | 0644 |
|
update_md.py | File | 25.9 KB | 0755 |
|
update_md.pyc | File | 21.72 KB | 0644 |
|
updateinfo.py | File | 18.29 KB | 0755 |
|
updateinfo.pyc | File | 16.36 KB | 0644 |
|
yumRepo.py | File | 83.85 KB | 0755 |
|
yumRepo.pyc | File | 64.83 KB | 0644 |
|