mirror of
https://github.com/openSUSE/osc.git
synced 2025-01-26 14:46:14 +01:00
Merge pull request #1151 from adrianschroeter/cpc
add create-pbuild-config(cpc) command
This commit is contained in:
commit
db225d44d8
4
NEWS
4
NEWS
@ -1,3 +1,7 @@
|
||||
1.0.0b3
|
||||
- add create-pbuild-config(cpc) command which allows to create a working
|
||||
config for pbuild tool based on OBS server side data
|
||||
|
||||
1.0.0b2
|
||||
- Support ssh-agent forwarding
|
||||
- ssh auth: Avoid password prompt when using TransientCredentialsManager
|
||||
|
17
osc/cmdln.py
17
osc/cmdln.py
@ -45,6 +45,22 @@ def alias(*aliases):
|
||||
return decorate
|
||||
|
||||
|
||||
def name(name):
|
||||
"""
|
||||
Decorator to explicitly name a Cmdln subcommand.
|
||||
|
||||
Example:
|
||||
class MyShell(cmdln.Cmdln):
|
||||
@cmdln.name("cmd-with-dashes")
|
||||
def do_cmd_with_dashes(self, subcmd, opts):
|
||||
#...
|
||||
"""
|
||||
def decorate(f):
|
||||
f.name = name
|
||||
return f
|
||||
return decorate
|
||||
|
||||
|
||||
def hide():
|
||||
"""
|
||||
For obsolete calls, hide them in help listings.
|
||||
@ -134,6 +150,7 @@ class Cmdln:
|
||||
cmd_func = getattr(self, attr)
|
||||
|
||||
# extract data from the function
|
||||
cmd_name = getattr(cmd_func, "name", cmd_name)
|
||||
options = getattr(cmd_func, "options", [])
|
||||
aliases = getattr(cmd_func, "aliases", [])
|
||||
hidden = getattr(cmd_func, "hidden", False)
|
||||
|
@ -8345,6 +8345,35 @@ Please submit there instead, or use --nodevelproject to force direct submission.
|
||||
if len(user) == 3:
|
||||
print("%s: \"%s\" <%s>" % (user[0], user[1], user[2]))
|
||||
|
||||
@cmdln.name("create-pbuild-config")
|
||||
@cmdln.alias('cpc')
|
||||
@cmdln.option("repository")
|
||||
@cmdln.option("arch")
|
||||
def do_create_pbuild_config(self, subcmd, opts):
|
||||
"""
|
||||
This command is creating the necessary files to build using pbuild tool.
|
||||
It basically creates _config and _pbuild file in the project directory.
|
||||
Changes from there can not get submitted back, except the project is managed
|
||||
in git.
|
||||
|
||||
Examples:
|
||||
osc cpc REPOSITORY ARCH
|
||||
"""
|
||||
|
||||
apiurl = self.get_api_url()
|
||||
project = None
|
||||
project_dir = os.curdir
|
||||
if is_project_dir(project_dir):
|
||||
project = store_read_project(project_dir)
|
||||
elif is_package_dir(project_dir):
|
||||
project_dir += '/..'
|
||||
project = store_read_project(project_dir)
|
||||
else:
|
||||
raise oscerr.WrongArgs('Creating pbuild only works in a checked out project or package')
|
||||
|
||||
create_pbuild_config(apiurl, project, opts.repository, opts.arch, project_dir)
|
||||
|
||||
|
||||
@cmdln.option('-r', '--revision', metavar='rev',
|
||||
help='print out the specified revision')
|
||||
@cmdln.option('-e', '--expand', action='store_true',
|
||||
|
33
osc/core.py
33
osc/core.py
@ -6379,6 +6379,39 @@ def get_buildconfig(apiurl, prj, repository, path=None):
|
||||
return f.read()
|
||||
|
||||
|
||||
def create_pbuild_config(apiurl, project, repository, arch, project_dir):
|
||||
"""
|
||||
This is always replacing a possible exiting config for now
|
||||
we could extend the _pbuild file easily, but what should we do with multiple instances of the _config?
|
||||
"""
|
||||
# get expanded buildconfig for given project and repository
|
||||
bc = get_buildconfig(apiurl, project, repository)
|
||||
if not bc:
|
||||
msg = "Failed to get build config for project '{project}', repository '{repository}'"
|
||||
raise oscerr.NotFoundAPIError(msg)
|
||||
|
||||
with open(os.path.join(project_dir, '_config'), "w") as f:
|
||||
f.write(decode_it(bc))
|
||||
|
||||
# create the _pbuild file based on expanded repository path informations
|
||||
pb = ET.fromstring('<pbuild></pbuild>')
|
||||
tree = ET.ElementTree(pb)
|
||||
preset = ET.SubElement(pb, 'preset', name=repository, default="") # default should be empty, but ET crashes
|
||||
bi_text = decode_it(get_buildinfo(apiurl, project, '_repository', repository, arch, specfile="Name: dummy"))
|
||||
root = ET.fromstring(bi_text)
|
||||
|
||||
# cross compile setups are not yet supported
|
||||
# for path in root.findall('hostsystem'):
|
||||
# ET.SubElement(preset, 'hostrepo').text = path.get('url')
|
||||
|
||||
for path in root.findall('path'):
|
||||
ET.SubElement(preset, 'repo').text = path.get('url')
|
||||
|
||||
ET.SubElement(preset, 'arch').text = arch
|
||||
xmlindent(tree)
|
||||
tree.write(os.path.join(project_dir,'_pbuild'), encoding="utf-8", xml_declaration=True)
|
||||
|
||||
|
||||
def get_worker_info(apiurl, worker):
|
||||
u = makeurl(apiurl, ['worker', worker])
|
||||
f = http_GET(u)
|
||||
|
@ -50,6 +50,15 @@ class APIError(OscBaseError):
|
||||
super().__init__()
|
||||
self.msg = msg
|
||||
|
||||
def __str__(self):
|
||||
return f"{self.__class__.__name__}: {self.msg}"
|
||||
|
||||
|
||||
class NotFoundAPIError(APIError):
|
||||
"""
|
||||
Requested data was not found.
|
||||
"""
|
||||
|
||||
|
||||
class NoConfigfile(OscBaseError):
|
||||
"""Exception raised when osc's configfile cannot be found"""
|
||||
|
Loading…
Reference in New Issue
Block a user