Source code for pykickstart.commands.device

#
# Chris Lumens <clumens@redhat.com>
#
# Copyright 2005, 2006, 2007 Red Hat, Inc.
#
# This copyrighted material is made available to anyone wishing to use, modify,
# copy, or redistribute it subject to the terms and conditions of the GNU
# General Public License v.2.  This program is distributed in the hope that it
# will be useful, but WITHOUT ANY WARRANTY expressed or implied, including the
# implied warranties of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
# See the GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License along with
# this program; if not, write to the Free Software Foundation, Inc., 51
# Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.  Any Red Hat
# trademarks that are incorporated in the source code or documentation are not
# subject to the GNU General Public License and may only be used or replicated
# with the express permission of Red Hat, Inc.
#
from pykickstart.version import versionToLongString, FC3, F24, F34
from pykickstart.base import BaseData, DeprecatedCommand, KickstartCommand, RemovedCommand
from pykickstart.errors import KickstartParseError, KickstartParseWarning
from pykickstart.options import KSOptionParser

import warnings
from pykickstart.i18n import _

[docs] class F8_DeviceData(BaseData): removedKeywords = BaseData.removedKeywords removedAttrs = BaseData.removedAttrs def __init__(self, *args, **kwargs): BaseData.__init__(self, *args, **kwargs) self.moduleName = kwargs.get("moduleName", "") self.moduleOpts = kwargs.get("moduleOpts", "") def __eq__(self, y): if not y: return False return self.moduleName == y.moduleName def __ne__(self, y): return not self == y def __str__(self): retval = BaseData.__str__(self) if self.moduleName: retval += "device %s" % self.moduleName if self.moduleOpts: retval += " --opts=\"%s\"" % self.moduleOpts return retval + "\n"
[docs] class FC3_Device(KickstartCommand): removedKeywords = KickstartCommand.removedKeywords removedAttrs = KickstartCommand.removedAttrs def __init__(self, writePriority=0, *args, **kwargs): KickstartCommand.__init__(self, writePriority, *args, **kwargs) self.op = self._getParser() self.type = kwargs.get("type", "") self.moduleName = kwargs.get("moduleName", "") self.moduleOpts = kwargs.get("moduleOpts", "") def __eq__(self, y): if not y: return False return self.moduleName == y.moduleName def __ne__(self, y): return not self == y def __str__(self): retval = KickstartCommand.__str__(self) if self.moduleName: retval += "device %s %s" % (self.type, self.moduleName) if self.moduleOpts: retval += " --opts=\"%s\"" % self.moduleOpts return retval + "\n" def _getParser(self): op = KSOptionParser(prog="device", description=""" On most PCI systems, the installation program will autoprobe for Ethernet and SCSI cards properly. On older systems and some PCI systems, however, kickstart needs a hint to find the proper devices. The device command, which tells the installation program to install extra modules, is in this format: ``device <moduleName> --opts=<options>`` ``<moduleName>`` Replace with the name of the kernel module which should be installed.""", version=FC3) op.add_argument("--opts", dest="moduleOpts", default="", version=FC3, help=""" Options to pass to the kernel module. For example: ``--opts="aic152x=0x340 io=11"`` """) return op
[docs] def parse(self, args): (ns, extra) = self.op.parse_known_args(args=args, lineno=self.lineno) if len(extra) != 2: raise KickstartParseError(_("device command requires two arguments: module type and name"), lineno=self.lineno) elif any(arg for arg in extra if arg.startswith("-")): mapping = {"command": "device", "options": extra} raise KickstartParseError(_("Unexpected arguments to %(command)s command: %(options)s") % mapping, lineno=self.lineno) self.moduleOpts = ns.moduleOpts self.type = extra[0] self.moduleName = extra[1] return self
[docs] class F8_Device(FC3_Device): removedKeywords = FC3_Device.removedKeywords removedAttrs = FC3_Device.removedAttrs def __init__(self, writePriority=0, *args, **kwargs): FC3_Device.__init__(self, writePriority, *args, **kwargs) self.deviceList = kwargs.get("deviceList", []) def __str__(self): retval = "" for device in self.deviceList: retval += device.__str__() return retval
[docs] def parse(self, args): (ns, extra) = self.op.parse_known_args(args=args, lineno=self.lineno) if len(extra) != 1: raise KickstartParseError(_("%(command)s command requires a single argument: %(argument)s") % {"command": "device", "argument": "module name"}, lineno=self.lineno) elif any(arg for arg in extra if arg.startswith("-")): mapping = {"command": "device", "options": extra} raise KickstartParseError(_("Unexpected arguments to %(command)s command: %(options)s") % mapping, lineno=self.lineno) dd = self.dataClass() # pylint: disable=not-callable self.set_to_obj(ns, dd) dd.lineno = self.lineno dd.moduleName = extra[0] # Check for duplicates in the data list. if dd in self.dataList(): warnings.warn(_("A module with the name %s has already been defined.") % dd.moduleName, KickstartParseWarning) return dd
[docs] def dataList(self): return self.deviceList
@property def dataClass(self): return self.handler.DeviceData
[docs] class F24_Device(DeprecatedCommand, F8_Device): def __init__(self): # pylint: disable=super-init-not-called DeprecatedCommand.__init__(self) def _getParser(self): op = F8_Device._getParser(self) op.description += "\n\n.. deprecated:: %s" % versionToLongString(F24) return op
[docs] class F34_Device(RemovedCommand, F24_Device): def _getParser(self): op = F24_Device._getParser(self) op.description += "\n\n.. versionremoved:: %s" % versionToLongString(F34) return op