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

Merge pull request #1164 from dirkmueller/handle_dot_expansion_in_more_commands

expand "." in copypac and rdelete as referencing the workdir project
This commit is contained in:
Daniel Mach 2022-10-12 08:48:52 +02:00 committed by GitHub
commit 10ea7b50f4
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -18,6 +18,7 @@ import time
import traceback import traceback
from functools import cmp_to_key from functools import cmp_to_key
from operator import itemgetter from operator import itemgetter
from pathlib import Path
from urllib.parse import urlsplit from urllib.parse import urlsplit
from urllib.error import HTTPError from urllib.error import HTTPError
@ -74,6 +75,14 @@ class Osc(cmdln.Cmdln):
def get_version(self): def get_version(self):
return get_osc_version() return get_osc_version()
def _expand_as_project_name(self, arg):
if arg == '.':
if is_package_dir(Path.cwd()) or is_project_dir(Path.cwd()):
arg = store_read_project(Path.cwd())
else:
raise oscerr.WrongArgs('No working directory')
return arg
def _process_project_name(self, project): def _process_project_name(self, project):
if isinstance(project, str): if isinstance(project, str):
return project.replace(conf.config['project_separator'], ':') return project.replace(conf.config['project_separator'], ':')
@ -354,11 +363,9 @@ class Osc(cmdln.Cmdln):
if project == '/': if project == '/':
project = None project = None
if project == '.': if project == '.':
project = self._expand_as_project_name(project)
cwd = os.getcwd() cwd = os.getcwd()
if is_project_dir(cwd): if is_package_dir(cwd):
project = store_read_project(cwd)
elif is_package_dir(cwd):
project = store_read_project(cwd)
package = store_read_package(cwd) package = store_read_package(cwd)
project = self._process_project_name(project) project = self._process_project_name(project)
if len(args) > 1: if len(args) > 1:
@ -3001,6 +3008,9 @@ Please submit there instead, or use --nodevelproject to force direct submission.
The DESTPAC name is optional; the source packages' name will be used if The DESTPAC name is optional; the source packages' name will be used if
DESTPAC is omitted. DESTPAC is omitted.
If SOURCEPRJ or DESTPRJ is '.' it will be expanded to the PRJ of the current
directory.
usage: usage:
osc copypac SOURCEPRJ SOURCEPAC DESTPRJ [DESTPAC] osc copypac SOURCEPRJ SOURCEPAC DESTPRJ [DESTPAC]
""" """
@ -3010,14 +3020,13 @@ Please submit there instead, or use --nodevelproject to force direct submission.
if not args or len(args) < 3: if not args or len(args) < 3:
self.argparse_error("Incorrect number of arguments.") self.argparse_error("Incorrect number of arguments.")
src_project = self._process_project_name(args[0]) src_project = self._process_project_name(self._expand_as_project_name(args[0]))
src_package = args[1] src_package = args[1]
dst_project = self._process_project_name(args[2]) dst_project = self._process_project_name(self._expand_as_project_name(args[2]))
if len(args) > 3: if len(args) > 3:
dst_package = args[3] dst_package = args[3]
else: else:
dst_package = src_package dst_package = src_package
src_apiurl = conf.config['apiurl'] src_apiurl = conf.config['apiurl']
if opts.to_apiurl: if opts.to_apiurl:
dst_apiurl = conf.config['apiurl_aliases'].get(opts.to_apiurl, opts.to_apiurl) dst_apiurl = conf.config['apiurl_aliases'].get(opts.to_apiurl, opts.to_apiurl)
@ -3697,7 +3706,7 @@ Please submit there instead, or use --nodevelproject to force direct submission.
well use \'--force\' switch. well use \'--force\' switch.
usage: usage:
osc rdelete [-r] [-f] PROJECT [PACKAGE] osc rdelete [-r] [-f] PROJECT|. [PACKAGE]
""" """
args = slash_split(args) args = slash_split(args)
@ -3705,7 +3714,7 @@ Please submit there instead, or use --nodevelproject to force direct submission.
raise oscerr.WrongArgs('Wrong number of arguments') raise oscerr.WrongArgs('Wrong number of arguments')
apiurl = self.get_api_url() apiurl = self.get_api_url()
prj = self._process_project_name(args[0]) prj = self._process_project_name(self._expand_as_project_name(args[0]))
msg = '' msg = ''
if opts.message: if opts.message: