3 Small script to prepare the tags and the distribution special directory for a
5 See https://twiki.cern.ch/twiki/bin/view/Gaudi/GaudiSVNRepository for a
6 description of the repository structure.
8 __author__ =
"Marco Clemencic <Marco.Clemencic@cern.ch>"
10 import os, re, sys, tempfile, shutil
11 from subprocess
import Popen, PIPE
12 from ConfigParser
import ConfigParser
14 def svn(*args, **kwargs):
15 print "> svn",
" ".join(args)
16 return apply(Popen, ([
"svn"] + list(args),), kwargs)
19 return svn(
"ls", url, stdout = PIPE).communicate()[0].splitlines()
22 return url.rsplit(
"/", 1)[-1]
25 return url.rsplit(
"/", 1)[1]
28 d,b = url.rsplit(
"/", 1)
29 l = [x.rstrip(
"/")
for x
in svn_ls(d)]
33 def checkout_level(base):
34 dirs = [
"%s/%s" % (base, d)
for d
in svn_ls(base)
if d.endswith(
"/")]
35 apply(svn, [
"up",
"-N"] + dirs).wait()
39 svn(
"co",
"-N", url, root).wait()
42 svn(
"up",
"-N", proj).wait()
43 br = [proj] + branch.split(
"/")
44 for base
in [
"/".join(br[:n+1])
for n
in range(len(br))]:
46 checkout_level(proj +
"/tags")
51 from optparse
import OptionParser
52 parser = OptionParser()
53 parser.add_option(
"--pre", action =
"store_true",
54 help =
"Create -pre tags instead of final tags.")
55 parser.add_option(
"-b",
"--branch",
56 help =
"Use the given (global) branch as source for the tags instead of the trunk")
57 opts, args = parser.parse_args()
59 opts.branch =
"/".join([
"branches",
"GAUDI", opts.branch])
63 url =
"svn+ssh://svn.cern.ch/reps/gaudi"
65 container =
"GaudiRelease"
66 project_info = ConfigParser()
67 project_info.optionxform = str
68 project_info.read(
'project.info')
69 packages = dict(project_info.items(
'Packages'))
70 tempdir = tempfile.mkdtemp()
77 pvers =
"%s_%s" % (proj.upper(), packages[container])
80 ptagdir =
"%s/tags/%s/%s" % (proj, proj.upper(), pvers)
82 svn(
'cp',
'/'.join([proj, opts.branch]), ptagdir).wait()
85 tag_re = re.compile(
r"^v(\d+)r(\d+)(?:p(\d+))?$")
88 pktagdir =
"%s/tags/%s/%s" % (proj, p, tag)
92 make_tag = no_tag
or (opts.pre
and no_tag
and not svn_exists(pktagdir +
"-pre"))
96 svn(
"cp",
"/".join([proj, opts.branch, p]), pktagdir).wait()
98 tagElements = tag_re.match(tag)
100 tagElements =
"-".join([
"%02d" % int(el
or "0")
for el
in tagElements.groups() ])
101 pktagdir =
"%s/tags/%s/%s-%s" % (proj, p, p, tagElements)
102 svn(
"cp",
"/".join([proj, opts.branch, p]), pktagdir).wait()
105 svn(
"up",
"--depth=empty", pktagdir).wait()
110 shutil.rmtree(tempdir, ignore_errors =
True)
114 if __name__ ==
'__main__':
NamedRange_< CONTAINER > range(const CONTAINER &cnt, const std::string &name)
simple function to create the named range form arbitrary container
def checkout_structure(url, proj, branch)