From 8dff7f58d79441e2a05c1de528a62b9d4244bf59 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Adrian=20Schr=C3=B6ter?= Date: Wed, 11 Sep 2024 09:32:39 +0200 Subject: [PATCH] checkout: allow to checkout obs imported sources of scmsync sources This allows to skip the check of obs-scm-bridge and checks out what is stored in OBS src server. Note: This is not necessarly the same representation as in git (.obscpio instead of directories or sub modules). Also no modification can be committed. So this is only intended for people who understand the current internal implementation of the source storage. There is no guarantee that this won't change. Checkout of entire project git is not working with this switch, as the packagelist of osc is empty. It may also make no sense to do this as it will not perform for large projects. --- osc/commandline.py | 10 ++++++---- osc/core.py | 3 ++- 2 files changed, 8 insertions(+), 5 deletions(-) diff --git a/osc/commandline.py b/osc/commandline.py index 70034376e..74529ce68 100644 --- a/osc/commandline.py +++ b/osc/commandline.py @@ -5007,6 +5007,8 @@ def do_browse(self, subcmd, opts, *args): help='Use server side generated sources instead of local generation.') @cmdln.option('-l', '--limit-size', metavar='limit_size', help='Skip all files with a given size') + @cmdln.option('--native-obs-package', action='store_true', + help='Do not clone native scm repositories: Different representation and you will not be able to submit changes!') @cmdln.alias('co') def do_checkout(self, subcmd, opts, *args): """ @@ -5103,7 +5105,7 @@ def do_checkout(self, subcmd, opts, *args): prj_dir=project_dir, service_files=opts.source_service_files, server_service_files=opts.server_side_source_service_files, progress_obj=self.download_progress, size_limit=opts.limit_size, - meta=opts.meta, outdir=opts.output_dir) + meta=opts.meta, outdir=opts.output_dir, native_obs_package=opts.native_obs_package) if os.isatty(sys.stdout.fileno()): print_request_list(apiurl, project, package) @@ -5118,7 +5120,7 @@ def do_checkout(self, subcmd, opts, *args): show_project_meta(apiurl, project) scm_url = show_scmsync(apiurl, project) - if scm_url is not None: + if scm_url is not None and opts.native_obs_package is False: 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)!') os.putenv("OSC_VERSION", get_osc_version()) @@ -5156,7 +5158,7 @@ def do_checkout(self, subcmd, opts, *args): prj_dir=prj_dir, service_files=opts.source_service_files, server_service_files=opts.server_side_source_service_files, progress_obj=self.download_progress, size_limit=opts.limit_size, - meta=opts.meta) + meta=opts.meta, native_obs_package=opts.native_obs_package) except oscerr.LinkExpandError as e: print('Link cannot be expanded:\n', e, file=sys.stderr) print('Use "osc repairlink" for fixing merge conflicts:\n', file=sys.stderr) @@ -5165,7 +5167,7 @@ def do_checkout(self, subcmd, opts, *args): prj_dir=prj_dir, service_files=opts.source_service_files, server_service_files=opts.server_side_source_service_files, progress_obj=self.download_progress, size_limit=opts.limit_size, - meta=opts.meta) + meta=opts.meta, native_obs_package=opts.native_obs_package) if os.isatty(sys.stdout.fileno()): print_request_list(apiurl, project) diff --git a/osc/core.py b/osc/core.py index 32a2c8df9..4eb236d65 100644 --- a/osc/core.py +++ b/osc/core.py @@ -3091,6 +3091,7 @@ def checkout_package( prj_dir: Path=None, server_service_files=None, service_files=None, + native_obs_package=False, progress_obj=None, size_limit=None, meta=False, @@ -3151,7 +3152,7 @@ def checkout_package( meta_data = b''.join(show_package_meta(apiurl, project, package)) root = ET.fromstring(meta_data) scmsync_element = root.find("scmsync") - if scmsync_element is not None and scmsync_element.text is not None: + if native_obs_package is False and scmsync_element is not None and scmsync_element.text is not None: 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)!') scm_url = scmsync_element.text