2 # Chris Lumens <clumens@redhat.com>
4 # Copyright 2006, 2007, 2008, 2009, 2010, 2012, 2013 Red Hat, Inc.
6 # This copyrighted material is made available to anyone wishing to use, modify,
7 # copy, or redistribute it subject to the terms and conditions of the GNU
8 # General Public License v.2. This program is distributed in the hope that it
9 # will be useful, but WITHOUT ANY WARRANTY expressed or implied, including the
10 # implied warranties of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
11 # See the GNU General Public License for more details.
13 # You should have received a copy of the GNU General Public License along with
14 # this program; if not, write to the Free Software Foundation, Inc., 51
15 # Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. Any Red Hat
16 # trademarks that are incorporated in the source code or documentation are not
17 # subject to the GNU General Public License and may only be used or replicated
18 # with the express permission of Red Hat, Inc.
21 Methods for working with kickstart versions.
23 This module defines several symbolic constants that specify kickstart syntax
24 versions. Each version corresponds roughly to one release of Red Hat Linux,
25 Red Hat Enterprise Linux, or Fedora Core as these are where most syntax
28 This module also exports several functions:
30 makeVersion - Given a version number, return an instance of the
31 matching handler class.
33 returnClassForVersion - Given a version number, return the matching
34 handler class. This does not return an
35 instance of that class, however.
37 stringToVersion - Convert a string representation of a version number
38 into the symbolic constant.
40 versionToString - Perform the reverse mapping.
42 versionFromFile - Read a kickstart file and determine the version of
43 syntax it uses. This requires the kickstart file to
44 have a version= comment in it.
46 import imputil
, re
, sys
47 from urlgrabber
import urlopen
50 _
= lambda x
: gettext
.ldgettext("pykickstart", x
)
52 from pykickstart
.errors
import KickstartVersionError
54 # Symbolic names for internal version numbers.
79 # This always points at the latest version and is the default.
82 # A one-to-one mapping from string representations to version numbers.
85 "FC3": FC3
, "FC4": FC4
, "FC5": FC5
, "FC6": FC6
, "F7": F7
, "F8": F8
,
86 "F9": F9
, "F10": F10
, "F11": F11
, "F12": F12
, "F13": F13
,
87 "F14": F14
, "F15": F15
, "F16": F16
, "F17": F17
, "F18": F18
,
88 "F19": F19
, "F20": F20
,
89 "RHEL3": RHEL3
, "RHEL4": RHEL4
, "RHEL5": RHEL5
, "RHEL6": RHEL6
,
93 def stringToVersion(s
):
94 """Convert string into one of the provided version constants. Raises
95 KickstartVersionError if string does not match anything.
97 # First try these short forms.
99 return versionMap
[s
.upper()]
103 # Now try the Fedora versions.
104 m
= re
.match(r
"^fedora.* (\d+)$", s
, re
.I
)
107 if versionMap
.has_key("FC" + m
.group(1)):
108 return versionMap
["FC" + m
.group(1)]
109 elif versionMap
.has_key("F" + m
.group(1)):
110 return versionMap
["F" + m
.group(1)]
112 raise KickstartVersionError(_("Unsupported version specified: %s") % s
)
114 # Now try the RHEL versions.
115 m
= re
.match(r
"^red hat enterprise linux.* (\d+)([\.\d]*)$", s
, re
.I
)
118 if versionMap
.has_key("RHEL" + m
.group(1)):
119 return versionMap
["RHEL" + m
.group(1)]
121 raise KickstartVersionError(_("Unsupported version specified: %s") % s
)
123 # If nothing else worked, we're out of options.
124 raise KickstartVersionError(_("Unsupported version specified: %s") % s
)
126 def versionToString(version
, skipDevel
=False):
127 """Convert version into a string representation of the version number.
128 This is the reverse operation of stringToVersion. Raises
129 KickstartVersionError if version does not match anything.
131 if not skipDevel
and version
== versionMap
["DEVEL"]:
134 for (key
, val
) in versionMap
.iteritems():
140 raise KickstartVersionError(_("Unsupported version specified: %s") % version
)
142 def versionFromFile(f
):
143 """Given a file or URL, look for a line starting with #version= and
144 return the version number. If no version is found, return DEVEL.
153 except StopIteration:
156 # At the end of the file?
160 if l
.isspace() or l
.strip() == "":
163 if l
[:9] == "#version=":
164 v
= stringToVersion(l
[9:].rstrip())
170 def returnClassForVersion(version
=DEVEL
):
171 """Return the class of the syntax handler for version. version can be
172 either a string or the matching constant. Raises KickstartValueError
173 if version does not match anything.
176 version
= int(version
)
177 module
= "%s" % versionToString(version
, skipDevel
=True)
179 module
= "%s" % version
180 version
= stringToVersion(version
)
182 module
= module
.lower()
185 import pykickstart
.handlers
186 sys
.path
.extend(pykickstart
.handlers
.__path
__)
187 found
= imputil
.imp
.find_module(module
)
188 loaded
= imputil
.imp
.load_module(module
, found
[0], found
[1], found
[2])
190 for (k
, v
) in loaded
.__dict
__.iteritems():
191 if k
.lower().endswith("%shandler" % module
):
194 raise KickstartVersionError(_("Unsupported version specified: %s") % version
)
196 def makeVersion(version
=DEVEL
):
197 """Return a new instance of the syntax handler for version. version can be
198 either a string or the matching constant. This function is useful for
199 standalone programs which just need to handle a specific version of
200 kickstart syntax (as provided by a command line argument, for example)
201 and need to instantiate the correct object.
203 cl
= returnClassForVersion(version
)