|
|
d2a170 |
commit 22271bf34e71bbfc75d0a59354fc0108e004f36c
|
|
|
d2a170 |
Author: James Antill <james@and.org>
|
|
|
d2a170 |
Date: Mon Jun 9 16:09:32 2014 -0400
|
|
|
d2a170 |
|
|
|
d2a170 |
Read FS yumvars before yum.conf setup, and reread if installroot changed.
|
|
|
d2a170 |
|
|
|
d2a170 |
diff --git a/yum/config.py b/yum/config.py
|
|
|
d2a170 |
index 6e0ecdc..1b5a11d 100644
|
|
|
d2a170 |
--- a/yum/config.py
|
|
|
d2a170 |
+++ b/yum/config.py
|
|
|
d2a170 |
@@ -1022,6 +1022,23 @@ class VersionGroupConf(BaseConfig):
|
|
|
d2a170 |
pkglist = ListOption()
|
|
|
d2a170 |
run_with_packages = BoolOption(False)
|
|
|
d2a170 |
|
|
|
d2a170 |
+def _read_yumvars(yumvars, root):
|
|
|
d2a170 |
+ # Read the FS yumvars
|
|
|
d2a170 |
+ try:
|
|
|
d2a170 |
+ dir_fsvars = root + "/etc/yum/vars/"
|
|
|
d2a170 |
+ fsvars = os.listdir(dir_fsvars)
|
|
|
d2a170 |
+ except OSError:
|
|
|
d2a170 |
+ fsvars = []
|
|
|
d2a170 |
+ for fsvar in fsvars:
|
|
|
d2a170 |
+ if os.path.islink(dir_fsvars + fsvar):
|
|
|
d2a170 |
+ continue
|
|
|
d2a170 |
+ try:
|
|
|
d2a170 |
+ val = open(dir_fsvars + fsvar).readline()
|
|
|
d2a170 |
+ if val and val[-1] == '\n':
|
|
|
d2a170 |
+ val = val[:-1]
|
|
|
d2a170 |
+ except (OSError, IOError):
|
|
|
d2a170 |
+ continue
|
|
|
d2a170 |
+ yumvars[fsvar] = val
|
|
|
d2a170 |
|
|
|
d2a170 |
def readStartupConfig(configfile, root, releasever=None):
|
|
|
d2a170 |
"""Parse Yum's main configuration file and return a
|
|
|
d2a170 |
@@ -1044,6 +1061,7 @@ def readStartupConfig(configfile, root, releasever=None):
|
|
|
d2a170 |
confpp_obj = ConfigPreProcessor(configfile)
|
|
|
d2a170 |
|
|
|
d2a170 |
yumvars = _getEnvVar()
|
|
|
d2a170 |
+ _read_yumvars(yumvars, yumconf.installroot)
|
|
|
d2a170 |
confpp_obj._vars = yumvars
|
|
|
d2a170 |
startupconf.yumvars = yumvars
|
|
|
d2a170 |
|
|
|
d2a170 |
@@ -1102,22 +1120,12 @@ def readMainConfig(startupconf):
|
|
|
d2a170 |
ir_path = varReplace(ir_path, yumvars)
|
|
|
d2a170 |
setattr(yumconf, option, ir_path)
|
|
|
d2a170 |
|
|
|
d2a170 |
- # Read the FS yumvars
|
|
|
d2a170 |
- try:
|
|
|
d2a170 |
- dir_fsvars = yumconf.installroot + "/etc/yum/vars/"
|
|
|
d2a170 |
- fsvars = os.listdir(dir_fsvars)
|
|
|
d2a170 |
- except OSError:
|
|
|
d2a170 |
- fsvars = []
|
|
|
d2a170 |
- for fsvar in fsvars:
|
|
|
d2a170 |
- if os.path.islink(dir_fsvars + fsvar):
|
|
|
d2a170 |
- continue
|
|
|
d2a170 |
- try:
|
|
|
d2a170 |
- val = open(dir_fsvars + fsvar).readline()
|
|
|
d2a170 |
- if val and val[-1] == '\n':
|
|
|
d2a170 |
- val = val[:-1]
|
|
|
d2a170 |
- except (OSError, IOError):
|
|
|
d2a170 |
- continue
|
|
|
d2a170 |
- yumvars[fsvar] = val
|
|
|
d2a170 |
+ if StartupConf.installroot.default != yumconf.installroot:
|
|
|
d2a170 |
+ # Note that this isn't perfect, in that if the initial installroot has
|
|
|
d2a170 |
+ # X=Y, and X doesn't exist in the new installroot ... then we'll still
|
|
|
d2a170 |
+ # have X afterwards (but if the new installroot has X=Z, that will be
|
|
|
d2a170 |
+ # the value after this).
|
|
|
d2a170 |
+ _read_yumvars(yumvars, yumconf.installroot)
|
|
|
d2a170 |
|
|
|
d2a170 |
# These can use the above FS yumvars
|
|
|
d2a170 |
for option in ('cachedir', 'logfile', 'persistdir'):
|
|
|
d2a170 |
commit 1ccd91f4b195737d6bb1bdfabcbf3714de1d9b85
|
|
|
d2a170 |
Author: James Antill <james@and.org>
|
|
|
d2a170 |
Date: Mon Jun 16 15:16:25 2014 -0400
|
|
|
d2a170 |
|
|
|
d2a170 |
Fix merge typo. with FS vars. before yum.conf
|
|
|
d2a170 |
|
|
|
d2a170 |
diff --git a/yum/config.py b/yum/config.py
|
|
|
d2a170 |
index 1b5a11d..8eab5bc 100644
|
|
|
d2a170 |
--- a/yum/config.py
|
|
|
d2a170 |
+++ b/yum/config.py
|
|
|
d2a170 |
@@ -1061,7 +1061,7 @@ def readStartupConfig(configfile, root, releasever=None):
|
|
|
d2a170 |
confpp_obj = ConfigPreProcessor(configfile)
|
|
|
d2a170 |
|
|
|
d2a170 |
yumvars = _getEnvVar()
|
|
|
d2a170 |
- _read_yumvars(yumvars, yumconf.installroot)
|
|
|
d2a170 |
+ _read_yumvars(yumvars, startupconf.installroot)
|
|
|
d2a170 |
confpp_obj._vars = yumvars
|
|
|
d2a170 |
startupconf.yumvars = yumvars
|
|
|
d2a170 |
|
|
|
d2a170 |
commit 6148c8a10b22763592c141ce9ee6d85dce5816f7
|
|
|
d2a170 |
Author: Michal Domonkos <mdomonko@redhat.com>
|
|
|
d2a170 |
Date: Thu Apr 21 16:08:19 2016 +0200
|
|
|
d2a170 |
|
|
|
d2a170 |
Honor FS yumvars over defaults for special vars. BZ 1327561
|
|
|
d2a170 |
|
|
|
d2a170 |
This fixes up commit 22271bf, which caused FS yumvars like $releasever
|
|
|
d2a170 |
to be unintentionally replaced by the default values (unless the
|
|
|
d2a170 |
installroot was redefined by yumconf, which caused us to reread them).
|
|
|
d2a170 |
|
|
|
d2a170 |
diff --git a/yum/config.py b/yum/config.py
|
|
|
d2a170 |
index 954700b..2ef5fa4 100644
|
|
|
d2a170 |
--- a/yum/config.py
|
|
|
d2a170 |
+++ b/yum/config.py
|
|
|
d2a170 |
@@ -1114,12 +1114,12 @@ def readMainConfig(startupconf):
|
|
|
d2a170 |
|
|
|
d2a170 |
# ' xemacs syntax hack
|
|
|
d2a170 |
|
|
|
d2a170 |
- # Set up substitution vars
|
|
|
d2a170 |
+ # Set up substitution vars but make sure we always prefer FS yumvars
|
|
|
d2a170 |
yumvars = startupconf.yumvars
|
|
|
d2a170 |
- yumvars['basearch'] = startupconf.basearch
|
|
|
d2a170 |
- yumvars['arch'] = startupconf.arch
|
|
|
d2a170 |
- yumvars['releasever'] = startupconf.releasever
|
|
|
d2a170 |
- yumvars['uuid'] = startupconf.uuid
|
|
|
d2a170 |
+ yumvars.setdefault('basearch', startupconf.basearch)
|
|
|
d2a170 |
+ yumvars.setdefault('arch', startupconf.arch)
|
|
|
d2a170 |
+ yumvars.setdefault('releasever', startupconf.releasever)
|
|
|
d2a170 |
+ yumvars.setdefault('uuid', startupconf.uuid)
|
|
|
d2a170 |
# Note: We don't setup the FS yumvars here, because we want to be able to
|
|
|
d2a170 |
# use the core yumvars in persistdir. Which is the base of FS yumvars.
|
|
|
d2a170 |
|
|
|
d2a170 |
commit 1897df3c1477afd8f221833120092f35c26f5a9d
|
|
|
d2a170 |
Author: Michal Domonkos <mdomonko@redhat.com>
|
|
|
d2a170 |
Date: Thu Apr 21 16:23:47 2016 +0200
|
|
|
d2a170 |
|
|
|
d2a170 |
Cosmetic: remove outdated comment
|
|
|
d2a170 |
|
|
|
d2a170 |
It was no longer true after commit ade6d16.
|
|
|
d2a170 |
|
|
|
d2a170 |
diff --git a/yum/config.py b/yum/config.py
|
|
|
d2a170 |
index 2ef5fa4..84be564 100644
|
|
|
d2a170 |
--- a/yum/config.py
|
|
|
d2a170 |
+++ b/yum/config.py
|
|
|
d2a170 |
@@ -1120,8 +1120,6 @@ def readMainConfig(startupconf):
|
|
|
d2a170 |
yumvars.setdefault('arch', startupconf.arch)
|
|
|
d2a170 |
yumvars.setdefault('releasever', startupconf.releasever)
|
|
|
d2a170 |
yumvars.setdefault('uuid', startupconf.uuid)
|
|
|
d2a170 |
- # Note: We don't setup the FS yumvars here, because we want to be able to
|
|
|
d2a170 |
- # use the core yumvars in persistdir. Which is the base of FS yumvars.
|
|
|
d2a170 |
|
|
|
d2a170 |
# Read [main] section
|
|
|
d2a170 |
yumconf = YumConf()
|