summaryrefslogtreecommitdiff
path: root/kswriter
diff options
context:
space:
mode:
authorAnas Nashif <anas.nashif@intel.com>2012-04-22 23:00:22 +0100
committerAnas Nashif <anas.nashif@intel.com>2012-04-22 23:00:22 +0100
commitace745a3804e6dc848c3c3c5f1ef69780a209ada (patch)
tree9676971a48787df2424a26a0002db599f38928e7 /kswriter
parentc18967433fe190c47a592831f33950f8817f7f43 (diff)
downloadkickstarter-ace745a3804e6dc848c3c3c5f1ef69780a209ada.tar.gz
kickstarter-ace745a3804e6dc848c3c3c5f1ef69780a209ada.tar.bz2
kickstarter-ace745a3804e6dc848c3c3c5f1ef69780a209ada.zip
move everything to a module
Diffstat (limited to 'kswriter')
-rw-r--r--kswriter/KSWriter.py57
1 files changed, 54 insertions, 3 deletions
diff --git a/kswriter/KSWriter.py b/kswriter/KSWriter.py
index 46afe04..e679789 100644
--- a/kswriter/KSWriter.py
+++ b/kswriter/KSWriter.py
@@ -1,16 +1,28 @@
#!/usr/bin/python
-
import copy
import time
import yaml
-import os
+import os, re
import sys
+import errno
+
+from kickstart import kickstart
+
+def mkdir_p(path):
+ try:
+ os.makedirs(path)
+ except OSError as exc: # Python >2.5
+ if exc.errno == errno.EEXIST:
+ pass
+ else: raise
class KSWriter():
- def __init__(self, im, rep, out):
+ def __init__(self, im, rep, out, config, packages):
self.image_filename = im
self.repo_filename = rep
self.outdir = out
+ self.packages = False
+ self.config = None
self.image_stream = file(self.image_filename, 'r')
self.repo_stream = file(self.repo_filename, 'r')
self.extra = {}
@@ -102,3 +114,42 @@ class KSWriter():
f.write(a)
f.close()
+ def generate(self):
+ r = self.repo_meta['Repositories']
+ if self.image_meta.has_key('Configurations'):
+ for img in self.image_meta['Configurations']:
+ conf = self.parse(img)
+ if options.config:
+ if img.has_key('FileName') and options.config == img['FileName']:
+ print "Creating %s (%s.ks)" %(img['Name'], img['FileName'] )
+ self.process_files(conf, r)
+ break
+ else:
+ if conf.has_key('Active') and conf['Active'] :
+ print "Creating %s (%s.ks)" %(img['Name'], img['FileName'] )
+ self.process_files(conf, r)
+ else:
+ print "%s is inactive, not generating %s at this time" %(img['Name'], img['FileName'] )
+ for path in self.image_meta['ExternalConfigs']:
+ for f in os.listdir(path):
+ if f.endswith('.yaml'):
+ fp = file('%s/%s' %(path, f), 'r')
+ local = yaml.load(fp)
+ conf = self.parse(local)
+ if self.config:
+ if self.config == conf['FileName']:
+ if self.packages:
+ print conf['Groups']
+ print conf['ExtraPackages']
+ else:
+ print "Creating %s (%s.ks)" %(conf['Name'], conf['FileName'] )
+ self.process_files(conf, r)
+ break
+ else:
+ if conf.has_key('Active') and conf['Active']:
+ print "Creating %s (%s.ks)" %(conf['Name'], conf['FileName'] )
+ self.process_files(conf, r)
+ else:
+ print "%s is inactive, not generate %s this time" %(conf['Name'], conf['FileName'] )
+ else:
+ print "WARNING: File '%s' ignored." % (f)