Merge pull request #49 from Tatsh-ansible/add-portage-binhost
Add support for emerge's --getbinpkg and --usepkgoonly
This commit is contained in:
commit
77485f6c6a
1 changed files with 41 additions and 2 deletions
|
@ -132,8 +132,22 @@ options:
|
||||||
default: null
|
default: null
|
||||||
choices: [ "yes", "web" ]
|
choices: [ "yes", "web" ]
|
||||||
|
|
||||||
|
getbinpkg:
|
||||||
|
description:
|
||||||
|
- Prefer packages specified at PORTAGE_BINHOST in make.conf
|
||||||
|
required: false
|
||||||
|
default: null
|
||||||
|
choices: [ "yes" ]
|
||||||
|
|
||||||
|
usepkgonly:
|
||||||
|
description:
|
||||||
|
- Merge only binaries (no compiling). This sets getbinpkg=yes.
|
||||||
|
required: false
|
||||||
|
deafult: null
|
||||||
|
choices: [ "yes" ]
|
||||||
|
|
||||||
requirements: [ gentoolkit ]
|
requirements: [ gentoolkit ]
|
||||||
author: Yap Sok Ann
|
author: Yap Sok Ann, Andrew Udvare
|
||||||
notes: []
|
notes: []
|
||||||
'''
|
'''
|
||||||
|
|
||||||
|
@ -147,6 +161,12 @@ EXAMPLES = '''
|
||||||
# Update package foo to the "best" version
|
# Update package foo to the "best" version
|
||||||
- portage: package=foo update=yes
|
- portage: package=foo update=yes
|
||||||
|
|
||||||
|
# Install package foo using PORTAGE_BINHOST setup
|
||||||
|
- portage: package=foo getbinpkg=yes
|
||||||
|
|
||||||
|
# Re-install world from binary packages only and do not allow any compiling
|
||||||
|
- portage: package=@world usepkgonly=yes
|
||||||
|
|
||||||
# Sync repositories and update world
|
# Sync repositories and update world
|
||||||
- portage: package=@world update=yes deep=yes sync=yes
|
- portage: package=@world update=yes deep=yes sync=yes
|
||||||
|
|
||||||
|
@ -160,6 +180,7 @@ EXAMPLES = '''
|
||||||
|
|
||||||
import os
|
import os
|
||||||
import pipes
|
import pipes
|
||||||
|
import re
|
||||||
|
|
||||||
|
|
||||||
def query_package(module, package, action):
|
def query_package(module, package, action):
|
||||||
|
@ -244,11 +265,17 @@ def emerge_packages(module, packages):
|
||||||
'onlydeps': '--onlydeps',
|
'onlydeps': '--onlydeps',
|
||||||
'quiet': '--quiet',
|
'quiet': '--quiet',
|
||||||
'verbose': '--verbose',
|
'verbose': '--verbose',
|
||||||
|
'getbinpkg': '--getbinpkg',
|
||||||
|
'usepkgonly': '--usepkgonly',
|
||||||
}
|
}
|
||||||
for flag, arg in emerge_flags.iteritems():
|
for flag, arg in emerge_flags.iteritems():
|
||||||
if p[flag]:
|
if p[flag]:
|
||||||
args.append(arg)
|
args.append(arg)
|
||||||
|
|
||||||
|
# usepkgonly implies getbinpkg
|
||||||
|
if p['usepkgonly'] and not p['getbinpkg']:
|
||||||
|
args.append('--getbinpkg')
|
||||||
|
|
||||||
cmd, (rc, out, err) = run_emerge(module, packages, *args)
|
cmd, (rc, out, err) = run_emerge(module, packages, *args)
|
||||||
if rc != 0:
|
if rc != 0:
|
||||||
module.fail_json(
|
module.fail_json(
|
||||||
|
@ -256,9 +283,19 @@ def emerge_packages(module, packages):
|
||||||
msg='Packages not installed.',
|
msg='Packages not installed.',
|
||||||
)
|
)
|
||||||
|
|
||||||
|
# Check for SSH error with PORTAGE_BINHOST, since rc is still 0 despite
|
||||||
|
# this error
|
||||||
|
if (p['usepkgonly'] or p['getbinpkg']) \
|
||||||
|
and 'Permission denied (publickey).' in err:
|
||||||
|
module.fail_json(
|
||||||
|
cmd=cmd, rc=rc, stdout=out, stderr=err,
|
||||||
|
msg='Please check your PORTAGE_BINHOST configuration in make.conf '
|
||||||
|
'and your SSH authorized_keys file',
|
||||||
|
)
|
||||||
|
|
||||||
changed = True
|
changed = True
|
||||||
for line in out.splitlines():
|
for line in out.splitlines():
|
||||||
if line.startswith('>>> Emerging (1 of'):
|
if re.match(r'(?:>+) Emerging (?:binary )?\(1 of', line):
|
||||||
break
|
break
|
||||||
else:
|
else:
|
||||||
changed = False
|
changed = False
|
||||||
|
@ -367,6 +404,8 @@ def main():
|
||||||
quiet=dict(default=None, choices=['yes']),
|
quiet=dict(default=None, choices=['yes']),
|
||||||
verbose=dict(default=None, choices=['yes']),
|
verbose=dict(default=None, choices=['yes']),
|
||||||
sync=dict(default=None, choices=['yes', 'web']),
|
sync=dict(default=None, choices=['yes', 'web']),
|
||||||
|
getbinpkg=dict(default=None, choices=['yes']),
|
||||||
|
usepkgonly=dict(default=None, choices=['yes']),
|
||||||
),
|
),
|
||||||
required_one_of=[['package', 'sync', 'depclean']],
|
required_one_of=[['package', 'sync', 'depclean']],
|
||||||
mutually_exclusive=[['nodeps', 'onlydeps'], ['quiet', 'verbose']],
|
mutually_exclusive=[['nodeps', 'onlydeps'], ['quiet', 'verbose']],
|
||||||
|
|
Loading…
Reference in a new issue