summaryrefslogtreecommitdiff
path: root/cloudinit
diff options
context:
space:
mode:
authorJoshua Harlow <harlowja@yahoo-inc.com>2012-06-08 17:54:45 -0700
committerJoshua Harlow <harlowja@yahoo-inc.com>2012-06-08 17:54:45 -0700
commitd3e6be27c8a2cd89baa545c1116442d3d5d5b53a (patch)
treea657376432857418d0dfc76ddc578e406472516d /cloudinit
parentd0a477cd6eb66b201363898f35cb8eecc3559759 (diff)
downloadvyos-cloud-init-d3e6be27c8a2cd89baa545c1116442d3d5d5b53a.tar.gz
vyos-cloud-init-d3e6be27c8a2cd89baa545c1116442d3d5d5b53a.zip
Seems like the util function extraction was not actually needed.
Diffstat (limited to 'cloudinit')
-rw-r--r--cloudinit/includer.py65
1 files changed, 0 insertions, 65 deletions
diff --git a/cloudinit/includer.py b/cloudinit/includer.py
deleted file mode 100644
index d1022c5a..00000000
--- a/cloudinit/includer.py
+++ /dev/null
@@ -1,65 +0,0 @@
-import os
-import re
-
-from cloudinit import downloader as down
-from cloudinit import exceptions as excp
-from cloudinit import log as logging
-from cloudinit import shell as sh
-
-INCLUDE_PATT = re.compile("^#(opt_include|include)[ \t](.*)$", re.MULTILINE)
-OPT_PATS = ['opt_include']
-
-LOG = logging.getLogger(__name__)
-
-
-class Includer(object):
-
- def __init__(self, root_fn, stack_limit=10):
- self.root_fn = root_fn
- self.stack_limit = stack_limit
-
- def _read_file(self, fname):
- return sh.read_file(fname)
-
- def _read(self, fname, stack, rel):
- if len(stack) >= self.stack_limit:
- raise excp.StackExceeded("Stack limit of %s reached while including %s" % (self.stack_limit, fname))
-
- canon_fname = self._canon_name(fname, rel)
- if canon_fname in stack:
- raise excp.RecursiveInclude("File %s recursively included" % (canon_fname))
-
- stack.add(canon_fname)
- new_rel = os.path.dirname(canon_fname)
- contents = self._read_file(canon_fname)
-
- def include_cb(match):
- is_optional = (match.group(1).lower() in OPT_PATS)
- fn = match.group(2).strip()
- if not fn:
- # Should we die??
- return match.group(0)
- else:
- try:
- LOG.debug("Including file %s", fn)
- return self._read(fn, stack, new_rel)
- except IOError:
- if is_optional:
- return ''
- else:
- raise
-
- adjusted_contents = INCLUDE_PATT.sub(include_cb, contents)
- stack.remove(fname)
- return adjusted_contents
-
- def _canon_name(self, fname, rel):
- fname = fname.strip()
- if not fname.startswith("/"):
- fname = os.path.sep.join([rel, fname])
- return os.path.realpath(fname)
-
- def read(self, relative_to="."):
- stack = set()
- return self._read(self.root_fn, stack, rel=relative_to)
-