summaryrefslogtreecommitdiff
path: root/cloudinit/mergers/__init__.py
diff options
context:
space:
mode:
authorJoshua Harlow <harlowja@gmail.com>2012-11-22 19:45:43 -0800
committerJoshua Harlow <harlowja@gmail.com>2012-11-22 19:45:43 -0800
commit3941466b3e065c9ce7bb7500e41f464993861672 (patch)
tree152ff7635217238d1ee562fd72df688c4c924599 /cloudinit/mergers/__init__.py
parent180e83b20aa02dc9df903fa7e31121dd49a49b3a (diff)
downloadvyos-cloud-init-3941466b3e065c9ce7bb7500e41f464993861672.tar.gz
vyos-cloud-init-3941466b3e065c9ce7bb7500e41f464993861672.zip
Allow mergers to take options.
Diffstat (limited to 'cloudinit/mergers/__init__.py')
-rw-r--r--cloudinit/mergers/__init__.py37
1 files changed, 22 insertions, 15 deletions
diff --git a/cloudinit/mergers/__init__.py b/cloudinit/mergers/__init__.py
index b3e728b0..20658edc 100644
--- a/cloudinit/mergers/__init__.py
+++ b/cloudinit/mergers/__init__.py
@@ -16,11 +16,14 @@
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
+import re
from cloudinit import importer
from cloudinit import log as logging
from cloudinit import util
+NAME_MTCH = re.compile(r"(^[a-zA-Z_][A-Za-z0-9_]*)\((.*?)\)$")
+
LOG = logging.getLogger(__name__)
@@ -71,10 +74,8 @@ def _extract_merger_names(merge_how):
names = []
for m_name in merge_how.split("+"):
# Canonicalize the name (so that it can be found
- # even when users alter it in various ways...
+ # even when users alter it in various ways)
m_name = m_name.lower().strip()
- m_name = m_name.replace(" ", "_")
- m_name = m_name.replace("\t", "_")
m_name = m_name.replace("-", "_")
if not m_name:
continue
@@ -82,23 +83,29 @@ def _extract_merger_names(merge_how):
return names
-def construct(merge_how, default_classes=None):
- mergers = []
- merger_classes = []
- root = LookupMerger(mergers)
- for m_name in _extract_merger_names(merge_how):
+def construct(merge_how):
+ mergers_to_be = []
+ for name in _extract_merger_names(merge_how):
+ match = NAME_MTCH.match(name)
+ if not match:
+ msg = "Matcher identifer '%s' is not in the right format" % (name)
+ raise ValueError(msg)
+ (m_name, m_ops) = match.groups()
+ m_ops = m_ops.strip().split(",")
+ m_ops = [m.strip().lower() for m in m_ops if m.strip()]
merger_locs = importer.find_module(m_name,
[__name__],
['Merger'])
if not merger_locs:
- msg = "Could not find merger named %s" % (m_name)
+ msg = "Could not find merger named '%s'" % (m_name)
raise ImportError(msg)
else:
mod = importer.import_module(merger_locs[0])
- cls = getattr(mod, 'Merger')
- merger_classes.append(cls)
- if not merger_classes and default_classes:
- merger_classes = default_classes
- for m_class in merger_classes:
- mergers.append(m_class(root))
+ mod_attr = getattr(mod, 'Merger')
+ mergers_to_be.append((mod_attr, m_ops))
+ # Now form them...
+ mergers = []
+ root = LookupMerger(mergers)
+ for (attr, opts) in mergers_to_be:
+ mergers.append(attr(root, opts))
return root \ No newline at end of file