qubes-installer-qubes-os/anaconda/pyanaconda/cmdline.py
2013-01-24 01:45:53 +01:00

199 lines
5.8 KiB
Python

#
# cmdline.py - non-interactive, very very simple frontend to anaconda
#
# Copyright (C) 2003, 2004, 2005, 2006, 2007 Red Hat, Inc.
# All rights reserved.
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty 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, see <http://www.gnu.org/licenses/>.
#
# Author(s): Jeremy Katz <katzj@redhat.com
#
import time
import signal
import parted
from constants import *
from flags import flags
from iutil import strip_markup
from installinterfacebase import InstallInterfaceBase
import gettext
_ = lambda x: gettext.ldgettext("anaconda", x)
import logging
log = logging.getLogger("anaconda")
def setupProgressDisplay(anaconda):
if anaconda.dir == DISPATCH_BACK:
anaconda.intf.setInstallProgressClass(None)
return DISPATCH_BACK
else:
anaconda.intf.setInstallProgressClass(progressDisplay())
return DISPATCH_FORWARD
stepToClasses = { "install" : setupProgressDisplay }
class WaitWindow:
def pop(self):
pass
def refresh(self):
pass
def __init__(self, title, text):
print(text)
class ProgressWindow:
def pop(self):
print("")
def pulse(self):
pass
def set(self, amount):
if amount == self.total:
print(_("Completed"))
def refresh(self):
pass
def __init__(self, title, text, total, updpct = 0.05, pulse = False):
self.total = total
print(text)
print(_("In progress"))
class InstallInterface(InstallInterfaceBase):
def __init__(self):
InstallInterfaceBase.__init__(self)
# signal.signal(signal.SIGINT, signal.SIG_IGN)
signal.signal(signal.SIGTSTP, signal.SIG_DFL)
self.instProgress = None
def __del__(self):
pass
def reinitializeWindow(self, title, path, size, description):
errtxt = _("(%s)\nCommand line mode requires all choices to be specified in a "
"kickstart configuration file." % (title,))
raise RuntimeError(errtxt)
def shutdown(self):
pass
def suspend(self):
pass
def resume(self):
pass
def progressWindow(self, title, text, total, updpct = 0.05, pulse = False):
return ProgressWindow(title, text, total, updpct, pulse)
def kickstartErrorWindow(self, text):
errtxt = _("The following error was found while parsing the "
"kickstart configuration file:\n\n%s") % (text,)
raise RuntimeError(errtxt)
def messageWindow(self, title, text, type="ok", default = None,
custom_icon = None, custom_buttons = []):
if type == "ok":
print(text)
else:
errtxt = _("(%s)\n%s" % (title, text))
raise RuntimeError(errtxt)
def detailedMessageWindow(self, title, text, longText=None, type="ok",
default=None, custom_buttons=None,
custom_icon=None, expanded=False):
if longText:
text += "\n\n%s" % longText
self.messageWindow(title, text, type=type, default=default,
custom_buttons=custom_buttons, custom_icon=custom_icon)
def passphraseEntryWindow(self, device):
errtxt = _("Can't have a question in command line mode!")
errtxt += "\n(passphraseEntryWindow: '%s')" % (device,)
raise RuntimeError(errtxt)
def getLUKSPassphrase(self, passphrase = "", isglobal = False):
errtxt = _("Can't have a question in command line mode!")
errtxt += "\n(getLUKSPassphrase)"
raise RuntimeError(errtxt)
def enableNetwork(self):
errtxt = "(enableNetwork)\n"
errtxt += _("Can't have a question in command line mode!")
raise RuntimeError(errtxt)
def questionInitializeDASD(self, c, devs):
errtxt = "(questionInitializeDASD)\n"
errtxt += _("Can't have a question in command line mode!")
raise RuntimeError(errtxt)
def mainExceptionWindow(self, shortText, longTextFile):
print(shortText)
def waitWindow(self, title, text):
return WaitWindow(title, text)
def beep(self):
pass
def run(self, anaconda):
self.anaconda = anaconda
def display_step(self, step):
if stepToClasses.has_key(step):
stepToClasses[step](self.anaconda)
else:
errtxt = _("In interactive step can't continue. (%s)" %(step,))
raise RuntimeError(errtxt)
def setInstallProgressClass(self, c):
self.instProgress = c
class progressDisplay:
def __init__(self):
self.pct = 0
self.display = ""
def __del__(self):
pass
def processEvents(self):
pass
def setShowPercentage(self, val):
pass
def get_fraction(self):
return self.pct
def set_fraction(self, pct):
self.pct = pct
def set_text(self, txt):
print(txt)
def set_label(self, txt):
stripped = strip_markup(txt)
if stripped != self.display:
self.display = stripped
print(self.display)
def setupProgressDisplay(anaconda):
if anaconda.dir == DISPATCH_BACK:
anaconda.intf.setInstallProgressClass(None)
return DISPATCH_BACK
else:
anaconda.intf.setInstallProgressClass(progressDisplay())
return DISPATCH_FORWARD