3 __author__ =
"Marco Clemencic <Marco.Clemencic@cern.ch>"
4 __version__ =
"$Id: update_versions.py,v 1.3 2008/11/10 19:43:31 marcocle Exp $"
6 import os, re, sys, time
11 _req_version_pattern = re.compile(
r"^\s*version\s*(v[0-9]+r[0-9]+(?:p[0-9]+)?)\s*$")
12 _cml_version_pattern = re.compile(
r"^\s*gaudi_subdir\s*\(\s*\S+\s+(v[0-9]+r[0-9]+(?:p[0-9]+)?)\)\s*$")
15 Find the version number in a requirements file.
17 global _req_version_pattern
19 m = _req_version_pattern.match(l)
25 if os.path.exists(cml):
29 m = _cml_version_pattern.match(l)
30 if m
and m.group(1) != newversion:
31 print "%s: %s -> %s"%(cml, m.group(1), newversion)
32 l = l.replace(m.group(1), newversion)
36 open(cml,
"w").writelines(out)
40 Compare the version of the package with the new one and update the package if
43 Returns true if the package have been modified.
45 global _req_version_pattern
48 req = os.path.join(packagedir,
"requirements")
50 m = _req_version_pattern.match(l)
52 if m.group(1) != newversion:
53 print "%s: %s -> %s"%(packagedir,m.group(1),newversion)
54 l = l.replace(m.group(1),newversion)
58 open(req,
"w").writelines(out)
60 ver = os.path.join(packagedir,
"version.cmt")
61 if os.path.exists(ver):
62 current = open(ver).read().strip()
63 if current != newversion:
64 open(ver,
"w").write(newversion +
"\n")
66 cml = os.path.normpath(os.path.join(packagedir,
"..",
"CMakeLists.txt"))
68 if "GaudiKernel" in packagedir:
69 cml = os.path.normpath(os.path.join(packagedir,
"..",
"src",
"Util",
"CMakeLists.txt"))
73 _use_pattern = re.compile(
r"^\s*use\s*(\w+)\s*(v[0-9]+r[0-9]+(?:p[0-9]+)?)\s*(\w+)?\s*$")
78 m = _use_pattern.match(l)
80 versions[m.group(1)] = m.group(2)
84 changelog_entry = re.compile(
r'^(! [0-9]{4}-[0-9]{2}-[0-9]{2} -)|!?============')
85 separator_entry = re.compile(
r'^!?============')
88 for l
in open(filename):
90 if state ==
"searching":
91 if changelog_entry.match(l):
95 if not separator_entry.match(l):
100 while notes
and not notes[-1].strip(): notes.pop()
101 return "".join(notes)
104 changelog_entry = re.compile(
r'^(! [0-9]{4}-[0-9]{2}-[0-9]{2} -)|============')
105 title =
" %s %s " % (pkg, version)
106 letf_chars = (78 - len(title)) / 2
107 right_chars = 78 - letf_chars - len(title)
108 separator = (
"=" * letf_chars) + title + (
"=" * right_chars) +
"\n"
111 for l
in open(filename):
114 if changelog_entry.match(l):
115 out.append(separator)
120 open(filename,
"w").writelines(out)
122 print "Warning: could not update release.notes in %s" % pkg
127 m = re.search(
"use\s*LCGCMT\s*LCGCMT_(\S*)",open(os.path.join(
"..",
"..",
"cmt",
"project.cmt")).read())
129 LCGCMTVers = m.group(1)
130 print "Using LCGCMT", LCGCMTVers
132 print "Cannot find LCGCMT version"
137 all_packages_tmp = []
138 exec(os.popen(
r"""cmt broadcast 'echo "all_packages_tmp.append((\"<package>\"", \"$PWD\""))"'""",
"r").read())
139 all_packages_names = []
141 for k,v
in all_packages_tmp:
142 all_packages_names.append(k)
146 special_packages = [
"Gaudi",
"GaudiExamples",
"GaudiSys",
"GaudiRelease"]
150 new_version = raw_input(
"The old version of the project is %s, which is the new one? " % old_version)
156 for pkg
in all_packages_names:
157 reqfile = os.path.join(all_packages[pkg],
"requirements")
158 relnotefile = os.path.join(all_packages[pkg],
"..",
"doc",
"release.notes")
160 if os.path.exists(relnotefile):
163 release_notes[pkg] =
""
164 if pkg
in special_packages:
165 new_versions[pkg] = new_version
167 if release_notes[pkg]:
168 new_versions[pkg] = raw_input(
"\nThe old version of %s is %s, this are the changes:\n%s\nWhich version you want (old is %s)? " % (pkg, old_versions[pkg], release_notes[pkg], old_versions[pkg]))
170 new_versions[pkg] = old_versions[pkg]
172 if new_versions[pkg] != old_versions[pkg]:
174 if os.path.exists(relnotefile):
178 reqfile = os.path.join(all_packages[
"GaudiRelease"],
"requirements")
180 for l
in open(reqfile):
181 sl = l.strip().split()
182 if sl
and sl[0] ==
"use":
183 if sl[1]
in new_versions:
184 if sl[2] != new_versions[sl[1]]:
185 l = l.replace(sl[2], new_versions[sl[1]])
187 open(reqfile,
"w").writelines(out)
191 new_lines.append(
"<!-- ====================================================================== -->")
192 data = {
"vers": new_version,
"date": time.strftime(
"%Y-%m-%d") }
193 new_lines.append(
'<h2><a name="%(vers)s">Gaudi %(vers)s</a> (%(date)s)</h2>' % data)
194 data = {
"vers": LCGCMTVers }
195 new_lines.append(
'<h3>Externals version: <a href="http://lcgsoft.cern.ch/index.py?page=cfg_overview&cfg=%(vers)s">LCGCMT_%(vers)s</a></h3>' % data)
196 new_lines.append(
"<h3>General Changes</h3>")
197 new_lines.append(
'<ul>\n<li><br/>\n (<span class="author"></span>)</li>\n</ul>')
198 new_lines.append(
"<h3>Packages Changes</h3>")
199 new_lines.append(
"<ul>")
200 for pkg
in all_packages_names:
201 if release_notes[pkg]:
202 new_lines.append(
'<li>%s (%s):\n<ul>\n<li><br/>\n (<span class="author"></span>)</li>\n</ul>\n<pre>'%(pkg,new_versions[pkg]))
203 new_lines.append(release_notes[pkg].replace(
'&',
'&') \
204 .replace(
'<',
'<') \
205 .replace(
'>',
'>') +
"</pre>")
206 new_lines.append(
"</li>")
207 new_lines.append(
"</ul>")
209 global_rel_notes = os.path.join(
"..",
"doc",
"release.notes.html")
211 separator = re.compile(
"<!-- =+ -->")
213 for l
in open(global_rel_notes):
214 if not block_added
and separator.match(l.strip()):
215 out.append(
"\n".join(new_lines) +
"\n")
218 open(global_rel_notes,
"w").writelines(out)
221 global_cmakelists = os.path.join(
"..",
"..",
"CMakeLists.txt")
223 for l
in open(global_cmakelists):
224 if l.strip().startswith(
'gaudi_project'):
225 l =
'gaudi_project(Gaudi %s)\n' % new_version
227 open(global_cmakelists,
"w").writelines(out)
229 if __name__ ==
'__main__':
def extract_recent_rel_notes
def add_release_separator_bar