+++ /dev/null
---- yum-2.3.2/docs/yum.conf.5.chroot 2005-03-25 11:12:20.000000000 +0100
-+++ yum-2.3.2/docs/yum.conf.5 2005-04-08 18:27:12.000000000 +0200
-@@ -23,8 +23,10 @@
- following options:
-
- .IP \fBcachedir\fR
--Directory where yum should store its cache and db files. The default is
--`/var/cache/yum'.
-+Directory where yum should store its cache and db files. The default
-+is `/var/cache/yum'. Unless the prefixes `hostfs://' or `chrootfs://'
-+are used, some magic will be applied to determine the real path in
-+combination with `--installroot'.
-
- .IP \fBreposdir\fR
- A list of directories where yum should look for .repo files which define
-@@ -34,6 +36,10 @@
- repositories defined in /etc/yum.conf to form the complete set of repositories
- that yum will use.
-
-+Unless the prefixes `hostfs://' or `chrootfs://' are used, some magic
-+will be applied to determine the real path in combination with
-+`--installroot'.
-+
- .IP \fBdebuglevel\fR
- Debug message output level. Practical range is 0\-10. Default is `2'.
-
-@@ -41,7 +47,10 @@
- Error message output level. Practical range is 0\-10. Default is `2'.
-
- .IP \fBlogfile\fR
--Full directory and file name for where yum should write its log file.
-+Full directory and file name for where yum should write its log
-+file. Unless the prefixes `hostfs://' or `chrootfs://' are used,
-+some magic will be applied to determine the real path in combination
-+with `--installroot'.
-
- .IP \fBgpgcheck\fR
- Either `1' or `0'. This tells yum whether or not it should perform a GPG
---- yum-2.3.2/yum/__init__.py.chroot 2005-04-04 20:14:18.000000000 +0200
-+++ yum-2.3.2/yum/__init__.py 2005-04-08 20:11:06.000000000 +0200
-@@ -97,9 +97,8 @@
- # read each of them in using confpp, then parse them same as any other repo
- # section - as above.
- for reposdir in self.conf.reposdir:
-- if os.path.exists(self.conf.installroot + '/' + reposdir):
-- reposdir = self.conf.installroot + '/' + reposdir
--
-+ reposdir = self.conf.getRootedPath(reposdir)
-+
- if os.path.isdir(reposdir):
- repofn = glob.glob(reposdir+'/*.repo')
- repofn.sort()
-@@ -405,17 +404,20 @@
- self.pkgSack.excludeArchs(archlist)
- self.log(3, 'Finished')
-
-+ def __getLockfileName(self):
-+ lockfile = self.conf.configdata['lockfile']
-+ return self.conf.getRootedPath(lockfile,
-+ enforce_default = True,
-+ defaults_to_host = False)
-
--
-- def doLock(self, lockfile):
-+ def doLock(self):
- """perform the yum locking, raise yum-based exceptions, not OSErrors"""
-
- # if we're not root then we don't lock - just return nicely
- if self.conf.getConfigOption('uid') != 0:
- return
--
-- root = self.conf.installroot
-- lockfile = root + '/' + lockfile # lock in the chroot
-+
-+ lockfile=self.__getLockfileName()
-
- mypid=str(os.getpid())
- while not self._lock(lockfile, mypid, 0644):
-@@ -439,15 +441,14 @@
- msg = 'Existing lock %s: another copy is running. Aborting.' % lockfile
- raise Errors.LockError(0, msg)
-
-- def doUnlock(self, lockfile):
-+ def doUnlock(self):
- """do the unlock for yum"""
-
- # if we're not root then we don't lock - just return nicely
- if self.conf.getConfigOption('uid') != 0:
- return
-
-- root = self.conf.installroot
-- lockfile = root + '/' + lockfile # lock in the chroot
-+ lockfile=self.__getLockfileName()
-
- self._unlock(lockfile)
-
---- yum-2.3.2/yum/config.py.chroot 2005-03-28 00:01:22.000000000 +0200
-+++ yum-2.3.2/yum/config.py 2005-04-08 20:09:25.000000000 +0200
-@@ -193,7 +193,8 @@
-
- #defaults -either get them or set them
- optionstrings = [('cachedir', '/var/cache/yum'),
-- ('logfile', '/var/log/yum.log'),
-+ ('logfile', '/var/log/yum.log'),
-+ ('lockfile', '/var/run/yum.pid'),
- ('reposdir', ['/etc/yum/repos.d', '/etc/yum.repos.d']),
- ('syslog_ident', None),
- ('syslog_facility', 'LOG_USER'),
-@@ -304,9 +305,7 @@
-
- # do the dirs - set the root if there is one (grumble)
- for option in ['cachedir', 'logfile']:
-- path = self.configdata[option]
-- root = self.configdata['installroot']
-- rootedpath = root + path
-+ rootedpath = self.getRootedPath(self.configdata[option])
- self.configdata[option] = rootedpath
- setattr(self, option, rootedpath)
-
-@@ -339,6 +338,23 @@
- "All plugin search paths must be absolute")
-
-
-+ def getRootedPath(self, path, enforce_default=False, defaults_to_host=False):
-+ instroot = self.configdata['installroot']
-+ if path.startswith('hostfs://'): res = path[9:]
-+ elif path.startswith('chrootfs://'): res = instroot + '/' + path[11:]
-+ else:
-+ tmp = instroot + '/' +path
-+
-+ if enforce_default:
-+ if defaults_to_host: res = path
-+ else: res = tmp
-+ else:
-+ if os.path.exists(tmp): res = tmp
-+ elif defaults_to_host: res = path
-+ else: res = tmp
-+
-+ return res
-+
- def listConfigOptions(self):
- """return list of options available for global config"""
- return self.configdata.keys()
-@@ -717,9 +733,7 @@
- # read each of them in using confpp, then parse them same as any other repo
- # section - as above.
-
-- reposdir = conf.reposdir
-- if os.path.exists(conf.installroot + '/' + reposdir):
-- reposdir = conf.installroot + '/' + reposdir
-+ reposdir = conf.getRootedPath(conf.reposdir)
-
- reposglob = reposdir + '/*.repo'
- if os.path.exists(reposdir) and os.path.isdir(reposdir):
---- yum-2.3.2/cli.py.chroot 2005-03-28 05:18:03.000000000 +0200
-+++ yum-2.3.2/cli.py 2005-04-08 18:27:12.000000000 +0200
-@@ -115,7 +115,7 @@
- sleeptime=0
- root = '/'
- installroot = None
-- conffile = '/etc/yum.conf'
-+ conffile = None
-
- try:
- for o,a in gopts:
-@@ -129,12 +129,14 @@
-
- # if the conf file is inside the installroot - use that.
- # otherwise look for it in the normal root
-+ if conffile==None:
-+ conffile = '/etc/yum.conf'
-+ if installroot and os.access(installroot + '/' + conffile, os.R_OK):
-+ conffile = installroot + '/' + conffile
-+
- if installroot:
-- if os.access(installroot + '/' + conffile, os.R_OK):
-- conffile = installroot + '/' + conffile
--
-- root = installroot
--
-+ root = installroot
-+
- try:
- self.doConfigSetup(fn = conffile, root = root)
- except yum.Errors.ConfigError, e:
---- yum-2.3.2/yummain.py.chroot 2005-03-27 07:39:17.000000000 +0200
-+++ yum-2.3.2/yummain.py 2005-04-08 18:27:12.000000000 +0200
-@@ -41,7 +41,7 @@
- def unlock():
- try:
- base.closeRpmDB()
-- base.doUnlock('/var/run/yum.pid')
-+ base.doUnlock()
- except Errors.LockError, e:
- sys.exit(200)
-
-@@ -58,7 +58,7 @@
- sys.exit(1)
-
- try:
-- base.doLock('/var/run/yum.pid')
-+ base.doLock()
- except Errors.LockError, e:
- base.errorlog(0,'%s' % e.msg)
- sys.exit(200)