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

gem_module: Add bindir option

This option allows to specify directory to install executables, e.g.
`/home/user/bin` or `/home/user/.local/bin`. This comes especially handy
when used with user_install option as the default path of executables is
not in PATH.
This commit is contained in:
Stanislav German-Evtushenko 2021-06-19 02:09:20 +09:00
parent ee23c26150
commit 12339d2b00
2 changed files with 13 additions and 0 deletions

View file

@ -0,0 +1,2 @@
minor_changes:
- gem module - add ``bindir`` option. This option allows to specify directory to install executables, e.g. ``/home/user/bin`` or ``/home/user/.local/bin``.

View file

@ -62,6 +62,11 @@ options:
These gems will be independent from the global installed ones. These gems will be independent from the global installed ones.
Specifying this requires user_install to be false. Specifying this requires user_install to be false.
required: false required: false
bindir:
type: path
description:
- Install executables into a specific directory.
required: false
env_shebang: env_shebang:
description: description:
- Rewrite the shebang line on installed scripts to use /usr/bin/env. - Rewrite the shebang line on installed scripts to use /usr/bin/env.
@ -198,6 +203,9 @@ def uninstall(module):
if module.params['install_dir']: if module.params['install_dir']:
cmd.extend(['--install-dir', module.params['install_dir']]) cmd.extend(['--install-dir', module.params['install_dir']])
if module.params['bindir']:
cmd.extend(['--bindir', module.params['bindir']])
if module.params['version']: if module.params['version']:
cmd.extend(['--version', module.params['version']]) cmd.extend(['--version', module.params['version']])
else: else:
@ -235,6 +243,8 @@ def install(module):
cmd.append('--no-user-install') cmd.append('--no-user-install')
if module.params['install_dir']: if module.params['install_dir']:
cmd.extend(['--install-dir', module.params['install_dir']]) cmd.extend(['--install-dir', module.params['install_dir']])
if module.params['bindir']:
cmd.extend(['--bindir', module.params['bindir']])
if module.params['pre_release']: if module.params['pre_release']:
cmd.append('--pre') cmd.append('--pre')
if not module.params['include_doc']: if not module.params['include_doc']:
@ -265,6 +275,7 @@ def main():
state=dict(required=False, default='present', choices=['present', 'absent', 'latest'], type='str'), state=dict(required=False, default='present', choices=['present', 'absent', 'latest'], type='str'),
user_install=dict(required=False, default=True, type='bool'), user_install=dict(required=False, default=True, type='bool'),
install_dir=dict(required=False, type='path'), install_dir=dict(required=False, type='path'),
bindir=dict(required=False, type='path'),
pre_release=dict(required=False, default=False, type='bool'), pre_release=dict(required=False, default=False, type='bool'),
include_doc=dict(required=False, default=False, type='bool'), include_doc=dict(required=False, default=False, type='bool'),
env_shebang=dict(required=False, default=False, type='bool'), env_shebang=dict(required=False, default=False, type='bool'),