1
0
mirror of https://github.com/openSUSE/osc.git synced 2025-01-27 15:06:15 +01:00

core.addFiles: improve usability a bit (as suggested by darix)

The previous errors are in fact just warnings.
This commit is contained in:
Marcus Huewe 2016-08-26 16:20:53 +02:00
parent 716560f628
commit 00c8876791

View File

@ -3062,12 +3062,19 @@ def expand_proj_pack(args, idx=0, howmany=0):
return args return args
def findpacs(files, progress_obj=None): def findpacs(files, progress_obj=None, fatal=True):
"""collect Package objects belonging to the given files """collect Package objects belonging to the given files
and make sure each Package is returned only once""" and make sure each Package is returned only once"""
pacs = [] pacs = []
no_pacs = []
for f in files: for f in files:
p = filedir_to_pac(f, progress_obj) try:
p = filedir_to_pac(f, progress_obj)
except oscerr.OscBaseError as e:
if fatal:
raise e
no_pacs.append(f)
continue
known = None known = None
for i in pacs: for i in pacs:
if i.name == p.name: if i.name == p.name:
@ -3077,6 +3084,8 @@ def findpacs(files, progress_obj=None):
i.merge(p) i.merge(p)
else: else:
pacs.append(p) pacs.append(p)
if not fatal:
return pacs, no_pacs
return pacs return pacs
@ -6742,15 +6751,17 @@ def addFiles(filenames, prj_obj = None):
prj_apiurl = store_read_apiurl(prj_dir, defaulturl=False) prj_apiurl = store_read_apiurl(prj_dir, defaulturl=False)
Package.init_package(prj_apiurl, prj_name, pac_dir, filename) Package.init_package(prj_apiurl, prj_name, pac_dir, filename)
elif is_package_dir(filename) and conf.config['do_package_tracking']: elif is_package_dir(filename) and conf.config['do_package_tracking']:
raise oscerr.PackageExists(store_read_project(filename), store_read_package(filename), print('osc: warning: \'%s\' is already under version control' % filename)
'osc: warning: \'%s\' is already under version control' % filename) pacs.remove(filename)
elif os.path.isdir(filename) and is_project_dir(prj_dir): elif os.path.isdir(filename) and is_project_dir(prj_dir):
raise oscerr.WrongArgs('osc: cannot add a directory to a project unless ' \ raise oscerr.WrongArgs('osc: cannot add a directory to a project unless ' \
'\'do_package_tracking\' is enabled in the configuration file') '\'do_package_tracking\' is enabled in the configuration file')
elif os.path.isdir(filename): elif os.path.isdir(filename):
print('skipping directory \'%s\'' % filename) print('skipping directory \'%s\'' % filename)
pacs.remove(filename) pacs.remove(filename)
pacs = findpacs(pacs) pacs, no_pacs = findpacs(pacs, fatal=False)
for filename in no_pacs:
print('osc: warning: \'%s\' cannot be associated to a package' % filename)
for pac in pacs: for pac in pacs:
if conf.config['do_package_tracking'] and not pac.todo: if conf.config['do_package_tracking'] and not pac.todo:
prj = prj_obj or Project(os.path.dirname(pac.absdir), False) prj = prj_obj or Project(os.path.dirname(pac.absdir), False)
@ -6770,7 +6781,11 @@ def addFiles(filenames, prj_obj = None):
if filename in pac.excluded: if filename in pac.excluded:
print('osc: warning: \'%s\' is excluded from a working copy' % filename, file=sys.stderr) print('osc: warning: \'%s\' is excluded from a working copy' % filename, file=sys.stderr)
continue continue
pac.addfile(filename) try:
pac.addfile(filename)
except oscerr.PackageFileConflict as e:
fname = os.path.join(getTransActPath(pac.dir), filename)
print('osc: warning: \'%s\' is already under version control' % fname)
def getPrjPacPaths(path): def getPrjPacPaths(path):
""" """