diff options
author | Sol Jerome <sol.jerome@gmail.com> | 2012-03-24 11:20:07 -0500 |
---|---|---|
committer | Sol Jerome <sol.jerome@gmail.com> | 2012-03-24 11:20:07 -0500 |
commit | dab1d03d81c538966d03fb9318a4588a9e803b44 (patch) | |
tree | f51e27fa55887e9fb961766805fe43f0da56c5b9 /src/lib/Client/Tools/Pacman.py | |
parent | 5cd6238df496a3cea178e4596ecd87967cce1ce6 (diff) | |
download | bcfg2-dab1d03d81c538966d03fb9318a4588a9e803b44.tar.gz bcfg2-dab1d03d81c538966d03fb9318a4588a9e803b44.tar.bz2 bcfg2-dab1d03d81c538966d03fb9318a4588a9e803b44.zip |
Allow to run directly from a git checkout (#1037)
Signed-off-by: Sol Jerome <sol.jerome@gmail.com>
Diffstat (limited to 'src/lib/Client/Tools/Pacman.py')
-rw-r--r-- | src/lib/Client/Tools/Pacman.py | 83 |
1 files changed, 0 insertions, 83 deletions
diff --git a/src/lib/Client/Tools/Pacman.py b/src/lib/Client/Tools/Pacman.py deleted file mode 100644 index c8c05061c..000000000 --- a/src/lib/Client/Tools/Pacman.py +++ /dev/null @@ -1,83 +0,0 @@ -"""This is the bcfg2 support for pacman""" - -import Bcfg2.Client.Tools - - -class Pacman(Bcfg2.Client.Tools.PkgTool): - '''Archlinux package support''' - name = 'Pacman' - __execs__ = ["/usr/bin/pacman"] - __handles__ = [('Package', 'pacman')] - __req__ = {'Package': ['name', 'version']} - pkgtype = 'pacman' - pkgtool = ("/usr/bin/pacman --needed --noconfirm --noprogressbar") - - def __init__(self, logger, setup, config): - Bcfg2.Client.Tools.PkgTool.__init__(self, logger, setup, config) - self.installed = {} - self.RefreshPackages() - - def RefreshPackages(self): - '''Refresh memory hashes of packages''' - pkgcache = self.cmd.run("/usr/bin/pacman -Q")[1] - self.installed = {} - for pkg in pkgcache: - pkgname = pkg.split(' ')[0].strip() - version = pkg.split(' ')[1].strip() - #self.logger.info(" pkgname: %s, version: %s" % (pkgname, version)) - self.installed[pkgname] = version - - def VerifyPackage(self, entry, modlist): - '''Verify Package status for entry''' - - self.logger.info("VerifyPackage : %s : %s" % entry.get('name'), - entry.get('version')) - - if not 'version' in entry.attrib: - self.logger.info("Cannot verify unversioned package %s" % - (entry.attrib['name'])) - return False - - if entry.attrib['name'] in self.installed: - if entry.attrib['version'] == 'auto': - return True - elif self.installed[entry.attrib['name']] == entry.attrib['version']: - #if not self.setup['quick'] and \ - # entry.get('verify', 'true') == 'true': - #FIXME: need to figure out if pacman - # allows you to verify packages - return True - else: - entry.set('current_version', self.installed[entry.get('name')]) - self.logger.info("attribname: %s" % (entry.attrib['name'])) - self.logger.info("attribname: %s" % (entry.attrib['name'])) - return False - entry.set('current_exists', 'false') - self.logger.info("attribname: %s" % (entry.attrib['name'])) - return False - - def RemovePackages(self, packages): - '''Remove extra packages''' - names = [pkg.get('name') for pkg in packages] - self.logger.info("Removing packages: %s" % " ".join(names)) - self.cmd.run("%s --noconfirm --noprogressbar -R %s" % \ - (self.pkgtool, " ".join(names))) - self.RefreshPackages() - self.extra = self.FindExtraPackages() - - def Install(self, packages, states): - ''' - Pacman Install - ''' - pkgline = "" - for pkg in packages: - pkgline += " " + pkg.get('name') - - self.logger.info("packages : " + pkgline) - - try: - self.logger.debug("Running : %s -S %s" % (self.pkgtool, pkgline)) - self.cmd.run("%s -S %s" % (self.pkgtool, pkgline)) - except Exception: - e = sys.exc_info()[1] - self.logger.error("Error occurred during installation: %s" % e) |