Merge pull request #3636 from uggedal/pacman-remove-recursive

Pacman module: recursive remove support
This commit is contained in:
Michael DeHaan 2013-08-03 11:26:15 -07:00
commit 74cde56b60

View file

@ -45,6 +45,14 @@ options:
default: "no"
choices: [ "yes", "no" ]
recursive:
description:
- remove all not explicitly installed dependencies not required
by other packages of the package to remove
required: false
default: "no"
choices: [ "yes", "no" ]
author: Afterburn
notes: []
'''
@ -59,6 +67,9 @@ EXAMPLES = '''
# Remove packages foo and bar
- pacman: name=foo,bar state=absent
# Recursively remove package baz
- pacman: name=baz state=absent recursive=yes
# Update the package database (pacman -Syy) and install bar (bar will be the updated if a newer version exists)
- pacman: name=bar, state=installed, update_cache=yes
'''
@ -92,6 +103,10 @@ def update_package_db(module):
def remove_packages(module, packages):
if module.params["recursive"]:
args = "Rs"
else:
args = "R"
remove_c = 0
# Using a for loop incase of error, we can report the package that failed
@ -100,7 +115,7 @@ def remove_packages(module, packages):
if not query_package(module, package):
continue
rc = os.system("pacman -R %s --noconfirm > /dev/null" % (package))
rc = os.system("pacman -%s %s --noconfirm > /dev/null" % (args, package))
if rc != 0:
module.fail_json(msg="failed to remove %s" % (package))
@ -141,6 +156,7 @@ def main():
argument_spec = dict(
state = dict(default="installed", choices=["installed","absent"]),
update_cache = dict(default="no", aliases=["update-cache"], type='bool'),
recursive = dict(default="no", type='bool'),
name = dict(aliases=["pkg"], required=True)))