mirror of
https://github.com/kevingruesser/bootstrap-vz.git
synced 2025-08-22 09:50:37 +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
42 lines
1.3 KiB
Python
42 lines
1.3 KiB
Python
|
|
|
|
class PreferenceLists(object):
|
|
"""Represents a list of preferences lists for apt
|
|
"""
|
|
|
|
def __init__(self, manifest_vars):
|
|
"""
|
|
:param dict manifest_vars: The manifest variables
|
|
"""
|
|
# A dictionary with the name of the file in preferences.d as the key
|
|
# That values are lists of Preference objects
|
|
self.preferences = {}
|
|
# Save the manifest variables, we need the later on
|
|
self.manifest_vars = manifest_vars
|
|
|
|
def add(self, name, preferences):
|
|
"""Adds a preference to the apt preferences list
|
|
|
|
:param str name: Name of the file in preferences.list.d, may contain manifest vars references
|
|
:param object preferences: The preferences
|
|
"""
|
|
name = name.format(**self.manifest_vars)
|
|
self.preferences[name] = [Preference(p) for p in preferences]
|
|
|
|
|
|
class Preference(object):
|
|
"""Represents a single preference
|
|
"""
|
|
|
|
def __init__(self, preference):
|
|
"""
|
|
:param dict preference: A apt preference dictionary
|
|
"""
|
|
self.preference = preference
|
|
|
|
def __str__(self):
|
|
"""Convert the object into a preference block
|
|
|
|
:rtype: str
|
|
"""
|
|
return "Package: {package}\nPin: {pin}\nPin-Priority: {pin-priority}\n".format(**self.preference)
|