80 """ Searches through the requested directory looking at
81 'classes_def.xml' files looking for duplicate Reflex definitions."""
83 classNameRE = re.compile (
r'class\s+name\s*=\s*"([^"]*)"')
84 spacesRE = re.compile (
r'\s+')
85 stdRE = re.compile (
r'std::')
86 srcClassNameRE = re.compile (
r'(\w+)/src/classes_def.xml')
87 ignoreSrcRE = re.compile (
r'.*/FWCore/Skeletons/scripts/mkTemplates/.+')
88 braketRE = re.compile (
r'<.+>')
89 print "Searching for 'classes_def.xml' in '%s'." % os.path.join(os.environ.get(
'CMSSW_BASE'),
'src')
91 for srcDir
in [os.environ.get(
'CMSSW_BASE'),os.environ.get(
'CMSSW_RELEASE_BASE')]:
92 if not len(srcDir):
continue
93 for xml
in commands.getoutput (
'cd '+os.path.join(srcDir,
'src')+
'; find . -name "*classes_def.xml" -print').split (
'\n'):
94 if xml
and (
not xml
in xmlFiles):
97 pprint.pprint (xmlFiles)
103 for item
in equivDict:
105 for equiv
in item[pack]:
106 explicitREs.append( (re.compile(
r'\b' + equiv +
r'\b'),pack))
108 for filename
in xmlFiles:
109 if (
not filename)
or (ignoreSrcRE.match(filename)):
continue
110 match = srcClassNameRE.search (filename)
111 if not match:
continue
112 packageName = match.group(1)
113 xmlPackages.append (packageName)
114 matchString =
r'\b' + packageName +
r'\b'
115 packagesREs[packageName] = re.compile (matchString)
116 equivList = equivREs.setdefault (packageName, [])
117 for item
in equivDict:
118 for equiv
in item.get (packageName, []):
119 matchString = re.compile(
r'\b' + equiv +
r'\b')
120 equivList.append( (matchString, equiv) )
121 equivList.append( (packagesREs[packageName], packageName) )
123 ncdict = {
'class' :
'className'}
124 for filename
in xmlFiles:
125 if (
not filename)
or (ignoreSrcRE.match(filename)):
continue
132 lostMatch = srcClassNameRE.search (filename)
134 exceptName = lostMatch.group (1)
135 regexList = equivREs[exceptName]
136 xcount = len(regexList)-1
137 if not regexList[xcount][0].search (exceptName):
138 print '%s not found in' % exceptName,
139 print regexList[xcount][0]
143 print "filename", filename
145 filepath = os.path.join(os.environ.get(
'CMSSW_BASE'),
'src',filename)
146 if not os.path.exists(filepath):
147 filepath = os.path.join(os.environ.get(
'CMSSW_RELEASE_BASE'),
'src',filename)
148 xmlObj = xml2obj (filename = filepath,
150 nameChangeDict = ncdict)
151 except Exception
as detail:
152 print "File %s is malformed XML. Please fix." % filename
156 classList = xmlObj.selection.className
159 classList = xmlObj.className
162 print "**** SKIPPING '%s' - Doesn't seem to have proper information." % filename
164 for piece
in classList:
166 className = spacesRE.sub (
'', piece.name)
171 className = stdRE.sub (
'', className)
174 for typedef, tdList
in typedefsDict.iteritems():
176 className = re.sub (alias, typedef, className)
177 classDict.setdefault (className, set()).add (filename)
179 if not options.lostDefs:
181 localObjects.append (className)
182 if options.lazyLostDefs
and not braketRE.search (className):
184 matchString =
r'\b' + className +
r'\b'
185 simpleObjectREs.append( (re.compile (matchString), className ) )
186 for className
in localObjects:
190 for equivRE
in regexList:
192 if equivRE[0].search (className):
195 for simpleRE
in simpleObjectREs:
196 if simpleRE[0].search (className):
198 if options.verbose
and simpleRE[1] != className:
199 print " Using %s to ignore %s" \
200 % (simpleRE[1], className)
202 if foundEquiv:
continue
203 for exRes
in explicitREs:
204 if exRes[0].
search(className):
205 dupProblems +=
" %s : %s\n" % (exRes[1], className)
208 if foundEquiv:
continue
209 for packageName
in xmlPackages:
212 if packagesREs[packageName].search (className):
213 dupProblems +=
" %s : %s\n" % (packageName, className)
217 print '\n%s\n%s\n' % (filename, dupProblems)
220 for name, fileSet
in sorted( classDict.iteritems() ):
221 if len (fileSet) < 2:
224 fileList = list (fileSet)
226 for filename
in fileList: