Support re-using existing destdirs better, with a --force option.
This commit is contained in:
parent
aef1db89aa
commit
6748133646
@ -1,3 +1,7 @@
|
|||||||
|
* Sun Dec 02 Jesse Keating <jkeating@redhat.com>
|
||||||
|
- Add a --force option to reuse an existing destdir
|
||||||
|
- Only overwrite dirs if --force is offered, clean out some specific dirs
|
||||||
|
|
||||||
* Fri Nov 30 2007 Jesse Keating <jkeating@redhat.com>
|
* Fri Nov 30 2007 Jesse Keating <jkeating@redhat.com>
|
||||||
- Only check for root if you're doing root level tasks (buildinstall)
|
- Only check for root if you're doing root level tasks (buildinstall)
|
||||||
|
|
||||||
|
@ -18,7 +18,7 @@ Display program's version number and then quit\&.
|
|||||||
.IP "\fB\-\-name=string\fP"
|
.IP "\fB\-\-name=string\fP"
|
||||||
Set the name for your distribution (defaults to "Fedora")\&.
|
Set the name for your distribution (defaults to "Fedora")\&.
|
||||||
.IP "\fB\-\-ver=string\fP"
|
.IP "\fB\-\-ver=string\fP"
|
||||||
Set the version for your distribution (defaults to datestamp)\&.
|
Set the version for your distribution (defaults to datestamp, used for $releasever in yum)\&.
|
||||||
.IP "\fB\-\-flavor=string\fP"
|
.IP "\fB\-\-flavor=string\fP"
|
||||||
Set the flavor of your spin (optional)\&.
|
Set the flavor of your spin (optional)\&.
|
||||||
.IP "\fB\-\-destdir=pathspec\fP"
|
.IP "\fB\-\-destdir=pathspec\fP"
|
||||||
@ -34,6 +34,8 @@ Disable gathering of source packages (optional)\&.
|
|||||||
.IP "\fB\-\-nosplitmedia\fP"
|
.IP "\fB\-\-nosplitmedia\fP"
|
||||||
Disable creation of split media (optional)\&.
|
Disable creation of split media (optional)\&.
|
||||||
.IP "\fB\-\-sourceisos\fP"
|
.IP "\fB\-\-sourceisos\fP"
|
||||||
|
Force reuse of an existing destination directory (will overwrite files)\&.
|
||||||
|
.IP "\fB\-\-force\fP"
|
||||||
Create the source media images (other arch runs must be done)\&.
|
Create the source media images (other arch runs must be done)\&.
|
||||||
.IP "\fB\-c ksfile, \-\-config=ksfile\fP"
|
.IP "\fB\-c ksfile, \-\-config=ksfile\fP"
|
||||||
Path to kickstart configuration file\&.
|
Path to kickstart configuration file\&.
|
||||||
|
6
pungi
6
pungi
@ -41,6 +41,8 @@ def main():
|
|||||||
for part in ksparser.handler.partition.partitions:
|
for part in ksparser.handler.partition.partitions:
|
||||||
if part.mountpoint == 'iso':
|
if part.mountpoint == 'iso':
|
||||||
config.set('default', 'cdsize', str(part.size))
|
config.set('default', 'cdsize', str(part.size))
|
||||||
|
|
||||||
|
config.set('default', 'force', opts.force)
|
||||||
|
|
||||||
# Set up our directories
|
# Set up our directories
|
||||||
if not os.path.exists(config.get('default', 'destdir')):
|
if not os.path.exists(config.get('default', 'destdir')):
|
||||||
@ -49,6 +51,8 @@ def main():
|
|||||||
except OSError, e:
|
except OSError, e:
|
||||||
print >> sys.stderr, "Error: Cannot create destination dir %s" % config.get('default', 'destdir')
|
print >> sys.stderr, "Error: Cannot create destination dir %s" % config.get('default', 'destdir')
|
||||||
sys.exit(1)
|
sys.exit(1)
|
||||||
|
else:
|
||||||
|
print >> sys.stdout, "Warning: Reusing existing destination directory."
|
||||||
|
|
||||||
cachedir = config.get('default', 'cachedir')
|
cachedir = config.get('default', 'cachedir')
|
||||||
|
|
||||||
@ -138,6 +142,8 @@ if __name__ == '__main__':
|
|||||||
help='disable creation of split media (optional)')
|
help='disable creation of split media (optional)')
|
||||||
parser.add_option("--sourceisos", default=False, action="store_true", dest="sourceisos",
|
parser.add_option("--sourceisos", default=False, action="store_true", dest="sourceisos",
|
||||||
help='Create the source isos (other arch runs must be done)')
|
help='Create the source isos (other arch runs must be done)')
|
||||||
|
parser.add_option("--force", default=False, action="store_true",
|
||||||
|
help='Force reuse of an existing destination directory (will overwrite files)')
|
||||||
|
|
||||||
parser.add_option("-c", "--config", dest="config",
|
parser.add_option("-c", "--config", dest="config",
|
||||||
help='Path to kickstart config file')
|
help='Path to kickstart config file')
|
||||||
|
@ -16,6 +16,7 @@ import logging
|
|||||||
import os
|
import os
|
||||||
import subprocess
|
import subprocess
|
||||||
import shutil
|
import shutil
|
||||||
|
import sys
|
||||||
|
|
||||||
class PungiBase(object):
|
class PungiBase(object):
|
||||||
"""The base Pungi class. Set up config items and logging here"""
|
"""The base Pungi class. Set up config items and logging here"""
|
||||||
@ -37,8 +38,7 @@ class PungiBase(object):
|
|||||||
|
|
||||||
logdir = os.path.join(self.config.get('default', 'destdir'), 'logs')
|
logdir = os.path.join(self.config.get('default', 'destdir'), 'logs')
|
||||||
|
|
||||||
if not os.path.exists(logdir):
|
_ensuredir(logdir, force=True) # Always allow logs to be written out
|
||||||
os.makedirs(logdir)
|
|
||||||
|
|
||||||
if self.config.get('default', 'flavor'):
|
if self.config.get('default', 'flavor'):
|
||||||
logfile = os.path.join(logdir, '%s.%s.log' % (self.config.get('default', 'flavor'),
|
logfile = os.path.join(logdir, '%s.%s.log' % (self.config.get('default', 'flavor'),
|
||||||
@ -85,3 +85,25 @@ def _link(local, target, force=False):
|
|||||||
# Can't hardlink cross file systems
|
# Can't hardlink cross file systems
|
||||||
shutil.copy2(local, target)
|
shutil.copy2(local, target)
|
||||||
|
|
||||||
|
def _ensuredir(target, force=False, clean=False):
|
||||||
|
"""Ensure that a directory exists, if it already exists, only continue
|
||||||
|
if force is set."""
|
||||||
|
|
||||||
|
def whoops(func, path, exc_info):
|
||||||
|
self.logger.error('Could not remove %s' % path)
|
||||||
|
sys.exit(1)
|
||||||
|
|
||||||
|
if os.path.exists(target) and not os.path.isdir(target):
|
||||||
|
self.logger.error('%s exists but is not a directory.' % target)
|
||||||
|
sys.exit(1)
|
||||||
|
|
||||||
|
if not os.path.isdir(target):
|
||||||
|
os.makedirs(target)
|
||||||
|
elif force and clean:
|
||||||
|
shutil.rmtree(target, onerror=whoops)
|
||||||
|
os.makedirs(target)
|
||||||
|
elif force:
|
||||||
|
return
|
||||||
|
else:
|
||||||
|
self.logger.error('Directory %s already exists. Use --force to overwrite.' % target)
|
||||||
|
sys.exit(1)
|
@ -46,6 +46,7 @@ class PungiYum(yum.YumBase):
|
|||||||
logfile = os.path.join(logdir, '%s.log' % (self.pungiconfig.get('default', 'arch')))
|
logfile = os.path.join(logdir, '%s.log' % (self.pungiconfig.get('default', 'arch')))
|
||||||
|
|
||||||
yum.logging.basicConfig(level=yum.logging.DEBUG, filename=logfile)
|
yum.logging.basicConfig(level=yum.logging.DEBUG, filename=logfile)
|
||||||
|
self.logger.error('foobar')
|
||||||
|
|
||||||
def doFileLogSetup(self, uid, logfile):
|
def doFileLogSetup(self, uid, logfile):
|
||||||
# This function overrides a yum function, allowing pungi to control
|
# This function overrides a yum function, allowing pungi to control
|
||||||
@ -320,8 +321,8 @@ class Gather(pypungi.PungiBase):
|
|||||||
self.config.get('default', 'flavor'),
|
self.config.get('default', 'flavor'),
|
||||||
relpkgdir)
|
relpkgdir)
|
||||||
|
|
||||||
if not os.path.exists(pkgdir):
|
# Ensure the pkgdir exists, force if requested, and make sure we clean it out
|
||||||
os.makedirs(pkgdir)
|
pypungi._ensuredir(pkgdir, force=self.config.getbool('default', 'force'), clean=True)
|
||||||
|
|
||||||
probs = self.ayum.downloadPkgs(polist)
|
probs = self.ayum.downloadPkgs(polist)
|
||||||
|
|
||||||
|
@ -44,8 +44,7 @@ class Pungi(pypungi.PungiBase):
|
|||||||
self.topdir = os.path.join(self.archdir, 'os')
|
self.topdir = os.path.join(self.archdir, 'os')
|
||||||
self.isodir = os.path.join(self.archdir, self.config.get('default','isodir'))
|
self.isodir = os.path.join(self.archdir, self.config.get('default','isodir'))
|
||||||
|
|
||||||
if not os.path.exists(self.workdir):
|
pypungi._ensuredir(workdir, force=self.config.getbool('default', 'force'))
|
||||||
os.makedirs(self.workdir)
|
|
||||||
|
|
||||||
self.common_files = []
|
self.common_files = []
|
||||||
self.infofile = os.path.join(self.config.get('default', 'destdir'),
|
self.infofile = os.path.join(self.config.get('default', 'destdir'),
|
||||||
@ -174,7 +173,7 @@ class Pungi(pypungi.PungiBase):
|
|||||||
for pattern in self.config.get('default', 'relnotedirre').split():
|
for pattern in self.config.get('default', 'relnotedirre').split():
|
||||||
dirres.append(re.compile(pattern))
|
dirres.append(re.compile(pattern))
|
||||||
|
|
||||||
os.makedirs(docsdir)
|
pypungi._ensuredir(docsdir, force=self.config.getbool('default', 'force'), clean=True)
|
||||||
|
|
||||||
# Expload the packages we list as relnote packages
|
# Expload the packages we list as relnote packages
|
||||||
pkgs = os.listdir(os.path.join(self.topdir, self.config.get('default', 'product_path')))
|
pkgs = os.listdir(os.path.join(self.topdir, self.config.get('default', 'product_path')))
|
||||||
@ -269,7 +268,9 @@ class Pungi(pypungi.PungiBase):
|
|||||||
|
|
||||||
# this is stolen from splittree.py in anaconda-runtime. Blame them if its ugly (:
|
# this is stolen from splittree.py in anaconda-runtime. Blame them if its ugly (:
|
||||||
for i in range(timber.src_list[0], timber.src_list[-1] + 1):
|
for i in range(timber.src_list[0], timber.src_list[-1] + 1):
|
||||||
os.makedirs("%s-disc%d/SRPMS" % (timber.dist_dir, i))
|
pypungi._ensuredir('%s-disc%d/SRPMS' % (timper.dist_dir, i),
|
||||||
|
force=self.config.getbool('default', 'force'),
|
||||||
|
clean=True)
|
||||||
timber.linkFiles(timber.dist_dir,
|
timber.linkFiles(timber.dist_dir,
|
||||||
"%s-disc%d" %(timber.dist_dir, i),
|
"%s-disc%d" %(timber.dist_dir, i),
|
||||||
timber.common_files)
|
timber.common_files)
|
||||||
@ -303,7 +304,8 @@ class Pungi(pypungi.PungiBase):
|
|||||||
|
|
||||||
createrepo.append('--outputdir')
|
createrepo.append('--outputdir')
|
||||||
if self.config.getint('default', 'discs') == 1:
|
if self.config.getint('default', 'discs') == 1:
|
||||||
os.makedirs('%s-disc1' % self.topdir) # rename this for single disc
|
pypungi._ensuredir('%s-disc1', force=self.config.getbool('default', 'force'),
|
||||||
|
clean=True) # rename this for single disc
|
||||||
createrepo.append('%s-disc1' % self.topdir)
|
createrepo.append('%s-disc1' % self.topdir)
|
||||||
|
|
||||||
createrepo.append('--basedir')
|
createrepo.append('--basedir')
|
||||||
@ -344,7 +346,8 @@ cost=500
|
|||||||
anaruntime = '/usr/lib/anaconda-runtime/boot'
|
anaruntime = '/usr/lib/anaconda-runtime/boot'
|
||||||
discinfofile = os.path.join(self.topdir, '.discinfo') # we use this a fair amount
|
discinfofile = os.path.join(self.topdir, '.discinfo') # we use this a fair amount
|
||||||
|
|
||||||
os.makedirs(self.isodir)
|
pypungi._ensuredir(self.isodir, force=self.config.getbool('default', 'force'),
|
||||||
|
clean=True) # This is risky...
|
||||||
|
|
||||||
# setup the base command
|
# setup the base command
|
||||||
mkisofs = ['/usr/bin/mkisofs']
|
mkisofs = ['/usr/bin/mkisofs']
|
||||||
|
Loading…
Reference in New Issue
Block a user