Freebsd pkgng autoremove support (#2324)
* Whitespace cleanup * Add autoremove capability to pkgng * Add "default" and "choices" documentnation items for autoremove
This commit is contained in:
parent
e6766078ea
commit
472bf733e0
1 changed files with 37 additions and 7 deletions
|
@ -75,6 +75,13 @@ options:
|
|||
- pkg will chroot in the specified environment
|
||||
- can not be used together with 'rootdir' option
|
||||
required: false
|
||||
autoremove:
|
||||
version_added: "2.2"
|
||||
description:
|
||||
- remove automatically installed packages which are no longer needed
|
||||
required: false
|
||||
choices: [ "yes", "no" ]
|
||||
default: no
|
||||
author: "bleader (@bleader)"
|
||||
notes:
|
||||
- When using pkgsite, be careful that already in cache packages won't be downloaded again.
|
||||
|
@ -271,6 +278,23 @@ def annotate_packages(module, pkgng_path, packages, annotation, dir_arg):
|
|||
return (True, "added %s annotations." % annotate_c)
|
||||
return (False, "changed no annotations")
|
||||
|
||||
def autoremove_packages(module, pkgng_path, dir_arg):
|
||||
rc, out, err = module.run_command("%s %s autoremove -n" % (pkgng_path, dir_arg))
|
||||
|
||||
autoremove_c = 0
|
||||
|
||||
match = re.search('^Deinstallation has been requested for the following ([0-9]+) packages', out, re.MULTILINE)
|
||||
if match:
|
||||
autoremove_c = int(match.group(1))
|
||||
|
||||
if autoremove_c == 0:
|
||||
return False, "no package(s) to autoremove"
|
||||
|
||||
if not module.check_mode:
|
||||
rc, out, err = module.run_command("%s %s autoremove -y" % (pkgng_path, dir_arg))
|
||||
|
||||
return True, "autoremoved %d package(s)" % (autoremove_c)
|
||||
|
||||
def main():
|
||||
module = AnsibleModule(
|
||||
argument_spec = dict(
|
||||
|
@ -280,7 +304,8 @@ def main():
|
|||
annotation = dict(default="", required=False),
|
||||
pkgsite = dict(default="", required=False),
|
||||
rootdir = dict(default="", required=False, type='path'),
|
||||
chroot = dict(default="", required=False, type='path')),
|
||||
chroot = dict(default="", required=False, type='path'),
|
||||
autoremove = dict(default=False, type='bool')),
|
||||
supports_check_mode = True,
|
||||
mutually_exclusive =[["rootdir", "chroot"]])
|
||||
|
||||
|
@ -314,6 +339,11 @@ def main():
|
|||
changed = changed or _changed
|
||||
msgs.append(_msg)
|
||||
|
||||
if p["autoremove"]:
|
||||
_changed, _msg = autoremove_packages(module, pkgng_path, dir_arg)
|
||||
changed = changed or _changed
|
||||
msgs.append(_msg)
|
||||
|
||||
if p["annotation"]:
|
||||
_changed, _msg = annotate_packages(module, pkgng_path, pkgs, p["annotation"], dir_arg)
|
||||
changed = changed or _changed
|
||||
|
|
Loading…
Reference in a new issue