mirror of
https://github.com/kevingruesser/bootstrap-vz.git
synced 2025-08-24 15:36:27 +00:00

Up until now I didn't see the point of using spaces for indentation. However, the previous commit (a18bec3) was quite eye opening. Given that python is an indentation aware language, the amount of mistakes that went unnoticed because tabs and spaces were used at the same time (tabs for indentation and spaces for alignment) were unacceptable. E101,W191 have been re-enable in the tox flake8 checker and the documentation has been modified accordingly. The following files have been left as-is: * bootstrapvz/common/assets/extlinux/extlinux.conf * bootstrapvz/common/assets/init.d/expand-root * bootstrapvz/common/assets/init.d/generate-ssh-hostkeys * bootstrapvz/common/assets/init.d/squeeze/generate-ssh-hostkeys * bootstrapvz/plugins/docker_daemon/assets/init.d/docker * bootstrapvz/providers/ec2/assets/bin/growpart * bootstrapvz/providers/ec2/assets/grub.d/40_custom * bootstrapvz/providers/ec2/assets/init.d/ec2-get-credentials * bootstrapvz/providers/ec2/assets/init.d/ec2-run-user-data * docs/_static/taskoverview.coffee * docs/_static/taskoverview.less * tests/unit/subprocess.sh
49 lines
1.7 KiB
Python
49 lines
1.7 KiB
Python
from abstract import AbstractPartition
|
|
import os.path
|
|
from bootstrapvz.common.tools import log_check_call
|
|
|
|
|
|
class Mount(object):
|
|
"""Represents a mount into the partition
|
|
"""
|
|
def __init__(self, source, destination, opts):
|
|
"""
|
|
:param str,AbstractPartition source: The path from where we mount or a partition
|
|
:param str destination: The path of the mountpoint
|
|
:param list opts: List of options to pass to the mount command
|
|
"""
|
|
self.source = source
|
|
self.destination = destination
|
|
self.opts = opts
|
|
|
|
def mount(self, prefix):
|
|
"""Performs the mount operation or forwards it to another partition
|
|
|
|
:param str prefix: Path prefix of the mountpoint
|
|
"""
|
|
mount_dir = os.path.join(prefix, self.destination)
|
|
# If the source is another partition, we tell that partition to mount itself
|
|
if isinstance(self.source, AbstractPartition):
|
|
self.source.mount(destination=mount_dir)
|
|
else:
|
|
log_check_call(['mount'] + self.opts + [self.source, mount_dir])
|
|
self.mount_dir = mount_dir
|
|
|
|
def unmount(self):
|
|
"""Performs the unmount operation or asks the partition to unmount itself
|
|
"""
|
|
# If its a partition, it can unmount itself
|
|
if isinstance(self.source, AbstractPartition):
|
|
self.source.unmount()
|
|
else:
|
|
log_check_call(['umount', self.mount_dir])
|
|
del self.mount_dir
|
|
|
|
def __getstate__(self):
|
|
state = self.__dict__.copy()
|
|
state['__class__'] = self.__module__ + '.' + self.__class__.__name__
|
|
return state
|
|
|
|
def __setstate__(self, state):
|
|
for key in state:
|
|
self.__dict__[key] = state[key]
|