1
0
mirror of https://github.com/openSUSE/osc.git synced 2025-01-14 17:46:17 +01:00

store list of repos for offline use

This commit is contained in:
Ludwig Nussel 2010-04-29 14:25:38 +02:00
parent 95a6643769
commit cfeee1c95d

View File

@ -3297,12 +3297,24 @@ Please submit there instead, or use --nodevelproject to force direct submission.
arg_arch = arg_arch or osc.build.hostarch arg_arch = arg_arch or osc.build.hostarch
if not noinit: repositories = []
# store list of repos for potential offline use
repolistfile = os.path.join(os.getcwd(), osc.core.store, "_build_repositories")
if noinit:
if os.path.exists(repolistfile):
f = open(repolistfile, 'r')
repositories = [ l.strip()for l in f.readlines()]
f.close()
else:
project = alternative_project or store_read_project('.') project = alternative_project or store_read_project('.')
repositories = get_repositories_of_project(store_read_apiurl('.'), project) repositories = get_repositories_of_project(store_read_apiurl('.'), project)
if not len(repositories): if not len(repositories):
raise oscerr.WrongArgs('no repositories defined for project \'%s\'' % project) raise oscerr.WrongArgs('no repositories defined for project \'%s\'' % project)
if not arg_repository: f = open(repolistfile, 'w')
f.write('\n'.join(repositories) + '\n')
f.close()
if not arg_repository and len(repositories):
# Use a default value from config, but just even if it's available # Use a default value from config, but just even if it's available
# unless try standard, or openSUSE_Factory # unless try standard, or openSUSE_Factory
arg_repository = repositories[-1] arg_repository = repositories[-1]
@ -3310,10 +3322,11 @@ Please submit there instead, or use --nodevelproject to force direct submission.
if repository in repositories: if repository in repositories:
arg_repository = repository arg_repository = repository
break break
if not arg_repository in repositories:
raise oscerr.WrongArgs('%s is not a valid repository, use one of: %s' % (arg_repository, ', '.join(repositories))) if not arg_repository:
elif not arg_repository:
raise oscerr.WrongArgs('please specify a repository') raise oscerr.WrongArgs('please specify a repository')
elif not arg_repository in repositories:
raise oscerr.WrongArgs('%s is not a valid repository, use one of: %s' % (arg_repository, ', '.join(repositories)))
# can be implemented using # can be implemented using
# reduce(lambda x, y: x + y, (glob.glob(x) for x in ('*.spec', '*.dsc', '*.kiwi'))) # reduce(lambda x, y: x + y, (glob.glob(x) for x in ('*.spec', '*.dsc', '*.kiwi')))