mirror of
https://github.com/openSUSE/osc.git
synced 2025-01-25 22:36:13 +01:00
checkout_package: Use pathlib.Path
Modify it to use pathlib.Path along with its callers. Some str(path) was
necessary to avoid having a large changeset.
It addresses #1258 and continues the work started in
bac162a712
.
This commit is contained in:
parent
83b1e22e52
commit
1d96c6eb2a
@ -1024,7 +1024,7 @@ class Osc(cmdln.Cmdln):
|
|||||||
filename = "_patchinfo"
|
filename = "_patchinfo"
|
||||||
else:
|
else:
|
||||||
checkout_package(apiurl, project, patchinfo, prj_dir=project_dir)
|
checkout_package(apiurl, project, patchinfo, prj_dir=project_dir)
|
||||||
filename = project_dir + "/" + patchinfo + "/_patchinfo"
|
filename = project_dir / patchinfo / "/_patchinfo"
|
||||||
|
|
||||||
run_editor(filename)
|
run_editor(filename)
|
||||||
|
|
||||||
@ -2917,8 +2917,7 @@ Please submit there instead, or use --nodevelproject to force direct submission.
|
|||||||
raise oscerr.WrongArgs('\'checkout\' not possible (request has no \'submit\' actions)')
|
raise oscerr.WrongArgs('\'checkout\' not possible (request has no \'submit\' actions)')
|
||||||
for action in sr_actions:
|
for action in sr_actions:
|
||||||
checkout_package(apiurl, action.src_project, action.src_package,
|
checkout_package(apiurl, action.src_project, action.src_package,
|
||||||
action.src_rev, expand_link=True, prj_dir=action.src_project)
|
action.src_rev, expand_link=True, prj_dir=Path(action.src_project))
|
||||||
|
|
||||||
else:
|
else:
|
||||||
state_map = {'reopen': 'new', 'accept': 'accepted', 'decline': 'declined', 'wipe': 'deleted', 'revoke': 'revoked', 'supersede': 'superseded'}
|
state_map = {'reopen': 'new', 'accept': 'accepted', 'decline': 'declined', 'wipe': 'deleted', 'revoke': 'revoked', 'supersede': 'superseded'}
|
||||||
# Change review state only
|
# Change review state only
|
||||||
@ -3759,7 +3758,7 @@ Please submit there instead, or use --nodevelproject to force direct submission.
|
|||||||
# all packages
|
# all packages
|
||||||
for package in meta_get_packagelist(apiurl, result):
|
for package in meta_get_packagelist(apiurl, result):
|
||||||
try:
|
try:
|
||||||
checkout_package(apiurl, result, package, expand_link=True, prj_dir=result)
|
checkout_package(apiurl, result, package, expand_link=True, prj_dir=Path(result))
|
||||||
except:
|
except:
|
||||||
print('Error while checkout package:\n', package, file=sys.stderr)
|
print('Error while checkout package:\n', package, file=sys.stderr)
|
||||||
|
|
||||||
@ -3914,7 +3913,7 @@ Please submit there instead, or use --nodevelproject to force direct submission.
|
|||||||
package = targetpkg or args[1]
|
package = targetpkg or args[1]
|
||||||
if opts.checkout:
|
if opts.checkout:
|
||||||
checkout_package(apiurl, targetprj, package, server_service_files=False,
|
checkout_package(apiurl, targetprj, package, server_service_files=False,
|
||||||
expand_link=True, prj_dir=targetprj)
|
expand_link=True, prj_dir=Path(targetprj))
|
||||||
if conf.config['verbose']:
|
if conf.config['verbose']:
|
||||||
print('Note: You can use "osc delete" or "osc submitpac" when done.\n')
|
print('Note: You can use "osc delete" or "osc submitpac" when done.\n')
|
||||||
else:
|
else:
|
||||||
@ -4687,7 +4686,8 @@ Please submit there instead, or use --nodevelproject to force direct submission.
|
|||||||
m = re.match(r"obs://([^/]+)/(\S+)/([^/]+)/([A-Fa-f\d]+)\-([^:]*)(:\S+)?", args[0])
|
m = re.match(r"obs://([^/]+)/(\S+)/([^/]+)/([A-Fa-f\d]+)\-([^:]*)(:\S+)?", args[0])
|
||||||
if m and len(args) == 1:
|
if m and len(args) == 1:
|
||||||
apiurl = "https://" + m.group(1)
|
apiurl = "https://" + m.group(1)
|
||||||
project = project_dir = m.group(2)
|
project = m.group(2)
|
||||||
|
project_dir = Path(project)
|
||||||
# platform = m.group(3)
|
# platform = m.group(3)
|
||||||
opts.revision = m.group(4)
|
opts.revision = m.group(4)
|
||||||
package = m.group(5)
|
package = m.group(5)
|
||||||
@ -4698,7 +4698,8 @@ Please submit there instead, or use --nodevelproject to force direct submission.
|
|||||||
project = package = filename = None
|
project = package = filename = None
|
||||||
apiurl = self.get_api_url()
|
apiurl = self.get_api_url()
|
||||||
try:
|
try:
|
||||||
project = project_dir = self._process_project_name(args[0])
|
project = self._process_project_name(args[0])
|
||||||
|
project_dir = Path(project)
|
||||||
package = args[1]
|
package = args[1]
|
||||||
filename = args[2]
|
filename = args[2]
|
||||||
except:
|
except:
|
||||||
@ -4706,7 +4707,7 @@ Please submit there instead, or use --nodevelproject to force direct submission.
|
|||||||
|
|
||||||
if len(args) == 1 and is_project_dir(Path.cwd()):
|
if len(args) == 1 and is_project_dir(Path.cwd()):
|
||||||
project = store_read_project(Path.cwd())
|
project = store_read_project(Path.cwd())
|
||||||
project_dir = str(Path.cwd())
|
project_dir = Path.cwd()
|
||||||
package = args[0]
|
package = args[0]
|
||||||
|
|
||||||
if opts.deleted and package:
|
if opts.deleted and package:
|
||||||
@ -4743,11 +4744,9 @@ Please submit there instead, or use --nodevelproject to force direct submission.
|
|||||||
print_request_list(apiurl, project, package)
|
print_request_list(apiurl, project, package)
|
||||||
|
|
||||||
elif project:
|
elif project:
|
||||||
prj_dir = opts.output_dir if opts.output_dir else project
|
sep = '/' if not opts.output_dir and conf.config['checkout_no_colon'] else conf.config['project_separator']
|
||||||
if not opts.output_dir and conf.config['checkout_no_colon']:
|
chosen_output = opts.output_dir if opts.output_dir else project
|
||||||
prj_dir = prj_dir.replace(':', '/')
|
prj_dir = Path(chosen_output.replace(':', sep))
|
||||||
else:
|
|
||||||
prj_dir = prj_dir.replace(':', conf.config['project_separator'])
|
|
||||||
if os.path.exists(prj_dir):
|
if os.path.exists(prj_dir):
|
||||||
sys.exit('osc: project directory \'%s\' already exists' % prj_dir)
|
sys.exit('osc: project directory \'%s\' already exists' % prj_dir)
|
||||||
|
|
||||||
@ -4759,7 +4758,7 @@ Please submit there instead, or use --nodevelproject to force direct submission.
|
|||||||
if not os.path.isfile('/usr/lib/obs/service/obs_scm_bridge'):
|
if not os.path.isfile('/usr/lib/obs/service/obs_scm_bridge'):
|
||||||
raise oscerr.OscIOError(None, 'Install the obs-scm-bridge package to work on packages managed in scm (git)!')
|
raise oscerr.OscIOError(None, 'Install the obs-scm-bridge package to work on packages managed in scm (git)!')
|
||||||
os.putenv("OSC_VERSION", get_osc_version())
|
os.putenv("OSC_VERSION", get_osc_version())
|
||||||
run_external(['/usr/lib/obs/service/obs_scm_bridge', '--outdir', prj_dir, '--url', scm_url])
|
run_external(['/usr/lib/obs/service/obs_scm_bridge', '--outdir', str(prj_dir), '--url', scm_url])
|
||||||
|
|
||||||
Project.init_project(apiurl, prj_dir, project, conf.config['do_package_tracking'], scm_url=scm_url)
|
Project.init_project(apiurl, prj_dir, project, conf.config['do_package_tracking'], scm_url=scm_url)
|
||||||
print(statfrmt('A', prj_dir))
|
print(statfrmt('A', prj_dir))
|
||||||
|
41
osc/core.py
41
osc/core.py
@ -31,6 +31,7 @@ import time
|
|||||||
from functools import cmp_to_key, total_ordering
|
from functools import cmp_to_key, total_ordering
|
||||||
from http.client import IncompleteRead
|
from http.client import IncompleteRead
|
||||||
from io import StringIO
|
from io import StringIO
|
||||||
|
from pathlib import Path
|
||||||
from typing import Optional, Dict, Union, List, Iterable
|
from typing import Optional, Dict, Union, List, Iterable
|
||||||
from urllib.parse import urlsplit, urlunsplit, urlparse, quote_plus, urlencode, unquote
|
from urllib.parse import urlsplit, urlunsplit, urlparse, quote_plus, urlencode, unquote
|
||||||
from urllib.error import HTTPError
|
from urllib.error import HTTPError
|
||||||
@ -712,7 +713,7 @@ class Project:
|
|||||||
|
|
||||||
`wc_check` : bool
|
`wc_check` : bool
|
||||||
"""
|
"""
|
||||||
self.dir = dir
|
self.dir = Path(dir)
|
||||||
self.absdir = os.path.abspath(dir)
|
self.absdir = os.path.abspath(dir)
|
||||||
self.store = Store(dir)
|
self.store = Store(dir)
|
||||||
self.progress_obj = progress_obj
|
self.progress_obj = progress_obj
|
||||||
@ -1181,7 +1182,7 @@ class Project:
|
|||||||
@staticmethod
|
@staticmethod
|
||||||
def init_project(
|
def init_project(
|
||||||
apiurl: str,
|
apiurl: str,
|
||||||
dir,
|
dir: Path,
|
||||||
project,
|
project,
|
||||||
package_tracking=True,
|
package_tracking=True,
|
||||||
getPackageList=True,
|
getPackageList=True,
|
||||||
@ -5371,7 +5372,7 @@ def checkout_package(
|
|||||||
pathname=None,
|
pathname=None,
|
||||||
prj_obj=None,
|
prj_obj=None,
|
||||||
expand_link=False,
|
expand_link=False,
|
||||||
prj_dir=None,
|
prj_dir: Path=None,
|
||||||
server_service_files=None,
|
server_service_files=None,
|
||||||
service_files=None,
|
service_files=None,
|
||||||
progress_obj=None,
|
progress_obj=None,
|
||||||
@ -5382,20 +5383,19 @@ def checkout_package(
|
|||||||
try:
|
try:
|
||||||
# the project we're in might be deleted.
|
# the project we're in might be deleted.
|
||||||
# that'll throw an error then.
|
# that'll throw an error then.
|
||||||
olddir = os.getcwd()
|
olddir = Path.cwd()
|
||||||
except:
|
except FileNotFoundError:
|
||||||
olddir = os.environ.get("PWD")
|
olddir = Path(os.environ.get("PWD"))
|
||||||
|
|
||||||
if not prj_dir:
|
if not prj_dir:
|
||||||
prj_dir = olddir
|
prj_dir = olddir
|
||||||
elif conf.config['checkout_no_colon']:
|
|
||||||
prj_dir = prj_dir.replace(':', '/')
|
|
||||||
else:
|
else:
|
||||||
prj_dir = prj_dir.replace(':', conf.config['project_separator'])
|
sep = "/" if conf.config['checkout_no_colon'] else conf.config['project_separator']
|
||||||
|
prj_dir = Path(str(prj_dir).replace(':', sep))
|
||||||
|
|
||||||
root_dots = '.'
|
root_dots = Path('.')
|
||||||
if conf.config['checkout_rooted']:
|
if conf.config['checkout_rooted']:
|
||||||
if prj_dir[:1] == '/':
|
if prj_dir.stem == '/':
|
||||||
if conf.config['verbose']:
|
if conf.config['verbose']:
|
||||||
print("checkout_rooted ignored for %s" % prj_dir)
|
print("checkout_rooted ignored for %s" % prj_dir)
|
||||||
# ?? should we complain if not is_project_dir(prj_dir) ??
|
# ?? should we complain if not is_project_dir(prj_dir) ??
|
||||||
@ -5409,27 +5409,25 @@ def checkout_package(
|
|||||||
# do not easily reveal the fact, that they are part of a project path.
|
# do not easily reveal the fact, that they are part of a project path.
|
||||||
# At least this test should find that the parent of 'home/username/branches'
|
# At least this test should find that the parent of 'home/username/branches'
|
||||||
# is a project (hack alert). Also goto parent in this case.
|
# is a project (hack alert). Also goto parent in this case.
|
||||||
root_dots = "../"
|
root_dots = Path("../")
|
||||||
elif is_project_dir("../.."):
|
elif is_project_dir("../.."):
|
||||||
# testing two levels is better than one.
|
# testing two levels is better than one.
|
||||||
# May happen in case of checkout_no_colon, or
|
# May happen in case of checkout_no_colon, or
|
||||||
# if project roots were previously inconsistent
|
# if project roots were previously inconsistent
|
||||||
root_dots = "../../"
|
root_dots = Path("../../")
|
||||||
if is_project_dir(root_dots):
|
if is_project_dir(root_dots):
|
||||||
oldproj = store_read_project(root_dots)
|
oldproj = store_read_project(root_dots)
|
||||||
if conf.config['checkout_no_colon']:
|
if conf.config['checkout_no_colon']:
|
||||||
n = len(oldproj.split(':'))
|
n = len(oldproj.split(':'))
|
||||||
else:
|
else:
|
||||||
n = 1
|
n = 1
|
||||||
if root_dots == '.':
|
root_dots = root_dots / ("../" * n)
|
||||||
root_dots = ''
|
|
||||||
root_dots = root_dots + "../" * n
|
|
||||||
|
|
||||||
if root_dots != '.':
|
if str(root_dots) != '.':
|
||||||
if conf.config['verbose']:
|
if conf.config['verbose']:
|
||||||
print("%s is project dir of %s. Root found at %s" %
|
print("%s is project dir of %s. Root found at %s" %
|
||||||
(prj_dir, oldproj, os.path.abspath(root_dots)))
|
(prj_dir, oldproj, os.path.abspath(root_dots)))
|
||||||
prj_dir = root_dots + prj_dir
|
prj_dir = root_dots / prj_dir
|
||||||
|
|
||||||
if not pathname:
|
if not pathname:
|
||||||
pathname = getTransActPath(os.path.join(prj_dir, package))
|
pathname = getTransActPath(os.path.join(prj_dir, package))
|
||||||
@ -7951,11 +7949,8 @@ def getTransActPath(pac_dir):
|
|||||||
Normally the "dir" attribute of a Package() object will be passed to
|
Normally the "dir" attribute of a Package() object will be passed to
|
||||||
this method.
|
this method.
|
||||||
"""
|
"""
|
||||||
if pac_dir != '.':
|
path = str(Path(pac_dir)) # accept str and Path as pac_dir
|
||||||
pathn = os.path.normpath(pac_dir)
|
return '' if path == '.' else path
|
||||||
else:
|
|
||||||
pathn = ''
|
|
||||||
return pathn
|
|
||||||
|
|
||||||
|
|
||||||
def get_commit_message_template(pac):
|
def get_commit_message_template(pac):
|
||||||
|
Loading…
Reference in New Issue
Block a user