85 """ Searches through the requested directory looking at 86 'classes_def.xml' files looking for duplicate Reflex definitions.""" 88 classNameRE = re.compile (
r'class\s+name\s*=\s*"([^"]*)"')
89 spacesRE = re.compile (
r'\s+')
90 stdRE = re.compile (
r'std::')
91 srcClassNameRE = re.compile (
r'(\w+)/src/classes_def.*[.]xml')
92 ignoreSrcRE = re.compile (
r'.*/FWCore/Skeletons/scripts/mkTemplates/.+')
93 braketRE = re.compile (
r'<.+>')
94 print "Searching for 'classes_def.xml' in '%s'." % os.path.join(os.environ.get(
'CMSSW_BASE'),
'src')
96 for srcDir
in [os.environ.get(
'CMSSW_BASE'),os.environ.get(
'CMSSW_RELEASE_BASE')]:
97 if not len(srcDir):
continue 98 for xml
in commands.getoutput (
'cd '+os.path.join(srcDir,
'src')+
'; find . -name "*classes_def*.xml" -follow -print').split (
'\n'):
99 if xml
and (
not xml
in xmlFiles):
102 pprint.pprint (xmlFiles)
108 for item
in equivDict:
110 for equiv
in item[pack]:
111 explicitREs.append( (re.compile(
r'\b' + equiv +
r'\b'),pack))
113 for filename
in xmlFiles:
114 if (
not filename)
or (ignoreSrcRE.match(filename)):
continue 115 match = srcClassNameRE.search (filename)
116 if not match:
continue 117 packageName = match.group(1)
118 xmlPackages.append (packageName)
119 matchString =
r'\b' + packageName +
r'\b' 120 packagesREs[packageName] = re.compile (matchString)
121 equivList = equivREs.setdefault (packageName, [])
122 for item
in equivDict:
123 for equiv
in item.get (packageName, []):
124 matchString = re.compile(
r'\b' + equiv +
r'\b')
125 equivList.append( (matchString, equiv) )
126 equivList.append( (packagesREs[packageName], packageName) )
128 ncdict = {
'class' :
'className',
'function' :
'functionName'}
129 for filename
in xmlFiles:
130 if (
not filename)
or (ignoreSrcRE.match(filename)):
continue 137 lostMatch = srcClassNameRE.search (filename)
139 exceptName = lostMatch.group (1)
140 regexList = equivREs[exceptName]
141 xcount = len(regexList)-1
142 if not regexList[xcount][0].search (exceptName):
143 print '%s not found in' % exceptName,
144 print regexList[xcount][0]
148 print "filename", filename
150 filepath = os.path.join(os.environ.get(
'CMSSW_BASE'),
'src',filename)
151 if not os.path.exists(filepath):
152 filepath = os.path.join(os.environ.get(
'CMSSW_RELEASE_BASE'),
'src',filename)
153 xmlObj = xml2obj (filename = filepath,
155 nameChangeDict = ncdict)
156 except Exception
as detail:
157 print "File %s is malformed XML. Please fix." % filename
161 classList = xmlObj.selection.className
164 classList = xmlObj.className
167 print "**** SKIPPING '%s' - Doesn't seem to have proper information." % filename
170 classList = xmlObj.functionName
172 print "**** SKIPPING '%s' - Dosen't seem to have proper information(not class/function)." % filename
174 for piece
in classList:
176 className = spacesRE.sub (
'', piece.name)
181 className = stdRE.sub (
'', className)
184 for typedef, tdList
in typedefsDict.iteritems():
186 className = re.sub (alias, typedef, className)
187 classDict.setdefault (className, set()).add (filename)
189 if not options.lostDefs:
191 localObjects.append (className)
192 if options.lazyLostDefs
and not braketRE.search (className):
194 matchString =
r'\b' + className +
r'\b' 195 simpleObjectREs.append( (re.compile (matchString), className ) )
196 for className
in localObjects:
200 for equivRE
in regexList:
202 if equivRE[0].search (className):
205 for simpleRE
in simpleObjectREs:
206 if simpleRE[0].search (className):
208 if options.verbose
and simpleRE[1] != className:
209 print " Using %s to ignore %s" \
210 % (simpleRE[1], className)
212 if foundEquiv:
continue 213 for exRes
in explicitREs:
214 if exRes[0].
search(className):
215 dupProblems +=
" %s : %s\n" % (exRes[1], className)
218 if foundEquiv:
continue 219 for packageName
in xmlPackages:
222 if packagesREs[packageName].search (className):
223 dupProblems +=
" %s : %s\n" % (packageName, className)
227 print '\n%s\n%s\n' % (filename, dupProblems)
230 for name, fileSet
in sorted( classDict.iteritems() ):
231 if len (fileSet) < 2:
234 fileList = list (fileSet)
236 for filename
in fileList:
std::vector< T >::const_iterator search(const cond::Time_t &val, const std::vector< T > &container)