1
0
mirror of https://github.com/openSUSE/osc.git synced 2025-01-15 01:56:17 +01:00
* make_dir() and checkout_package() got a new optionally 'prj_dir'     parameter. This parameter specifies in which dir we want to create new project/package dirs.
This commit is contained in:
Marcus Hüwe 2008-04-02 15:30:44 +00:00
parent 06fb595140
commit a3f948dede
2 changed files with 28 additions and 34 deletions

View File

@ -819,7 +819,7 @@ class Osc(cmdln.Cmdln):
elif package: elif package:
checkout_package(conf.config['apiurl'], project, package, checkout_package(conf.config['apiurl'], project, package,
rev, expand_link=opts.expand_link) rev, expand_link=opts.expand_link, prj_dir=project)
elif project: elif project:
if not os.path.exists(project): if not os.path.exists(project):
@ -835,7 +835,7 @@ class Osc(cmdln.Cmdln):
# all packages # all packages
for package in meta_get_packagelist(conf.config['apiurl'], project): for package in meta_get_packagelist(conf.config['apiurl'], project):
checkout_package(conf.config['apiurl'], project, package, checkout_package(conf.config['apiurl'], project, package,
expand_link=opts.expand_link) expand_link=opts.expand_link, prj_dir=project)
else: else:
print >>sys.stderr, 'Missing argument.' print >>sys.stderr, 'Missing argument.'
self.do_help([None, 'checkout']) self.do_help([None, 'checkout'])

View File

@ -256,14 +256,9 @@ class Project:
sys.exit(1) sys.exit(1)
else: else:
print 'checking out new package %s' % pac print 'checking out new package %s' % pac
olddir = os.getcwd() checkout_package(self.apiurl, self.name, pac, \
#os.chdir(os.pardir) pathname=getTransActPath(os.path.join(self.dir, pac)), \
os.chdir(os.path.join(self.absdir, os.pardir)) prj_obj=self, prj_dir=self.dir)
#checkout_package(self.apiurl, self.name, pac, pathname = os.path.normpath(os.path.join(self.dir, pac)))
checkout_package(self.apiurl, self.name, pac, pathname = getTransActPath(os.path.join(self.dir, pac)), prj_obj=self)
os.chdir(olddir)
#self.new_package_entry(pac, ' ')
#self.pacs_have.append(pac)
def set_state(self, pac, state): def set_state(self, pac, state):
node = self.get_package_node(pac) node = self.get_package_node(pac)
@ -392,11 +387,8 @@ class Project:
state = self.get_state(pac) state = self.get_state(pac)
if pac in self.pacs_broken: if pac in self.pacs_broken:
if self.get_state(pac) != 'A': if self.get_state(pac) != 'A':
olddir = self.absdir
os.chdir(os.path.join(self.absdir, os.pardir))
checkout_package(self.apiurl, self.name, pac, checkout_package(self.apiurl, self.name, pac,
pathname=getTransActPath(os.path.join(self.dir, pac)), prj_obj=self) pathname=getTransActPath(os.path.join(self.dir, pac)), prj_obj=self, prj_dir=self.dir)
os.chdir(olddir)
elif state == ' ': elif state == ' ':
# do a simple update # do a simple update
p = Package(os.path.join(self.dir, pac)) p = Package(os.path.join(self.dir, pac))
@ -414,11 +406,8 @@ class Project:
elif state == 'D': elif state == 'D':
# TODO: Package::update has to fixed to behave like svn does # TODO: Package::update has to fixed to behave like svn does
if pac in self.pacs_broken: if pac in self.pacs_broken:
olddir = self.absdir
os.chdir(os.path.join(self.absdir, os.pardir))
checkout_package(self.apiurl, self.name, pac, checkout_package(self.apiurl, self.name, pac,
pathname=getTransActPath(os.path.join(self.dir, pac)), prj_obj=self) pathname=getTransActPath(os.path.join(self.dir, pac)), prj_obj=self, prj_dir=self.dir)
os.chdir(olddir)
else: else:
Package(os.path.join(self.dir, pac)).update() Package(os.path.join(self.dir, pac)).update()
elif state == 'A' and pac in self.pacs_available: elif state == 'A' and pac in self.pacs_available:
@ -2217,29 +2206,35 @@ def pretty_diff(apiurl,
return f.read() return f.read()
def make_dir(apiurl, project, package, pathname): def make_dir(apiurl, project, package, pathname=None, prj_dir=None):
#print "creating directory '%s'" % project """
if not os.path.exists(project): creates the plain directory structure for a package dir.
print statfrmt('A', project) The 'apiurl' parameter is needed for the project dir initialization.
init_project_dir(apiurl, project, project) The 'project' and 'package' parameters specify the name of the
#print "creating directory '%s/%s'" % (project, package) project and the package. The optional 'pathname' parameter is used
if not pathname: for printing out the message that a new dir was created (default: 'prj_dir/package').
pathname = os.path.join(project, package) The optional 'prj_dir' parameter specifies the path to the project dir (default: 'project').
if not os.path.exists(os.path.join(project, package)): """
prj_dir = prj_dir or project
pathname = pathname or getTransActPath(os.path.join(prj_dir, package))
if not os.path.exists(prj_dir):
print statfrmt('A', prj_dir)
init_project_dir(apiurl, prj_dir, project)
if not os.path.exists(os.path.join(prj_dir, package)):
print statfrmt('A', pathname) print statfrmt('A', pathname)
os.mkdir(os.path.join(project, package)) os.mkdir(os.path.join(prj_dir, package))
os.mkdir(os.path.join(project, package, store)) os.mkdir(os.path.join(prj_dir, package, store))
return(os.path.join(project, package)) return(os.path.join(prj_dir, package))
def checkout_package(apiurl, project, package, def checkout_package(apiurl, project, package,
revision=None, pathname=None, prj_obj=None, revision=None, pathname=None, prj_obj=None,
expand_link=False): expand_link=False, prj_dir=os.getcwd()):
olddir = os.getcwd() olddir = os.getcwd()
if not pathname: if not pathname:
pathname = os.path.join(project, package) pathname = getTransActPath(os.path.join(prj_dir, package))
path = (quote_plus(project), quote_plus(package)) path = (quote_plus(project), quote_plus(package))
if meta_exists(metatype='pkg', path_args=path, create_new=False, apiurl=apiurl) == None: if meta_exists(metatype='pkg', path_args=path, create_new=False, apiurl=apiurl) == None:
@ -2253,8 +2248,7 @@ def checkout_package(apiurl, project, package,
# it is a link - thus, we use the xsrcmd5 as the revision to be # it is a link - thus, we use the xsrcmd5 as the revision to be
# checked out # checked out
revision = x revision = x
os.chdir(make_dir(apiurl, project, package, pathname, prj_dir))
os.chdir(make_dir(apiurl, project, package, pathname))
init_package_dir(apiurl, project, package, store, revision) init_package_dir(apiurl, project, package, store, revision)
os.chdir(os.pardir) os.chdir(os.pardir)
p = Package(package) p = Package(package)