1
0
Fork 0
mirror of https://github.com/ansible-collections/community.general.git synced 2024-09-14 20:13:21 +02:00

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" default: "no"
choices: [ "yes", "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 author: Afterburn
notes: [] notes: []
''' '''
@ -59,6 +67,9 @@ EXAMPLES = '''
# Remove packages foo and bar # Remove packages foo and bar
- pacman: name=foo,bar state=absent - 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) # 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 - pacman: name=bar, state=installed, update_cache=yes
''' '''
@ -92,6 +103,10 @@ def update_package_db(module):
def remove_packages(module, packages): def remove_packages(module, packages):
if module.params["recursive"]:
args = "Rs"
else:
args = "R"
remove_c = 0 remove_c = 0
# Using a for loop incase of error, we can report the package that failed # 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): if not query_package(module, package):
continue 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: if rc != 0:
module.fail_json(msg="failed to remove %s" % (package)) module.fail_json(msg="failed to remove %s" % (package))
@ -141,6 +156,7 @@ def main():
argument_spec = dict( argument_spec = dict(
state = dict(default="installed", choices=["installed","absent"]), state = dict(default="installed", choices=["installed","absent"]),
update_cache = dict(default="no", aliases=["update-cache"], type='bool'), update_cache = dict(default="no", aliases=["update-cache"], type='bool'),
recursive = dict(default="no", type='bool'),
name = dict(aliases=["pkg"], required=True))) name = dict(aliases=["pkg"], required=True)))