7 Author : Valentin Kuznetsov <vkuznet@gmail.com> 8 Description: AbstractGenerator class provides basic functionality 9 to generate CMSSW class from given template 19 from FWCore.Skeletons.utils
import parse_word, functor, user_info, tree
23 AbstractPkg takes care how to generate code from template/PKG 24 package area. The PKG can be any directory which may include 25 any types of files, e.g. C++ (.cc), python (.py), etc. 26 This class relies on specific logic which we outline here: 28 - each template may use tags defined with double underscores 29 enclosure, e.g. __class__, __record__, etc. 30 - each template may have example tags, such tags should 31 start with @example_. While processing template user may 32 choose to strip them off or keep the code behind those tags 33 - in addition user may specify pure python code which can 34 operate with user defined tags. This code snipped should 35 be enclosed with #python_begin and #python_end lines 36 which declares start and end of python block 44 self.
pname = self.config.get(
'pname',
None)
45 self.
tmpl = self.config.get(
'tmpl',
None)
46 self.
debug = self.config.get(
'debug', 0)
47 self.
tdir = self.config.get(
'tmpl_dir')
49 self.
date = time.strftime(
"%a, %d %b %Y %H:%M:%S GMT", time.gmtime())
54 "Scan template files and return example tags" 56 sdir =
'%s/%s' % (self.
tdir, self.
tmpl)
57 for name
in os.listdir(sdir):
62 fname = os.path.join(sdir, name)
63 with open(fname,
'r') as stream: 64 for line
in stream.readlines():
65 if line.find(
'@example_') != -1:
66 keys += [k
for k
in line.split()
if \
67 k.find(
'@example_') != -1]
71 "Print out template example tags" 76 "Scan template files and return template tags" 78 sdir =
'%s/%s' % (self.
tdir, self.
tmpl)
79 for name
in os.listdir(sdir):
84 fname = os.path.join(sdir, name)
85 with open(fname,
'r') as stream: 86 for line
in stream.readlines():
87 if line.find(
'__') != -1:
92 "Print out template keys" 98 Determine either skip or keep given line based on class tags 102 keep_etags = self.config.get(
'tmpl_etags', [])
103 for tag
in tmpl_etags:
104 for valid_tag
in keep_etags:
105 if line.find(valid_tag) != -1:
106 line = line.replace(valid_tag,
'')
108 if line.find(tag) != -1:
113 def write(self, fname, tmpl_name, kwds):
114 "Create new file from given template name and set of arguments" 117 if os.path.exists(fname):
119 with open(fname,
'w')
as stream:
120 for line
in open(tmpl_name,
'r').readlines(): 124 if line.find(
'#python_begin') != -1:
127 if line.find(
'#python_end') != -1:
131 if code
and not read_code:
137 for key, val
in kwds.items():
138 if isinstance(val, str):
139 line = line.replace(key, val)
143 "Return keyword arguments to be used in methods" 144 kwds = {
'__pkgname__': self.config.get(
'pkgname',
'Package'),
145 '__author__': self.
author,
146 '__user__': os.getlogin(),
147 '__date__': self.
date,
148 '__class__': self.
pname,
149 '__class_lowercase__': self.pname.lower(),
150 '__name__': self.
pname,
151 '__subsys__': self.config.get(
'subsystem',
'Subsystem')}
152 args = self.config.get(
'args',
None)
155 print "Template tags:" 160 "Generate package templates in a given directory" 166 tmpl_files = self.config.get(
'tmpl_files',
'all')
173 if os.path.isdir(self.
pname):
174 msg =
"Can't create package '%s'\n" % self.
pname 175 msg +=
"Directory %s is already exists" % self.
pname 178 os.makedirs(self.
pname)
182 sdir = os.path.join(self.
tdir, self.
tmpl)
183 sources = [s
for s
in os.listdir(sdir) \
184 if s !=
'Driver.dir' and s.find(
'~') == -1]
185 driver = os.path.join(sdir,
'Driver.dir')
186 if os.path.isfile(driver):
187 sources = [s.replace(
'\n',
'')
for s
in open(driver,
'r').readlines()] 189 sources.remove(
'CVS')
193 names = set([s.split(
'.')[0]
for s
in sources])
194 if names == set([
'Skeleton']):
195 if self.pname.find(
'.') != -1:
196 _, ext = os.path.splitext(self.
pname)
197 sources = [s
for s
in sources
if s.rfind(ext) != -1]
198 self.
pname = self.pname.replace(ext,
'')
201 msg =
'Unable to find skeleton for extension "%s"' % ext
204 bdir = os.environ.get(
'CMSSW_BASE',
'')
206 ldir = os.getcwd().
split(
'/')[-1]
208 subsys = kwds[
'__subsys__']
209 pkgname = kwds[
'__pkgname__']
210 if sources == [
'Skeleton.cc',
'Skeleton.h']:
211 if ldir ==
'interface' and os.getcwd().
find(bdir) != -1:
212 idir =
'%s/%s/interface/' % (subsys, pkgname)
215 elif sources == [
'Skeleton.cc']
and \
216 len(dirs) == 5
and dirs[0] ==
'' and dirs[1] ==
'src':
217 idir =
'%s/%s/interface/' % (subsys, pkgname)
218 elif sources == [
'Skeleton.h']
and ldir ==
'interface' and \
219 len(dirs) == 5
and dirs[0] ==
'' and dirs[1] ==
'src':
220 idir =
'%s/%s/interface/' % (subsys, pkgname)
221 kwds.update({
'__incdir__': idir})
227 if tmpl_files !=
'all':
228 fname, ext = os.path.splitext(src)
229 if tmpl_files != ext:
234 src = src.split(
'/')[-1]
237 items = src.split(
'/')
241 tmpl_name = os.path.join(sdir, items[-1])
242 if os.path.isfile(tmpl_name):
247 if items[-1] ==
'testBuildFile.xml':
248 name2gen =
'/'.
join(src.split(
'/')[:-1])+
'/BuildFile.xml' 249 if -1 !=tname.split(
'.')[0].
find(self.
tmpl):
250 name2gen = name2gen.replace(self.
tmpl, self.
pname)
251 name2gen = os.path.join(os.getcwd(), name2gen)
253 print "Create", name2gen
255 if not os.path.isdir(name2gen):
256 os.makedirs(name2gen)
258 fdir = os.path.dirname(name2gen)
259 if not os.path.isdir(fdir):
261 self.
write(name2gen, tmpl_name, kwds)
262 gen_files.append(name2gen.split(
'/')[-1])
264 msg =
'New package "%s" of %s type is successfully generated' \
267 msg =
'Generated %s file' %
', '.
join(gen_files)
268 if len(gen_files) > 1:
273 if msg.find(
'New package') != -1:
def __init__(self, config=None)
def user_info(ainput=None)
def replace(string, replacements)
void find(edm::Handle< EcalRecHitCollection > &hits, DetId thisDet, std::vector< EcalRecHitCollection::const_iterator > &hit, bool debug=false)
def parse_etags(self, line)
static std::string join(char **cmd)
def write(self, fname, tmpl_name, kwds)
def functor(code, kwds, debug=0)