"CoDemux": "codemux",
"NodeManager": "nodemanager",
"NodeUpdate": "nodeupdate",
- "Monitor": "monitor",
-
- #we keep planetlab modules in a sub-directory
- "planetlab/PLEWWW": "planetlab/plewww",
- "planetlab/PLCAPI": "planetlab/plcapi",
- "planetlab/BootManager": "planetlab/bootmanager",
- "planetlab/BootCD": "planetlab/bootcd",
- "planetlab/VserverReference": "planetlab/vserver-reference",
- "planetlab/BootstrapFS": "planetlab/bootstrapfs",
- "planetlab/MyPLC": "planetlab/myplc",
- "planetlab/CoDemux": "planetlab/codemux",
- "planetlab/NodeManager": "planetlab/nodemanager",
- "planetlab/NodeUpdate": "planetlab/nodeupdate"
-
+ "Monitor": "monitor"
}
def svn_to_git_name(module):
for line in out.split('\n'):
if line.startswith("Repository Root:"):
root = line.split()[2].strip()
- return "%s/%s" % (root, self.pathname())
+ return "%s/%s" % (root, self.name())
@classmethod
def checkout(cls, remote, local, options, recursive=False):
def gitweb(self):
c = Command("git show | grep commit | awk '{print $2;}'", self.options)
out = self.__run_in_repo(c.output_of).strip()
- return "http://git.onelab.eu/?p=%s.git;a=commit;h=%s" % (self.pathname(), out)
+ return "http://git.onelab.eu/?p=%s.git;a=commit;h=%s" % (self.name(), out)
def repo_root(self):
c = Command("git remote show origin", self.options)
cls.prompt_config_option(key, message, default)
# for parsing module spec name:branch
- matcher_branch_spec=re.compile("\A(?P<name>[\w\.-\/]+):(?P<branch>[\w\.-]+)\Z")
+ matcher_branch_spec=re.compile("\A(?P<name>[\w\.-]+):(?P<branch>[\w\.-]+)\Z")
# special form for tagged module - for Build
- matcher_tag_spec=re.compile("\A(?P<name>[\w\.-\/]+)@(?P<tagname>[\w\.-]+)\Z")
+ matcher_tag_spec=re.compile("\A(?P<name>[\w\.-]+)@(?P<tagname>[\w\.-]+)\Z")
# parsing specfiles
matcher_rpm_define=re.compile("%(define|global)\s+(\S+)\s+(\S*)\s*")
def __init__ (self,module_spec,options):
# parse module spec
- self.pathname, branch_or_tagname, module_type = self.parse_module_spec(module_spec)
- self.name = os.path.basename(self.pathname)
+ self.name, branch_or_tagname, module_type = self.parse_module_spec(module_spec)
if module_type == "branch":
self.branch=branch_or_tagname
self.name = svn_to_git_name(self.name)
self.options=options
- self.module_dir="%s/%s"%(options.workdir,self.pathname)
+ self.module_dir="%s/%s"%(options.workdir,self.name)
self.repository = None
self.build = None
def friendly_name (self):
if hasattr(self,'branch'):
- return "%s:%s"%(self.pathname,self.branch)
+ return "%s:%s"%(self.name,self.branch)
elif hasattr(self,'tagname'):
- return "%s@%s"%(self.pathname,self.tagname)
+ return "%s@%s"%(self.name,self.tagname)
else:
- return self.pathname
+ return self.name
@classmethod
def git_remote_dir (cls, name):
Module.config[key]=value
f.close()
- # owerride config variables using options.
- if options.build_module:
- Module.config['build'] = options.build_module
-
if not os.path.isdir (options.workdir):
print "Cannot find",options.workdir,"let's create it"
Command("mkdir -p %s" % options.workdir, options).run_silent()
print 'Checking for',self.module_dir
if not os.path.isdir (self.module_dir):
- if Repository.has_moved_to_git(self.pathname, Module.config):
- self.repository = GitRepository.checkout(self.git_remote_dir(self.pathname),
+ if Repository.has_moved_to_git(self.name, Module.config):
+ self.repository = GitRepository.checkout(self.git_remote_dir(self.name),
self.module_dir,
self.options)
else:
self.repository = Repository(self.module_dir, self.options)
if self.repository.type == "svn":
# check if module has moved to git
- if Repository.has_moved_to_git(self.pathname, Module.config):
+ if Repository.has_moved_to_git(self.name, Module.config):
Command("rm -rf %s" % self.module_dir, self.options).run_silent()
self.init_module_dir()
# check if we have the required branch/tag
if level2:
return level2[0]
- raise Exception, 'Cannot guess specfile for module %s -- patterns were %s or %s'%(self.pathname,pattern1,pattern2)
+ raise Exception, 'Cannot guess specfile for module %s -- patterns were %s or %s'%(self.name,pattern1,pattern2)
def all_specnames (self):
level1=glob("%s/*.spec" % self.module_dir)
# brute-force : change uncommented lines that define <module>-SVNPATH
else:
if self.options.verbose:
- print 'Searching for -SVNPATH or -GITPATH lines referring to /%s/\n\tin %s .. '%(self.pathname,tagsfile),
+ print 'Searching for -SVNPATH or -GITPATH lines referring to /%s/\n\tin %s .. '%(self.name,tagsfile),
pattern="\A\s*%s-(SVNPATH|GITPATH)\s*(=|:=)\s*(?P<url_main>[^\s]+)/%s[^\s]+"\
%(self.name,self.name)
matcher_module=re.compile(pattern)
if attempt:
if line.find("-GITPATH") >= 0:
modulepath = "%s-GITPATH"%self.name
- replacement = "%-32s:= %s/%s.git@%s\n"%(modulepath,attempt.group('url_main'),self.pathname,newname)
+ replacement = "%-32s:= %s/%s.git@%s\n"%(modulepath,attempt.group('url_main'),self.name,newname)
else:
modulepath = "%s-SVNPATH"%self.name
replacement = "%-32s:= %s/%s/tags/%s\n"%(modulepath,attempt.group('url_main'),self.name,newname)
# checking for diffs
diff_output = self.repository.diff_with_tag(old_tag_name)
if len(diff_output) == 0:
- if not prompt ("No pending difference in module %s, want to tag anyway"%self.pathname,False):
+ if not prompt ("No pending difference in module %s, want to tag anyway"%self.name,False):
return
# side effect in trunk's specfile
if self.options.list:
if diff_output:
- print self.pathname
+ print self.name
else:
thename=self.friendly_name()
do_print=False
** THIS MUST NOT ** be your usual working directory""")
parser.add_option("-F","--fast-checks",action="store_true",dest="fast_checks",default=False,
help="skip safety checks, such as svn updates -- use with care")
- parser.add_option("-B","--build-module",action="store",dest="build_module",default=None,
- help="specify a build module to owerride the one in the CONFIG")
# default verbosity depending on function - temp
verbose_modes= ['tag', 'sync', 'branch']