本文整理匯總了Python中ubiquity.parted_server.PartedServer類的典型用法代碼示例。如果您正苦於以下問題:Python PartedServer類的具體用法?Python PartedServer怎麽用?Python PartedServer使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
在下文中一共展示了PartedServer類的9個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: filter_parts
def filter_parts(self):
question = 'migration-assistant/partitions'
from ubiquity.parted_server import PartedServer
with raised_privileges():
parted = PartedServer()
parts = []
for disk in parted.disks():
parted.select_disk(disk)
for partition in parted.partitions():
# We check to see if the partition is scheduled to be
# formatted and if not add it to the list of post-commit
# available partitions.
filename = '/var/lib/partman/devices/%s/%s/format' % \
(disk, partition[1])
if os.path.exists(filename):
syslog.syslog('filtering out %s as it is to be formatted.' % partition[5])
else:
parts.append(partition[5])
ret = []
for choice in self.choices(question):
if choice[choice.rfind('(')+1:choice.rfind(')')] in parts:
ret.append(choice)
self.preseed(question, ", ".join(ret))
示例2: filter_parts
def filter_parts(self):
question = 'migration-assistant/partitions'
from ubiquity.parted_server import PartedServer
os.seteuid(0)
parted = PartedServer()
parts = []
for disk in parted.disks():
parted.select_disk(disk)
for partition in parted.partitions():
# We check to see if the partition is scheduled to be
# formatted and if not add it to the list of post-commit
# available partitions.
filename = '/var/lib/partman/devices/%s/%s/view' % \
(disk, partition[1])
fd = open(filename)
pieces = fd.readline().rstrip('\n').split(None, 8)
fd.close()
line = [''] * 8
line[0:len(pieces)] = pieces
formatted = ['F', 'f', 'swap']
if not (set(line) & set(formatted)):
parts.append(partition[5])
else:
syslog.syslog('filtering out %s as it is to be formatted.' % partition[5])
drop_privileges()
ret = []
for choice in self.choices(question):
if choice[choice.rfind('(')+1:choice.rfind(')')] in parts:
ret.append(choice)
self.preseed(question, ", ".join(ret))
示例3: grub_options
def grub_options():
""" Generates a list of suitable targets for grub-installer
@return empty list or a list of ['/dev/sda1','Ubuntu Hardy 8.04'] """
from ubiquity.parted_server import PartedServer
l = []
try:
oslist = {}
subp = subprocess.Popen(['os-prober'], stdout=subprocess.PIPE,
stderr=subprocess.PIPE)
result = subp.communicate()[0].splitlines()
for res in result:
res = res.split(':')
oslist[res[0]] = res[1]
p = PartedServer()
for disk in p.disks():
p.select_disk(disk)
dev = ''
mod = ''
size = ''
try:
fp = open(p.device_entry('model'))
mod = fp.readline()
fp.close()
fp = open(p.device_entry('device'))
dev = fp.readline()
fp.close()
fp = open(p.device_entry('size'))
size = fp.readline()
fp.close()
finally:
if fp:
fp.close()
if dev and mod:
if size.isdigit():
size = format_size(int(size))
l.append([dev, '%s (%s)' % (mod, size)])
else:
l.append([dev, mod])
for part in p.partitions():
ostype = ''
if part[4] == 'linux-swap':
continue
if part[4] == 'free':
continue
if os.path.exists(p.part_entry(part[1], 'format')):
# Don't bother looking for an OS type.
pass
elif part[5] in oslist.keys():
ostype = oslist[part[5]]
l.append([part[5], ostype])
except:
import traceback
for line in traceback.format_exc().split('\n'):
syslog.syslog(syslog.LOG_ERR, line)
return l
示例4: find_grub_target
def find_grub_target():
# This needs to be somewhat duplicated from grub-installer here because we
# need to be able to show the user what device GRUB will be installed to
# well before grub-installer is run.
try:
boot = ""
root = ""
regain_privileges()
p = PartedServer()
for disk in p.disks():
p.select_disk(disk)
for part in p.partitions():
part = part[1]
if p.has_part_entry(part, "mountpoint"):
mp = p.readline_part_entry(part, "mountpoint")
if mp == "/boot":
boot = disk.replace("=", "/")
elif mp == "/":
root = disk.replace("=", "/")
drop_privileges()
if boot:
return boot
elif root:
return root
return "(hd0)"
except Exception, e:
drop_privileges()
import syslog
syslog.syslog("Exception in find_grub_target: " + str(e))
return "(hd0)"
示例5: boot_device
def boot_device():
from ubiquity.parted_server import PartedServer
boot = None
root = None
try:
p = PartedServer()
for disk in p.disks():
p.select_disk(disk)
for part in p.partitions():
part = part[1]
if p.has_part_entry(part, 'mountpoint'):
mp = p.readline_part_entry(part, 'mountpoint')
if mp == '/boot':
boot = disk.replace('=', '/')
elif mp == '/':
root = disk.replace('=', '/')
except Exception:
import traceback
for line in traceback.format_exc().split('\n'):
syslog.syslog(syslog.LOG_ERR, line)
if boot:
return boot
return root
示例6: grub_options
def grub_options():
""" Generates a list of suitable targets for grub-installer
@return empty list or a list of ['/dev/sda1','Ubuntu Hardy 8.04'] """
from ubiquity.parted_server import PartedServer
l = []
try:
oslist = {}
subp = subprocess.Popen(["os-prober"], stdout=subprocess.PIPE, stderr=subprocess.PIPE, universal_newlines=True)
result = subp.communicate()[0].splitlines()
for res in result:
res = res.split(":")
oslist[res[0]] = res[1]
p = PartedServer()
for disk in p.disks():
p.select_disk(disk)
with open(p.device_entry("model")) as fp:
mod = fp.readline()
with open(p.device_entry("device")) as fp:
dev = fp.readline()
with open(p.device_entry("size")) as fp:
size = fp.readline()
if dev and mod:
if size.isdigit():
size = format_size(int(size))
l.append([dev, "%s (%s)" % (mod, size)])
else:
l.append([dev, mod])
for part in p.partitions():
ostype = ""
if part[4] == "linux-swap":
continue
if part[4] == "free":
continue
if os.path.exists(p.part_entry(part[1], "format")):
# Don't bother looking for an OS type.
pass
elif part[5] in oslist.keys():
ostype = oslist[part[5]]
l.append([part[5], ostype])
except:
import traceback
for line in traceback.format_exc().split("\n"):
syslog.syslog(syslog.LOG_ERR, line)
return l
示例7: grub_options
def grub_options():
""" Generates a list of suitable targets for grub-installer
@return empty list or a list of ['/dev/sda1','Ubuntu Hardy 8.04'] """
os.seteuid(0)
l = []
oslist = {}
subp = subprocess.Popen(['os-prober'], stdout=subprocess.PIPE,
stderr=subprocess.PIPE)
result = subp.communicate()[0].splitlines()
for res in result:
res = res.split(':')
oslist[res[0]] = res[1]
p = PartedServer()
for disk in p.disks():
p.select_disk(disk)
dev = ''
mod = ''
size = ''
try:
fp = open(p.device_entry('model'))
mod = fp.readline()
fp.close()
fp = open(p.device_entry('device'))
dev = fp.readline()
fp = open(p.device_entry('size'))
size = fp.readline()
finally:
fp.close()
if dev and mod:
if size.isdigit():
size = format_size(int(size))
l.append([dev, '%s (%s)' % (mod, size)])
else:
l.append([dev, mod])
for part in p.partitions():
ostype = ''
if part[4] == 'xfs' or part[4] == 'linux-swap':
continue
if os.path.exists(p.part_entry(part[1], 'format')):
pass
elif part[5] in oslist.keys():
ostype = oslist[part[5]]
l.append([part[5], ostype])
drop_privileges()
return l
示例8: run
def run(self, priority, question):
if self.stashed_auto_mountpoints is None:
# We need to extract the automatic mountpoints calculated by
# partman at some point while parted_server is running, so that
# they can be used later if manual partitioning is selected.
# This hack is only necessary because the manual partitioner is
# NIHed rather than being based on partman.
self.stashed_auto_mountpoints = {}
parted = PartedServer()
for disk in parted.disks():
parted.select_disk(disk)
for part in parted.partitions():
(p_num, p_id, p_size, p_type, p_fs, p_path, p_name) = part
if p_fs == 'free':
continue
if not parted.has_part_entry(p_id, 'method'):
continue
method = parted.readline_part_entry(p_id, 'method')
if method == 'swap':
continue
elif p_fs == 'hfs' and method == 'newworld':
self.stashed_auto_mountpoints[p_path] = 'newworld'
elif parted.has_part_entry(p_id, 'acting_filesystem'):
mountpoint = parted.readline_part_entry(p_id,
'mountpoint')
self.stashed_auto_mountpoints[p_path] = mountpoint
self.frontend.set_auto_mountpoints(self.stashed_auto_mountpoints)
if self.done:
# user answered confirmation question or selected manual
# partitioning
return self.succeeded
self.current_question = question
try:
qtype = self.db.metaget(question, 'Type')
except debconf.DebconfError:
qtype = ''
if question == 'partman-auto/select_disk':
self.resize_allowed = True
self.manual_desc = \
self.description('partman-auto/text/custom_partitioning')
self.do_nothing_desc = \
self.description('partman-auto/text/do_nothing_partitioning')
self.use_biggest_free_desc = \
self.description('partman-auto/text/use_biggest_free')
if not self.frontend.set_disk_choices(self.choices(question),
self.manual_desc):
# disk selector not implemented; just use first disk
return self.succeeded
elif question.endswith('automatically_partition'):
if self.backup_from_new_size is not None:
# We backed up from the resize question and now need to
# carry on down a different (preseeded) path.
self.preseed(question, self.backup_from_new_size)
self.backup_from_new_size = None
self.succeeded = True
return True
self.autopartition_question = question
self.resize_desc = \
self.description('partman-auto/text/resize_use_free')
self.manual_desc = \
self.description('partman-auto/text/custom_partitioning')
self.do_nothing_desc = \
self.description('partman-auto/text/do_nothing_partitioning')
self.use_biggest_free_desc = \
self.description('partman-auto/text/use_biggest_free')
choices = self.choices(question)
if not self.resize_allowed:
try:
del choices[choices.index(self.resize_desc)]
except ValueError:
pass
self.frontend.set_autopartition_choices(
choices, self.resize_desc, self.manual_desc, self.do_nothing_desc, self.use_biggest_free_desc)
if self.resize_desc in choices:
# The resize option is available, so we need to present the
# user with an accurate resize slider before passing control
# to the UI.
# Don't preseed_as_c, because Perl debconf is buggy in that
# it doesn't expand variables in the result of METAGET
# choices-c. All locales have the same variables anyway so
# it doesn't matter.
self.preseed(question, self.resize_desc)
return True
elif question == 'partman-partitioning/new_size':
self.backup_from_new_size = None
self.frontend.set_autopartition_resize_bounds(self.resize_min_size,
self.resize_max_size)
elif question.startswith('partman/confirm'):
if question == 'partman/confirm':
self.db.set('ubiquity/partman-made-changes', 'true')
else:
self.db.set('ubiquity/partman-made-changes', 'false')
#.........這裏部分代碼省略.........
示例9: progress_stop
def progress_stop(self, progress_title):
ret = super(PartmanCommit, self).progress_stop(progress_title)
if (progress_title == 'partman/progress/init/title' and
self.manual_input):
partitions = {}
parted = PartedServer()
for disk in parted.disks():
parted.select_disk(disk)
for part in parted.partitions():
(p_num, p_id, p_size, p_type, p_fs, p_path, p_name) = part
partitions[p_path] = (disk, p_id)
mountpoints = self.frontend.get_mountpoints()
for device in partitions:
(disk, p_id) = partitions[device]
parted.select_disk(disk)
if device in mountpoints:
(path, format, fstype, flags) = mountpoints[device]
if path == 'swap':
parted.write_part_entry(p_id, 'method', 'swap\n')
if format:
parted.write_part_entry(p_id, 'format', '')
else:
parted.remove_part_entry(p_id, 'format')
parted.remove_part_entry(p_id, 'use_filesystem')
else:
if (fstype == 'hfs' and
flags is not None and 'boot' in flags):
parted.write_part_entry(
p_id, 'method', 'newworld\n')
parted.write_part_entry(
p_id, 'filesystem', 'newworld')
parted.remove_part_entry(p_id, 'format')
path = None
elif format:
parted.write_part_entry(p_id, 'method', 'format\n')
parted.write_part_entry(p_id, 'format', '')
if fstype is None:
if parted.has_part_entry(
p_id, 'detected_filesystem'):
fstype = parted.readline_part_entry(
p_id, 'detected_filesystem')
else:
# TODO cjwatson 2006-09-27: Why don't we
# know the filesystem type? Fortunately,
# we have an explicit indication from
# the user that it's OK to format this
# filesystem.
fstype = 'ext3'
parted.write_part_entry(p_id, 'filesystem', fstype)
parted.remove_part_entry(p_id, 'options')
parted.mkdir_part_entry(p_id, 'options')
else:
parted.write_part_entry(p_id, 'method', 'keep\n')
parted.remove_part_entry(p_id, 'format')
if fstype is not None:
parted.write_part_entry(
p_id, 'detected_filesystem', fstype)
parted.write_part_entry(p_id, 'use_filesystem', '')
if path is not None:
parted.write_part_entry(p_id, 'mountpoint', path)
else:
parted.remove_part_entry(p_id, 'mountpoint')
elif (parted.has_part_entry(p_id, 'method') and
parted.readline_part_entry(p_id, 'method') == 'newworld'):
# Leave existing newworld boot partitions alone.
pass
else:
parted.remove_part_entry(p_id, 'method')
parted.remove_part_entry(p_id, 'format')
parted.remove_part_entry(p_id, 'use_filesystem')
return ret